/* Minification failed. Returning unminified contents.
(4883,5,4885,6): run-time error JS1314: Implicit property name must be identifier: ShowStandardAjaxErrorAlert(jqXhr, _, errorThrown) {
        alert(Donorfy.GetStandardAjaxErrorMessage(jqXhr, errorThrown));
    }
 */
(function(e){var t={set:{colors:1,values:1,backgroundColor:1,scaleColors:1,normalizeFunction:1,focus:1},get:{selectedRegions:1,selectedMarkers:1,mapObject:1,regionName:1}};e.fn.vectorMap=function(e){var n,r,i,n=this.children(".jvectormap-container").data("mapObject");if(e==="addMap"){jvm.WorldMap.maps[arguments[1]]=arguments[2]}else{if(!(e!=="set"&&e!=="get"||!t[e][arguments[1]])){return r=arguments[1].charAt(0).toUpperCase()+arguments[1].substr(1),n[e+r].apply(n,Array.prototype.slice.call(arguments,2))}e=e||{},e.container=this,n=new jvm.WorldMap(e)}return this}})(jQuery),function(e){function r(t){var n=t||window.event,r=[].slice.call(arguments,1),i=0,s=!0,o=0,u=0;return t=e.event.fix(n),t.type="mousewheel",n.wheelDelta&&(i=n.wheelDelta/120),n.detail&&(i=-n.detail/3),u=i,n.axis!==undefined&&n.axis===n.HORIZONTAL_AXIS&&(u=0,o=-1*i),n.wheelDeltaY!==undefined&&(u=n.wheelDeltaY/120),n.wheelDeltaX!==undefined&&(o=-1*n.wheelDeltaX/120),r.unshift(t,i,o,u),(e.event.dispatch||e.event.handle).apply(this,r)}var t=["DOMMouseScroll","mousewheel"];if(e.event.fixHooks){for(var n=t.length;n;){e.event.fixHooks[t[--n]]=e.event.mouseHooks}}e.event.special.mousewheel={setup:function(){if(this.addEventListener){for(var e=t.length;e;){this.addEventListener(t[--e],r,!1)}}else{this.onmousewheel=r}},teardown:function(){if(this.removeEventListener){for(var e=t.length;e;){this.removeEventListener(t[--e],r,!1)}}else{this.onmousewheel=null}}},e.fn.extend({mousewheel:function(e){return e?this.bind("mousewheel",e):this.trigger("mousewheel")},unmousewheel:function(e){return this.unbind("mousewheel",e)}})}(jQuery);var jvm={inherits:function(e,t){function n(){}n.prototype=t.prototype,e.prototype=new n,e.prototype.constructor=e,e.parentClass=t},mixin:function(e,t){var n;for(n in t.prototype){t.prototype.hasOwnProperty(n)&&(e.prototype[n]=t.prototype[n])}},min:function(e){var t=Number.MAX_VALUE,n;if(e instanceof Array){for(n=0;n<e.length;n++){e[n]<t&&(t=e[n])}}else{for(n in e){e[n]<t&&(t=e[n])}}return t},max:function(e){var t=Number.MIN_VALUE,n;if(e instanceof Array){for(n=0;n<e.length;n++){e[n]>t&&(t=e[n])}}else{for(n in e){e[n]>t&&(t=e[n])}}return t},keys:function(e){var t=[],n;for(n in e){t.push(n)}return t},values:function(e){var t=[],n,r;for(r=0;r<arguments.length;r++){e=arguments[r];for(n in e){t.push(e[n])}}return t}};jvm.$=jQuery,jvm.AbstractElement=function(e,t){this.node=this.createElement(e),this.name=e,this.properties={},t&&this.set(t)},jvm.AbstractElement.prototype.set=function(e,t){var n;if(typeof e=="object"){for(n in e){this.properties[n]=e[n],this.applyAttr(n,e[n])}}else{this.properties[e]=t,this.applyAttr(e,t)}},jvm.AbstractElement.prototype.get=function(e){return this.properties[e]},jvm.AbstractElement.prototype.applyAttr=function(e,t){this.node.setAttribute(e,t)},jvm.AbstractElement.prototype.remove=function(){jvm.$(this.node).remove()},jvm.AbstractCanvasElement=function(e,t,n){this.container=e,this.setSize(t,n),this.rootElement=new jvm[this.classPrefix+"GroupElement"],this.node.appendChild(this.rootElement.node),this.container.appendChild(this.node)},jvm.AbstractCanvasElement.prototype.add=function(e,t){t=t||this.rootElement,t.add(e),e.canvas=this},jvm.AbstractCanvasElement.prototype.addPath=function(e,t,n){var r=new jvm[this.classPrefix+"PathElement"](e,t);return this.add(r,n),r},jvm.AbstractCanvasElement.prototype.addCircle=function(e,t,n){var r=new jvm[this.classPrefix+"CircleElement"](e,t);return this.add(r,n),r},jvm.AbstractCanvasElement.prototype.addGroup=function(e){var t=new jvm[this.classPrefix+"GroupElement"];return e?e.node.appendChild(t.node):this.node.appendChild(t.node),t.canvas=this,t},jvm.AbstractShapeElement=function(e,t,n){this.style=n||{},this.style.current={},this.isHovered=!1,this.isSelected=!1,this.updateStyle()},jvm.AbstractShapeElement.prototype.setHovered=function(e){this.isHovered!==e&&(this.isHovered=e,this.updateStyle())},jvm.AbstractShapeElement.prototype.setSelected=function(e){this.isSelected!==e&&(this.isSelected=e,this.updateStyle(),jvm.$(this.node).trigger("selected",[e]))},jvm.AbstractShapeElement.prototype.setStyle=function(e,t){var n={};typeof e=="object"?n=e:n[e]=t,jvm.$.extend(this.style.current,n),this.updateStyle()},jvm.AbstractShapeElement.prototype.updateStyle=function(){var e={};jvm.AbstractShapeElement.mergeStyles(e,this.style.initial),jvm.AbstractShapeElement.mergeStyles(e,this.style.current),this.isHovered&&jvm.AbstractShapeElement.mergeStyles(e,this.style.hover),this.isSelected&&(jvm.AbstractShapeElement.mergeStyles(e,this.style.selected),this.isHovered&&jvm.AbstractShapeElement.mergeStyles(e,this.style.selectedHover)),this.set(e)},jvm.AbstractShapeElement.mergeStyles=function(e,t){var n;t=t||{};for(n in t){t[n]===null?delete e[n]:e[n]=t[n]}},jvm.SVGElement=function(e,t){jvm.SVGElement.parentClass.apply(this,arguments)},jvm.inherits(jvm.SVGElement,jvm.AbstractElement),jvm.SVGElement.svgns="http://www.w3.org/2000/svg",jvm.SVGElement.prototype.createElement=function(e){return document.createElementNS(jvm.SVGElement.svgns,e)},jvm.SVGElement.prototype.addClass=function(e){this.node.setAttribute("class",e)},jvm.SVGElement.prototype.getElementCtr=function(e){return jvm["SVG"+e]},jvm.SVGElement.prototype.getBBox=function(){return this.node.getBBox()},jvm.SVGGroupElement=function(){jvm.SVGGroupElement.parentClass.call(this,"g")},jvm.inherits(jvm.SVGGroupElement,jvm.SVGElement),jvm.SVGGroupElement.prototype.add=function(e){this.node.appendChild(e.node)},jvm.SVGCanvasElement=function(e,t,n){this.classPrefix="SVG",jvm.SVGCanvasElement.parentClass.call(this,"svg"),jvm.AbstractCanvasElement.apply(this,arguments)},jvm.inherits(jvm.SVGCanvasElement,jvm.SVGElement),jvm.mixin(jvm.SVGCanvasElement,jvm.AbstractCanvasElement),jvm.SVGCanvasElement.prototype.setSize=function(e,t){this.width=e,this.height=t,this.node.setAttribute("width",e),this.node.setAttribute("height",t)},jvm.SVGCanvasElement.prototype.applyTransformParams=function(e,t,n){this.scale=e,this.transX=t,this.transY=n,this.rootElement.node.setAttribute("transform","scale("+e+") translate("+t+", "+n+")")},jvm.SVGShapeElement=function(e,t,n){jvm.SVGShapeElement.parentClass.call(this,e,t),jvm.AbstractShapeElement.apply(this,arguments)},jvm.inherits(jvm.SVGShapeElement,jvm.SVGElement),jvm.mixin(jvm.SVGShapeElement,jvm.AbstractShapeElement),jvm.SVGPathElement=function(e,t){jvm.SVGPathElement.parentClass.call(this,"path",e,t),this.node.setAttribute("fill-rule","evenodd")},jvm.inherits(jvm.SVGPathElement,jvm.SVGShapeElement),jvm.SVGCircleElement=function(e,t){jvm.SVGCircleElement.parentClass.call(this,"circle",e,t)},jvm.inherits(jvm.SVGCircleElement,jvm.SVGShapeElement),jvm.VMLElement=function(e,t){jvm.VMLElement.VMLInitialized||jvm.VMLElement.initializeVML(),jvm.VMLElement.parentClass.apply(this,arguments)},jvm.inherits(jvm.VMLElement,jvm.AbstractElement),jvm.VMLElement.VMLInitialized=!1,jvm.VMLElement.initializeVML=function(){try{document.namespaces.rvml||document.namespaces.add("rvml","urn:schemas-microsoft-com:vml"),jvm.VMLElement.prototype.createElement=function(e){return document.createElement("<rvml:"+e+' class="rvml">')}}catch(e){jvm.VMLElement.prototype.createElement=function(e){return document.createElement("<"+e+' xmlns="urn:schemas-microsoft.com:vml" class="rvml">')}}document.createStyleSheet().addRule(".rvml","behavior:url(#default#VML)"),jvm.VMLElement.VMLInitialized=!0},jvm.VMLElement.prototype.getElementCtr=function(e){return jvm["VML"+e]},jvm.VMLElement.prototype.addClass=function(e){jvm.$(this.node).addClass(e)},jvm.VMLElement.prototype.applyAttr=function(e,t){this.node[e]=t},jvm.VMLElement.prototype.getBBox=function(){var e=jvm.$(this.node);return{x:e.position().left/this.canvas.scale,y:e.position().top/this.canvas.scale,width:e.width()/this.canvas.scale,height:e.height()/this.canvas.scale}},jvm.VMLGroupElement=function(){jvm.VMLGroupElement.parentClass.call(this,"group"),this.node.style.left="0px",this.node.style.top="0px",this.node.coordorigin="0 0"},jvm.inherits(jvm.VMLGroupElement,jvm.VMLElement),jvm.VMLGroupElement.prototype.add=function(e){this.node.appendChild(e.node)},jvm.VMLCanvasElement=function(e,t,n){this.classPrefix="VML",jvm.VMLCanvasElement.parentClass.call(this,"group"),jvm.AbstractCanvasElement.apply(this,arguments),this.node.style.position="absolute"},jvm.inherits(jvm.VMLCanvasElement,jvm.VMLElement),jvm.mixin(jvm.VMLCanvasElement,jvm.AbstractCanvasElement),jvm.VMLCanvasElement.prototype.setSize=function(e,t){var n,r,i,s;this.width=e,this.height=t,this.node.style.width=e+"px",this.node.style.height=t+"px",this.node.coordsize=e+" "+t,this.node.coordorigin="0 0";if(this.rootElement){n=this.rootElement.node.getElementsByTagName("shape");for(i=0,s=n.length;i<s;i++){n[i].coordsize=e+" "+t,n[i].style.width=e+"px",n[i].style.height=t+"px"}r=this.node.getElementsByTagName("group");for(i=0,s=r.length;i<s;i++){r[i].coordsize=e+" "+t,r[i].style.width=e+"px",r[i].style.height=t+"px"}}},jvm.VMLCanvasElement.prototype.applyTransformParams=function(e,t,n){this.scale=e,this.transX=t,this.transY=n,this.rootElement.node.coordorigin=this.width-t-this.width/100+","+(this.height-n-this.height/100),this.rootElement.node.coordsize=this.width/e+","+this.height/e},jvm.VMLShapeElement=function(e,t){jvm.VMLShapeElement.parentClass.call(this,e,t),this.fillElement=new jvm.VMLElement("fill"),this.strokeElement=new jvm.VMLElement("stroke"),this.node.appendChild(this.fillElement.node),this.node.appendChild(this.strokeElement.node),this.node.stroked=!1,jvm.AbstractShapeElement.apply(this,arguments)},jvm.inherits(jvm.VMLShapeElement,jvm.VMLElement),jvm.mixin(jvm.VMLShapeElement,jvm.AbstractShapeElement),jvm.VMLShapeElement.prototype.applyAttr=function(e,t){switch(e){case"fill":this.node.fillcolor=t;break;case"fill-opacity":this.fillElement.node.opacity=Math.round(t*100)+"%";break;case"stroke":t==="none"?this.node.stroked=!1:this.node.stroked=!0,this.node.strokecolor=t;break;case"stroke-opacity":this.strokeElement.node.opacity=Math.round(t*100)+"%";break;case"stroke-width":parseInt(t,10)===0?this.node.stroked=!1:this.node.stroked=!0,this.node.strokeweight=t;break;case"d":this.node.path=jvm.VMLPathElement.pathSvgToVml(t);break;default:jvm.VMLShapeElement.parentClass.prototype.applyAttr.apply(this,arguments)}},jvm.VMLPathElement=function(e,t){var n=new jvm.VMLElement("skew");jvm.VMLPathElement.parentClass.call(this,"shape",e,t),this.node.coordorigin="0 0",n.node.on=!0,n.node.matrix="0.01,0,0,0.01,0,0",n.node.offset="0,0",this.node.appendChild(n.node)},jvm.inherits(jvm.VMLPathElement,jvm.VMLShapeElement),jvm.VMLPathElement.prototype.applyAttr=function(e,t){e==="d"?this.node.path=jvm.VMLPathElement.pathSvgToVml(t):jvm.VMLShapeElement.prototype.applyAttr.call(this,e,t)},jvm.VMLPathElement.pathSvgToVml=function(e){var t="",n=0,r=0,i,s;return e=e.replace(/(-?\d+)e(-?\d+)/g,"0"),e.replace(/([MmLlHhVvCcSs])\s*((?:-?\d*(?:\.\d+)?\s*,?\s*)+)/g,function(e,t,o,u){o=o.replace(/(\d)-/g,"$1,-").replace(/^\s+/g,"").replace(/\s+$/g,"").replace(/\s+/g,",").split(","),o[0]||o.shift();for(var a=0,f=o.length;a<f;a++){o[a]=Math.round(100*o[a])}switch(t){case"m":return n+=o[0],r+=o[1],"t"+o.join(",");case"M":return n=o[0],r=o[1],"m"+o.join(",");case"l":return n+=o[0],r+=o[1],"r"+o.join(",");case"L":return n=o[0],r=o[1],"l"+o.join(",");case"h":return n+=o[0],"r"+o[0]+",0";case"H":return n=o[0],"l"+n+","+r;case"v":return r+=o[0],"r0,"+o[0];case"V":return r=o[0],"l"+n+","+r;case"c":return i=n+o[o.length-4],s=r+o[o.length-3],n+=o[o.length-2],r+=o[o.length-1],"v"+o.join(",");case"C":return i=o[o.length-4],s=o[o.length-3],n=o[o.length-2],r=o[o.length-1],"c"+o.join(",");case"s":return o.unshift(r-s),o.unshift(n-i),i=n+o[o.length-4],s=r+o[o.length-3],n+=o[o.length-2],r+=o[o.length-1],"v"+o.join(",");case"S":return o.unshift(r+r-s),o.unshift(n+n-i),i=o[o.length-4],s=o[o.length-3],n=o[o.length-2],r=o[o.length-1],"c"+o.join(",")}return""}).replace(/z/g,"e")},jvm.VMLCircleElement=function(e,t){jvm.VMLCircleElement.parentClass.call(this,"oval",e,t)},jvm.inherits(jvm.VMLCircleElement,jvm.VMLShapeElement),jvm.VMLCircleElement.prototype.applyAttr=function(e,t){switch(e){case"r":this.node.style.width=t*2+"px",this.node.style.height=t*2+"px",this.applyAttr("cx",this.get("cx")||0),this.applyAttr("cy",this.get("cy")||0);break;case"cx":if(!t){return}this.node.style.left=t-(this.get("r")||0)+"px";break;case"cy":if(!t){return}this.node.style.top=t-(this.get("r")||0)+"px";break;default:jvm.VMLCircleElement.parentClass.prototype.applyAttr.call(this,e,t)}},jvm.VectorCanvas=function(e,t,n){return this.mode=window.SVGAngle?"svg":"vml",this.mode=="svg"?this.impl=new jvm.SVGCanvasElement(e,t,n):this.impl=new jvm.VMLCanvasElement(e,t,n),this.impl},jvm.SimpleScale=function(e){this.scale=e},jvm.SimpleScale.prototype.getValue=function(e){return e},jvm.OrdinalScale=function(e){this.scale=e},jvm.OrdinalScale.prototype.getValue=function(e){return this.scale[e]},jvm.NumericScale=function(e,t,n,r){this.scale=[],t=t||"linear",e&&this.setScale(e),t&&this.setNormalizeFunction(t),n&&this.setMin(n),r&&this.setMax(r)},jvm.NumericScale.prototype={setMin:function(e){this.clearMinValue=e,typeof this.normalize=="function"?this.minValue=this.normalize(e):this.minValue=e},setMax:function(e){this.clearMaxValue=e,typeof this.normalize=="function"?this.maxValue=this.normalize(e):this.maxValue=e},setScale:function(e){var t;for(t=0;t<e.length;t++){this.scale[t]=[e[t]]}},setNormalizeFunction:function(e){e==="polynomial"?this.normalize=function(e){return Math.pow(e,0.2)}:e==="linear"?delete this.normalize:this.normalize=e,this.setMin(this.clearMinValue),this.setMax(this.clearMaxValue)},getValue:function(e){var t=[],n=0,r,i=0,s;typeof this.normalize=="function"&&(e=this.normalize(e));for(i=0;i<this.scale.length-1;i++){r=this.vectorLength(this.vectorSubtract(this.scale[i+1],this.scale[i])),t.push(r),n+=r}s=(this.maxValue-this.minValue)/n;for(i=0;i<t.length;i++){t[i]*=s}i=0,e-=this.minValue;while(e-t[i]>=0){e-=t[i],i++}return i==this.scale.length-1?e=this.vectorToNum(this.scale[i]):e=this.vectorToNum(this.vectorAdd(this.scale[i],this.vectorMult(this.vectorSubtract(this.scale[i+1],this.scale[i]),e/t[i]))),e},vectorToNum:function(e){var t=0,n;for(n=0;n<e.length;n++){t+=Math.round(e[n])*Math.pow(256,e.length-n-1)}return t},vectorSubtract:function(e,t){var n=[],r;for(r=0;r<e.length;r++){n[r]=e[r]-t[r]}return n},vectorAdd:function(e,t){var n=[],r;for(r=0;r<e.length;r++){n[r]=e[r]+t[r]}return n},vectorMult:function(e,t){var n=[],r;for(r=0;r<e.length;r++){n[r]=e[r]*t}return n},vectorLength:function(e){var t=0,n;for(n=0;n<e.length;n++){t+=e[n]*e[n]}return Math.sqrt(t)}},jvm.ColorScale=function(e,t,n,r){jvm.ColorScale.parentClass.apply(this,arguments)},jvm.inherits(jvm.ColorScale,jvm.NumericScale),jvm.ColorScale.prototype.setScale=function(e){var t;for(t=0;t<e.length;t++){this.scale[t]=jvm.ColorScale.rgbToArray(e[t])}},jvm.ColorScale.prototype.getValue=function(e){return jvm.ColorScale.numToRgb(jvm.ColorScale.parentClass.prototype.getValue.call(this,e))},jvm.ColorScale.arrayToRgb=function(e){var t="#",n,r;for(r=0;r<e.length;r++){n=e[r].toString(16),t+=n.length==1?"0"+n:n}return t},jvm.ColorScale.numToRgb=function(e){e=e.toString(16);while(e.length<6){e="0"+e}return"#"+e},jvm.ColorScale.rgbToArray=function(e){return e=e.substr(1),[parseInt(e.substr(0,2),16),parseInt(e.substr(2,2),16),parseInt(e.substr(4,2),16)]},jvm.DataSeries=function(e,t){var n;e=e||{},e.attribute=e.attribute||"fill",this.elements=t,this.params=e,e.attributes&&this.setAttributes(e.attributes),jvm.$.isArray(e.scale)?(n=e.attribute==="fill"||e.attribute==="stroke"?jvm.ColorScale:jvm.NumericScale,this.scale=new n(e.scale,e.normalizeFunction,e.min,e.max)):e.scale?this.scale=new jvm.OrdinalScale(e.scale):this.scale=new jvm.SimpleScale(e.scale),this.values=e.values||{},this.setValues(this.values)},jvm.DataSeries.prototype={setAttributes:function(e,t){var n=e,r;if(typeof e=="string"){this.elements[e]&&this.elements[e].setStyle(this.params.attribute,t)}else{for(r in n){this.elements[r]&&this.elements[r].element.setStyle(this.params.attribute,n[r])}}},setValues:function(e){var t=Number.MIN_VALUE,n=Number.MAX_VALUE,r,i,s={};if(this.scale instanceof jvm.OrdinalScale||this.scale instanceof jvm.SimpleScale){for(i in e){e[i]?s[i]=this.scale.getValue(e[i]):s[i]=this.elements[i].element.style.initial[this.params.attribute]}}else{if(!this.params.min||!this.params.max){for(i in e){r=parseFloat(e[i]),r>t&&(t=e[i]),r<n&&(n=r)}this.params.min||this.scale.setMin(n),this.params.max||this.scale.setMax(t),this.params.min=n,this.params.max=t}for(i in e){r=parseFloat(e[i]),isNaN(r)?s[i]=this.elements[i].element.style.initial[this.params.attribute]:s[i]=this.scale.getValue(r)}}this.setAttributes(s),jvm.$.extend(this.values,e)},clear:function(){var e,t={};for(e in this.values){this.elements[e]&&(t[e]=this.elements[e].element.style.initial[this.params.attribute])}this.setAttributes(t),this.values={}},setScale:function(e){this.scale.setScale(e),this.values&&this.setValues(this.values)},setNormalizeFunction:function(e){this.scale.setNormalizeFunction(e),this.values&&this.setValues(this.values)}},jvm.Proj={degRad:180/Math.PI,radDeg:Math.PI/180,radius:6381372,sgn:function(e){return e>0?1:e<0?-1:e},mill:function(e,t,n){return{x:this.radius*(t-n)*this.radDeg,y:-this.radius*Math.log(Math.tan((45+0.4*e)*this.radDeg))/0.8}},mill_inv:function(e,t,n){return{lat:(2.5*Math.atan(Math.exp(0.8*t/this.radius))-5*Math.PI/8)*this.degRad,lng:(n*this.radDeg+e/this.radius)*this.degRad}},merc:function(e,t,n){return{x:this.radius*(t-n)*this.radDeg,y:-this.radius*Math.log(Math.tan(Math.PI/4+e*Math.PI/360))}},merc_inv:function(e,t,n){return{lat:(2*Math.atan(Math.exp(t/this.radius))-Math.PI/2)*this.degRad,lng:(n*this.radDeg+e/this.radius)*this.degRad}},aea:function(e,t,n){var r=0,i=n*this.radDeg,s=29.5*this.radDeg,o=45.5*this.radDeg,u=e*this.radDeg,a=t*this.radDeg,f=(Math.sin(s)+Math.sin(o))/2,l=Math.cos(s)*Math.cos(s)+2*f*Math.sin(s),c=f*(a-i),h=Math.sqrt(l-2*f*Math.sin(u))/f,p=Math.sqrt(l-2*f*Math.sin(r))/f;return{x:h*Math.sin(c)*this.radius,y:-(p-h*Math.cos(c))*this.radius}},aea_inv:function(e,t,n){var r=e/this.radius,i=t/this.radius,s=0,o=n*this.radDeg,u=29.5*this.radDeg,a=45.5*this.radDeg,f=(Math.sin(u)+Math.sin(a))/2,l=Math.cos(u)*Math.cos(u)+2*f*Math.sin(u),c=Math.sqrt(l-2*f*Math.sin(s))/f,h=Math.sqrt(r*r+(c-i)*(c-i)),p=Math.atan(r/(c-i));return{lat:Math.asin((l-h*h*f*f)/(2*f))*this.degRad,lng:(o+p/f)*this.degRad}},lcc:function(e,t,n){var r=0,i=n*this.radDeg,s=t*this.radDeg,o=33*this.radDeg,u=45*this.radDeg,a=e*this.radDeg,f=Math.log(Math.cos(o)*(1/Math.cos(u)))/Math.log(Math.tan(Math.PI/4+u/2)*(1/Math.tan(Math.PI/4+o/2))),l=Math.cos(o)*Math.pow(Math.tan(Math.PI/4+o/2),f)/f,c=l*Math.pow(1/Math.tan(Math.PI/4+a/2),f),h=l*Math.pow(1/Math.tan(Math.PI/4+r/2),f);return{x:c*Math.sin(f*(s-i))*this.radius,y:-(h-c*Math.cos(f*(s-i)))*this.radius}},lcc_inv:function(e,t,n){var r=e/this.radius,i=t/this.radius,s=0,o=n*this.radDeg,u=33*this.radDeg,a=45*this.radDeg,f=Math.log(Math.cos(u)*(1/Math.cos(a)))/Math.log(Math.tan(Math.PI/4+a/2)*(1/Math.tan(Math.PI/4+u/2))),l=Math.cos(u)*Math.pow(Math.tan(Math.PI/4+u/2),f)/f,c=l*Math.pow(1/Math.tan(Math.PI/4+s/2),f),h=this.sgn(f)*Math.sqrt(r*r+(c-i)*(c-i)),p=Math.atan(r/(c-i));return{lat:(2*Math.atan(Math.pow(l/h,1/f))-Math.PI/2)*this.degRad,lng:(o+p/f)*this.degRad}}},jvm.WorldMap=function(e){var t=this,n;this.params=jvm.$.extend(!0,{},jvm.WorldMap.defaultParams,e);if(!jvm.WorldMap.maps[this.params.map]){throw new Error("Attempt to use map which was not loaded: "+this.params.map)}this.mapData=jvm.WorldMap.maps[this.params.map],this.markers={},this.regions={},this.regionsColors={},this.regionsData={},this.container=jvm.$("<div>").css({width:"100%",height:"100%"}).addClass("jvectormap-container"),this.params.container.append(this.container),this.container.data("mapObject",this),this.container.css({position:"relative",overflow:"hidden"}),this.defaultWidth=this.mapData.width,this.defaultHeight=this.mapData.height,this.setBackgroundColor(this.params.backgroundColor),this.onResize=function(){t.setSize()},jvm.$(window).resize(this.onResize);for(n in jvm.WorldMap.apiEvents){this.params[n]&&this.container.bind(jvm.WorldMap.apiEvents[n]+".jvectormap",this.params[n])}this.canvas=new jvm.VectorCanvas(this.container[0],this.width,this.height),"ontouchstart" in window||window.DocumentTouch&&document instanceof DocumentTouch?this.params.bindTouchEvents&&this.bindContainerTouchEvents():this.bindContainerEvents(),this.bindElementEvents(),this.createLabel(),this.params.zoomButtons&&this.bindZoomButtons(),this.createRegions(),this.createMarkers(this.params.markers||{}),this.setSize(),this.params.focusOn&&(typeof this.params.focusOn=="object"?this.setFocus.call(this,this.params.focusOn.scale,this.params.focusOn.x,this.params.focusOn.y):this.setFocus.call(this,this.params.focusOn)),this.params.selectedRegions&&this.setSelectedRegions(this.params.selectedRegions),this.params.selectedMarkers&&this.setSelectedMarkers(this.params.selectedMarkers),this.params.series&&this.createSeries()},jvm.WorldMap.prototype={transX:0,transY:0,scale:1,baseTransX:0,baseTransY:0,baseScale:1,width:0,height:0,setBackgroundColor:function(e){this.container.css("background-color",e)},resize:function(){var e=this.baseScale;this.width/this.height>this.defaultWidth/this.defaultHeight?(this.baseScale=this.height/this.defaultHeight,this.baseTransX=Math.abs(this.width-this.defaultWidth*this.baseScale)/(2*this.baseScale)):(this.baseScale=this.width/this.defaultWidth,this.baseTransY=Math.abs(this.height-this.defaultHeight*this.baseScale)/(2*this.baseScale)),this.scale*=this.baseScale/e,this.transX*=this.baseScale/e,this.transY*=this.baseScale/e},setSize:function(){this.width=this.container.width(),this.height=this.container.height(),this.resize(),this.canvas.setSize(this.width,this.height),this.applyTransform()},reset:function(){var e,t;for(e in this.series){for(t=0;t<this.series[e].length;t++){this.series[e][t].clear()}}this.scale=this.baseScale,this.transX=this.baseTransX,this.transY=this.baseTransY,this.applyTransform()},applyTransform:function(){var e,t,n,r;this.defaultWidth*this.scale<=this.width?(e=(this.width-this.defaultWidth*this.scale)/(2*this.scale),n=(this.width-this.defaultWidth*this.scale)/(2*this.scale)):(e=0,n=(this.width-this.defaultWidth*this.scale)/this.scale),this.defaultHeight*this.scale<=this.height?(t=(this.height-this.defaultHeight*this.scale)/(2*this.scale),r=(this.height-this.defaultHeight*this.scale)/(2*this.scale)):(t=0,r=(this.height-this.defaultHeight*this.scale)/this.scale),this.transY>t?this.transY=t:this.transY<r&&(this.transY=r),this.transX>e?this.transX=e:this.transX<n&&(this.transX=n),this.canvas.applyTransformParams(this.scale,this.transX,this.transY),this.markers&&this.repositionMarkers(),this.container.trigger("viewportChange",[this.scale/this.baseScale,this.transX,this.transY])},bindContainerEvents:function(){var e=!1,t,n,r=this;this.container.mousemove(function(i){return e&&(r.transX-=(t-i.pageX)/r.scale,r.transY-=(n-i.pageY)/r.scale,r.applyTransform(),t=i.pageX,n=i.pageY),!1}).mousedown(function(r){return e=!0,t=r.pageX,n=r.pageY,!1}),jvm.$("body").mouseup(function(){e=!1}),this.params.zoomOnScroll&&this.container.mousewheel(function(e,t,n,i){var s=jvm.$(r.container).offset(),o=e.pageX-s.left,u=e.pageY-s.top,a=Math.pow(1.3,i);r.label.hide(),r.setScale(r.scale*a,o,u),e.preventDefault()})},bindContainerTouchEvents:function(){var e,t,n=this,r,i,s,o,u,a=function(a){var f=a.originalEvent.touches,l,c,h,p;a.type=="touchstart"&&(u=0),f.length==1?(u==1&&(h=n.transX,p=n.transY,n.transX-=(r-f[0].pageX)/n.scale,n.transY-=(i-f[0].pageY)/n.scale,n.applyTransform(),n.label.hide(),(h!=n.transX||p!=n.transY)&&a.preventDefault()),r=f[0].pageX,i=f[0].pageY):f.length==2&&(u==2?(c=Math.sqrt(Math.pow(f[0].pageX-f[1].pageX,2)+Math.pow(f[0].pageY-f[1].pageY,2))/t,n.setScale(e*c,s,o),n.label.hide(),a.preventDefault()):(l=jvm.$(n.container).offset(),f[0].pageX>f[1].pageX?s=f[1].pageX+(f[0].pageX-f[1].pageX)/2:s=f[0].pageX+(f[1].pageX-f[0].pageX)/2,f[0].pageY>f[1].pageY?o=f[1].pageY+(f[0].pageY-f[1].pageY)/2:o=f[0].pageY+(f[1].pageY-f[0].pageY)/2,s-=l.left,o-=l.top,e=n.scale,t=Math.sqrt(Math.pow(f[0].pageX-f[1].pageX,2)+Math.pow(f[0].pageY-f[1].pageY,2)))),u=f.length};jvm.$(this.container).bind("touchstart",a),jvm.$(this.container).bind("touchmove",a)},bindElementEvents:function(){var e=this,t;this.container.mousemove(function(){t=!0}),this.container.delegate("[class~='jvectormap-element']","mouseover mouseout",function(t){var n=this,r=jvm.$(this).attr("class").baseVal?jvm.$(this).attr("class").baseVal:jvm.$(this).attr("class"),i=r.indexOf("jvectormap-region")===-1?"marker":"region",s=i=="region"?jvm.$(this).attr("data-code"):jvm.$(this).attr("data-index"),o=i=="region"?e.regions[s].element:e.markers[s].element,u=i=="region"?e.mapData.paths[s].name:e.markers[s].config.name||"",a=jvm.$.Event(i+"LabelShow.jvectormap"),f=jvm.$.Event(i+"Over.jvectormap");t.type=="mouseover"?(e.container.trigger(f,[s]),f.isDefaultPrevented()||o.setHovered(!0),e.label.text(u),e.container.trigger(a,[e.label,s]),a.isDefaultPrevented()||(e.label.show(),e.labelWidth=e.label.width(),e.labelHeight=e.label.height())):(o.setHovered(!1),e.label.hide(),e.container.trigger(i+"Out.jvectormap",[s]))}),this.container.delegate("[class~='jvectormap-element']","mousedown",function(e){t=!1}),this.container.delegate("[class~='jvectormap-element']","mouseup",function(n){var r=this,i=jvm.$(this).attr("class").baseVal?jvm.$(this).attr("class").baseVal:jvm.$(this).attr("class"),s=i.indexOf("jvectormap-region")===-1?"marker":"region",o=s=="region"?jvm.$(this).attr("data-code"):jvm.$(this).attr("data-index"),u=jvm.$.Event(s+"Click.jvectormap"),a=s=="region"?e.regions[o].element:e.markers[o].element;if(!t){e.container.trigger(u,[o]);if(s==="region"&&e.params.regionsSelectable||s==="marker"&&e.params.markersSelectable){u.isDefaultPrevented()||(e.params[s+"sSelectableOne"]&&e.clearSelected(s+"s"),a.setSelected(!a.isSelected))}}})},bindZoomButtons:function(){var e=this;jvm.$("<div/>").addClass("jvectormap-zoomin").html("<i class='fa fa-plus'></i>").appendTo(this.container),jvm.$("<div/>").addClass("jvectormap-zoomout").html("<i class='fa fa-minus'></i>").appendTo(this.container),this.container.find(".jvectormap-zoomin").click(function(){e.setScale(e.scale*e.params.zoomStep,e.width/2,e.height/2)}),this.container.find(".jvectormap-zoomout").click(function(){e.setScale(e.scale/e.params.zoomStep,e.width/2,e.height/2)})},createLabel:function(){if($(".jvectormap-label").length){$(".jvectormap-label").remove()}var e=this;this.label=jvm.$("<div/>").addClass("jvectormap-label").appendTo(jvm.$("body")),this.container.mousemove(function(t){var n=t.pageX-15-e.labelWidth,r=t.pageY-15-e.labelHeight;n<5&&(n=t.pageX+15),r<5&&(r=t.pageY+15),e.label.is(":visible")&&e.label.css({left:n,top:r})})},setScale:function(e,t,n,r){var i,s=jvm.$.Event("zoom.jvectormap");e>this.params.zoomMax*this.baseScale?e=this.params.zoomMax*this.baseScale:e<this.params.zoomMin*this.baseScale&&(e=this.params.zoomMin*this.baseScale),typeof t!="undefined"&&typeof n!="undefined"&&(i=e/this.scale,r?(this.transX=t+this.defaultWidth*(this.width/(this.defaultWidth*e))/2,this.transY=n+this.defaultHeight*(this.height/(this.defaultHeight*e))/2):(this.transX-=(i-1)/e*t,this.transY-=(i-1)/e*n)),this.scale=e,this.applyTransform(),this.container.trigger(s,[e/this.baseScale])},setFocus:function(e,t,n){var r,i,s,o,u;if(jvm.$.isArray(e)||this.regions[e]){jvm.$.isArray(e)?o=e:o=[e];for(u=0;u<o.length;u++){this.regions[o[u]]&&(i=this.regions[o[u]].element.getBBox(),i&&(typeof r=="undefined"?r=i:(s={x:Math.min(r.x,i.x),y:Math.min(r.y,i.y),width:Math.max(r.x+r.width,i.x+i.width)-Math.min(r.x,i.x),height:Math.max(r.y+r.height,i.y+i.height)-Math.min(r.y,i.y)},r=s)))}this.setScale(Math.min(this.width/r.width,this.height/r.height),-(r.x+r.width/2),-(r.y+r.height/2),!0)}else{e*=this.baseScale,this.setScale(e,-t*this.defaultWidth,-n*this.defaultHeight,!0)}},getSelected:function(e){var t,n=[];for(t in this[e]){this[e][t].element.isSelected&&n.push(t)}return n},getSelectedRegions:function(){return this.getSelected("regions")},getSelectedMarkers:function(){return this.getSelected("markers")},setSelected:function(e,t){var n;typeof t!="object"&&(t=[t]);if(jvm.$.isArray(t)){for(n=0;n<t.length;n++){this[e][t[n]].element.setSelected(!0)}}else{for(n in t){this[e][n].element.setSelected(!!t[n])}}},setSelectedRegions:function(e){this.setSelected("regions",e)},setSelectedMarkers:function(e){this.setSelected("markers",e)},clearSelected:function(e){var t={},n=this.getSelected(e),r;for(r=0;r<n.length;r++){t[n[r]]=!1}this.setSelected(e,t)},clearSelectedRegions:function(){this.clearSelected("regions")},clearSelectedMarkers:function(){this.clearSelected("markers")},getMapObject:function(){return this},getRegionName:function(e){return this.mapData.paths[e].name},createRegions:function(){var e,t,n=this;for(e in this.mapData.paths){t=this.canvas.addPath({d:this.mapData.paths[e].path,"data-code":e},jvm.$.extend(!0,{},this.params.regionStyle)),jvm.$(t.node).bind("selected",function(e,t){n.container.trigger("regionSelected.jvectormap",[jvm.$(this).attr("data-code"),t,n.getSelectedRegions()])}),t.addClass("jvectormap-region jvectormap-element"),this.regions[e]={element:t,config:this.mapData.paths[e]}}},createMarkers:function(e){var t,n,r,i,s,o=this;this.markersGroup=this.markersGroup||this.canvas.addGroup();if(jvm.$.isArray(e)){s=e.slice(),e={};for(t=0;t<s.length;t++){e[t]=s[t]}}for(t in e){i=e[t] instanceof Array?{latLng:e[t]}:e[t],r=this.getMarkerPosition(i),r!==!1&&(n=this.canvas.addCircle({"data-index":t,cx:r.x,cy:r.y},jvm.$.extend(!0,{},this.params.markerStyle,{initial:i.style||{}}),this.markersGroup),n.addClass("jvectormap-marker jvectormap-element"),jvm.$(n.node).bind("selected",function(e,t){o.container.trigger("markerSelected.jvectormap",[jvm.$(this).attr("data-index"),t,o.getSelectedMarkers()])}),this.markers[t]&&this.removeMarkers([t]),this.markers[t]={element:n,config:i})}},repositionMarkers:function(){var e,t;for(e in this.markers){t=this.getMarkerPosition(this.markers[e].config),t!==!1&&this.markers[e].element.setStyle({cx:t.x,cy:t.y})}},getMarkerPosition:function(e){return jvm.WorldMap.maps[this.params.map].projection?this.latLngToPoint.apply(this,e.latLng||[0,0]):{x:e.coords[0]*this.scale+this.transX*this.scale,y:e.coords[1]*this.scale+this.transY*this.scale}},addMarker:function(e,t,n){var r={},i=[],s,o,n=n||[];r[e]=t;for(o=0;o<n.length;o++){s={},s[e]=n[o],i.push(s)}this.addMarkers(r,i)},addMarkers:function(e,t){var n;t=t||[],this.createMarkers(e);for(n=0;n<t.length;n++){this.series.markers[n].setValues(t[n]||{})}},removeMarkers:function(e){var t;for(t=0;t<e.length;t++){this.markers[e[t]].element.remove(),delete this.markers[e[t]]}},removeAllMarkers:function(){var e,t=[];for(e in this.markers){t.push(e)}this.removeMarkers(t)},latLngToPoint:function(e,t){var n,r=jvm.WorldMap.maps[this.params.map].projection,i=r.centralMeridian,s=this.width-this.baseTransX*2*this.baseScale,o=this.height-this.baseTransY*2*this.baseScale,u,a,f=this.scale/this.baseScale;return t<-180+i&&(t+=360),n=jvm.Proj[r.type](e,t,i),u=this.getInsetForPoint(n.x,n.y),u?(a=u.bbox,n.x=(n.x-a[0].x)/(a[1].x-a[0].x)*u.width*this.scale,n.y=(n.y-a[0].y)/(a[1].y-a[0].y)*u.height*this.scale,{x:n.x+this.transX*this.scale+u.left*this.scale,y:n.y+this.transY*this.scale+u.top*this.scale}):!1},pointToLatLng:function(e,t){var n=jvm.WorldMap.maps[this.params.map].projection,r=n.centralMeridian,i=jvm.WorldMap.maps[this.params.map].insets,s,o,u,a,f;for(s=0;s<i.length;s++){o=i[s],u=o.bbox,a=e-(this.transX*this.scale+o.left*this.scale),f=t-(this.transY*this.scale+o.top*this.scale),a=a/(o.width*this.scale)*(u[1].x-u[0].x)+u[0].x,f=f/(o.height*this.scale)*(u[1].y-u[0].y)+u[0].y;if(a>u[0].x&&a<u[1].x&&f>u[0].y&&f<u[1].y){return jvm.Proj[n.type+"_inv"](a,-f,r)}}return !1},getInsetForPoint:function(e,t){var n=jvm.WorldMap.maps[this.params.map].insets,r,i;for(r=0;r<n.length;r++){i=n[r].bbox;if(e>i[0].x&&e<i[1].x&&t>i[0].y&&t<i[1].y){return n[r]}}},createSeries:function(){var e,t;this.series={markers:[],regions:[]};for(t in this.params.series){for(e=0;e<this.params.series[t].length;e++){this.series[t][e]=new jvm.DataSeries(this.params.series[t][e],this[t])}}},remove:function(){this.label.remove(),this.container.remove(),jvm.$(window).unbind("resize",this.onResize)}},jvm.WorldMap.maps={},jvm.WorldMap.defaultParams={map:"world_mill_en",backgroundColor:"#505050",zoomButtons:!0,zoomOnScroll:!0,zoomMax:8,zoomMin:1,zoomStep:1.6,regionsSelectable:!1,markersSelectable:!1,bindTouchEvents:!0,regionStyle:{initial:{fill:"white","fill-opacity":1,stroke:"none","stroke-width":0,"stroke-opacity":1},hover:{"fill-opacity":0.8},selected:{fill:"yellow"},selectedHover:{}},markerStyle:{initial:{fill:"grey",stroke:"#505050","fill-opacity":1,"stroke-width":1,"stroke-opacity":1,r:5},hover:{stroke:"black","stroke-width":2},selected:{fill:"blue"},selectedHover:{}}},jvm.WorldMap.apiEvents={onRegionLabelShow:"regionLabelShow",onRegionOver:"regionOver",onRegionOut:"regionOut",onRegionClick:"regionClick",onRegionSelected:"regionSelected",onMarkerLabelShow:"markerLabelShow",onMarkerOver:"markerOver",onMarkerOut:"markerOut",onMarkerClick:"markerClick",onMarkerSelected:"markerSelected",onViewportChange:"viewportChange"};;
$.fn.vectorMap('addMap', 'world_mill_en',{"insets": [{"width": 900.0, "top": 0, "height": 440.7063107441331, "bbox": [{"y": -12671671.123330014, "x": -20004297.151525836}, {"y": 6930392.02513512, "x": 20026572.394749384}], "left": 0}], "paths": {"BD": {"path": "M652.71,228.85l-0.04,1.38l-0.46,-0.21l-0.42,0.3l0.05,0.65l-0.17,-1.37l-0.48,-1.26l-1.08,-1.6l-0.23,-0.13l-2.31,-0.11l-0.31,0.36l0.21,0.98l-0.6,1.11l-0.8,-0.4l-0.37,0.09l-0.23,0.3l-0.54,-0.21l-0.78,-0.19l-0.38,-2.04l-0.83,-1.89l0.4,-1.5l-0.16,-0.35l-1.24,-0.57l0.36,-0.62l1.5,-0.95l0.02,-0.49l-1.62,-1.26l0.64,-1.31l1.7,1.0l0.12,0.04l0.96,0.11l0.19,1.62l0.25,0.26l2.38,0.37l2.32,-0.04l1.06,0.33l-0.92,1.79l-0.97,0.13l-0.23,0.16l-0.77,1.51l0.05,0.35l1.37,1.37l0.5,-0.14l0.35,-1.46l0.24,-0.0l1.24,3.92Z", "name": "Bangladesh"}, "BE": {"path": "M429.28,143.95l1.76,0.25l0.13,-0.01l2.16,-0.64l1.46,1.34l1.26,0.71l-0.23,1.8l-0.44,0.08l-0.24,0.25l-0.2,1.36l-1.8,-1.22l-0.23,-0.05l-1.14,0.23l-1.62,-1.43l-1.15,-1.31l-0.21,-0.1l-0.95,-0.04l-0.21,-0.68l1.66,-0.54Z", "name": "Belgium"}, "BF": {"path": "M413.48,260.21l-1.22,-0.46l-0.13,-0.02l-1.17,0.1l-0.15,0.06l-0.73,0.53l-0.87,-0.41l-0.39,-0.75l-0.13,-0.13l-0.98,-0.48l-0.14,-1.2l0.63,-0.99l0.05,-0.18l-0.05,-0.73l1.9,-2.01l0.08,-0.14l0.35,-1.65l0.49,-0.44l1.05,0.3l0.21,-0.02l1.05,-0.52l0.13,-0.13l0.3,-0.58l1.87,-1.1l0.11,-0.1l0.43,-0.72l2.23,-1.01l1.21,-0.32l0.51,0.4l0.19,0.06l1.25,-0.01l-0.14,0.89l0.01,0.13l0.34,1.16l0.06,0.11l1.35,1.59l0.07,1.13l0.24,0.28l2.64,0.53l-0.05,1.39l-0.42,0.59l-1.11,0.21l-0.22,0.17l-0.46,0.99l-0.69,0.23l-2.12,-0.05l-1.14,-0.2l-0.19,0.03l-0.72,0.36l-1.07,-0.17l-4.35,0.12l-0.29,0.29l-0.06,1.44l0.25,1.45Z", "name": "Burkina Faso"}, "BG": {"path": "M477.63,166.84l0.51,0.9l0.33,0.14l0.9,-0.21l1.91,0.47l3.68,0.16l0.17,-0.05l1.2,-0.75l2.78,-0.67l1.72,1.05l1.02,0.24l-0.97,0.97l-0.91,2.17l0.0,0.24l0.56,1.19l-1.58,-0.3l-0.16,0.01l-2.55,0.95l-0.2,0.28l-0.02,1.23l-1.92,0.24l-1.68,-0.99l-0.27,-0.02l-1.94,0.8l-1.52,-0.07l-0.15,-1.72l-0.12,-0.21l-0.99,-0.76l0.18,-0.18l0.02,-0.39l-0.17,-0.22l0.33,-0.75l0.91,-0.91l0.01,-0.42l-1.16,-1.25l-0.18,-0.89l0.24,-0.27Z", "name": "Bulgaria"}, "BA": {"path": "M468.39,164.66l0.16,0.04l0.43,-0.0l-0.43,0.93l0.06,0.34l1.08,1.06l-0.28,1.09l-0.5,0.13l-0.47,0.28l-0.86,0.74l-0.1,0.16l-0.28,1.29l-1.81,-0.94l-0.9,-1.22l-1.0,-0.73l-1.1,-1.1l-0.55,-0.96l-1.11,-1.3l0.3,-0.75l0.59,0.46l0.42,-0.04l0.46,-0.54l1.0,-0.06l2.11,0.5l1.72,-0.03l1.06,0.64Z", "name": "Bosnia and Herzegovina"}, "BN": {"path": "M707.34,273.57l0.76,-0.72l1.59,-1.03l-0.18,1.93l-0.9,-0.06l-0.28,0.14l-0.31,0.51l-0.68,-0.78Z", "name": "Brunei"}, "BO": {"path": "M263.83,340.79l-0.23,-0.12l-2.86,-0.11l-0.28,0.17l-0.77,1.67l-1.17,-1.51l-0.18,-0.11l-3.28,-0.64l-0.28,0.1l-2.02,2.3l-1.43,0.29l-0.91,-3.35l-1.31,-2.88l0.75,-2.41l-0.09,-0.32l-1.23,-1.03l-0.31,-1.76l-0.05,-0.12l-1.12,-1.6l1.49,-2.62l0.01,-0.28l-1.0,-2.0l0.48,-0.72l0.02,-0.29l-0.37,-0.78l0.87,-1.13l0.06,-0.18l0.05,-2.17l0.12,-1.71l0.5,-0.8l0.01,-0.3l-1.9,-3.58l1.3,0.15l1.34,-0.05l0.23,-0.12l0.51,-0.7l2.12,-0.99l1.31,-0.93l2.81,-0.37l-0.21,1.51l0.01,0.13l0.29,0.91l-0.19,1.64l0.11,0.27l2.72,2.27l0.15,0.07l2.71,0.41l0.92,0.88l0.12,0.07l1.64,0.49l1.0,0.71l0.18,0.06l1.5,-0.02l1.24,0.64l0.1,1.31l0.05,0.14l0.44,0.68l0.02,0.73l-0.44,0.03l-0.27,0.39l0.96,2.99l0.28,0.21l4.43,0.1l-0.28,1.12l0.0,0.15l0.27,1.02l0.15,0.19l1.27,0.67l0.52,1.42l-0.42,1.91l-0.66,1.1l-0.04,0.2l0.21,1.3l-0.19,0.13l-0.01,-0.27l-0.15,-0.24l-2.33,-1.33l-0.14,-0.04l-2.38,-0.03l-4.36,0.76l-0.21,0.16l-1.2,2.29l-0.03,0.13l-0.06,1.37l-0.79,2.53l-0.05,-0.08Z", "name": "Bolivia"}, "JP": {"path": "M781.17,166.78l1.8,0.67l0.28,-0.04l1.38,-1.01l0.43,2.67l-3.44,0.77l-0.18,0.12l-2.04,2.79l-3.71,-1.94l-0.42,0.15l-1.29,3.11l-2.32,0.04l-0.3,-2.63l1.12,-2.1l2.51,-0.16l0.28,-0.25l0.73,-4.22l0.58,-1.9l2.59,2.84l2.0,1.1ZM773.66,187.36l-0.92,2.24l-0.01,0.2l0.4,1.3l-1.18,1.81l-3.06,1.28l-4.35,0.17l-0.19,0.08l-3.4,3.06l-1.36,-0.87l-0.1,-1.95l-0.34,-0.28l-4.35,0.62l-2.99,1.33l-2.87,0.05l-0.28,0.2l0.09,0.33l2.37,1.93l-1.57,4.44l-1.35,0.97l-0.9,-0.79l0.57,-2.32l-0.15,-0.34l-1.5,-0.77l-0.81,-1.53l2.04,-0.75l0.14,-0.1l1.28,-1.72l2.47,-1.43l1.84,-1.92l4.83,-0.82l2.62,0.57l0.33,-0.16l2.45,-4.77l1.38,1.14l0.38,0.0l5.1,-4.02l0.09,-0.11l1.57,-3.57l0.02,-0.16l-0.42,-3.22l0.94,-1.67l2.27,-0.47l1.26,3.82l-0.07,2.23l-2.26,2.86l-0.06,0.19l0.04,2.93ZM757.85,196.18l0.22,0.66l-1.11,1.33l-0.8,-0.7l-0.33,-0.04l-1.28,0.65l-0.14,0.15l-0.54,1.34l-1.17,-0.57l0.02,-1.03l1.2,-1.45l1.24,0.28l0.29,-0.1l0.9,-1.03l1.51,0.5Z", "name": "Japan"}, "BI": {"path": "M494.7,295.83l-0.14,-2.71l-0.04,-0.13l-0.34,-0.62l0.93,0.12l0.3,-0.16l0.67,-1.25l0.9,0.11l0.11,0.76l0.08,0.16l0.46,0.48l0.02,0.56l-0.55,0.48l-0.96,1.29l-0.82,0.82l-0.61,0.07Z", "name": "Burundi"}, "BJ": {"path": "M427.4,268.94l-1.58,0.22l-0.52,-1.45l0.11,-5.73l-0.08,-0.21l-0.43,-0.44l-0.09,-1.13l-0.09,-0.19l-1.52,-1.52l0.24,-1.01l0.7,-0.23l0.18,-0.16l0.45,-0.97l1.07,-0.21l0.19,-0.12l0.53,-0.73l0.73,-0.65l0.68,-0.0l1.69,1.3l-0.08,0.67l0.02,0.14l0.52,1.38l-0.44,0.9l-0.01,0.24l0.2,0.52l-1.1,1.42l-0.76,0.76l-0.08,0.13l-0.47,1.59l0.05,1.69l-0.13,3.79Z", "name": "Benin"}, "BT": {"path": "M650.38,213.78l0.88,0.75l-0.13,1.24l-1.77,0.07l-2.1,-0.18l-1.57,0.4l-2.02,-0.91l-0.02,-0.24l1.54,-1.87l1.18,-0.6l1.67,0.59l1.32,0.08l1.01,0.67Z", "name": "Bhutan"}, "JM": {"path": "M226.67,238.37l1.64,0.23l1.2,0.56l0.11,0.19l-1.25,0.03l-0.14,0.04l-0.65,0.37l-1.24,-0.37l-1.17,-0.77l0.11,-0.22l0.86,-0.15l0.52,0.08Z", "name": "Jamaica"}, "BW": {"path": "M484.91,331.96l0.53,0.52l0.82,1.53l2.83,2.86l0.14,0.08l0.85,0.22l0.03,0.81l0.74,1.66l0.21,0.17l1.87,0.39l1.17,0.87l-3.13,1.71l-2.3,2.01l-0.07,0.1l-0.82,1.74l-0.66,0.88l-1.24,0.19l-0.24,0.2l-0.65,1.98l-1.4,0.55l-1.9,-0.12l-1.2,-0.74l-1.06,-0.32l-0.22,0.02l-1.22,0.62l-0.14,0.14l-0.58,1.21l-1.16,0.79l-1.18,1.13l-1.5,0.23l-0.4,-0.68l0.22,-1.53l-0.04,-0.19l-1.48,-2.54l-0.11,-0.11l-0.53,-0.31l-0.0,-7.25l2.18,-0.08l0.29,-0.3l0.07,-9.0l1.63,-0.08l3.69,-0.86l0.84,0.93l0.38,0.05l1.53,-0.97l0.79,-0.03l1.3,-0.53l0.23,0.1l0.92,1.96Z", "name": "Botswana"}, "BR": {"path": "M259.49,274.87l1.42,0.25l1.97,0.62l0.28,-0.05l0.67,-0.55l1.76,-0.38l2.8,-0.94l0.12,-0.08l0.92,-0.96l0.05,-0.33l-0.15,-0.32l0.73,-0.06l0.36,0.35l-0.27,0.93l0.17,0.36l0.76,0.34l0.44,0.9l-0.58,0.73l-0.06,0.13l-0.4,2.13l0.03,0.19l0.62,1.22l0.17,1.11l0.11,0.19l1.54,1.18l0.15,0.06l1.23,0.12l0.29,-0.15l0.2,-0.36l0.71,-0.11l1.13,-0.44l0.79,-0.63l1.25,0.19l0.65,-0.08l1.32,0.2l0.32,-0.18l0.23,-0.51l-0.05,-0.31l-0.31,-0.37l0.11,-0.31l0.75,0.17l0.13,0.0l1.1,-0.24l1.34,0.5l1.08,0.51l0.33,-0.05l0.67,-0.58l0.27,0.05l0.28,0.57l0.31,0.17l1.2,-0.18l0.17,-0.08l1.03,-1.05l0.76,-1.82l1.39,-2.16l0.49,-0.07l0.52,1.17l1.4,4.37l0.2,0.2l1.14,0.35l0.05,1.39l-1.8,1.97l0.01,0.42l0.78,0.75l0.18,0.08l4.16,0.37l0.08,2.25l0.5,0.22l1.78,-1.54l2.98,0.85l4.07,1.5l1.07,1.28l-0.37,1.23l0.36,0.38l2.83,-0.75l4.8,1.3l3.75,-0.09l3.6,2.02l3.27,2.84l1.93,0.72l2.13,0.11l0.76,0.66l1.22,4.56l-0.96,4.03l-1.22,1.58l-3.52,3.51l-1.63,2.91l-1.75,2.09l-0.5,0.04l-0.26,0.19l-0.72,1.99l0.18,4.76l-0.95,5.56l-0.74,0.96l-0.06,0.15l-0.43,3.39l-2.49,3.34l-0.06,0.13l-0.4,2.56l-1.9,1.07l-0.13,0.16l-0.51,1.38l-2.59,0.0l-3.94,1.01l-1.82,1.19l-2.85,0.81l-3.01,2.17l-2.12,2.65l-0.06,0.13l-0.36,2.0l0.01,0.13l0.4,1.42l-0.45,2.63l-0.53,1.23l-1.76,1.53l-2.76,4.79l-2.16,2.15l-1.69,1.29l-0.09,0.12l-1.12,2.6l-1.3,1.26l-0.45,-1.02l0.99,-1.18l0.01,-0.37l-1.5,-1.95l-1.98,-1.54l-2.58,-1.77l-0.2,-0.05l-0.81,0.07l-2.42,-2.05l-0.25,-0.07l-0.77,0.14l2.75,-3.07l2.8,-2.61l1.67,-1.09l2.11,-1.49l0.13,-0.24l0.05,-2.15l-0.07,-0.2l-1.26,-1.54l-0.35,-0.09l-0.64,0.27l0.3,-0.95l0.34,-1.57l0.01,-1.52l-0.16,-0.26l-0.9,-0.48l-0.27,-0.01l-0.86,0.39l-0.65,-0.08l-0.23,-0.8l-0.23,-2.39l-0.04,-0.12l-0.47,-0.79l-0.14,-0.12l-1.69,-0.71l-0.25,0.01l-0.93,0.47l-2.29,-0.44l0.15,-3.3l-0.03,-0.15l-0.62,-1.22l0.57,-0.39l0.13,-0.3l-0.22,-1.37l0.67,-1.13l0.44,-2.04l-0.01,-0.17l-0.59,-1.61l-0.14,-0.16l-1.25,-0.66l-0.22,-0.82l0.35,-1.41l-0.28,-0.37l-4.59,-0.1l-0.78,-2.41l0.34,-0.02l0.28,-0.31l-0.03,-1.1l-0.05,-0.16l-0.45,-0.68l-0.1,-1.4l-0.16,-0.24l-1.45,-0.76l-0.14,-0.03l-1.48,0.02l-1.04,-0.73l-1.62,-0.48l-0.93,-0.9l-0.16,-0.08l-2.72,-0.41l-2.53,-2.12l0.18,-1.54l-0.01,-0.13l-0.29,-0.91l0.26,-1.83l-0.34,-0.34l-3.28,0.43l-0.14,0.05l-1.3,0.93l-2.16,1.01l-0.12,0.09l-0.47,0.65l-1.12,0.05l-1.84,-0.21l-0.12,0.01l-1.33,0.41l-0.82,-0.21l0.16,-3.6l-0.48,-0.26l-1.97,1.43l-1.96,-0.06l-0.86,-1.23l-0.22,-0.13l-1.23,-0.11l0.34,-0.69l-0.05,-0.33l-1.36,-1.5l-0.92,-2.0l0.45,-0.32l0.13,-0.25l-0.0,-0.87l1.34,-0.64l0.17,-0.32l-0.23,-1.23l0.56,-0.77l0.05,-0.13l0.16,-1.03l2.7,-1.61l2.01,-0.47l0.16,-0.09l0.24,-0.27l2.11,0.11l0.31,-0.25l1.13,-6.87l0.06,-1.12l-0.4,-1.53l-0.1,-0.15l-1.0,-0.82l0.01,-1.45l1.08,-0.32l0.39,0.2l0.44,-0.24l0.08,-0.96l-0.25,-0.32l-1.22,-0.22l-0.02,-1.01l4.57,0.05l0.22,-0.09l0.6,-0.63l0.44,0.5l0.47,1.42l0.45,0.16l0.27,-0.18l1.21,1.16l0.23,0.08l1.95,-0.16l0.23,-0.14l0.43,-0.67l1.76,-0.55l1.05,-0.42l0.18,-0.2l0.25,-0.92l1.65,-0.66l0.18,-0.35l-0.14,-0.53l-0.26,-0.22l-1.91,-0.19l-0.29,-1.33l0.1,-1.64l-0.15,-0.28l-0.44,-0.25Z", "name": "Brazil"}, "BS": {"path": "M227.51,216.69l0.3,0.18l-0.24,1.07l0.03,-1.04l-0.09,-0.21ZM226.5,224.03l-0.13,0.03l-0.54,-1.3l-0.09,-0.12l-0.78,-0.64l0.4,-1.26l0.33,0.05l0.79,2.0l0.01,1.24ZM225.76,216.5l-2.16,0.34l-0.07,-0.41l0.85,-0.16l1.36,0.07l0.02,0.16Z", "name": "The Bahamas"}, "BY": {"path": "M480.08,135.28l2.09,0.02l0.13,-0.03l2.72,-1.3l0.16,-0.19l0.55,-1.83l1.94,-1.06l0.15,-0.31l-0.2,-1.33l1.33,-0.52l2.58,-1.3l2.39,0.8l0.3,0.75l0.37,0.17l1.22,-0.39l2.18,0.75l0.2,1.36l-0.48,0.85l0.01,0.32l1.57,2.26l0.92,0.6l-0.1,0.41l0.19,0.35l1.61,0.57l0.48,0.6l-0.64,0.49l-1.91,-0.11l-0.18,0.05l-0.48,0.32l-0.1,0.39l0.57,1.1l0.51,1.78l-1.79,0.17l-0.18,0.08l-0.77,0.73l-0.09,0.19l-0.13,1.31l-0.75,-0.22l-2.11,0.15l-0.56,-0.66l-0.39,-0.06l-0.8,0.49l-0.79,-0.4l-0.13,-0.03l-1.94,-0.07l-2.76,-0.79l-2.58,-0.27l-1.98,0.07l-0.15,0.05l-1.31,0.86l-0.8,0.09l-0.04,-1.16l-0.03,-0.12l-0.63,-1.28l1.22,-0.56l0.17,-0.27l0.01,-1.35l-0.04,-0.15l-0.66,-1.24l-0.08,-1.12Z", "name": "Belarus"}, "BZ": {"path": "M198.03,239.7l0.28,0.19l0.43,-0.1l0.82,-1.42l0.0,0.07l0.29,0.29l0.16,0.0l-0.02,0.35l-0.39,1.08l0.02,0.25l0.16,0.29l-0.23,0.8l0.04,0.24l0.09,0.14l-0.25,1.12l-0.38,0.53l-0.33,0.06l-0.21,0.15l-0.41,0.74l-0.25,0.0l0.17,-2.58l0.01,-2.2Z", "name": "Belize"}, "RU": {"path": "M688.57,38.85l0.63,2.39l0.44,0.19l2.22,-1.23l7.18,0.07l5.54,2.49l1.85,1.77l-0.55,2.34l-2.64,1.42l-6.57,2.76l-1.95,1.5l0.12,0.53l3.09,0.68l3.69,1.23l0.21,-0.01l1.98,-0.81l1.16,2.84l0.5,0.08l1.03,-1.18l3.86,-0.74l7.79,0.78l0.56,2.05l0.27,0.22l10.47,0.71l0.32,-0.29l0.13,-3.34l4.98,0.8l3.96,-0.02l3.88,2.43l1.06,2.79l-1.38,1.83l0.01,0.38l3.15,3.64l0.1,0.08l3.94,1.86l0.4,-0.14l2.28,-4.56l3.75,1.94l0.22,0.02l4.18,-1.22l4.76,1.4l0.26,-0.04l1.74,-1.23l3.98,0.63l0.32,-0.41l-1.71,-4.1l3.0,-1.86l22.39,3.04l2.06,2.67l0.1,0.08l6.55,3.51l0.17,0.03l10.08,-0.86l4.86,0.73l1.91,1.72l-0.29,3.13l0.18,0.31l3.08,1.26l0.19,0.01l3.32,-0.9l4.37,-0.11l4.78,0.87l4.61,-0.48l4.26,3.82l0.32,0.05l3.1,-1.4l0.12,-0.45l-1.91,-2.67l0.92,-1.64l7.78,1.22l5.22,-0.26l7.12,2.1l9.6,5.22l6.4,4.15l-0.2,2.44l0.14,0.28l1.69,1.04l0.45,-0.31l-0.51,-2.66l6.31,0.58l4.52,3.61l-2.1,1.52l-4.02,0.42l-0.27,0.29l-0.06,3.83l-0.81,0.67l-2.14,-0.11l-1.91,-1.39l-3.19,-1.13l-0.51,-1.63l-0.21,-0.2l-2.54,-0.67l-0.13,-0.0l-2.69,0.5l-1.12,-1.19l0.48,-1.36l-0.38,-0.39l-3.0,0.98l-0.17,0.44l1.02,1.76l-1.27,1.55l-3.09,1.71l-3.15,-0.29l-0.3,0.18l0.07,0.34l2.22,2.1l1.47,3.22l1.15,1.09l0.25,1.41l-0.48,0.76l-4.47,-0.81l-0.17,0.02l-6.97,2.9l-2.2,0.44l-0.11,0.05l-3.83,2.68l-3.63,2.32l-0.1,0.11l-0.76,1.4l-3.3,-2.4l-0.3,-0.03l-6.31,2.85l-0.99,-1.21l-0.4,-0.06l-2.32,1.54l-3.23,-0.49l-0.33,0.2l-0.79,2.39l-2.97,3.51l-0.07,0.21l0.09,1.47l0.22,0.27l2.62,0.74l-0.3,4.7l-2.06,0.12l-0.26,0.2l-1.07,2.94l0.04,0.27l0.83,1.19l-4.03,1.63l-0.18,0.21l-0.83,3.72l-3.55,0.79l-0.23,0.23l-0.73,3.32l-3.22,2.76l-0.76,-1.88l-1.07,-4.88l-1.39,-7.59l1.17,-4.76l2.05,-2.08l0.09,-0.19l0.11,-1.46l3.67,-0.77l0.15,-0.08l4.47,-4.61l4.29,-3.82l4.48,-3.01l0.11,-0.14l2.01,-5.43l-0.31,-0.4l-3.04,0.33l-0.24,0.17l-1.47,3.11l-5.98,3.94l-1.91,-4.36l-0.33,-0.17l-6.46,1.3l-0.15,0.08l-6.27,6.33l-0.01,0.41l1.7,1.87l-5.04,0.87l-3.51,0.34l0.16,-2.32l-0.26,-0.32l-3.89,-0.56l-0.19,0.04l-3.02,1.77l-7.63,-0.63l-8.24,1.1l-0.16,0.07l-8.11,7.09l-9.6,8.31l0.16,0.52l3.79,0.42l1.16,2.03l0.17,0.14l2.43,0.76l0.31,-0.08l1.5,-1.61l2.49,0.2l3.46,3.6l0.08,2.67l-1.91,3.26l-0.04,0.14l-0.21,3.91l-1.11,5.09l-3.73,4.55l-0.87,2.21l-6.73,7.14l-1.59,1.77l-3.23,1.72l-1.38,0.03l-1.48,-1.39l-0.37,-0.03l-3.36,2.22l-0.11,0.14l-0.16,0.42l-0.01,-1.09l1.0,-0.06l0.28,-0.27l0.36,-3.6l-0.61,-2.51l1.85,-0.94l2.94,0.53l0.32,-0.15l1.71,-3.1l0.84,-3.38l0.97,-1.18l1.32,-2.88l-0.34,-0.42l-4.14,0.95l-2.18,1.25l-3.51,-0.0l-0.95,-2.81l-0.1,-0.14l-2.97,-2.3l-0.11,-0.05l-4.19,-1.0l-0.89,-3.08l-0.87,-2.03l-0.95,-1.46l-1.54,-3.37l-0.12,-0.14l-2.27,-1.28l-3.83,-1.02l-3.37,0.1l-3.11,0.61l-0.13,0.06l-2.07,1.69l0.04,0.49l1.23,0.72l0.03,1.53l-1.34,1.05l-2.26,3.51l-0.05,0.17l0.02,1.27l-3.25,1.9l-2.87,-1.17l-0.14,-0.02l-2.86,0.26l-1.22,-1.02l-0.12,-0.06l-1.5,-0.35l-0.23,0.04l-3.62,2.27l-3.24,0.53l-2.28,0.79l-3.08,-0.51l-2.24,0.03l-1.49,-1.61l-2.45,-1.57l-0.11,-0.04l-2.6,-0.43l-3.17,0.43l-2.31,0.59l-3.31,-1.28l-0.45,-2.31l-0.21,-0.23l-2.94,-0.85l-2.26,-0.39l-2.77,-1.36l-0.37,0.09l-2.59,3.45l-0.03,0.32l0.91,1.74l-2.15,2.01l-3.47,-0.79l-2.44,-0.12l-1.59,-1.46l-0.2,-0.08l-2.55,-0.05l-2.12,-0.98l-0.24,-0.01l-3.85,1.57l-4.74,2.79l-2.59,0.55l-0.79,0.21l-1.21,-1.81l-0.29,-0.13l-3.05,0.41l-0.96,-1.25l-0.14,-0.1l-1.65,-0.6l-1.15,-1.82l-0.13,-0.12l-1.38,-0.6l-0.19,-0.02l-3.49,0.82l-3.35,-1.85l-0.38,0.08l-1.08,1.4l-5.36,-8.17l-3.02,-2.52l0.72,-0.85l0.01,-0.38l-0.37,-0.08l-6.22,3.21l-1.98,0.16l0.17,-1.51l-0.2,-0.31l-3.22,-1.17l-0.19,-0.0l-2.3,0.74l-0.72,-3.27l-0.24,-0.23l-4.5,-0.75l-0.21,0.04l-2.2,1.42l-6.21,1.27l-0.11,0.05l-1.16,0.81l-9.3,1.19l-0.18,0.09l-1.15,1.17l-0.02,0.39l1.56,2.01l-2.02,0.74l-0.16,0.42l0.35,0.68l-2.18,1.49l0.02,0.51l3.83,2.16l-0.45,1.13l-3.31,-0.13l-0.25,0.12l-0.57,0.77l-2.97,-1.59l-0.15,-0.04l-3.97,0.07l-0.13,0.03l-2.53,1.32l-2.84,-1.28l-5.52,-2.3l-0.12,-0.02l-3.91,0.09l-0.16,0.05l-5.17,3.6l-0.13,0.21l-0.25,1.89l-2.17,-1.6l-0.44,0.1l-2.0,3.59l0.06,0.37l0.55,0.5l-1.32,2.23l0.04,0.36l2.13,2.17l0.23,0.09l1.7,-0.08l1.42,1.89l-0.23,1.5l0.19,0.32l0.94,0.38l-0.89,1.44l-2.3,0.49l-0.17,0.11l-2.49,3.2l0.0,0.37l2.2,2.81l-0.23,1.93l0.06,0.22l2.56,3.32l-1.27,1.02l-0.4,0.66l-0.8,-0.15l-1.65,-1.75l-0.18,-0.09l-0.66,-0.09l-1.45,-0.64l-0.72,-1.16l-0.18,-0.13l-2.34,-0.63l-0.17,0.0l-1.32,0.41l-0.31,-0.4l-0.12,-0.09l-3.49,-1.48l-3.67,-0.49l-2.1,-0.52l-0.3,0.1l-0.12,0.14l-2.96,-2.4l-2.89,-1.19l-1.69,-1.42l1.27,-0.35l0.16,-0.1l2.08,-2.61l-0.04,-0.41l-1.02,-0.9l3.21,-1.12l0.2,-0.31l-0.07,-0.69l-0.37,-0.26l-1.86,0.42l0.05,-0.86l1.11,-0.76l2.35,-0.23l0.25,-0.19l0.39,-1.07l0.0,-0.19l-0.51,-1.64l0.95,-1.58l0.04,-0.16l-0.03,-0.95l-0.22,-0.28l-3.69,-1.06l-1.43,0.02l-1.45,-1.44l-0.29,-0.08l-1.83,0.49l-2.88,-1.04l0.04,-0.42l-0.04,-0.18l-0.89,-1.43l-0.23,-0.14l-1.77,-0.14l-0.13,-0.66l0.52,-0.56l0.01,-0.4l-1.6,-1.9l-0.27,-0.1l-2.55,0.32l-0.71,-0.16l-0.3,0.1l-0.53,0.63l-0.58,-0.08l-0.56,-1.97l-0.48,-0.94l0.17,-0.11l1.92,0.11l0.2,-0.06l0.97,-0.74l0.05,-0.42l-0.72,-0.91l-0.13,-0.1l-1.43,-0.51l0.09,-0.36l-0.13,-0.33l-0.97,-0.59l-1.43,-2.06l0.44,-0.77l0.04,-0.19l-0.25,-1.64l-0.2,-0.24l-2.45,-0.84l-0.19,-0.0l-1.05,0.34l-0.25,-0.62l-0.18,-0.17l-2.5,-0.84l-0.74,-1.93l-0.21,-1.7l-0.13,-0.21l-0.92,-0.63l0.83,-0.89l0.07,-0.27l-0.71,-3.26l1.69,-2.01l0.03,-0.34l-0.24,-0.41l2.63,-1.9l-0.01,-0.49l-2.31,-1.57l5.08,-4.61l2.33,-2.24l1.01,-2.08l-0.09,-0.37l-3.52,-2.56l0.94,-2.38l-0.04,-0.29l-2.14,-2.86l1.61,-3.35l-0.01,-0.29l-2.81,-4.58l2.19,-3.04l-0.06,-0.42l-3.7,-2.76l0.32,-2.67l1.87,-0.38l4.26,-1.77l2.46,-1.47l3.96,2.58l0.12,0.05l6.81,1.04l9.37,4.87l1.81,1.92l0.15,2.55l-2.61,2.06l-3.95,1.07l-11.1,-3.15l-0.17,0.0l-1.84,0.53l-0.1,0.53l3.97,2.97l0.15,1.77l0.16,4.14l0.19,0.27l3.21,1.22l1.94,1.03l0.44,-0.22l0.32,-1.94l-0.07,-0.25l-1.32,-1.52l1.25,-1.2l5.87,2.45l0.24,-0.01l2.11,-0.98l0.13,-0.42l-1.55,-2.75l5.52,-3.84l2.13,0.22l2.28,1.42l0.43,-0.12l1.46,-2.87l-0.04,-0.33l-1.97,-2.37l1.14,-2.38l-0.02,-0.3l-1.42,-2.07l6.15,1.22l1.14,1.92l-2.74,0.46l-0.25,0.3l0.02,2.36l0.12,0.24l1.97,1.44l0.25,0.05l3.87,-0.91l0.22,-0.23l0.58,-2.55l5.09,-1.98l8.67,-3.69l1.22,0.14l-2.06,2.2l0.18,0.5l3.11,0.45l0.23,-0.07l1.71,-1.41l4.59,-0.12l0.12,-0.03l3.53,-1.72l2.7,2.48l0.42,-0.01l2.85,-2.88l-0.0,-0.43l-2.42,-2.35l1.0,-1.13l7.2,1.31l3.42,1.36l9.06,4.97l0.39,-0.08l1.67,-2.27l-0.04,-0.4l-2.46,-2.23l-0.06,-0.82l-0.26,-0.27l-2.64,-0.38l0.69,-1.76l0.0,-0.22l-1.32,-3.47l-0.07,-1.27l4.52,-4.09l0.08,-0.11l1.6,-4.18l1.67,-0.84l6.33,1.2l0.46,2.31l-2.31,3.67l0.05,0.38l1.49,1.41l0.77,3.04l-0.56,6.05l0.09,0.24l2.62,2.54l-0.99,2.65l-4.87,5.96l0.17,0.48l2.86,0.61l0.31,-0.13l0.94,-1.42l2.67,-1.04l0.18,-0.19l0.64,-2.01l2.11,-1.98l0.05,-0.37l-1.38,-2.32l1.11,-2.74l-0.24,-0.41l-2.53,-0.33l-0.53,-2.16l1.96,-4.42l-0.05,-0.32l-3.03,-3.48l4.21,-2.94l0.12,-0.3l-0.52,-3.04l0.72,-0.06l1.18,2.35l-0.97,4.39l0.2,0.35l2.68,0.84l0.37,-0.38l-1.05,-3.07l3.89,-1.71l5.05,-0.24l4.55,2.62l0.36,-0.05l0.05,-0.36l-2.19,-3.84l-0.23,-4.78l4.07,-0.92l5.98,0.21l5.47,-0.64l0.2,-0.48l-1.88,-2.37l2.65,-2.99l2.75,-0.13l0.12,-0.03l4.82,-2.48l6.56,-0.67l0.23,-0.14l0.76,-1.27l6.33,-0.46l1.97,1.11l0.28,0.01l5.55,-2.71l4.53,0.08l0.29,-0.21l0.67,-2.18l2.29,-2.15l5.75,-2.13l3.48,1.4l-2.7,1.03l-0.19,0.31l0.26,0.26l5.47,0.78ZM871.83,65.73l0.25,-0.15l1.99,0.01l3.3,1.2l-0.08,0.22l-2.41,1.03l-5.73,0.49l-0.31,-1.0l2.99,-1.8ZM797.64,48.44l-2.22,1.51l-3.85,-0.43l-4.35,-1.85l0.42,-1.13l4.42,0.72l5.59,1.17ZM783.82,46.06l-1.71,3.25l-9.05,-0.14l-4.11,1.15l-4.64,-3.04l1.21,-3.13l3.11,-0.91l6.53,0.22l8.66,2.59ZM780.37,145.71l2.28,5.23l-3.09,-0.89l-0.37,0.19l-1.54,4.65l0.04,0.27l2.38,3.17l-0.05,1.4l-1.41,-1.41l-0.46,0.04l-1.23,1.81l-0.33,-1.86l0.28,-3.1l-0.28,-3.41l0.58,-2.46l0.11,-4.39l-0.03,-0.13l-1.44,-3.2l0.21,-4.39l2.19,-1.49l0.09,-0.41l-0.81,-1.3l0.48,-0.21l0.56,1.94l0.86,3.23l-0.05,3.36l1.03,3.35ZM780.16,57.18l-3.4,0.03l-5.06,-0.53l1.97,-1.59l2.95,-0.42l3.35,1.75l0.18,0.77ZM683.84,31.18l-13.29,1.97l4.16,-6.56l1.88,-0.58l1.77,0.34l6.08,3.02l-0.6,1.8ZM670.94,28.02l-5.18,0.65l-6.89,-1.58l-4.03,-2.07l-1.88,-3.98l-0.18,-0.16l-2.8,-0.93l5.91,-3.62l5.25,-1.29l4.73,2.88l5.63,5.44l-0.57,4.66ZM564.37,68.98l-0.85,0.23l-7.93,-0.57l-0.6,-1.84l-0.21,-0.2l-4.34,-1.18l-0.3,-2.08l2.34,-0.92l0.19,-0.29l-0.08,-2.43l4.85,-4.0l-0.12,-0.52l-1.68,-0.43l5.47,-3.94l0.11,-0.33l-0.6,-2.02l5.36,-2.55l8.22,-3.27l8.29,-0.96l4.34,-1.94l4.67,-0.65l1.45,1.72l-1.43,1.37l-8.8,2.52l-7.65,2.42l-7.92,4.84l-3.73,4.75l-3.92,4.58l-0.07,0.23l0.51,3.88l0.11,0.2l4.32,3.39ZM548.86,18.57l-3.28,0.75l-2.25,0.44l-0.22,0.19l-0.3,0.81l-2.67,0.86l-2.27,-1.14l1.2,-1.51l-0.23,-0.49l-3.14,-0.1l2.48,-0.54l3.55,-0.07l0.44,1.36l0.49,0.12l1.4,-1.35l2.2,-0.9l3.13,1.08l-0.54,0.49ZM477.5,133.25l-4.21,0.05l-2.69,-0.34l0.39,-1.03l3.24,-1.06l2.51,0.58l0.85,0.43l-0.2,0.71l-0.0,0.15l0.12,0.52Z", "name": "Russia"}, "RW": {"path": "M497.03,288.12l0.78,1.11l-0.12,1.19l-0.49,0.21l-1.25,-0.15l-0.3,0.16l-0.67,1.24l-1.01,-0.13l0.16,-0.92l0.22,-0.12l0.15,-0.24l0.09,-1.37l0.49,-0.48l0.42,0.18l0.25,-0.01l1.26,-0.65Z", "name": "Rwanda"}, "RS": {"path": "M469.75,168.65l0.21,-0.21l0.36,-1.44l-0.08,-0.29l-1.06,-1.03l0.54,-1.16l-0.28,-0.43l-0.26,0.0l0.55,-0.67l-0.01,-0.39l-0.77,-0.86l-0.45,-0.89l1.56,-0.67l1.39,0.12l1.22,1.1l0.26,0.91l0.16,0.19l1.38,0.66l0.17,1.12l0.14,0.21l1.46,0.9l0.35,-0.03l0.62,-0.54l0.09,0.06l-0.28,0.25l-0.03,0.42l0.29,0.34l-0.44,0.5l-0.07,0.26l0.22,1.12l0.07,0.14l1.02,1.1l-0.81,0.84l-0.42,0.96l0.04,0.3l0.12,0.15l-0.15,0.16l-1.04,0.04l-0.39,0.08l0.33,-0.81l-0.29,-0.41l-0.21,0.01l-0.39,-0.45l-0.13,-0.09l-0.32,-0.11l-0.27,-0.4l-0.14,-0.11l-0.4,-0.16l-0.31,-0.37l-0.34,-0.09l-0.45,0.17l-0.18,0.18l-0.29,0.84l-0.96,-0.65l-0.81,-0.33l-0.32,-0.37l-0.22,-0.18Z", "name": "Republic of Serbia"}, "LT": {"path": "M478.13,133.31l-0.14,-0.63l0.25,-0.88l-0.15,-0.35l-1.17,-0.58l-2.43,-0.57l-0.45,-2.51l2.58,-0.97l4.14,0.22l2.3,-0.32l0.26,0.54l0.22,0.17l1.26,0.22l2.25,1.6l0.19,1.23l-1.87,1.01l-0.14,0.18l-0.54,1.83l-2.54,1.21l-2.18,-0.02l-0.52,-0.91l-0.18,-0.14l-1.11,-0.32Z", "name": "Lithuania"}, "LU": {"path": "M435.95,147.99l0.33,0.49l-0.11,1.07l-0.39,0.04l-0.29,-0.15l0.21,-1.4l0.25,-0.05Z", "name": "Luxembourg"}, "LR": {"path": "M401.37,273.67l-0.32,0.01l-2.48,-1.15l-2.24,-1.89l-2.14,-1.38l-1.47,-1.42l0.44,-0.59l0.05,-0.13l0.12,-0.65l1.07,-1.3l1.08,-1.09l0.52,-0.07l0.43,-0.18l0.84,1.24l-0.15,0.89l0.07,0.25l0.49,0.54l0.22,0.1l0.71,0.01l0.27,-0.16l0.42,-0.83l0.19,0.02l-0.06,0.52l0.23,1.12l-0.5,1.03l0.06,0.35l0.73,0.69l0.14,0.08l0.71,0.15l0.92,0.91l0.06,0.76l-0.17,0.22l-0.06,0.15l-0.17,1.8Z", "name": "Liberia"}, "RO": {"path": "M477.94,155.19l1.02,-0.64l1.49,0.33l1.52,0.01l1.09,0.73l0.32,0.01l0.81,-0.46l1.8,-0.3l0.18,-0.1l0.54,-0.64l0.86,0.0l0.64,0.26l0.71,0.87l0.8,1.35l1.39,1.81l0.07,1.25l-0.26,1.3l0.01,0.15l0.45,1.42l0.15,0.18l1.12,0.57l0.25,0.01l1.05,-0.45l0.86,0.4l0.03,0.43l-0.92,0.51l-0.63,-0.24l-0.4,0.22l-0.64,3.41l-1.12,-0.24l-1.78,-1.09l-0.23,-0.04l-2.95,0.71l-1.25,0.77l-3.55,-0.16l-1.89,-0.47l-0.14,-0.0l-0.75,0.17l-0.61,-1.07l-0.3,-0.36l0.36,-0.32l-0.04,-0.48l-0.62,-0.38l-0.36,0.03l-0.62,0.54l-1.15,-0.71l-0.18,-1.14l-0.17,-0.22l-1.4,-0.67l-0.24,-0.86l-0.09,-0.14l-0.96,-0.87l1.49,-0.44l0.16,-0.11l1.51,-2.14l1.15,-2.09l1.44,-0.63Z", "name": "Romania"}, "GW": {"path": "M383.03,256.73l-1.12,-0.88l-0.14,-0.06l-0.94,-0.15l-0.43,-0.54l0.01,-0.27l-0.13,-0.26l-0.68,-0.48l-0.05,-0.16l0.99,-0.31l0.77,0.08l0.15,-0.02l0.61,-0.26l4.25,0.1l-0.02,0.44l-0.19,0.18l-0.08,0.29l0.17,0.66l-0.17,0.14l-0.44,0.0l-0.16,0.05l-0.57,0.37l-0.66,-0.04l-0.24,0.1l-0.92,1.03Z", "name": "Guinea Bissau"}, "GT": {"path": "M195.13,249.89l-1.05,-0.35l-1.5,-0.04l-1.06,-0.47l-1.19,-0.93l0.04,-0.53l0.27,-0.55l-0.03,-0.31l-0.24,-0.32l1.02,-1.77l3.04,-0.01l0.3,-0.28l0.06,-0.88l-0.19,-0.3l-0.3,-0.11l-0.23,-0.45l-0.11,-0.12l-0.9,-0.58l-0.35,-0.33l0.37,-0.0l0.3,-0.3l0.0,-1.15l4.05,0.02l-0.02,1.74l-0.2,2.89l0.3,0.32l0.67,-0.0l0.75,0.42l0.4,-0.11l-0.62,0.53l-1.17,0.7l-0.13,0.16l-0.18,0.49l0.0,0.21l0.14,0.34l-0.35,0.44l-0.49,0.13l-0.2,0.41l0.03,0.06l-0.27,0.16l-0.86,0.64l-0.12,0.22ZM199.35,245.38l0.07,-0.13l0.05,0.02l-0.13,0.11Z", "name": "Guatemala"}, "GR": {"path": "M487.2,174.55l-0.64,1.54l-0.43,0.24l-1.41,-0.08l-1.28,-0.28l-0.14,0.0l-3.03,0.77l-0.13,0.51l1.39,1.34l-0.78,0.29l-1.2,0.0l-1.23,-1.42l-0.47,0.02l-0.47,0.65l-0.04,0.27l0.56,1.76l0.06,0.11l1.02,1.12l-0.66,0.45l-0.04,0.46l1.39,1.35l1.15,0.79l0.02,1.06l-1.91,-0.63l-0.36,0.42l0.56,1.12l-1.2,0.23l-0.22,0.4l0.8,2.14l-1.15,0.02l-1.89,-1.15l-0.89,-2.19l-0.43,-1.91l-0.05,-0.11l-0.98,-1.35l-1.24,-1.62l-0.13,-0.63l1.07,-1.32l0.06,-0.14l0.13,-0.81l0.68,-0.36l0.16,-0.25l0.03,-0.54l1.4,-0.23l0.12,-0.05l0.87,-0.6l1.26,0.05l0.25,-0.11l0.34,-0.43l0.33,-0.07l1.81,0.08l0.13,-0.02l1.87,-0.77l1.64,0.97l0.19,0.04l2.28,-0.28l0.26,-0.29l0.02,-0.95l0.56,0.36ZM480.44,192.0l1.05,0.74l0.01,0.0l-1.26,-0.23l0.2,-0.51ZM481.76,192.79l1.86,-0.15l1.53,0.17l-0.02,0.19l0.34,0.3l-2.28,0.15l0.01,-0.13l-0.25,-0.31l-1.19,-0.22ZM485.65,193.28l0.65,-0.16l-0.05,0.12l-0.6,0.04Z", "name": "Greece"}, "GQ": {"path": "M444.81,282.04l-0.21,-0.17l0.74,-2.4l3.56,0.05l0.02,2.42l-3.34,-0.02l-0.76,0.13Z", "name": "Equatorial Guinea"}, "GY": {"path": "M271.34,264.25l1.43,0.81l1.44,1.53l0.06,1.19l0.28,0.28l0.84,0.05l2.13,1.92l-0.34,1.93l-1.37,0.59l-0.17,0.34l0.12,0.51l-0.43,1.21l0.03,0.26l1.11,1.82l0.26,0.14l0.56,0.0l0.32,1.29l1.25,1.78l-0.08,0.01l-1.34,-0.21l-0.24,0.06l-0.78,0.64l-1.06,0.41l-0.76,0.1l-0.22,0.15l-0.18,0.32l-0.95,-0.1l-1.38,-1.05l-0.19,-1.13l-0.6,-1.18l0.37,-1.96l0.65,-0.83l0.03,-0.32l-0.57,-1.17l-0.15,-0.14l-0.62,-0.27l0.25,-0.85l-0.08,-0.3l-0.58,-0.58l-0.24,-0.09l-1.15,0.1l-1.41,-1.58l0.48,-0.49l0.09,-0.22l-0.04,-0.92l1.31,-0.34l0.73,-0.52l0.04,-0.44l-0.75,-0.82l0.16,-0.66l1.74,-1.3Z", "name": "Guyana"}, "GE": {"path": "M525.41,174.19l0.26,-0.88l-0.0,-0.17l-0.63,-2.06l-0.1,-0.15l-1.45,-1.12l-0.11,-0.05l-1.31,-0.33l-0.66,-0.69l1.97,0.48l3.65,0.49l3.3,1.41l0.39,0.5l0.33,0.1l1.43,-0.45l2.14,0.58l0.7,1.14l0.13,0.12l1.06,0.47l-0.18,0.11l-0.08,0.43l1.08,1.41l-0.06,0.06l-1.16,-0.15l-1.82,-0.84l-0.31,0.04l-0.55,0.44l-3.29,0.44l-2.32,-1.41l-0.17,-0.04l-2.25,0.12Z", "name": "Georgia"}, "GB": {"path": "M412.82,118.6l-2.31,3.4l-0.0,0.33l0.31,0.13l2.52,-0.49l2.34,0.02l-0.56,2.51l-2.22,3.13l0.22,0.47l2.43,0.21l2.35,4.35l0.17,0.14l1.58,0.51l1.49,3.78l0.73,1.37l0.2,0.15l2.76,0.59l-0.25,1.75l-1.18,0.91l-0.08,0.39l0.87,1.49l-1.96,1.51l-3.31,-0.02l-4.15,0.88l-1.07,-0.59l-0.35,0.04l-1.55,1.44l-2.17,-0.35l-0.22,0.05l-1.61,1.15l-0.78,-0.38l3.31,-3.12l2.18,-0.7l0.21,-0.31l-0.26,-0.27l-3.78,-0.54l-0.48,-0.9l2.3,-0.92l0.13,-0.46l-1.29,-1.71l0.39,-1.83l3.46,0.29l0.32,-0.24l0.37,-1.99l-0.06,-0.24l-1.71,-2.17l-0.18,-0.11l-2.91,-0.58l-0.43,-0.68l0.82,-1.4l-0.03,-0.35l-0.82,-0.97l-0.46,0.01l-0.85,1.05l-0.11,-2.6l-0.05,-0.16l-1.19,-1.7l0.86,-3.53l1.81,-2.75l1.88,0.26l2.38,-0.24ZM406.39,132.84l-1.09,1.92l-1.65,-0.62l-1.26,0.02l0.41,-1.46l0.0,-0.16l-0.42,-1.51l1.62,-0.11l2.39,1.92Z", "name": "United Kingdom"}, "GA": {"path": "M448.76,294.47l-2.38,-2.34l-1.63,-2.04l-1.46,-2.48l0.06,-0.66l0.54,-0.81l0.61,-1.82l0.46,-1.69l0.63,-0.11l3.62,0.03l0.3,-0.3l-0.02,-2.75l0.88,-0.12l1.47,0.32l0.13,0.0l1.39,-0.3l-0.13,0.87l0.03,0.19l0.7,1.29l0.3,0.16l1.74,-0.19l0.36,0.29l-1.01,2.7l0.05,0.29l1.13,1.42l0.25,1.82l-0.3,1.56l-0.64,0.99l-1.93,-0.09l-1.26,-1.13l-0.5,0.17l-0.16,0.91l-1.48,0.27l-0.12,0.05l-0.86,0.63l-0.08,0.39l0.81,1.42l-1.48,1.08Z", "name": "Gabon"}, "GN": {"path": "M399.83,265.31l-0.69,-0.06l-0.3,0.16l-0.43,0.85l-0.39,-0.01l-0.3,-0.33l0.14,-0.87l-0.05,-0.22l-1.05,-1.54l-0.37,-0.11l-0.61,0.27l-0.84,0.12l0.02,-0.54l-0.04,-0.17l-0.35,-0.57l0.07,-0.63l-0.03,-0.17l-0.57,-1.11l-0.7,-0.9l-0.24,-0.12l-2.0,-0.0l-0.19,0.07l-0.51,0.42l-0.6,0.05l-0.21,0.11l-0.43,0.55l-0.3,0.7l-1.04,0.86l-0.91,-1.24l-1.0,-1.02l-0.69,-0.37l-0.52,-0.42l-0.3,-1.11l-0.37,-0.56l-0.1,-0.1l-0.4,-0.23l0.77,-0.85l0.62,0.04l0.18,-0.05l0.58,-0.38l0.46,-0.0l0.19,-0.07l0.39,-0.34l0.1,-0.3l-0.17,-0.67l0.15,-0.14l0.09,-0.2l0.03,-0.57l0.87,0.02l1.76,0.6l0.13,0.01l0.55,-0.06l0.22,-0.13l0.08,-0.12l1.18,0.17l0.17,-0.02l0.09,0.56l0.3,0.25l0.4,-0.0l0.14,-0.03l0.56,-0.29l0.23,0.05l0.63,0.59l0.15,0.07l1.07,0.2l0.24,-0.06l0.65,-0.52l0.77,-0.32l0.55,-0.32l0.3,0.04l0.44,0.45l0.34,0.74l0.84,0.87l-0.35,0.45l-0.06,0.15l-0.1,0.82l0.42,0.31l0.35,-0.16l0.05,0.04l-0.1,0.59l0.09,0.27l0.42,0.4l-0.06,0.02l-0.18,0.21l-0.2,0.86l0.03,0.21l0.56,1.02l0.52,1.71l-0.65,0.21l-0.15,0.12l-0.24,0.35l-0.03,0.28l0.16,0.41l-0.1,0.76l-0.12,0.0Z", "name": "Guinea"}, "GM": {"path": "M379.18,251.48l0.15,-0.55l2.51,-0.07l0.21,-0.09l0.48,-0.52l0.58,-0.03l0.91,0.58l0.16,0.05l0.78,0.01l0.14,-0.03l0.59,-0.31l0.16,0.24l-0.71,0.38l-0.94,-0.04l-1.02,-0.51l-0.3,0.01l-0.86,0.55l-0.37,0.02l-0.14,0.04l-0.53,0.31l-1.81,-0.04Z", "name": "Gambia"}, "GL": {"path": "M304.13,6.6l8.19,-3.63l8.72,0.28l0.19,-0.06l3.12,-2.28l8.75,-0.61l19.94,0.8l14.93,4.75l-3.92,2.01l-9.52,0.27l-13.48,0.6l-0.27,0.2l0.09,0.33l1.26,1.09l0.22,0.07l8.81,-0.67l7.49,2.07l0.19,-0.01l4.68,-1.78l1.76,1.84l-2.59,3.26l-0.01,0.36l0.34,0.11l6.35,-2.2l12.09,-2.32l7.31,1.14l1.17,2.13l-9.9,4.05l-1.43,1.32l-7.91,0.98l-0.26,0.31l0.29,0.29l5.25,0.25l-2.63,3.72l-2.02,3.61l-0.04,0.15l0.08,6.05l0.07,0.19l2.61,3.0l-3.4,0.2l-4.12,1.66l-0.04,0.54l4.5,2.67l0.53,3.9l-2.39,0.42l-0.19,0.48l2.91,3.83l-5.0,0.32l-0.27,0.22l0.12,0.33l2.69,1.84l-0.65,1.35l-3.36,0.71l-3.46,0.01l-0.21,0.51l3.05,3.15l0.02,1.53l-4.54,-1.79l-0.32,0.06l-1.29,1.26l0.11,0.5l3.33,1.15l3.17,2.74l0.85,3.29l-4.0,0.78l-1.83,-1.66l-3.1,-2.64l-0.36,-0.02l-0.13,0.33l0.8,2.92l-2.76,2.26l-0.09,0.33l0.28,0.2l6.59,0.19l2.47,0.18l-5.86,3.38l-6.76,3.43l-7.26,1.48l-2.73,0.02l-0.16,0.05l-2.67,1.72l-3.44,4.42l-5.28,2.86l-1.73,0.18l-3.33,1.01l-3.59,0.96l-0.15,0.1l-2.15,2.52l-0.07,0.19l-0.03,2.76l-1.21,2.49l-4.03,3.1l-0.1,0.33l0.98,2.94l-2.31,6.57l-3.21,0.21l-3.6,-3.0l-0.19,-0.07l-4.9,-0.02l-2.29,-1.97l-1.69,-3.78l-4.31,-4.86l-1.23,-2.52l-0.34,-3.58l-0.08,-0.17l-3.35,-3.67l0.85,-2.92l-0.09,-0.31l-1.5,-1.34l2.33,-4.7l3.67,-1.57l0.15,-0.13l1.02,-1.93l0.52,-3.47l-0.44,-0.31l-2.85,1.57l-1.33,0.64l-2.12,0.59l-2.81,-1.32l-0.15,-2.79l0.88,-2.17l2.09,-0.06l5.07,1.2l0.34,-0.17l-0.11,-0.37l-4.3,-2.9l-2.24,-1.58l-0.25,-0.05l-2.38,0.62l-1.7,-0.93l2.62,-4.1l-0.03,-0.36l-1.51,-1.75l-1.97,-3.3l-3.01,-5.21l-0.1,-0.11l-3.04,-1.85l0.03,-1.94l-0.18,-0.28l-6.82,-3.01l-5.35,-0.38l-6.69,0.21l-6.03,0.37l-2.81,-1.59l-3.84,-2.9l5.94,-1.5l5.01,-0.28l0.28,-0.29l-0.26,-0.31l-10.68,-1.38l-5.38,-2.1l0.27,-1.68l9.3,-2.6l9.18,-2.68l0.19,-0.16l0.97,-2.05l-0.18,-0.42l-6.29,-1.91l1.81,-1.9l8.58,-4.05l3.6,-0.63l0.23,-0.4l-0.92,-2.37l5.59,-1.5l7.66,-0.95l7.58,-0.05l2.65,1.84l0.31,0.02l6.52,-3.29l5.85,2.24l3.55,0.49l5.17,1.95l0.38,-0.16l-0.13,-0.39l-5.77,-3.16l0.29,-2.26Z", "name": "Greenland"}, "KW": {"path": "M540.87,207.81l0.41,0.94l-0.18,0.51l0.0,0.21l0.65,1.66l-1.15,0.05l-0.54,-1.12l-0.24,-0.17l-1.73,-0.2l1.44,-2.06l1.33,0.18Z", "name": "Kuwait"}, "GH": {"path": "M423.16,269.88l-3.58,1.34l-1.41,0.87l-2.13,0.69l-1.91,-0.61l0.09,-0.75l-0.03,-0.17l-1.04,-2.07l0.62,-2.7l1.04,-2.08l0.03,-0.19l-1.0,-5.46l0.05,-1.12l4.04,-0.11l1.08,0.18l0.18,-0.03l0.72,-0.36l0.75,0.13l-0.11,0.48l0.06,0.26l0.98,1.22l-0.0,1.77l0.24,1.99l0.05,0.13l0.55,0.81l-0.52,2.14l0.19,1.37l0.69,1.66l0.38,0.62Z", "name": "Ghana"}, "OM": {"path": "M568.16,231.0l-0.08,0.1l-0.84,1.61l-0.93,-0.11l-0.27,0.11l-0.58,0.73l-0.4,1.32l-0.01,0.14l0.29,1.61l-0.07,0.09l-1.0,-0.01l-0.16,0.04l-1.56,0.97l-0.14,0.2l-0.23,1.17l-0.41,0.4l-1.44,-0.02l-0.17,0.05l-0.98,0.65l-0.13,0.25l0.01,0.87l-0.97,0.57l-1.27,-0.22l-0.19,0.03l-1.63,0.84l-0.88,0.11l-2.55,-5.57l7.2,-2.49l0.19,-0.19l1.67,-5.23l-0.03,-0.25l-1.1,-1.78l0.05,-0.89l0.68,-1.03l0.05,-0.16l0.01,-0.89l0.96,-0.44l0.07,-0.5l-0.32,-0.26l0.16,-1.31l0.85,-0.01l1.03,1.67l0.09,0.09l1.4,0.96l0.11,0.05l1.82,0.34l1.37,0.45l1.75,2.32l0.13,0.1l0.7,0.26l-0.0,0.3l-1.25,2.19l-1.01,0.8ZM561.88,218.47l-0.01,0.02l-0.15,-0.29l0.3,-0.38l-0.14,0.65Z", "name": "Oman"}, "_3": {"path": "M543.2,261.06l-1.07,1.46l-1.65,1.99l-1.91,0.01l-8.08,-2.95l-0.89,-0.84l-0.9,-1.19l-0.81,-1.23l0.44,-0.73l0.76,-1.12l0.49,0.28l0.52,1.05l1.13,1.06l0.2,0.08l1.24,0.01l2.42,-0.65l2.77,-0.31l2.17,-0.78l1.31,-0.19l0.84,-0.43l1.03,-0.06l-0.01,4.54Z", "name": "Somaliland"}, "_2": {"path": "M384.23,230.37l0.07,-0.06l0.28,-0.89l0.99,-1.13l0.07,-0.13l0.8,-3.54l3.4,-2.8l0.09,-0.13l0.76,-2.17l0.07,5.5l-2.07,0.21l-0.24,0.17l-0.61,1.36l-0.02,0.16l0.43,3.46l-4.01,-0.01ZM391.82,218.2l0.07,-0.06l0.75,-1.93l1.86,-0.25l0.94,0.34l1.14,0.0l0.18,-0.06l0.73,-0.56l1.41,-0.08l-0.0,2.72l-7.08,-0.12Z", "name": "Western Sahara"}, "_1": {"path": "M472.71,172.84l-0.07,-0.43l-0.16,-0.22l-0.53,-0.27l-0.38,-0.58l0.3,-0.43l0.51,-0.19l0.18,-0.18l0.3,-0.87l0.12,-0.04l0.22,0.26l0.12,0.09l0.38,0.15l0.28,0.41l0.15,0.12l0.34,0.12l0.43,0.5l0.15,0.07l-0.12,0.3l-0.27,0.32l-0.03,0.18l-0.31,0.06l-1.48,0.47l-0.15,0.17Z", "name": "Kosovo"}, "_0": {"path": "M503.54,192.92l0.09,-0.17l0.41,0.01l-0.08,0.01l-0.42,0.15ZM504.23,192.76l1.02,0.02l0.4,-0.13l-0.09,0.29l0.03,0.08l-0.35,0.16l-0.24,-0.04l-0.06,-0.1l-0.18,-0.17l-0.19,-0.08l-0.33,-0.02Z", "name": "Northern Cyprus"}, "JO": {"path": "M510.26,200.93l0.28,-0.57l2.53,1.0l0.27,-0.02l4.57,-2.77l0.84,2.84l-0.28,0.25l-4.95,1.37l-0.14,0.49l2.24,2.48l-0.5,0.28l-0.13,0.14l-0.35,0.78l-1.76,0.35l-0.2,0.14l-0.57,0.94l-0.94,0.73l-2.45,-0.38l-0.03,-0.12l1.23,-4.32l-0.04,-1.1l0.34,-0.75l0.03,-0.12l0.0,-1.63Z", "name": "Jordan"}, "HR": {"path": "M455.49,162.73l1.53,0.09l0.24,-0.1l0.29,-0.34l0.64,0.38l0.14,0.04l0.98,0.06l0.32,-0.3l-0.01,-0.66l0.67,-0.25l0.19,-0.22l0.21,-1.11l1.72,-0.72l0.65,0.32l1.94,1.37l2.07,0.6l0.22,-0.02l0.67,-0.33l0.47,0.94l0.67,0.76l-0.63,0.77l-0.91,-0.55l-0.16,-0.04l-1.69,0.04l-2.2,-0.51l-1.17,0.07l-0.21,0.11l-0.36,0.42l-0.67,-0.53l-0.46,0.12l-0.52,1.29l0.05,0.31l1.21,1.42l0.58,0.99l1.15,1.14l0.95,0.68l0.92,1.23l0.1,0.09l1.75,0.91l-1.87,-0.89l-1.5,-1.11l-2.23,-0.88l-1.77,-1.9l0.12,-0.06l0.1,-0.47l-1.07,-1.22l-0.04,-0.94l-0.21,-0.27l-1.61,-0.49l-0.35,0.14l-0.53,0.93l-0.41,-0.57l0.04,-0.73Z", "name": "Croatia"}, "HT": {"path": "M237.82,234.68l1.35,0.1l1.95,0.37l0.18,1.15l-0.16,0.83l-0.51,0.37l-0.06,0.44l0.57,0.68l-0.02,0.22l-1.31,-0.35l-1.26,0.17l-1.49,-0.18l-0.15,0.02l-1.03,0.43l-1.02,-0.61l0.09,-0.36l2.04,0.32l1.9,0.21l0.19,-0.05l0.9,-0.58l0.05,-0.47l-1.05,-1.03l0.02,-0.86l-0.23,-0.3l-1.13,-0.29l0.18,-0.23Z", "name": "Haiti"}, "HU": {"path": "M461.96,157.92l0.68,-1.66l-0.03,-0.29l-0.15,-0.22l0.84,-0.0l0.3,-0.26l0.12,-0.84l0.88,0.57l0.98,0.38l0.16,0.01l2.1,-0.39l0.23,-0.21l0.14,-0.45l0.88,-0.1l1.06,-0.43l0.13,0.1l0.28,0.04l1.18,-0.4l0.14,-0.1l0.52,-0.67l0.63,-0.15l2.6,0.95l0.26,-0.03l0.38,-0.23l1.12,0.7l0.1,0.49l-1.31,0.57l-0.14,0.13l-1.18,2.14l-1.44,2.04l-1.85,0.55l-1.51,-0.13l-0.14,0.02l-1.92,0.82l-0.85,0.42l-1.91,-0.55l-1.83,-1.31l-0.74,-0.37l-0.44,-0.97l-0.26,-0.18Z", "name": "Hungary"}, "HN": {"path": "M202.48,251.87l-0.33,-0.62l-0.18,-0.14l-0.5,-0.15l0.13,-0.76l-0.11,-0.28l-0.34,-0.28l-0.6,-0.23l-0.18,-0.01l-0.81,0.22l-0.16,-0.24l-0.72,-0.39l-0.51,-0.48l-0.12,-0.07l-0.31,-0.09l0.24,-0.3l0.04,-0.3l-0.16,-0.4l0.1,-0.28l1.14,-0.69l1.0,-0.86l0.09,0.04l0.3,-0.05l0.47,-0.39l0.49,-0.03l0.14,0.13l0.29,0.06l0.31,-0.1l1.16,0.22l1.24,-0.08l0.81,-0.28l0.29,-0.25l0.63,0.1l0.69,0.18l0.65,-0.06l0.49,-0.2l1.04,0.32l0.38,0.06l0.7,0.44l0.71,0.56l0.92,0.41l0.1,0.11l-0.11,-0.01l-0.23,0.09l-0.3,0.3l-0.76,0.29l-0.58,0.0l-0.15,0.04l-0.45,0.26l-0.31,-0.07l-0.37,-0.34l-0.28,-0.07l-0.26,0.07l-0.18,0.15l-0.23,0.43l-0.04,-0.0l-0.33,0.28l-0.03,0.4l-0.76,0.61l-0.45,0.3l-0.15,0.16l-0.51,-0.36l-0.41,0.06l-0.45,0.56l-0.41,-0.01l-0.59,0.06l-0.27,0.31l0.04,0.96l-0.07,0.0l-0.25,0.16l-0.24,0.45l-0.42,0.06Z", "name": "Honduras"}, "PR": {"path": "M254.95,238.31l1.15,0.21l0.2,0.23l-0.36,0.36l-1.76,-0.01l-1.2,0.07l-0.09,-0.69l0.17,-0.18l1.89,0.01Z", "name": "Puerto Rico"}, "PS": {"path": "M509.66,201.06l-0.0,1.44l-0.29,0.63l-0.59,0.19l0.02,-0.11l0.52,-0.31l-0.02,-0.53l-0.41,-0.2l0.36,-1.28l0.41,0.17Z", "name": "West Bank"}, "PT": {"path": "M398.65,173.6l0.75,-0.63l0.7,-0.3l0.51,1.2l0.28,0.18l1.48,-0.0l0.2,-0.08l0.33,-0.3l1.16,0.08l0.52,1.11l-0.95,0.66l-0.13,0.24l-0.03,2.2l-0.33,0.35l-0.08,0.18l-0.08,1.17l-0.86,0.19l-0.2,0.44l0.93,1.64l-0.64,1.79l0.07,0.31l0.72,0.72l-0.24,0.56l-0.9,1.05l-0.07,0.26l0.17,0.77l-0.73,0.54l-1.18,-0.36l-0.16,-0.0l-0.85,0.21l0.31,-1.81l-0.23,-1.87l-0.23,-0.25l-0.99,-0.24l-0.49,-0.91l0.18,-1.72l0.93,-0.99l0.08,-0.16l0.17,-1.17l0.52,-1.76l-0.04,-1.36l-0.51,-1.14l-0.09,-0.8Z", "name": "Portugal"}, "PY": {"path": "M264.33,341.43l0.93,-2.96l0.07,-1.42l1.1,-2.1l4.19,-0.73l2.22,0.04l2.12,1.21l0.07,0.76l0.7,1.38l-0.16,3.48l0.24,0.31l2.64,0.5l0.19,-0.03l0.9,-0.45l1.47,0.62l0.38,0.64l0.23,2.35l0.3,1.07l0.25,0.21l0.93,0.12l0.16,-0.02l0.8,-0.37l0.61,0.33l-0.0,1.25l-0.33,1.53l-0.5,1.57l-0.39,2.26l-2.14,1.94l-1.85,0.4l-2.74,-0.4l-2.13,-0.62l2.26,-3.75l0.03,-0.24l-0.36,-1.18l-0.17,-0.19l-2.55,-1.03l-3.04,-1.95l-2.07,-0.43l-4.4,-4.12Z", "name": "Paraguay"}, "PA": {"path": "M213.65,263.79l0.18,-0.43l0.02,-0.18l-0.06,-0.28l0.23,-0.18l-0.01,-0.48l-0.4,-0.29l-0.01,-0.62l0.57,-0.13l0.68,0.69l-0.04,0.39l0.26,0.33l1.0,0.11l0.27,-0.1l0.49,0.44l0.24,0.07l1.34,-0.22l1.04,-0.62l1.49,-0.5l0.86,-0.73l0.99,0.11l0.18,0.28l1.35,0.08l1.02,0.4l0.78,0.72l0.71,0.53l-0.1,0.12l-0.05,0.3l0.53,1.34l-0.28,0.44l-0.6,-0.13l-0.36,0.22l-0.2,0.76l-0.41,-0.36l-0.44,-1.12l0.49,-0.53l-0.14,-0.49l-0.51,-0.14l-0.41,-0.72l-0.11,-0.11l-1.25,-0.7l-0.19,-0.04l-1.1,0.16l-0.22,0.15l-0.47,0.81l-0.9,0.56l-0.49,0.08l-0.22,0.17l-0.25,0.52l0.05,0.32l0.93,1.07l-0.41,0.21l-0.29,0.3l-0.81,0.09l-0.36,-1.26l-0.53,-0.1l-0.21,0.28l-0.5,-0.09l-0.44,-0.88l-0.22,-0.16l-0.99,-0.16l-0.61,-0.28l-0.13,-0.03l-1.0,0.0Z", "name": "Panama"}, "PG": {"path": "M808.4,298.6l0.62,0.46l1.19,1.56l1.04,0.77l-0.18,0.37l-0.42,0.15l-0.92,-0.82l-1.05,-1.53l-0.27,-0.96ZM804.09,296.06l-0.3,0.26l-0.36,-1.11l-0.66,-1.06l-2.55,-1.89l-1.42,-0.59l0.17,-0.15l1.16,0.6l0.85,0.55l1.01,0.58l0.97,1.02l0.9,0.76l0.24,1.03ZM796.71,297.99l0.15,0.82l0.34,0.24l1.43,-0.19l0.19,-0.11l0.68,-0.82l1.36,-0.87l0.13,-0.31l-0.21,-1.13l1.04,-0.03l0.3,0.25l-0.04,1.17l-0.74,1.34l-1.17,0.18l-0.22,0.15l-0.35,0.62l-2.51,1.13l-1.21,-0.0l-1.99,-0.71l-1.19,-0.58l0.07,-0.28l1.98,0.32l1.46,-0.2l0.24,-0.21l0.25,-0.79ZM789.24,303.52l0.11,0.15l2.19,1.62l1.6,2.62l0.27,0.14l1.09,-0.06l-0.07,0.77l0.23,0.32l1.23,0.27l-0.14,0.09l0.05,0.53l2.39,0.95l-0.11,0.28l-1.33,0.14l-0.51,-0.55l-0.18,-0.09l-4.59,-0.65l-1.87,-1.55l-1.38,-1.35l-1.28,-2.17l-0.16,-0.13l-3.27,-1.1l-0.19,0.0l-2.12,0.72l-1.58,0.85l-0.15,0.31l0.28,1.63l-1.65,0.73l-1.37,-0.4l-2.3,-0.09l-0.08,-15.65l3.95,1.57l4.58,1.42l1.67,1.25l1.32,1.19l0.36,1.39l0.19,0.21l4.06,1.51l0.39,0.85l-1.9,0.22l-0.25,0.39l0.55,1.68Z", "name": "Papua New Guinea"}, "PE": {"path": "M246.44,329.21l-0.63,1.25l-1.05,0.54l-2.25,-1.33l-0.19,-0.93l-0.16,-0.21l-4.95,-2.58l-4.46,-2.79l-1.87,-1.52l-0.94,-1.91l0.33,-0.6l-0.01,-0.31l-2.11,-3.33l-2.46,-4.66l-2.36,-5.02l-1.04,-1.18l-0.77,-1.81l-0.08,-0.11l-1.95,-1.64l-1.54,-0.88l0.61,-0.85l0.02,-0.31l-1.15,-2.27l0.69,-1.56l1.59,-1.26l0.12,0.42l-0.56,0.47l-0.11,0.25l0.07,0.92l0.36,0.27l0.97,-0.19l0.85,0.23l0.99,1.19l0.41,0.05l1.42,-1.03l0.11,-0.16l0.46,-1.64l1.45,-2.06l2.92,-0.96l0.11,-0.07l2.73,-2.62l0.84,-1.72l0.02,-0.18l-0.3,-1.65l0.28,-0.1l1.49,1.06l0.77,1.14l0.1,0.09l1.08,0.6l1.43,2.55l0.21,0.15l1.86,0.31l0.18,-0.03l1.25,-0.6l0.77,0.37l0.17,0.03l1.4,-0.2l1.57,0.96l-1.45,2.29l0.23,0.46l0.63,0.05l0.66,0.7l-1.51,-0.08l-0.24,0.1l-0.27,0.31l-1.96,0.46l-2.95,1.74l-0.14,0.21l-0.17,1.1l-0.6,0.82l-0.05,0.23l0.21,1.13l-1.31,0.63l-0.17,0.27l0.0,0.91l-0.53,0.37l-0.1,0.37l1.04,2.27l1.31,1.46l-0.44,0.9l0.24,0.43l1.52,0.13l0.87,1.23l0.24,0.13l2.21,0.07l0.18,-0.06l1.55,-1.13l-0.14,3.22l0.23,0.3l1.14,0.29l0.16,-0.0l1.18,-0.36l1.97,3.71l-0.45,0.71l-0.04,0.14l-0.12,1.8l-0.05,2.07l-0.92,1.2l-0.03,0.31l0.38,0.8l-0.48,0.72l-0.02,0.3l1.01,2.02l-1.5,2.64Z", "name": "Peru"}, "PK": {"path": "M609.08,187.76l1.66,1.21l0.71,2.11l0.2,0.19l3.62,1.01l-1.98,1.95l-2.65,0.4l-3.75,-0.68l-0.26,0.08l-1.23,1.22l-0.07,0.31l0.89,2.46l0.88,1.92l0.1,0.12l1.67,1.14l-1.8,1.35l-0.12,0.25l0.04,1.85l-2.35,2.67l-1.59,2.79l-2.5,2.72l-2.76,-0.2l-0.24,0.09l-2.76,2.83l0.04,0.45l1.54,1.13l0.27,1.94l0.09,0.17l1.34,1.29l0.4,1.83l-5.14,-0.01l-0.22,0.09l-1.53,1.63l-1.52,-0.56l-0.76,-1.88l-1.93,-2.03l-0.25,-0.09l-4.6,0.5l-4.05,0.05l-3.1,0.33l0.77,-2.53l3.48,-1.33l0.19,-0.33l-0.21,-1.24l-0.19,-0.23l-1.01,-0.37l-0.06,-2.18l-0.17,-0.26l-2.32,-1.16l-0.96,-1.57l-0.56,-0.65l3.16,1.05l0.14,0.01l2.45,-0.4l1.44,0.33l0.3,-0.1l0.4,-0.47l1.58,0.22l0.14,-0.01l3.25,-1.14l0.2,-0.27l0.08,-2.23l1.23,-1.38l1.73,0.0l0.28,-0.2l0.22,-0.61l1.68,-0.32l0.86,0.24l0.27,-0.05l0.98,-0.78l0.11,-0.26l-0.13,-1.57l0.96,-1.52l1.51,-0.67l0.14,-0.41l-0.74,-1.4l1.86,0.07l0.26,-0.13l0.69,-1.01l0.05,-0.2l-0.09,-0.94l1.14,-1.09l0.09,-0.28l-0.29,-1.41l-0.51,-1.07l1.23,-1.05l2.6,-0.58l2.86,-0.33l1.33,-0.54l1.3,-0.29Z", "name": "Pakistan"}, "PH": {"path": "M737.11,263.82l0.25,1.66l0.14,1.34l-0.54,1.46l-0.64,-1.79l-0.5,-0.1l-1.17,1.28l-0.05,0.32l0.74,1.71l-0.49,0.81l-2.6,-1.28l-0.61,-1.57l0.68,-1.07l-0.07,-0.4l-1.59,-1.19l-0.42,0.06l-0.69,0.91l-1.01,-0.08l-0.21,0.06l-1.58,1.2l-0.17,-0.3l0.87,-1.88l1.48,-0.66l1.18,-0.81l0.71,0.92l0.34,0.1l1.9,-0.69l0.18,-0.18l0.34,-0.94l1.57,-0.06l0.29,-0.32l-0.1,-1.38l1.41,0.83l0.36,2.06ZM734.94,254.42l0.56,2.24l-1.41,-0.49l-0.4,0.3l0.07,0.94l0.51,1.3l-0.54,0.26l-0.08,-1.34l-0.25,-0.28l-0.56,-0.1l-0.23,-0.91l1.03,0.14l0.34,-0.31l-0.03,-0.96l-0.06,-0.18l-1.14,-1.44l1.62,0.04l0.57,0.78ZM724.68,238.33l1.48,0.71l0.33,-0.04l0.44,-0.38l0.05,0.13l-0.37,0.97l0.01,0.23l0.81,1.75l-0.59,1.92l-1.37,0.79l-0.14,0.2l-0.39,2.07l0.01,0.14l0.56,2.04l0.23,0.21l1.33,0.28l0.14,-0.0l1.0,-0.27l2.82,1.28l-0.2,1.16l0.12,0.29l0.66,0.5l-0.13,0.56l-1.54,-0.99l-0.89,-1.29l-0.49,0.0l-0.44,0.65l-1.34,-1.28l-0.26,-0.08l-2.18,0.36l-0.96,-0.44l0.09,-0.72l0.69,-0.57l-0.01,-0.47l-0.75,-0.59l-0.47,0.14l-0.15,0.43l-0.86,-1.02l-0.34,-1.02l-0.07,-1.74l0.49,0.41l0.49,-0.21l0.26,-3.99l0.73,-2.1l1.23,0.0ZM731.12,258.92l-0.82,0.75l-0.83,1.64l-0.52,0.5l-1.17,-1.33l0.36,-0.47l0.62,-0.7l0.07,-0.15l0.24,-1.35l0.73,-0.08l-0.31,1.29l0.16,0.34l0.37,-0.09l1.21,-1.6l-0.12,1.24ZM726.66,255.58l0.85,0.45l0.14,0.03l1.28,-0.0l-0.03,0.62l-1.04,0.96l-1.15,0.55l-0.05,-0.71l0.17,-1.26l-0.01,-0.13l-0.16,-0.51ZM724.92,252.06l-0.45,1.5l-0.7,-0.83l-0.95,-1.43l1.44,0.06l0.67,0.7ZM717.48,261.28l-1.87,1.35l0.21,-0.3l1.81,-1.57l1.5,-1.75l0.97,-1.84l0.23,1.08l-1.56,1.33l-1.29,1.7Z", "name": "Philippines"}, "PL": {"path": "M458.8,144.25l-0.96,-1.98l0.18,-1.06l-0.01,-0.15l-0.62,-1.8l-0.82,-1.11l0.56,-0.73l0.05,-0.28l-0.51,-1.51l1.48,-0.87l3.88,-1.58l3.06,-1.14l2.23,0.52l0.15,0.66l0.29,0.23l2.4,0.04l3.11,0.39l4.56,-0.05l1.12,0.32l0.51,0.89l0.1,1.45l0.03,0.12l0.66,1.23l-0.01,1.08l-1.33,0.61l-0.14,0.41l0.74,1.5l0.07,1.53l1.22,2.79l-0.19,0.66l-1.09,0.33l-0.14,0.09l-2.27,2.72l-0.04,0.31l0.35,0.8l-2.22,-1.16l-0.21,-0.02l-1.72,0.44l-1.1,-0.31l-0.21,0.02l-1.3,0.61l-1.11,-1.02l-0.32,-0.05l-0.81,0.35l-1.15,-1.61l-0.21,-0.12l-1.65,-0.17l-0.19,-0.82l-0.23,-0.23l-1.72,-0.37l-0.34,0.17l-0.25,0.56l-0.88,-0.44l0.12,-0.69l-0.25,-0.35l-1.78,-0.27l-1.08,-0.97Z", "name": "Poland"}, "ZM": {"path": "M502.81,308.32l1.09,1.04l0.58,1.94l-0.39,0.66l-0.5,2.05l-0.0,0.14l0.45,1.95l-0.69,0.77l-0.06,0.11l-0.76,2.37l0.15,0.36l0.62,0.31l-6.85,1.9l-0.22,0.33l0.2,1.54l-1.62,0.3l-0.12,0.05l-1.43,1.02l-0.11,0.15l-0.25,0.73l-0.73,0.17l-0.14,0.08l-2.18,2.12l-1.33,1.6l-0.65,0.05l-0.83,-0.29l-2.75,-0.28l-0.24,-0.1l-0.15,-0.27l-0.99,-0.58l-0.12,-0.04l-1.73,-0.14l-1.88,0.54l-1.5,-1.48l-1.61,-2.01l0.11,-7.73l4.92,0.03l0.29,-0.37l-0.19,-0.79l0.34,-0.86l0.0,-0.21l-0.41,-1.11l0.26,-1.14l-0.01,-0.16l-0.12,-0.36l0.18,0.01l0.1,0.56l0.31,0.25l1.14,-0.06l1.44,0.21l0.76,1.05l0.19,0.12l2.01,0.35l0.19,-0.03l1.24,-0.65l0.44,1.03l0.22,0.18l1.81,0.34l0.85,0.99l1.02,1.39l0.24,0.12l1.92,0.02l0.3,-0.32l-0.21,-2.74l-0.47,-0.23l-0.53,0.36l-1.58,-0.89l-0.51,-0.34l0.29,-2.36l0.44,-2.99l-0.03,-0.18l-0.5,-0.99l0.61,-1.38l0.53,-0.24l3.26,-0.41l0.89,0.23l1.01,0.62l1.04,0.44l1.6,0.43l1.35,0.72Z", "name": "Zambia"}, "EE": {"path": "M482.19,120.88l0.23,-1.68l-0.43,-0.31l-0.75,0.37l-1.34,-1.1l-0.18,-1.75l2.92,-0.95l3.07,-0.53l2.66,0.6l2.48,-0.1l0.18,0.31l-1.65,1.96l-0.06,0.26l0.71,3.25l-0.88,0.94l-1.85,-0.01l-2.08,-1.3l-1.14,-0.47l-0.2,-0.01l-1.69,0.51Z", "name": "Estonia"}, "EG": {"path": "M508.07,208.8l-0.66,1.06l-0.53,2.03l-0.64,1.32l-0.32,0.26l-1.74,-1.85l-1.77,-3.86l-0.48,-0.09l-0.26,0.25l-0.07,0.32l1.04,2.88l1.55,2.76l1.89,4.18l0.94,1.48l0.83,1.54l2.08,2.73l-0.3,0.28l-0.1,0.23l0.08,1.72l0.11,0.22l2.91,2.37l-28.78,0.0l0.0,-19.06l-0.73,-2.2l0.61,-1.59l0.0,-0.2l-0.34,-1.04l0.73,-1.08l3.13,-0.04l2.36,0.72l2.48,0.81l1.15,0.43l0.23,-0.01l1.93,-0.87l1.02,-0.78l2.08,-0.21l1.59,0.31l0.62,1.24l0.52,0.03l0.46,-0.71l1.86,0.59l1.95,0.16l0.17,-0.04l0.92,-0.52l1.48,4.24Z", "name": "Egypt"}, "ZA": {"path": "M467.06,373.27l-0.13,-0.29l0.01,-1.58l-0.02,-0.12l-0.71,-1.64l0.59,-0.37l0.14,-0.26l-0.07,-2.13l-0.05,-0.15l-1.63,-2.58l-1.25,-2.31l-1.71,-3.37l0.88,-0.98l0.7,0.52l0.39,1.08l0.23,0.19l1.1,0.19l1.55,0.51l0.14,0.01l1.35,-0.2l0.11,-0.04l2.24,-1.39l0.14,-0.25l0.0,-9.4l0.16,0.09l1.39,2.38l-0.22,1.53l0.04,0.19l0.56,0.94l0.3,0.14l1.79,-0.27l0.16,-0.08l1.23,-1.18l1.17,-0.79l0.1,-0.12l0.57,-1.19l1.02,-0.52l0.9,0.28l1.16,0.73l0.14,0.05l2.04,0.13l0.13,-0.02l1.6,-0.62l0.18,-0.19l0.63,-1.93l1.18,-0.19l0.19,-0.12l0.78,-1.05l0.81,-1.71l2.18,-1.91l3.44,-1.88l0.89,0.02l1.17,0.43l0.21,-0.0l0.76,-0.29l1.07,0.21l1.15,3.55l0.63,1.82l-0.44,2.9l0.1,0.52l-0.74,-0.29l-0.18,-0.01l-0.72,0.19l-0.21,0.2l-0.22,0.74l-0.66,0.97l-0.05,0.18l0.02,0.93l0.09,0.21l1.49,1.46l0.27,0.08l1.47,-0.29l0.22,-0.18l0.43,-1.01l1.29,0.02l-0.51,1.63l-0.29,2.2l-0.59,1.12l-2.2,1.78l-1.06,1.39l-0.72,1.44l-1.39,1.93l-2.81,2.84l-1.75,1.65l-1.85,1.24l-2.55,1.06l-1.23,0.14l-0.24,0.18l-0.22,0.54l-1.27,-0.35l-0.2,0.01l-1.15,0.5l-2.62,-0.52l-0.12,0.0l-1.46,0.33l-0.98,-0.14l-0.16,0.02l-2.55,1.1l-2.11,0.44l-1.59,1.07l-0.93,0.06l-0.97,-0.92l-0.19,-0.08l-0.72,-0.04l-1.0,-1.16l-0.25,0.05ZM493.72,359.24l-1.12,-0.86l-0.31,-0.03l-1.23,0.59l-1.36,1.07l-1.39,1.78l0.01,0.38l1.88,2.11l0.31,0.09l0.9,-0.27l0.18,-0.15l0.4,-0.77l1.28,-0.39l0.18,-0.16l0.42,-0.88l0.76,-1.32l-0.05,-0.37l-0.87,-0.82Z", "name": "South Africa"}, "EC": {"path": "M220.2,293.48l1.25,-1.76l0.02,-0.31l-0.54,-1.09l-0.5,-0.06l-0.78,0.94l-1.03,-0.75l0.33,-0.46l0.05,-0.23l-0.38,-2.04l0.66,-0.28l0.17,-0.19l0.45,-1.52l0.93,-1.58l0.04,-0.2l-0.13,-0.78l1.19,-0.47l1.57,-0.91l2.35,1.34l0.17,0.04l0.28,-0.02l0.52,0.91l0.21,0.15l2.12,0.35l0.2,-0.03l0.55,-0.31l1.08,0.73l0.97,0.54l0.31,1.67l-0.71,1.49l-2.64,2.54l-2.95,0.97l-0.15,0.11l-1.53,2.18l-0.49,1.68l-1.1,0.8l-0.87,-1.05l-0.15,-0.1l-1.01,-0.27l-0.13,-0.0l-0.7,0.14l-0.03,-0.43l0.6,-0.5l0.1,-0.31l-0.26,-0.91Z", "name": "Ecuador"}, "AL": {"path": "M470.27,171.7l0.38,0.19l0.45,-0.18l0.4,0.61l0.11,0.1l0.46,0.24l0.13,0.87l-0.3,0.95l-0.0,0.17l0.36,1.28l0.12,0.17l0.9,0.63l-0.03,0.44l-0.67,0.35l-0.16,0.22l-0.14,0.88l-0.96,1.18l-0.06,-0.03l-0.04,-0.48l-0.12,-0.22l-1.28,-0.92l-0.19,-1.25l0.2,-1.96l0.33,-0.89l-0.06,-0.3l-0.36,-0.41l-0.13,-0.75l0.66,-0.9Z", "name": "Albania"}, "AO": {"path": "M461.62,299.93l0.55,1.67l0.73,1.54l1.56,2.18l0.28,0.12l1.66,-0.2l0.81,-0.34l1.28,0.33l0.33,-0.14l0.39,-0.67l0.56,-1.3l1.37,-0.09l0.27,-0.21l0.07,-0.23l0.67,-0.01l-0.13,0.53l0.29,0.37l2.74,-0.02l0.04,1.29l0.03,0.13l0.46,0.87l-0.35,1.52l0.18,1.55l0.07,0.16l0.75,0.85l-0.13,2.89l0.41,0.29l0.56,-0.21l1.11,0.05l1.5,-0.37l0.9,0.12l0.18,0.53l-0.27,1.15l0.01,0.17l0.4,1.08l-0.33,0.85l-0.01,0.18l0.12,0.51l-4.83,-0.03l-0.3,0.3l-0.12,8.13l0.07,0.19l1.69,2.1l1.27,1.25l-4.03,0.92l-5.93,-0.36l-1.66,-1.19l-0.18,-0.06l-10.15,0.11l-0.34,0.13l-1.35,-1.05l-0.17,-0.06l-1.62,-0.08l-1.6,0.45l-0.88,0.36l-0.17,-1.2l0.34,-2.19l0.85,-2.32l0.14,-1.13l0.79,-2.24l0.57,-1.0l1.42,-1.64l0.82,-1.15l0.05,-0.13l0.26,-1.88l-0.13,-1.51l-0.07,-0.16l-0.72,-0.87l-1.23,-2.91l0.09,-0.37l0.73,-0.95l0.05,-0.27l-1.27,-4.12l-1.19,-1.54l0.1,-0.2l0.86,-0.28l0.78,0.03l0.83,-0.29l7.12,0.03ZM451.81,298.94l-0.17,0.07l-0.5,-1.42l0.85,-0.92l0.53,-0.29l0.48,0.44l-0.56,0.32l-0.1,0.1l-0.41,0.65l-0.05,0.14l-0.07,0.91Z", "name": "Angola"}, "KZ": {"path": "M598.42,172.08l-1.37,0.54l-3.3,2.09l-0.11,0.12l-1.01,1.97l-0.56,0.01l-0.6,-1.24l-0.26,-0.17l-2.95,-0.09l-0.46,-2.22l-0.29,-0.24l-0.91,-0.02l0.17,-2.72l-0.12,-0.26l-3.0,-2.22l-0.2,-0.06l-4.29,0.24l-2.8,0.42l-2.36,-2.7l-6.4,-3.65l-0.23,-0.03l-6.45,1.83l-0.22,0.29l0.1,10.94l-0.84,0.1l-1.65,-2.21l-0.11,-0.09l-1.69,-0.84l-0.2,-0.02l-2.84,0.63l-0.14,0.07l-0.71,0.64l-0.02,-0.11l0.57,-1.17l0.0,-0.26l-0.48,-1.05l-0.17,-0.16l-2.78,-0.99l-1.08,-2.62l-0.13,-0.15l-1.24,-0.7l-0.04,-0.48l2.07,0.25l0.34,-0.29l0.09,-2.03l1.84,-0.44l2.12,0.45l0.36,-0.25l0.45,-3.04l-0.45,-2.06l-0.31,-0.23l-2.44,0.15l-2.07,-0.75l-0.23,0.01l-2.88,1.38l-2.21,0.62l-0.96,-0.38l0.22,-1.39l-0.06,-0.23l-1.6,-2.12l-0.25,-0.12l-1.72,0.08l-1.87,-1.91l1.33,-2.24l-0.06,-0.38l-0.55,-0.5l1.72,-3.08l2.3,1.7l0.48,-0.2l0.29,-2.26l4.99,-3.48l3.76,-0.08l5.46,2.27l2.96,1.33l0.26,-0.01l2.59,-1.36l3.82,-0.06l3.13,1.67l0.38,-0.09l0.63,-0.85l3.36,0.14l0.29,-0.19l0.63,-1.57l-0.13,-0.37l-3.64,-2.05l2.0,-1.36l0.1,-0.38l-0.32,-0.62l2.09,-0.76l0.13,-0.47l-1.65,-2.13l0.89,-0.91l9.27,-1.18l0.13,-0.05l1.17,-0.82l6.2,-1.27l2.26,-1.43l4.19,0.7l0.74,3.39l0.38,0.22l2.52,-0.81l2.9,1.06l-0.18,1.63l0.32,0.33l2.52,-0.23l5.0,-2.58l0.03,0.39l3.16,2.62l5.57,8.48l0.49,0.02l1.18,-1.53l3.22,1.78l0.21,0.03l3.5,-0.83l1.21,0.52l1.16,1.82l0.15,0.12l1.67,0.61l1.01,1.32l0.28,0.11l3.04,-0.41l1.1,1.64l-1.68,1.89l-1.97,0.28l-0.26,0.29l-0.12,3.09l-1.2,1.23l-4.81,-1.01l-0.35,0.2l-1.77,5.51l-1.14,0.62l-4.92,1.23l-0.2,0.41l2.14,5.06l-1.45,0.67l-0.17,0.31l0.15,1.28l-1.05,-0.3l-1.21,-1.04l-0.17,-0.07l-3.73,-0.32l-4.15,-0.08l-0.92,0.31l-3.46,-1.24l-0.22,0.01l-1.42,0.63l-0.17,0.21l-0.32,1.49l-3.82,-0.97l-0.15,0.0l-1.65,0.43l-0.2,0.17l-0.51,1.21Z", "name": "Kazakhstan"}, "ET": {"path": "M516.0,247.63l1.21,0.92l0.3,0.04l1.3,-0.53l0.46,0.41l0.19,0.08l1.65,0.03l2.05,0.96l0.67,0.88l1.07,0.79l1.0,1.45l0.7,0.68l-0.72,0.92l-0.85,1.19l-0.04,0.25l0.19,0.67l0.04,0.74l0.29,0.28l1.4,0.04l0.55,-0.15l0.23,0.19l-0.41,0.67l0.01,0.32l0.92,1.39l0.93,1.23l0.99,0.94l0.1,0.06l8.19,2.99l1.51,0.01l-6.51,6.95l-3.14,0.11l-0.18,0.06l-2.15,1.71l-1.51,0.04l-0.22,0.1l-0.6,0.69l-1.46,-0.0l-0.93,-0.78l-0.32,-0.04l-2.29,1.05l-0.12,0.1l-0.64,0.9l-1.44,-0.17l-0.51,-0.26l-0.17,-0.03l-0.56,0.07l-0.68,-0.02l-3.1,-2.08l-0.17,-0.05l-1.62,0.0l-0.68,-0.65l0.0,-1.28l-0.21,-0.29l-1.19,-0.38l-1.42,-2.63l-0.13,-0.12l-1.05,-0.53l-0.46,-1.0l-1.27,-1.23l-0.17,-0.08l-1.08,-0.13l0.53,-0.9l1.17,-0.05l0.26,-0.17l0.37,-0.77l0.03,-0.14l-0.03,-2.23l0.7,-2.49l1.08,-0.65l0.14,-0.19l0.24,-1.0l1.03,-1.85l1.47,-1.22l0.09,-0.12l1.02,-2.51l0.36,-1.96l2.62,0.48l0.33,-0.18l0.63,-1.55Z", "name": "Ethiopia"}, "ZW": {"path": "M498.95,341.2l-1.16,-0.23l-0.16,0.01l-0.74,0.28l-1.11,-0.41l-1.02,-0.04l-1.52,-1.13l-0.12,-0.05l-1.79,-0.37l-0.65,-1.46l-0.01,-0.86l-0.22,-0.29l-0.99,-0.26l-2.74,-2.77l-0.77,-1.46l-0.52,-0.5l-0.72,-1.54l2.24,0.23l0.78,0.28l0.12,0.02l0.85,-0.06l0.21,-0.11l1.38,-1.66l2.11,-2.05l0.81,-0.18l0.22,-0.2l0.27,-0.8l1.29,-0.93l1.53,-0.28l0.11,0.66l0.3,0.25l2.02,-0.05l1.04,0.48l0.5,0.59l0.18,0.1l1.13,0.18l1.11,0.7l0.01,3.06l-0.49,1.82l-0.11,1.94l0.03,0.16l0.35,0.68l-0.24,1.3l-0.27,0.17l-0.12,0.15l-0.64,1.83l-2.49,2.8Z", "name": "Zimbabwe"}, "ES": {"path": "M398.67,172.8l0.09,-1.45l-0.06,-0.2l-0.82,-1.05l3.16,-1.96l3.01,0.54l3.33,-0.02l2.64,0.52l2.14,-0.15l3.9,0.1l0.91,1.08l0.14,0.09l4.61,1.38l0.26,-0.04l0.77,-0.55l2.66,1.29l0.17,0.03l2.59,-0.35l0.1,1.28l-2.2,1.85l-3.13,0.62l-0.23,0.23l-0.21,0.92l-1.54,1.68l-0.97,2.4l0.02,0.26l0.85,1.46l-1.27,1.14l-0.09,0.14l-0.5,1.73l-1.73,0.53l-0.15,0.1l-1.68,2.1l-3.03,0.04l-2.38,-0.05l-0.17,0.05l-1.57,1.01l-0.9,1.01l-0.96,-0.19l-0.82,-0.86l-0.69,-1.6l-0.22,-0.18l-2.14,-0.41l-0.13,-0.62l0.83,-0.97l0.39,-0.86l-0.06,-0.33l-0.73,-0.73l0.63,-1.74l-0.02,-0.25l-0.8,-1.41l0.69,-0.15l0.23,-0.27l0.09,-1.29l0.33,-0.36l0.08,-0.2l0.03,-2.16l1.03,-0.72l0.1,-0.37l-0.7,-1.5l-0.25,-0.17l-1.46,-0.11l-0.22,0.07l-0.34,0.3l-1.17,0.0l-0.55,-1.29l-0.39,-0.16l-1.02,0.44l-0.45,0.36Z", "name": "Spain"}, "ER": {"path": "M527.15,253.05l-0.77,-0.74l-1.01,-1.47l-1.14,-0.86l-0.62,-0.84l-0.11,-0.09l-2.18,-1.02l-0.12,-0.03l-1.61,-0.03l-0.52,-0.46l-0.31,-0.05l-1.31,0.54l-1.38,-1.06l-0.46,0.12l-0.69,1.68l-2.49,-0.46l-0.2,-0.76l1.06,-3.69l0.24,-1.65l0.66,-0.66l1.76,-0.4l0.16,-0.1l0.97,-1.13l1.24,2.55l0.68,2.34l0.09,0.14l1.4,1.27l3.39,2.4l1.37,1.43l2.14,2.34l0.94,0.6l-0.32,0.26l-0.85,-0.17Z", "name": "Eritrea"}, "ME": {"path": "M469.05,172.9l-0.57,-0.8l-0.1,-0.09l-0.82,-0.46l0.16,-0.33l0.35,-1.57l0.72,-0.62l0.27,-0.16l0.48,0.38l0.35,0.4l0.12,0.08l0.79,0.32l0.66,0.43l-0.43,0.62l-0.28,0.11l-0.07,-0.25l-0.53,-0.1l-1.09,1.49l-0.05,0.23l0.06,0.32Z", "name": "Montenegro"}, "MD": {"path": "M488.2,153.75l0.14,-0.11l1.49,-0.28l1.75,0.95l1.06,0.14l0.92,0.7l-0.15,0.9l0.15,0.31l0.8,0.46l0.33,1.2l0.09,0.14l0.72,0.66l-0.11,0.28l0.1,0.33l-0.06,0.02l-1.25,-0.08l-0.17,-0.29l-0.39,-0.12l-0.52,0.25l-0.16,0.36l0.13,0.42l-0.6,0.88l-0.43,1.03l-0.22,0.12l-0.32,-1.0l0.25,-1.34l-0.08,-1.38l-0.06,-0.17l-1.43,-1.87l-0.81,-1.36l-0.78,-0.95l-0.12,-0.09l-0.29,-0.12Z", "name": "Moldova"}, "MG": {"path": "M544.77,316.45l0.64,1.04l0.6,1.62l0.4,3.04l0.63,1.21l-0.22,1.07l-0.15,0.26l-0.59,-1.05l-0.52,-0.01l-0.47,0.76l-0.04,0.23l0.46,1.84l-0.19,0.92l-0.61,0.53l-0.1,0.21l-0.16,2.15l-0.97,2.98l-1.24,3.59l-1.55,4.97l-0.96,3.67l-1.08,2.93l-1.94,0.61l-2.05,1.06l-3.2,-1.53l-0.62,-1.26l-0.18,-2.39l-0.87,-2.07l-0.22,-1.8l0.4,-1.69l1.01,-0.4l0.19,-0.28l0.01,-0.79l1.15,-1.91l0.04,-0.11l0.23,-1.66l-0.03,-0.17l-0.57,-1.21l-0.46,-1.58l-0.19,-2.25l0.82,-1.36l0.33,-1.51l1.11,-0.1l1.4,-0.53l0.9,-0.45l1.03,-0.03l0.21,-0.09l1.41,-1.45l2.12,-1.65l0.75,-1.29l0.03,-0.24l-0.17,-0.56l0.53,0.15l0.32,-0.1l1.38,-1.77l0.06,-0.18l0.04,-1.44l0.54,-0.74l0.62,0.77Z", "name": "Madagascar"}, "MA": {"path": "M378.66,230.13l0.07,-0.75l0.93,-0.72l0.82,-1.37l0.04,-0.21l-0.14,-0.8l0.8,-1.74l1.33,-1.61l0.79,-0.4l0.14,-0.15l0.66,-1.55l0.08,-1.46l0.83,-1.52l1.6,-0.94l0.11,-0.11l1.56,-2.71l1.2,-0.99l2.24,-0.29l0.17,-0.08l1.95,-1.83l1.3,-0.77l2.09,-2.28l0.07,-0.26l-0.61,-3.34l0.92,-2.3l0.33,-1.44l1.52,-1.79l2.48,-1.27l1.86,-1.16l0.1,-0.11l1.67,-2.93l0.72,-1.59l1.54,0.01l1.43,1.14l0.21,0.06l2.33,-0.19l2.55,0.62l0.97,0.03l0.83,1.6l0.15,1.71l0.86,2.96l0.09,0.14l0.5,0.45l-0.31,0.73l-3.11,0.44l-0.16,0.07l-1.07,0.97l-1.36,0.23l-0.25,0.28l-0.1,1.85l-2.74,1.02l-0.14,0.11l-0.9,1.3l-1.93,0.69l-2.56,0.44l-4.04,2.01l-0.17,0.27l0.02,2.91l-0.08,0.0l-0.3,0.31l0.05,1.15l-1.25,0.07l-0.16,0.06l-0.73,0.55l-0.98,0.0l-0.85,-0.33l-0.15,-0.02l-2.11,0.29l-0.24,0.19l-0.76,1.95l-0.63,0.16l-0.21,0.19l-1.15,3.29l-3.42,2.81l-0.1,0.17l-0.81,3.57l-0.98,1.12l-0.3,0.85l-5.13,0.19Z", "name": "Morocco"}, "UZ": {"path": "M587.83,186.48l0.06,-1.46l-0.19,-0.29l-3.31,-1.24l-2.57,-1.4l-1.63,-1.38l-2.79,-1.98l-1.2,-2.98l-0.12,-0.14l-0.84,-0.54l-0.18,-0.05l-2.61,0.13l-0.76,-0.48l-0.25,-2.25l-0.17,-0.24l-3.37,-1.6l-0.32,0.04l-2.08,1.73l-2.11,1.02l-0.16,0.35l0.31,1.14l-2.14,0.03l-0.09,-10.68l6.1,-1.74l6.25,3.57l2.36,2.72l0.27,0.1l2.92,-0.44l4.17,-0.23l2.78,2.06l-0.18,2.87l0.29,0.32l0.98,0.02l0.46,2.22l0.28,0.24l3.0,0.09l0.61,1.25l0.28,0.17l0.93,-0.02l0.26,-0.16l1.06,-2.06l3.21,-2.03l1.3,-0.5l0.19,0.08l-1.75,1.62l0.05,0.48l1.85,1.12l0.27,0.02l1.65,-0.69l2.4,1.27l-2.69,1.79l-1.79,-0.27l-0.89,0.06l-0.22,-0.52l0.48,-1.26l-0.34,-0.4l-3.35,0.69l-0.22,0.18l-0.78,1.87l-1.07,1.47l-1.93,-0.13l-0.29,0.16l-0.65,1.29l0.16,0.42l1.69,0.64l0.48,1.91l-1.25,2.6l-1.64,-0.53l-1.18,-0.03Z", "name": "Uzbekistan"}, "MM": {"path": "M670.1,233.39l-1.46,1.11l-1.68,0.11l-0.26,0.19l-1.1,2.7l-0.95,0.42l-0.14,0.42l1.21,2.27l1.61,1.92l0.94,1.55l-0.82,1.99l-0.77,0.42l-0.13,0.39l0.64,1.35l1.62,1.97l0.26,1.32l-0.04,1.15l0.02,0.13l0.92,2.18l-1.3,2.23l-0.79,1.69l-0.1,-0.77l0.74,-1.87l-0.02,-0.26l-0.8,-1.42l0.2,-2.68l-0.06,-0.2l-0.98,-1.27l-0.8,-2.98l-0.45,-3.22l-1.11,-2.22l-0.45,-0.1l-1.64,1.28l-2.74,1.76l-1.26,-0.2l-1.27,-0.49l0.79,-2.93l0.0,-0.14l-0.52,-2.42l-1.93,-2.97l0.26,-0.8l-0.22,-0.39l-1.37,-0.31l-1.65,-1.98l-0.12,-1.5l0.41,0.19l0.42,-0.26l0.05,-1.7l1.08,-0.54l0.16,-0.34l-0.24,-1.0l0.5,-0.79l0.05,-0.15l0.08,-2.35l1.58,0.49l0.36,-0.15l1.12,-2.19l0.15,-1.34l1.35,-2.18l0.04,-0.17l-0.07,-1.35l2.97,-1.71l1.67,0.45l0.38,-0.33l-0.18,-1.46l0.7,-0.4l0.15,-0.32l-0.13,-0.72l0.94,-0.13l0.74,1.41l0.11,0.12l0.95,0.56l0.07,1.89l-0.09,2.08l-2.28,2.15l-0.09,0.19l-0.3,3.15l0.35,0.32l2.37,-0.39l0.53,2.17l0.2,0.21l1.3,0.42l-0.63,1.9l0.14,0.36l1.86,0.99l1.1,0.49l0.24,0.0l1.45,-0.6l0.04,0.51l-2.01,1.6l-0.56,0.96l-1.34,0.56Z", "name": "Myanmar"}, "ML": {"path": "M390.79,248.2l0.67,-0.37l0.14,-0.18l0.36,-1.31l0.51,-0.04l1.68,0.69l0.21,0.0l1.34,-0.48l0.89,0.16l0.3,-0.13l0.29,-0.44l9.89,-0.04l0.29,-0.21l0.56,-1.8l-0.11,-0.33l-0.33,-0.24l-2.37,-22.1l3.41,-0.04l8.37,5.73l8.38,5.68l0.56,1.15l0.14,0.14l1.56,0.75l0.99,0.36l0.03,1.45l0.33,0.29l2.45,-0.22l0.01,5.52l-1.3,1.64l-0.06,0.15l-0.18,1.37l-1.99,0.36l-3.4,0.22l-0.19,0.09l-0.85,0.83l-1.48,0.09l-1.49,0.01l-0.54,-0.43l-0.26,-0.05l-1.38,0.36l-2.39,1.08l-0.13,0.12l-0.44,0.73l-1.88,1.11l-0.11,0.12l-0.3,0.57l-0.86,0.42l-1.1,-0.31l-0.28,0.07l-0.69,0.62l-0.09,0.16l-0.35,1.66l-1.93,2.04l-0.08,0.23l0.05,0.76l-0.63,0.99l-0.04,0.19l0.14,1.23l-0.81,0.29l-0.32,0.17l-0.27,-0.75l-0.39,-0.18l-0.65,0.26l-0.36,-0.04l-0.29,0.14l-0.37,0.6l-1.69,-0.02l-0.63,-0.34l-0.32,0.02l-0.12,0.09l-0.47,-0.45l0.1,-0.6l-0.09,-0.27l-0.31,-0.3l-0.33,-0.05l-0.05,0.02l0.02,-0.21l0.46,-0.59l-0.02,-0.39l-0.99,-1.02l-0.34,-0.74l-0.56,-0.56l-0.17,-0.09l-0.5,-0.07l-0.19,0.04l-0.58,0.35l-0.79,0.33l-0.65,0.51l-0.85,-0.16l-0.63,-0.59l-0.14,-0.07l-0.41,-0.08l-0.2,0.03l-0.59,0.31l-0.07,0.0l-0.1,-0.63l0.11,-0.85l-0.21,-0.98l-0.11,-0.17l-0.86,-0.66l-0.45,-1.34l-0.1,-1.36Z", "name": "Mali"}, "MN": {"path": "M641.06,150.59l2.41,-0.53l4.76,-2.8l3.67,-1.49l2.06,0.96l0.12,0.03l2.5,0.05l1.59,1.45l0.19,0.08l2.47,0.12l3.59,0.81l0.27,-0.07l2.43,-2.28l0.06,-0.36l-0.93,-1.77l2.33,-3.1l2.66,1.3l2.26,0.39l2.75,0.8l0.44,2.3l0.19,0.22l3.56,1.38l0.18,0.01l2.35,-0.6l3.1,-0.42l2.4,0.41l2.37,1.52l1.49,1.63l0.23,0.1l2.29,-0.03l3.13,0.52l0.15,-0.01l2.28,-0.79l3.27,-0.53l0.11,-0.04l3.56,-2.23l1.31,0.31l1.26,1.05l0.22,0.07l2.45,-0.22l-0.98,1.96l-1.77,3.21l-0.01,0.28l0.64,1.31l0.35,0.16l1.35,-0.38l2.4,0.48l0.22,-0.04l1.78,-1.09l1.82,0.92l2.11,2.07l-0.17,0.68l-1.79,-0.31l-3.74,0.45l-1.85,0.96l-1.78,2.01l-3.74,1.18l-2.46,1.61l-2.45,-0.6l-1.42,-0.28l-0.31,0.13l-1.31,1.99l0.0,0.33l0.78,1.15l0.3,0.74l-1.58,0.93l-1.75,1.59l-2.83,1.03l-3.77,0.12l-4.05,1.05l-2.81,1.54l-0.95,-0.8l-0.19,-0.07l-2.96,0.0l-3.64,-1.8l-2.55,-0.48l-3.38,0.41l-5.13,-0.67l-2.66,0.06l-1.35,-1.65l-1.12,-2.78l-0.21,-0.18l-1.5,-0.33l-2.98,-1.89l-0.12,-0.04l-3.37,-0.43l-2.84,-0.51l-0.75,-1.13l0.93,-3.54l-0.04,-0.24l-1.73,-2.55l-0.15,-0.12l-3.52,-1.18l-1.99,-1.61l-0.54,-1.85Z", "name": "Mongolia"}, "MK": {"path": "M472.73,173.87l0.08,0.01l0.32,-0.25l0.08,-0.44l1.29,-0.41l1.37,-0.28l1.03,-0.04l1.06,0.82l0.14,1.59l-0.22,0.04l-0.17,0.11l-0.32,0.4l-1.2,-0.05l-0.18,0.05l-0.9,0.61l-1.45,0.23l-0.85,-0.59l-0.3,-1.09l0.22,-0.71Z", "name": "Macedonia"}, "MW": {"path": "M507.18,313.84l-0.67,1.85l-0.01,0.16l0.7,3.31l0.31,0.24l0.75,-0.03l0.78,0.71l0.99,1.75l0.2,3.03l-0.91,0.45l-0.14,0.15l-0.59,1.38l-1.24,-1.21l-0.17,-1.62l0.49,-1.12l0.02,-0.16l-0.15,-1.03l-0.13,-0.21l-0.99,-0.65l-0.26,-0.03l-0.53,0.18l-1.31,-1.12l-1.15,-0.59l0.66,-2.06l0.75,-0.84l0.07,-0.27l-0.47,-2.04l0.48,-1.94l0.4,-0.65l0.03,-0.24l-0.64,-2.15l-0.08,-0.13l-0.44,-0.42l1.34,0.26l1.25,1.73l0.67,3.3Z", "name": "Malawi"}, "MR": {"path": "M390.54,247.66l-1.48,-1.58l-1.51,-1.88l-0.12,-0.09l-1.64,-0.67l-1.17,-0.74l-0.17,-0.05l-1.4,0.03l-0.12,0.03l-1.14,0.52l-1.15,-0.21l-0.26,0.08l-0.44,0.43l-0.11,-0.72l0.68,-1.29l0.31,-2.43l-0.28,-2.63l-0.29,-1.27l0.24,-1.24l-0.03,-0.2l-0.65,-1.24l-1.19,-1.05l0.32,-0.51l9.64,0.02l0.3,-0.34l-0.46,-3.71l0.51,-1.12l2.17,-0.22l0.27,-0.3l-0.08,-6.5l7.91,0.13l0.31,-0.3l0.01,-3.5l8.17,5.63l-2.89,0.04l-0.29,0.33l2.42,22.56l0.12,0.21l0.26,0.19l-0.43,1.38l-9.83,0.04l-0.25,0.13l-0.27,0.41l-0.77,-0.14l-0.15,0.01l-1.3,0.47l-1.64,-0.67l-0.14,-0.02l-0.79,0.06l-0.27,0.22l-0.39,1.39l-0.53,0.29Z", "name": "Mauritania"}, "UG": {"path": "M500.74,287.17l-2.84,-0.02l-0.92,0.32l-1.37,0.71l-0.29,-0.12l0.02,-1.6l0.54,-0.89l0.04,-0.13l0.14,-1.96l0.49,-1.09l0.91,-1.24l0.97,-0.68l0.8,-0.89l-0.13,-0.49l-0.79,-0.27l0.13,-2.55l0.78,-0.52l1.45,0.51l0.18,0.01l1.97,-0.57l1.72,0.01l0.18,-0.06l1.29,-0.97l0.98,1.44l0.29,1.24l1.05,2.75l-0.84,1.68l-1.94,2.66l-0.06,0.18l0.02,2.36l-4.8,0.18Z", "name": "Uganda"}, "MY": {"path": "M717.6,273.52l-1.51,0.7l-2.13,-0.41l-2.88,-0.0l-0.29,0.21l-0.84,2.77l-0.9,0.82l-0.08,0.12l-1.23,3.34l-1.81,0.47l-2.29,-0.68l-0.14,-0.01l-1.2,0.22l-0.14,0.07l-1.36,1.18l-1.47,-0.17l-0.12,0.01l-1.46,0.46l-1.51,-1.25l-0.24,-0.97l1.26,0.59l0.2,0.02l1.93,-0.47l0.22,-0.22l0.47,-1.98l0.9,-0.4l2.97,-0.54l0.17,-0.09l1.8,-1.98l1.02,-1.32l0.9,1.03l0.48,-0.04l0.43,-0.7l1.02,0.07l0.32,-0.27l0.25,-2.72l1.84,-1.67l1.23,-1.89l0.73,-0.01l1.12,1.11l0.1,0.99l0.18,0.24l1.66,0.71l1.85,0.67l-0.09,0.51l-1.45,0.11l-0.26,0.4l0.35,0.97ZM673.78,269.53l0.17,1.14l0.35,0.25l1.65,-0.3l0.18,-0.11l0.68,-0.86l0.31,0.13l1.41,1.45l0.99,1.59l0.13,1.57l-0.26,1.09l0.0,0.15l0.24,0.84l0.18,1.46l0.11,0.2l0.82,0.64l0.92,2.08l-0.03,0.52l-1.4,0.13l-2.29,-1.79l-2.86,-1.92l-0.27,-1.16l-0.07,-0.13l-1.39,-1.61l-0.33,-1.99l-0.05,-0.12l-0.84,-1.27l0.26,-1.72l-0.03,-0.18l-0.45,-0.87l0.13,-0.13l1.71,0.92Z", "name": "Malaysia"}, "MX": {"path": "M133.41,213.83l0.61,0.09l0.27,-0.09l0.93,-1.01l0.08,-0.18l0.09,-1.22l-0.09,-0.23l-1.93,-1.94l-1.46,-0.77l-2.96,-5.62l-0.86,-2.1l2.44,-0.18l2.68,-0.25l-0.03,0.08l0.17,0.4l3.79,1.35l5.81,1.97l6.96,-0.02l0.3,-0.3l0.0,-0.84l3.91,0.0l0.87,0.93l1.27,0.87l1.44,1.17l0.79,1.37l0.62,1.49l0.12,0.14l1.35,0.85l2.08,0.82l0.35,-0.1l1.49,-2.04l1.81,-0.05l1.63,1.01l1.21,1.8l0.86,1.58l1.47,1.55l0.53,1.82l0.73,1.32l0.14,0.13l1.98,0.84l1.78,0.59l0.61,-0.03l-0.78,1.89l-0.45,1.96l-0.19,3.58l-0.24,1.27l0.01,0.14l0.43,1.43l0.78,1.31l0.49,1.98l0.06,0.12l1.63,1.9l0.61,1.51l0.98,1.28l0.16,0.11l2.58,0.67l0.98,1.02l0.31,0.08l2.17,-0.71l1.91,-0.26l1.87,-0.47l1.67,-0.49l1.59,-1.06l0.11,-0.14l0.6,-1.52l0.22,-2.21l0.35,-0.62l1.58,-0.64l2.59,-0.59l2.18,0.09l1.43,-0.2l0.39,0.36l-0.07,1.02l-1.28,1.48l-0.65,1.68l0.07,0.32l0.33,0.32l-0.79,2.49l-0.28,-0.3l-0.24,-0.09l-1.0,0.08l-0.24,0.15l-0.74,1.28l-0.19,-0.13l-0.28,-0.03l-0.3,0.12l-0.19,0.29l0.0,0.06l-4.34,-0.02l-0.3,0.3l-0.0,1.16l-0.83,0.0l-0.28,0.19l0.08,0.33l0.93,0.86l0.9,0.58l0.24,0.48l0.16,0.15l0.2,0.08l-0.03,0.38l-2.94,0.01l-0.26,0.15l-1.21,2.09l0.02,0.33l0.25,0.33l-0.21,0.44l-0.04,0.22l-2.42,-2.35l-1.36,-0.87l-2.04,-0.67l-0.13,-0.01l-1.4,0.19l-2.07,0.98l-1.14,0.23l-1.72,-0.66l-1.85,-0.48l-2.31,-1.16l-1.92,-0.38l-2.79,-1.18l-2.04,-1.2l-0.6,-0.66l-0.19,-0.1l-1.37,-0.15l-2.45,-0.78l-1.07,-1.18l-2.63,-1.44l-1.2,-1.56l-0.44,-0.93l0.5,-0.15l0.2,-0.39l-0.2,-0.58l0.46,-0.55l0.07,-0.19l0.01,-0.91l-0.06,-0.18l-0.81,-1.13l-0.25,-1.08l-0.86,-1.36l-2.21,-2.63l-2.53,-2.09l-1.2,-1.63l-0.11,-0.09l-2.08,-1.06l-0.34,-0.48l0.35,-1.53l-0.16,-0.34l-1.24,-0.61l-1.39,-1.23l-0.6,-1.81l-0.24,-0.2l-1.25,-0.2l-1.38,-1.35l-1.11,-1.25l-0.1,-0.76l-0.05,-0.13l-1.33,-2.04l-0.85,-2.02l0.04,-0.99l-0.14,-0.27l-1.81,-1.1l-0.2,-0.04l-0.74,0.11l-1.34,-0.72l-0.42,0.16l-0.4,1.12l-0.0,0.19l0.41,1.3l0.24,2.04l0.06,0.15l0.88,1.16l1.84,1.86l0.4,0.61l0.12,0.1l0.27,0.14l0.29,0.82l0.31,0.2l0.2,-0.02l0.43,1.51l0.09,0.14l0.72,0.65l0.51,0.91l1.58,1.4l0.8,2.42l0.77,1.23l0.66,1.19l0.13,1.34l0.28,0.27l1.08,0.08l0.92,1.1l0.83,1.08l-0.03,0.24l-0.88,0.81l-0.13,-0.0l-0.59,-1.42l-0.07,-0.11l-1.67,-1.53l-1.81,-1.28l-1.15,-0.61l0.07,-1.85l-0.38,-1.45l-0.12,-0.17l-2.91,-2.03l-0.39,0.04l-0.11,0.11l-0.42,-0.46l-0.11,-0.08l-1.49,-0.63l-1.09,-1.16Z", "name": "Mexico"}, "VU": {"path": "M839.92,325.66l0.78,0.73l-0.18,0.07l-0.6,-0.8ZM839.13,322.74l0.27,1.36l-0.13,-0.06l-0.21,-0.02l-0.29,0.08l-0.22,-0.43l-0.03,-1.32l0.61,0.4Z", "name": "Vanuatu"}, "FR": {"path": "M444.58,172.63l-0.68,1.92l-0.72,-0.38l-0.51,-1.79l0.43,-0.95l1.15,-0.83l0.33,2.04ZM429.71,147.03l1.77,1.57l0.26,0.07l1.16,-0.23l2.12,1.44l0.56,0.28l0.16,0.03l0.61,-0.06l1.09,0.78l0.13,0.05l3.18,0.53l-1.09,1.94l-0.3,2.16l-0.48,0.38l-1.0,-0.26l-0.37,0.32l0.07,0.66l-1.73,1.68l-0.09,0.21l-0.04,1.42l0.41,0.29l0.96,-0.4l0.67,1.07l-0.09,0.78l0.04,0.19l0.61,0.97l-0.71,0.78l-0.07,0.28l0.65,2.39l0.21,0.21l1.09,0.31l-0.2,0.95l-2.08,1.58l-4.81,-0.8l-0.13,0.01l-3.65,0.99l-0.22,0.24l-0.25,1.6l-2.59,0.35l-2.74,-1.33l-0.31,0.03l-0.79,0.57l-4.38,-1.31l-0.79,-0.94l1.16,-1.64l0.05,-0.15l0.48,-6.17l-0.06,-0.21l-2.58,-3.3l-1.89,-1.65l-0.11,-0.06l-3.64,-1.17l-0.2,-1.88l2.92,-0.63l4.14,0.82l0.35,-0.36l-0.65,-3.0l1.77,1.05l0.27,0.02l5.83,-2.54l0.17,-0.19l0.71,-2.54l1.75,-0.53l0.27,0.88l0.27,0.21l1.04,0.05l1.08,1.23ZM289.1,278.45l-0.85,0.84l-0.88,0.13l-0.25,-0.51l-0.21,-0.16l-0.56,-0.1l-0.25,0.07l-0.63,0.55l-0.62,-0.29l0.5,-0.88l0.21,-1.11l0.42,-1.05l-0.03,-0.28l-0.93,-1.42l-0.18,-1.54l1.13,-1.87l2.42,0.78l2.55,2.04l0.33,0.81l-1.4,2.16l-0.77,1.84Z", "name": "France"}, "FI": {"path": "M492.26,76.42l-0.38,3.12l0.12,0.28l3.6,2.69l-2.14,2.96l-0.01,0.33l2.83,4.61l-1.61,3.36l0.03,0.31l2.15,2.87l-0.96,2.44l0.1,0.35l3.51,2.55l-0.81,1.72l-2.28,2.19l-5.28,4.79l-4.51,0.31l-4.39,1.37l-3.87,0.75l-1.34,-1.89l-0.11,-0.09l-2.23,-1.14l0.53,-3.54l-0.01,-0.14l-1.17,-3.37l1.12,-2.13l2.23,-2.44l5.69,-4.33l1.65,-0.84l0.16,-0.31l-0.26,-1.73l-0.15,-0.22l-3.4,-1.91l-0.77,-1.47l-0.07,-6.45l-0.12,-0.24l-3.91,-2.94l-3.0,-1.92l0.97,-0.76l2.6,2.17l0.21,0.07l3.2,-0.21l2.63,1.03l0.3,-0.05l2.39,-1.94l0.09,-0.13l1.18,-3.12l3.63,-1.42l2.87,1.59l-0.98,2.87Z", "name": "Finland"}, "FJ": {"path": "M869.98,327.07l-1.31,0.44l-0.14,-0.41l0.96,-0.41l0.85,-0.17l1.43,-0.78l-0.16,0.65l-1.64,0.67ZM867.58,329.12l0.54,0.47l-0.31,1.0l-1.32,0.3l-1.13,-0.26l-0.17,-0.78l0.72,-0.66l0.98,0.27l0.25,-0.04l0.43,-0.29Z", "name": "Fiji"}, "FK": {"path": "M268.15,427.89l2.6,-1.73l1.98,0.77l0.31,-0.05l1.32,-1.17l1.58,1.18l-0.54,0.84l-3.1,0.92l-1.0,-1.04l-0.39,-0.04l-1.9,1.35l-0.86,-1.04Z", "name": "Falkland Islands"}, "NI": {"path": "M202.1,252.6l0.23,-0.0l0.12,-0.11l0.68,-0.09l0.22,-0.15l0.23,-0.43l0.2,-0.01l0.28,-0.31l-0.04,-0.97l0.29,-0.03l0.5,0.02l0.25,-0.11l0.37,-0.46l0.51,0.35l0.4,-0.06l0.23,-0.28l0.45,-0.29l0.87,-0.7l0.11,-0.21l0.02,-0.26l0.23,-0.12l0.25,-0.48l0.29,0.27l0.14,0.07l0.5,0.12l0.22,-0.03l0.48,-0.28l0.66,-0.02l0.87,-0.33l0.36,-0.32l0.21,0.01l-0.11,0.48l0.0,0.14l0.22,0.8l-0.54,0.85l-0.27,1.03l-0.09,1.18l0.14,0.72l0.05,0.95l-0.24,0.15l-0.13,0.19l-0.23,1.09l0.0,0.14l0.14,0.53l-0.42,0.53l-0.06,0.24l0.12,0.69l0.08,0.15l0.18,0.19l-0.26,0.23l-0.49,-0.11l-0.35,-0.44l-0.16,-0.1l-0.79,-0.21l-0.23,0.03l-0.45,0.26l-1.51,-0.62l-0.31,0.05l-0.17,0.15l-1.81,-1.62l-0.6,-0.9l-1.04,-0.79l-0.77,-0.71Z", "name": "Nicaragua"}, "NL": {"path": "M436.22,136.65l1.82,0.08l0.36,0.89l-0.6,2.96l-0.53,1.06l-1.32,0.0l-0.3,0.34l0.35,2.89l-0.83,-0.47l-1.56,-1.43l-0.29,-0.07l-2.26,0.67l-1.02,-0.15l0.68,-0.48l0.1,-0.12l2.14,-4.84l3.25,-1.35Z", "name": "Netherlands"}, "NO": {"path": "M491.45,67.31l7.06,3.0l-2.52,0.94l-0.11,0.49l2.43,2.49l-3.82,1.59l-1.48,0.3l0.89,-2.61l-0.14,-0.36l-3.21,-1.78l-0.25,-0.02l-3.89,1.52l-0.17,0.17l-1.2,3.17l-2.19,1.78l-2.53,-0.99l-0.13,-0.02l-3.15,0.21l-2.69,-2.25l-0.38,-0.01l-1.43,1.11l-1.47,0.17l-0.26,0.26l-0.33,2.57l-4.42,-0.65l-0.33,0.22l-0.6,2.19l-2.17,-0.01l-0.27,0.16l-4.15,7.68l-3.88,5.76l-0.0,0.33l0.81,1.23l-0.7,1.27l-2.3,-0.06l-0.28,0.18l-1.63,3.72l-0.02,0.13l0.15,5.17l0.07,0.18l1.51,1.84l-0.79,4.24l-2.04,2.5l-0.92,1.75l-1.39,-1.88l-0.44,-0.05l-4.89,4.21l-3.16,0.81l-3.24,-1.74l-0.86,-3.82l-0.78,-8.6l2.18,-2.36l6.56,-3.28l5.0,-4.16l4.63,-5.74l5.99,-8.09l4.17,-3.23l6.84,-5.49l5.39,-1.92l4.06,0.24l0.23,-0.09l3.72,-3.67l4.51,0.19l4.4,-0.89ZM484.58,19.95l4.42,1.82l-3.25,2.68l-7.14,0.65l-7.16,-0.91l-0.39,-1.37l-0.28,-0.22l-3.48,-0.1l-2.25,-2.15l7.09,-1.48l3.55,1.36l0.28,-0.03l2.42,-1.66l6.18,1.41ZM481.99,33.92l-4.73,1.85l-3.76,-1.06l1.27,-1.02l0.04,-0.43l-1.18,-1.35l4.46,-0.94l0.89,1.83l0.17,0.15l2.83,0.96ZM466.5,23.95l7.64,3.87l-5.63,1.94l-0.19,0.19l-1.35,3.88l-2.08,0.96l-0.16,0.19l-1.14,4.18l-2.71,0.18l-4.94,-2.95l1.95,-1.63l-0.08,-0.51l-3.7,-1.54l-4.79,-4.54l-1.78,-4.01l6.29,-1.88l1.25,1.81l0.25,0.13l3.57,-0.08l0.26,-0.17l0.87,-1.79l3.41,-0.18l3.08,1.94Z", "name": "Norway"}, "NA": {"path": "M461.88,357.98l-1.61,-1.77l-0.94,-1.9l-0.54,-2.58l-0.62,-1.95l-0.83,-4.05l-0.06,-3.13l-0.33,-1.5l-0.07,-0.14l-0.95,-1.06l-1.27,-2.12l-1.3,-3.1l-0.59,-1.71l-1.98,-2.46l-0.13,-1.67l0.99,-0.4l1.44,-0.42l1.48,0.07l1.42,1.11l0.31,0.03l0.32,-0.15l9.99,-0.11l1.66,1.18l0.16,0.06l6.06,0.37l4.69,-1.06l2.01,-0.57l1.5,0.14l0.63,0.37l-1.0,0.41l-0.7,0.01l-0.16,0.05l-1.38,0.88l-0.79,-0.88l-0.29,-0.09l-3.83,0.9l-1.84,0.08l-0.29,0.3l-0.07,8.99l-2.18,0.08l-0.29,0.3l-0.0,17.47l-2.04,1.27l-1.21,0.18l-1.51,-0.49l-0.99,-0.18l-0.36,-1.0l-0.1,-0.14l-0.99,-0.74l-0.4,0.04l-0.98,1.09Z", "name": "Namibia"}, "NC": {"path": "M835.87,338.68l2.06,1.63l1.01,0.94l-0.49,0.32l-1.21,-0.62l-1.76,-1.16l-1.58,-1.36l-1.61,-1.79l-0.16,-0.41l0.54,0.02l1.32,0.83l1.08,0.87l0.79,0.73Z", "name": "New Caledonia"}, "NE": {"path": "M426.67,254.17l0.03,-1.04l-0.24,-0.3l-2.66,-0.53l-0.06,-1.0l-0.07,-0.17l-1.37,-1.62l-0.3,-1.04l0.15,-0.94l1.37,-0.09l0.19,-0.09l0.85,-0.83l3.34,-0.22l2.22,-0.41l0.24,-0.26l0.2,-1.5l1.32,-1.65l0.07,-0.19l-0.01,-5.74l3.4,-1.13l7.24,-5.12l8.46,-4.95l3.76,1.08l1.35,1.39l0.36,0.05l1.39,-0.77l0.55,3.66l0.12,0.2l0.82,0.6l0.03,0.69l0.1,0.21l0.87,0.74l-0.47,0.99l-0.96,5.26l-0.13,3.25l-3.08,2.34l-0.1,0.15l-1.08,3.37l0.08,0.31l0.94,0.86l-0.01,1.51l0.29,0.3l1.25,0.05l-0.14,0.66l-0.51,0.11l-0.24,0.26l-0.06,0.57l-0.04,0.0l-1.59,-2.62l-0.21,-0.14l-0.59,-0.1l-0.23,0.05l-1.83,1.33l-1.79,-0.68l-1.42,-0.17l-0.17,0.03l-0.65,0.32l-1.39,-0.07l-0.19,0.06l-1.4,1.03l-1.12,0.05l-2.97,-1.29l-0.26,0.01l-1.12,0.59l-1.08,-0.04l-0.85,-0.88l-0.11,-0.07l-2.51,-0.95l-0.14,-0.02l-2.69,0.3l-0.16,0.07l-0.65,0.55l-0.1,0.16l-0.34,1.41l-0.69,0.98l-0.05,0.15l-0.13,1.72l-1.47,-1.13l-0.18,-0.06l-0.9,0.01l-0.2,0.08l-0.32,0.28Z", "name": "Niger"}, "NG": {"path": "M442.0,272.7l-2.4,0.83l-0.88,-0.12l-0.19,0.04l-0.89,0.52l-1.78,-0.05l-1.23,-1.44l-0.88,-1.87l-1.77,-1.66l-0.21,-0.08l-3.78,0.03l0.13,-3.75l-0.06,-1.58l0.44,-1.47l0.74,-0.75l1.21,-1.56l0.04,-0.29l-0.22,-0.56l0.44,-0.9l0.01,-0.24l-0.54,-1.44l0.26,-2.97l0.72,-1.06l0.33,-1.37l0.51,-0.43l2.53,-0.28l2.38,0.9l0.89,0.91l0.2,0.09l1.28,0.04l0.15,-0.03l1.06,-0.56l2.9,1.26l0.13,0.02l1.28,-0.06l0.16,-0.06l1.39,-1.02l1.36,0.07l0.15,-0.03l0.64,-0.32l1.22,0.13l1.9,0.73l0.28,-0.04l1.86,-1.35l0.33,0.06l1.62,2.67l0.29,0.14l0.32,-0.04l0.73,0.74l-0.19,0.37l-0.12,0.74l-2.03,1.89l-0.07,0.11l-0.66,1.62l-0.35,1.28l-0.48,0.51l-0.07,0.12l-0.48,1.67l-1.26,0.98l-0.1,0.15l-0.38,1.24l-0.58,1.07l-0.2,0.91l-1.43,0.7l-1.26,-0.93l-0.19,-0.06l-0.95,0.04l-0.2,0.09l-1.41,1.39l-0.61,0.02l-0.26,0.17l-1.19,2.42l-0.61,1.67Z", "name": "Nigeria"}, "NZ": {"path": "M857.9,379.62l1.85,3.1l0.33,0.14l0.22,-0.28l0.04,-1.41l0.57,0.4l0.35,2.06l0.17,0.22l2.02,0.94l1.78,0.26l0.22,-0.06l1.31,-1.01l0.84,0.22l-0.53,2.27l-0.67,1.5l-1.71,-0.05l-0.25,0.12l-0.67,0.89l-0.05,0.23l0.21,1.15l-0.31,0.46l-2.15,3.57l-1.6,0.99l-0.28,-0.51l-0.15,-0.13l-0.72,-0.3l1.27,-2.15l0.01,-0.29l-0.82,-1.63l-0.15,-0.14l-2.5,-1.09l0.05,-0.69l1.67,-0.94l0.15,-0.21l0.42,-2.24l-0.11,-1.95l-0.03,-0.12l-0.97,-1.85l0.05,-0.41l-0.09,-0.25l-1.18,-1.17l-1.94,-2.49l-0.86,-1.64l0.38,-0.09l1.24,1.43l0.12,0.08l1.81,0.68l0.67,2.39ZM853.93,393.55l0.57,1.24l0.44,0.12l1.51,-1.03l0.52,0.91l0.0,1.09l-0.88,1.31l-1.62,2.2l-1.26,1.2l-0.05,0.38l0.64,1.02l-1.4,0.03l-0.14,0.04l-2.14,1.16l-0.14,0.17l-0.67,2.0l-1.38,3.06l-3.07,2.19l-2.12,-0.06l-1.55,-0.99l-0.14,-0.05l-2.53,-0.2l-0.31,-0.84l1.25,-2.15l3.07,-2.97l1.62,-0.59l1.81,-1.17l2.18,-1.63l1.55,-1.65l1.08,-2.18l0.9,-0.72l0.11,-0.17l0.35,-1.56l1.37,-1.07l0.4,0.91Z", "name": "New Zealand"}, "NP": {"path": "M641.26,213.53l-0.14,0.95l0.32,1.64l-0.21,0.78l-1.83,0.04l-2.98,-0.62l-1.86,-0.25l-1.37,-1.3l-0.18,-0.08l-3.38,-0.34l-3.21,-1.49l-2.38,-1.34l-2.16,-0.92l0.84,-2.2l1.51,-1.18l0.89,-0.57l1.83,0.77l2.5,1.76l1.39,0.41l0.78,1.21l0.17,0.13l1.91,0.53l2.0,1.17l2.92,0.66l2.63,0.24Z", "name": "Nepal"}, "CI": {"path": "M413.53,272.08l-0.83,0.02l-1.79,-0.49l-1.64,0.03l-3.04,0.46l-1.73,0.72l-2.4,0.89l-0.12,-0.02l0.16,-1.7l0.19,-0.25l0.06,-0.2l-0.08,-0.99l-0.09,-0.19l-1.06,-1.05l-0.15,-0.08l-0.71,-0.15l-0.51,-0.48l0.45,-0.92l0.02,-0.19l-0.24,-1.16l0.07,-0.43l0.14,-0.0l0.3,-0.26l0.15,-1.1l-0.02,-0.15l-0.13,-0.34l0.09,-0.13l0.83,-0.27l0.19,-0.37l-0.62,-2.02l-0.55,-1.0l0.14,-0.59l0.35,-0.14l0.24,-0.16l0.53,0.29l0.14,0.04l1.93,0.02l0.26,-0.14l0.36,-0.58l0.39,0.01l0.43,-0.17l0.28,0.79l0.43,0.16l0.56,-0.31l0.89,-0.32l0.92,0.45l0.39,0.75l0.14,0.13l1.13,0.53l0.3,-0.03l0.81,-0.59l1.02,-0.08l1.49,0.57l0.62,3.33l-1.03,2.09l-0.65,2.84l0.02,0.2l1.05,2.08l-0.07,0.64Z", "name": "Ivory Coast"}, "CH": {"path": "M444.71,156.27l0.05,0.3l-0.34,0.69l0.13,0.4l1.13,0.58l1.07,0.1l-0.12,0.81l-0.87,0.42l-1.75,-0.37l-0.34,0.18l-0.47,1.1l-0.86,0.07l-0.33,-0.38l-0.41,-0.04l-1.34,1.01l-1.02,0.13l-0.93,-0.58l-0.82,-1.32l-0.37,-0.12l-0.77,0.32l0.02,-0.84l1.74,-1.69l0.09,-0.25l-0.04,-0.38l0.73,0.19l0.26,-0.06l0.6,-0.48l2.02,0.02l0.24,-0.12l0.38,-0.51l2.31,0.84Z", "name": "Switzerland"}, "CO": {"path": "M232.24,284.95l-0.94,-0.52l-1.22,-0.82l-0.31,-0.01l-0.62,0.35l-1.88,-0.31l-0.54,-0.95l-0.29,-0.15l-0.37,0.03l-2.34,-1.33l-0.15,-0.35l0.57,-0.11l0.24,-0.32l-0.1,-1.15l0.46,-0.71l1.11,-0.15l0.21,-0.13l1.05,-1.57l0.95,-1.31l-0.08,-0.43l-0.73,-0.47l0.4,-1.24l0.01,-0.16l-0.53,-2.15l0.44,-0.54l0.06,-0.24l-0.4,-2.13l-0.06,-0.13l-0.93,-1.22l0.21,-0.8l0.52,0.12l0.32,-0.13l0.47,-0.75l0.03,-0.27l-0.52,-1.32l0.09,-0.11l1.14,0.07l0.22,-0.08l1.82,-1.71l0.96,-0.25l0.22,-0.28l0.02,-0.81l0.43,-2.01l1.28,-1.04l1.48,-0.05l0.27,-0.19l0.12,-0.31l1.73,0.19l0.2,-0.05l1.96,-1.28l0.97,-0.56l1.16,-1.16l0.64,0.11l0.43,0.44l-0.31,0.55l-1.49,0.39l-0.19,0.16l-0.6,1.2l-0.97,0.74l-0.73,0.94l-0.06,0.13l-0.3,1.76l-0.68,1.44l0.23,0.43l1.1,0.14l0.27,0.97l0.08,0.13l0.49,0.49l0.17,0.85l-0.27,0.86l-0.01,0.14l0.09,0.53l0.2,0.23l0.52,0.18l0.54,0.79l0.27,0.13l3.18,-0.24l1.31,0.29l1.7,2.08l0.31,0.1l0.96,-0.26l1.75,0.13l1.41,-0.27l0.56,0.27l-0.36,1.07l-0.54,0.81l-0.05,0.13l-0.2,1.8l0.51,1.79l0.07,0.12l0.65,0.68l0.05,0.32l-1.16,1.14l0.05,0.47l0.86,0.52l0.6,0.79l0.31,1.01l-0.7,-0.81l-0.44,-0.01l-0.74,0.77l-4.75,-0.05l-0.3,0.31l0.03,1.57l0.25,0.29l1.2,0.21l-0.02,0.24l-0.1,-0.05l-0.22,-0.02l-1.41,0.41l-0.22,0.29l-0.01,1.82l0.11,0.23l1.04,0.85l0.35,1.3l-0.06,1.02l-1.02,6.26l-0.84,-0.89l-0.19,-0.09l-0.25,-0.02l1.35,-2.13l-0.1,-0.42l-1.92,-1.17l-0.2,-0.04l-1.41,0.2l-0.82,-0.39l-0.26,0.0l-1.29,0.62l-1.63,-0.27l-1.4,-2.5l-0.12,-0.12l-1.1,-0.61l-0.83,-1.2l-1.67,-1.19l-0.27,-0.04l-0.54,0.19Z", "name": "Colombia"}, "CN": {"path": "M740.32,148.94l0.22,0.21l4.3,1.03l2.84,2.2l0.99,2.92l0.28,0.2l3.8,0.0l0.15,-0.04l2.13,-1.24l3.5,-0.8l-1.05,2.29l-0.95,1.13l-0.06,0.12l-0.85,3.41l-1.56,2.81l-2.83,-0.51l-0.19,0.03l-2.15,1.09l-0.15,0.34l0.65,2.59l-0.33,3.3l-1.03,0.07l-0.28,0.3l0.01,0.75l-1.09,-1.2l-0.48,0.05l-0.94,1.6l-3.76,1.26l-0.2,0.36l0.29,1.19l-1.67,-0.08l-1.11,-0.88l-0.42,0.05l-1.69,2.08l-2.71,1.57l-2.04,1.88l-3.42,0.84l-0.11,0.05l-1.8,1.34l-1.54,0.46l0.52,-0.53l0.06,-0.33l-0.44,-0.96l1.84,-1.84l0.02,-0.41l-1.32,-1.56l-0.36,-0.08l-2.23,1.08l-2.83,2.06l-1.52,1.85l-2.32,0.13l-0.2,0.09l-1.28,1.37l-0.03,0.37l1.32,1.97l0.18,0.13l1.83,0.43l0.07,1.08l0.18,0.26l1.98,0.84l0.3,-0.03l2.66,-1.96l2.06,1.04l0.12,0.03l1.4,0.07l0.27,1.0l-3.24,0.73l-0.17,0.11l-1.13,1.5l-2.38,1.4l-0.1,0.1l-1.29,1.99l0.1,0.42l2.6,1.5l0.97,2.72l1.52,2.56l1.66,2.08l-0.03,1.76l-1.4,0.67l-0.15,0.38l0.6,1.47l0.13,0.15l1.29,0.75l-0.35,2.0l-0.58,1.96l-1.22,0.21l-0.2,0.14l-1.83,2.93l-2.02,3.51l-2.29,3.13l-3.4,2.42l-3.42,2.18l-2.75,0.3l-0.15,0.06l-1.32,1.01l-0.68,-0.67l-0.41,-0.01l-1.37,1.27l-3.42,1.28l-2.62,0.4l-0.24,0.21l-0.8,2.57l-0.95,0.11l-0.53,-1.54l0.52,-0.89l-0.19,-0.44l-3.36,-0.84l-0.17,0.01l-1.09,0.4l-2.36,-0.64l-1.0,-0.9l0.35,-1.34l-0.23,-0.37l-2.22,-0.47l-1.15,-0.94l-0.36,-0.02l-2.08,1.37l-2.35,0.29l-1.98,-0.01l-0.13,0.03l-1.32,0.63l-1.28,0.38l-0.21,0.33l0.33,2.65l-0.78,-0.04l-0.14,-0.39l-0.07,-1.04l-0.41,-0.26l-1.72,0.71l-0.96,-0.43l-1.63,-0.86l0.65,-1.95l-0.19,-0.38l-1.43,-0.46l-0.56,-2.27l-0.34,-0.22l-2.26,0.38l0.25,-2.65l2.29,-2.15l0.09,-0.2l0.1,-2.21l-0.07,-2.09l-0.15,-0.25l-1.02,-0.6l-0.8,-1.52l-0.31,-0.16l-1.42,0.2l-2.16,-0.32l0.55,-0.74l0.01,-0.35l-1.17,-1.7l-0.41,-0.08l-1.67,1.07l-1.97,-0.63l-0.25,0.03l-2.89,1.73l-2.26,1.99l-1.82,0.3l-1.0,-0.66l-0.15,-0.05l-1.28,-0.06l-1.75,-0.61l-0.24,0.02l-1.35,0.69l-0.1,0.08l-1.2,1.45l-0.14,-1.41l-0.4,-0.25l-1.46,0.55l-2.83,-0.26l-2.77,-0.61l-1.99,-1.17l-1.91,-0.54l-0.78,-1.21l-0.17,-0.13l-1.36,-0.38l-2.54,-1.79l-2.01,-0.84l-0.28,0.02l-0.89,0.56l-3.31,-1.83l-2.35,-1.67l-0.57,-2.49l1.34,0.28l0.36,-0.28l0.08,-1.42l-0.05,-0.19l-0.93,-1.34l0.24,-2.18l-0.07,-0.22l-2.69,-3.32l-0.15,-0.1l-3.97,-1.11l-0.69,-2.05l-0.11,-0.15l-1.79,-1.3l-0.39,-0.73l-0.36,-1.57l0.08,-1.09l-0.18,-0.3l-1.52,-0.66l-0.22,-0.01l-0.51,0.18l-0.52,-2.21l0.59,-0.55l0.06,-0.35l-0.22,-0.44l2.12,-1.24l1.63,-0.55l2.58,0.39l0.31,-0.16l0.87,-1.75l3.05,-0.34l0.21,-0.12l0.84,-1.12l3.87,-1.59l0.15,-0.14l0.35,-0.68l0.03,-0.17l-0.17,-1.51l1.52,-0.7l0.15,-0.39l-2.12,-5.0l4.62,-1.15l1.35,-0.72l0.14,-0.17l1.72,-5.37l4.7,0.99l0.28,-0.08l1.39,-1.43l0.08,-0.2l0.11,-2.95l1.83,-0.26l0.18,-0.1l1.85,-2.08l0.61,-0.17l0.57,1.97l0.1,0.15l2.2,1.75l3.48,1.17l1.59,2.36l-0.93,3.53l0.04,0.24l0.9,1.35l0.2,0.13l2.98,0.53l3.32,0.43l2.97,1.89l1.49,0.35l1.08,2.67l1.52,1.88l0.24,0.11l2.74,-0.07l5.15,0.67l3.36,-0.41l2.39,0.43l3.67,1.81l0.13,0.03l2.92,-0.0l1.02,0.86l0.34,0.03l2.88,-1.59l3.98,-1.03l3.81,-0.13l3.02,-1.12l1.77,-1.61l1.73,-1.01l0.13,-0.37l-0.41,-1.01l-0.72,-1.07l1.09,-1.66l1.21,0.24l2.57,0.63l0.24,-0.04l2.46,-1.62l3.78,-1.19l0.13,-0.09l1.8,-2.03l1.66,-0.84l3.54,-0.41l1.93,0.35l0.34,-0.22l0.27,-1.12l-0.08,-0.29l-2.27,-2.22l-2.08,-1.07l-0.29,0.01l-1.82,1.12l-2.36,-0.47l-0.14,0.01l-1.18,0.34l-0.46,-0.94l1.69,-3.08l1.1,-2.21l2.75,1.12l0.26,-0.02l3.53,-2.06l0.15,-0.26l-0.02,-1.35l2.18,-3.39l1.35,-1.04l0.12,-0.24l-0.03,-1.85l-0.15,-0.25l-1.0,-0.58l1.68,-1.37l3.01,-0.59l3.25,-0.09l3.67,0.99l2.08,1.18l1.51,3.3l0.95,1.45l0.85,1.99l0.92,3.19ZM697.0,237.37l-1.95,1.12l-1.74,-0.68l-0.06,-1.9l1.08,-1.03l2.62,-0.7l1.23,0.05l0.37,0.65l-1.01,1.08l-0.54,1.4Z", "name": "China"}, "CM": {"path": "M453.76,278.92l-0.26,-0.11l-0.18,-0.02l-1.42,0.31l-1.56,-0.33l-1.17,0.16l-3.7,-0.05l0.3,-1.63l-0.04,-0.21l-0.98,-1.66l-0.15,-0.13l-1.03,-0.38l-0.46,-1.01l-0.13,-0.14l-0.48,-0.27l0.02,-0.46l0.62,-1.72l1.1,-2.25l0.54,-0.02l0.2,-0.09l1.41,-1.39l0.73,-0.03l1.32,0.97l0.31,0.03l1.72,-0.85l0.16,-0.2l0.22,-1.0l0.57,-1.03l0.36,-1.18l1.26,-0.98l0.1,-0.15l0.49,-1.7l0.48,-0.51l0.07,-0.13l0.35,-1.3l0.63,-1.54l2.06,-1.92l0.09,-0.17l0.12,-0.79l0.24,-0.41l-0.04,-0.36l-0.89,-0.91l0.04,-0.45l0.28,-0.06l0.85,1.39l0.16,1.59l-0.09,1.66l0.04,0.17l1.09,1.84l-0.86,-0.02l-0.72,0.17l-1.07,-0.24l-0.34,0.17l-0.54,1.19l0.06,0.34l1.48,1.47l1.06,0.44l0.32,0.94l0.73,1.6l-0.32,0.57l-1.23,2.49l-0.54,0.41l-0.12,0.21l-0.19,1.95l0.24,1.08l-0.18,0.67l0.07,0.28l1.13,1.25l0.24,0.93l0.92,1.29l1.1,0.8l0.1,1.01l0.26,0.73l-0.12,0.93l-1.65,-0.49l-2.02,-0.66l-3.19,-0.11Z", "name": "Cameroon"}, "CL": {"path": "M246.8,429.1l-1.14,0.78l-2.25,1.21l-0.16,0.23l-0.37,2.94l-0.75,0.06l-2.72,-1.07l-2.83,-2.34l-3.06,-1.9l-0.71,-1.92l0.67,-1.84l-0.02,-0.25l-1.22,-2.13l-0.31,-5.41l1.02,-2.95l2.59,-2.4l-0.13,-0.51l-3.32,-0.8l2.06,-2.4l0.07,-0.15l0.79,-4.77l2.44,0.95l0.4,-0.22l1.31,-6.31l-0.16,-0.33l-1.68,-0.8l-0.42,0.21l-0.72,3.47l-1.01,-0.27l0.74,-4.06l0.85,-5.46l1.12,-1.96l0.03,-0.22l-0.71,-2.82l-0.19,-2.94l0.76,-0.07l0.26,-0.2l1.53,-4.62l1.73,-4.52l1.07,-4.2l-0.56,-4.2l0.73,-2.2l0.01,-0.12l-0.29,-3.3l1.46,-3.34l0.45,-5.19l0.8,-5.52l0.78,-5.89l-0.18,-4.33l-0.49,-3.47l1.1,-0.56l0.13,-0.13l0.44,-0.88l0.9,1.29l0.32,1.8l0.1,0.18l1.16,0.97l-0.73,2.33l0.01,0.21l1.33,2.91l0.97,3.6l0.35,0.22l1.57,-0.31l0.16,0.34l-0.79,2.51l-2.61,1.25l-0.17,0.28l0.08,4.36l-0.48,0.79l0.01,0.33l0.6,0.84l-1.62,1.55l-1.67,2.6l-0.89,2.47l-0.02,0.13l0.23,2.56l-1.5,2.76l-0.03,0.21l1.15,4.8l0.11,0.17l0.54,0.42l-0.01,2.37l-1.4,2.7l-0.03,0.15l0.06,2.25l-1.8,1.78l-0.09,0.21l0.02,2.73l0.71,2.63l-1.33,0.94l-0.12,0.17l-0.67,2.64l-0.59,3.03l0.4,3.55l-0.84,0.51l-0.14,0.31l0.58,3.5l0.08,0.16l0.96,0.99l-0.7,1.08l0.11,0.43l1.04,0.55l0.19,0.8l-0.89,0.48l-0.16,0.31l0.26,1.77l-0.89,4.06l-1.31,2.67l-0.03,0.19l0.28,1.53l-0.73,1.88l-1.85,1.37l-0.12,0.26l0.22,3.46l0.06,0.16l0.88,1.19l0.28,0.12l1.32,-0.17l-0.04,2.13l0.04,0.15l1.04,1.95l0.24,0.16l5.94,0.44ZM248.79,430.71l0.0,7.41l0.3,0.3l2.67,0.0l1.01,0.06l-0.54,0.91l-1.99,1.01l-1.13,-0.1l-1.42,-0.27l-1.87,-1.06l-2.57,-0.49l-3.09,-1.9l-2.52,-1.83l-2.65,-2.93l0.93,0.32l3.54,2.29l3.32,1.23l0.34,-0.09l1.29,-1.57l0.83,-2.32l2.11,-1.28l1.43,0.32Z", "name": "Chile"}, "CA": {"path": "M280.14,145.66l-1.66,2.88l0.06,0.37l0.37,0.03l1.5,-1.01l1.17,0.49l-0.64,0.83l0.13,0.46l2.22,0.89l0.28,-0.03l1.02,-0.7l2.09,0.83l-0.69,2.1l0.37,0.38l1.43,-0.45l0.27,1.43l0.74,1.88l-0.95,2.5l-0.88,0.09l-1.34,-0.48l0.49,-2.34l-0.14,-0.32l-0.7,-0.4l-0.36,0.04l-2.81,2.66l-0.63,-0.05l1.2,-1.01l-0.1,-0.52l-2.4,-0.77l-2.79,0.18l-4.65,-0.09l-0.22,-0.54l1.37,-0.99l0.01,-0.48l-0.82,-0.65l1.91,-1.79l2.57,-5.17l1.49,-1.81l2.04,-1.07l0.63,0.08l-0.27,0.51l-1.33,2.07ZM193.92,74.85l-0.01,4.24l0.19,0.28l0.33,-0.07l3.14,-3.22l2.65,2.5l-0.71,3.04l0.06,0.26l2.42,2.88l0.46,0.0l2.66,-3.14l1.83,-3.74l0.03,-0.12l0.13,-4.53l3.23,0.31l3.63,0.64l3.18,2.08l0.13,1.91l-1.79,2.22l-0.0,0.37l1.69,2.2l-0.28,1.8l-4.74,2.84l-3.33,0.62l-2.5,-1.21l-0.41,0.17l-0.73,2.05l-2.39,3.44l-0.74,1.78l-2.78,2.61l-3.48,0.26l-0.17,0.07l-1.98,1.68l-0.1,0.21l-0.15,2.33l-2.68,0.45l-0.17,0.09l-3.1,3.2l-2.75,4.38l-0.99,3.06l-0.14,4.31l0.25,0.31l3.5,0.58l1.07,3.24l1.18,2.76l0.34,0.18l3.43,-0.69l4.55,1.52l2.45,1.32l1.76,1.65l0.12,0.07l3.11,0.96l2.63,1.46l0.13,0.04l4.12,0.2l2.41,0.3l-0.36,2.81l0.8,3.51l1.81,3.78l0.08,0.1l3.73,3.17l0.34,0.03l1.93,-1.08l0.13,-0.15l1.35,-3.44l0.01,-0.18l-1.31,-5.38l-0.08,-0.14l-1.46,-1.5l3.68,-1.51l2.84,-2.46l1.45,-2.55l0.04,-0.17l-0.2,-2.39l-0.04,-0.12l-1.7,-3.07l-2.9,-2.64l2.79,-3.66l0.05,-0.27l-1.08,-3.38l-0.8,-5.75l1.45,-0.75l4.18,1.03l2.6,0.38l0.18,-0.03l1.93,-0.95l2.18,1.23l3.01,2.18l0.73,1.42l0.25,0.16l4.18,0.27l-0.06,2.95l0.83,4.7l0.22,0.24l2.19,0.55l1.75,2.08l0.38,0.07l3.63,-2.03l0.11,-0.11l2.38,-4.06l1.36,-1.43l1.76,3.01l3.26,4.68l2.68,4.19l-0.94,2.09l0.12,0.38l3.31,1.98l2.23,1.98l0.13,0.07l3.94,0.89l1.48,1.02l0.96,2.82l0.22,0.2l1.85,0.43l0.88,1.13l0.17,3.53l-1.68,1.16l-1.76,1.14l-4.08,1.17l-0.11,0.06l-3.08,2.65l-4.11,0.52l-5.35,-0.69l-3.76,-0.02l-2.62,0.23l-0.2,0.1l-2.05,2.29l-3.13,1.41l-0.11,0.08l-3.6,4.24l-2.87,2.92l-0.05,0.36l0.33,0.14l2.13,-0.52l0.15,-0.08l3.98,-4.15l5.16,-2.63l3.58,-0.31l1.82,1.3l-2.09,1.91l-0.09,0.29l0.8,3.46l0.82,2.37l0.15,0.17l3.25,1.56l0.16,0.03l4.14,-0.45l0.21,-0.12l2.03,-2.86l0.11,1.46l0.13,0.22l1.26,0.88l-2.7,1.78l-5.51,1.83l-2.52,1.26l-2.75,2.16l-1.52,-0.18l-0.08,-2.16l4.19,-2.47l0.14,-0.34l-0.3,-0.22l-4.01,0.1l-2.66,0.36l-1.45,-1.56l0.0,-4.16l-0.11,-0.23l-1.11,-0.91l-0.28,-0.05l-1.5,0.48l-0.7,-0.7l-0.45,0.02l-1.91,2.39l-0.8,2.5l-0.82,1.31l-0.95,0.43l-0.77,0.15l-0.23,0.2l-0.18,0.56l-8.2,0.02l-0.13,0.03l-1.19,0.61l-2.95,2.45l-0.78,1.13l-4.6,0.01l-0.12,0.02l-1.13,0.48l-0.13,0.44l0.37,0.55l0.2,0.82l-0.01,0.09l-3.1,1.42l-2.63,0.5l-2.84,1.57l-0.47,0.0l-0.72,-0.4l-0.18,-0.27l0.03,-0.15l0.52,-1.0l1.2,-1.71l0.73,-1.8l0.02,-0.17l-1.03,-5.47l-0.15,-0.21l-2.35,-1.32l0.16,-0.29l-0.05,-0.35l-0.37,-0.38l-0.22,-0.09l-0.56,0.0l-0.35,-0.34l-0.11,-0.65l-0.46,-0.2l-0.39,0.26l-0.2,-0.03l-0.11,-0.33l-0.48,-0.25l-0.21,-0.71l-0.15,-0.18l-3.97,-2.07l-4.8,-2.39l-0.25,-0.01l-2.19,0.89l-0.72,0.03l-3.04,-0.82l-0.14,-0.0l-1.94,0.4l-2.4,-0.98l-2.56,-0.51l-1.7,-0.19l-0.62,-0.44l-0.42,-1.67l-0.3,-0.23l-0.85,0.02l-0.29,0.3l-0.01,0.95l-69.26,-0.01l-4.77,-3.14l-1.78,-1.41l-4.51,-1.38l-1.3,-2.73l0.34,-1.96l-0.17,-0.33l-3.06,-1.37l-0.41,-2.58l-0.11,-0.18l-2.92,-2.4l-0.05,-1.53l1.32,-1.59l0.07,-0.2l-0.07,-2.21l-0.16,-0.26l-4.19,-2.22l-2.52,-4.02l-1.56,-2.6l-0.08,-0.09l-2.28,-1.64l-1.65,-1.48l-1.31,-1.89l-0.38,-0.1l-2.51,1.21l-2.28,1.92l-2.03,-2.22l-1.85,-1.71l-2.44,-1.04l-2.28,-0.12l0.03,-37.72l4.27,0.98l4.0,2.13l2.61,0.4l0.24,-0.07l2.17,-1.81l2.92,-1.33l3.63,0.53l0.18,-0.03l3.72,-1.94l3.89,-1.06l1.6,1.72l0.37,0.06l1.87,-1.04l0.14,-0.19l0.48,-1.83l1.37,0.38l4.18,3.96l0.41,0.0l2.89,-2.62l0.28,2.79l0.37,0.26l3.08,-0.73l0.17,-0.12l0.85,-1.16l2.81,0.24l3.83,1.86l5.86,1.61l3.46,0.75l2.44,-0.26l2.89,1.89l-3.12,1.89l-0.14,0.31l0.24,0.24l4.53,0.92l6.84,-0.5l2.04,-0.71l2.54,2.44l0.39,0.02l2.72,-2.16l-0.01,-0.48l-2.26,-1.61l1.27,-1.16l2.94,-0.19l1.94,-0.42l1.89,0.97l2.49,2.32l0.24,0.08l2.71,-0.33l4.35,1.9l0.17,0.02l3.86,-0.67l3.62,0.1l0.31,-0.33l-0.26,-2.44l1.9,-0.65l3.58,1.36l-0.01,3.84l0.23,0.29l0.34,-0.17l1.51,-3.23l1.81,0.1l0.31,-0.22l1.13,-4.37l-0.08,-0.29l-2.68,-2.73l-2.83,-1.76l0.19,-4.73l2.77,-3.15l3.06,0.69l2.44,1.97l3.24,4.88l-2.05,2.02l0.15,0.51l4.41,0.85ZM265.85,150.7l-0.84,0.04l-3.15,-0.99l-1.77,-1.17l0.19,-0.06l3.17,0.79l2.39,1.27l0.01,0.12ZM249.41,3.71l6.68,0.49l5.34,0.79l4.34,1.6l-0.08,1.24l-5.91,2.56l-6.03,1.21l-2.36,1.38l-0.14,0.34l0.29,0.22l4.37,-0.02l-4.96,3.01l-4.06,1.64l-0.11,0.08l-4.21,4.62l-5.07,0.92l-0.12,0.05l-1.53,1.1l-7.5,0.59l-0.28,0.28l0.24,0.31l2.67,0.54l-1.04,0.6l-0.09,0.44l1.89,2.49l-2.11,1.66l-3.83,1.52l-0.15,0.13l-1.14,2.01l-3.41,1.55l-0.16,0.36l0.35,1.19l0.3,0.22l3.98,-0.19l0.03,0.78l-6.42,2.99l-6.44,-1.41l-7.41,0.79l-3.72,-0.62l-4.48,-0.26l-0.25,-2.0l4.37,-1.13l0.21,-0.38l-1.14,-3.55l1.13,-0.28l6.61,2.29l0.35,-0.12l-0.04,-0.37l-3.41,-3.45l-0.14,-0.08l-3.57,-0.92l1.62,-1.7l4.36,-1.3l0.2,-0.18l0.71,-1.94l-0.12,-0.36l-3.45,-2.15l-0.88,-2.43l6.36,0.23l1.94,0.61l0.23,-0.02l3.91,-2.1l0.15,-0.32l-0.26,-0.24l-5.69,-0.67l-8.69,0.37l-4.3,-1.92l-2.12,-2.39l-2.82,-1.68l-0.44,-1.65l3.41,-1.06l2.93,-0.2l4.91,-0.99l3.69,-2.28l2.93,0.31l2.64,1.68l0.42,-0.1l1.84,-3.23l3.17,-0.96l4.45,-0.69l7.56,-0.26l1.26,0.64l0.18,0.03l7.2,-1.06l10.81,0.8ZM203.94,57.59l0.01,0.32l1.97,2.97l0.51,-0.01l2.26,-3.75l6.05,-1.89l4.08,4.72l-0.36,2.95l0.38,0.33l4.95,-1.36l0.11,-0.05l2.23,-1.77l5.37,2.31l3.32,2.14l0.3,1.89l0.36,0.25l4.48,-1.01l2.49,2.8l0.14,0.09l5.99,1.78l2.09,1.74l2.18,3.83l-4.29,1.91l-0.01,0.54l5.9,2.83l3.95,0.94l3.54,3.84l0.2,0.1l3.58,0.25l-0.67,2.51l-4.18,4.54l-2.84,-1.61l-3.91,-3.95l-0.26,-0.09l-3.24,0.52l-0.25,0.26l-0.32,2.37l0.1,0.26l2.63,2.38l3.42,1.89l0.96,1.0l1.57,3.8l-0.74,2.43l-2.85,-0.96l-6.26,-3.15l-0.38,0.09l0.04,0.39l3.54,3.4l2.55,2.31l0.23,0.78l-6.26,-1.43l-5.33,-2.25l-2.73,-1.73l0.67,-0.86l-0.09,-0.45l-7.38,-4.01l-0.44,0.27l0.03,0.89l-6.85,0.61l-1.8,-1.17l1.43,-2.6l4.56,-0.07l5.15,-0.52l0.23,-0.45l-0.76,-1.34l0.8,-1.89l3.21,-4.06l0.05,-0.29l-0.72,-1.95l-0.97,-1.47l-0.11,-0.1l-3.84,-2.1l-4.53,-1.33l1.09,-0.75l0.05,-0.45l-2.65,-2.75l-0.18,-0.09l-2.12,-0.24l-1.91,-1.47l-0.39,0.02l-1.27,1.25l-4.4,0.56l-9.06,-0.99l-5.28,-1.31l-4.01,-0.67l-1.72,-1.31l2.32,-1.85l0.1,-0.33l-0.28,-0.2l-3.3,-0.02l-0.74,-4.36l1.86,-4.09l2.46,-1.88l5.74,-1.15l-1.5,2.55ZM261.28,159.28l0.19,0.14l1.82,0.42l1.66,-0.05l-0.66,0.68l-0.75,0.16l-3.0,-1.25l-0.46,-0.77l0.51,-0.52l0.68,1.19ZM230.87,84.48l-2.48,0.19l-0.52,-1.74l0.96,-2.17l2.03,-0.53l1.71,1.04l0.02,1.6l-0.22,0.46l-1.5,1.16ZM229.52,58.19l0.14,0.82l-4.99,-0.22l-2.73,0.63l-0.59,-0.23l-2.61,-2.4l0.08,-1.38l0.94,-0.25l5.61,0.51l4.14,2.54ZM222.12,105.0l-0.79,1.63l-0.75,-0.22l-0.52,-0.91l0.04,-0.09l0.84,-1.01l0.74,0.06l0.44,0.55ZM183.77,38.22l2.72,1.65l0.16,0.04l4.83,-0.01l1.92,1.52l-0.51,1.75l0.18,0.36l2.84,1.14l1.56,1.19l0.16,0.06l3.37,0.22l3.65,0.42l4.07,-1.1l5.05,-0.43l3.96,0.35l2.53,1.8l0.48,1.79l-1.37,1.16l-3.6,1.03l-3.22,-0.59l-7.17,0.76l-5.1,0.09l-4.0,-0.6l-6.48,-1.56l-0.81,-2.57l-0.3,-2.49l-0.1,-0.19l-2.51,-2.25l-0.16,-0.07l-5.12,-0.63l-2.61,-1.45l0.75,-1.71l4.88,0.32ZM207.46,91.26l0.42,1.62l0.42,0.19l1.12,-0.55l1.35,0.99l2.74,1.39l2.73,1.2l0.2,1.74l0.35,0.26l1.72,-0.29l1.31,0.97l-1.72,0.96l-3.68,-0.9l-1.34,-1.71l-0.43,-0.04l-2.46,2.1l-3.23,1.85l-0.74,-1.98l-0.31,-0.19l-2.47,0.28l1.49,-1.34l0.1,-0.19l0.32,-3.15l0.79,-3.45l1.34,0.25ZM215.59,102.66l-2.73,2.0l-1.49,-0.08l-0.37,-0.7l1.61,-1.56l3.0,0.03l-0.02,0.3ZM202.79,24.07l0.11,0.12l2.54,1.53l-3.01,1.47l-4.55,4.07l-4.3,0.38l-5.07,-0.68l-2.51,-2.09l0.03,-1.72l1.86,-1.4l0.1,-0.34l-0.29,-0.2l-4.49,0.04l-2.63,-1.79l-1.45,-2.36l1.61,-2.38l1.65,-1.69l2.47,-0.4l0.19,-0.48l-0.72,-0.89l5.1,-0.26l3.1,3.05l0.13,0.07l4.21,1.25l3.99,1.06l1.92,3.65ZM187.5,59.3l-0.15,0.1l-2.59,3.4l-2.5,-0.15l-1.47,-3.92l0.04,-2.24l1.22,-1.92l2.34,-1.26l5.11,0.17l4.28,1.06l-3.36,3.86l-2.9,0.9ZM186.19,48.8l-1.15,1.63l-3.42,-0.35l-2.68,-1.15l1.11,-1.88l3.34,-1.27l2.01,1.63l0.79,1.38ZM185.78,35.41l-0.95,0.13l-4.48,-0.33l-0.4,-0.91l4.5,0.07l1.45,0.82l-0.1,0.21ZM180.76,32.56l-3.43,1.03l-1.85,-1.14l-1.01,-1.92l-0.16,-1.87l2.87,0.2l1.39,0.35l2.75,1.75l-0.55,1.6ZM181.03,76.32l-1.21,1.2l-3.19,-1.26l-0.18,-0.01l-1.92,0.45l-2.88,-1.67l1.84,-1.16l1.6,-1.77l2.45,1.17l1.45,0.77l2.05,2.28ZM169.72,54.76l2.83,0.97l0.14,0.01l4.25,-0.58l0.47,1.01l-2.19,2.16l0.07,0.48l3.61,1.95l-0.41,3.84l-3.87,1.68l-2.23,-0.36l-1.73,-1.75l-6.07,-3.53l0.03,-1.01l4.79,0.55l0.3,-0.16l-0.04,-0.34l-2.55,-2.89l2.59,-2.05ZM174.44,40.56l1.49,1.87l0.07,2.48l-1.07,3.52l-3.87,0.48l-2.41,-0.72l0.05,-2.72l-0.33,-0.3l-3.79,0.36l-0.13,-3.31l2.36,0.14l0.15,-0.03l3.7,-1.74l3.44,0.29l0.31,-0.22l0.03,-0.12ZM170.14,31.5l0.75,1.74l-3.52,-0.52l-4.19,-1.77l-4.65,-0.17l1.65,-1.11l-0.05,-0.52l-2.86,-1.26l-0.13,-1.58l4.52,0.7l6.66,1.99l1.84,2.5ZM134.64,58.08l-1.08,1.93l0.34,0.44l5.44,-1.41l3.37,2.32l0.37,-0.02l2.66,-2.28l2.03,1.38l2.01,4.53l0.53,0.04l1.26,-1.93l0.03,-0.27l-1.67,-4.55l1.82,-0.58l2.36,0.73l2.69,1.84l1.53,4.46l0.77,3.24l0.15,0.19l4.22,2.26l4.32,2.04l-0.21,1.51l-3.87,0.34l-0.19,0.5l1.45,1.54l-0.65,1.23l-4.3,-0.65l-4.4,-1.19l-2.97,0.28l-4.67,1.48l-6.31,0.65l-4.27,0.39l-1.26,-1.91l-0.15,-0.12l-3.42,-1.2l-0.16,-0.01l-2.05,0.45l-2.66,-3.02l1.2,-0.34l3.82,-0.76l3.58,0.19l3.27,-0.78l0.23,-0.29l-0.24,-0.29l-4.84,-1.06l-5.42,0.35l-3.4,-0.09l-0.97,-1.22l5.39,-1.7l0.21,-0.33l-0.3,-0.25l-3.82,0.06l-3.95,-1.1l1.88,-3.13l1.68,-1.81l6.54,-2.84l2.11,0.77ZM158.85,56.58l-1.82,2.62l-3.38,-2.9l0.49,-0.39l3.17,-0.18l1.54,0.86ZM149.71,42.7l1.0,1.87l0.37,0.14l2.17,-0.83l2.33,0.2l0.38,2.16l-1.38,2.17l-8.33,0.76l-6.34,2.15l-3.51,0.1l-0.22,-1.13l4.98,-2.12l0.17,-0.34l-0.31,-0.23l-11.27,0.6l-3.04,-0.78l3.14,-4.57l2.2,-1.35l6.87,1.7l4.4,3.0l0.14,0.05l4.37,0.39l0.27,-0.48l-3.41,-4.68l1.96,-1.62l2.28,0.53l0.79,2.32ZM145.44,29.83l-2.18,0.77l-3.79,-0.0l0.02,-0.31l2.34,-1.5l1.2,0.23l2.42,0.83ZM144.83,34.5l-4.44,1.46l-3.18,-1.48l1.6,-1.36l3.51,-0.53l3.1,0.75l-0.6,1.16ZM119.02,65.87l-6.17,2.07l-1.19,-1.82l-0.13,-0.11l-5.48,-2.32l0.92,-1.7l1.73,-3.44l2.16,-3.15l-0.02,-0.36l-2.09,-2.56l7.84,-0.71l3.59,1.02l6.32,0.27l2.35,1.37l2.25,1.71l-2.68,1.04l-6.21,3.41l-3.1,3.28l-0.08,0.21l0.0,1.81ZM129.66,35.4l-0.3,3.55l-1.77,1.67l-2.34,0.27l-4.62,2.2l-3.89,0.76l-2.83,-0.93l3.85,-3.52l5.04,-3.36l3.75,0.07l3.11,-0.7ZM111.24,152.74l-0.82,0.29l-3.92,-1.39l-0.7,-1.06l-0.12,-0.1l-2.15,-1.09l-0.41,-0.84l-0.2,-0.16l-2.44,-0.56l-0.84,-1.56l0.1,-0.36l2.34,0.64l1.53,0.5l2.28,0.34l0.78,1.04l1.24,1.55l0.09,0.08l2.42,1.3l0.81,1.39ZM88.54,134.82l0.14,0.02l2.0,-0.23l-0.67,3.48l0.06,0.24l1.78,2.22l-0.24,-0.0l-1.4,-1.42l-0.91,-1.53l-1.26,-1.08l-0.42,-1.35l0.09,-0.66l0.82,0.31Z", "name": "Canada"}, "CG": {"path": "M453.66,296.61l-0.9,-0.82l-0.35,-0.04l-0.83,0.48l-0.77,0.83l-1.65,-2.13l1.66,-1.2l0.08,-0.39l-0.81,-1.43l0.59,-0.43l1.62,-0.29l0.24,-0.24l0.1,-0.58l0.94,0.84l0.19,0.08l2.21,0.11l0.27,-0.14l0.81,-1.29l0.32,-1.76l-0.27,-1.96l-0.06,-0.15l-1.08,-1.35l1.02,-2.74l-0.09,-0.34l-0.62,-0.5l-0.22,-0.06l-1.66,0.18l-0.55,-1.03l0.12,-0.73l2.85,0.09l1.98,0.65l2.0,0.59l0.38,-0.25l0.17,-1.3l1.26,-2.24l1.34,-1.19l1.54,0.38l1.35,0.12l-0.11,1.15l-0.74,1.34l-0.5,1.61l-0.31,2.22l0.12,1.41l-0.4,0.9l-0.06,0.88l-0.24,0.67l-1.57,1.15l-1.24,1.41l-1.09,2.43l-0.03,0.13l0.08,1.95l-0.55,0.69l-1.46,1.23l-1.32,1.41l-0.61,-0.29l-0.13,-0.57l-0.29,-0.23l-1.36,-0.02l-0.23,0.1l-0.72,0.81l-0.41,-0.16Z", "name": "Republic of the Congo"}, "CF": {"path": "M459.41,266.56l1.9,-0.17l0.22,-0.12l0.36,-0.5l0.14,0.02l0.55,0.51l0.29,0.07l3.15,-0.96l0.12,-0.07l1.05,-0.97l1.29,-0.87l0.12,-0.33l-0.17,-0.61l0.38,-0.12l2.36,0.15l0.15,-0.03l2.36,-1.17l0.12,-0.1l1.78,-2.72l1.18,-0.96l1.23,-0.34l0.21,0.79l0.07,0.13l1.37,1.5l0.01,0.86l-0.39,1.0l-0.01,0.17l0.16,0.78l0.1,0.17l0.91,0.76l1.89,1.09l1.24,0.92l0.02,0.67l0.12,0.23l1.67,1.3l0.99,1.03l0.61,1.46l0.14,0.15l1.79,0.95l0.2,0.4l-0.44,0.14l-1.54,-0.06l-1.98,-0.26l-0.93,0.22l-0.19,0.14l-0.3,0.48l-0.57,0.05l-0.91,-0.49l-0.26,-0.01l-2.7,1.21l-1.04,-0.23l-0.21,0.03l-0.34,0.19l-0.12,0.13l-0.64,1.3l-1.67,-0.43l-1.77,-0.24l-1.58,-0.91l-2.06,-0.85l-0.27,0.02l-1.42,0.88l-0.97,1.27l-0.06,0.14l-0.19,1.46l-1.3,-0.11l-1.67,-0.42l-0.27,0.07l-1.55,1.41l-0.99,1.76l-0.14,-1.18l-0.13,-0.22l-1.1,-0.78l-0.86,-1.2l-0.2,-0.84l-0.07,-0.13l-1.07,-1.19l0.16,-0.59l0.0,-0.15l-0.24,-1.01l0.18,-1.77l0.5,-0.38l0.09,-0.11l1.18,-2.4Z", "name": "Central African Republic"}, "CD": {"path": "M497.85,276.25l-0.14,2.77l0.2,0.3l0.57,0.19l-0.47,0.52l-1.0,0.71l-0.96,1.31l-0.56,1.22l-0.16,2.04l-0.54,0.89l-0.04,0.15l-0.02,1.76l-0.63,0.61l-0.09,0.2l-0.08,1.33l-0.2,0.11l-0.15,0.21l-0.23,1.37l0.03,0.2l0.6,1.08l0.16,2.96l0.44,2.29l-0.24,1.25l0.01,0.15l0.5,1.46l0.07,0.12l1.41,1.37l1.09,2.56l-0.51,-0.11l-3.45,0.45l-0.67,0.3l-0.15,0.15l-0.71,1.61l0.01,0.26l0.52,1.03l-0.43,2.9l-0.31,2.55l0.13,0.29l0.7,0.46l1.75,0.99l0.31,-0.01l0.26,-0.17l0.15,1.9l-1.44,-0.02l-0.94,-1.28l-0.94,-1.1l-0.17,-0.1l-1.76,-0.33l-0.5,-1.18l-0.42,-0.15l-1.44,0.75l-1.79,-0.32l-0.77,-1.05l-0.2,-0.12l-1.59,-0.23l-0.97,0.04l-0.1,-0.53l-0.27,-0.25l-0.86,-0.06l-1.13,-0.15l-1.62,0.37l-1.04,-0.06l-0.32,0.09l0.11,-2.56l-0.08,-0.21l-0.77,-0.87l-0.17,-1.41l0.36,-1.47l-0.03,-0.21l-0.48,-0.91l-0.04,-1.52l-0.3,-0.29l-2.65,0.02l0.13,-0.53l-0.29,-0.37l-1.28,0.01l-0.28,0.21l-0.07,0.24l-1.35,0.09l-0.26,0.18l-0.62,1.45l-0.25,0.42l-1.17,-0.3l-0.19,0.01l-0.79,0.34l-1.44,0.18l-1.41,-1.96l-0.7,-1.47l-0.61,-1.86l-0.28,-0.21l-7.39,-0.03l-0.92,0.3l-0.78,-0.03l-0.78,0.25l-0.11,-0.25l0.35,-0.15l0.18,-0.26l0.07,-1.02l0.33,-0.52l0.72,-0.42l0.52,0.2l0.33,-0.08l0.76,-0.86l0.99,0.02l0.11,0.48l0.16,0.2l0.94,0.44l0.35,-0.07l1.46,-1.56l1.44,-1.21l0.68,-0.85l0.06,-0.2l-0.08,-1.99l1.04,-2.33l1.1,-1.23l1.62,-1.19l0.11,-0.14l0.29,-0.8l0.08,-0.94l0.38,-0.82l0.03,-0.16l-0.13,-1.38l0.3,-2.16l0.47,-1.51l0.73,-1.31l0.04,-0.12l0.15,-1.51l0.21,-1.66l0.89,-1.16l1.16,-0.7l1.9,0.79l1.69,0.95l1.81,0.24l1.85,0.48l0.35,-0.16l0.71,-1.43l0.16,-0.09l1.03,0.23l0.19,-0.02l2.65,-1.19l0.86,0.46l0.17,0.03l0.81,-0.08l0.23,-0.14l0.31,-0.5l0.75,-0.17l1.83,0.26l1.64,0.06l0.72,-0.21l1.39,1.9l0.16,0.11l1.12,0.3l0.24,-0.04l0.58,-0.36l1.05,0.15l0.15,-0.02l1.15,-0.44l0.47,0.84l0.08,0.09l2.08,1.57Z", "name": "Democratic Republic of the Congo"}, "CZ": {"path": "M463.29,152.22l-0.88,-0.47l-0.18,-0.03l-1.08,0.15l-1.86,-0.94l-0.21,-0.02l-0.88,0.24l-0.13,0.07l-1.25,1.17l-1.63,-0.91l-1.38,-1.36l-1.22,-0.75l-0.24,-1.24l-0.33,-0.75l1.53,-0.6l0.98,-0.84l1.74,-0.62l0.11,-0.07l0.47,-0.47l0.46,0.27l0.24,0.03l0.96,-0.3l1.06,0.95l0.15,0.07l1.57,0.24l-0.1,0.6l0.16,0.32l1.36,0.68l0.41,-0.15l0.28,-0.62l1.29,0.28l0.19,0.84l0.26,0.23l1.73,0.18l0.74,1.02l-0.17,0.0l-0.25,0.13l-0.32,0.49l-0.46,0.11l-0.22,0.23l-0.13,0.57l-0.32,0.1l-0.2,0.22l-0.03,0.14l-0.65,0.25l-1.05,-0.05l-0.28,0.17l-0.22,0.43Z", "name": "Czech Republic"}, "CY": {"path": "M505.03,193.75l-1.51,0.68l-1.0,-0.3l-0.32,-0.63l0.69,-0.06l0.41,0.13l0.19,-0.0l0.62,-0.22l0.31,0.02l0.06,0.22l0.49,0.17l0.06,-0.01Z", "name": "Cyprus"}, "CR": {"path": "M213.0,263.84l-0.98,-0.4l-0.3,-0.31l0.16,-0.24l0.05,-0.21l-0.09,-0.56l-0.1,-0.18l-0.76,-0.65l-0.99,-0.5l-0.74,-0.28l-0.13,-0.58l-0.12,-0.18l-0.66,-0.45l-0.34,-0.0l-0.13,0.31l0.13,0.59l-0.17,0.21l-0.34,-0.42l-0.14,-0.1l-0.7,-0.22l-0.23,-0.34l0.01,-0.62l0.31,-0.74l-0.14,-0.38l-0.3,-0.15l0.47,-0.4l1.48,0.6l0.26,-0.02l0.47,-0.27l0.58,0.15l0.35,0.44l0.17,0.11l0.74,0.17l0.27,-0.07l0.3,-0.27l0.52,1.09l0.97,1.02l0.77,0.71l-0.41,0.1l-0.23,0.3l0.01,1.02l0.12,0.24l0.2,0.14l-0.07,0.05l-0.11,0.3l0.08,0.37l-0.23,0.63Z", "name": "Costa Rica"}, "CU": {"path": "M215.01,226.09l2.08,0.18l1.94,0.03l2.24,0.86l0.95,0.92l0.25,0.08l2.22,-0.28l0.79,0.55l3.68,2.81l0.19,0.06l0.77,-0.03l1.18,0.42l-0.12,0.47l0.27,0.37l1.78,0.1l1.59,0.9l-0.11,0.22l-1.5,0.3l-1.64,0.13l-1.75,-0.2l-2.69,0.19l1.0,-0.86l-0.03,-0.48l-1.02,-0.68l-0.13,-0.05l-1.52,-0.16l-0.74,-0.64l-0.57,-1.42l-0.3,-0.19l-1.36,0.1l-2.23,-0.67l-0.71,-0.52l-0.14,-0.06l-3.2,-0.4l-0.42,-0.25l0.56,-0.39l0.12,-0.33l-0.27,-0.22l-2.46,-0.13l-0.2,0.06l-1.72,1.31l-0.94,0.03l-0.25,0.15l-0.29,0.53l-1.04,0.24l-0.29,-0.07l0.7,-0.43l0.1,-0.11l0.5,-0.87l1.04,-0.54l1.23,-0.49l1.86,-0.25l0.62,-0.28Z", "name": "Cuba"}, "SZ": {"path": "M500.95,353.41l-0.41,0.97l-1.16,0.23l-1.29,-1.26l-0.02,-0.71l0.63,-0.93l0.23,-0.7l0.47,-0.12l1.04,0.4l0.32,1.05l0.2,1.08Z", "name": "Swaziland"}, "SY": {"path": "M510.84,199.83l0.09,-0.11l0.07,-0.2l-0.04,-1.08l0.56,-1.4l1.3,-1.01l0.1,-0.34l-0.41,-1.11l-0.24,-0.19l-0.89,-0.11l-0.2,-1.84l0.55,-1.05l1.3,-1.22l0.09,-0.19l0.09,-1.09l0.39,0.27l0.25,0.04l2.66,-0.77l1.35,0.52l2.06,-0.01l2.93,-1.08l1.35,0.04l2.14,-0.34l-0.83,1.16l-1.31,0.68l-0.16,0.3l0.23,2.03l-0.9,3.25l-5.43,2.87l-4.79,2.91l-2.32,-0.92Z", "name": "Syria"}, "KG": {"path": "M599.04,172.15l0.38,-0.9l1.43,-0.37l4.04,1.02l0.37,-0.23l0.36,-1.64l1.17,-0.52l3.45,1.24l0.2,-0.0l0.86,-0.31l4.09,0.08l3.61,0.31l1.18,1.02l0.11,0.06l1.19,0.34l-0.13,0.26l-3.84,1.58l-0.13,0.1l-0.81,1.08l-3.08,0.34l-0.24,0.16l-0.85,1.7l-2.43,-0.37l-0.14,0.01l-1.79,0.61l-2.39,1.4l-0.12,0.39l0.25,0.49l-0.48,0.45l-4.57,0.43l-3.04,-0.94l-2.45,0.18l0.14,-1.02l2.42,0.44l0.27,-0.08l0.81,-0.81l1.76,0.27l0.21,-0.05l3.21,-2.14l-0.03,-0.51l-2.97,-1.57l-0.26,-0.01l-1.64,0.69l-1.38,-0.84l1.81,-1.67l-0.09,-0.5l-0.46,-0.18Z", "name": "Kyrgyzstan"}, "KE": {"path": "M523.3,287.04l0.06,0.17l1.29,1.8l-1.46,0.84l-0.11,0.11l-0.55,0.93l-0.81,0.16l-0.24,0.24l-0.34,1.69l-0.81,1.06l-0.46,1.58l-0.76,0.63l-3.3,-2.3l-0.16,-1.32l-0.15,-0.23l-9.35,-5.28l-0.02,-2.4l1.92,-2.63l0.91,-1.83l0.01,-0.24l-1.09,-2.86l-0.29,-1.24l-1.09,-1.63l2.93,-2.85l0.92,0.3l0.0,1.19l0.09,0.22l0.86,0.83l0.21,0.08l1.65,0.0l3.09,2.08l0.16,0.05l0.79,0.03l0.54,-0.06l0.58,0.28l1.67,0.2l0.28,-0.12l0.69,-0.98l2.04,-0.94l0.86,0.73l0.19,0.07l1.1,0.0l-1.82,2.36l-0.06,0.18l0.03,9.12Z", "name": "Kenya"}, "SS": {"path": "M505.7,261.39l0.02,1.64l-0.27,0.55l-1.15,0.05l-0.24,0.15l-0.85,1.44l0.22,0.45l1.44,0.17l1.15,1.12l0.42,0.95l0.14,0.15l1.06,0.54l1.33,2.45l-3.06,2.98l-1.44,1.08l-1.75,0.01l-1.92,0.56l-1.5,-0.53l-0.27,0.03l-0.85,0.57l-1.98,-1.5l-0.56,-1.02l-0.37,-0.13l-1.32,0.5l-1.08,-0.15l-0.2,0.04l-0.56,0.35l-0.9,-0.24l-1.44,-1.97l-0.39,-0.77l-0.13,-0.13l-1.78,-0.94l-0.65,-1.5l-1.08,-1.12l-1.57,-1.22l-0.02,-0.68l-0.12,-0.23l-1.37,-1.02l-1.17,-0.68l0.2,-0.08l0.86,-0.48l0.14,-0.18l0.63,-2.22l0.6,-1.02l1.47,-0.28l0.35,0.56l1.29,1.48l0.14,0.09l0.69,0.22l0.22,-0.02l0.83,-0.4l1.58,0.08l0.26,0.39l0.25,0.13l2.49,0.0l0.3,-0.25l0.06,-0.35l1.13,-0.42l0.18,-0.18l0.22,-0.63l0.68,-0.38l1.95,1.37l0.23,0.05l1.29,-0.26l0.19,-0.12l1.23,-1.8l1.36,-1.37l0.08,-0.25l-0.21,-1.52l-0.06,-0.15l-0.25,-0.3l0.94,-0.08l0.26,-0.21l0.1,-0.32l0.6,0.09l-0.25,1.67l0.3,1.83l0.11,0.19l1.22,0.94l0.25,0.73l-0.04,1.2l0.26,0.31l0.09,0.01Z", "name": "South Sudan"}, "SR": {"path": "M278.1,270.26l2.71,0.45l0.31,-0.14l0.19,-0.32l1.82,-0.16l2.25,0.56l-1.09,1.81l-0.04,0.19l0.2,1.72l0.05,0.13l0.9,1.35l-0.39,0.99l-0.21,1.09l-0.48,0.8l-1.2,-0.44l-0.17,-0.01l-1.12,0.24l-0.95,-0.21l-0.35,0.2l-0.25,0.73l0.05,0.29l0.3,0.35l-0.06,0.13l-1.01,-0.15l-1.42,-2.03l-0.32,-1.36l-0.29,-0.23l-0.63,-0.0l-0.95,-1.56l0.41,-1.16l0.01,-0.17l-0.08,-0.35l1.29,-0.56l0.18,-0.22l0.35,-1.97Z", "name": "Suriname"}, "KH": {"path": "M680.28,257.89l-0.93,-1.2l-1.24,-2.56l-0.56,-2.9l1.45,-1.92l3.07,-0.46l2.26,0.35l2.03,0.98l0.38,-0.11l1.0,-1.55l1.86,0.79l0.52,1.51l-0.28,2.82l-4.05,1.88l-0.12,0.45l0.79,1.1l-2.2,0.17l-2.08,0.98l-1.89,-0.33Z", "name": "Cambodia"}, "SV": {"path": "M197.02,248.89l0.18,-0.05l0.59,0.17l0.55,0.51l0.64,0.35l0.06,0.22l0.37,0.21l1.01,-0.28l0.38,0.13l0.16,0.13l-0.14,0.81l-0.18,0.38l-1.22,-0.03l-0.84,-0.23l-1.11,-0.52l-1.31,-0.15l-0.49,-0.38l0.02,-0.08l0.76,-0.57l0.46,-0.27l0.11,-0.35Z", "name": "El Salvador"}, "SK": {"path": "M468.01,150.02l0.05,0.07l0.36,0.1l0.85,-0.37l1.12,1.02l0.33,0.05l1.38,-0.65l1.07,0.3l0.16,0.0l1.69,-0.43l1.95,1.02l-0.51,0.64l-0.45,1.2l-0.32,0.2l-2.55,-0.93l-0.17,-0.01l-0.82,0.2l-0.17,0.11l-0.53,0.68l-0.94,0.32l-0.14,-0.11l-0.29,-0.04l-1.18,0.48l-0.95,0.09l-0.26,0.21l-0.15,0.47l-1.84,0.34l-0.82,-0.31l-1.14,-0.73l-0.2,-0.89l0.42,-0.84l0.91,0.05l0.12,-0.02l0.86,-0.33l0.18,-0.21l0.03,-0.13l0.32,-0.1l0.2,-0.22l0.12,-0.55l0.39,-0.1l0.18,-0.13l0.3,-0.45l0.43,-0.0Z", "name": "Slovakia"}, "KR": {"path": "M737.31,185.72l0.84,0.08l0.27,-0.12l0.89,-1.2l1.63,-0.13l1.1,-0.2l0.21,-0.16l0.12,-0.24l1.86,2.95l0.59,1.79l0.02,3.17l-0.84,1.38l-2.23,0.55l-1.95,1.14l-1.91,0.21l-0.22,-1.21l0.45,-2.07l-0.01,-0.17l-0.99,-2.67l1.54,-0.4l0.17,-0.46l-1.55,-2.24Z", "name": "South Korea"}, "SI": {"path": "M455.77,159.59l1.79,0.21l0.18,-0.04l1.2,-0.68l2.12,-0.08l0.21,-0.1l0.38,-0.42l0.1,0.01l0.28,0.62l-1.71,0.71l-0.18,0.22l-0.21,1.1l-0.71,0.26l-0.2,0.28l0.01,0.55l-0.59,-0.04l-0.79,-0.47l-0.38,0.06l-0.36,0.41l-0.84,-0.05l0.05,-0.15l-0.56,-1.24l0.21,-1.17Z", "name": "Slovenia"}, "KP": {"path": "M747.76,172.02l-0.23,-0.04l-0.26,0.08l-1.09,1.02l-0.78,1.06l-0.06,0.19l0.09,1.95l-1.12,0.57l-0.53,0.58l-0.88,0.82l-1.69,0.51l-1.09,0.79l-0.12,0.22l-0.07,1.17l-0.22,0.25l0.09,0.47l0.96,0.46l1.22,1.1l-0.19,0.37l-0.91,0.16l-1.75,0.14l-0.22,0.12l-0.87,1.18l-0.95,-0.09l-0.3,0.18l-0.97,-0.44l-0.39,0.13l-0.25,0.44l-0.29,0.09l-0.03,-0.2l-0.18,-0.23l-0.62,-0.25l-0.43,-0.29l0.52,-0.97l0.52,-0.3l0.13,-0.38l-0.18,-0.42l0.59,-1.47l0.01,-0.21l-0.16,-0.48l-0.22,-0.2l-1.41,-0.31l-0.82,-0.55l1.74,-1.62l2.73,-1.58l1.62,-1.96l0.96,0.76l0.17,0.06l2.17,0.11l0.31,-0.37l-0.32,-1.31l3.61,-1.21l0.16,-0.13l0.79,-1.34l1.25,1.38Z", "name": "North Korea"}, "SO": {"path": "M543.8,256.48l0.61,-0.05l1.14,-0.37l1.31,-0.25l0.12,-0.05l1.11,-0.81l0.57,-0.0l0.03,0.39l-0.23,1.49l0.01,1.25l-0.52,0.92l-0.7,2.71l-1.19,2.79l-1.54,3.2l-2.13,3.66l-2.12,2.79l-2.92,3.39l-2.47,2.0l-3.76,2.5l-2.33,1.9l-2.77,3.06l-0.61,1.35l-0.28,0.29l-1.22,-1.69l-0.03,-8.92l2.12,-2.76l0.59,-0.68l1.47,-0.04l0.18,-0.06l2.15,-1.71l3.16,-0.11l0.21,-0.09l7.08,-7.55l1.76,-2.12l1.14,-1.57l0.06,-0.18l0.01,-4.67Z", "name": "Somalia"}, "SN": {"path": "M379.28,250.34l-0.95,-1.82l-0.09,-0.1l-0.83,-0.6l0.62,-0.28l0.13,-0.11l1.21,-1.8l0.6,-1.31l0.71,-0.68l1.09,0.2l0.18,-0.02l1.17,-0.53l1.25,-0.03l1.17,0.73l1.59,0.65l1.47,1.83l1.59,1.7l0.12,1.56l0.49,1.46l0.1,0.14l0.85,0.65l0.18,0.82l-0.08,0.57l-0.13,0.05l-1.29,-0.19l-0.29,0.13l-0.11,0.16l-0.35,0.04l-1.83,-0.61l-5.84,-0.13l-0.12,0.02l-0.6,0.26l-0.87,-0.06l-1.01,0.32l-0.26,-1.26l1.9,0.04l0.16,-0.04l0.54,-0.32l0.37,-0.02l0.15,-0.05l0.78,-0.5l0.92,0.46l0.12,0.03l1.09,0.04l0.15,-0.03l1.08,-0.57l0.11,-0.44l-0.51,-0.74l-0.39,-0.1l-0.76,0.39l-0.62,-0.01l-0.92,-0.58l-0.18,-0.05l-0.79,0.04l-0.2,0.09l-0.48,0.51l-2.41,0.06Z", "name": "Senegal"}, "SL": {"path": "M392.19,267.53l-0.44,-0.12l-1.73,-0.97l-1.24,-1.28l-0.4,-0.84l-0.27,-1.65l1.21,-1.0l0.09,-0.12l0.27,-0.66l0.32,-0.41l0.56,-0.05l0.16,-0.07l0.5,-0.41l1.75,0.0l0.59,0.77l0.49,0.96l-0.07,0.64l0.04,0.19l0.36,0.58l-0.03,0.84l0.24,0.2l-0.64,0.65l-1.13,1.37l-0.06,0.14l-0.12,0.66l-0.43,0.58Z", "name": "Sierra Leone"}, "SB": {"path": "M826.74,311.51l0.23,0.29l-0.95,-0.01l-0.39,-0.63l0.65,0.27l0.45,0.09ZM825.01,308.52l-1.18,-1.39l-0.37,-1.06l0.24,0.0l0.82,1.84l0.49,0.6ZM823.21,309.42l-0.44,0.03l-1.43,-0.24l-0.32,-0.24l0.08,-0.5l1.29,0.31l0.72,0.47l0.11,0.18ZM817.9,303.81l2.59,1.44l0.3,0.41l-1.21,-0.66l-1.34,-0.89l-0.34,-0.3ZM813.77,302.4l0.48,0.34l0.1,0.08l-0.33,-0.17l-0.25,-0.25Z", "name": "Solomon Islands"}, "SA": {"path": "M528.24,243.1l-0.2,-0.69l-0.07,-0.12l-0.69,-0.71l-0.18,-0.94l-0.12,-0.19l-1.24,-0.89l-1.28,-2.09l-0.7,-2.08l-0.07,-0.11l-1.73,-1.79l-0.11,-0.07l-1.03,-0.39l-1.57,-2.36l-0.27,-1.72l0.1,-1.53l-0.03,-0.15l-1.44,-2.93l-1.25,-1.13l-1.34,-0.56l-0.72,-1.33l0.11,-0.49l-0.02,-0.2l-0.7,-1.38l-0.08,-0.1l-0.68,-0.56l-0.97,-1.98l-2.8,-4.03l-0.25,-0.13l-0.85,0.01l0.29,-1.11l0.12,-0.97l0.23,-0.81l2.52,0.39l0.23,-0.06l1.08,-0.84l0.6,-0.95l1.78,-0.35l0.22,-0.17l0.37,-0.83l0.74,-0.42l0.08,-0.46l-2.17,-2.4l4.55,-1.26l0.12,-0.06l0.36,-0.32l2.83,0.71l3.67,1.91l7.04,5.5l0.17,0.06l4.64,0.22l2.06,0.24l0.55,1.15l0.28,0.17l1.56,-0.06l0.9,2.15l0.14,0.15l1.14,0.57l0.39,0.85l0.11,0.13l1.59,1.06l0.12,0.91l-0.23,0.83l0.01,0.18l0.32,0.9l0.07,0.11l0.68,0.7l0.33,0.86l0.37,0.65l0.09,0.1l0.76,0.53l0.25,0.04l0.45,-0.12l0.35,0.75l0.1,0.63l0.96,2.68l0.23,0.19l7.53,1.33l0.27,-0.09l0.24,-0.26l0.87,1.41l-1.58,4.96l-7.34,2.54l-7.28,1.02l-2.34,1.17l-0.12,0.1l-1.74,2.63l-0.86,0.32l-0.49,-0.68l-0.28,-0.12l-0.92,0.12l-2.32,-0.25l-0.41,-0.23l-0.15,-0.04l-2.89,0.06l-0.63,0.2l-0.91,-0.59l-0.43,0.11l-0.66,1.27l-0.03,0.21l0.21,0.89l-0.6,0.45Z", "name": "Saudi Arabia"}, "SE": {"path": "M476.42,90.44l-0.15,0.1l-2.43,2.86l-0.07,0.24l0.36,2.31l-3.84,3.1l-4.83,3.38l-0.11,0.15l-1.82,5.45l0.03,0.26l1.78,2.68l2.27,1.99l-2.13,3.88l-2.49,0.82l-0.2,0.24l-0.95,6.05l-1.32,3.09l-2.82,-0.32l-0.3,0.16l-1.34,2.64l-2.48,0.14l-0.76,-3.15l-2.09,-4.04l-1.85,-5.01l1.03,-1.98l2.06,-2.53l0.06,-0.13l0.83,-4.45l-0.06,-0.25l-1.54,-1.86l-0.15,-5.0l1.52,-3.48l2.28,0.06l0.27,-0.16l0.87,-1.59l-0.01,-0.31l-0.8,-1.21l3.79,-5.63l4.07,-7.54l2.23,0.01l0.29,-0.22l0.59,-2.15l4.46,0.66l0.34,-0.26l0.34,-2.64l1.21,-0.14l3.24,2.08l3.78,2.85l0.06,6.37l0.03,0.14l0.67,1.29l-3.95,1.07Z", "name": "Sweden"}, "SD": {"path": "M505.98,259.75l-0.31,-0.9l-0.1,-0.14l-1.2,-0.93l-0.27,-1.66l0.29,-1.83l-0.25,-0.34l-1.16,-0.17l-0.33,0.21l-0.11,0.37l-1.3,0.11l-0.21,0.49l0.55,0.68l0.18,1.29l-1.31,1.33l-1.18,1.72l-1.04,0.21l-2.0,-1.4l-0.32,-0.02l-0.95,0.52l-0.14,0.16l-0.21,0.6l-1.16,0.43l-0.19,0.23l-0.04,0.27l-2.08,0.0l-0.25,-0.39l-0.24,-0.13l-1.81,-0.09l-0.14,0.03l-0.8,0.38l-0.49,-0.16l-1.22,-1.39l-0.42,-0.67l-0.31,-0.14l-1.81,0.35l-0.2,0.14l-0.72,1.24l-0.61,2.14l-0.73,0.4l-0.62,0.22l-0.83,-0.68l-0.12,-0.6l0.38,-0.97l0.01,-1.14l-0.08,-0.2l-1.39,-1.53l-0.25,-0.97l0.03,-0.57l-0.11,-0.25l-0.81,-0.66l-0.03,-1.34l-0.04,-0.14l-0.52,-0.98l-0.31,-0.15l-0.42,0.07l0.12,-0.44l0.63,-1.03l0.03,-0.23l-0.24,-0.88l0.69,-0.66l0.02,-0.41l-0.4,-0.46l0.58,-1.39l1.04,-1.71l1.97,0.16l0.32,-0.3l-0.12,-10.24l0.02,-0.8l2.59,-0.01l0.3,-0.3l0.0,-4.92l29.19,0.0l0.68,2.17l-0.4,0.35l-0.1,0.27l0.36,2.69l0.93,3.15l0.12,0.16l2.05,1.4l-0.99,1.15l-1.75,0.4l-0.15,0.08l-0.79,0.79l-0.08,0.17l-0.24,1.69l-1.07,3.75l-0.0,0.16l0.25,0.96l-0.38,2.1l-0.98,2.41l-1.52,1.3l-1.07,1.94l-0.25,0.99l-1.08,0.64l-0.13,0.18l-0.46,1.65Z", "name": "Sudan"}, "DO": {"path": "M241.7,234.97l0.15,-0.22l1.73,0.01l1.43,0.64l0.15,0.03l0.45,-0.04l0.36,0.74l0.28,0.17l1.02,-0.04l-0.04,0.43l0.27,0.33l1.03,0.09l0.91,0.7l-0.57,0.64l-0.99,-0.47l-0.16,-0.03l-1.11,0.11l-0.79,-0.12l-0.26,0.09l-0.38,0.4l-0.66,0.11l-0.28,-0.45l-0.38,-0.12l-0.83,0.37l-0.14,0.13l-0.85,1.49l-0.27,-0.17l-0.1,-0.58l0.05,-0.67l-0.07,-0.21l-0.44,-0.53l0.35,-0.25l0.12,-0.19l0.19,-1.0l-0.2,-1.4Z", "name": "Dominican Republic"}, "DJ": {"path": "M528.78,253.36l0.34,0.45l-0.06,0.76l-1.26,0.54l-0.05,0.53l0.82,0.53l-0.57,0.83l-0.3,-0.25l-0.27,-0.05l-0.56,0.17l-1.07,-0.03l-0.04,-0.56l-0.16,-0.56l0.76,-1.07l0.76,-0.97l0.89,0.18l0.25,-0.06l0.51,-0.42Z", "name": "Djibouti"}, "DK": {"path": "M452.4,129.07l-1.27,2.39l-2.25,-1.69l-0.26,-1.08l3.15,-1.0l0.63,1.39ZM447.87,126.25l-0.35,0.76l-0.47,-0.24l-0.38,0.09l-1.8,2.53l-0.03,0.29l0.56,1.4l-1.22,0.4l-1.68,-0.41l-0.92,-1.76l-0.07,-3.47l0.38,-0.88l0.62,-0.93l2.07,-0.21l0.19,-0.1l0.84,-0.95l1.5,-0.76l-0.06,1.26l-0.7,1.1l-0.03,0.25l0.3,1.0l0.18,0.19l1.06,0.42Z", "name": "Denmark"}, "DE": {"path": "M445.51,131.69l0.03,0.94l0.21,0.28l2.32,0.74l-0.02,1.0l0.37,0.3l2.55,-0.65l1.36,-0.89l2.63,1.27l1.09,1.01l0.51,1.51l-0.6,0.78l-0.0,0.36l0.88,1.17l0.58,1.68l-0.18,1.08l0.03,0.18l0.87,1.81l-0.66,0.2l-0.55,-0.32l-0.36,0.05l-0.58,0.58l-1.73,0.62l-0.99,0.84l-1.77,0.7l-0.16,0.4l0.42,0.94l0.26,1.34l0.14,0.2l1.25,0.76l1.22,1.2l-0.71,1.2l-0.81,0.37l-0.17,0.32l0.34,1.99l-0.04,0.09l-0.47,-0.39l-0.17,-0.07l-1.2,-0.1l-1.85,0.57l-2.15,-0.13l-0.29,0.18l-0.21,0.5l-0.96,-0.67l-0.24,-0.05l-0.67,0.16l-2.6,-0.94l-0.34,0.1l-0.42,0.57l-1.64,-0.02l0.26,-1.88l1.24,-2.15l-0.21,-0.45l-3.54,-0.58l-0.98,-0.71l0.12,-1.26l-0.05,-0.2l-0.44,-0.64l0.27,-2.18l-0.38,-3.14l1.17,-0.0l0.27,-0.17l0.63,-1.26l0.65,-3.17l-0.02,-0.17l-0.41,-1.0l0.32,-0.47l1.77,-0.16l0.37,0.6l0.47,0.06l1.7,-1.69l0.06,-0.33l-0.55,-1.24l-0.09,-1.51l1.5,0.36l0.16,-0.01l1.22,-0.4Z", "name": "Germany"}, "YE": {"path": "M553.53,242.65l-1.51,0.58l-0.17,0.16l-0.48,1.14l-0.07,0.79l-2.31,1.0l-3.98,1.19l-2.28,1.8l-0.97,0.12l-0.7,-0.14l-0.23,0.05l-1.42,1.03l-1.51,0.47l-2.07,0.13l-0.68,0.15l-0.17,0.1l-0.49,0.6l-0.57,0.16l-0.18,0.13l-0.3,0.49l-1.06,-0.05l-0.13,0.02l-0.73,0.32l-1.48,-0.11l-0.55,-1.26l0.07,-1.32l-0.04,-0.16l-0.39,-0.72l-0.48,-1.85l-0.52,-0.79l0.08,-0.02l0.22,-0.36l-0.23,-1.05l0.24,-0.39l0.04,-0.19l-0.09,-0.95l0.96,-0.72l0.11,-0.31l-0.23,-0.98l0.46,-0.88l0.75,0.49l0.26,0.03l0.63,-0.22l2.76,-0.06l0.5,0.25l2.42,0.26l0.85,-0.11l0.52,0.71l0.35,0.1l1.17,-0.43l0.15,-0.12l1.75,-2.64l2.22,-1.11l6.95,-0.96l2.55,5.58Z", "name": "Yemen"}, "AT": {"path": "M463.17,154.15l-0.14,0.99l-1.15,0.01l-0.24,0.47l0.39,0.56l-0.75,1.84l-0.36,0.4l-2.06,0.07l-0.14,0.04l-1.18,0.67l-1.96,-0.23l-3.43,-0.78l-0.5,-0.97l-0.33,-0.16l-2.47,0.55l-0.2,0.16l-0.18,0.37l-1.27,-0.38l-1.28,-0.09l-0.81,-0.41l0.25,-0.51l0.03,-0.18l-0.05,-0.28l0.35,-0.08l1.16,0.81l0.45,-0.13l0.27,-0.64l2.0,0.12l1.84,-0.57l1.05,0.09l0.71,0.59l0.47,-0.11l0.23,-0.54l0.02,-0.17l-0.32,-1.85l0.69,-0.31l0.13,-0.12l0.73,-1.23l1.61,0.89l0.35,-0.04l1.35,-1.27l0.7,-0.19l1.84,0.93l0.18,0.03l1.08,-0.15l0.81,0.43l-0.07,0.15l-0.02,0.2l0.24,1.06Z", "name": "Austria"}, "DZ": {"path": "M450.58,224.94l-8.31,4.86l-7.23,5.12l-3.46,1.13l-2.42,0.22l-0.02,-1.33l-0.2,-0.28l-1.15,-0.42l-1.45,-0.69l-0.55,-1.13l-0.1,-0.12l-8.45,-5.72l-17.72,-12.17l0.03,-0.38l-0.02,-3.21l3.84,-1.91l2.46,-0.41l2.1,-0.75l0.14,-0.11l0.9,-1.3l2.84,-1.06l0.19,-0.27l0.09,-1.81l1.21,-0.2l0.15,-0.07l1.06,-0.96l3.19,-0.46l0.23,-0.18l0.46,-1.08l-0.08,-0.34l-0.6,-0.54l-0.83,-2.85l-0.18,-1.8l-0.82,-1.57l2.13,-1.37l2.65,-0.49l0.13,-0.05l1.55,-1.15l2.34,-0.85l4.2,-0.51l4.07,-0.23l1.21,0.41l0.23,-0.01l2.3,-1.11l2.52,-0.02l0.94,0.62l0.2,0.05l1.25,-0.13l-0.36,1.03l-0.01,0.14l0.39,2.66l-0.56,2.2l-1.49,1.52l-0.08,0.24l0.22,2.12l0.11,0.2l1.94,1.58l0.02,0.54l0.12,0.23l1.45,1.06l1.04,4.85l0.81,2.42l0.13,1.19l-0.43,2.17l0.17,1.28l-0.31,1.53l0.2,1.56l-0.9,1.02l-0.01,0.38l1.43,1.88l0.09,1.06l0.04,0.13l0.89,1.48l0.37,0.12l1.03,-0.43l1.79,1.12l0.89,1.34Z", "name": "Algeria"}, "US": {"path": "M892.64,99.05l1.16,0.57l0.21,0.02l1.45,-0.38l1.92,0.99l2.17,0.47l-1.65,0.72l-1.75,-0.79l-0.93,-0.7l-0.21,-0.06l-2.11,0.22l-0.35,-0.2l0.09,-0.87ZM183.29,150.37l0.39,1.54l0.12,0.17l0.78,0.55l0.14,0.05l1.74,0.2l2.52,0.5l2.4,0.98l0.17,0.02l1.96,-0.4l3.01,0.81l0.91,-0.02l2.22,-0.88l4.67,2.33l3.86,2.01l0.21,0.71l0.15,0.18l0.33,0.17l-0.02,0.05l0.23,0.43l0.67,0.1l0.21,-0.05l0.1,-0.07l0.05,0.29l0.09,0.16l0.5,0.5l0.21,0.09l0.56,0.0l0.13,0.13l-0.2,0.36l0.12,0.41l2.49,1.39l0.99,5.24l-0.69,1.68l-1.16,1.64l-0.6,1.18l-0.06,0.31l0.04,0.22l0.28,0.43l0.11,0.1l0.85,0.47l0.15,0.04l0.63,0.0l0.14,-0.04l2.87,-1.58l2.6,-0.49l3.28,-1.5l0.17,-0.23l0.04,-0.43l-0.23,-0.93l-0.24,-0.39l0.74,-0.32l4.7,-0.01l0.25,-0.13l0.77,-1.15l2.9,-2.41l1.04,-0.52l8.35,-0.02l0.28,-0.21l0.2,-0.6l0.7,-0.14l1.06,-0.48l0.13,-0.11l0.92,-1.49l0.75,-2.39l1.67,-2.08l0.59,0.6l0.3,0.07l1.52,-0.49l0.88,0.72l-0.0,4.14l0.08,0.2l1.6,1.72l0.31,0.72l-2.42,1.35l-2.55,1.05l-2.64,0.9l-0.14,0.11l-1.33,1.81l-0.44,0.7l-0.05,0.15l-0.03,1.6l0.03,0.14l0.83,1.59l0.24,0.16l0.78,0.06l-1.15,0.33l-1.25,-0.04l-1.83,0.52l-2.51,0.29l-2.17,0.88l-0.17,0.36l0.33,0.22l3.55,-0.54l0.15,0.11l-2.87,0.73l-1.19,0.0l-0.16,-0.33l-0.36,0.06l-0.76,0.82l0.17,0.5l0.42,0.08l-0.45,1.75l-1.4,1.74l-0.04,-0.17l-0.21,-0.22l-0.48,-0.13l-0.77,-0.69l-0.36,-0.03l-0.12,0.34l0.52,1.58l0.09,0.14l0.52,0.43l0.03,0.87l-0.74,1.05l-0.39,0.63l0.05,-0.12l-0.08,-0.34l-1.19,-1.03l-0.28,-2.31l-0.26,-0.26l-0.32,0.19l-0.48,1.27l-0.01,0.19l0.39,1.33l-1.14,-0.31l-0.36,0.18l0.14,0.38l1.57,0.85l0.1,2.58l0.22,0.28l0.55,0.15l0.21,0.81l0.33,2.72l-1.46,1.94l-2.5,0.81l-0.12,0.07l-1.58,1.58l-1.15,0.17l-0.15,0.06l-1.27,1.03l-0.09,0.13l-0.32,0.85l-2.71,1.79l-1.45,1.37l-1.18,1.64l-0.05,0.12l-0.39,1.96l0.0,0.13l0.44,1.91l0.85,2.37l1.1,1.91l0.03,1.2l1.16,3.07l-0.08,1.74l-0.1,0.99l-0.57,1.48l-0.54,0.24l-0.97,-0.26l-0.34,-1.02l-0.12,-0.16l-0.89,-0.58l-2.44,-4.28l-0.34,-0.94l0.49,-1.71l-0.02,-0.21l-0.7,-1.5l-2.0,-2.35l-0.11,-0.08l-0.98,-0.42l-0.25,0.01l-2.42,1.19l-0.26,-0.08l-1.26,-1.29l-1.57,-0.68l-0.16,-0.02l-2.79,0.34l-2.18,-0.3l-1.98,0.19l-1.12,0.45l-0.14,0.44l0.4,0.65l-0.04,1.02l0.09,0.22l0.29,0.3l-0.06,0.05l-0.77,-0.33l-0.26,0.01l-0.87,0.48l-1.64,-0.08l-1.79,-1.39l-0.23,-0.06l-2.11,0.33l-1.75,-0.61l-0.14,-0.01l-1.61,0.2l-2.11,0.64l-0.11,0.06l-2.25,1.99l-2.53,1.21l-1.43,1.38l-0.58,1.22l-0.03,0.12l-0.03,1.86l0.13,1.32l0.3,0.62l-0.46,0.04l-1.71,-0.57l-1.85,-0.79l-0.63,-1.14l-0.54,-1.85l-0.07,-0.12l-1.45,-1.51l-0.86,-1.58l-1.26,-1.87l-0.09,-0.09l-1.76,-1.09l-0.17,-0.04l-2.05,0.05l-0.23,0.12l-1.44,1.97l-1.84,-0.72l-1.19,-0.76l-0.6,-1.45l-0.9,-1.52l-1.49,-1.21l-1.27,-0.87l-0.89,-0.96l-0.22,-0.1l-4.34,-0.0l-0.3,0.3l-0.0,0.84l-6.62,0.02l-5.66,-1.93l-3.48,-1.24l0.11,-0.25l-0.3,-0.42l-3.18,0.3l-2.6,0.2l-0.35,-1.19l-0.08,-0.13l-1.62,-1.61l-0.13,-0.08l-1.02,-0.29l-0.22,-0.66l-0.25,-0.2l-1.31,-0.13l-0.82,-0.7l-0.16,-0.07l-2.25,-0.27l-0.48,-0.34l-0.28,-1.44l-0.07,-0.14l-2.41,-2.84l-2.03,-3.89l0.08,-0.58l-0.1,-0.27l-1.08,-0.94l-1.87,-2.36l-0.33,-2.31l-0.07,-0.15l-1.24,-1.5l0.52,-2.4l-0.09,-2.57l-0.78,-2.3l0.96,-2.83l0.61,-5.66l-0.46,-4.26l-0.79,-2.71l-0.68,-1.4l0.13,-0.26l3.24,0.97l1.28,2.88l0.52,0.06l0.62,-0.84l0.06,-0.22l-0.4,-2.61l-0.74,-2.29l68.9,-0.0l0.3,-0.3l0.01,-0.95l0.32,-0.01ZM32.5,67.43l1.75,1.99l0.41,0.04l1.02,-0.81l3.79,0.25l-0.1,0.72l0.24,0.34l3.83,0.77l2.6,-0.44l5.21,1.41l4.84,0.43l1.9,0.57l0.15,0.01l3.25,-0.71l3.72,1.32l2.52,0.58l-0.03,38.14l0.29,0.3l2.41,0.11l2.34,1.0l1.7,1.59l2.22,2.42l0.42,0.03l2.41,-2.04l2.25,-1.08l1.23,1.76l1.71,1.53l2.24,1.62l1.54,2.56l2.56,4.09l0.11,0.11l4.1,2.17l0.06,1.93l-1.12,1.35l-1.22,-1.14l-2.08,-1.05l-0.68,-2.94l-0.09,-0.16l-3.18,-2.84l-1.32,-3.35l-0.25,-0.19l-2.43,-0.24l-3.93,-0.09l-2.85,-1.02l-5.24,-3.85l-6.77,-2.04l-3.52,0.3l-4.84,-1.7l-2.96,-1.6l-0.23,-0.02l-2.78,0.8l-0.21,0.35l0.46,2.31l-1.11,0.19l-2.9,0.78l-2.24,1.26l-2.42,0.68l-0.29,-1.79l1.07,-3.49l2.54,-1.11l0.12,-0.45l-0.69,-0.96l-0.41,-0.07l-3.19,2.12l-1.76,2.54l-3.57,2.62l-0.03,0.46l1.63,1.59l-2.14,2.38l-2.64,1.49l-2.49,1.09l-0.16,0.17l-0.58,1.48l-3.8,1.79l-0.14,0.14l-0.75,1.57l-2.75,1.41l-1.62,-0.25l-0.16,0.02l-2.35,0.98l-2.54,1.19l-2.06,1.15l-4.05,0.93l-0.1,-0.15l2.45,-1.45l2.49,-1.1l2.61,-1.88l3.03,-0.39l0.19,-0.1l1.2,-1.41l3.43,-2.11l0.61,-0.75l1.81,-1.24l0.13,-0.2l0.42,-2.7l1.24,-2.12l-0.03,-0.35l-0.34,-0.09l-2.73,1.05l-0.67,-0.53l-0.39,0.02l-1.13,1.11l-1.43,-1.62l-0.49,0.06l-0.41,0.8l-0.67,-1.31l-0.42,-0.12l-2.43,1.43l-1.18,-0.0l-0.18,-1.86l0.43,-1.3l-0.09,-0.33l-1.61,-1.33l-0.26,-0.06l-3.11,0.68l-2.0,-1.66l-1.61,-0.85l-0.01,-1.97l-0.11,-0.23l-1.76,-1.48l0.86,-1.96l2.01,-2.13l0.88,-1.94l1.79,-0.25l1.65,0.6l0.31,-0.06l1.91,-1.8l1.67,0.31l0.22,-0.04l1.91,-1.23l0.13,-0.33l-0.47,-1.82l-0.15,-0.19l-1.0,-0.52l1.51,-1.27l0.09,-0.34l-0.29,-0.19l-1.62,0.06l-2.66,0.88l-0.13,0.09l-0.62,0.72l-1.77,-0.8l-0.16,-0.02l-3.48,0.44l-3.5,-0.92l-1.06,-1.61l-2.78,-2.09l3.07,-1.51l5.52,-2.01l1.65,0.0l-0.28,1.73l0.31,0.35l5.29,-0.16l0.23,-0.49l-2.03,-2.59l-0.1,-0.08l-3.03,-1.58l-1.79,-2.12l-2.4,-1.83l-3.18,-1.27l1.13,-1.84l4.28,-0.14l0.15,-0.05l3.16,-2.0l0.13,-0.17l0.57,-2.07l2.43,-2.02l2.42,-0.52l4.67,-1.98l2.22,0.29l0.2,-0.04l3.74,-2.37l3.57,0.91ZM37.66,123.49l-2.31,1.26l-1.04,-0.75l-0.31,-1.35l2.06,-1.16l1.24,-0.51l1.48,0.22l0.76,0.81l-1.89,1.49ZM30.89,233.84l1.2,0.57l0.35,0.3l0.48,0.69l-1.6,0.86l-0.3,0.31l-0.24,-0.14l0.05,-0.54l-0.02,-0.15l-0.36,-0.83l0.05,-0.12l0.39,-0.38l0.07,-0.31l-0.09,-0.27ZM29.06,231.89l0.5,0.14l0.31,0.19l-0.46,0.1l-0.34,-0.43ZM25.02,230.13l0.2,-0.11l0.4,0.47l-0.43,-0.05l-0.17,-0.31ZM21.29,228.68l0.1,-0.07l0.22,0.02l0.02,0.21l-0.02,0.02l-0.32,-0.18ZM6.0,113.33l-1.19,0.45l-1.5,-0.64l-0.94,-0.63l1.76,-0.46l1.71,0.29l0.16,0.98Z", "name": "United States of America"}, "LV": {"path": "M473.99,127.16l0.07,-2.15l1.15,-2.11l2.05,-1.07l1.84,2.48l0.25,0.12l2.01,-0.07l0.29,-0.25l0.45,-2.58l1.85,-0.56l0.98,0.4l2.13,1.33l0.16,0.05l1.97,0.01l1.02,0.7l0.21,1.67l0.71,1.84l-2.44,1.23l-1.36,0.53l-2.28,-1.62l-0.12,-0.05l-1.18,-0.2l-0.28,-0.6l-0.31,-0.17l-2.43,0.35l-4.17,-0.23l-0.12,0.02l-2.45,0.93Z", "name": "Latvia"}, "UY": {"path": "M276.9,363.17l1.3,-0.23l2.4,2.04l0.22,0.07l0.82,-0.07l2.48,1.7l1.93,1.5l1.28,1.67l-0.95,1.14l-0.04,0.31l0.63,1.45l-0.96,1.57l-2.65,1.47l-1.73,-0.53l-0.15,-0.01l-1.25,0.28l-2.22,-1.16l-0.16,-0.03l-1.56,0.08l-1.33,-1.36l0.17,-1.58l0.48,-0.55l0.07,-0.2l-0.02,-2.74l0.66,-2.8l0.57,-2.02Z", "name": "Uruguay"}, "LB": {"path": "M510.44,198.11l-0.48,0.03l-0.26,0.17l-0.15,0.32l-0.21,-0.0l0.72,-1.85l1.19,-1.9l0.74,0.09l0.27,0.73l-1.19,0.93l-0.09,0.13l-0.54,1.36Z", "name": "Lebanon"}, "LA": {"path": "M684.87,248.8l0.61,-0.86l0.05,-0.16l0.11,-2.17l-0.08,-0.22l-1.96,-2.16l-0.15,-2.44l-0.08,-0.18l-1.9,-2.1l-0.19,-0.1l-1.89,-0.18l-0.29,0.15l-0.42,0.76l-1.21,0.06l-0.67,-0.41l-0.31,-0.0l-2.2,1.29l-0.05,-1.77l0.61,-2.7l-0.27,-0.37l-1.44,-0.1l-0.12,-1.31l-0.12,-0.21l-0.87,-0.65l0.38,-0.68l1.76,-1.41l0.08,0.22l0.27,0.2l1.33,0.07l0.31,-0.34l-0.35,-2.75l0.85,-0.25l1.32,1.88l1.11,2.36l0.27,0.17l2.89,0.02l0.78,1.82l-1.32,0.56l-0.12,0.09l-0.72,0.93l0.1,0.45l2.93,1.52l3.62,5.27l1.88,1.78l0.58,1.67l-0.38,2.11l-1.87,-0.79l-0.37,0.11l-0.99,1.54l-1.51,-0.73Z", "name": "Laos"}, "TW": {"path": "M725.6,222.5l-1.5,4.22l-0.82,1.65l-1.01,-1.7l-0.26,-1.8l1.4,-2.48l1.8,-1.81l0.76,0.53l-0.38,1.39Z", "name": "Taiwan"}, "TT": {"path": "M266.35,259.46l0.41,-0.39l0.09,-0.23l-0.04,-0.75l1.14,-0.26l0.2,0.03l-0.07,1.37l-1.73,0.23Z", "name": "Trinidad and Tobago"}, "TR": {"path": "M513.25,175.38l3.63,1.17l0.14,0.01l2.88,-0.45l2.11,0.26l0.18,-0.03l2.9,-1.53l2.51,-0.13l2.25,1.37l0.36,0.88l-0.23,1.36l0.19,0.33l1.81,0.72l0.61,0.53l-1.31,0.64l-0.16,0.34l0.76,3.24l-0.44,0.8l0.01,0.3l1.19,2.02l-0.71,0.29l-0.74,-0.62l-0.15,-0.07l-2.91,-0.37l-0.15,0.02l-1.04,0.43l-2.78,0.44l-1.44,-0.03l-2.83,1.06l-1.95,0.01l-1.28,-0.52l-0.2,-0.01l-2.62,0.76l-0.7,-0.48l-0.47,0.22l-0.13,1.49l-1.01,0.94l-0.58,-0.82l0.79,-0.9l0.04,-0.34l-0.31,-0.15l-1.46,0.23l-2.03,-0.64l-0.3,0.07l-1.65,1.58l-3.58,0.3l-1.94,-1.47l-0.17,-0.06l-2.7,-0.1l-0.28,0.17l-0.51,1.06l-1.47,0.29l-2.32,-1.46l-0.17,-0.05l-2.55,0.05l-1.4,-2.7l-1.72,-1.54l1.11,-2.06l-0.07,-0.37l-1.35,-1.19l2.47,-2.51l3.74,-0.11l0.26,-0.17l0.96,-2.07l4.56,0.38l0.19,-0.05l2.97,-1.92l2.84,-0.83l4.03,-0.06l4.31,2.08ZM488.85,176.8l-1.81,1.38l-0.57,-1.01l0.02,-0.36l0.45,-0.25l0.13,-0.15l0.78,-1.87l-0.11,-0.37l-0.72,-0.47l1.91,-0.71l1.89,0.35l0.25,0.97l0.17,0.2l1.87,0.83l-0.19,0.31l-2.82,0.16l-0.18,0.07l-1.06,0.91Z", "name": "Turkey"}, "LK": {"path": "M625.44,266.07l-0.35,2.4l-0.9,0.61l-1.91,0.5l-1.04,-1.75l-0.43,-3.5l1.0,-3.6l1.34,1.09l1.13,1.72l1.16,2.52Z", "name": "Sri Lanka"}, "TN": {"path": "M444.91,206.18l-0.99,-4.57l-0.12,-0.18l-1.43,-1.04l-0.02,-0.53l-0.11,-0.22l-1.95,-1.59l-0.19,-1.85l1.44,-1.47l0.08,-0.14l0.59,-2.34l-0.38,-2.77l0.44,-1.28l2.52,-1.08l1.41,0.28l-0.06,1.2l0.43,0.28l1.81,-0.9l0.02,0.06l-1.14,1.28l-0.08,0.2l-0.02,1.32l0.11,0.24l0.74,0.6l-0.29,2.18l-1.56,1.35l-0.09,0.32l0.48,1.54l0.28,0.21l1.11,0.04l0.55,1.17l0.15,0.14l0.76,0.35l-0.12,1.79l-1.1,0.72l-0.8,0.91l-1.68,1.04l-0.13,0.32l0.25,1.08l-0.18,0.96l-0.74,0.39Z", "name": "Tunisia"}, "TL": {"path": "M734.21,307.22l0.17,-0.34l1.99,-0.52l1.72,-0.08l0.78,-0.3l0.29,0.1l-0.43,0.32l-2.57,1.09l-1.71,0.59l-0.05,-0.49l-0.19,-0.36Z", "name": "East Timor"}, "TM": {"path": "M553.16,173.51l-0.12,1.0l-0.26,-0.65l0.38,-0.34ZM553.54,173.16l0.13,-0.12l0.43,-0.09l-0.56,0.21ZM555.68,172.6l0.65,-0.14l1.53,0.76l1.71,2.29l0.27,0.12l1.27,-0.14l2.81,-0.04l0.29,-0.38l-0.35,-1.27l1.98,-0.97l1.96,-1.63l3.05,1.44l0.25,2.23l0.14,0.22l0.96,0.61l0.18,0.05l2.61,-0.13l0.68,0.44l1.2,2.97l0.1,0.13l2.85,2.03l1.67,1.41l2.66,1.45l3.13,1.17l-0.05,1.23l-0.36,-0.04l-1.12,-0.73l-0.44,0.14l-0.34,0.89l-1.96,0.52l-0.22,0.23l-0.47,2.17l-1.26,0.78l-1.93,0.42l-0.21,0.18l-0.46,1.14l-1.64,0.33l-2.3,-0.97l-0.2,-2.23l-0.28,-0.27l-1.76,-0.1l-2.78,-2.48l-0.15,-0.07l-1.95,-0.31l-2.82,-1.48l-1.78,-0.27l-0.18,0.03l-1.03,0.51l-1.6,-0.08l-0.22,0.08l-1.72,1.6l-1.83,0.46l-0.39,-1.7l0.36,-3.0l-0.16,-0.3l-1.73,-0.88l0.57,-1.77l-0.25,-0.39l-1.33,-0.14l0.41,-1.85l2.05,0.63l0.21,-0.01l2.2,-0.95l0.09,-0.49l-1.78,-1.75l-0.69,-1.66l-0.07,-0.03Z", "name": "Turkmenistan"}, "TJ": {"path": "M597.99,178.71l-0.23,0.23l-2.57,-0.47l-0.35,0.25l-0.24,1.7l0.32,0.34l2.66,-0.22l3.15,0.95l4.47,-0.42l0.58,2.45l0.39,0.21l0.71,-0.25l1.22,0.53l-0.06,1.01l0.29,1.28l-2.19,-0.0l-1.71,-0.21l-0.23,0.07l-1.51,1.25l-1.05,0.27l-0.77,0.51l-0.71,-0.67l0.22,-2.28l-0.24,-0.32l-0.43,-0.08l0.17,-0.57l-0.16,-0.36l-1.36,-0.66l-0.34,0.05l-1.08,1.01l-0.09,0.15l-0.25,1.09l-0.24,0.26l-1.36,-0.05l-0.27,0.14l-0.65,1.06l-0.58,-0.39l-0.3,-0.02l-1.68,0.86l-0.36,-0.16l1.28,-2.65l0.02,-0.2l-0.54,-2.17l-0.18,-0.21l-1.53,-0.58l0.41,-0.82l1.89,0.13l0.26,-0.12l1.19,-1.63l0.77,-1.82l2.66,-0.55l-0.33,0.87l0.01,0.23l0.36,0.82l0.3,0.18l0.23,-0.02Z", "name": "Tajikistan"}, "LS": {"path": "M493.32,359.69l0.69,0.65l-0.65,1.12l-0.38,0.8l-1.27,0.39l-0.18,0.15l-0.4,0.77l-0.59,0.18l-1.59,-1.78l1.16,-1.5l1.3,-1.02l0.97,-0.46l0.94,0.72Z", "name": "Lesotho"}, "TH": {"path": "M677.42,253.68l-1.7,-0.88l-0.14,-0.03l-1.77,0.04l0.3,-1.64l-0.3,-0.35l-2.21,0.01l-0.3,0.28l-0.2,2.76l-2.15,5.9l-0.02,0.13l0.17,1.83l0.28,0.27l1.45,0.07l0.93,2.1l0.44,2.15l0.08,0.15l1.4,1.44l0.16,0.09l1.43,0.27l1.04,1.05l-0.58,0.73l-1.24,0.22l-0.15,-0.99l-0.15,-0.22l-2.04,-1.1l-0.36,0.06l-0.23,0.23l-0.72,-0.71l-0.41,-1.18l-0.06,-0.11l-1.33,-1.42l-1.22,-1.2l-0.5,0.13l-0.15,0.54l-0.14,-0.41l0.26,-1.48l0.73,-2.38l1.2,-2.57l1.37,-2.35l0.02,-0.27l-0.95,-2.26l0.03,-1.19l-0.29,-1.42l-0.06,-0.13l-1.65,-2.0l-0.46,-0.99l0.62,-0.34l0.13,-0.15l0.92,-2.23l-0.02,-0.27l-1.05,-1.74l-1.57,-1.86l-1.04,-1.96l0.76,-0.34l0.16,-0.16l1.07,-2.63l1.58,-0.1l0.16,-0.06l1.43,-1.11l1.24,-0.52l0.84,0.62l0.13,1.43l0.28,0.27l1.34,0.09l-0.54,2.39l0.05,2.39l0.45,0.25l2.48,-1.45l0.6,0.36l0.17,0.04l1.47,-0.07l0.25,-0.15l0.41,-0.73l1.58,0.15l1.76,1.93l0.15,2.44l0.08,0.18l1.94,2.15l-0.1,1.96l-0.66,0.93l-2.25,-0.34l-3.24,0.49l-0.19,0.12l-1.6,2.12l-0.06,0.24l0.48,2.46Z", "name": "Thailand"}, "TF": {"path": "M593.76,417.73l1.38,0.84l2.15,0.37l0.04,0.31l-0.59,1.24l-3.36,0.19l-0.05,-1.38l0.43,-1.56Z", "name": "French Southern and Antarctic Lands"}, "TG": {"path": "M425.23,269.29l-1.49,0.4l-0.43,-0.68l-0.64,-1.54l-0.18,-1.16l0.54,-2.21l-0.04,-0.24l-0.59,-0.86l-0.23,-1.9l0.0,-1.82l-0.07,-0.19l-0.95,-1.19l0.1,-0.41l1.58,0.04l-0.23,0.97l0.08,0.28l1.55,1.55l0.09,1.13l0.08,0.19l0.42,0.43l-0.11,5.66l0.52,1.53Z", "name": "Togo"}, "TD": {"path": "M457.57,252.46l0.23,-1.08l-0.28,-0.36l-1.32,-0.05l0.0,-1.35l-0.1,-0.22l-0.9,-0.82l0.99,-3.1l3.12,-2.37l0.12,-0.23l0.13,-3.33l0.95,-5.2l0.53,-1.09l-0.07,-0.36l-0.94,-0.81l-0.03,-0.7l-0.12,-0.23l-0.84,-0.61l-0.57,-3.76l2.21,-1.26l19.67,9.88l0.12,9.74l-1.83,-0.15l-0.28,0.14l-1.14,1.89l-0.68,1.62l0.05,0.31l0.33,0.38l-0.61,0.58l-0.08,0.3l0.25,0.93l-0.58,0.95l-0.29,1.01l0.34,0.37l0.67,-0.11l0.39,0.73l0.03,1.4l0.11,0.23l0.8,0.65l-0.01,0.24l-1.38,0.37l-0.11,0.06l-1.27,1.03l-1.83,2.76l-2.21,1.1l-2.34,-0.15l-0.82,0.25l-0.2,0.37l0.19,0.68l-1.16,0.79l-1.01,0.94l-2.92,0.89l-0.5,-0.46l-0.17,-0.08l-0.41,-0.05l-0.28,0.12l-0.38,0.54l-1.36,0.12l0.1,-0.18l0.01,-0.27l-0.78,-1.72l-0.35,-1.03l-0.17,-0.18l-1.03,-0.41l-1.29,-1.28l0.36,-0.78l0.9,0.2l0.14,-0.0l0.67,-0.17l1.36,0.02l0.26,-0.45l-1.32,-2.22l0.09,-1.64l-0.17,-1.68l-0.04,-0.13l-0.93,-1.53Z", "name": "Chad"}, "LY": {"path": "M457.99,226.38l-1.57,0.87l-1.25,-1.28l-0.13,-0.08l-3.85,-1.11l-1.04,-1.57l-0.09,-0.09l-1.98,-1.23l-0.27,-0.02l-0.93,0.39l-0.72,-1.2l-0.09,-1.07l-0.06,-0.16l-1.33,-1.75l0.83,-0.94l0.07,-0.24l-0.21,-1.64l0.31,-1.43l-0.17,-1.29l0.43,-2.26l-0.15,-1.33l-0.73,-2.18l0.99,-0.52l0.16,-0.21l0.22,-1.16l-0.22,-1.06l1.54,-0.95l0.81,-0.92l1.19,-0.78l0.14,-0.23l0.12,-1.76l2.57,0.84l0.16,0.01l0.99,-0.23l2.01,0.45l3.19,1.2l1.12,2.36l0.2,0.16l2.24,0.53l3.5,1.14l2.65,1.36l0.29,-0.01l1.22,-0.71l1.27,-1.32l0.07,-0.29l-0.55,-2.0l0.69,-1.19l1.7,-1.23l1.61,-0.35l3.2,0.54l0.78,1.14l0.24,0.13l0.85,0.01l0.84,0.47l2.35,0.31l0.42,0.63l-0.79,1.16l-0.04,0.26l0.35,1.08l-0.61,1.6l-0.0,0.2l0.73,2.16l0.0,24.24l-2.58,0.01l-0.3,0.29l-0.02,0.62l-19.55,-9.83l-0.28,0.01l-2.53,1.44Z", "name": "Libya"}, "AE": {"path": "M550.59,223.8l0.12,0.08l1.92,-0.41l3.54,0.15l0.23,-0.09l1.71,-1.79l1.86,-1.7l1.31,-1.36l0.26,0.5l0.28,1.72l-0.93,0.01l-0.3,0.26l-0.21,1.73l0.11,0.27l0.08,0.06l-0.7,0.32l-0.17,0.27l-0.01,0.99l-0.68,1.02l-0.05,0.15l-0.06,0.96l-0.32,0.36l-7.19,-1.27l-0.79,-2.22Z", "name": "United Arab Emirates"}, "VE": {"path": "M240.66,256.5l0.65,0.91l-0.03,1.13l-1.05,1.39l-0.03,0.31l0.95,2.0l0.32,0.17l1.08,-0.16l0.24,-0.21l0.56,-1.83l-0.06,-0.29l-0.71,-0.81l-0.1,-1.58l2.9,-0.96l0.19,-0.37l-0.29,-1.02l0.45,-0.41l0.72,1.43l0.26,0.16l1.65,0.04l1.46,1.27l0.08,0.72l0.3,0.27l2.28,0.02l2.55,-0.25l1.34,1.06l0.14,0.06l1.92,0.31l0.2,-0.03l1.4,-0.79l0.15,-0.25l0.02,-0.36l2.82,-0.14l1.17,-0.01l-0.41,0.14l-0.14,0.46l0.86,1.19l0.22,0.12l1.93,0.18l1.73,1.13l0.37,1.9l0.31,0.24l1.21,-0.05l0.52,0.32l-1.63,1.21l-0.11,0.17l-0.22,0.92l0.07,0.27l0.63,0.69l-0.31,0.24l-1.48,0.39l-0.22,0.3l0.04,1.03l-0.59,0.6l-0.01,0.41l1.67,1.87l0.23,0.48l-0.72,0.76l-2.71,0.91l-1.78,0.39l-0.13,0.06l-0.6,0.49l-1.84,-0.58l-1.89,-0.33l-0.18,0.03l-0.47,0.23l-0.02,0.53l0.96,0.56l-0.08,1.58l0.35,1.58l0.26,0.23l1.91,0.19l0.02,0.07l-1.54,0.62l-0.18,0.2l-0.25,0.92l-0.88,0.35l-1.85,0.58l-0.16,0.13l-0.4,0.64l-1.66,0.14l-1.22,-1.18l-0.79,-2.52l-0.67,-0.88l-0.66,-0.43l0.99,-0.98l0.09,-0.26l-0.09,-0.56l-0.08,-0.16l-0.66,-0.69l-0.47,-1.54l0.18,-1.67l0.55,-0.85l0.45,-1.35l-0.15,-0.36l-0.89,-0.43l-0.19,-0.02l-1.39,0.28l-1.76,-0.13l-0.92,0.23l-1.64,-2.01l-0.17,-0.1l-1.54,-0.33l-3.05,0.23l-0.5,-0.73l-0.15,-0.12l-0.45,-0.15l-0.05,-0.28l0.28,-0.86l0.01,-0.15l-0.2,-1.01l-0.08,-0.15l-0.5,-0.5l-0.3,-1.08l-0.25,-0.22l-0.89,-0.12l0.54,-1.18l0.29,-1.73l0.66,-0.85l0.94,-0.7l0.09,-0.11l0.3,-0.6Z", "name": "Venezuela"}, "AF": {"path": "M574.42,192.1l2.24,0.95l0.18,0.02l1.89,-0.38l0.22,-0.18l0.46,-1.14l1.82,-0.4l1.5,-0.91l0.14,-0.19l0.46,-2.12l1.93,-0.51l0.2,-0.18l0.26,-0.68l0.87,0.57l0.13,0.05l0.79,0.09l1.35,0.02l1.83,0.59l0.75,0.34l0.26,-0.01l1.66,-0.85l0.7,0.46l0.42,-0.09l0.72,-1.17l1.32,0.05l0.23,-0.1l0.39,-0.43l0.07,-0.14l0.24,-1.08l0.86,-0.81l0.94,0.46l-0.2,0.64l0.23,0.38l0.49,0.09l-0.21,2.15l0.09,0.25l0.99,0.94l0.38,0.03l0.83,-0.57l1.06,-0.27l0.12,-0.06l1.46,-1.21l1.63,0.2l2.4,0.0l0.17,0.32l-1.12,0.25l-1.23,0.52l-2.86,0.33l-2.69,0.6l-0.13,0.06l-1.46,1.25l-0.07,0.36l0.58,1.18l0.25,1.21l-1.13,1.08l-0.09,0.25l0.09,0.98l-0.53,0.79l-2.22,-0.08l-0.28,0.44l0.83,1.57l-1.3,0.58l-0.13,0.11l-1.06,1.69l-0.05,0.18l0.13,1.51l-0.73,0.58l-0.78,-0.22l-0.14,-0.01l-1.91,0.36l-0.23,0.19l-0.2,0.57l-1.65,-0.0l-0.22,0.1l-1.4,1.56l-0.08,0.19l-0.08,2.13l-2.99,1.05l-1.67,-0.23l-0.27,0.1l-0.39,0.46l-1.43,-0.31l-2.43,0.4l-3.69,-1.23l1.96,-2.15l0.08,-0.24l-0.21,-1.78l-0.23,-0.26l-1.69,-0.42l-0.19,-1.62l-0.77,-2.08l0.98,-1.41l-0.14,-0.45l-0.82,-0.31l0.6,-1.79l0.93,-3.21Z", "name": "Afghanistan"}, "IQ": {"path": "M534.42,190.89l0.13,0.14l1.5,0.78l0.15,1.34l-1.13,0.87l-0.11,0.16l-0.58,2.2l0.04,0.24l1.73,2.67l0.12,0.1l2.99,1.49l1.18,1.94l-0.39,1.89l0.29,0.36l0.5,-0.0l0.02,1.17l0.08,0.2l0.83,0.86l-2.36,-0.29l-0.29,0.13l-1.74,2.49l-4.4,-0.21l-7.03,-5.49l-3.73,-1.94l-2.92,-0.74l-0.89,-3.0l5.33,-2.81l0.15,-0.19l0.95,-3.43l-0.2,-2.0l1.19,-0.61l0.11,-0.09l1.23,-1.73l0.92,-0.38l2.75,0.35l0.81,0.68l0.31,0.05l0.94,-0.38l1.5,3.17Z", "name": "Iraq"}, "IS": {"path": "M384.26,87.96l-0.51,2.35l0.08,0.28l2.61,2.58l-2.99,2.83l-7.16,2.72l-2.08,0.7l-9.51,-1.71l1.89,-1.36l-0.07,-0.53l-4.4,-1.59l3.33,-0.59l0.25,-0.32l-0.11,-1.2l-0.25,-0.27l-4.82,-0.88l1.38,-2.2l3.54,-0.57l3.8,2.74l0.33,0.01l3.68,-2.18l3.02,1.12l0.25,-0.02l4.01,-2.18l3.72,0.27Z", "name": "Iceland"}, "IR": {"path": "M556.2,187.5l2.05,-0.52l0.13,-0.07l1.69,-1.57l1.55,0.08l0.15,-0.03l1.02,-0.5l1.64,0.25l2.82,1.48l1.91,0.3l2.8,2.49l0.18,0.08l1.61,0.09l0.19,2.09l-1.0,3.47l-0.69,2.04l0.18,0.38l0.73,0.28l-0.85,1.22l-0.04,0.28l0.81,2.19l0.19,1.72l0.23,0.26l1.69,0.42l0.17,1.43l-2.18,2.39l-0.01,0.4l1.22,1.42l1.0,1.62l0.12,0.11l2.23,1.11l0.06,2.2l0.2,0.27l1.03,0.38l0.14,0.83l-3.38,1.3l-0.18,0.19l-0.87,2.85l-4.44,-0.76l-2.75,-0.62l-2.64,-0.32l-1.01,-3.11l-0.17,-0.19l-1.2,-0.48l-0.18,-0.01l-1.99,0.51l-2.42,1.25l-2.89,-0.84l-2.48,-2.03l-2.41,-0.79l-1.61,-2.47l-1.84,-3.63l-0.36,-0.15l-1.22,0.4l-1.48,-0.84l-0.37,0.06l-0.72,0.82l-1.08,-1.12l-0.02,-1.35l-0.3,-0.29l-0.43,0.0l0.34,-1.64l-0.04,-0.22l-1.29,-2.11l-0.12,-0.11l-3.0,-1.49l-1.62,-2.49l0.52,-1.98l1.18,-0.92l0.11,-0.27l-0.19,-1.66l-0.16,-0.23l-1.55,-0.81l-1.58,-3.33l-1.3,-2.2l0.41,-0.75l0.03,-0.21l-0.73,-3.12l1.2,-0.59l0.35,0.9l1.26,1.35l0.15,0.09l1.81,0.39l0.91,-0.09l0.15,-0.06l2.9,-2.13l0.7,-0.16l0.48,0.56l-0.75,1.26l0.05,0.37l1.56,1.53l0.28,0.08l0.37,-0.09l0.7,1.89l0.21,0.19l2.31,0.59l1.69,1.4l0.15,0.07l3.66,0.49l3.91,-0.76l0.23,-0.19l0.19,-0.52Z", "name": "Iran"}, "AM": {"path": "M530.51,176.08l2.91,-0.39l0.41,0.63l0.11,0.1l0.66,0.36l-0.32,0.47l0.07,0.41l1.1,0.84l-0.53,0.7l0.06,0.42l1.06,0.8l1.01,0.44l0.04,1.56l-0.44,0.04l-0.88,-1.46l0.01,-0.37l-0.3,-0.31l-0.98,0.01l-0.65,-0.69l-0.26,-0.09l-0.38,0.06l-0.97,-0.82l-1.64,-0.65l0.2,-1.2l-0.02,-0.16l-0.28,-0.69Z", "name": "Armenia"}, "IT": {"path": "M451.68,158.58l0.2,0.16l3.3,0.75l-0.22,1.26l0.02,0.18l0.35,0.78l-1.4,-0.32l-0.21,0.03l-2.04,1.1l-0.16,0.29l0.13,1.47l-0.29,0.82l0.02,0.24l0.82,1.57l0.1,0.11l2.28,1.5l1.29,2.53l2.79,2.43l0.2,0.07l1.83,-0.02l0.31,0.34l-0.46,0.39l0.06,0.5l4.06,1.97l2.06,1.49l0.17,0.36l-0.24,0.53l-1.08,-1.07l-0.15,-0.08l-2.18,-0.49l-0.33,0.15l-1.05,1.91l0.11,0.4l1.63,0.98l-0.22,1.12l-0.84,0.14l-0.22,0.15l-1.27,2.38l-0.54,0.12l0.01,-0.47l0.48,-1.46l0.5,-0.58l0.03,-0.35l-0.97,-1.69l-0.76,-1.48l-0.17,-0.15l-0.94,-0.33l-0.68,-1.18l-0.16,-0.13l-1.53,-0.52l-1.03,-1.14l-0.19,-0.1l-1.78,-0.19l-1.88,-1.3l-2.27,-1.94l-1.64,-1.68l-0.76,-2.94l-0.21,-0.21l-1.22,-0.35l-2.01,-1.0l-0.24,-0.01l-1.15,0.42l-0.11,0.07l-1.38,1.36l-0.5,0.11l0.19,-0.87l-0.21,-0.35l-1.19,-0.34l-0.56,-2.06l0.76,-0.82l0.03,-0.36l-0.68,-1.08l0.04,-0.31l0.68,0.42l0.19,0.04l1.21,-0.15l0.14,-0.06l1.18,-0.89l0.25,0.29l0.25,0.1l1.19,-0.1l0.25,-0.18l0.45,-1.04l1.61,0.34l0.19,-0.02l1.1,-0.53l0.17,-0.22l0.15,-0.95l1.19,0.35l0.35,-0.16l0.23,-0.47l2.11,-0.47l0.45,0.89ZM459.35,184.63l-0.71,1.81l0.0,0.23l0.33,0.79l-0.37,1.03l-1.6,-0.91l-1.33,-0.34l-3.24,-1.36l0.23,-0.99l2.73,0.24l3.95,-0.5ZM443.95,175.91l1.26,1.77l-0.31,3.47l-0.82,-0.13l-0.26,0.08l-0.83,0.79l-0.64,-0.52l-0.1,-3.42l-0.44,-1.34l0.91,0.1l0.21,-0.06l1.01,-0.74Z", "name": "Italy"}, "VN": {"path": "M690.8,230.21l-2.86,1.93l-2.09,2.46l-0.06,0.11l-0.55,1.8l0.04,0.26l4.26,6.1l2.31,1.63l1.46,1.97l1.12,4.62l-0.32,4.3l-1.97,1.57l-2.85,1.62l-2.09,2.14l-2.83,2.13l-0.67,-1.19l0.65,-1.58l-0.09,-0.35l-1.47,-1.14l1.67,-0.79l2.57,-0.18l0.22,-0.47l-0.89,-1.24l3.88,-1.8l0.17,-0.24l0.31,-3.05l-0.01,-0.13l-0.56,-1.63l0.44,-2.48l-0.01,-0.15l-0.63,-1.81l-0.08,-0.12l-1.87,-1.77l-3.64,-5.3l-0.11,-0.1l-2.68,-1.39l0.45,-0.59l1.53,-0.65l0.16,-0.39l-0.97,-2.27l-0.27,-0.18l-2.89,-0.02l-1.04,-2.21l-1.28,-1.83l0.96,-0.46l1.97,0.01l2.43,-0.3l0.13,-0.05l1.95,-1.29l1.04,0.85l0.13,0.06l1.98,0.42l-0.32,1.21l0.09,0.3l1.19,1.07l0.12,0.07l1.88,0.51Z", "name": "Vietnam"}, "AR": {"path": "M258.11,341.34l1.4,1.81l0.51,-0.06l0.89,-1.94l2.51,0.1l0.36,0.49l4.6,4.31l0.15,0.08l1.99,0.39l3.01,1.93l2.5,1.01l0.28,0.91l-2.4,3.97l0.17,0.44l2.57,0.74l2.81,0.41l2.09,-0.44l0.14,-0.07l2.27,-2.06l0.09,-0.17l0.38,-2.2l0.88,-0.36l1.05,1.29l-0.04,1.88l-1.98,1.4l-1.72,1.13l-2.84,2.65l-3.34,3.73l-0.07,0.12l-0.63,2.22l-0.67,2.85l0.02,2.73l-0.47,0.54l-0.07,0.17l-0.36,3.28l0.12,0.27l3.03,2.32l-0.31,1.78l0.11,0.29l1.44,1.15l-0.11,1.17l-2.32,3.57l-3.59,1.51l-4.95,0.6l-2.72,-0.29l-0.32,0.38l0.5,1.67l-0.49,2.13l0.01,0.16l0.4,1.29l-1.27,0.88l-2.41,0.39l-2.33,-1.05l-0.31,0.04l-0.97,0.78l-0.11,0.27l0.35,2.98l0.16,0.23l1.69,0.91l0.31,-0.02l1.08,-0.75l0.46,0.96l-2.1,0.88l-2.01,1.89l-0.09,0.18l-0.36,3.05l-0.51,1.42l-2.16,0.01l-0.19,0.07l-1.96,1.59l-0.1,0.15l-0.72,2.34l0.08,0.31l2.46,2.31l0.13,0.07l2.09,0.56l-0.74,2.45l-2.86,1.75l-0.12,0.14l-1.59,3.71l-2.2,1.24l-0.1,0.09l-1.03,1.54l-0.04,0.23l0.81,3.45l0.06,0.13l1.13,1.32l-2.59,-0.57l-5.89,-0.44l-0.92,-1.73l0.05,-2.4l-0.34,-0.3l-1.49,0.19l-0.72,-0.98l-0.2,-3.21l1.79,-1.33l0.1,-0.13l0.79,-2.04l0.02,-0.16l-0.27,-1.52l1.31,-2.69l0.91,-4.15l-0.23,-1.72l0.91,-0.49l0.15,-0.33l-0.27,-1.16l-0.15,-0.2l-0.87,-0.46l0.65,-1.01l-0.04,-0.37l-1.06,-1.09l-0.54,-3.2l0.83,-0.51l0.14,-0.29l-0.42,-3.6l0.58,-2.98l0.64,-2.5l1.41,-1.0l0.12,-0.32l-0.75,-2.8l-0.01,-2.48l1.81,-1.78l0.09,-0.22l-0.06,-2.3l1.39,-2.69l0.03,-0.14l0.01,-2.58l-0.11,-0.24l-0.57,-0.45l-1.1,-4.59l1.49,-2.73l0.04,-0.17l-0.23,-2.59l0.86,-2.38l1.6,-2.48l1.74,-1.65l0.04,-0.39l-0.64,-0.89l0.42,-0.7l0.04,-0.16l-0.08,-4.26l2.55,-1.23l0.16,-0.18l0.86,-2.75l-0.01,-0.22l-0.22,-0.48l1.84,-2.1l3.0,0.59ZM256.77,438.98l-2.1,0.15l-1.18,-1.14l-0.19,-0.08l-1.53,-0.09l-2.38,-0.0l-0.0,-6.28l0.4,0.65l1.25,2.55l0.11,0.12l3.26,2.07l3.19,0.8l-0.82,1.26Z", "name": "Argentina"}, "AU": {"path": "M705.55,353.06l0.09,0.09l0.37,0.05l0.13,-0.35l-0.57,-1.69l0.48,0.3l0.71,0.99l0.34,0.11l0.2,-0.29l-0.04,-1.37l-0.04,-0.14l-1.22,-2.07l-0.28,-0.9l-0.51,-0.69l0.24,-1.33l0.52,-0.7l0.34,-1.32l0.01,-0.13l-0.25,-1.44l0.51,-0.94l0.1,1.03l0.23,0.26l0.32,-0.14l1.01,-1.72l1.94,-0.84l1.27,-1.14l1.84,-0.92l1.0,-0.18l0.6,0.28l0.26,-0.0l1.94,-0.96l1.48,-0.28l0.19,-0.13l0.32,-0.49l0.51,-0.18l1.42,0.05l2.63,-0.76l0.11,-0.06l1.36,-1.15l0.08,-0.1l0.61,-1.33l1.42,-1.27l0.1,-0.19l0.11,-1.03l0.06,-1.32l1.39,-1.74l0.85,1.79l0.4,0.14l1.07,-0.51l0.11,-0.45l-0.77,-1.05l0.53,-0.84l0.86,0.43l0.43,-0.22l0.29,-1.85l1.29,-1.19l0.6,-0.98l1.16,-0.4l0.2,-0.27l0.02,-0.34l0.74,0.2l0.38,-0.27l0.03,-0.44l1.98,-0.61l1.7,1.08l1.36,1.48l0.22,0.1l1.55,0.02l1.57,0.24l0.33,-0.4l-0.48,-1.27l1.09,-1.86l1.06,-0.63l0.1,-0.42l-0.28,-0.46l0.93,-1.24l1.36,-0.8l1.16,0.27l0.14,0.0l2.1,-0.48l0.23,-0.3l-0.05,-1.3l-0.18,-0.26l-1.08,-0.49l0.44,-0.12l1.52,0.58l1.39,1.06l2.11,0.65l0.19,-0.0l0.59,-0.21l1.44,0.72l0.27,0.0l1.37,-0.68l0.84,0.2l0.26,-0.06l0.37,-0.3l0.82,0.89l-0.56,1.14l-0.84,0.91l-0.75,0.07l-0.26,0.38l0.26,0.9l-0.67,1.15l-0.88,1.24l-0.05,0.25l0.18,0.72l0.12,0.17l1.99,1.42l1.96,0.84l1.25,0.86l1.8,1.51l0.19,0.07l0.63,-0.0l1.15,0.58l0.34,0.7l0.17,0.15l2.39,0.88l0.24,-0.02l1.65,-0.88l0.14,-0.16l0.49,-1.37l0.52,-1.19l0.31,-1.39l0.75,-2.02l0.01,-0.19l-0.33,-1.16l0.16,-0.67l0.0,-0.13l-0.28,-1.41l0.3,-1.78l0.42,-0.45l0.05,-0.33l-0.33,-0.73l0.56,-1.25l0.48,-1.39l0.07,-0.69l0.58,-0.59l0.48,0.84l0.17,1.53l0.17,0.24l0.47,0.23l0.09,0.9l0.05,0.14l0.87,1.23l0.17,1.33l-0.09,0.89l0.03,0.15l0.9,2.0l0.43,0.13l1.38,-0.83l0.71,0.92l1.06,0.88l-0.22,0.96l0.0,0.14l0.53,2.2l0.38,1.3l0.15,0.18l0.52,0.26l0.62,2.01l-0.23,1.27l0.02,0.18l0.81,1.76l0.14,0.14l2.69,1.35l3.21,2.21l-0.2,0.4l0.04,0.34l1.39,1.6l0.95,2.78l0.43,0.16l0.79,-0.46l0.85,0.96l0.39,0.05l0.22,-0.15l0.36,2.33l0.09,0.18l1.78,1.63l1.16,1.01l1.9,2.1l0.67,2.05l0.06,1.47l-0.17,1.64l0.03,0.17l1.16,2.22l-0.14,2.28l-0.43,1.24l-0.68,2.44l0.04,1.63l-0.48,1.92l-1.06,2.43l-1.79,1.32l-0.1,0.12l-0.91,2.15l-0.82,1.37l-0.76,2.47l-0.98,1.46l-0.63,2.14l-0.33,2.02l0.1,0.82l-1.21,0.85l-2.71,0.1l-0.13,0.03l-2.31,1.19l-1.21,1.17l-1.34,1.11l-1.89,-1.18l-1.33,-0.46l0.32,-1.24l-0.4,-0.35l-1.46,0.61l-2.06,1.98l-1.99,-0.73l-1.43,-0.46l-1.45,-0.22l-2.32,-0.81l-1.51,-1.67l-0.45,-2.11l-0.6,-1.5l-0.07,-0.11l-1.23,-1.16l-0.16,-0.08l-1.96,-0.28l0.59,-0.99l0.03,-0.24l-0.61,-2.1l-0.54,-0.08l-1.16,1.85l-1.23,0.29l0.73,-0.88l0.06,-0.12l0.37,-1.57l0.93,-1.33l0.05,-0.2l-0.2,-2.07l-0.53,-0.17l-2.01,2.35l-1.52,0.94l-0.12,0.14l-0.82,1.93l-1.5,-0.9l0.07,-1.32l-0.06,-0.2l-1.57,-2.04l-1.15,-0.92l0.3,-0.41l-0.1,-0.44l-3.21,-1.69l-0.13,-0.03l-1.69,-0.08l-2.35,-1.31l-0.16,-0.04l-4.55,0.27l-3.24,0.99l-2.8,0.91l-2.33,-0.18l-0.17,0.03l-2.63,1.41l-2.14,0.64l-0.2,0.19l-0.47,1.42l-0.8,0.99l-1.99,0.06l-1.55,0.24l-2.27,-0.5l-1.79,0.3l-1.71,0.13l-0.19,0.09l-1.38,1.39l-0.58,-0.1l-0.21,0.04l-1.26,0.8l-1.13,0.85l-1.72,-0.1l-1.6,-0.0l-2.58,-1.76l-1.21,-0.49l0.04,-1.19l1.04,-0.32l0.16,-0.12l0.42,-0.64l0.05,-0.19l-0.09,-0.97l0.3,-2.0l-0.28,-1.64l-1.34,-2.84l-0.39,-1.49l0.1,-1.51l-0.04,-0.17l-0.96,-1.72l-0.06,-0.73l-0.09,-0.19l-1.04,-1.01l-0.3,-2.02l-0.05,-0.12l-1.23,-1.83ZM784.95,393.35l2.39,1.01l0.2,0.01l3.26,-0.96l1.19,0.16l0.16,3.19l-0.78,0.95l-0.07,0.16l-0.19,1.83l-0.43,-0.41l-0.44,0.03l-1.61,1.96l-0.4,-0.12l-1.38,-0.09l-1.43,-2.42l-0.37,-2.03l-1.4,-2.53l0.04,-0.94l1.27,0.2Z", "name": "Australia"}, "IL": {"path": "M509.04,199.22l0.71,0.0l0.27,-0.17l0.15,-0.33l0.19,-0.01l0.02,0.73l-0.27,0.34l0.02,0.08l-0.32,0.62l-0.65,-0.27l-0.41,0.19l-0.52,1.85l0.16,0.35l0.14,0.07l-0.17,0.1l-0.14,0.21l-0.11,0.73l0.39,0.33l0.81,-0.26l0.03,0.64l-0.97,3.43l-1.28,-3.67l0.62,-0.78l-0.03,-0.41l0.58,-1.16l0.5,-2.07l0.27,-0.54Z", "name": "Israel"}, "IN": {"path": "M615.84,192.58l2.4,2.97l-0.24,2.17l0.05,0.2l0.94,1.35l-0.06,0.97l-1.46,-0.3l-0.35,0.36l0.7,3.06l0.12,0.18l2.46,1.75l3.11,1.72l-1.23,0.96l-0.1,0.13l-0.97,2.55l0.16,0.38l2.41,1.02l2.37,1.33l3.27,1.52l3.43,0.37l1.37,1.3l0.17,0.08l1.92,0.25l3.0,0.62l2.15,-0.04l0.28,-0.22l0.29,-1.06l0.0,-0.13l-0.32,-1.66l0.16,-0.94l1.0,-0.37l0.23,2.28l0.18,0.24l2.28,1.02l0.2,0.02l1.52,-0.41l2.06,0.18l2.08,-0.08l0.29,-0.27l0.18,-1.66l-0.1,-0.26l-0.53,-0.44l1.38,-0.23l0.15,-0.07l2.26,-2.0l2.75,-1.65l1.97,0.63l0.25,-0.03l1.54,-0.99l0.89,1.28l-0.72,0.97l0.2,0.48l2.49,0.37l0.11,0.61l-0.69,0.39l-0.15,0.3l0.15,1.22l-1.36,-0.37l-0.23,0.03l-3.24,1.86l-0.15,0.28l0.07,1.44l-1.33,2.16l-0.04,0.13l-0.12,1.24l-0.98,1.91l-1.72,-0.53l-0.39,0.28l-0.09,2.66l-0.52,0.83l-0.04,0.23l0.21,0.89l-0.71,0.36l-1.21,-3.85l-0.29,-0.21l-0.69,0.01l-0.29,0.23l-0.28,1.17l-0.84,-0.84l0.6,-1.17l0.97,-0.13l0.23,-0.16l1.15,-2.25l-0.18,-0.42l-1.54,-0.47l-2.3,0.04l-2.13,-0.33l-0.19,-1.63l-0.26,-0.26l-1.13,-0.13l-1.93,-1.13l-0.42,0.13l-0.88,1.82l0.08,0.37l1.47,1.15l-1.21,0.77l-0.1,0.1l-0.56,0.97l0.13,0.42l1.31,0.61l-0.36,1.35l0.01,0.2l0.85,1.95l0.37,2.05l-0.26,0.68l-1.55,-0.02l-3.09,0.54l-0.25,0.32l0.13,1.84l-1.21,1.4l-3.64,1.79l-2.79,3.04l-1.86,1.61l-2.48,1.68l-0.13,0.25l-0.0,1.0l-1.07,0.55l-2.21,0.9l-1.13,0.13l-0.25,0.19l-0.75,1.96l-0.02,0.15l0.52,3.31l0.13,2.03l-1.03,2.35l-0.03,0.12l-0.01,4.03l-1.02,0.1l-0.23,0.15l-1.14,1.93l0.04,0.36l0.44,0.48l-1.83,0.57l-0.18,0.15l-0.81,1.65l-0.74,0.53l-2.14,-2.12l-1.14,-3.47l-0.96,-2.57l-0.9,-1.26l-1.3,-2.38l-0.61,-3.14l-0.44,-1.62l-2.29,-3.56l-1.03,-4.94l-0.74,-3.29l0.01,-3.12l-0.49,-2.51l-0.41,-0.22l-3.56,1.53l-1.59,-0.28l-2.96,-2.87l0.94,-0.74l0.06,-0.41l-0.74,-1.03l-2.73,-2.1l1.35,-1.43l5.38,0.01l0.29,-0.36l-0.5,-2.29l-0.09,-0.15l-1.33,-1.28l-0.27,-1.96l-0.12,-0.2l-1.36,-1.0l2.42,-2.48l2.77,0.2l0.24,-0.1l2.62,-2.85l1.59,-2.8l2.41,-2.74l0.07,-0.2l-0.04,-1.82l2.01,-1.51l-0.01,-0.49l-1.95,-1.33l-0.83,-1.81l-0.82,-2.27l0.98,-0.97l3.64,0.66l2.89,-0.42l0.17,-0.08l2.18,-2.15Z", "name": "India"}, "TZ": {"path": "M505.77,287.58l0.36,0.23l8.95,5.03l0.15,1.3l0.13,0.21l3.4,2.37l-1.07,2.88l-0.02,0.14l0.15,1.42l0.15,0.23l1.47,0.84l0.05,0.42l-0.66,1.44l-0.02,0.18l0.13,0.72l-0.16,1.16l0.03,0.19l0.87,1.57l1.03,2.48l0.12,0.14l0.53,0.32l-1.59,1.18l-2.64,0.95l-1.45,-0.04l-0.2,0.07l-0.81,0.69l-1.64,0.06l-0.68,0.3l-2.9,-0.69l-1.71,0.17l-0.65,-3.18l-0.05,-0.12l-1.35,-1.88l-0.19,-0.12l-2.41,-0.46l-1.38,-0.74l-1.63,-0.44l-0.96,-0.41l-0.95,-0.58l-1.31,-3.09l-1.47,-1.46l-0.45,-1.31l0.24,-1.34l-0.39,-1.99l0.71,-0.08l0.18,-0.09l0.91,-0.91l0.98,-1.31l0.59,-0.5l0.11,-0.24l-0.02,-0.81l-0.08,-0.2l-0.47,-0.5l-0.1,-0.67l0.51,-0.23l0.18,-0.25l0.14,-1.47l-0.05,-0.2l-0.76,-1.09l0.45,-0.15l2.71,0.03l5.01,-0.19Z", "name": "Tanzania"}, "AZ": {"path": "M539.36,175.66l0.16,0.09l1.11,0.2l0.32,-0.15l0.4,-0.71l1.22,-0.99l1.11,1.33l1.26,2.09l0.22,0.14l1.06,0.13l0.28,0.29l-1.46,0.17l-0.26,0.24l-0.43,2.26l-0.39,0.92l-0.85,0.63l-0.12,0.25l0.06,1.2l-0.22,0.05l-1.28,-1.25l0.74,-1.25l-0.03,-0.35l-0.74,-0.86l-0.3,-0.1l-1.05,0.27l-2.49,1.82l-0.04,-1.46l-0.18,-0.27l-1.09,-0.47l-0.8,-0.6l0.53,-0.7l-0.06,-0.42l-1.11,-0.84l0.34,-0.51l-0.11,-0.43l-0.89,-0.48l-0.33,-0.49l0.25,-0.2l1.78,0.81l1.35,0.18l0.25,-0.09l0.34,-0.35l0.02,-0.39l-1.04,-1.36l0.28,-0.18l0.49,0.07l1.65,1.74ZM533.53,180.16l0.63,0.67l0.22,0.09l0.8,-0.0l0.04,0.31l0.66,1.09l-0.94,-0.21l-1.16,-1.24l-0.25,-0.71Z", "name": "Azerbaijan"}, "IE": {"path": "M405.17,135.35l0.36,2.16l-1.78,2.84l-4.28,1.91l-3.02,-0.43l1.81,-3.13l0.02,-0.26l-1.23,-3.26l3.24,-2.56l1.54,-1.32l0.37,1.33l-0.49,1.77l0.3,0.38l1.49,-0.05l1.68,0.63Z", "name": "Ireland"}, "ID": {"path": "M756.56,287.86l0.69,4.02l0.15,0.21l2.59,1.5l0.39,-0.07l2.05,-2.61l2.75,-1.45l2.09,-0.0l2.08,0.85l1.85,0.89l2.52,0.46l0.08,15.44l-1.72,-1.6l-0.15,-0.07l-2.54,-0.51l-0.29,0.1l-0.53,0.62l-2.53,0.06l0.78,-1.51l1.48,-0.66l0.17,-0.34l-0.65,-2.74l-1.23,-2.19l-0.14,-0.13l-4.85,-2.13l-2.09,-0.23l-3.7,-2.28l-0.41,0.1l-0.67,1.11l-0.63,0.14l-0.41,-0.67l-0.01,-1.01l-0.14,-0.25l-1.39,-0.89l2.05,-0.69l1.73,0.05l0.29,-0.39l-0.21,-0.66l-0.29,-0.21l-3.5,-0.0l-0.9,-1.36l-0.19,-0.13l-2.14,-0.44l-0.65,-0.76l2.86,-0.51l1.28,-0.79l3.75,0.96l0.32,0.76ZM758.01,300.37l-0.79,1.04l-0.14,-1.07l0.4,-0.81l0.29,-0.47l0.24,0.31l-0.0,1.0ZM747.45,292.9l0.48,1.02l-1.45,-0.69l-2.09,-0.21l-1.45,0.16l-1.28,-0.07l0.35,-0.81l2.86,-0.1l2.58,0.68ZM741.15,285.69l-0.16,-0.25l-0.72,-3.08l0.47,-1.86l0.35,-0.38l0.1,0.73l0.25,0.26l1.28,0.19l0.18,0.78l-0.11,1.8l-0.96,-0.18l-0.35,0.22l-0.38,1.52l0.05,0.24ZM741.19,285.75l0.76,0.97l-0.11,0.05l-0.65,-1.02ZM739.18,293.52l-0.61,0.54l-1.44,-0.38l-0.25,-0.55l1.93,-0.09l0.36,0.48ZM728.4,295.87l-0.27,-0.07l-2.26,0.89l-0.37,-0.41l0.27,-0.8l-0.09,-0.33l-1.68,-1.37l0.17,-2.29l-0.42,-0.3l-1.67,0.76l-0.17,0.29l0.21,2.92l0.09,3.34l-1.22,0.28l-0.78,-0.54l0.65,-2.1l0.01,-0.14l-0.39,-2.42l-0.29,-0.25l-0.86,-0.02l-0.63,-1.4l0.99,-1.61l0.35,-1.97l1.24,-3.73l0.49,-0.96l1.95,-1.7l1.86,0.69l3.16,0.35l2.92,-0.1l0.17,-0.06l2.24,-1.65l0.11,0.14l-1.8,2.22l-1.72,0.44l-2.41,-0.48l-4.21,0.13l-2.19,0.36l-0.25,0.24l-0.36,1.9l0.08,0.27l2.24,2.23l0.4,0.02l1.29,-1.08l3.19,-0.58l-0.19,0.06l-1.04,1.4l-2.13,0.94l-0.12,0.45l2.26,3.06l-0.37,0.69l0.03,0.32l1.51,1.95ZM728.48,295.97l0.59,0.76l-0.02,1.37l-1.0,0.55l-0.64,-0.58l1.09,-1.84l-0.02,-0.26ZM728.64,286.95l0.79,-0.14l-0.07,0.39l-0.72,-0.24ZM732.38,310.1l-1.89,0.49l-0.06,-0.06l0.17,-0.64l1.0,-1.42l2.14,-0.87l0.1,0.2l0.04,0.58l-1.49,1.72ZM728.26,305.71l-0.17,0.63l-3.53,0.67l-3.02,-0.28l-0.0,-0.42l1.66,-0.44l1.47,0.71l0.16,0.03l1.75,-0.21l1.69,-0.69ZM722.98,310.33l-0.74,0.03l-2.52,-1.35l1.42,-0.3l1.19,0.7l0.72,0.63l-0.06,0.28ZM716.24,305.63l0.66,0.49l0.22,0.06l1.35,-0.18l0.31,0.53l-4.18,0.77l-0.8,-0.01l0.51,-0.86l1.2,-0.02l0.24,-0.12l0.49,-0.65ZM715.84,280.21l0.09,0.34l2.25,1.86l-2.25,0.22l-0.24,0.17l-0.84,1.71l-0.03,0.15l0.1,2.11l-2.27,1.62l-0.13,0.24l-0.06,2.46l-0.74,2.92l-0.02,-0.05l-0.39,-0.16l-2.62,1.04l-0.86,-1.33l-0.23,-0.14l-1.71,-0.14l-1.19,-0.76l-0.25,-0.03l-2.78,0.84l-0.79,-1.05l-0.26,-0.12l-1.61,0.13l-1.8,-0.25l-0.36,-3.13l-0.15,-0.23l-1.18,-0.65l-1.13,-2.02l-0.33,-2.1l0.27,-2.19l1.05,-1.17l0.28,1.12l0.1,0.16l1.71,1.41l0.28,0.05l1.55,-0.49l1.54,0.17l0.23,-0.07l1.4,-1.21l1.05,-0.19l2.3,0.68l0.16,0.0l2.04,-0.53l0.21,-0.19l1.26,-3.41l0.91,-0.82l0.09,-0.14l0.8,-2.64l2.63,0.0l1.71,0.33l-1.19,1.89l0.02,0.34l1.74,2.24l-0.37,1.0ZM692.67,302.0l0.26,0.19l4.8,0.25l0.28,-0.16l0.44,-0.83l4.29,1.12l0.85,1.52l0.23,0.15l3.71,0.45l2.37,1.15l-2.06,0.69l-2.77,-1.0l-2.25,0.07l-2.57,-0.18l-2.31,-0.45l-2.94,-0.97l-1.84,-0.25l-0.13,0.01l-0.97,0.29l-4.34,-0.98l-0.38,-0.94l-0.25,-0.19l-1.76,-0.14l1.31,-1.84l2.81,0.14l1.97,0.96l0.95,0.19l0.28,0.74ZM685.63,299.27l-2.36,0.04l-2.07,-2.05l-3.17,-2.02l-1.06,-1.5l-1.88,-2.02l-1.22,-1.85l-1.9,-3.49l-2.2,-2.11l-0.71,-2.08l-0.94,-1.99l-0.1,-0.12l-2.21,-1.54l-1.35,-2.17l-1.86,-1.39l-2.53,-2.68l-0.14,-0.81l1.22,0.08l3.76,0.47l2.16,2.4l1.94,1.7l1.37,1.04l2.35,2.67l0.22,0.1l2.44,0.04l1.99,1.62l1.42,2.06l0.09,0.09l1.67,1.0l-0.88,1.8l0.11,0.39l1.44,0.87l0.13,0.04l0.68,0.05l0.41,1.62l0.87,1.4l0.22,0.14l1.71,0.21l1.06,1.38l-0.61,3.04l-0.09,3.6Z", "name": "Indonesia"}, "UA": {"path": "M500.54,141.42l0.9,0.13l0.27,-0.11l0.52,-0.62l0.68,0.13l2.43,-0.3l1.32,1.57l-0.45,0.48l-0.07,0.26l0.21,1.03l0.27,0.24l1.85,0.15l0.76,1.22l-0.05,0.55l0.2,0.31l3.18,1.15l0.18,0.01l1.75,-0.47l1.42,1.41l0.22,0.09l1.42,-0.03l3.44,0.99l0.02,0.65l-0.97,1.62l-0.03,0.24l0.52,1.67l-0.29,0.79l-2.24,0.22l-0.14,0.05l-1.29,0.89l-0.13,0.23l-0.07,1.16l-1.75,0.22l-0.12,0.04l-1.6,0.98l-2.27,0.16l-0.12,0.04l-2.16,1.17l-0.16,0.29l0.15,1.94l0.14,0.23l1.23,0.75l0.18,0.04l2.06,-0.15l-0.22,0.51l-2.67,0.54l-3.27,1.72l-1.0,-0.45l0.45,-1.19l-0.19,-0.39l-2.34,-0.78l0.15,-0.2l2.32,-1.0l0.09,-0.49l-0.73,-0.72l-0.15,-0.08l-3.69,-0.75l-0.14,-0.96l-0.35,-0.25l-2.32,0.39l-0.21,0.15l-0.91,1.7l-1.77,2.1l-0.93,-0.44l-0.24,-0.0l-1.05,0.45l-0.48,-0.25l0.13,-0.07l0.14,-0.15l0.43,-1.04l0.67,-0.97l0.04,-0.26l-0.1,-0.31l0.04,-0.02l0.11,0.19l0.24,0.15l1.48,0.09l0.78,-0.25l0.07,-0.53l-0.27,-0.19l0.09,-0.25l-0.08,-0.33l-0.81,-0.74l-0.34,-1.24l-0.14,-0.18l-0.73,-0.42l0.15,-0.87l-0.11,-0.29l-1.13,-0.86l-0.15,-0.06l-0.97,-0.11l-1.79,-0.97l-0.2,-0.03l-1.66,0.32l-0.13,0.06l-0.52,0.41l-0.95,-0.0l-0.23,0.11l-0.56,0.66l-1.74,0.29l-0.79,0.43l-1.01,-0.68l-0.16,-0.05l-1.57,-0.01l-1.52,-0.35l-0.23,0.04l-0.71,0.45l-0.09,-0.43l-0.13,-0.19l-1.18,-0.74l0.38,-1.02l0.53,-0.64l0.35,0.12l0.37,-0.41l-0.57,-1.29l2.1,-2.5l1.16,-0.36l0.2,-0.2l0.27,-0.92l-0.01,-0.2l-1.1,-2.52l0.79,-0.09l0.13,-0.05l1.3,-0.86l1.83,-0.07l2.48,0.26l2.84,0.8l1.91,0.06l0.88,0.45l0.29,-0.01l0.72,-0.44l0.49,0.58l0.25,0.11l2.2,-0.16l0.94,0.3l0.39,-0.26l0.15,-1.57l0.61,-0.59l2.01,-0.19Z", "name": "Ukraine"}, "QA": {"path": "M548.47,221.47l-0.15,-1.72l0.59,-1.23l0.38,-0.16l0.54,0.6l0.04,1.4l-0.47,1.37l-0.41,0.11l-0.53,-0.37Z", "name": "Qatar"}, "MZ": {"path": "M507.71,314.14l1.65,-0.18l2.96,0.7l0.2,-0.02l0.6,-0.29l1.68,-0.06l0.18,-0.07l0.8,-0.69l1.5,0.02l2.74,-0.98l1.74,-1.27l0.25,0.7l-0.1,2.47l0.31,2.27l0.1,3.97l0.42,1.24l-0.7,1.71l-0.94,1.73l-1.52,1.52l-5.06,2.21l-2.88,2.8l-1.01,0.51l-1.72,1.81l-0.99,0.58l-0.15,0.23l-0.21,1.86l0.04,0.19l1.17,1.95l0.47,1.47l0.03,0.74l0.39,0.28l0.05,-0.01l-0.06,2.13l-0.39,1.19l0.1,0.33l0.42,0.32l-0.28,0.83l-0.95,0.86l-2.03,0.88l-3.08,1.49l-1.1,0.99l-0.09,0.28l0.21,1.13l0.21,0.23l0.38,0.11l-0.14,0.89l-1.39,-0.02l-0.17,-0.94l-0.38,-1.23l-0.2,-0.89l0.44,-2.91l-0.01,-0.14l-0.65,-1.88l-1.15,-3.55l2.52,-2.85l0.68,-1.89l0.29,-0.18l0.14,-0.2l0.28,-1.53l-0.03,-0.19l-0.36,-0.7l0.1,-1.83l0.49,-1.84l-0.01,-3.26l-0.14,-0.25l-1.3,-0.83l-0.11,-0.04l-1.08,-0.17l-0.47,-0.55l-0.1,-0.08l-1.16,-0.54l-0.13,-0.03l-1.83,0.04l-0.32,-2.25l7.19,-1.99l1.32,1.12l0.29,0.06l0.55,-0.19l0.75,0.49l0.11,0.81l-0.49,1.11l-0.02,0.15l0.19,1.81l0.09,0.18l1.63,1.59l0.48,-0.1l0.72,-1.68l0.99,-0.49l0.17,-0.29l-0.21,-3.29l-0.04,-0.13l-1.11,-1.92l-0.9,-0.82l-0.21,-0.08l-0.62,0.03l-0.63,-2.98l0.61,-1.67Z", "name": "Mozambique"}}, "height": 440.7063107441331, "projection": {"type": "mill", "centralMeridian": 11.5}, "width": 900.0});;
//
// (c) FB2 Consulting Ltd 2014
// 
// Common Javascript Functions 
//
var Donorfy = {
    ////////////////////////////////////////////////////////////////////////
    // Constituent & Contact Block Functions 
    ////////////////////////////////////////////////////////////////////////

    // Toggles the controls on the address block when a constituent is being linked 
    // to another address
    Address_ToggleFinderDisplay: function (id) {
        var checked = $('#CheckBox' + id).is(':checked');
        //    checked = !checked;
        var addressLinkDiv = $('#AddressLinkDiv' + id);
        var addressEnterDiv = $('#AddressEntryDiv' + id);

        var addressLinkFindDiv = $('#AddressLinkFindDiv' + id);
        var addressLinkProfileDiv = $('#AddressLinkProfileDiv' + id);

        if (checked) {
            // clear 
            // allow selection of address 
            addressLinkDiv.show();
            addressLinkFindDiv.show();
            addressLinkProfileDiv.hide();
            addressEnterDiv.hide();
        } else {
            addressLinkDiv.hide();
            addressEnterDiv.show();
            $("#ID" + id).val('');
        }
    },

    // called from constituent preference centre form to allow editing  
    CommsPreferenceEnableEdit: function (id) {
        var editCommPrefForm = "EditCommPrefForm" + id;
        Donorfy.UI_MakeFormActive(editCommPrefForm);

        var editBtnCommPrefForm = "EditBtnCommPrefForm" + id;
        $('#' + editBtnCommPrefForm).toggleClass("hidden");

        var saveBtnCommPrefForm = "SaveBtnCommPrefForm" + id;
        $('#' + saveBtnCommPrefForm).toggleClass("hidden");

        var cancelBtnCommPrefForm = "CancelBtnCommPrefForm" + id;
        $('#' + cancelBtnCommPrefForm).toggleClass("hidden");

        var divId = "UpdateDetails" + id;
        $('#' + divId).toggleClass("hidden");
    },

    // called from constituent preference centre form to put form into read only
    CommsPreferenceReadOnly: function (id) {
        var editCommPrefForm = "EditCommPrefForm" + id;
        Donorfy.UI_MakeFormReadOnly(editCommPrefForm);

        var editBtnCommPrefForm = "EditBtnCommPrefForm" + id;
        $('#' + editBtnCommPrefForm).toggleClass("hidden").prop('disabled', '');;

        var saveBtnCommPrefForm = "SaveBtnCommPrefForm" + id;
        $('#' + saveBtnCommPrefForm).toggleClass("hidden");

        var cancelBtnCommPrefForm = "CancelBtnCommPrefForm" + id;
        $('#' + cancelBtnCommPrefForm).toggleClass("hidden");

        var divId = "UpdateDetails" + id;
        $('#' + divId).toggleClass("hidden");

    },

    // Adds household member to constituent id passed in and refreshes the constituent list in the profile display
    Constituent_AddLinked: function (id) {
        var formContainer = $("#Form" + id);
        var title = $(formContainer).find("#AddConsTitle").val();
        var lastName = $(formContainer).find("#AddConsLastName").val();
        var firstName = $(formContainer).find("#AddConsFirstName").val();
        var dayOfBirth = $(formContainer).find("#AddConsDayOfBirth").val();
        var monthOfBirth = $(formContainer).find("#AddConsMonthOfBirth").val();
        var yearOfBirth = $(formContainer).find("#AddConsYearOfBirth").val();
        var gender = $(formContainer).find("#AddConsGender").val();
        var linkedConstituentList = $(formContainer).find('#LinkedConstituentList');
        var loadingLinkedConstituentList = $(formContainer).find('#LoadingLinkedConstituentList');
        if (loadingLinkedConstituentList != null) {
            loadingLinkedConstituentList.removeClass('hidden');
        }
        Donorfy.UI_ShowHide('AddLinkedConstituent');
        $.ajax({
            url: "/Constituent/AddLinkedConstituent?id=" +
                id +
                "&title=" +
                title +
                "&lastName=" +
                lastName +
                "&firstName=" +
                firstName +
                "&dayOfBirth=" +
                dayOfBirth +
                "&monthOfBirth=" +
                monthOfBirth +
                "&yearOfBirth=" +
                yearOfBirth +
                "&gender=" +
                gender,
            type: 'post',
            success: function (data) {
                Donorfy.AJAX_GetHTMLContentForEntity(id,
                    'Constituent',
                    'Constituent',
                    'GetLinkedConstituentList',
                    linkedConstituentList,
                    loadingLinkedConstituentList);
                $(formContainer).find("#AddConsLastName").val('');
                $(formContainer).find("#AddConsTitle").val('');
                $(formContainer).find("#AddConsFirstName").val('');
                $(formContainer).find("#AddConsDayOfBirth").val('');
                $(formContainer).find("#AddConsMonthOfBirth").val('');
                $(formContainer).find("#AddConsYearOfBirth").val('');
                $(formContainer).find("#AddConsGender").val('');
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });
    },

    Constituent_RemoveMajorGivingProfile: function (id) {
        var errorMessageDiv = $("#removeGivingProfileErrDiv" + id);
        var errorMessage = $("#removeGivingProfileMsg" + id);
        var blockbtn = $('#removeGivingProfileBtn' + id);
        blockbtn.button("loading");
        $.ajax({
            url: "/Constituent/RemoveMajorGivingProfile?id=" + id,
            type: 'post',
            success: function (data) {
                if (data.ErrorMessage != "") {
                    errorMessageDiv.show();
                    errorMessage.text(data.ErrorMessage);
                    blockbtn.button("reset");
                }
                if (data.IsSuccess) {
                    Donorfy.AJAX_HandleResponse_RedirectToURL(data.ReloadUrl);
                }
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });
    },

    // Removed the household member link between the two constituents passed in and then refreshes the constituent list in the profile display
    Constituent_RemoveLinked: function (fromId, toId) {
        var btn = $("#RemoveLinked" + toId);
        btn.button("loading");
        var formContainer = $("#Form" + fromId);
        var linkedConstituentList = $(formContainer).find('#LinkedConstituentList');
        $.ajax({
            url: "/Constituent/RemoveLinkedConstituent?fromId=" + fromId + "&toId=" + toId,
            type: 'post',
            success: function (data) {
                Donorfy.AJAX_GetHTMLContentForEntity(fromId,
                    'Constituent',
                    'Constituent',
                    'GetLinkedConstituentList',
                    linkedConstituentList);
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });
    },

    ////////////////////////////////////////////////////////////////////////
    // User  Functions 
    ////////////////////////////////////////////////////////////////////////

    // Toggles status of items on the getting started list
    User_UpdateGettingStartedListItem: function (id) {
        $.ajax({
            url: "/Home/UpdateGettingStartedItem?id=" + id,
            type: 'post',
            success: function (data) {
                $('#getting-started-grid').html(data);
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });
    },

    // Shows / Hides guides in the app
    User_ShowHideGuides: function (menuOptionId) {
        var guidesAreVisible = $("#GuidesAreVisible").val();
        Donorfy.UI_ShowHide('ContainerDivGuide');
        if (guidesAreVisible === "Yes") {
            $('#ShowHideGuideMenuOption').html($('#ShowHideGuideMenuOption').html().replace('Hide', 'Show'));
            $("#GuidesAreVisible").val("No");
            $("#MenuItemGuideIcon").addClass('fa-angle-down').removeClass('fa-angle-up');
            $.ajax({
                url: "/Home/HideGuide?setting=all&value=all",
                type: 'post',
                success: function (data) {
                    //
                }
            });
        }
        else {
            $('#ShowHideGuideMenuOption').html($('#ShowHideGuideMenuOption').html().replace('Show', 'Hide'));
            $("#GuidesAreVisible").val("Yes");
            $("#MenuItemGuideIcon").removeClass('fa-angle-down').addClass('fa-angle-up');
            $.ajax({
                url: "/Home/ShowGuide",
                type: 'post',
                success: function (data) {
                    //
                }
            });
        }
        return false;
    },
    ////////////////////////////////////////////////////////////////////////
    // Helper Functions 
    ////////////////////////////////////////////////////////////////////////

    // returns a Guid
    Helper_GetGuid: function () {
        return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g,
            function (c) {
                var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
                return v.toString(16);
            });
    },

    ////////////////////////////////////////////////////////////////////////
    // Ajax Functions 
    ////////////////////////////////////////////////////////////////////////

    // This retrieves details (e.g. description) for an entity and populates the html of the control passed in with the description
    // e.g. used when selecting a constituent for a soft credit
    //
    //    id - id of the entity whose details we need 
    //    controller - name of controller to post to 
    //    actionPrefix - any prefix to 'standard' controller action to call - e.g. for Look Ups base for standard lookups or specific overrides e.g. title
    //    action  - controller action, if the action is update (used for update or add) then form is validated
    //    targetControl - control which should be updated the description
    //    targetProperty - whether html or val property of the control should be updated - allows for updating of lables or inputs 
    //    successCallback - a function to callback to on success
    //
    AJAX_GetEntityDetails: function (id,
        controller,
        actionPrefix,
        action,
        targetControl,
        targetProperty,
        successCallback) {
        if (targetProperty === 'undefined') {
            targetProperty = 'html';
        }
        var target = $('#' + targetControl);
        if ((controller === undefined) || (controller === 'undefined') || (controller === '')) {
            return;
        }
        if ((action === undefined) || (action === 'undefined') || (action === '')) {
            return;
        }
        $.ajax({
            url: "/" + controller + "/" + actionPrefix + action + "?id=" + id,
            type: 'post',
            success: function (data) {
                if (data.ErrorMessage != "") {
                    if (targetProperty == "html") {
                        target.html(data.ErrorMessage);
                    } else {
                        target.val(data.ErrorMessage);
                    }
                }
                if (data.IsSuccess) {
                    if (targetProperty == "html") {
                        target.html(data.ConfirmMessage);
                    } else {
                        target.val(data.ConfirmMessage);
                    }
                }

                if (typeof successCallback === "function") {
                    successCallback(data);
                }

            },
            error: function (jqXhr) {
                let error = Donorfy.GetStandardAjaxErrorMessage(jqXhr);
                if (targetProperty == "html") {
                    target.html(error);
                } else {
                    target.val(error);
                }
            }
        });

    },

    // Called to perform a manage function on an entity - 
    //   - manageFunction - required manage function e.g. cancel
    //   - id, controller, actionPrefix, action are as for AJAX_PerformOperation
    AJAX_PerformManageFunction: function (manageFunciton, id, controller, actionPrefix, action) {
        $("#Form" + id + ' #ManageFunction').val(manageFunciton);
        Donorfy.AJAX_PerformOperation(id, controller, actionPrefix, action);
    },

    ShowPleaseWaitFormMessage: function (formId) {
        var formContainer = $("#Form" + formId);
        $(formContainer).find('#pleaseWaitMsg').removeClass('hidden');
        $(formContainer).find('#pleaseWaitHide').addClass('hidden');
    },

    HideFormMessages: function (formId) {

        $("#ErrMsgDiv" + formId).hide();
        $("#ConfirmMsgDiv" + formId).hide();

        $(".confirm-message-div").hide();
        $(".confirm-message-div").hide();
    },
    ShowFormMessage: function (formId, data) {
        if (data.ErrorMessage !== "") {

            Donorfy.DisplayErrorMessage(data, formId);
            //  btn.button("reset");
            $("[id=" + action + id + "]").button("reset");
        }

        if (data.ConfirmMessage !== "") {
            Donorfy.DisplayConfirmMessage(data);
        }

    },
    ShowStandardFormButtons: function (formId) {

        $("#StdBtns" + formId).show();
        $("[id^='Conf'][id$='Btns'" + formId + "]").hide();

    },
    // This posts back a form of data to controller and displays success or error messages
    //
    //    buttonClicked - the button clicked
    //    formId - id of the form to postback 
    //    url - the url to post to 
    //    successCallback - a function to callback to on success
    //
    AJAX_PostForm: function (buttonClicked, formId, url, successCallback) {

        let formContainer = $("#Form" + formId);

        Donorfy.HideFormMessages(formId);
        Donorfy.ShowPleaseWaitFormMessage(formId);

        if (typeof CKEDITOR != "undefined") {
            for (var instanceName in CKEDITOR.instances)
                if (CKEDITOR.instances.hasOwnProperty(instanceName)) CKEDITOR.instances[instanceName].updateElement();
        }

        $(buttonClicked).button("loading");

        $.ajax({
            url: url,
            type: "post",
            data: formContainer.serialize(),
            success: function (data) {

                Donorfy.ShowFormMessage(formId, data);

                if (data.IsSuccess && successCallback) {
                    successCallback(data);
                } else {
                    Donorfy.ShowStandardFormButtons(formId);
                    $(buttonClicked).button("reset");
                }

            },
            error: function (jqXhr) {
                let errorData = { ErrorMessage: Donorfy.GetStandardAjaxErrorMessage(jqXhr), ErrorMessageDivId: "", ConfirmMessage: "" };
                Donorfy.ShowFormMessage(formId, errorData);
                Donorfy.ShowStandardFormButtons(formId);
                $(buttonClicked).button("reset");
            }
        });

    },

    // This posts back a form of data to controller in response to an add, update or delete operation
    //
    //    id - id of the entity being operated on 
    //    controller - name of controller to post to 
    //    actionPrefix - any prefix to 'standard' controller action to call - e.g. for Look Us base for standard lookups or specific overrides e.g. title
    //    action  - controller action, if the action is update (used for update or add) then form is validated
    //    parentId - the parent form id when reloading data after resetting a pushdown
    //    callback - a function to call if operation completes successfully
    //
    AJAX_PerformOperation: function (id, controller, actionPrefix, action, parentId, callback) {
        var formContainer = $("#Form" + id);
        if (typeof CKEDITOR != "undefined") {
            for (var instanceName in CKEDITOR.instances)
                if (CKEDITOR.instances.hasOwnProperty(instanceName)) CKEDITOR.instances[instanceName].updateElement();
        }
        Donorfy.AJAX_PerformOperationForInputs(id, formContainer, formContainer.serialize(), controller, actionPrefix, action, parentId, callback)
    },

    AJAX_PerformOperationForInputs: function (id, elementContainer, postData, controller, actionPrefix, action, parentId, callback) {

        Donorfy.HideFormMessages(id);

        $(elementContainer).find('#pleaseWaitMsg').removeClass('hidden');
        $(elementContainer).find('#pleaseWaitHide').addClass('hidden');


        var btn = $("#" + action + id);
        //  btn.button("loading");
        $("[id=" + action + id + "]").button("loading");
        $("[id=" + actionPrefix + action + id + "]").button("loading");

        $.ajax({
            url: "/" + controller + "/" + actionPrefix + action,
            type: 'post',
            data: postData,
            success: function (data) {
                $(elementContainer).find('#pleaseWaitMsg').addClass('hidden');
                $(elementContainer).find('#pleaseWaitHide').removeClass('hidden');

                if (data.ErrorMessage !== "") {
                    Donorfy.DisplayErrorMessage(data, id);

                    //show standard buttons
                    $("#StdBtns" + id).show();

                    //hide any confirm dialogues
                    $("[id^='Conf'][id$='Btns" + id + "']").hide();

                    //  btn.button("reset");
                    $("[id=" + action + id + "]").button("reset");
                    $("[id=" + actionPrefix + action + id + "]").button("reset");

                    if (data.ContainerToClose !== "") {
                        Donorfy.UI_ShowHide(data.ContainerToClose);
                    }
                }
                if (data.IsSuccess) {
                    // if successful operation refresh display so items are up to date 
                    if (data.ReloadClosePopUp) {
                        Donorfy.AJAX_HandleResponse_ClosePopUp();
                    }
                    if (data.ReloadResetPushdown) {
                        Donorfy.AJAX_HandleResponse_ResetPushdown();
                        if (!data.Reload) {

                            Donorfy.DisplayConfirmMessage(data, id);

                            if (data.RefreshUserTasks) {
                                Donorfy.RefreshTaskUI();
                            }

                            //raise callback if function set on page
                            if (window.pushdownCallback) {
                                window.pushdownCallback(data);
                            }

                            return;
                        } else {

                            //set form container to parent for reload
                            elementContainer = $("#Form" + parentId);
                            id = parentId;
                        }
                    }
                    if (data.Reload) {
                        if (data.ResetUnsavedChanges === "yes") {
                            try {
                                $('#' + data.ResetUnsavedChangesContainer)[0]
                                    .reset(); //prevent leave/stay on page browser warning
                            } catch (e) {
                                //
                            }
                        }
                        if (data.ReloadUrl === "") {
                            if (data.ReloadController !== "") {
                                controller = data.ReloadController;
                            }
                            Donorfy.AJAX_HandleResponse_UpdateUI(id,
                                elementContainer,
                                controller,
                                btn,
                                data.ConfirmMessage,
                                data, callback);

                            if ((data.ReloadTarget2 !== "") && (data.ReloadTarget2 !== "null")) {
                                data.ReloadTarget = data.ReloadTarget2;
                                Donorfy.AJAX_HandleResponse_UpdateUI(id,
                                    elementContainer,
                                    controller,
                                    btn,
                                    data.ConfirmMessage,
                                    data);
                            }

                            if (data.RefreshUserTasks) {
                                Donorfy.RefreshTaskUI();
                            }
                        } else {

                            try {
                                $(elementContainer)[0].reset(); //prevent leave/stay on page browser warning
                            } catch (e) {
                                //
                            }

                            Donorfy.SaveConfirmMessage(data.ConfirmMessage, data.ConfirmMessageDivId, id);
                            Donorfy.AJAX_HandleResponse_RedirectToURL(data.ReloadUrl);
                        }
                    }
                    if (!data.Reload) {
                        Donorfy.DisplayConfirmMessage(data, id);
                        //  btn.button("reset");
                        $("[id=" + action + id + "]").button("reset");
                        $("[id=" + actionPrefix + action + id + "]").button("reset");

                        if (data.RefreshUserTasks) {
                            Donorfy.RefreshTaskUI();
                        }

                        if (typeof callback === "function") {
                            callback(data);
                        }

                    }
                    if (data.ContainerToClose !== "") {
                        Donorfy.UI_ShowHide(data.ContainerToClose);
                    }
                    // Updates page header stats - e.g. after transaction inserted 
                    if (data.RefreshHeaderStats) {
                        //  Donorfy.AJAX_GetEntityDetails(data.HeaderStatsRefreshId, data.HeaderStatsRefreshController, '', data.HeaderStatsRefreshAction, 'PageHeaderStatsDiv', 'html');
                        Donorfy.AJAX_RefreshPageHeaderStats(data.HeaderStatsRefreshId,
                            data.HeaderStatsRefreshController,
                            data.HeaderStatsRefreshAction);
                    }
                }
            },
            error: function (jqXhr) {
                Donorfy.DisplayErrorMessageText("ErrMsgDiv" + id, Donorfy.GetStandardAjaxErrorMessage(jqXhr));
                btn.button("reset");
            }
        });
    },

    // refreshes stats / KPI in page header
    AJAX_RefreshPageHeaderStats: function (id, controller, action) {

        if (action === "TriggerHeaderRefresh") {
            $(document).trigger("refresh-header-stats");

        } else {
            var targetUrl = "/" + controller + "/" + action + "?id=" + id;
            $.ajax({
                url: targetUrl,
                type: "GET",
                cache: false,
                datatype: "html",
                success: function (refreshData) {
                    $("#PageHeaderStatsDiv").replaceWith(refreshData);
                }
            });
        }
    },

    // Called from AJAX_PerformOperation to update UI by calling a controller action
    AJAX_HandleResponse_UpdateUI: function (id, formContainer, controller, btn, confirmMessageTxt, data, successCallback) {
        var targetUrl = "/" + controller + "/" + data.ReloadMethod;
        if ((data.ReloadParam1Name != "") && (data.ReloadParam1Name != "null")) {
            targetUrl = targetUrl + "?" + data.ReloadParam1Name + "=" + data.ReloadParam1Value;
        }
        if ((data.ReloadParam2Name != "") && (data.ReloadParam2Name != "null")) {
            targetUrl = targetUrl + "&" + data.ReloadParam2Name + "=" + data.ReloadParam2Value;
        }
        if ((data.ReloadParam3Name != "") && (data.ReloadParam3Name != "null")) {
            targetUrl = targetUrl + "&" + data.ReloadParam3Name + "=" + data.ReloadParam3Value;
        }
        if ((data.ReloadParam4Name != "") && (data.ReloadParam4Name != "null")) {
            targetUrl = targetUrl + "&" + data.ReloadParam4Name + "=" + data.ReloadParam4Value;
        }
        if ((data.ReloadParam5Name != "") && (data.ReloadParam5Name != "null")) {
            targetUrl = targetUrl + "&" + data.ReloadParam5Name + "=" + data.ReloadParam5Value;
        }
        if ((data.ReloadTarget != "") && (data.ReloadTarget != "null")) {
            formContainer = $("#" + data.ReloadTarget);
        }
        var replaceForm = false;
        if (data.ReloadReplace) {
            replaceForm = true;
        }

        $.ajax({
            url: targetUrl,
            type: "GET",
            cache: false,
            datatype: "html",
            success: function (refreshData) {
                if (replaceForm) {
                    formContainer.replaceWith(refreshData);
                } else {
                    formContainer.html(refreshData);
                }

                refreshData.ConfirmMessage = confirmMessageTxt;
                Donorfy.DisplayConfirmMessage(data, id);
                btn.button("reset");

                if (typeof successCallback === "function") {
                    successCallback(data);
                }
            }
        });
    },

    // Called from AJAX_PerformOperation to redirect to a new page
    AJAX_HandleResponse_RedirectToURL: function (gotoURL) {
        window.location.href = gotoURL;
    },

    AJAX_HandleResponse_OpenInNewTab: function (gotoURL) {
        {
            window.open(gotoURL);
        }
    },

    // Called from AJAX_PerformOperation to close the standard popup form
    AJAX_HandleResponse_ClosePopUp: function () {
        var popupForm = $('#Popup-Form');
        popupForm.modal('hide');
        var popupTarget = $('#Popup-Target');
        popupTarget.html('');
    },

    // Called from AJAX_PerformOperation to reset the main pushdown div
    AJAX_HandleResponse_ResetPushdown: function () {
        var pushdown1 = $('#MainPushdownTarget');
        pushdown1.addClass('hidden');
        pushdown1.html('<img src="/images/Spinner1.gif"/>');
        $('#content').removeClass('hidden');
        $('#PageHeaderDiv').removeClass('hidden');
    },

    // Gets HTML content (i.e. a partial view)  e.g. in response to user action (e.g. tab click) 
    // The Id passed is the data-id of the tab, menu item etc clicked 
    AJAX_GetHTMLContent: function (id) {
        var formContainer = $("#Form" + id);
        var targetDiv = $("#Target" + id);
        if (targetDiv.attr('id') == null) {
            targetDiv = $("#Target");
            targetDiv.show();
        }
        $(formContainer).find('#pleaseWaitMsg').removeClass('hidden');
        $(formContainer).find('#pleaseWaitHide').addClass('hidden');
        let submitData = formContainer.serialize();
        let controller = $("#Controller" + id).val();
        let action = $("#Action" + id).val();
        let targetUrl = '/' + controller + '/' + action;
        if ((controller === undefined) || (controller === 'undefined') || (controller === '')) {
            return;
        }
        if ((action === undefined) || (action === 'undefined') || (action === '')) {
            return;
        }
        $.ajax({
            url: targetUrl,
            type: 'get',
            cache: false,
            data: submitData,
            datatype: "html",
            success: function (data) {
                targetDiv.show();
                targetDiv.html(data);
                nav_page_height();
            },
            error: Donorfy.ShowStandardAjaxErrorAlert//function (jqXhr) {
            //Donorfy.DisplayErrorMessageText("ErrMsgDiv" + id, Donorfy.GetStandardAjaxErrorMessage(jqXhr));
            //}
        });
    },

    // Gets content for action confirmation - e.g. do you want to create this batch
    // this method is needed when the confirmation requires some server side processing - e.g. to calculate batch totals for a preview
    AJAX_GetActionConfirmation: function (id, controller, actionPrefix, action) {
        var formContainer = $("#Form" + id);

        $(formContainer).find('#pleaseWaitMsg').removeClass('hidden');
        $(formContainer).find('#pleaseWaitHide').addClass('hidden');

        $("[id=" + action + id + "]").button("loading");
        $("[id=" + actionPrefix + action + id + "]").button("loading");

        var submitData = formContainer.serialize();
        var targetUrl = '/' + controller + '/' + actionPrefix + action;
        if ((controller === undefined) || (controller === 'undefined') || (controller === '')) {
            return;
        }
        if ((action === undefined) || (action === 'undefined') || (action === '')) {
            return;
        }
        $.ajax({
            url: targetUrl,
            type: 'get',
            cache: false,
            data: submitData,
            datatype: "html",
            success: function (data) {
                var targetDiv = $("#ConfirmActionDiv" + id);
                targetDiv.removeClass('hidden');
                var previewDiv = $("#PreviewActionDiv" + id);
                previewDiv.addClass('hidden');
                targetDiv.html(data);
                $("[id=" + action + id + "]").button("reset");
                $("[id=" + actionPrefix + action + id + "]").button("reset");
                // pageSetUp();
                nav_page_height();
            },
            error: function (jqXhr) {
                Donorfy.DisplayErrorMessageText("ErrMsgDiv" + id, Donorfy.GetStandardAjaxErrorMessage(jqXhr));
            }
        });
    },

    // Called when a Confirmation action e.g. from AJAX_GetActionConfirmation is not performed so the UI should be reset 
    AJAX_ResetActionConfirmation: function (id) {
        var formContainer = $("#Form" + id);
        var targetDiv = $("#ConfirmActionDiv" + id);
        targetDiv.addClass('hidden');
        var previewDiv = $("#PreviewActionDiv" + id);
        previewDiv.removeClass('hidden');

        $(formContainer).find('#pleaseWaitMsg').addClass('hidden');
        $(formContainer).find('#pleaseWaitHide').removeClass('hidden');

        $('#ResetButton' + id).button("reset");

    },
    // Gets HTML content (i.e. a partial view) to provide data about a specific entity
    // Guid id of entity
    // entity Type - optional
    // Controller & Action to return content 
    // targetDiv - div where results get written back to 
    AJAX_GetHTMLContentForEntity: function (id, entityType, controller, action, targetDiv, pleaseWaitDiv, successCallback) {
        var parameters = 'id=' + id + '&entityType=' + entityType;
        Donorfy.AJAX_GetHTMLContentForTarget(controller, action, parameters, targetDiv, pleaseWaitDiv, successCallback);
    },

    AJAX_PostWithCallback: function (controller, action, parameters, body, pleaseWaitDiv, successCallback, dataType) {
        if (pleaseWaitDiv != null) {
            pleaseWaitDiv.removeClass('hidden');
        }

        if (!dataType) {
            dataType = "html";
        }

        let targetUrl = '/' + controller + '/' + action + '?' + parameters;
        $.ajax({
            url: targetUrl,
            type: 'post',
            cache: false,
            data: body,
            contentType: "application/json",
            dataType: dataType,
            success: function (data) {
                if (pleaseWaitDiv != null) {
                    pleaseWaitDiv.addClass('hidden');
                }

                if (typeof (successCallback) === "function") {
                    successCallback(data);
                }
            },
            error: function () {
                if (pleaseWaitDiv != null) {
                    pleaseWaitDiv.addClass('hidden');
                }
            }
        });
    },
    AJAX_GetHTMLContentForTarget: function (controller, action, parameters, targetDiv, pleaseWaitDiv, successCallback) {
        if (pleaseWaitDiv != null) {
            pleaseWaitDiv.removeClass('hidden');
        }
        var targetUrl = '/' + controller + '/' + action + '?' + parameters;
        $.ajax({
            url: targetUrl,
            type: 'get',
            cache: false,
            datatype: "html",
            success: function (data) {
                targetDiv.show();
                targetDiv.html(data);
                if (pleaseWaitDiv != null) {
                    pleaseWaitDiv.addClass('hidden');
                }
                nav_page_height();

                if (successCallback) {
                    successCallback(data);
                }

            },
            error: function () {
                if (pleaseWaitDiv != null) {
                    pleaseWaitDiv.addClass('hidden');
                }
            }
        });
    },
    AJAX_ReplaceContentForEntity: function (id, entityType, controller, action, targetDiv, pleaseWaitDiv) {
        var parameters = 'id=' + id + '&entityType=' + entityType;
        Donorfy.AJAX_ReplaceContentForTarget(controller, action, parameters, targetDiv, pleaseWaitDiv);
    },
    AJAX_ReplaceContentForTarget: function (controller, action, parameters, targetDiv, pleaseWaitDiv, successCallback) {
        if (pleaseWaitDiv != null) {
            pleaseWaitDiv.removeClass('hidden');
        }
        var targetUrl = '/' + controller + '/' + action + '?' + parameters;
        $.ajax({
            url: targetUrl,
            type: 'get',
            cache: false,
            datatype: "html",
            success: function (data) {
                targetDiv.show();
                targetDiv.replaceWith(data);
                if (pleaseWaitDiv != null) {
                    pleaseWaitDiv.addClass('hidden');
                }
                nav_page_height();

                if (successCallback) {
                    successCallback(data);
                }

            },
            error: function () {
                if (pleaseWaitDiv != null) {
                    pleaseWaitDiv.addClass('hidden');
                }
            }
        });
    },

    // This function is called to undo changes made to an entity 
    // it calls the undo method of the controller and renders 
    // the HTML returned into the fieldset HTML for the entity
    AJAX_Undo: function (id, type, controller, operation) {
        var btn = $("#" + operation + id);
        btn.button("loading");

        var fieldContainer = $("#FieldSet" + id);
        $.ajax({
            url: "/" + controller + "/" + operation,
            type: 'post',
            data: { id: id, entityType: type },
            success: function (data) {
                fieldContainer.html(data);
            },
            error: function (jqXhr) {
                Donorfy.DisplayErrorMessageText("ErrMsgDiv" + id, Donorfy.GetStandardAjaxErrorMessage(jqXhr));
            }
        });

    },

    // This function saves a config setting - e.g. when the user toggles
    // between basic & advanced form display
    AJAX_SaveConfigSetting: function (controller, action, setting, value) {
        $.ajax({
            url: "/" + controller + "/" + action + "?setting=" + setting + "&value=" + value,
            type: 'post',
            success: function () {
                // handle success 
            },
            error: function () {
                // handle error
            }
        });
    },


    // Used to retrieve a json from the server - e.g. for settings - which can then be passed to the callback function - e.g. to configure the UI
    // see Views\Constituent\_ContactDetailsBlock.cshtml
    Ajax_GetJsonData: function (controller,
        action,
        callback,
        idParam,
        idValue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3,
        paramName4,
        paramValue4,
        paramName5,
        paramValue5) {
        var urlString = idParam + "=" + idValue;
        if (paramName1) {
            urlString = urlString + "&" + paramName1 + "=" + encodeURIComponent(paramValue1);
        }
        if (paramName2) {
            urlString = urlString + "&" + paramName2 + "=" + encodeURIComponent(paramValue2);
        }
        if (paramName3) {
            urlString = urlString + "&" + paramName3 + "=" + encodeURIComponent(paramValue3);
        }
        if (paramName4) {
            urlString = urlString + "&" + paramName4 + "=" + encodeURIComponent(paramValue4);
        }
        if (paramName5) {
            urlString = urlString + "&" + paramName5 + "=" + encodeURIComponent(paramValue5);
        }
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            success: function (data) {
                if (typeof callback === "function") {
                    callback(data);
                }
            }
        });
    },
    ////////////////////////////////////////////////////////////////////////
    // Grid (dataTables) Related 
    ////////////////////////////////////////////////////////////////////////

    // Calls the grid specific function passed (e.g. DataLoad, Grid Reset etc) - this is to allow dynamic names for loading function 
    Grid_Function: function (fnLoader) {
        fnLoader();
    },

    // Used to display a form as a push down below a row in the grid
    //  id - id of entity selected in the grid - also used to identify row being selected
    //  controller - controller & action to call which will return the form
    //  parameters to pass to action
    Grid_DisplayForm: function (sender,
        controller,
        action,
        idparam,
        idvalue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3,
        paramName4,
        paramValue4,
        paramName5,
        paramValue5) {
        var targetRowId = '';
        var parent;
        if (idvalue == '00000000-0000-0000-0000-000000000000') {
            var grid = $('#' + sender);
            parent = grid.find('tr:first');
        } else {
            parent = $(sender).closest('tr');
        }

        targetRowId = 'Target' + idvalue;
        var targetRow = $('tr[id=' + targetRowId + ']');
        if (targetRow.is(':visible')) {
            targetRow.hide();
        } else {
            var targetDivId = 'TargetRowDiv' + idvalue;
            if (!targetRow.length) {
                parent.after('<tr id=' +
                    targetRowId +
                    '><td colspan="11"><div id=' +
                    targetDivId +
                    ' ><img src="/images/Spinner1.gif"/></div></td></tr>');
            } else {
                targetRow.show();
                targetRow.removeClass('hidden');
            }

            var urlString = idparam + "=" + idvalue;
            if (paramName1 != "") {
                urlString = urlString + "&" + paramName1 + "=" + paramValue1;
            }
            if (paramName2 != "") {
                urlString = urlString + "&" + paramName2 + "=" + paramValue2;
            }
            if (paramName3 != "") {
                urlString = urlString + "&" + paramName3 + "=" + paramValue3;
            }
            if (paramName4 != "") {
                urlString = urlString + "&" + paramName4 + "=" + paramValue4;
            }
            if (paramName5 != "") {
                urlString = urlString + "&" + paramName5 + "=" + paramValue5;
            }
            $.ajax({
                url: "/" + controller + "/" + action + "?" + urlString,
                type: 'get',
                datatype: "html",
                cache: false,
                success: function (data) {
                    $("#" + targetDivId).html(data);
                },
                error: function (jqXhr) {
                    $("#" + targetDivId).text(Donrfy.GetStandardAjaxErrorMessage(jqXhr));
                }
            });
        }
    },

    // Called when a grid item is clicked on to display the associated detail / edit form which overlays the grid
    //  - gridId - id of grid making call
    //  - controller & action - to call to get form (partial view)
    //  - parameters to pass to action
    Grid_DisplayDetails: function (gridId,
        controller,
        action,
        idparam,
        idvalue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3) {
        var detailContainer = $('#GridDetailContainer' + gridId);
        var detailContainerLoading = $('#GridDetailContainerLoading' + gridId);
        var detailContainerDisplay = $('#GridDetailContainerDetail' + gridId);
        var gridContainer = $('#GridContainer' + gridId);
        // without this line it pushes the grid down, with it grid is hidden
        //   gridContainer.addClass('hidden');
        detailContainerDisplay.addClass('hidden');
        detailContainer.removeClass('hidden');
        detailContainerLoading.removeClass('hidden');

        var urlString = idparam + "=" + idvalue;
        if (paramName1 != "") {
            urlString = urlString + "&" + paramName1 + "=" + paramValue1;
        }
        if (paramName2 != "") {
            urlString = urlString + "&" + paramName2 + "=" + paramValue2;
        }
        if (paramName3 != "") {
            urlString = urlString + "&" + paramName3 + "=" + paramValue3;
        }
        urlString = urlString + "&popup=true";
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (popUpForm) {
                detailContainerDisplay.removeClass('hidden');
                detailContainerDisplay.html(popUpForm);
                detailContainerLoading.addClass('hidden');
            },
            error: function (jqXhr, textStatus, errorThrown) {
                detailContainerLoading.addClass('hidden');
                detailContainer.addClass('hidden');
                gridContainer.removeClass('hidden');
                Donorfy.ShowStandardAjaxErrorAlert(jqXhr, textStatus, errorThrown);
            }
        });
    },
    ////////////////////////////////////////////////////////////////////////
    // Tag Related
    ////////////////////////////////////////////////////////////////////////

    // Called from _Tags.cshtm to perform operations on tags as they are added and deleted
    Tag_PerformOperation: function (entityId, paramIdName, tagid, entityType, operation, startDate, endDate) {
        var targetUrl = '/Tags/Tag_Operation';
        targetUrl = targetUrl + '?' + paramIdName + '=' + entityId;
        targetUrl = targetUrl + "&tagTypeId=" + tagid;
        targetUrl = targetUrl + "&operation=" + operation;
        targetUrl = targetUrl + "&startDate=" + startDate;
        targetUrl = targetUrl + "&endDate=" + endDate;
        targetUrl = targetUrl + "&tagEntityType=" + entityType;
        $.ajax({
            url: targetUrl,
            type: 'post',
            datatype: "html",
            success: function (data) {
                //
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });

    },


    ////////////////////////////////////////////////////////////////////////
    // List Related
    ////////////////////////////////////////////////////////////////////////

    // called for List Save & Update preview - sets hidden fields of selected fields etc prior to save
    List_PreviewUpdate: function (id, controller, actionPrefix, action, parentId) {
        var formId = "Form" + id;
        var gridId = $('#' + formId).find("#GridId").val();
        var gId = 'Grid' + gridId + 'xGrid';
        var grid = $('#' + gId).DataTable();
        var sortFieldNumber = '';
        try {
            sortFieldNumber = grid.fnSettings().aaSorting[0][0];
        } catch (e) {
        }
        var sortDirection = '';
        try {
            sortDirection = grid.fnSettings().aaSorting[0][1];
        } catch (e) {
        }
        var sortFieldName = "";
        var i = 0;
        var columnsShown = new Array();
        try {
            $.each(grid.fnSettings().aoColumns,
                function (c) {
                    if (grid.fnSettings().aoColumns[c].bVisible === true) {
                        var colName = grid.fnSettings().aoColumns[c].sName;
                        if (colName !== '') {
                            columnsShown = columnsShown.concat(colName);
                            if (i === sortFieldNumber) {
                                sortFieldName = colName;
                            }
                        }
                    }
                    i++;
                });
        } catch (e) {
        }

        if (sortFieldNumber === 0) {
            sortFieldName = "EntityId";
        }
        $('#' + formId).find('#SelectedFields').val(columnsShown);
        $('#' + formId).find('#SortBy').val(sortFieldName);
        $('#' + formId).find('#SortDirection').val(sortDirection);
        Donorfy.AJAX_PerformOperation(id, controller, actionPrefix, action, parentId);
    },

    ////////////////////////////////////////////////////////////////////////
    // Template Related
    // - these are partial views that are added on the fly
    ////////////////////////////////////////////////////////////////////////

    // adds a template to a form
    // templateToAdd - name of Div containing template to add -  this will be set in the partial view used for the template as containerBaseName   e.g. softCredit
    // targetDiv - id of Div where new template should be inserted or jquery object 
    // prefix - add to name of new template to make it unique - usually Id of associated model
    // numberSep - number separate to use - if omitted then defaults to ,
    // decPoint - decimal point to use - if omitted then defaults to .
    Template_AddTemplate: function (templateToAdd, targetDiv, prefix, numberSep, decPoint) {

        if (numberSep === undefined) {
            numberSep = ',';
        }
        if (decPoint === undefined) {
            decPoint = '.';
        }



        var template;
        var counterField;
        if (typeof templateToAdd === "object") {
            template = templateToAdd;
            counterField = templateToAdd.siblings("input[type='hidden'][id$='TemplateId']");
        } else {
            template = $("#" + templateToAdd + "Template");
            // name of hidden field used to provide next index number to use  e.g. SoftCreditTemplateId
            counterField = $("#" + prefix + templateToAdd + "TemplateId");
        }


        var fieldIndex = counterField.val();
        var newValue = parseInt(fieldIndex) + 1;
        counterField.val(newValue);
        var newElem = template.clone();
        var newId = newElem.attr('id');
        newId = prefix + newId.replace('Template', fieldIndex);
        newElem.attr('id', newId);
        newElem.removeClass('hidden');

        // renames the inputs including buttons 
        newElem.find(':input').each(function () {
            newId = this.id.replace('%S', fieldIndex);
            this.id = newId;
            newId = this.name.replace('%S', fieldIndex);
            $(this).attr('data-fieldIndex', fieldIndex).attr('data-prefix', prefix);
            this.name = newId;

            var onChangeNode = $(this)[0].getAttributeNode('onchange');
            if (onChangeNode) {
                onChangeNode.value = onChangeNode.value.replace(new RegExp('%S', 'g'), fieldIndex);
            }

            var onClickNode = $(this)[0].getAttributeNode('onclick');
            if (onClickNode) {
                onClickNode.value = onClickNode.value.replace(new RegExp('%S', 'g'), fieldIndex);
            }
        });
        // renames a tags
        newElem.find('a').each(function () {
            newId = this.id.replace('%S', fieldIndex);
            this.id = newId;
            newId = this.name.replace('%S', fieldIndex);
            $(this).attr('data-fieldIndex', fieldIndex).attr('data-prefix', prefix);
            this.name = newId;

            var onClickNode = $(this)[0].getAttributeNode('onclick');
            if (onClickNode) {
                onClickNode.value = onClickNode.value.replace(new RegExp('%S', 'g'), fieldIndex);
            }
        });
        // renames labels 
        newElem.find('label').each(function () {
            newId = this.id.replace('%S', fieldIndex);
            this.id = newId;
            var forId = this.htmlFor.replace('%S', fieldIndex);
            this.htmlFor = forId;

        });

        //renames divs
        newElem.find('div').each(function () {
            newId = this.id.replace('%S', fieldIndex);
            this.id = newId;
        });


        var addTemplateId = template.attr('id');

        // Buttons - the name of the btn is set to the fieldindex and template prefix stored in data attr and gets passed to the JS function
        newElem.find('[id=' + addTemplateId + 'DeleteBtn' + fieldIndex + ']').attr('data-fieldIndex', fieldIndex)
            .attr('data-prefix', prefix);
        newElem.find('[id=' + addTemplateId + 'EditBtn' + fieldIndex + ']').attr('data-fieldIndex', fieldIndex)
            .attr('data-prefix', prefix);
        newElem.find('[id=' + addTemplateId + 'CancelBtn' + fieldIndex + ']').attr('data-fieldIndex', fieldIndex)
            .attr('data-prefix', prefix);
        // show / hide details links 
        newElem.find('[id=' + addTemplateId + 'ShowDetails]').attr('id', addTemplateId + 'ShowDetails' + fieldIndex);
        newElem.find('[id=' + addTemplateId + 'HideDetails]').attr('id', addTemplateId + 'HideDetails' + fieldIndex);
        // div containing the details which are shown / hidden
        newElem.find('[id=' + addTemplateId + 'Details]').attr('id', prefix + addTemplateId + 'Details' + fieldIndex);
        // divs containing display / edit controls
        newElem.find('[id=' + addTemplateId + 'Display]').attr('id', prefix + addTemplateId + 'Display' + fieldIndex);
        newElem.find('[id=' + addTemplateId + 'Edit]').attr('id', prefix + addTemplateId + 'Edit' + fieldIndex);
        // link for show / hide details 
        var link = newElem.find('[id=' + addTemplateId + 'ShowHideLink]');
        link.attr('id', addTemplateId + 'ShowHideLink' + fieldIndex);
        link.attr('href',
            'javascript:Donorfy.Template_ShowTemplateDetails("' +
            prefix +
            '","' +
            addTemplateId +
            '","' +
            fieldIndex +
            '")');

        newElem.find('[data-initselect2]').select2();


        if (typeof targetDiv === "object") {
            targetDiv.append(newElem);
        } else {
            $('#' + targetDiv).append(newElem);
        }

        // ReSharper disable once UnknownCssClass
        $('.datepicker', newElem).removeClass('hasDatepicker').datepicker();
        $('[data-autonumeric]').autoNumeric('init', { aSep: numberSep, aDec: decPoint });


        if (templateToAdd === 'InstructionDetails') {
            Donorfy.UI_InstructionDetailsInitialise(newElem, fieldIndex);
        }

        return newElem;
    },

    // RPI payment initialise dropdown options for start and end dates
    UI_InstructionDetailsInitialise: function (newElement, fieldIndex) {

        newElement.find('#StartDate').each(function () {
            this.id = 'StartDate' + fieldIndex;
        });
        newElement.find('#StartOption').each(function () {
            this.id = 'StartOption' + fieldIndex;
            $('#StartOption' + fieldIndex).change(function () {
                if ($(this).val() == 'NextCollectionDay') {
                    $('#StartDate' + fieldIndex).addClass('hidden');
                } else { $('#StartDate' + fieldIndex).removeClass('hidden'); }
            });
        });

        newElement.find('#EndDate').each(function () {
            this.id = 'EndDate' + fieldIndex;
        });

        newElement.find('#EndOption').each(function () {
            this.id = 'EndOption' + fieldIndex;
            $('#EndOption' + fieldIndex).change(function () {
                if ($(this).val() == 'NextCollectionDay') {
                    $('#EndDate' + fieldIndex).addClass('hidden');
                } else { $('#EndDate' + fieldIndex).removeClass('hidden'); }
            });
        });
    },

    // deletes the template - see _Allocation 
    // btn - button calling function - correct data attributes have been assigned in add template
    // template - type of template e.g. soft credit
    Template_DeleteTemplate: function (btn, template) {
        var prefix = "";
        var index = "";
        if (btn != null) {
            index = $(btn).data('fieldindex');
            prefix = $(btn).data('prefix');
        }

        var templateDiv = $('#' + prefix + template + index);
        templateDiv.addClass('hidden');
        var statusField = templateDiv.find('[id=TemplateStatus]');
        statusField.val('deleted');
    },

    // Called to toggle a template between a display and an edit mode e.g. in reponse to a edit / save button  - see _SoftCredit 
    // btn - id of button calling function - correct data attributes have been assigned in add template
    // template - type of template e.g. soft credit
    // -- these 2 are populated when the function is called from Transaction_AddSoftCreditCallBack
    // prefixParm - optional - prefix of template to make it unique - usually Id of associated model - can be picked up from calling btn
    // indexParm - optional - fieldindex of template
    Template_ToggleDisplayEdit: function (btn, template, prefixParm, indexParm) {

        var prefix = prefixParm;
        var index = indexParm;
        if (btn != null) {
            index = $(btn).data('fieldindex');
            prefix = $(btn).data('prefix');
        }


        if ($('#' + prefix + template + index).find('#SoftCreditsDisplay').hasClass('hidden') == true) {
            $('#' + prefix + template + index).find('#SoftCreditsDisplay').removeClass('hidden');
            $('#' + prefix + template + index).find('#SoftCreditsEdit').addClass('hidden');

        } else {
            $('#' + prefix + template + index).find('#SoftCreditsDisplay').addClass('hidden');
            $('#' + prefix + template + index).find('#SoftCreditsEdit').removeClass('hidden');
        }

        if (prefix !== '00000000000000000000000000000000') {
            if ($('#' + prefix + template + index).find('#' + prefix + 'SoftCreditsDisplay' + index).hasClass('hidden') == true) {
                $('#' + prefix + template + index).find('#' + prefix + 'SoftCreditsDisplay' + index).removeClass('hidden');
                $('#' + prefix + template + index).find('#' + prefix + 'SoftCreditsEdit' + index).addClass('hidden');

            } else {
                $('#' + prefix + template + index).find('#' + prefix + 'SoftCreditsDisplay' + index).addClass('hidden');
                $('#' + prefix + template + index).find('#' + prefix + 'SoftCreditsEdit' + index).removeClass('hidden');
            }
        }
    },

    // Called when the save btn is pressed on the edit fields on a template to update the display only labels
    // btn - button calling function - correct data attributes have been assigned in add template
    // template - type of template e.g. soft credit 
    Template_UpdateDisplayFields: function (btn, template) {
        var index = $(btn).data('fieldindex');
        var prefix = $(btn).data('prefix');


        $('#' + prefix + template + index).find('#SoftCreditsEdit').find('input').each(function () {
            var ctrlId = this.id + 'Label';
            ctrlId = ctrlId.replace('.', '').replace('[', '').replace(']', '');
            var label = $('#' + ctrlId);
            label.text(this.value);
        });
        if (prefix !== '00000000000000000000000000000000') {
            $('#' + prefix + template + index).find('#' + prefix + 'SoftCreditsEdit' + index).find('input').each(function () {
                var ctrlId = this.id + 'Label';
                ctrlId = ctrlId.replace('.', '').replace('[', '').replace(']', '');
                var label = $('#' + ctrlId);
                label.text(this.value);
            });
        }

        Donorfy.Template_ToggleDisplayEdit(null, template, prefix, index);
    },

    // Called to toggle a details section of a template in reponse to a show / hide link  - see _Allocation 
    // index - index number of template
    // template - type of template e.g. soft credit
    Template_ShowTemplateDetails: function (prefix, template, index) {
        if ($('#' + prefix + template + 'Details' + index).hasClass('hidden') == true) {
            $('#' + prefix + template + 'Details' + index).removeClass('hidden');

        } else {
            $('#' + prefix + template + 'Details' + index).addClass('hidden');
        }
        Donorfy.UI_ShowHide(prefix + template + 'ShowDetails' + index);
        Donorfy.UI_ShowHide(prefix + template + 'HideDetails' + index);
    },

    ////////////////////////////////////////////////////////////////////////
    // Timeline Related
    ////////////////////////////////////////////////////////////////////////

    // Called when the description of a time line entry is clicked on - if entry is being displayed it hides it
    // otherwise it retrieves the details of entry and displays them
    TimeLine_DisplayDetails: function (id, paramValue1, paramValue2, paramValue3) {
        var targetDiv = $("#Target" + id);
        if (targetDiv.is(':visible')) {
            targetDiv.hide();
        } else {
            targetDiv.removeClass('hidden');
            targetDiv.show();
            targetDiv.html('<img src="/images/Spinner1.gif"/>');
            var controller = $("#Controller" + id).val();
            var action = $("#Action" + id).val();
            var targetUrl = '/' + controller + '/' + action;
            targetUrl = targetUrl + '?id=' + id;
            targetUrl = targetUrl + "&param1=" + paramValue1;
            targetUrl = targetUrl + "&param2=" + paramValue2;
            targetUrl = targetUrl + "&param3=" + paramValue3;
            $.ajax({
                url: targetUrl,
                type: 'get',
                cache: false,
                datatype: "html",
                success: function (data) {
                    targetDiv.removeClass('hidden');
                    targetDiv.show();
                    targetDiv.html(data);
                    nav_page_height();
                },
                error: Donorfy.ShowStandardAjaxErrorAlert
            });
        }
    },

    // Display form which allows user to select entries from the line for the constituent passed in
    // consId - constituentId whose timelien we should browse
    // parentId - if of allocation that will own the link, needed to handle the call back generated template
    TimeLineBrowser: function (consId, parentId) {
        Donorfy.UI_DisplayPopUp('Constituent',
            'GetTimeLineDetails',
            'id',
            consId,
            'param1',
            'TimelineBrowse',
            'param2',
            parentId,
            '',
            '');
    },

    // Called from add menu on timeline tabe to allow addition of new time line entry  
    TimeLine_Add: function (controller,
        action,
        idParam,
        idValue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3) {
        var addContainer = $('#timeline_add');
        addContainer.removeClass('hidden');
        var urlString = idParam + "=" + idValue;
        if (paramName1 != "") {
            urlString = urlString + "&" + paramName1 + "=" + paramValue1;
        }
        if (paramName2 != "") {
            urlString = urlString + "&" + paramName2 + "=" + paramValue2;
        }
        if (paramName3 != "") {
            urlString = urlString + "&" + paramName3 + "=" + paramValue3;
        }
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (popUpForm) {
                addContainer.show();
                addContainer.html(popUpForm);
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });
    },

    // Gets time line for id passed - optionally filter based on the values passed in
    // dateFilter - type of date filter - see UIHelper Literals for options 
    // fromDate & toDate - if date filter is a date range 
    // filterstr - string of timeline types to restrict display to
    // callBackFunction - optional function to call when time line entry clicked
    // displayType - Summary means return timeline summary, otherwise type of detail to show e.g. transactions
    TimeLine_Display: function (controller,
        id,
        target,
        dateFilter,
        fromDate,
        toDate,
        filterstr,
        callBackFunction,
        displayType,
        refreshTarget) {

        var targetDiv = $('#' + target);
        targetDiv.show();

        if ((displayType === 'Summary') || (displayType === undefined)) {
            $('#timeline_filter').removeClass('hidden');
            $('#timelinefieldfilter').html('');
        } else {
            if (displayType != 'MailChimpSummary') {
                $('#timeline_filter').addClass('hidden');
            }
        }
        //   $('#timelinefieldfilter').html('');
        $('#TimeUpdating').removeClass('hidden');

        var action = 'GetTimeLine';
        var targetUrl = '/' +
            controller +
            '/' +
            action +
            '?id=' +
            id +
            "&dateFilter=" +
            dateFilter +
            "&fromDate=" +
            fromDate +
            "&toDate=" +
            toDate +
            "&filterstr=" +
            filterstr +
            "&callBack=" +
            callBackFunction +
            "&displayType=" +
            displayType +
            "&refreshTarget=" +
            refreshTarget;
        $.ajax({
            url: targetUrl,
            type: 'get',
            cache: false,
            datatype: "html",
            success: function (data) {
                targetDiv.show();
                $('#TimeUpdating').addClass('hidden');
                if (dateFilter === "DateInitialLoad2") {
                    targetDiv.append(data);
                } else if (displayType === "MailChimpSummary") {
                    // merge in MC items to existing TL
                    Donorfy.TimeLine_MergeTimeLines(data);
                } else {
                    targetDiv.html(data);
                    // filtering summary TL by date - i.e. its not the initial TL load - see if we have any MC to display for this date range
                    if (controller === "Constituent" && dateFilter !== "DateInitialLoad1" && (displayType === undefined || displayType === "Summary")) {
                        Donorfy.TimeLine_Display(controller,
                            id,
                            target,
                            dateFilter,
                            fromDate,
                            toDate,
                            filterstr,
                            callBackFunction,
                            "MailChimpSummary",
                            refreshTarget);
                    }
                }
                nav_page_height();
                if (dateFilter === "DateInitialLoad1") {
                    Donorfy.TimeLine_Display(controller,
                        id,
                        target,
                        "DateInitialLoad2",
                        fromDate,
                        toDate,
                        filterstr,
                        callBackFunction,
                        displayType,
                        refreshTarget);
                }
                if (controller === "Constituent" && dateFilter === "DateInitialLoad2") {
                    // having done initial load of the 2nd half of the summary TL now get any MC 
                    Donorfy.TimeLine_Display(controller,
                        id,
                        target,
                        "MailChimpSummary",
                        fromDate,
                        toDate,
                        filterstr,
                        callBackFunction,
                        "MailChimpSummary",
                        refreshTarget);
                }
            },
            error: function (jqXhr) {
                targetDiv.text(Donorfy.GetStandardAjaxErrorMessage(jqXhr));
            }
        });

    },

    // Merges the timeline items passed in to the existing TL summary - inserting the items into
    // the correct place based on date
    TimeLine_MergeTimeLines: function (itemsToMerge) {
        try {
            $('body').append(itemsToMerge);

            if ($('#mergeItems ul li').length < 1) {
                $('#mergeItems').remove();
                return;
            }

            if ($('#TimeLineMain ul li').length < 1) {
                $('#mergeItems ul:first li').each(function (idx, li) {
                    $('#TimeLineMain ul:first').append(li);
                });
                $('#mergeItems').remove();
                return;
            }

            $('#mergeItems ul:first li').each(function (idx, li) {
                var appendAfter = null;
                var firstMainItem = null;
                var tlDate = $(li).data("tldate");
                $('#TimeLineMain ul:first li').each(function (idx, mainLi) {
                    if (firstMainItem === null) {
                        firstMainItem = $(mainLi);
                    }
                    var maintlDate = $(mainLi).data("tldate");
                    if (maintlDate > tlDate) {
                        appendAfter = $(mainLi);
                    }
                });

                if (appendAfter === null) {
                    $(li).insertBefore($(firstMainItem)).fadeIn("fast");
                } else {
                    $(li).insertAfter($(appendAfter)).fadeIn("fast");
                }
            });
            $('#mergeItems').remove();
        }
        catch (e) {
            console.log('Exception in TimeLine_MergeTimeLines ' + e);
        }
    },

    // Gets the basic details of a time line entry 
    // id of time line entry
    // type - type of entry 
    // dateInput - id of input field to store time line date 
    // typeInput - id of input field to store time line type
    // constituentIdInput - id of input field to store related constituent 
    // 
    TimeLine_GetDetails: function (id, type, dateInput, typeInput, constituentIdInput, constituentLink) {
        var dte = $('#' + dateInput);
        var tlType = $('#' + typeInput);
        var consId = $('#' + constituentIdInput);
        var consLink = $('#' + constituentLink);
        $.ajax({
            url: "/Constituent/TimeLineGetDetails?id=" + id + "&timeLineType=" + type,
            type: 'post',
            success: function (data) {
                if (data.ErrorMessage != "") {
                    target.html(data.ErrorMessage);
                }
                if (data.IsSuccess) {
                    dte.text(data.ReloadParam1Value);
                    tlType.text(data.ReloadParam2Value);
                    consId.val(data.ReloadParam3Value);
                    consLink.attr('href',
                        '/Constituent/Index?Id=' + data.ReloadParam3Value + '&EntityType=Constituent');
                    consLink.html(data.ReloadParam3Name);
                }
            },
            error: function (jqXhr) {
                target.html(Donorfy.ShowStandardAjaxErrorAlert(jqXhr));
            }
        });

    },

    ////////////////////////////////////////////////////////////////////////
    // Recurring Transaction Form Related 
    ////////////////////////////////////////////////////////////////////////
    // RecurringTransaction Form - swicthes the form between basic and advanced mode - and saves the setting to the config
    RecurringTransaction_Toggle: function (id, formContainerId) {
        Donorfy.UI_ShowHide('ShowFormDetails' + id);
        Donorfy.UI_ShowHide('HideFormDetails' + id);
        Donorfy.UI_ShowHide('BasicRow' + id);
        Donorfy.UI_ShowHide('DetailsRow' + id);
        Donorfy.UI_ShowHide('CommentsRow' + id);
        Donorfy.UI_ShowHide('AcknowledgementRow' + id);
        Donorfy.UI_ShowHide('AckText' + id);

        if ($('#AckDate' + id).length) {
            Donorfy.UI_ShowHide('AckDate' + id);
        }

        Donorfy.UI_ShowHide('InstructionsRow' + id);
        Donorfy.UI_ShowHide('AllocationsRow' + id);

        var simpleForm = 'false';
        var formMode = 'Advanced';
        if ($('#BasicRow' + id).is(':visible')) {
            simpleForm = 'true';
            formMode = 'Basic';
        }
        Donorfy.AJAX_SaveConfigSetting('Home', 'SaveConfigSetting', 'UISettings.UseSimpleRPIForm', simpleForm);
        $('#' + formContainerId + ' #DisplayMode').val(formMode);
    },

    RecurringTransaction_ToggleDetails: function (id) {
        if ($('#RecurringTransaction_More' + id).hasClass('hidden') == true) {
            $('#RecurringTransaction_More' + id).removeClass('hidden');
        } else {
            $('#RecurringTransaction_More' + id).addClass('hidden');
        }
        Donorfy.UI_ShowHide('ShowRecurringTransactionDetails' + id);
        Donorfy.UI_ShowHide('HideRecurringTransactionDetails' + id);
    },

    // Called from recurring instruction form to allow selection of new invoice to
    RecurringTransaction_ChangeInvoiceTo: function (formId) {
        // display finder
        window.FindConstituent('id', 'Donorfy.RecurringTransaction_ChangeInvoiceToCallBack', formId);
    },

    // Called from recurring instruction form to change status
    // formId - form containing the 
    RecurringTransaction_UpdateStatus: function (formId) {
        // display finder
        window.FindConstituent('id', 'Donorfy.RecurringTransaction_ChangeInvoiceToCallBack', formId);
    },

    // Callback function for constituent finder when changing invoice to
    RecurringTransaction_ChangeInvoiceToCallBack: function (id) {
        // assign constituent description to link 
        var parentForm = $('#Find-Constituent-ParentForm-Id').val();
        Donorfy.AJAX_GetEntityDetails(id,
            'Constituent',
            '',
            'GetDetails',
            parentForm + ' #RecurringInstructionInvoiceToDisplay',
            'val');
        //    $('#RecurringInstructionInvoiceToDisplay').val($('#RecurringInstructionInvoiceTo').text());
        $('#' + parentForm + ' #FK_ConstituentInvoiceToId').val(id);
        // $('#' + parentForm).find('#FK_ConstituentInvoiceToId').val(id);
        $('#Find-Constituent').modal('hide');
    },


    ////////////////////////////////////////////////////////////////////////
    // Transaction Form Related 
    ////////////////////////////////////////////////////////////////////////

    // Called from soft credit percentage forms to update the associated amounts
    // softCreditPercentField - reference to soft credit field
    Transaction_SoftCreditUpdateFromPercentage: function (softCreditPercentField) {
        // id of % age field e.g. SoftCreditPercentage0 
        var amtField = softCreditPercentField.id.replace('PercentageStr', 'Amount');
        var prefix = $(softCreditPercentField).data('prefix');
        //var paymentAmt = $('#CreditAmount' + prefix).val();

        var paymentAmt = 0;
        $('.soft-credit-amount').each(function () {
            var v = $(this).autoNumeric('get');
            paymentAmt += (isNaN(v) ? 0 : v);
        });

        if (!$('#' + amtField).hasClass('changed')) {
            var percentage = $(softCreditPercentField).val().replace('%', '');
            var percentAmt = parseFloat(paymentAmt * (percentage / 100)).toFixed(2);
            $('#' + amtField).val(percentAmt);
        }
    },

    // Callback function for constituent finder when adding a soft credit
    Transaction_AddSoftCreditCallBack: function (id) {
        var parentTransactionId = $('#Find-Constituent-UpdateId').val();
        // get ID that will be allocated to new template
        var nxtId = $('#' + parentTransactionId + 'SoftCreditsTemplateId').val();
        Donorfy.Template_AddTemplate('SoftCredits', 'SoftCreditContainer' + parentTransactionId, parentTransactionId);
        // assign constituent description to link 
        Donorfy.AJAX_GetEntityDetails(id, 'Constituent', '', 'GetDetails', 'softCreditLink' + nxtId, 'html');
        var ctrl = $('#SoftCreditsFK_ConstituentId' + nxtId);
        ctrl.val(id);
        ctrl = $('#softCreditLink' + nxtId);
        ctrl.attr('href', '/Constituent/Index?Id=' + id + '&EntityType=Constituent"');
        Donorfy.Template_ToggleDisplayEdit(null, 'SoftCredits', parentTransactionId, nxtId);
        $('#Find-Constituent').modal('hide');
    },

    // Called from Transaciton form to display the constituent finder when adding a soft credit
    Transaction_AddSoftCredit: function (transactionId, connectionConsId) {
        // display finder
        window.FindConstituent(transactionId, 'Donorfy.Transaction_AddSoftCreditCallBack', null, connectionConsId);
    },

    // Transaction Form - swicthes the form between basic and advanced mode - and saves the setting to the config
    Transaction_swapForms: function (id, formContainerId) {

        Donorfy.UI_ShowHide('ShowFormDetails' + id);
        Donorfy.UI_ShowHide('HideFormDetails' + id);
        Donorfy.UI_ShowHide('Transaction_SimpleForm' + id);
        Donorfy.UI_ShowHide('Payment_Basic' + id);
        Donorfy.UI_ShowHide('Allocation_Basic' + id);
        var simpleForm = 'false';
        var formMode = 'Advanced';
        if ($('#Transaction_SimpleForm' + id).is(':visible')) {
            simpleForm = 'true';
            formMode = 'Basic';
        }

        if (simpleForm == 'true' && $('#Payment_More' + id).hasClass('hidden') == false) {
            $('#Payment_More' + id).addClass('hidden');
        }

        Donorfy.AJAX_SaveConfigSetting('Home', 'SaveConfigSetting', 'UISettings.UseSimpleTransactionForm', simpleForm);
        $('#' + formContainerId + ' #DisplayMode').val(formMode);
    },

    // Transaction form - toggles the display of the payment details section of the form
    Transaction_showPaymentDetails: function (id) {
        if ($('#Payment_More' + id).hasClass('hidden') == true) {
            $('#Payment_More' + id).removeClass('hidden');
        } else {
            $('#Payment_More' + id).addClass('hidden');
        }
        Donorfy.UI_ShowHide('Transaction_showPaymentDetails' + id);
        Donorfy.UI_ShowHide('HidePaymentDetails' + id);
    },

    // Callback function used by Allocations to link to timeline entries
    // its is used in TimeLine browse - when an item is selected from the 
    // timeline browse this function is called to create the link 
    // id - id of item selected from browser
    // type - type of entity selected from browser
    // parentId - id of rpi of allocation that owns the link
    TransactionAllocation_AddLinkCallBack: function (id, type, parentId) {
        // get number that will be allocated to new template
        var nxtId = $('#LinksTemplateId').val();
        // add new template to form
        Donorfy.Template_AddTemplate('Links', 'TransactionAllocationLinksContainer', parentId);
        // get description of time line entry selected
        Donorfy.TimeLine_GetDetails(id,
            type,
            'TimeLineDate' + nxtId,
            'TimeLineDescription' + nxtId,
            'timeFK_ConstituentId' + nxtId,
            'timeLineLink' + nxtId);
        //  Put into edit mode 
        Donorfy.Template_ToggleDisplayEdit(nxtId, 'Links');
        Donorfy.AJAX_HandleResponse_ClosePopUp();
    },
    ////////////////////////////////////////////////////////////////////////
    // Membership Related 
    ////////////////////////////////////////////////////////////////////////
    // Callback function for constituent finder when adding a new membership
    Membership_AddMembershipCallBack: function (id) {
        var membershipFieldId = $('#Find-Constituent-UpdateId').val();
        var localId = $('#Find-Constituent-ParentForm-Id').val();

        var ctrl = $('#' + membershipFieldId);
        ctrl.val(id);

        $('#Find-Constituent').modal('hide');
        var membershipAddFormDiv = "TargetmembershipsAddFormDiv" + localId;
        var membershipAddFormPleaseWaitDiv = "TargetmembershipsAddPleaseWaitForm" + localId;
        var parameters = "id=" + id + "&param1=MembershipAdd&param2=" + id + "&param3=Add&pushDown=true";
        Donorfy.AJAX_GetHTMLContentForTarget('Constituent', 'GetTimeLineDetails', parameters, $('#' + membershipAddFormDiv), $('#' + membershipAddFormPleaseWaitDiv));
    },

    // Called from add membership button to display the constituent finder when adding a membership
    Membership_AddMembership: function (membershipId, localId) {
        // display finder
        window.FindConstituent(membershipId, 'Donorfy.Membership_AddMembershipCallBack', localId, null);
    },
    ////////////////////////////////////////////////////////////////////////
    // Link Constituent Related 
    ////////////////////////////////////////////////////////////////////////

    // Callback function for constituent finder when linking constituent to another entity e.g. transaction
    LinkConstituent_LinkConstituentCallBack: function (id) {
        var parentFormId = $('#Find-Constituent-ParentForm-Id').val();

        //// get ID that will be allocated to new template
        //var nxtId = $('#' + parentTransactionId + 'SoftCreditsTemplateId').val();
        //Donorfy.Template_AddTemplate('SoftCredits', 'SoftCreditContainer' + parentTransactionId, parentTransactionId);

        // Field used to display constituent details 
        $('#' + parentFormId).find('#FK_LinkedConstituentId').val(id);
        var consDescControl = 'linkedConstituentDescription' + parentFormId;
        // assign constituent description to link 
        Donorfy.AJAX_GetEntityDetails(id,
            'Constituent',
            '',
            'GetDetails',
            consDescControl,
            'html',
            function () {
                //if added then don't make a link until it's saved
                var ctrl = $('#' + consDescControl);
                var replaceClass = ctrl.attr('class');
                var replaceId = ctrl.attr('id');
                var replaceStyle = ctrl.attr('style');
                var replaceText = ctrl.text();
                ctrl.replaceWith('<span class="' +
                    replaceClass +
                    '" id="' +
                    replaceId +
                    '" style="' +
                    replaceStyle +
                    '">' +
                    replaceText +
                    '</span>');
            });

        $('#' + parentFormId).find('#showLinkedConstituentContainer').removeClass('hidden');
        $('#' + parentFormId).find('#hideLinkedConstituentContainer').addClass('hidden');

        $('#Find-Constituent').modal('hide');
    },

    // Called from data entry forms - e.g. Transaction Entry - to display the constituent finder when adding a link - e.g. to a beneficary
    // entityId - e.g. transactionId 
    // parentFormId - e.g. form Id  
    // connectionConsId  - the constituent id to display connection shortcuts for
    LinkConstituent_AddLink: function (entityId, parentFormId, connectionConsId) {
        // display finder
        window.FindConstituent(entityId,
            'Donorfy.LinkConstituent_LinkConstituentCallBack',
            parentFormId,
            connectionConsId);
    },

    // Called from data entry forms - e.g. Transaction Entry - to clear constituent link - e.g. to a beneficary
    // parentFormId - e.g. form Id
    LinkConstituent_ClearLink: function (parentFormId) {
        var consDescControl = 'linkedConstituentDescription' + parentFormId;
        $('#' + consDescControl).html('');
        $('#' + parentFormId).find('#FK_LinkedConstituentId').val('');
        $('#' + parentFormId).find('#showLinkedConstituentContainer').addClass('hidden');
        $('#' + parentFormId).find('#hideLinkedConstituentContainer').removeClass('hidden');
    },
    ////////////////////////////////////////////////////////////////////////
    // Beneficiary Constituent Related 
    ////////////////////////////////////////////////////////////////////////

    // Callback function for constituent finder when linking constituent to another entity e.g. transaction
    LinkBeneficiaryConstituent_LinkConstituentCallBack: function (id) {
        var parentFormId = $('#Find-Constituent-ParentForm-Id').val();

        //// get ID that will be allocated to new template
        //var nxtId = $('#' + parentTransactionId + 'SoftCreditsTemplateId').val();
        //Donorfy.Template_AddTemplate('SoftCredits', 'SoftCreditContainer' + parentTransactionId, parentTransactionId);

        // Field used to display constituent details 
        $('#' + parentFormId).find('#FK_BeneficiaryConstituentId').val(id);
        var consDescControl = 'BeneficiaryConstituentDescription' + parentFormId;
        // assign constituent description to link 
        Donorfy.AJAX_GetEntityDetails(id,
            'Constituent',
            '',
            'GetDetails',
            consDescControl,
            'html',
            function () {
                //if added then don't make a link until it's saved
                var ctrl = $('#' + consDescControl);
                var replaceClass = ctrl.attr('class');
                var replaceId = ctrl.attr('id');
                var replaceStyle = ctrl.attr('style');
                var replaceText = ctrl.text();
                ctrl.replaceWith('<span class="' +
                    replaceClass +
                    '" id="' +
                    replaceId +
                    '" style="' +
                    replaceStyle +
                    '">' +
                    replaceText +
                    '</span>');
            });
        $('#' + parentFormId).find('#showBeneficiaryConstituentContainer').removeClass('hidden');
        $('#' + parentFormId).find('#hideBeneficiaryConstituentContainer').addClass('hidden');

        $('#Find-Constituent').modal('hide');
    },

    // Called from data entry forms - e.g. Transaction Entry - to display the constituent finder when adding a link - e.g. to a beneficary
    // entityId - e.g. transactionId 
    // parentFormId - e.g. form Id  
    // connectionConsId - the id of the consituent to use for finder's connection shortcuts
    LinkBeneficiaryConstituent_AddLink: function (entityId, parentFormId, connectionConsId) {
        // display finder
        window.FindConstituent(entityId,
            'Donorfy.LinkBeneficiaryConstituent_LinkConstituentCallBack',
            parentFormId,
            connectionConsId);
    },

    // Called from data entry forms - e.g. Transaction Entry - to clear constituent link - e.g. to a beneficary
    // parentFormId - e.g. form Id
    LinkBeneficiaryConstituent_ClearLink: function (parentFormId) {
        var consDescControl = 'BeneficiaryConstituentDescription' + parentFormId;
        $('#' + consDescControl).html('');
        $('#' + parentFormId).find('#FK_BeneficiaryConstituentId').val('');
        $('#' + parentFormId).find('#showBeneficiaryConstituentContainer').addClass('hidden');
        $('#' + parentFormId).find('#hideBeneficiaryConstituentContainer').removeClass('hidden');
    },
    ////////////////////////////////////////////////////////////////////////
    // Search Related 
    ////////////////////////////////////////////////////////////////////////

    // Toogle the display of the facet list associated with the search result list
    Search_toggleFacets: function (searchResultsList, facetList) {
        Donorfy.UI_ShowHide(facetList);
        $('#' + searchResultsList).removeClass('col-md-9');
        $('#' + searchResultsList).addClass('col-md-12');
        if ($('#' + facetList).is(":visible")) {
            $('#' + searchResultsList).removeClass('col-md-12');
            $('#' + searchResultsList).addClass('col-md-9');
        }
    },

    // Refresh a search based on values selected in filters
    Search_RefreshSearchFromFilters: function (gridId, searchType, filterContainerId) {

        $("#ApplyFilter" + gridId).button("loading");
        var sortOrder = $('#SortOrderFld' + gridId).val();
        var entityId = $('#User1' + gridId).val();
        var gridLayout = $('#GridLayout' + gridId).val();
        var currentUserOnly = $('#CurrentUserOnly' + gridId).val();
        if (currentUserOnly == 'undefined') {
            currentUserOnly = 'false';
        }

        var selectedFilterValues = Donorfy.Search_GetSelectedFilters(filterContainerId);
        if (selectedFilterValues !== null) {
            try {
                selectedFilterValues = String(selectedFilterValues).replace("&", "%26");
            } catch (e) {
                //
            }
        }

        $.ajax({
            url: "/Search/RefreshSearchFromFilters?" +
                "entityType=" +
                searchType +
                "&entityId=" +
                entityId +
                "&selectedFilterValues=" +
                selectedFilterValues +
                "&gridLayout=" +
                gridLayout +
                "&gridId=" +
                gridId +
                "&sortOrder=" +
                sortOrder +
                "&currentUserOnly=" +
                currentUserOnly,
            type: "GET",
            cache: false,
            datatype: "html",
            success: function (data) {
                $("#ApplyFilter" + gridId).button("reset");
                $('#searchResultsList' + gridId).html(data);

            },
            error: function () {
                $("#ApplyFilter" + gridId).button("reset");
            }
        });
    },

    // Clear filters from search  
    Search_ClearFilters: function (gridId, searchType) {

        $("#ClearFilter" + gridId).button("loading");
        var sortOrder = $('#SortOrderFld' + gridId).val();
        var entityId = $('#User1' + gridId).val();
        var gridLayout = $('#GridLayout' + gridId).val();
        var currentUserOnly = $('#CurrentUserOnly' + gridId).val();
        if (currentUserOnly == 'undefined') {
            currentUserOnly = 'false';
        }

        var selectedFilterValues = '';

        $.ajax({
            url: "/Search/RefreshSearchFromFilters?" +
                "entityType=" +
                searchType +
                "&entityId=" +
                entityId +
                "&selectedFilterValues=" +
                selectedFilterValues +
                "&gridLayout=" +
                gridLayout +
                "&gridId=" +
                gridId +
                "&sortOrder=" +
                sortOrder +
                "&currentUserOnly=" +
                currentUserOnly,
            type: "GET",
            cache: false,
            datatype: "html",
            success: function (data) {
                $("#ClearFilter" + gridId).button("reset");
                $('#searchResultsList' + gridId).html(data);

            },
            error: function () {
                $("#ClearFilter" + gridId).button("reset");
            }
        });
    },

    Search_GetSelectedFilters: function (filterContainerId) {

        var selectedFilterValues = $('#' + filterContainerId + ' select option:selected').map(function () {
            return this.value;
        }).get();

        return selectedFilterValues;
    },

    //Update search based on selected facets
    Search_RefreshSearchFromFacets: function (gridId) {

        $("#SearchBtn" + gridId).button("loading");
        var sortOrder = $('#SortOrderFld' + gridId).val();

        var gridLayout = $('#GridLayout' + gridId).val();
        var selectedSubEntities = $('#SelectSearchSubEntity' + gridId).val();
        var entityType = $('#SelectSearchEntity' + gridId).val();

        var searchFor = $("#SearchFld" + gridId).val();

        var currentUserOnly = $('#CurrentUserOnly' + gridId).val();
        if (currentUserOnly == 'undefined') {
            currentUserOnly = 'false';
        }

        var selectedFacetValues = Donorfy.GetSelectedFacets(gridId);
        var safeFacetVals = encodeURIComponent(Donorfy.GetFilterForQueryString(selectedFacetValues));

        $.ajax({
            url: "/Search/RefreshSearch?searchFor=" + searchFor +
                "&entityType=" + entityType + "&selectedEntityTypes=" + selectedSubEntities +
                "&currentUserOnly=" + currentUserOnly +
                "&selectedFacetValues=" + safeFacetVals.toString() +
                "&dateValues=&numericValues=&gridLayout=" + gridLayout + "&gridId=" + gridId + "&sortOrder=" + sortOrder,
            type: "GET",
            cache: false,
            datatype: "html",
            success: function (data) {
                $("#SearchBtn" + gridId).button("reset");
                $('#searchResultsList' + gridId).html(data);

            },
            error: function () {
                $("#SearchBtn" + gridId).button("reset");
            }
        });

    },
    Search_GetFacetStateValues: function (searchType) {
        if (!searchType) {
            return [];
        }

        var facetStateVals = [];
        var facetState = Donorfy.Search_GetFacetState();

        //set-up any defaults by search type
        if (searchType === "Prospect") {
            facetStateVals = ["EntityStatus:Active"];
        }
        if (searchType === "Document") {
            facetStateVals = ["DocumentDownloaded:No", "DocumentType:Merged Document"];
        }

        //find facet state by search type if specified
        $.each(facetState, function (typeIndex, typeItem) {
            if (typeItem.type === searchType.replace(" ", "")) {
                facetStateVals = typeItem.values;
                return false;
            }
            return true;
        });

        return facetStateVals;

    },
    Search_GetFacetState: function () {
        var facetState = window.localStorage.getItem('SearchFacetsState');
        if (!facetState) {
            facetState = {};
        } else {
            facetState = JSON.parse(facetState);
        }

        return facetState;
    },
    Search_SaveFacetState: function (searchType, gridId) {
        var facetState = Donorfy.Search_GetFacetState();
        var selectedFacets = { type: searchType.replace(" ", ""), values: Donorfy.GetSelectedFacets(gridId) };
        facetState[searchType] = selectedFacets;
        window.localStorage.setItem('SearchFacetsState', JSON.stringify(facetState));
    },
    Search_LoadFacetByDependency: function (searchType, field, dependencyField, dependencyValue, facetIsSelect) {

        $.ajax({
            url: "/Search/GetFacetByDependency?searchType=" + searchType +
                "&field=" + field + "&dependencyField=" + dependencyField +
                "&dependencyValue=" + dependencyValue.toString(),
            type: "GET",
            cache: false,
            datatype: "json",
            success: function (response) {

                if (response.IsSuccess) {

                    if (facetIsSelect) {

                        var selectItem = $("." + field + + "-select-valueslist select.facet-select");
                        selectItem.select2("destroy");
                        selectItem.empty();
                        $.each(response.Data.ItemList,
                            function (i, item) {
                                var itemOption = $("<option>", { value: item.Value }).text(item.Text);
                                itemOption.appendTo(selectItem);
                            });
                        selectItem.select2();

                    } else {

                        var valuesList = $("." + field + "-select-valueslist");
                        valuesList.empty();

                        $.each(response.Data.ItemList,
                            function (i, item) {
                                var checkboxDiv = $("<div>").addClass("facet-checkbox").appendTo(valuesList);
                                $("<input>", { type: "checkbox", id: item.Value }).appendTo(checkboxDiv);
                                checkboxDiv.append("&nbsp;");
                                $("<label>").text(item.Text).appendTo(checkboxDiv);
                            });
                    }
                }

            }
        });

    },
    Search_RefreshFacets: function (entity, entitySubType, gridId, refreshGrid) {

        var selectedFacetValues = Donorfy.Search_GetFacetStateValues(entity);
        var safeFacetVals = encodeURIComponent(Donorfy.GetFilterForQueryString(selectedFacetValues));


        var parameters = "entity=" + entity +
            "&entitySubType=" +
            entitySubType +
            "&gridId=" +
            gridId +
            "&facetFilters=" +
            safeFacetVals.toString();

        Donorfy.AJAX_GetHTMLContentForTarget("Search", "GetFacets", parameters, $("#facetList").parent(), null,
            function () {
                $("#FieldList" + gridId + " select.facet-select").select2();

                Donorfy.Search_GetInitialFacetState(entity, gridId);
                //re-save facet state in case facet value no longer exists
                //after facets refreshed to keep controls in synch with state
                Donorfy.Search_SaveFacetState(entity, gridId);

                $(document).trigger("facets-refreshed");

                if (refreshGrid) {

                    //We may need to refresh the grid after the facets have been reloaded
                    //because certain filter values may no longer be valid options
                    $(document).trigger("facet-selection-changed", [gridId]);
                }
            });

    },
    Search_GetInitialFacetState: function (searchType, gridId) {

        var facetStateVals = Donorfy.Search_GetFacetStateValues(searchType);
        $.each(facetStateVals,
            function (valIndex, valItem) {
                if (valItem) {
                    try {


                        var itemIsArray = $.isArray(valItem);
                        var facetFieldName = (itemIsArray ? valItem[0].substring(0, valItem[0].indexOf(":")) : valItem.substring(0, valItem.indexOf(":")));
                        var selectorDivCtrl = $("#FieldList" + gridId + " ." + facetFieldName + "-select-valueslist");

                        var textInput = selectorDivCtrl.find(".facet-value input[name='" + facetFieldName + "']");

                        if (textInput.length > 0) {

                            var facetFieldValue = valItem.substring(valItem.indexOf(":") + 1, valItem.length);
                            textInput.val(facetFieldValue);
                        } else {
                            //stops the refresh search event firing whilst we set initial facet options from state
                            selectorDivCtrl.find("select.facet-select").removeClass("facet-select").addClass("temp-select-changes");

                            if (itemIsArray) {

                                selectorDivCtrl.find("select.temp-select-changes").val(valItem).trigger("change");

                            } else {

                                //escape the colon and any spaces for jquery
                                var selectorVal = valItem.replace(/[!"#$ %&'()*+,.\/:;<=>?@[\\\]^`{|}~]/g, "\\$&");
                                var selectorCtrl = $("#" + selectorVal);

                                if (selectorCtrl.length > 0) {
                                    //assume checkbox if can find a control with value
                                    selectorCtrl.prop("checked", true);
                                } else {

                                    //otherwise assume single select dropdown
                                    var singleSelect = selectorDivCtrl.find("select.temp-select-changes");

                                    singleSelect.val(valItem).trigger("change");
                                    var visibleAllowClear = (valItem.length > 0);
                                    singleSelect.closest("div").find(".select2-container .select2-choice abbr").toggle(visibleAllowClear);
                                }

                            }

                            selectorDivCtrl.find("select.temp-select-changes").addClass("facet-select").removeClass("temp-select-changes");
                        }
                    } catch (e) {
                        console.log('Search_GetInitialFacetState:' + e);
                    }
                }

            });

        return Donorfy.GetFilterForQueryString(facetStateVals).toString();
    },
    GetFilterForQueryString: function (filterVals) {

        if (filterVals == null) {
            return null;
        }

        var safeFilter = filterVals.map(function (val) {

            if ($.isArray(val)) {
                return val.map(function (v2) { return v2.replace(",", "") });
            } else {
                return val.replace(",", "");
            }
        });

        return safeFilter;
    },

    // Performs search 
    // gridId - id of grid where search results should be returned
    // selectedEntity - e.g. constituent - if search is to be restricted to an entity type
    // inProgressFlagId - id of field in calling form which can contain a flag to indicate that a search is still in progress - e.g. on Constituent Adder form, 
    //  can be checked in calling form to prevent search being called many times before result has been returned
    Search_GetResults: function (gridId, selectedEntity) {
        // $('#' + gridName).dataTable().fnDestroy();
        $("#SearchBtn" + gridId).button("loading");
        $('#SearchInProgressFlag' + gridId).val('yes');

        if ($("#SearchFld" + gridId).val().startsWith("#")) {
            Donorfy.AJAX_HandleResponse_RedirectToURL("/Search/All?param=" +
                encodeURIComponent($("#SearchFld" + gridId).val()));
            return;
        }


        var searchFor = encodeURIComponent($("#SearchFld" + gridId).val());
        var sortOrder = $('#SortOrderFld' + gridId).val();
        var gridLayout = $('#GridLayout' + gridId).val();
        var callBack = $('#SelectCallBackFunction' + gridId).val();
        if (callBack == 'undefined') {
            callBack = '';
        }
        var hideFacets = $('#HideFacets' + gridId).val();
        if (hideFacets == 'undefined') {
            hideFacets = 'false';
        }
        var currentUserOnly = $('#CurrentUserOnly' + gridId).val();
        if (currentUserOnly == 'undefined') {
            currentUserOnly = 'false';
        }
        var showPaging = $('#ShowPaging' + gridId).val();
        if (showPaging == 'undefined') {
            showPaging = 'true';
        }
        var showRowsPerPage = $('#ShowRowsPerPage' + gridId).val();
        if (showRowsPerPage == 'undefined') {
            showRowsPerPage = 'true';
        }
        var entityType = $('#SelectSearchEntity' + gridId).val();
        var selectedSubEntities = '';

        var targetUrl = "/Search/Search?searchFor=" +
            searchFor +
            "&entityType=" +
            entityType +
            "&selectedEntityTypes=" +
            selectedSubEntities +
            "&gridLayout=" +
            gridLayout +
            "&selectCallBack=" +
            callBack +
            "&hideFacets=" +
            hideFacets +
            "&currentUserOnly=" +
            currentUserOnly +
            "&showPaging=" +
            showPaging +
            "&showRowsPerPage=" +
            showRowsPerPage +
            "&gridId=" +
            gridId +
            "&sortOrder=" +
            sortOrder;

        var targetDiv = $("#resultsContainer" + gridId);

        $.ajax({
            url: targetUrl,
            type: 'get',
            cache: false,
            datatype: "html",
            success: function (data) {
                $("#SearchBtn" + gridId).button("reset");
                $('#SearchInProgressFlag' + gridId).val('');
                targetDiv.show();
                targetDiv.html(data);
            },
            error: function (jqXhr, error, errorThrown) {
                $("#SearchBtn" + gridId).button("reset");
                $('#SearchInProgressFlag' + gridId).val('');
                Donorfy.ShowStandardAjaxErrorAlert(jqXhr, error, errorThrown)
                window.errorMessageDiv.text(Donorfy.GetStandardAjaxErrorMessage(jqXhr));
            }
        });
    },


    ////////////////////////////////////////////////////////////////////////
    // Form Functions
    ////////////////////////////////////////////////////////////////////////

    // Updates HTML for widget
    UI_WebwidgetUpdateCode: function (data) {
        $('#HTML' + data.ReloadParam1Value).val(data.Data);
        $('#CopyGenerateWebWidget' + data.ReloadParam1Value).removeClass('hidden');
    },

    UI_PreviewForm: function (previewUrl) {
        window.open(previewUrl, '_blank');
        return false;
    },

    UI_ShowCopyForm: function (id) {
        var copyFormDiv = 'formCopyDiv' + id;
        var formCopyDescription = 'formCopyDescription' + id;
        var formCopyErrMsg = 'formCopyError' + id;
        $('#' + formCopyDescription).val('');
        $('#' + formCopyErrMsg).html('').hide();
        Donorfy.UI_ShowHide(copyFormDiv);
        return false;
    },

    // copy a form and update the UI

    UI_CopyForm: function (id, confirmMsgDiv, confirmMsg) {
        var formCopyDescription = 'formCopyDescription' + id;
        var formCopyErrMsg = 'formCopyError' + id;
        var formCopyBtn = 'FormCopyBtn' + id;
        var copyFormDiv = 'formCopyDiv' + id;
        var newFormDescription = $('#' + formCopyDescription).val();
        if (newFormDescription === '') {
            $('#' + formCopyErrMsg).css('display', 'block').removeClass('hidden')
                .html('A description must be entered for the copied form');
            return false;
        }
        $('#' + confirmMsgDiv).show();
        $('#' + confirmMsg).html('Please Wait..');

        $('#' + formCopyBtn).button('loading');
        $.ajax({
            url: '/Form/FormCopy?id=' + id + '&description=' + encodeURIComponent(newFormDescription),
            type: 'post',
            success: function (data) {
                $('#' + formCopyBtn).button("reset");
                if (data.ErrorMessage !== "") {
                    $('#' + formCopyErrMsg).css('display', 'block').removeClass('hidden').html(data.ErrorMessage);
                }
                if (data.IsSuccess) {
                    $('#' + confirmMsgDiv).html(data.ConfirmMessage);
                    Donorfy.UI_ShowHide(copyFormDiv);
                }
            },
            error: function (jqXhr) {
                $('#' + formCopyErrMsg).css('display', 'block').removeClass('hidden').html(Donorfy.GetStandardAjaxErrorMessage(jqXhr));
                $('#' + formCopyBtn).button("reset");
            }
        });
        return false;
    },

    UI_ValidInputLength: function (input) {
        var maxLength = $(input).attr('maxlength');
        var currentLength = $(input).val().length;
        var warningId = `#${$(input).data('warningInput')}`;

        if (currentLength > maxLength) {
            $(warningId).removeClass('hidden');
        } else {
            $(warningId).addClass('hidden');
        }
    },

    // generate tracking codes for a form

    UI_GenerateFormTrackingCodes: function (id) {
        $('#trackingFormError' + id).html('').hide();
        $('#iframeTrackingCodeExampleDiv' + id).hide();
        $('#buttonTrackingCodeExampleDiv' + id).hide();
        // find values 
        let utmSource = '';
        let utmMedium = '';
        let utmContent = '';
        let utmCampaign = '';
        let trackingUrl = '';
        let hostPageUrl = $('#HostPageUrl' + id).val();

        try {
            utmSource = $('#UtmSourceSelectId' + id).select2('data').text;
            trackingUrl = 'utm_source=' + encodeURIComponent(utmSource);
        } catch (e) {
            //
        }

        try {
            utmMedium = $('#UtmMediumSelectId' + id).select2('data').text;
            trackingUrl += '&utm_medium=' + encodeURIComponent(utmMedium);
        } catch (e) {
            //
        }

        try {
            utmContent = $('#UtmContentSelectId' + id).select2('data').text;
            trackingUrl += '&utm_content=' + encodeURIComponent(utmContent);
        } catch (e) {
            //
        }

        try {
            utmCampaign = $('#CampaignId' + id).select2('data').text;
            trackingUrl += '&utm_campaign=' + encodeURIComponent(utmCampaign);
        } catch (e) {
            //
        }


        let errMsg = '';
        if (utmSource === '') {
            errMsg = errMsg + 'UTM Source';
        }
        if (utmMedium === '') {
            if (errMsg !== '') {
                errMsg = errMsg + ', ';
            }
            errMsg = errMsg + 'UTM Medium';
        }

        if ($('#displayAsStandAloneHiddenFieldId' + id).val().toLowerCase() === 'false' && hostPageUrl === '') {
            if (errMsg !== '') {
                errMsg = errMsg + ', ';
            }
            errMsg = errMsg + 'URL for the page on your website which will host this form';
        }

        if (errMsg !== '') {
            errMsg = errMsg + ' must be entered';
            $('#trackingFormError' + id).css('display', 'block').removeClass('hidden').html(errMsg);
            return false;
        }

        // display the correct UI 

        let btnTrackingCodeExampleTemplate = $('#btnTrackingCodeExampleTemplate' + id).val();
        let iframeTrackingCodeExampleTemplate = $('#iframeTrackingCodeExampleTemplate' + id).val();
        let linkTrackingCodeExampleTemplate = $('#linkTrackingCodeExampleTemplate' + id).val();

        btnTrackingCodeExampleTemplate = btnTrackingCodeExampleTemplate.replace('##TrackingCodes##', trackingUrl);
        iframeTrackingCodeExampleTemplate = iframeTrackingCodeExampleTemplate.replace('##TrackingCodes##', trackingUrl);

        $('#iframeTrackingCodeExample' + id).val(iframeTrackingCodeExampleTemplate);
        $('#buttonTrackingCodeExample' + id).val(btnTrackingCodeExampleTemplate);
        $('#standaloneLinkTrackingCodeExample' + id).val(linkTrackingCodeExampleTemplate + '?' + trackingUrl);

        $('#hostpageTrackingCodeExample' + id).val(hostPageUrl + '?' + trackingUrl);

        $('#iframeTrackingCodeExampleDiv' + id).show();
        $('#buttonTrackingCodeExampleDiv' + id).hide();
        if ($('#displayAsStandAloneHiddenFieldId' + id).val().toLowerCase() === 'true') {
            $('#iframeTrackingCodeExampleDiv' + id).hide();
            $('#buttonTrackingCodeExampleDiv' + id).show();
        }


        // save the values
        $.ajax({
            url: '/Form/SaveFormTrackingCodes?utmSource=' +
                encodeURIComponent(utmSource) +
                '&utmMedium=' +
                encodeURIComponent(utmMedium) +
                '&utmContent=' +
                encodeURIComponent(utmContent),
            type: 'post',
            success: function (data) { }
        });
        return false;
    },

    // clear the tracking codes entered for a form

    UI_ClearFormTrackingCodes: function (id) {
        $('#trackingFormError' + id).html('').hide();
        try {
            $('#UtmSourceSelectId' + id).select2('val', '');
            $('#UtmMediumSelectId' + id).select2('val', '');
            $('#UtmContentSelectId' + id).select2('val', '');
            $('#iframeTrackingCodeExampleDiv' + id).hide();
            $('#buttonTrackingCodeExampleDiv' + id).hide();
        } catch (e) {

        }
        return false;
    },


    // Updates the form UI depending on whether the form is stand alone or hosted

    UI_UpdateDisplayStandalone: function (id) {
        let displayAsStandAloneSliderId = 'displayAsStandAloneSliderId' + id;
        let displayAsStandAloneHiddenFieldId = 'displayAsStandAloneHiddenFieldId' + id;
        let iframeCodeExampleDiv = 'iframeCodeExampleDiv' + id;
        let buttonCodeExampleDiv = 'buttonCodeExampleDiv' + id;
        let hostPageUrlIdDiv = "HostPageUrlDiv" + id;

        Donorfy.UI_ToggleSwitch(displayAsStandAloneHiddenFieldId, displayAsStandAloneSliderId);
        if ($('#' + displayAsStandAloneSliderId).is(':checked')) {
            $('#' + iframeCodeExampleDiv).hide();
            $('#' + buttonCodeExampleDiv).show();
            $('#' + hostPageUrlIdDiv).hide();
        } else {
            $('#' + iframeCodeExampleDiv).show();
            $('#' + buttonCodeExampleDiv).hide();
            $('#' + hostPageUrlIdDiv).show();
        }
    },


    // adds a templated form element to the form
    // btn pressed to add element
    // templateToAdd - name of Div containing template to add -  this will be set in the partial view used for the template as containerBaseName   e.g. softCredit
    // targetDiv - name of Div where new template should be inserted 
    // prefix - add to name of new template to make it unique - usually Id of associated model
    // numberSep - number separate to use - if omitted then defaults to ,
    // decPoint - decimal point to use - if omitted then defaults to .
    // onePerForm - True if only one element of this type can be added
    UI_AddElementToForm: function (btn, templateToAdd, targetDiv, prefix, numberSep, decPoint, onePerForm) {
        try {


            if (numberSep === undefined) {
                numberSep = ',';
            }
            if (decPoint === undefined) {
                decPoint = '.';
            }

            var counterField =
                'Count' +
                prefix +
                'FormElementsTemplateId'; // name of hidden field used to provide next index number to use  e.g. Count <GUID> TemplateId
            var template = $('#' + templateToAdd + 'Template');
            var fieldIndex = $('#' + counterField).val();
            var newValue = parseInt(fieldIndex) + 1;
            $('#' + counterField).val(newValue);

            var newElem = template.clone();
            var newId = newElem.attr('id');
            newId = prefix + newId.replace('Template', fieldIndex).replace(templateToAdd, 'FormElements');;
            newElem.attr('id', newId);
            var newGuidId = Donorfy.Helper_GetGuid();
            newElem.attr('data-id', newGuidId);
            newElem.removeClass('hidden');

            newElem.find('#CampaignFormElementId').val(newGuidId);
            newElem.find('#ElementOrder').val(fieldIndex);
            newElem.find('#TemplateStatus').val('new');

            // renames the inputs including buttons 
            newElem.find(':input').each(function () {
                newId = this.id.replace('%S', fieldIndex);
                this.id = newId;
                newId = this.name.replace('%S', fieldIndex);
                $(this).attr('data-fieldIndex', fieldIndex).attr('data-prefix', prefix);
                this.name = newId;

                var onChangeNode = $(this)[0].getAttributeNode('onchange');
                if (onChangeNode) {
                    onChangeNode.value = onChangeNode.value.replace(new RegExp('%S', 'g'), fieldIndex);
                }
            });


            // renames a tags
            newElem.find('a').each(function () {
                newId = this.id.replace('%S', fieldIndex);
                this.id = newId;
                newId = this.name.replace('%S', fieldIndex);
                this.name = newId;
            });
            // renames labels 
            newElem.find('label').each(function () {
                newId = this.id;
                if (newId !== 'undefined') {
                    newId = this.id.replace('%S', fieldIndex);
                    this.id = newId;
                    var forId = this.htmlFor.replace('%S', fieldIndex);
                    this.htmlFor = forId;
                }

            });

            // rename divs
            newElem.find('div').each(function () {
                newId = this.id;
                if (newId !== 'undefined' && newId !== "") {
                    newId = this.id.replace('%S', fieldIndex);
                    this.id = newId;
                }

            });

            // Buttons - the name of the btn is set to the fieldindex and template prefix stored in data attr and gets passed to the JS function
            newElem.find('[id=' + templateToAdd + 'DeleteBtn' + fieldIndex + ']').attr('data-fieldIndex', fieldIndex)
                .attr('data-prefix', prefix);
            newElem.find('[id=' + templateToAdd + 'EditBtn' + fieldIndex + ']').attr('data-fieldIndex', fieldIndex)
                .attr('data-prefix', prefix);
            newElem.find('[id=' + templateToAdd + 'CancelBtn' + fieldIndex + ']').attr('data-fieldIndex', fieldIndex)
                .attr('data-prefix', prefix);
            // show / hide details links 
            newElem.find('[id=' + templateToAdd + 'ShowDetails]')
                .attr('id', templateToAdd + 'ShowDetails' + fieldIndex);
            newElem.find('[id=' + templateToAdd + 'HideDetails]')
                .attr('id', templateToAdd + 'HideDetails' + fieldIndex);
            // div containing the details which are shown / hidden
            newElem.find('[id=' + templateToAdd + 'Details]')
                .attr('id', prefix + templateToAdd + 'Details' + fieldIndex);
            // divs containing display / edit controls
            newElem.find('[id=' + templateToAdd + 'Display]')
                .attr('id', prefix + templateToAdd + 'Display' + fieldIndex);
            newElem.find('[id=' + templateToAdd + 'Edit]').attr('id', prefix + templateToAdd + 'Edit' + fieldIndex);
            // link for show / hide details 
            var link = newElem.find('[id=' + templateToAdd + 'ShowHideLink]');
            link.attr('id', templateToAdd + 'ShowHideLink' + fieldIndex);
            link.attr('href',
                'javascript:Donorfy.UI_ShowHideToggleLinkUpdateCaption("' +
                templateToAdd +
                'ShowHideLink' +
                fieldIndex +
                '","' +
                "elementDetailsDivId" +
                fieldIndex +
                '","Show Details","Hide Details")');

            newElem.find('[data-initselect2]').select2();

            // store id of button used to add this element
            newElem.find('[id=AddBtnId]').val(($(btn).attr('id')));

            $('#' + targetDiv).append(newElem);
            // ReSharper disable once UnknownCssClass
            $('.datepicker', newElem).removeClass('hasDatepicker').datepicker();
            $('[data-autonumeric]').autoNumeric('init', { aSep: numberSep, aDec: decPoint });

            Donorfy.UI_FormElementUpdateSequence($('#formElements').data('output', $('#FormElementsSequenceList')));

            if (newElem.find('[data-initckeditor]').length > 0) {
                var newEditorId = Donorfy.Helper_GetGuid();
                newElem.find('[data-initckeditor]').attr('id', newEditorId);

                var editor = CKEDITOR.instances[newEditorId];
                if (editor) {
                    editor.destroy(true);
                }
                CKEDITOR.replace(newEditorId,
                    {
                        customConfig: '/Scripts/ckeditor/basicdonorfyconfig.js',
                        startupFocus: false
                    });
            }

            if (onePerForm === 'True') {
                $(btn).prop('disabled', true);
            }


            var excludeGroup = $(btn).attr('data-excludegroup');
            if (excludeGroup !== 'NoGroup') {
                var formElementContainer = $(btn).attr('data-container');
                $('#' + formElementContainer).find("[data-excludegroup='" + excludeGroup + "']").prop('disabled', true);
            }

            if (templateToAdd === 'DonationElement') {
                Donorfy.UI_DonationDisplaySettingsInitialise(fieldIndex, prefix, 'DonationSuggestedAmounts', 'DonationAskIfOneOffOrRecurring', 'DonationConnectedConstituentNone');

            }

            if (templateToAdd === 'Membership') {
                Donorfy.UI_MembershipProductSettingsInitialise(newElem, fieldIndex);
            }

        } catch (e) {
            console.log('Exception ' + e);
        }
        return false;

    },

    UI_MembershipProductSettingsInitialise: function (newElement, fieldIndex) {
        newElement.find('[data-productdetails]').each(function () {
            this.href = this.href.replace('%S', fieldIndex);
        });


        newElement.find('[data-pricingOptions]').each(function () {
            var divNumber = $(this).data('pricingoptions');

            var pricingOptionsDivId = newElement.find('[data-pricingOptions=' + divNumber + ']').attr('id');
            var fixedPriceDiv = newElement.find('[data-fixedPriceDiv=' + divNumber + ']');
            var optionPriceDiv = newElement.find('[data-optionPriceDiv=' + divNumber + ']');

            $('#' + pricingOptionsDivId + " :radio").change(function () {
                var pricingOption = $('#' + pricingOptionsDivId + " input[type='radio']:checked").val();
                if (pricingOption === 'MembershipProductPriceChoiceOf') {
                    $(fixedPriceDiv).addClass('hidden');
                    $(optionPriceDiv).removeClass('hidden');
                } else {
                    $(fixedPriceDiv).removeClass('hidden');
                    $(optionPriceDiv).addClass('hidden');
                }
            });
        });

    },

    UI_DonationDisplaySettingsInitialise: function (fieldIndex, parentFormId, selectedDonationSuggestedAmounts, selectedDonationAskIfOneOffOrRecurring, selectedDonationConnectedOption) {

        const donationFrequencyOptionLocalId = 'DonationFrequencyOption' + parentFormId + fieldIndex;
        const donationAnyFrequencyContainer = 'donationAnyFrequencyContainer' + parentFormId + fieldIndex;

        var donationSuggestedAmountsContainer = "donationSuggestedAmountsContainer" + parentFormId + fieldIndex;
        var donationAmountOptionLocalId = "DonationAmountOption" + parentFormId + fieldIndex;
        var donationConnectedConstituentOptionLocalId = "donationConnectedConstituentOptionLocalId" + parentFormId + fieldIndex;

        var donationFixedAmountContainer = "donationFixedAmountContainer" + parentFormId + fieldIndex;

        var donationAnyAmountContainer = "donationAnyAmountContainer" + parentFormId + fieldIndex;
        var donationPaymentMethodFrequency = "donationPaymentMethodFrequency" + parentFormId + fieldIndex;

        Donorfy.UI_FormsDonationSetUpGiftOptions(selectedDonationSuggestedAmounts, donationSuggestedAmountsContainer, donationFixedAmountContainer, donationAnyAmountContainer, donationPaymentMethodFrequency);
        Donorfy.UI_FormsDonationSetUpFrequencyOptions(selectedDonationAskIfOneOffOrRecurring, donationAnyFrequencyContainer);
        Donorfy.UI_FormsDonationSetUpConnectedConstituentOptions(selectedDonationConnectedOption, fieldIndex, parentFormId);


        $('#' + donationFrequencyOptionLocalId).select2().on('select2-selecting',
            function (item) {
                Donorfy.UI_FormsDonationSetUpFrequencyOptions(item.val, donationAnyFrequencyContainer);
            });


        $('#' + donationAmountOptionLocalId).select2().on('select2-selecting',
            function (item) {
                Donorfy.UI_FormsDonationSetUpGiftOptions(item.val, donationSuggestedAmountsContainer, donationFixedAmountContainer, donationAnyAmountContainer, donationPaymentMethodFrequency);
            });

        $('#' + donationConnectedConstituentOptionLocalId).select2().on('select2-selecting',
            function (item) {
                Donorfy.UI_FormsDonationSetUpConnectedConstituentOptions(item.val, fieldIndex, parentFormId);
            });
    },

    UI_FormDonationShowDonationComments: function (event, storeInFieldId, checkBoxId, checkedValue, notcheckedValue) {
        Donorfy.UI_Checkbox_StoreValue(event, storeInFieldId, checkedValue, notcheckedValue);
    },

    UI_FormDonationClearConnectedConstituent: function (searchContainerId, donationConnectedConstituentContainerId,
        constituentDetailsTargetContainerId, donationConnectedConstituentId) {
        $('#' + searchContainerId).show();
        $('#' + donationConnectedConstituentContainerId).hide('');
        $('#' + constituentDetailsTargetContainerId).html('');
        $('#' + constituentDetailsTargetContainerId).hide('');
        $('#' + donationConnectedConstituentId).val('');
        return false;
    },

    UI_FormDonationSetConnectedConstituentDetails: function (consId, searchContainerId, donationConnectedConstituentContainerId, constituentDetailsTargetContainerId, donationConnectedConstituentId) {
        $('#' + searchContainerId).hide();
        $('#' + donationConnectedConstituentContainerId).show();
        $('#' + donationConnectedConstituentId).val(consId);
        Donorfy.AJAX_GetHTMLContentForEntity(consId, 'Constituent', 'Constituent', 'GetProfile', $('#' + constituentDetailsTargetContainerId));
    },

    // controls display of connected constituent UI 
    UI_FormsDonationSetUpConnectedConstituentOptions: function (optionSelected, fieldIndex, parentFormId) {
        var donationConnectedConstituentSelectedContainer = "donationConnectedConstituentSelectedContainer" + parentFormId + fieldIndex;
        var donationConnectedConstituentFromListContainer = "donationConnectedConstituentFromListContainer" + parentFormId + fieldIndex;
        $('#' + donationConnectedConstituentSelectedContainer).hide();
        $('#' + donationConnectedConstituentFromListContainer).hide();

        if (optionSelected === 'DonationConnectedConstituentSelected') {
            $('#' + donationConnectedConstituentSelectedContainer).show();
        }
        if (optionSelected === 'DonationConnectedConstituentFromList') {
            $('#' + donationConnectedConstituentFromListContainer).show();
        }
    },

    // Controls display of prompted for amounts in donation elements
    UI_DonationAmountsDisplay: function (event, storeInFieldId, checkboxId, checkedValue, notcheckedValue) {

        const showHideDiv = event.target.getAttribute("data-value");

        if (event.target.checked) {
            $('#' + showHideDiv).removeClass('hidden');
        } else {
            $('#' + showHideDiv).addClass('hidden');
        }


        Donorfy.UI_Checkbox_StoreValue(event, storeInFieldId, checkedValue, notcheckedValue);
    },

    UI_SetDonationAmountDefault: function (event, storeInFieldId, checkboxId, checkedValue, notcheckedValue) {
        var otherCheckBox = '';
        var hiddenField = '';

        // Single amt
        if (checkboxId.indexOf('DonationSuggestedAmount1IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount1', 'Amount2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount1', 'Amount3');
            $('#' + otherCheckBox).prop('checked', false);

            hiddenField = checkboxId.replace('Amount1', 'Amount2').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount1', 'Amount3').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }
        if (checkboxId.indexOf('DonationSuggestedAmount2IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount2', 'Amount1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount2', 'Amount3');
            $('#' + otherCheckBox).prop('checked', false);
            hiddenField = checkboxId.replace('Amount2', 'Amount1').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount2', 'Amount3').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }
        if (checkboxId.indexOf('DonationSuggestedAmount3IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount3', 'Amount1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount3', 'Amount2');
            $('#' + otherCheckBox).prop('checked', false);
            hiddenField = checkboxId.replace('Amount3', 'Amount1').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount3', 'Amount2').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }

        // monthly
        if (checkboxId.indexOf('DonationSuggestedRecurringAmount1IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount1', 'Amount2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount1', 'Amount3');
            $('#' + otherCheckBox).prop('checked', false);

            hiddenField = checkboxId.replace('Amount1', 'Amount2').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount1', 'Amount3').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }
        if (checkboxId.indexOf('DonationSuggestedRecurringAmount2IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount2', 'Amount1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount2', 'Amount3');
            $('#' + otherCheckBox).prop('checked', false);
            hiddenField = checkboxId.replace('Amount2', 'Amount1').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount2', 'Amount3').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }
        if (checkboxId.indexOf('DonationSuggestedRecurringAmount3IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount3', 'Amount1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount3', 'Amount2');
            $('#' + otherCheckBox).prop('checked', false);
            hiddenField = checkboxId.replace('Amount3', 'Amount1').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount3', 'Amount2').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }

        // annual
        if (checkboxId.indexOf('DonationAnnualSuggestedRecurringAmount1IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount1', 'Amount2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount1', 'Amount3');
            $('#' + otherCheckBox).prop('checked', false);

            hiddenField = checkboxId.replace('Amount1', 'Amount2').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount1', 'Amount3').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }
        if (checkboxId.indexOf('DonationAnnualSuggestedRecurringAmount2IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount2', 'Amount1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount2', 'Amount3');
            $('#' + otherCheckBox).prop('checked', false);
            hiddenField = checkboxId.replace('Amount2', 'Amount1').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount2', 'Amount3').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }
        if (checkboxId.indexOf('DonationAnnualSuggestedRecurringAmount3IsDefault') > 0) {
            otherCheckBox = checkboxId.replace('Amount3', 'Amount1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Amount3', 'Amount2');
            $('#' + otherCheckBox).prop('checked', false);
            hiddenField = checkboxId.replace('Amount3', 'Amount1').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
            hiddenField = checkboxId.replace('Amount3', 'Amount2').replace("checkboxId", "id");
            $('#' + hiddenField).val('No');
        }

        Donorfy.UI_Checkbox_StoreValue(event, storeInFieldId, checkedValue, notcheckedValue);
    },

    UI_SetDonationFrequencyDefault: function (event, storeInFieldId, checkboxId, checkedValue, notcheckedValue) {
        var otherCheckBox = '';

        var hiddenField = event.target.getAttribute("data-custom");
        var selectedOption = event.target.getAttribute("data-value");


        if (checkboxId.indexOf('Frequency1') > 0) {
            otherCheckBox = checkboxId.replace('Frequency1', 'Frequency2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency1', 'Frequency3');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency1', 'Frequency4');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency1', 'Frequency5');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency1', 'Frequency6');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency1', 'Frequency7');
            $('#' + otherCheckBox).prop('checked', false);
        }

        if (checkboxId.indexOf('Frequency2') > 0) {
            otherCheckBox = checkboxId.replace('Frequency2', 'Frequency1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency2', 'Frequency3');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency2', 'Frequency4');
            $('#' + otherCheckBox).prop('checked', false)
            otherCheckBox = checkboxId.replace('Frequency2', 'Frequency5');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency2', 'Frequency6');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency2', 'Frequency7');
        }

        if (checkboxId.indexOf('Frequency3') > 0) {
            otherCheckBox = checkboxId.replace('Frequency3', 'Frequency1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency3', 'Frequency2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency3', 'Frequency4');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency3', 'Frequency5');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency3', 'Frequency6');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency3', 'Frequency7');
            $('#' + otherCheckBox).prop('checked', false);
        }

        if (checkboxId.indexOf('Frequency4') > 0) {
            otherCheckBox = checkboxId.replace('Frequency4', 'Frequency1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency4', 'Frequency2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency4', 'Frequency3');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency4', 'Frequency5');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency4', 'Frequency6');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency4', 'Frequency7');
            $('#' + otherCheckBox).prop('checked', false);
        }

        if (checkboxId.indexOf('Frequency5') > 0) {
            otherCheckBox = checkboxId.replace('Frequency5', 'Frequency1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency5', 'Frequency2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency5', 'Frequency3');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency5', 'Frequency4');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency5', 'Frequency6');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency5', 'Frequency7');
            $('#' + otherCheckBox).prop('checked', false);
        }

        if (checkboxId.indexOf('Frequency6') > 0) {
            otherCheckBox = checkboxId.replace('Frequency6', 'Frequency1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency6', 'Frequency2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency6', 'Frequency3');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency6', 'Frequency4');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency6', 'Frequency5');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency6', 'Frequency7');
            $('#' + otherCheckBox).prop('checked', false);
        }

        if (checkboxId.indexOf('Frequency7') > 0) {
            otherCheckBox = checkboxId.replace('Frequency7', 'Frequency1');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency7', 'Frequency2');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency7', 'Frequency3');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency7', 'Frequency4');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency7', 'Frequency5');
            $('#' + otherCheckBox).prop('checked', false);
            otherCheckBox = checkboxId.replace('Frequency7', 'Frequency6');
            $('#' + otherCheckBox).prop('checked', false);
        }
        if (event.target.checked) {
            $('#' + hiddenField).val(selectedOption);
        } else {
            $('#' + hiddenField).val('');
        }
    },

    UI_FormDonationShowGiftAidOptions: function (event, storeInFieldId, checkBoxId, checkedValue, notcheckedValue) {
        Donorfy.UI_Checkbox_StoreValue(event, storeInFieldId, checkedValue, notcheckedValue);
    },

    UI_FormsDonationSetUpGiftOptions: function (optionSelected, suggestedContainer, fixedContainer, anyContainer, paymentMethodFrequencyContainer) {

        $('#' + suggestedContainer).hide();
        $('#' + fixedContainer).hide();
        $('#' + anyContainer).hide();
        $('#' + paymentMethodFrequencyContainer).hide();

        if (optionSelected === 'DonationSuggestedAmounts') {
            $('#' + suggestedContainer).show();
        }

        if (optionSelected === 'DonationFixedAmount') {
            $('#' + fixedContainer).show();
            $('#' + paymentMethodFrequencyContainer).show();
        }
        if (optionSelected === 'DonationAnyAmount') {
            $('#' + anyContainer).show();
            $('#' + paymentMethodFrequencyContainer).show();
        }

    },

    UI_FormsDonationSetUpFrequencyOptions: function (optionSelected, containerDiv) {
        $('#' + containerDiv).hide();
        if (optionSelected === 'DonationAskIfOneOffOrRecurring') {
            $('#' + containerDiv).show();
        }
    },

    // deletes the element from the form
    // btn - button calling function - correct data attributes have been assigned in add template
    // template - type of template e.g. soft credit
    UI_DeleteElementFromForm: function (btn, template) {
        var prefix = "";
        var index = "";
        if (btn != null) {
            index = $(btn).data('fieldindex');
            prefix = $(btn).data('prefix');
        }

        var templateDiv = $('#' + prefix + template + index);
        templateDiv.addClass('hidden');
        var statusField = templateDiv.find('[id=TemplateStatus]');
        statusField.val('deleted');



        // find button used to add this element and re-enabled it 
        var btnId = templateDiv.find('[id=AddBtnId]').val();
        if (btnId === undefined || btnId === '') {
            return false;
        }

        // find buttons in this exclude group and and re-enabled 
        var excludeGroup = $('#' + btnId).attr('data-excludegroup');
        if (excludeGroup !== 'NoGroup') {
            var formElementContainer = $('#' + btnId).attr('data-container');
            $('#' + formElementContainer).find("[data-excludegroup='" + excludeGroup + "']").prop('disabled', false);
        }

        $('#' + btnId).prop('disabled', false);
        return false;
    },

    // Used to update form element sequence hidden field
    UI_FormElementUpdateSequence: function (e) {
        var list = e.length ? e : $(e.target), output = list.data('output');
        if (output === undefined || output === null) return;
        if (window.JSON) {
            output.val(window.JSON.stringify(list.nestable('serialize')));
        }
    },

    // used for form designer to set size of submit button
    UI_FormSubmitButtonSetSize: function (id, size) {
        let exampleButtonId = "ExampleButton" + id;
        $('#' + exampleButtonId).removeClass('btn-sm').removeClass('btn-lg').removeClass('padding-7')
            .css({ 'width': '', 'height': '' });
        if (size === "custom") {
            let SubmitButtonCustomHeight = $('#SubmitButtonCustomHeight' + id).val();
            let SubmitButtonCustomWidthId = $('#SubmitButtonCustomWidth' + id).val();
            $('#' + exampleButtonId).css({ 'width': SubmitButtonCustomWidthId, 'height': SubmitButtonCustomHeight });
        } else {
            $('#' + exampleButtonId).addClass(size);
        }
        // todo store size in hidden field
        let SubmitButtonSizeHiddenFieldId = "SubmitButtonSizeHiddenFieldId" + id;
        $('#' + SubmitButtonSizeHiddenFieldId).val(size);
        return false;
    },

    // Used in form details to update sample code for form iframe
    UI_Set_IframeExampleCode: function (template, id) {
        var heightInput = $("#formUrlHeightInput" + id).val();
        var widthInput = $("#formUrlWidthInput" + id).val();
        var exampleCode = template.replace('{height}', heightInput).replace('{width}', widthInput);
        $("#iframeCodeExample" + id).val(exampleCode);
    },

    // Used with Select 2 & Form Tracking codes to add a delete button to the result list items
    UI_FormsFormatResult: function (item, container) {
        if (!item.id) return item.text; // optgroup
        container.append(item.text);
        if (item.text === '') return item.text; // blank
        $(
            '<span class="btn btn-xs trackingCodeInfo" data-toggle="tooltip" data-placement="bottom" title="Delete"><i class="fa fa-times"></i></span>')
            .appendTo(container)
            .mouseup(function (e) {
                e.stopPropagation();
            })
            .click(function (e) {
                e.preventDefault();
                Donorfy.UI_FormsDeleteTrackingCodeFromResults(item, container);
            });
    },

    // Used with Select 2 & Form Tracking codes to add a delete button to the selected item
    UI_FormsFormatSelection: function (item, container) {
        container.append(
            $(
                '<span class="selected-TrackingCodeState" data-toggle="tooltip" data-placement="bottom" title="Delete"></span>')
                .text(item.text));
        $(
            '<span class="btn btn-xs trackingCodeInfo" data-toggle="tooltip" data-placement="bottom" title="Delete"><i class="fa fa-times"></i></span>')
            .appendTo(container)
            .mousedown(function (e) {
                e.stopPropagation();
            })
            .click(function (e) {
                e.preventDefault();
                Donorfy.UI_FormsDeleteTrackingCodeFromSelection(item, container);
            });
    },

    // Called from Select2 delete button to
    // delete tracking code when shown in results of Select2
    UI_FormsDeleteTrackingCodeFromResults: function (item, container) {
        Donorfy.AJAX_PostWithCallback('Form', 'DeleteTrackingCode', 'trackingCodeId=' + item.id, null, null, null);
        // clears the selected item if it is the one we are deleting /
        if ($('#' + item.additionalInfo).select2('val') === item.id) {
            $('#' + item.additionalInfo).select2('val', '');
        }
        // clears items from the dropdown list 
        $(container).parent().html('');

    },

    // Called from Select2 delete button to
    // delete tracking code when it has been selected  
    UI_FormsDeleteTrackingCodeFromSelection: function (item, container) {
        Donorfy.AJAX_PostWithCallback('Form', 'DeleteTrackingCode', 'trackingCodeId=' + item.id, null, null, null);
        //clears the selected item  
        $('#' + item.additionalInfo).select2('val', '');
    },


    ////////////////////////////////////////////////////////////////////////
    // General UI Functions
    ////////////////////////////////////////////////////////////////////////


    // Allows an individual guide to be hidden
    UI_HideSelectedGuideContent: function (contentUsageId, guideContentId, guideContentContainerId) {
        Donorfy.AJAX_SaveConfigSetting('Home', 'HideGuide', contentUsageId, guideContentId);
        $('#' + guideContentContainerId).addClass('hidden');
        $("div").find("[data-guideLocalId='" + guideContentContainerId + "']").addClass('hidden');

        if (contentUsageId === 'all') {
            $("div").find("[data-guidecontent]").addClass('hidden');
        }
    },

    // updates guide content - i.e. the link between a guide and a place in the app where a guide can be shown
    UI_UpdateGuideContent: function (localId, editGuideContentContainerId) {
        Donorfy.UI_ShowHide(editGuideContentContainerId);
        Donorfy.AJAX_PerformOperation(localId, 'Home', '', 'UpdateGuideContent', '');
        return false;
    },

    // Called from  Views\Settings\_EditUserDataServiceAccess.cshtml
    // to show or hide the data service IP restriction UI
    UI_ToggleUserDataServiceIpRestrictionDisplay: function (userId) {
        $('#DataServiceIpRestriction' + userId).toggleClass('hidden');
        if ($('#DataServiceIpRestriction' + userId).hasClass('hidden') === true) {
            $('#accessDataServiceField' + userId).val('false');
        } else {
            $('#accessDataServiceField' + userId).val('true');
        }
        return false;
    },


    // Used for copying the contents of a control to the clipboard
    // controlId is the Id of the control (input, textarea) containing the text to copy
    UI_CopyToClipboard: function (controlId) {
        try {
            var copyText = document.getElementById(controlId);
            var tempInput = document.createElement("textarea");
            tempInput.style = "position: absolute; left: -1000px; top: -1000px";
            tempInput.value = copyText.value;
            document.body.appendChild(tempInput);
            tempInput.select();
            document.execCommand("copy");
            document.body.removeChild(tempInput);
        } catch (e) {
            console.log('exception in UI_CopyToClipboard ' + e);
        }
        return false;
    },

    // Displays a map using Azure Maps when we know the long & lat of the map
    UI_DisplayMapFromAzure: function (mapCanvas, longitude, latitude, subscriptionKey) {

        let longI = parseFloat(longitude);
        let latI = parseFloat(latitude);
        let w = $('#' + mapCanvas).width();
        let h = $('#' + mapCanvas).height();

        let map = new atlas.Map(mapCanvas,
            {
                center: [longI, latI],
                zoom: 15,
                authOptions: {
                    authType: 'subscriptionKey',
                    subscriptionKey: subscriptionKey
                },
                style: "road_shaded_relief",
                showLogo: true,
                showFeedbackLink: false
            });

        map.events.add('ready',
            function () {
                let dataSource = new atlas.source.DataSource();
                map.sources.add(dataSource);
                let point = new atlas.Shape(new atlas.data.Point([longI, latI]));
                dataSource.add([point]);
                map.layers.add(new atlas.layer.SymbolLayer(dataSource, null));
                let zoomControl = new atlas.control.ZoomControl();
                map.controls.add(zoomControl,
                    {
                        position: "bottom-left"
                    });
                map.resize(h, w);
            });
    },


    // Looks up long and lat for address passed in using Azure Maps - then updates stored details
    UI_GetGeoLocationAndMapFromAzure: function (contactDetailsId, lastChangedOn, mapCanvas, addressInfo, subscriptionKey) {
        if (addressInfo.trim() === '') {
            return;
        }
        let geocodeUrlTemplate =
            'https://atlas.microsoft.com/search/address/json?subscription-key={subscription-key}&api-version=1&query={query}';
        let geocodeRequest = geocodeUrlTemplate.replace('{query}', encodeURIComponent(addressInfo))
            .replace('{subscription-key}', subscriptionKey);

        fetch(geocodeRequest)
            .then(function (response) {
                return response.json();
            }).then(function (response) {
                if (response &&
                    response.results &&
                    response.results.length > 0) {
                    let results = response.results;
                    $('#' + mapCanvas).removeClass('hidden');
                    Donorfy.UI_DisplayMapFromAzure(mapCanvas,
                        results[0].position.lon,
                        results[0].position.lat,
                        subscriptionKey);
                    Donorfy.UI_UpdateConstituentLocation(contactDetailsId,
                        lastChangedOn,
                        results[0].position.lon,
                        results[0].position.lat);
                } else {
                    $('#' + mapCanvas).addClass('hidden');
                }
            });
    },

    // updates latest long & lat for contact details
    UI_UpdateConstituentLocation: function (contactDetailsId, lastChangedOn, longitude, latitude) {
        let numberCultureFormatter = new Intl.NumberFormat(currentCulture);
        $.ajax({
            url: '/Constituent/UpdateConstituentLocation',
            data: {
                contactDetailsId: contactDetailsId,
                longitude: numberCultureFormatter.format(longitude),
                latitude: numberCultureFormatter.format(latitude),
                contactDetailsDateChanged: lastChangedOn
            },
            type: 'post',
            success: function () {
            }
        });
    },

    // When Configuring extra fields on a form - set ups the UI options for a Yes No field 
    UI_FormInitialiseExtraYesNoFieldDisplay: function (entityAddOptionSelectLocalId, questionPromptId, answerPromptId) {
        let currentValue = $(entityAddOptionSelectLocalId).find(":selected").val();

        if (currentValue === 'DoNotUse') {
            $("#" + questionPromptId).hide();
            $("#" + answerPromptId).hide();
        }
        if (currentValue === 'UseThisValue') {
            $("#" + questionPromptId).hide();
            $("#" + answerPromptId).show();
        }

        if (currentValue === 'AskQuestionChooseFromList') {
            $("#" + questionPromptId).show();
            $("#" + answerPromptId).hide();
        }
    },

    // When Configuring extra fields on a form - set ups the UI options for a Text field 
    UI_FormInitialiseExtraFieldDisplay: function (entityAddOptionSelectLocalId, questionPromptId, answerPromptId) {
        let currentValue = $(entityAddOptionSelectLocalId).find(":selected").val();

        if (currentValue === 'DoNotUse') {
            $("#" + questionPromptId).hide();
            $("#" + answerPromptId).hide();
        }
        if (currentValue === 'UseThisValue') {
            $("#" + questionPromptId).hide();
            $("#" + answerPromptId).show().attr("placeholder", "Enter the value");;
        }
        if (currentValue === 'AskQuestionFreeTextAnswer') {
            $("#" + questionPromptId).show();
            $("#" + answerPromptId).hide();
        }
        if (currentValue === 'AskQuestionChooseFromList') {
            $("#" + questionPromptId).show();
            $("#" + answerPromptId).show().attr("placeholder", "Enter the list of answers separated by commas");
        }
    },

    // Hides or shows the question prompt - e.g. when adding an activity element to a form
    UI_FormShowHideQuestionPrompt: function (AddOptionSelect, questionPromptId) {
        let currentValue = $(AddOptionSelect).find(":selected").val();
        if (currentValue === 'AskYesNoQuestion') {
            $("#" + questionPromptId).show();
        } else {
            $("#" + questionPromptId).hide();
        }
    },


    // When Configuring extra fields on a form refreshes the fields for the extra field 
    // based on the activity type of tag selected
    UI_FormUpdateExtraFieldDisplay: function (activitySelect,
        formElementId,
        formId,
        formElementType,
        targetId,
        prefix,
        currentActivityTypeId) {

        var extraFieldsPleaseWait = 'ExtraFieldsTarget' + 'PleaseWait' + "_" + formId + "_" + targetId;
        var extraFieldsTarget = 'ExtraFieldsTarget' + "_" + formId + "_" + targetId;


        $('#' + extraFieldsTarget).hide();

        var selectedCommsType = '';

        if (currentActivityTypeId !== '' && currentActivityTypeId !== 'undefined') {
            selectedCommsType = currentActivityTypeId;
        } else {
            selectedCommsType = $(activitySelect).find(":selected").val();
        }

        var parameters = "formId=" +
            formId +
            "&lookUpTypeId=" +
            selectedCommsType +
            "&formElementId=" +
            formElementId +
            "&formElementType=" +
            formElementType +
            "&prefix=" +
            prefix;
        Donorfy.AJAX_GetHTMLContentForTarget("Form",
            "GetFormExtraFields",
            parameters,
            $('#' + extraFieldsTarget),
            $('#' + extraFieldsPleaseWait));
    },

    // Copies the form URL to the clipboard
    UI_FormCopyUrlToClipboard: function (url, formUrlComplete) {
        $('#' + formUrlComplete).val(url);
        Donorfy.UI_CopyToClipboard(formUrlComplete);
        return false;
    },

    UI_MakeFormReadOnly: function (container) {
        $('#' + container).find(':input').prop('disabled', 'disabled');
        $('#' + container).find('.viewenable').prop('disabled', '');
    },

    UI_MakeFormActive: function (container) {
        $('#' + container).find(':input').prop('disabled', '');
    },

    // Toggles the visibility of the two divs
    // this is used for display confirmation messages in response to button clicks
    // e.g. Delete -> Are you sure?
    UI_ToggleDivs: function (div1, div2) {
        div1.toggle();
        div2.toggle();
    },

    // Closes accordion - used to close panel in response to ok btn 
    UI_CloseAccordion: function (id) {
        $("#" + id).accordion({ active: false }).click();
    },

    // Called from main menu to display form in a pushdown at top of main form - e.g. for adding from main add menu
    // MainPushdownTarget is in pageHeading.cshtml
    UI_DisplayInMainPushdown: function (controller,
        action,
        idParam,
        idValue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3,
        paramName4,
        paramValue4,
        paramName5,
        paramValue5) {
        $(".activeMenuItem").removeClass("activeMenuItem");
        let menuItem = null;
        switch (controller) {
            case "Constituent":
                menuItem = "#mainNav_Constituents";
                break;
            case "List":
                menuItem = "#mainNav_Lists";
                break;
        }
        if (menuItem) {
            $(menuItem).addClass("activeMenuItem");
        }

        var addContainer = $('#MainPushdownTarget');
        addContainer.removeClass('hidden');
        addContainer.html('<img src="/images/Spinner1.gif"/>');
        $('#content').addClass('hidden');
        $('#PageHeaderDiv').addClass('hidden');
        $('#ConfirmMsgDivMainForm').addClass('hidden');
        $('#ErrMsgDiv').addClass('hidden');

        var urlString = idParam + "=" + idValue;
        if (paramName1) {
            urlString = urlString + "&" + paramName1 + "=" + paramValue1;
        }
        if (paramName2) {
            urlString = urlString + "&" + paramName2 + "=" + paramValue2;
        }
        if (paramName3) {
            urlString = urlString + "&" + paramName3 + "=" + paramValue3;
        }
        if (paramName4) {
            urlString = urlString + "&" + paramName4 + "=" + paramValue4;
        }
        if (paramName5) {
            urlString = urlString + "&" + paramName5 + "=" + paramValue5;
        }
        urlString = urlString + "&popup=false&pushDown=true";
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (pushdownForm) {
                addContainer.show();
                addContainer.html(pushdownForm);
            },
            error: function (jqXhr, textStatus, errorThrown) {
                Donorfy.ShowStandardAjaxErrorAlert(jqXhr, textStatus, errorThrown);
                $('#MainPushdownTarget').addClass('hidden');
                $('#content').removeClass('hidden');
                $('#PageHeaderDiv').removeClass('hidden');
            }
        });
    },

    // Called from constituent profile to display alternate content in profile - e.g. to show connection diagram & list    
    UI_DisplaySwapConstituentMainPanel: function (controller,
        action,
        idParam,
        idValue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3,
        paramName4,
        paramValue4,
        paramName5,
        paramValue5) {
        window.SavedContent = $('#ConstituentMainPanel').html();
        var addContainer = $('#ConstituentMainPanel');
        addContainer.removeClass('hidden');
        addContainer.html('<img src="/images/Spinner1.gif"/>');

        var urlString = idParam + "=" + idValue;
        if (paramName1 !== "") {
            urlString = urlString + "&" + paramName1 + "=" + paramValue1;
        }
        if (paramName2 !== "") {
            urlString = urlString + "&" + paramName2 + "=" + paramValue2;
        }
        if (paramName3 !== "") {
            urlString = urlString + "&" + paramName3 + "=" + paramValue3;
        }
        if (paramName4 !== "") {
            urlString = urlString + "&" + paramName4 + "=" + paramValue4;
        }
        if (paramName5 !== "") {
            urlString = urlString + "&" + paramName5 + "=" + paramValue5;
        }
        urlString = urlString + "&popup=false&pushDown=true";
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (pushdownForm) {
                addContainer.html(pushdownForm);
            },
            error: function (jqXhr, textStatus, errorThrown) {
                Donorfy.ShowStandardAjaxErrorAlert(jqXhr, textStatus, errorThrown);
                $('#ConstituentMainPanel').html(window.SavedContent);
            }
        });
    },

    // Displays a pop up form by calling the controller action passed in
    // the pop up is displayed in popup target div in Page Heading
    // this displays the standard size popup - e.g. for tag editing or the finder 
    UI_DisplayPopUp: function (controller,
        action,
        idparam,
        idvalue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3) {
        $('#PopUpDialog').addClass('modal-dialog').css('max-width', '700px').css('margin-top', '')
            .css('margin-left', '');
        var popupContainer = $('#Popup-Target');
        popupContainer.html('').css('height', '');
        var popupForm = $('#Popup-Form');
        popupForm.modal('show');
        var popupLoading = $('#popupLoading');
        if (!popupLoading.is(':visible')) {
            popupLoading.show();
        }
        if (idparam == null) {
            idparam = "Id";
        }
        if (idparam === "") {
            idparam = "Id";
        }
        if (paramName1 == null) {
            paramName1 = "";
        }
        if (paramName2 == null) {
            paramName2 = "";
        }
        if (paramName3 == null) {
            paramName3 = "";
        }
        var urlString = idparam + "=" + idvalue;
        if (paramName1 !== "") {
            urlString = urlString + "&" + paramName1 + "=" + paramValue1;
        }
        if (paramName2 !== "") {
            urlString = urlString + "&" + paramName2 + "=" + paramValue2;
        }
        if (paramName3 !== "") {
            urlString = urlString + "&" + paramName3 + "=" + paramValue3;
        }
        urlString = urlString + "&popup=true";
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (popUpForm) {
                popupContainer.html(popUpForm);
                popupLoading.hide();
                //  popupForm.modal('show');
            },
            error: function (jqXhr, textStatus, errorThrown) {
                popupLoading.hide();
                Donorfy.ShowStandardAjaxErrorAlert(jqXhr, textStatus, errorThrown);
            }
        });
    },

    // Displays a pop up form by calling the controller action passed in
    // the pop up is displayed in popup target div in Page Heading
    // this re-szies the pop up displays to max possible - e.g. for connections diagram
    UI_DisplayPopUpMaxSize: function (controller,
        action,
        idparam,
        idvalue,
        paramName1,
        paramValue1,
        paramName2,
        paramValue2,
        paramName3,
        paramValue3,
        paramName4,
        paramValue4,
        allowScroll) {
        var height = 600;
        var width = 1000;
        try {
            height = $(window.top).height() - 150;
        } catch (e) {
            //
        }
        try {
            width = $(window.top).width() - 150;
        } catch (e) {
            //
        }
        $('#PopUpDialog').addClass('modal-dialog').css('max-width', '700px').css('margin-top', '')
            .css('margin-left', '');
        var popupContainer = $('#Popup-Target');
        popupContainer.html('').css('height', '');
        var popupForm = $('#Popup-Form');
        popupForm.modal('show');
        var popupLoading = $('#popupLoading');
        if (!popupLoading.is(':visible')) {
            popupLoading.show();
        }
        if (idparam == null) {
            idparam = "Id";
        }
        if (idparam === "") {
            idparam = "Id";
        }
        if (paramName1 == null) {
            paramName1 = "";
        }
        if (paramName2 == null) {
            paramName2 = "";
        }
        if (paramName3 == null) {
            paramName3 = "";
        }
        if (paramName4 == null) {
            paramName4 = "";
        }
        var urlString = idparam + "=" + idvalue;
        if (paramName1 !== "") {
            urlString = urlString + "&" + paramName1 + "=" + encodeURIComponent(paramValue1);
        }
        if (paramName2 !== "") {
            urlString = urlString + "&" + paramName2 + "=" + encodeURIComponent(paramValue2);
        }
        if (paramName3 !== "") {
            urlString = urlString + "&" + paramName3 + "=" + encodeURIComponent(paramValue3);
        }
        if (paramName4 !== "") {
            urlString = urlString + "&" + paramName4 + "=" + encodeURIComponent(paramValue4);
        }
        urlString = urlString + "&popup=true&viewPortWidth=" + width;
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (popUpForm) {
                $('#PopUpDialog').css('max-width', '').css('margin-top', '100px').css('margin-left', '100px')
                    .css('width', width + 'px');
                if (!allowScroll) {
                    popupContainer.css('height', height + 'px');
                }
                popupContainer.html(popUpForm);
                popupLoading.hide();
            },
            error: function (jqXhr, textStatus, errorThrown) {
                popupLoading.hide();
                Donorfy.ShowStandardAjaxErrorAlert(jqXhr, textStatus, errorThrown);
            }
        });
    },

    // Used to trigger a file download from a button
    // url is the url of file to download
    UI_DownloadFile: function (e, url, preview) {

        if (e) {
            e.preventDefault();
        }
        if (preview) {
            window.open(url);
        } else {
            window.location.href = url;
        }
    },

    // Removed mark up e.g. html, script tags etc from a string 
    // used to clean up text pasted into notes 
    UI_RemoveMarkUpFromInput: function (html) {
        var tagBody = '(?:[^"\'>]|"[^"]*"|\'[^\']*\')*';

        var tagOrComment = new RegExp(
            '<(?:'
            // Comment body.
            +
            '!--(?:(?:-*[^->])*--+|-?)'
            // Special "raw text" elements whose content should be elided.
            +
            '|script\\b' +
            tagBody +
            '>[\\s\\S]*?</script\\s*' +
            '|style\\b' +
            tagBody +
            '>[\\s\\S]*?</style\\s*'
            // Regular name
            +
            '|/?[a-z]' +
            tagBody +
            ')>',
            'gi');
        var oldHtml;
        do {
            oldHtml = html;
            html = html.replace(tagOrComment, '');
        } while (html !== oldHtml);
        return html.replace(/</g, '&lt;');
    },


    // used with _Checkbox to store selected value in a hidden field
    UI_Checkbox_StoreValue: function (event, storeInFieldId, checkedValue, notcheckedValue, callBack) {
        event.preventDefault();
        var setToValue = 'unknown';
        if (event.target.checked) {
            setToValue = checkedValue;
        } else {
            setToValue = notcheckedValue;
        }

        storeInFieldId.val(setToValue);
        if (typeof callBack === "function") {
            callBack(setToValue);
        }

    },

    // Used with _TwoRadioButtons set to store selected value in a hidden field based on the button pressed 
    // and update button colour
    //  - storeInFieldId is the ID of the hidden field to hold the value associated with the button
    //  - btnValue - value to store in the hidden field
    //  - clickedBtnId - Id of the button pressed 
    //  - otherBtnId - Id of the other button in the set 
    //  - callBack - function to call after button pressed
    UI_BtnSet_StoreValue: function (event, storeInFieldId, btnValue, clickedBtnId, otherBtnId, callBack) {
        event.preventDefault();
        // set based on button pressed     
        storeInFieldId.val(btnValue);

        var btnClass = "btn-success";
        if (btnValue == "No") {
            btnClass = "btn-danger";
        }
        clickedBtnId.removeClass('btn-primary');
        clickedBtnId.addClass(btnClass);
        clickedBtnId.css('color', 'white');
        clickedBtnId.css('border-color', 'yellow');

        otherBtnId.removeClass('btn-danger');
        otherBtnId.removeClass('btn-success');
        otherBtnId.addClass('btn-default');
        otherBtnId.css('color', 'grey');
        otherBtnId.css('border-color', 'grey');

        if (typeof callBack === "function") {
            callBack(btnValue);
        }
        return false;
    },

    // Used with _TwoRadioButtons set to store selected value in a hidden field based on the button pressed 
    // and update button colour
    //  - storeInFieldId is the ID of the hidden field to hold the value associated with the button
    //  - btnValue - value to store in the hidden field
    //  - clickedBtnId - Id of the button pressed 
    //  - otherBtnId - Id of the other button in the set 
    UI_ThreeBtnSet_StoreValue: function (event, storeInFieldId, btnValue, clickedBtnId, otherBtnId1, otherBtnId2) {
        event.preventDefault();
        // set based on button pressed     
        storeInFieldId.val(btnValue);

        clickedBtnId.removeClass('btn-default');
        clickedBtnId.addClass('btn-primary');
        clickedBtnId.css('border-color', 'yellow');
        clickedBtnId.css('border-width', '1px');

        otherBtnId1.removeClass('btn-primary');
        otherBtnId1.addClass('btn-default');
        otherBtnId1.css('border-color', 'grey');
        otherBtnId1.css('border-width', '1px');

        otherBtnId2.removeClass('btn-primary');
        otherBtnId2.addClass('btn-default');
        otherBtnId2.css('border-color', 'grey');
        otherBtnId2.css('border-width', '1px');

        var icon1 = clickedBtnId.attr('id') + "Icon";
        $('#' + icon1).addClass('fa fa-check pull-left');

        var icon2 = otherBtnId1.attr('id') + "Icon";
        $('#' + icon2).removeClass('fa fa-check pull-left');

        var icon3 = otherBtnId2.attr('id') + "Icon";
        $('#' + icon3).removeClass('fa fa-check pull-left');
    },

    // Use with UI_MarkFieldAsChanged below 
    // sourceId - id of field provding the contents 
    // targetId - Id of field that should be updated 
    // example - CreditAmount is updating AllocationDebitAmount0
    //    $('#CreditAmount').keyup(function () {  Donorfy.UI_UpdateFieldFromThis('CreditAmount', 'AllocationDebitAmount0'); });
    //    $("#AllocationDebitAmount0").keyup(function() { Donorfy.UI_MarkFieldAsChanged('AllocationDebitAmount0');} );
    UI_UpdateFieldFromThis: function (sourceId, targetId) {
        if (!$('#' + targetId).hasClass('changed')) {
            $('#' + targetId).val($('#' + sourceId).val());
        }
    },

    // Use with UI_UpdateFieldFromThis above 
    // used to mark field as changed - e.g. when the input of one field (e.g. amount paid) is automatically entered into another
    // (e.g. amount due)
    // pass in id of field to be changed
    UI_MarkFieldAsChanged: function (id) {
        var fld = $('#' + id);
        var value = $.trim($('#' + id).val());
        if (value.length > 0) {
            fld.addClass("changed");
        } else {
            fld.removeClass("changed");
        }
    },

    // Toggles Visibility of the control (e.g. div) with the id passed
    UI_ShowHide: function (id) {

        $('[id*=' + id + ']').toggleClass('hidden');

        if ($(event).length > 0) {
            //toggle up/down arrow
            var sourceIcon = $($(event)[0].target);
            if (sourceIcon.prop('tagName') !== 'I' || !sourceIcon.hasClass('fa')) {
                sourceIcon = sourceIcon.find('i.fa');
            }
            if (sourceIcon.hasClass('fa-angle-down') || sourceIcon.hasClass('fa-angle-up')) {
                sourceIcon.toggleClass('fa-angle-down').toggleClass('fa-angle-up');
            }
        }
        // optional update a hidden field with state of toggled control - hidden field has id which is same as control being toggled followed by hidden e.g. myDivHidden
        var targetHiddenField = $('#' + id + 'hidden');
        if (targetHiddenField.length > 0) {

            if ($('#' + id).is(':visible')) {
                targetHiddenField.val('true');
            } else {
                targetHiddenField.val('false');
            }
            targetHiddenField.addClass('hidden');
        }
    },

    // Called from a button to toggle visiblility and then change the caption of the button
    //   button - is button being clicked
    //   id - id of UI element to hide
    //   visibleCaption - caption for button when UI element if visible
    //   hiddenCaption - caption for button when UI element if hidden
    // optional update a hidden field with state of toggled control - hidden field has id which is same as control being toggled followed by hidden e.g. myDivHidden
    UI_ShowHideToggleUpdateCaption: function (button, id, visibleCaption, hiddenCaption) {
        $('[id*=' + id + ']').toggleClass("hidden");
        var target = $('#' + id);
        if (target.is(':visible')) {
            $(button).html(visibleCaption);
        } else {
            $(button).html(hiddenCaption);
        }
        var targetHiddenField = $('#' + id + 'hidden');
        if (target.is(':visible')) {
            targetHiddenField.val('true');
        } else {
            targetHiddenField.val('false');
        }
        targetHiddenField.addClass("hidden");
    },


    // Called from a html link  to toggle visiblility and then change the caption of the link
    //   linkId - is the id of the link being clicked
    //   id - id of UI element to show or hide
    //   visibleCaption - caption for button when UI element if visible
    //   hiddenCaption - caption for button when UI element if hidden
    // optional update a hidden field with state of toggled control - hidden field has id which is same as control being toggled followed by hidden e.g. myDivHidden
    UI_ShowHideToggleLinkUpdateCaption: function (linkId, id, visibleCaption, hiddenCaption) {
        $('[id*=' + id + ']').toggleClass("hidden");
        var target = $('#' + id);
        if (target.is(':visible')) {
            $('#' + linkId).text(hiddenCaption);
        } else {
            $('#' + linkId).text(visibleCaption);
        }
        var targetHiddenField = $('#' + id + 'hidden');
        if (target.is(':visible')) {
            targetHiddenField.val('true');
        } else {
            targetHiddenField.val('false');
        }
        targetHiddenField.addClass("hidden");
    },

    // Toggles Visibility of a sub menu below a main nav item
    // works with Jarvis menu - see app.js
    // ev - event
    // menuItem - menu item clicked on
    // subMenuId - Id of sub menu to be toggled
    UI_MenuShowHide: function (ev, menuItem, subMenuId, controller, action, successCallback = null) {
        ev.preventDefault();
        var target = $('#Target' + subMenuId);
        var loadingGif = $('#Loading' + subMenuId);
        $(menuItem).removeClass();
        if (target.is(':visible')) {
            target.toggleClass("hidden");
            $(menuItem).addClass("fa fa-plus-square-o");
            ev.stopPropagation();
            return;
        }
        // we have the menu - just show it
        if (!target.is(':empty')) {
            target.toggleClass("hidden");
            $(menuItem).addClass("fa fa-minus-square-o");
            loadingGif.addClass("hidden");
            ev.stopPropagation();
            return;
        }

        // get the menu 
        loadingGif.toggleClass("hidden");
        $.ajax({
            url: "/" + controller + "/" + action,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (menu) {
                target.toggleClass("hidden");
                target.html(menu);
                $(menuItem).addClass("fa fa-minus-square-o");
                if (successCallback) {
                    target.ready(successCallback);
                }
                loadingGif.toggleClass("hidden");

            },
            error: function (jqXhr, textStatus, errorThrown) {
                loadingGif.toggleClass("hidden");
                Donorfy.ShowStandardAjaxErrorAlert(jqXhr, textStatus, errorThrown);
            }
        });

        ev.stopPropagation();
    },

    // handles click on in line menu in main nav, sets active status and then loads content
    UI_InLineMenuClick: function (ev, menuItem, id, entityType, controller, action, targetDiv, pleaseWait, useReplace, successCallback) {
        ev.preventDefault();
        $(".activeMenuItem").removeClass("activeMenuItem");
        menuItem.parentElement.parentElement.closest("li").classList.add("activeMenuItem");
        $('#left-menu li').removeClass('active');
        $(menuItem).parent().toggleClass('active');
        if (menuItem.hasAttribute('data-navurl') && menuItem.getAttribute('data-navurl') != null) {
            if (window.location.pathname.includes(menuItem.getAttribute('data-navurl'))) return;
            window.history.replaceState('', '', menuItem.getAttribute('data-navurl'));
        } else if (window.location.pathname !== '/') {
            window.history.pushState('', '', '/');
        }
        if (menuItem.hasAttribute('data-pagetitle')) {
            if (menuItem.getAttribute('data-pagetitle') != null) { document.title = menuItem.getAttribute('data-pagetitle'); }
        } else { document.title = "Donorfy" }

        if (useReplace) {
            Donorfy.AJAX_ReplaceContentForEntity(id, entityType, controller, action, targetDiv, pleaseWait);
        } else {
            Donorfy.AJAX_GetHTMLContentForEntity(id, entityType, controller, action, targetDiv, pleaseWait, successCallback);
        }
    },

    // Called from Select2 dropdown to format contact details in comms prefs 
    UI_CommsPref_FormatContactDetails: function (icon) {
        var originalOption = icon.element;
        return "<i class=\"fa " + $(originalOption).data('icon') + '"></i> ' + "&nbsp" + icon.text;
    },

    // Used when a group of controls should be displayed when a button etc is clicked 
    // Id of the required group is passed in - all other controls ending in Group are hidden
    UI_ShowRelatedGroup: function (id) {
        $("[id*=SubGroup] ").hide();
        $("#" + id).show();
    },

    // Makes selectedValue the selected item in the dropDown (select list passed)
    UI_SelectList_AssignSelected: function (dropDown, selectedValue) {
        $("#" + dropDown + " selected").removeClass("selected");
        $("#" + dropDown + " option").filter(function () {
            return $(this).text() == selectedValue;
        }).prop('selected', true);
    },

    // Used to make heights of items matching group passed the same
    // needed when displaying grids in panel style 
    UI_EqualHeight: function (group) {
        var tallest = 0;
        group.each(function () {
            var thisHeight = $(this).height();
            if (thisHeight > tallest) {
                tallest = thisHeight;
            }
        });
        group.height(tallest);
    },

    // Sets up the form when a manage button is clicked - e.g. recurring payment instructions
    //  id - id of current rpi
    //  manageFunction - function being selected - i.e. from UIHelper ManageFunctions
    UI_HandleManageDisplay: function (id, manageFunction) {
        $('#StdBtns' + id).addClass('hidden');
        $('#Upgrade' + id).addClass('hidden');
        $('#Pause' + id).addClass('hidden');
        $('#Cancel' + id).addClass('hidden');
        $('#Delete' + id).addClass('hidden');
        $('#DeleteItem' + id).addClass('hidden');
        $('#Reassign' + id).addClass('hidden');
        $('#SendDocument' + id).addClass('hidden');
        $('#Relodge' + id).addClass('hidden');
        $('#Notify' + id).addClass('hidden');
        $('#ChangeCollectionMethod' + id).addClass('hidden');

        if (manageFunction === "Reset") {
            $('#StdBtns' + id).removeClass('hidden');
        }
        if (manageFunction === "Upgrade") {
            $('#Upgrade' + id).removeClass('hidden');
        }
        if (manageFunction === "Pause") {
            $('#Pause' + id).removeClass('hidden');
        }
        if (manageFunction === "Cancel") {
            $('#Cancel' + id).removeClass('hidden');
        }
        if (manageFunction === "Delete") {
            $('#Delete' + id).removeClass('hidden');
        }
        if (manageFunction === "DeleteItem") {
            $('#DeleteItem' + id).removeClass('hidden');
        }
        if (manageFunction === "Reassign") {
            $('#Reassign' + id).removeClass('hidden');
        }
        if (manageFunction === "SendDocument") {
            $('#SendDocument' + id).removeClass('hidden');
        }
        if (manageFunction === "Relodge") {
            $('#Relodge' + id).removeClass('hidden');
        }
        if (manageFunction === "Notify") {
            $('#Notify' + id).removeClass('hidden');
        }
        if (manageFunction === "ChangeCollectionMethod") {
            $('#ChangeCollectionMethod' + id).removeClass('hidden');
        }
    },


    // display the confirmation message passed in - e.g. to confirm delete , if user responds yes 
    // the form is faded out and the action associated with the form is called
    UI_DisplayConfirmAction: function (confirmMessage, controller, action, closeForm, idparam, idvalue, confirmCallback, cancelCallback) {

        var defaultCallback = function () {
            $('#Form' + idvalue).removeClass('animated fadeOutUp hidden');
        }

        $.SmartMessageBox({
            title: "<i class='fa fa-question-circle txt-color-orangeDark'>&nbsp</i>Please Confirm",
            content: confirmMessage,
            buttons: '[No][Yes]'

        }, function (ButtonPressed) {
            if (ButtonPressed == "Yes") {
                if (closeForm == "True") {
                    $('#Form' + idvalue).addClass('animated fadeOutUp');
                }

                if (typeof confirmCallback === "function") {
                    confirmCallback(idvalue, controller, action);
                } else {
                    Donorfy.AJAX_PerformOperation(idvalue, controller, '', action, null, defaultCallback);
                }
            } else if (typeof cancelCallback === "function") {
                cancelCallback();
            }
        });
    },



    // Called from button grid to submit request to prepare a report for the grid
    UI_PrintGrid: function (localId, gridId) {
        var gId = 'Grid' + gridId + 'xGrid';
        var grid = $('#' + gId).DataTable();
        var formId = "Form" + localId;
        var sortFieldNumber = grid.fnSettings().aaSorting[0][0];
        var sortDirection = grid.fnSettings().aaSorting[0][1];
        var sortFieldName = "";
        var facetSearchString = $('#FacetSearchString' + gridId).val();
        var i = 0;
        var columnsShown = new Array();
        $.each(grid.fnSettings().aoColumns, function (c) {
            if (grid.fnSettings().aoColumns[c].bVisible === true) {
                var colName = grid.fnSettings().aoColumns[c].sName;
                if (colName !== '') {
                    columnsShown = columnsShown.concat(colName);
                    if (i === sortFieldNumber) {
                        sortFieldName = colName;
                    }
                }
            }
            i++;
        });
        $('#' + formId).find('#SelectedFields').val(columnsShown);
        $('#' + formId).find('#SortBy').val(sortFieldName);
        $('#' + formId).find('#SortDirection').val(sortDirection);
        $('#' + formId).find('#ExportFacetsSelected').val(facetSearchString);
        Donorfy.AJAX_PerformOperation(localId, 'Action', '', 'AddListPrintAction');
    },

    // Called from grid download
    UI_ExportGrid: function (localId, gridId) {
        var gId = 'Grid' + gridId + 'xGrid';
        var grid = $('#' + gId).DataTable();
        var formId = "Form" + localId;
        var sortFieldNumber = 0;
        var sortDirection = 'asc';
        var columnsShown = new Array();
        var sortFieldName = "";
        var i = 0;
        var facetSearchString = $('#FacetSearchString' + gridId).val();
        try {
            sortFieldNumber = grid.fnSettings().aaSorting[0][0];
            sortDirection = grid.fnSettings().aaSorting[0][1];
            $.each(grid.fnSettings().aoColumns,
                function (c) {
                    if (grid.fnSettings().aoColumns[c].bVisible === true) {
                        var colName = grid.fnSettings().aoColumns[c].sName;
                        if (colName !== '') {
                            columnsShown = columnsShown.concat(colName);
                            if (i === sortFieldNumber) {
                                sortFieldName = colName;
                            }
                        }
                    }
                    i++;
                });
        }
        catch (ex) {
        }

        $('#' + formId).find('#SelectedFields').val(columnsShown);
        $('#' + formId).find('#SortBy').val(sortFieldName);
        $('#' + formId).find('#SortDirection').val(sortDirection);
        $('#' + formId).find('#ExportFacetsSelected').val(facetSearchString);
        Donorfy.AJAX_PerformOperation(localId, 'Action', '', 'AddListDownloadAction');
    },

    // Handles the sign out request 
    UI_SignOut: function () {
        $.ajax({
            url: "/Account/LogOff",
            type: 'post',
            success: function (data) {
                localStorage.setItem('DonorfySessionEnd', JSON.stringify(true));
                localStorage.removeItem('DonorfySessionEnd');
                Donorfy.AJAX_HandleResponse_RedirectToURL(data.ReloadUrl);
            },
            error: function () {
                Donorfy.AJAX_HandleResponse_RedirectToURL("/Home/Error");
            }
        });
    },

    // used when an on / off switch is used to toggle a hidden field
    // hiddenField - id of hidden field containing the model value 
    // checkbox - id of checkbox which is toggled by the on off switch
    // divToShowHide - optional id of div which should be shown or hidden when the switch is toggled
    // reverseValue - store the switch value reversed in the hidden field
    UI_ToggleSwitch: function (hiddenField, checkbox, divToShowHide, reverseValue) {
        var cbox = $('#' + checkbox);
        var ctrl = $('#' + hiddenField);

        if (reverseValue) {
            if (cbox.is(':checked'))
                ctrl.val('false');
            else ctrl.val('true');
        } else {
            if (cbox.is(':checked'))
                ctrl.val('true');
            else ctrl.val('false');
        }



        if (divToShowHide !== undefined && divToShowHide !== 'undefined' && divToShowHide !== '') {
            if (cbox.is(':checked')) {
                $('#' + divToShowHide).show();
            } else {
                $('#' + divToShowHide).hide();
            }
        }
    },

    // Checks whether the current session is still active
    // If session is not longer active notify any other browser tabs and sign out
    UI_CheckForSessionTimeOut: function () {
        $.ajax({
            url: "/Session/Status",
            type: 'get',
            success: function (data) {
                if (data.IsSuccess === false) {
                    localStorage.setItem('DonorfySessionTimeOut', JSON.stringify(true));
                    localStorage.removeItem('DonorfySessionTimeOut');
                    Donorfy.AJAX_HandleResponse_RedirectToURL("/Account/SessionTimeOut");
                }
            }
        });
    },

    // If the user signs out or if another browser tab
    // has timed out this will sign out of the other open tabs
    UI_CheckForSessionEndNotification: function (ev) {
        if (ev.key === 'DonorfySessionTimeOut') {
            Donorfy.AJAX_HandleResponse_RedirectToURL("/Account/SessionTimeOut");
        }
        if (ev.key === 'DonorfySessionEnd') {
            Donorfy.AJAX_HandleResponse_RedirectToURL("/Account/LogOffConfirmed");
        }
    },
    ////////////////////////////////////////////////////////////////////////
    // Tasks
    ////////////////////////////////////////////////////////////////////////

    //switches task to complete from reminders box
    UI_CompleteTask: function (id) {

        $.ajax({
            url: "/Users/CompleteTask?id=" + id,
            type: "POST",
            success: function (data) {
                Donorfy.UpdateTaskUI(data);
            }
        });
    },
    RefreshTaskUI: function () {
        $.ajax({
            url: "/Users/GetTaskCounts",
            type: "GET",
            success: function (data) {
                Donorfy.UpdateTaskUI(data);
            }
        });
    },
    UpdateTaskUI: function (data) {

        if (data.IsSuccess) {

            Donorfy.UpdateTaskBadge("tasks-badge", data);
            Donorfy.UpdateTaskBadge("tasks-profile-badge", data);
            $("#OverdueTasksCount").text(data.OverdueTasksCount);
            $("#TodayTasksCount").text(data.TodayTasksCount);
            $("#UpcomingTasksCount").text(data.UpcomingTasksCount);

            Donorfy.RefreshTaskList();
        }
    },
    UpdateTaskBadge: function (badgeId, taskData) {

        $("#" + badgeId).text(taskData.BadgeCount);
        if (taskData.BadgeCount > 0) {
            $("#" + badgeId).show();
            $("#" + badgeId).removeClassPrefix("bg-color-");

            if (taskData.OverdueTasksCount > 0) {
                $("#" + badgeId).addClass("bg-color-red");
            } else {
                $("#" + badgeId).addClass("bg-color-orange");
            }
        } else {
            $("#" + badgeId).hide();
        }

    },
    LoadTaskList: function (tasksType) {

        $.ajax({
            url: "/Users/TaskList?type=" + tasksType,
            dataType: "html",
            type: "GET",
            beforeSend: function () {
                $(".task-list").html("<h1><i class='fa fa-cog fa-spin'></i> Loading...</h1>");
            },
            success: function (data) {
                $(".task-list").css({
                    opacity: "0.0"
                }).html(data).delay(50).animate({
                    opacity: "1.0"
                }, 300);

                //show caption if required
                if (!$.trim($("#reminder-footer-text").val()).length) {
                    $(".reminder-footer-caption").hide();
                } else {
                    $(".reminder-footer-caption").text($("#reminder-footer-text").val());
                    $(".reminder-footer-caption").show();
                }
            },
            error: function (jqXhr, textStatus, errorThrown) {
                $(".task-list").html("<h4><i class='fa fa-warning txt-color-orangeDark'></i> Error 404! Page not found.</h4>");
            },
            async: false
        });
    },
    RefreshTaskList: function () {
        var tasksType = $(".reminders-box .active > input").val();
        Donorfy.LoadTaskList(tasksType);

        if (typeof window.UpdateTaskBadge == 'function') {
            window.UpdateTaskBadge.call();
        }

    },
    ShowTaskList: function () {
        if (!$('#reminders-box').is(':visible')) {
            $('#reminders-box').fadeIn(150);
            setTimeout(function () {
                if (!$.trim($('#task-list').html()).length) {
                    Donorfy.RefreshTaskList();
                }
            }, 500);

        } else {
            $('#reminders-box').fadeOut(150);
        }
    },
    // Called from add menu on timeline tabe to allow addition of new time line entry  
    TaskList_Add: function (controller, action, idParam, idValue, paramName1, paramValue1, paramName2, paramValue2, paramName3, paramValue3, paramName4, paramValue4, paramName5, paramValue5) {
        Donorfy.GetAddContainer(controller, action, idParam, idValue, paramName1, paramValue1, paramName2, paramValue2, paramName3, paramValue3, paramName4, paramValue4, paramName5, paramValue5, 'task_add');
    },
    GetAddContainer: function (controller, action, idParam, idValue, paramName1, paramValue1, paramName2, paramValue2, paramName3, paramValue3, paramName4, paramValue4, paramName5, paramValue5, containerId) {
        var addContainer = $('#' + containerId);
        addContainer.removeClass('hidden');
        var urlString = idParam + "=" + idValue;
        if (paramName1 != "") { urlString = urlString + "&" + paramName1 + "=" + paramValue1; }
        if (paramName2 != "") { urlString = urlString + "&" + paramName2 + "=" + paramValue2; }
        if (paramName3 != "") { urlString = urlString + "&" + paramName3 + "=" + paramValue3; }
        if (paramName4 != "") { urlString = urlString + "&" + paramName4 + "=" + paramValue4; }
        if (paramName5 != "") { urlString = urlString + "&" + paramName5 + "=" + paramValue5; }
        $.ajax({
            url: "/" + controller + "/" + action + "?" + urlString,
            type: 'GET',
            cache: false,
            datatype: 'html',
            success: function (popUpForm) {
                addContainer.show();
                addContainer.html(popUpForm);
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });
    },
    SaveConfirmMessage: function (confirmMessage, confirmMessageDivId, id) {

        if (confirmMessage !== "" && Modernizr.localstorage) {
            //save confirm message in local storage for display after reload
            var messageItem = {
                ConfirmMessage: confirmMessage,
                ConfirmMessageDivId: confirmMessageDivId,
                Entered: new Date().getTime(),
                Id: id
            }
            localStorage.setItem("Donorfy_ConfirmMessage", JSON.stringify(messageItem));
        }
    },
    LoadConfirmMessage: function () {

        if (Modernizr.localstorage) {

            var message = localStorage.getItem("Donorfy_ConfirmMessage");
            if (message) {
                var messageData = JSON.parse(message);
                var diff = new Date().getTime() - messageData.Entered;
                if ((diff / 1000) < 60) {
                    //check confirm message occurred a maximum of 60 secs ago
                    Donorfy.DisplayConfirmMessage(messageData, messageData.Id);
                }
                localStorage.removeItem("Donorfy_ConfirmMessage");
            }
        }

    },
    DisplayConfirmMessageText: function (confirmDivId, text) {
        var data = { "ConfirmMessageDivId": confirmDivId, "ConfirmMessage": text };
        Donorfy.DisplayConfirmMessage(data, null);
    },
    DisplayConfirmMessage: function (data, id) {

        if (!data || !data.ConfirmMessage || data.ConfirmMessage === "") {
            return;
        }

        var confirmMessageDiv = Donorfy.GetMessageDiv(data, id, true);

        if (confirmMessageDiv == null || confirmMessageDiv.length === 0) {
            //can't find any confirm divs
            return;
        }

        var confirmMessage = Donorfy.GetMessageElement(confirmMessageDiv, id, true);

        if (confirmMessage == null || confirmMessage.length === 0) {
            //can't find any message div
            return;
        }

        confirmMessageDiv.show();
        confirmMessageDiv.removeClass("hidden");
        confirmMessage.html(data.ConfirmMessage);
    },
    DisplayErrorMessageText: function (errorDivId, text) {
        var data = { "ErrorMessageDivId": errorDivId, "ErrorMessage": text };
        Donorfy.DisplayErrorMessage(data, null);
    },
    DisplayErrorMessage: function (data, id) {

        if (!data || !data.ErrorMessage || data.ErrorMessage === "") {
            return;
        }

        var errorMessageDiv = Donorfy.GetMessageDiv(data, id, false);

        if (errorMessageDiv.length === 0) {
            //can't find any error divs
            return;
        }

        var errorMessage = Donorfy.GetMessageElement(errorMessageDiv, id, false);

        if (errorMessage.length === 0) {
            //can't find an error message div
            return;
        }

        errorMessageDiv.show();
        errorMessageDiv.removeClass("hidden");
        errorMessage.html(data.ErrorMessage);
    },
    GetMessageDiv: function (data, id, showConfirm) {

        var messageDiv;

        var divId = showConfirm ? data.ConfirmMessageDivId : data.ErrorMessageDivId;

        if (divId) {
            messageDiv = $("#" + divId);
            if (messageDiv.length > 0) { return messageDiv; }
        }

        var divName = showConfirm ? "ConfirmMsgDiv" : "ErrMsgDiv";

        if (id) {
            messageDiv = $("#" + divName + id);
            if (messageDiv.length > 0) { return messageDiv; }
        }

        //use main div if no confirm div found
        return $("#" + divName + "MainForm");

    },
    GetMessageElement: function (messageDiv, id, showConfirm) {
        if (messageDiv.length === 0) {
            return $([]);
        }

        var className = showConfirm ? "confirm-message" : "error-message";

        var messageElement = messageDiv.find("." + className);
        if (messageElement.length > 0) { return messageElement; }

        var divName = showConfirm ? "ConfirmMsg" : "ErrMsg";

        if (id) {
            messageElement = messageDiv.find("#" + divName + id);
            if (messageElement.length > 0) {
                return messageElement;
            }
        }
        return messageDiv.find("#" + divName);

    },
    GetSelectedFacets: function (gridId) {

        var selectedFacetValues = [];

        var facetDivs = $("#FieldList" + gridId + " > div.col:not(.hidden)");

        // get list of facet values selected from checkboxes
        facetDivs.find(".facet-checkbox input:checked").each(function (i, item) {
            if ($(item).attr('id')) {
                selectedFacetValues.push($(item).attr('id'));
            }
        });


        // get list of facet values selected from any selects
        facetDivs.find("select.facet-select").each(function (i, item) {
            if ($(item).val()) {
                selectedFacetValues.push($(item).val());
            }
        });


        facetDivs.find(".facet-value input").each(function (i, item) {
            if ($(item).val()) {

                var facetValue = $(item).attr("name") + ":" + $(item).val().replace("&", "§");
                selectedFacetValues.push(facetValue);
            }
        });

        return selectedFacetValues;
    },
    LoadRecentItems: function () {

        $.ajax({
            url: "/Users/RecentItems",
            type: "get",
            cache: false,
            datatype: "html",
            success: function (data) {
                $("#RecentItems").replaceWith(data);
            },
            error: Donorfy.ShowStandardAjaxErrorAlert
        });

    },
    UI_SwapStatusButton: function (btn, id) {
        var noBtnId = 'no' + id;
        var yesBtnId = 'yes' + id;


        $(btn).addClass('hidden');
        if ($(btn).data('status') === "yes") {
            $('#' + id).val('false');
            $('#' + noBtnId).removeClass('hidden');
        } else {
            $('#' + id).val('true');
            $('#' + yesBtnId).removeClass('hidden');
        }
        return false;
    },

    // used to highlight a checkbox when it gets focused
    UI_FocusCheckbox: function (controlId) {
        $('#' + controlId).css('padding', '1px');
        $('#' + controlId).css('padding-left', '5px');
        $('#' + controlId).css('border-color', '#5D98CC');
        $('#' + controlId).css('border-width', '1px');
        $('#' + controlId).css('border-style', 'solid');
    },

    // used to remove highlight from a checkbox when it loses focused
    UI_BlurCheckbox: function (controlId) {
        $('#' + controlId).css('border-style', 'none');
    },

    // Toggles the buttons between three states
    // Yes -> No No -> Unknown Unknown -> Yes 
    UI_SwapThreeStateButton: function (btn, id) {
        var noBtnId = 'No' + id;
        var yesBtnId = 'Yes' + id;
        var unknownBtnId = 'Unknown' + id;

        $(btn).addClass('hidden');
        if ($(btn).data('status') === "Yes") {
            $('#' + id).val('No');
            $('#' + noBtnId).removeClass('hidden');
        }
        if ($(btn).data('status') === "No") {
            $('#' + id).val('Unknown');
            $('#' + unknownBtnId).removeClass('hidden');
        }
        if ($(btn).data('status') === "Unknown") {
            $('#' + id).val('Yes');
            $('#' + yesBtnId).removeClass('hidden');
        }

        return false;
    },

    ResetToDefaults: function () {
        window.localStorage.clear();
        return true;
    },


    ListUsers_PerformOperation: function (listDefinitionId, userId, operation) {
        let targetUrl = '/List/ShowMenuListUser_Operation';
        targetUrl = targetUrl + "?listDefinitionId=" + listDefinitionId;
        targetUrl = targetUrl + "&operation=" + operation;
        targetUrl = targetUrl + "&userId=" + userId;
        $.ajax({
            url: targetUrl,
            type: 'post',
            datatype: "html",
            success: function (data) {
                //
            },
            error: function (jqXhr) {
                Donorfy.DisplayErrorMessageText(null, Donorfy.GetStandardAjaxErrorMessage(jqXhr));
            }
        });

    },

    Standard_DataTable: function (selector, options) {
        let iLength = parseInt(localStorage.getItem('GlobalGridLength'));
        if (!Number.isInteger(iLength)) {
            iLength = 15;
        }
        let settings = $.extend({},
            {
                aLengthMenu: [[15, 30, 90, 150], [15, 30, 90, 150]],
                sDom: "fip r<'dt-top-row'l>r<'dt-wrapper't>ip",
                sPaginationType: "bootstrap_full",
                iDisplayLength: iLength,
                bStateSave: true,
                oLanguage: {
                    sSearch: "Search:"
                },
                fnStateSave: function (oSettings, oData) {
                    localStorage.setItem('GlobalGridLength', oData.iLength);
                    delete oData.iLength;
                }
            },
            options);

        return selector.dataTable(settings);
    },
    FormatNumber: function (num) {
        if (num >= 1000) {
            return (num / 1000).toFixed(0) + 'k';
        }
        return num;
    },
    GetStandardAjaxErrorMessage: function (jqXhr) {
        return `Error: Donorfy was unable to complete this request, please refresh the page and try again.  If this issue persists please contact Donorfy Support. (${jqXhr.status})`;
    },
    ShowStandardAjaxErrorAlert(jqXhr, _, errorThrown) {
        alert(Donorfy.GetStandardAjaxErrorMessage(jqXhr, errorThrown));
    },
    UpdateCheckBoxIndeterminateState: function (chk, state) {
        chk.prop('indeterminate', state);
        if (state) {
            chk.addClass('indeterminate');
        } else {
            chk.removeClass('indeterminate');
        }
    }
};;
//
// (c) Donorfy Ltd 2020
// 
//  Javascript Functions for Forms
//
var DonorfyForms = {
    Mode: 'Live',
    Country: 'GB',
    Currency: 'gbp',
    StripeStatementText: '',
    StripePublicKey: '',
    PayPalClientId: '',
    PayPalStatementText: '',
    FormId: '',
    Stripe: null,
    Elements: null,
    PayPal: null,
    StripePaymentRequest: null,
    StripePaymentRequestButton: null,
    reCaptchaSiteKey: null,
    recaptchaTokenId: null,
    gclMinAmount: 1,
    stripeMinAmount: 0.3,
    localeCode: null,
    decimalSeparator: '.',
    isDonationForm: false,
    isMembershipForm: false,
    DonationHowGiveErrorText: 'Please choose how you want to give',
    ReCaptchaUrlSuffix: '',

    // Finds all controls in a div with the attribute data-heightsync and makes them the same height
    // NB the controls must be visible for this work
    DF_SyncControlHeights: function (containingDiv) {
        var heightToSet = 0;
        $("#" + containingDiv).find("[data-heightsync]").each(function () {
            if ($(this).height() > heightToSet) {
                heightToSet = $(this).height();
            }
        });

        $("#" + containingDiv).find("[data-heightsync]").each(function () {
            $(this).height(heightToSet);
        });
    },

    DF_SetUpPayPal: function () {
        if (DonorfyForms.PayPalClientId === undefined || DonorfyForms.PayPalClientId === "" || DonorfyForms.PayPalClientId === 'none') {
            $('#paypal-button-container').html('');
            return;
        }
        var email = $('#' + DonorfyForms.FormId).find('input[data-main-emailAddress="yes"]').val();
        var donAmt = $('#' + DonorfyForms.FormId).find('input[data-amount="yes"]').val();
        if (donAmt === undefined || donAmt === "" || donAmt === 'none') {
            $('#PayPalContainer').addClass('hidden');
            return;
        }

        if (donAmt === 0) {
            $('#PayPalContainer').addClass('hidden');
            return;
        }

        var uCurrency = DonorfyForms.Currency.toUpperCase();

        $('#PayPalContainer').removeClass('hidden');
        $('#otherPaymentMethodId').removeClass('hidden');

        $('#paypal-button-container').html('');

        DonorfyForms.PayPal = paypal.Buttons({
            createOrder: function (data, actions) {
                if (!jQuery('#' + DonorfyForms.FormId).valid()) {
                    return false;
                }
                return actions.order.create({
                    purchase_units: [{
                        amount: {
                            value: donAmt,
                            currency_code: uCurrency
                        },
                        soft_descriptorstring: DonorfyForms.PayPalStatementText
                        , description: DonorfyForms.PayPalStatementText
                    }]
                });
            },
            onApprove: function (data, actions) {
                return actions.order.capture().then(function (details) {
                    $('#' + DonorfyForms.FormId).find('input[data-method="yes"]').val('PayPal');
                    $('#' + DonorfyForms.FormId).find('#ExternalPaymentReference').val(details.id);
                    DonorfyForms.DF_PostForm('yes');
                });
            }
        }).render('#paypal-button-container');



    },

    DF_SetUpStripe: function () {
        if (DonorfyForms.StripePublicKey === undefined || DonorfyForms.StripePublicKey === "" || DonorfyForms.StripePublicKey === 'none') {
            $('#StripeCardDetails').html('');
            return;
        }

        var donAmt = $('#' + DonorfyForms.FormId).find('input[data-amount="yes"]').val();
        if (donAmt === undefined || donAmt === "" || donAmt === 'none') {
            $('#StripeCardDetails').addClass('hidden');
            if ($('#payment-request-button').length) {
                document.getElementById('payment-request-button').style.display = 'none';
            }
            return;
        }

        // convert amount to pence
        donAmt = Math.round(donAmt * 100);
        if (donAmt === 0) {
            $('#StripeCardDetails').addClass('hidden');
            if ($('#payment-request-button').length) {
                document.getElementById('payment-request-button').style.display = 'none';
            }
            return;
        }


        $('#StripeCardDetails').removeClass('hidden');

        if (DonorfyForms.Stripe === null) {
            DonorfyForms.Stripe = Stripe(DonorfyForms.StripePublicKey);
            DonorfyForms.Elements = DonorfyForms.Stripe.elements();

            window.cardNumber = DonorfyForms.Elements.create('cardNumber');
            window.cardNumber.mount('#card-number');

            window.cardExpiry = DonorfyForms.Elements.create('cardExpiry');
            cardExpiry.mount('#card-expiry');

            window.cardCvc = DonorfyForms.Elements.create('cardCvc');
            cardCvc.mount('#card-cvc');
        }

        if ($('#payment-request-button').length) {
            try {
                // Apply pay btn
                if (DonorfyForms.StripePaymentRequest === null) {
                    DonorfyForms.StripePaymentRequest = DonorfyForms.Stripe.paymentRequest({
                        country: DonorfyForms.Country,
                        currency: DonorfyForms.Currency,
                        total: {
                            label: DonorfyForms.StripeStatementText,
                            amount: donAmt
                        },
                        requestPayerName: true,
                        requestPayerEmail: true
                    });
                    DonorfyForms.StripePaymentRequestButton = DonorfyForms.Elements.create('paymentRequestButton', {
                        paymentRequest: DonorfyForms.StripePaymentRequest
                    });
                } else {
                    DonorfyForms.StripePaymentRequest.update({
                        total: {
                            label: DonorfyForms.StripeStatementText,
                            amount: donAmt
                        }
                    });
                }


                // Check the availability of the Payment Request API first.
                DonorfyForms.StripePaymentRequest.canMakePayment().then(function (result) {
                    if (result) {
                        DonorfyForms.StripePaymentRequestButton.mount('#payment-request-button');
                        $('#otherPaymentMethodId').removeClass('hidden');
                    } else {
                        document.getElementById('payment-request-button').style.display = 'none';
                    }
                });

                DonorfyForms.StripePaymentRequest.on('paymentmethod',
                    function (ev) {
                        DonorfyForms.DF_ValidateStripeApplePayRequest(ev);
                    });

                document.getElementById('payment-request-button').style.display = 'none';
                var paymentMethod = $('#' + DonorfyForms.FormId).find('input[data-frequency="yes"]').val();
                if (paymentMethod === 'DonationStripeOneOff') {
                    document.getElementById('payment-request-button').style.display = '';
                }

            } catch (e) {
                console.log('DF_SetUpStripe ' + e);
            }
        }
    },

    DF_PostForm: function (success) {
        var formContainerId = "formContainer" + DonorfyForms.FormId;
        var tenantCode = $('#' + DonorfyForms.FormId).find('#TenantCode').val();
        if (success === 'yes') {
            $("#" + formContainerId).find('[data-submitPleaseWait]').removeClass('hidden');
            DonorfyForms.DF_ResetErrorMessage();
            DonorfyForms.DF_DisableSubmitButton();

            grecaptcha.ready(() => {
                grecaptcha.execute(DonorfyForms.reCaptchaSiteKey, { action: tenantCode + '_' + DonorfyForms.ReCaptchaUrlSuffix + '_PostForm' }).then(function (token) {
                    $('#' + DonorfyForms.recaptchaTokenId).val(token);
                    document.getElementById(DonorfyForms.FormId).submit();
                });
            });
        } else {
            DonorfyForms.DF_EnableSubmitButton();
            DonorfyForms.DF_DisplayErrorMessage();
        }
    },

    DF_AddStyleAttribute: function ($element, styleAttribute) {
        if (typeof $element.attr('style') === typeof undefined) {
            $element.attr('style', styleAttribute);
        } else {
            $element.attr('style', $element.attr('style') + '; ' + styleAttribute);
        }
    },

    DF_ResetErrorMessage: function () {
        var formContainerId = "formContainer" + DonorfyForms.FormId;
        $("#" + formContainerId).find('[data-SubmitErrors]').html('');
        $("#" + formContainerId).find('[data-SubmitErrorContainer]').hide();
    },

    DF_ValidateForm: function () {
        DonorfyForms.DF_ResetErrorMessage();
        $('#' + DonorfyForms.FormId + ' [id=AmountError]').addClass('hidden');
        $('#' + DonorfyForms.FormId + ' [id=FreqError]').addClass('hidden');
        $('#' + DonorfyForms.FormId + ' [id=MinimumAmountError]').addClass('hidden');

        var worked = 'no';
        var result = false;
        var paymentMethod = "";
        var donationChecks = DonorfyForms.DF_ValidateDonation(0);

        if (DonorfyForms.isDonationForm) {

            paymentMethod = $('#' + DonorfyForms.FormId).find('input[data-method="yes"]').val();

            if (paymentMethod === undefined || paymentMethod === "") {
                paymentMethod = $('#' + DonorfyForms.FormId).find('input[data-frequency="yes"]').val();

                if (paymentMethod.startsWith('DonationGoCardless')) {
                    paymentMethod = "GoCardless";
                }
                if (paymentMethod.startsWith('DonationStripe')) {
                    paymentMethod = "Stripe";
                }
            }

            if (paymentMethod === undefined || paymentMethod === "") {
                DonorfyForms.DF_DisplayErrorMessage(DonorfyForms.DonationHowGiveErrorText, 'yes');
                return false;
            }
        }

        if (DonorfyForms.isMembershipForm) {
            paymentMethod = $('#' + DonorfyForms.FormId).find('input[data-method="yes"]').val();
        }

        if (paymentMethod.startsWith('Stripe')) {
            var stripeChecks = false;
            donationChecks = DonorfyForms.DF_ValidateDonation(DonorfyForms.stripeMinAmount);
            if (donationChecks) {
                stripeChecks = DonorfyForms.DF_ValidateStripeRequest();
            }
            // return donationChecks && stripeChecks;
            if (donationChecks && stripeChecks) {
                worked = 'yes';
                result = true;
            }
            DonorfyForms.DF_PostForm(worked);
            return result;
        }
        if (paymentMethod.startsWith('GoCardless')) {
            var gclChecks = false;
            donationChecks = DonorfyForms.DF_ValidateDonation(DonorfyForms.gclMinAmount);
            if (donationChecks) {
                gclChecks = DonorfyForms.DF_ValidateGCLRequest();
            }
            // return donationChecks && gclChecks;
            if (donationChecks && gclChecks) {
                worked = 'yes';
                result = true;
            }
            DonorfyForms.DF_PostForm(worked);
            return result;
        }

        if (paymentMethod.startsWith('ApplePay')) {
            var stripeChecks = false;
            donationChecks = DonorfyForms.DF_ValidateDonation(DonorfyForms.stripeMinAmount);
            if (donationChecks) {
                stripeChecks = DonorfyForms.DF_ValidateStripeRequest();
            }
            // return donationChecks && stripeChecks;
            if (donationChecks && stripeChecks) {
                worked = 'yes';
                result = true;
            }
            DonorfyForms.DF_PostForm(worked);
            return result;
        }

        if (paymentMethod.startsWith('PayPal')) {
            worked = 'yes';
            result = true;
            DonorfyForms.DF_PostForm(worked);
            return result;
        }

        var mainChecks = jQuery('#' + DonorfyForms.FormId).valid();

        if (mainChecks && donationChecks) {
            worked = 'yes';
            result = true;
        }
        DonorfyForms.DF_PostForm(worked);
        return result;
    },

    DF_ValidateGCLRequest: function () {
        if (jQuery('#' + DonorfyForms.FormId).valid()) {
            try {
                DonorfyForms.DF_DisableSubmitButton();
                jQuery.ajax({
                    dataType: 'json',
                    url: DonorfyForms.DF_GetGoCardlessBaseServiceUrl() + 'DirectDebitSetUp',
                    data: DonorfyForms.DF_GetGCLPostData(),
                    method: 'POST',
                    type: 'POST'
                }).done(function (data) {
                    if (data.OK) {
                        $('#GoCardlessSetUpLink').val(data.RedirectUrl);
                        $('#' + DonorfyForms.FormId).find('input[data-method="yes"]').val('GoCardless');
                        DonorfyForms.DF_PostForm('yes');
                        return true;
                    } else {
                        DonorfyForms.DF_DisplayErrorMessage(data.Errors, 'yes');
                        DonorfyForms.DF_PostForm('no');
                        return false;
                    }

                }).fail(function (jqXHR, textStatus, errorThrown) {
                    DonorfyForms.DF_DisplayErrorMessage(DonorfyForms.DF_GetErrorArray(jqXHR));
                    DonorfyForms.DF_PostForm('no');
                    return false;
                });

            } catch (e) {
                console.log('ValidateGCL Requestexception ' + e);
                DonorfyForms.DF_PostForm('no');
                return false;
            }
        } else {
            DonorfyForms.DF_PostForm('no');
            return false;
        }
    },

    DF_GetGCLPostData: function () {
        var localAmt = $('#' + DonorfyForms.FormId).find('input[data-amount="yes"]').val();

        var localMdl = {
            title: $('#' + DonorfyForms.FormId).find('input[data-title="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-title="yes"]').val() : '',
            firstName: $('#' + DonorfyForms.FormId).find('input[data-firstname="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-firstname="yes"]').val() : '',
            lastName: $('#' + DonorfyForms.FormId).find('input[data-lastname="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-lastname="yes"]').val() : '',
            email: $('#' + DonorfyForms.FormId).find('input[data-main-emailAddress="yes"]').val(),
            address1: $('#' + DonorfyForms.FormId).find('input[data-address1="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-address1="yes"]').val() : '',
            address2: $('#' + DonorfyForms.FormId).find('input[data-address2="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-address2="yes"]').val() : '',
            town: $('#' + DonorfyForms.FormId).find('input[data-addressTown="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-addressTown="yes"]').val() : '',
            county: $('#' + DonorfyForms.FormId).find('input[data-addressCounty="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-addressCounty="yes"]').val() : '',
            postCode: $('#' + DonorfyForms.FormId).find('input[data-addressPostCode="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-addressPostCode="yes"]').val() : '',
            amount: localAmt,
            tenantCode: $('#' + DonorfyForms.FormId).find('#TenantCode').val(),
            widgetId: $('#' + DonorfyForms.FormId).find('#ParentFormId').val(),
            paymentSchedule: 'Monthly',
            FormRenderId: $('#' + DonorfyForms.FormId).find('#FormRenderId').val()
        };

        return localMdl;
    },

    DF_ValidateDonation: function (minAmount) {
        $('#' + DonorfyForms.FormId + ' [id=AmountError]').addClass('hidden');
        $('#' + DonorfyForms.FormId + ' [id=FreqError]').addClass('hidden');
        $('#' + DonorfyForms.FormId + ' [id=MinimumAmountError]').addClass('hidden');

        var valid = true;

        var amount = $('#' + DonorfyForms.FormId).find('input[data-amount="yes"]').val();

        if (amount === undefined) {
            return true;
        }

        // there is an amount field 
        if ($('#' + DonorfyForms.FormId).find('input[data-amount="yes"]').length) {
            // ..but nothing entered
            if (amount === undefined || amount === "" || amount === "0") {
                $('#' + DonorfyForms.FormId + ' [id=AmountError]').removeClass('hidden');
                $("#" + DonorfyForms.FormId).find('#ErrorContainer').css('display', 'none');
                valid = false;
            }
            else {
                if (minAmount !== 0 && amount < minAmount) {
                    $('#' + DonorfyForms.FormId + ' [id=MinimumAmountError]').removeClass('hidden');
                    $('#' + DonorfyForms.FormId + ' [id=MinimumAmountError]').text('Minimum amount is ' +
                        new Intl.NumberFormat(DonorfyForms.localeCode, { style: 'currency', currency: DonorfyForms.Currency }).format(minAmount));
                    $("#" + DonorfyForms.FormId).find('#ErrorContainer').css('display', 'none');
                    valid = false;
                }
            }
        }

        // there is a frequency field but nothing selected
        if ($('#' + DonorfyForms.FormId).find('input[data-frequency="yes"]').length && $('#' + DonorfyForms.FormId).find('input[data-frequency="yes"]').val() === '') {
            $('#' + DonorfyForms.FormId + ' [id=FreqError]').removeClass('hidden');
            valid = false;
        }
        return valid;
    },

    // Validates and processes Apple Pay via Stripe  
    DF_ValidateStripeApplePayRequest: function (ev) {
        if (jQuery('#' + DonorfyForms.FormId).valid()) {
            var code = $('#' + DonorfyForms.FormId).find('#TenantCode').val();
            var email = $('#' + DonorfyForms.FormId).find('input[data-main-emailAddress="yes"]').val();
            var recurring = false;
            if ($('#' + DonorfyForms.FormId).find('input[data-frequency="yes"]').val() === 'DonationStripeRecurringMonthly') {
                recurring = true;
            }

            var isMembership = $('#' + DonorfyForms.FormId).find('#IsMembershipForm').val();
            if (isMembership === 'yes') {
                recurring = true;
            }

            var id = $('#' + DonorfyForms.FormId).find('#ParentFormId').val();
            var amount = $('#' + DonorfyForms.FormId).find('input[data-amount="yes"]').val();

            // convert amount to pence
            amount = amount * 100;

            var formContainerId = "formContainer" + DonorfyForms.FormId;
            var tenantCode = $('#' + DonorfyForms.FormId).find('#TenantCode').val();
            try {
                grecaptcha.ready(function () {
                    grecaptcha.execute(DonorfyForms.reCaptchaSiteKey, { action: tenantCode + '_' + DonorfyForms.ReCaptchaUrlSuffix + '_ValidateStripeApplePayRequest' }).then(function (token) {
                        DonorfyForms.DF_DisableSubmitButton();
                        let body = { id: id, code: code, amount: amount, email: email, rec: recurring, token: token }
                       jQuery.ajax({
                           dataType: 'json',
                           url: DonorfyForms.DF_GetStripeBaseServiceUrl() + 'P1a',
                           method: 'POST',
                           type: 'POST',
                           data:body
                        }).done(function (data) {
                            if (data.OK) {
                                $("#" + formContainerId).find('[data-submitbtn]').attr('data-secret', data.RequestData);
                                DonorfyForms.Stripe.confirmCardPayment(data.RequestData,
                                    { payment_method: ev.paymentMethod.id },
                                    { handleActions: false }
                                ).then(function (confirmResult) {
                                    if (confirmResult.error) {
                                        jQuery('#' + DonorfyForms.FormId).valid();
                                        DonorfyForms.DF_DisplayErrorMessage(confirmResult.error.message, 'yes');
                                        DonorfyForms.DF_PostForm('no');
                                        ev.complete('fail');
                                        return false;
                                    } else {
                                        $('#' + DonorfyForms.FormId).find('#StripePaymentIntentId').val(confirmResult.paymentIntent.id);
                                        DonorfyForms.DF_PostForm('yes');
                                        ev.complete('success');
                                        // Check if the PaymentIntent requires any actions and if so let Stripe.js
                                        // handle the flow. If using an API version older than "2019-02-11" instead
                                        // instead check for: `paymentIntent.status === "requires_source_action"`.
                                        if (confirmResult.paymentIntent.status === "requires_action") {
                                            // Let Stripe.js handle the rest of the payment flow.
                                            DonorfyForms.Stripe.confirmCardPayment(data.RequestData).then(
                                                function (result) {
                                                    if (result.error) {
                                                        // The payment failed -- ask your customer for a new payment method.
                                                        jQuery('#' + DonorfyForms.FormId).valid();
                                                        DonorfyForms.DF_DisplayErrorMessage(confirmResult.error.message, 'yes');
                                                        DonorfyForms.DF_PostForm('no');
                                                        return false;
                                                    } else {
                                                        // The payment has succeeded.
                                                        $('#' + DonorfyForms.FormId).find('#StripePaymentIntentId').val(result.paymentIntent.id);
                                                        $('#' + DonorfyForms.FormId).find('input[data-method="yes"]').val('ApplePay');
                                                        DonorfyForms.DF_PostForm('yes');
                                                        return true;
                                                    }
                                                });
                                        } else {
                                            // The payment has succeeded.
                                            $('#' + DonorfyForms.FormId).find('#StripePaymentIntentId').val(result.paymentIntent.id);
                                            DonorfyForms.DF_PostForm('yes');
                                            return true;
                                        }
                                        return true;
                                    }
                                });
                            }
                        }).fail(function (jqXHR, textStatus, errorThrown) {
                            console.log('DF_ValidateStripeApplePayRequest jqXHR ' + jqXHR);
                            DonorfyForms.DF_DisplayErrorMessage(DonorfyForms.DF_GetErrorArray(jqXHR));
                            DonorfyForms.DF_PostForm('no');
                            return false;
                        });
                    });
                });
            } catch (e) {
                console.log('Exception in DF_ValidateStripeApplePayRequest ' + e);
                DonorfyForms.DF_PostForm('no');
                return false;
            }
        }
        else {
            DonorfyForms.DF_PostForm('no');
            return false;
        }
    },

    // Validates and processes Stripe payment card 
    DF_ValidateStripeRequest: function () {
        if (jQuery('#' + DonorfyForms.FormId).valid()) {
            var code = $('#' + DonorfyForms.FormId).find('#TenantCode').val();
            var email = $('#' + DonorfyForms.FormId).find('input[data-main-emailAddress="yes"]').val();
            var recurring = false;
            if ($('#' + DonorfyForms.FormId).find('input[data-frequency="yes"]').val() === 'DonationStripeRecurringMonthly') {
                recurring = true;
            }

            var isMembership = $('#' + DonorfyForms.FormId).find('#IsMembershipForm').val();
            if (isMembership === 'yes') {
                recurring = true;
            }

            var id = $('#' + DonorfyForms.FormId).find('#ParentFormId').val();
            var amount = $('#' + DonorfyForms.FormId).find('input[data-amount="yes"]').val();

            // convert amount to pence
            amount = Math.round(amount * 100);

            var firstName = $('#' + DonorfyForms.FormId).find('input[data-firstname="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-firstname="yes"]').val() : '';
            var lastName = $('#' + DonorfyForms.FormId).find('input[data-lastname="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-lastname="yes"]').val() : '';
            var town = $('#' + DonorfyForms.FormId).find('input[data-addressTown="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-addressTown="yes"]').val() : '';
            var address2 = $('#' + DonorfyForms.FormId).find('input[data-address2="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-address2="yes"]').val() : '';
            var address1 = $('#' + DonorfyForms.FormId).find('input[data-address1="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-address1="yes"]').val() : '';
            var postcode = $('#' + DonorfyForms.FormId).find('input[data-addressPostCode="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-addressPostCode="yes"]').val() : '';
            var county = $('#' + DonorfyForms.FormId).find('input[data-addressCounty="yes"]').length > 0 ? $('#' + DonorfyForms.FormId).find('input[data-addressCounty="yes"]').val() : '';

            var formContainerId = "formContainer" + DonorfyForms.FormId;
            var tenantCode = $('#' + DonorfyForms.FormId).find('#TenantCode').val();
            try {
                grecaptcha.ready(function () {
                    grecaptcha.execute(DonorfyForms.reCaptchaSiteKey, { action: tenantCode + '_' + DonorfyForms.ReCaptchaUrlSuffix + '_ValidateStripeRequest' }).then(function (token) {
                        DonorfyForms.DF_DisableSubmitButton();
                        let body = { id: id, code: code, amount: amount, email: email, rec: recurring, token: token }
                       jQuery.ajax({
                           dataType: 'json',
                           url: DonorfyForms.DF_GetStripeBaseServiceUrl() + 'P1a',
                           method: 'POST',
                           type: 'POST',
                           data: body
                        }).done(function (data) {
                            if (data.OK) {
                                $("#" + formContainerId).find('[data-submitbtn]').attr('data-secret', data.RequestData);
                                DonorfyForms.Stripe.handleCardPayment(data.RequestData,
                                    cardNumber,
                                    {
                                        save_payment_method: recurring,
                                        receipt_email: email,
                                        payment_method_data: {
                                            billing_details: {
                                                name: firstName + ' ' + lastName,
                                                email: email,
                                                address: {
                                                    city: town,
                                                    line1: address1,
                                                    line2: address2,
                                                    postal_code: postcode,
                                                    state: county
                                                }
                                            }
                                        }
                                    }).then(function (result) {
                                        if (result.error) {
                                            jQuery('#' + DonorfyForms.FormId).valid();
                                            DonorfyForms.DF_DisplayErrorMessage(result.error.message, 'yes');
                                            DonorfyForms.DF_PostForm('no');
                                            return false;
                                        } else {
                                            $('#' + DonorfyForms.FormId).find('#StripePaymentIntentId').val(result.paymentIntent.id);
                                            $('#' + DonorfyForms.FormId).find('input[data-method="yes"]').val('Stripe');
                                            DonorfyForms.DF_PostForm('yes');
                                            return true;
                                        }
                                    });
                            }
                        }).fail(function (jqXHR, textStatus, errorThrown) {
                            console.log('ProcessStripeRequest jqXHR ' + jqXHR);
                            DonorfyForms.DF_DisplayErrorMessage(DonorfyForms.DF_GetErrorArray(jqXHR));
                            DonorfyForms.DF_PostForm('no');
                            return false;
                        });
                    });
                });
            } catch (e) {
                console.log('Exception in ProcessStripeRequest ' + e);
                DonorfyForms.DF_PostForm('no');
                return false;
            }
        }
        else {
            DonorfyForms.DF_PostForm('no');
            return false;
        }
    },

    DF_EnableSubmitButton: function () {
        var formContainerId = "formContainer" + DonorfyForms.FormId;
        $('#' + formContainerId).find('[data-submitbtn]').removeAttr('disabled');
        $('#' + formContainerId).find('[data-submitbtn]').button('reset');
        $('#' + formContainerId).find('[data-submitPleaseWait]').hide();
    },

    DF_DisableSubmitButton: function () {
        var formContainerId = "formContainer" + DonorfyForms.FormId;
        $('#' + formContainerId).find('[data-submitbtn]').button('loading');
        $('#' + formContainerId).find('[data-submitbtn]').attr('disabled', 'disabled');
        $('#' + formContainerId).find('[data-submitPleaseWait]').show();
    },

    DF_SuspendSubmitButton: function () {
        var formContainerId = "formContainer" + DonorfyForms.FormId;
        $('#' + formContainerId).find('[data-submitbtn]').attr('disabled', 'disabled');
    },

    DF_DisplayErrorMessage: function (errorMessage, addtoMsg) {
        var formContainerId = "formContainer" + DonorfyForms.FormId;
        if (errorMessage === undefined) {
            return;
        }
        $("#" + formContainerId).find('[data-submitPleaseWait]').hide();
        $("#" + formContainerId).find('[data-SubmitErrorContainer]').show();
        if (addtoMsg === 'yes' && $("#" + + formContainerId).find('[data-submitErrors]').html() != undefined) {
            errorMessage = $("#" + + formContainerId).find('[data-submitErrors]').html() + errorMessage;
        }
        $("#" + formContainerId).find('[data-submitErrors]').html(errorMessage);
    },

    DF_GetDateFormatString: function () {
        try {
            const formatObj = new Intl.DateTimeFormat().formatToParts(new Date());

            return formatObj
                .map(obj => {
                    switch (obj.type) {
                        case "day":
                            return "DD";
                        case "month":
                            return "MM";
                        case "year":
                            return "YYYY";
                        default:
                            return obj.value;
                    }
                })
                .join("");
        } catch (e) {
            console.log('DonorfyForms.DF_GetDateFormatString ' + e);
        }
        return '';
    },

    DF_GetLocale: function () {
        try {
            var language;
            if (window.navigator.languages) {
                language = window.navigator.languages[0];
            } else {
                language = window.navigator.userLanguage || window.navigator.language;
            }
            return language;
        }
        catch (e) {
            console.log('DonorfyForms.DF_GetLocale ' + e);
        }
        return '';
    },

    DF_GetErrorArray: function (jqXhr) {

        var errors = [];

        if (jqXhr.responseText === undefined) {
            errors.push('Undefined error occurred');
            return errors;
        }

        var response = JSON.parse(jqXhr.responseText);

        if (response.ModelState) {
            for (var key in response.ModelState) {
                errors.push(response.ModelState[key]);
            }
        } else if (response.Message) {
            errors.push(response.Message);
        } else {
            errors.push('An unexpected error occurred.');
        }

        return errors;
    },

    DF_GetStripeBaseServiceUrl: function () {

        if (DonorfyForms.Mode === undefined || DonorfyForms.Mode === '' || DonorfyForms.Mode === 'Live') {
            return 'https://api.donorfy.com/api/stripe/';
        }
        if (DonorfyForms.Mode === 'Local') {
            return "https://localhost:44321/api/stripe/";
        }
        if (DonorfyForms.Mode === 'Demo') {
            return "https://demoapi.donorfy.com/api/stripe/";
        }

    },

    DF_GetGoCardlessBaseServiceUrl: function () {

        if (DonorfyForms.Mode === undefined || DonorfyForms.Mode === '' || DonorfyForms.Mode === 'Live') {
            return "https://api.donorfy.com/api/gocardless2/";
        }
        if (DonorfyForms.Mode === 'Local') {
            return "https://localhost:44321/api/gocardless2/";
        }
        if (DonorfyForms.Mode === 'Demo') {
            return "https://demoapi.donorfy.com/api/gocardless2/";
        }

    },

    DF_FormatAmountWithCurrency: function (amount) {
        let format = new Intl.NumberFormat(DonorfyForms.localeCode,
            {
                style: "currency",
                currencyDisplay: "narrowSymbol",
                currency: DonorfyForms.Currency,
                minimumFractionDigits: 2,
                maximumFractionDigits: 2
            });

        let parts = format.formatToParts(amount);
        let skipFraction = false;
        let output = "";

        parts.forEach(x => {
            if (x.type === "fraction") {
                skipFraction = x.value === "00";
            }
        });
        parts.forEach(y => {
            let result = y.value;
            switch (y.type) {
                case "fraction":
                case "decimal":
                    result = skipFraction ? "" : y.value;
            }
            output += result;
        });
        return output;
    }
};
const DonorfyCharts = {

    CreateBarChart: function (chart, canvas, data, title, options) {

        let calcCanvasSize = (capturedCanvas) => {
            let canvasHeight = ($(window).height() - $(capturedCanvas).closest('.widget-body').offset().top) * 0.9;
            if (canvasHeight < 250) {
                canvasHeight = 250;
            }

            // Make it visually fill the positioned parent
            capturedCanvas.style.height = canvasHeight + "px";
            capturedCanvas.style.width = "100%";
        };

        let eChart;
        try {
            if (chart) {
                window.removeEventListener('resize', () => {
                    calcCanvasSize(canvas);
                    chart.resize();
                });
                chart.dispose();
            }

            let series = [];

            $.each(data.datasets, function (i, item) {
                let serie = {
                    data: item.data,
                    type: 'bar',
                    stack: 'category',
                    name: item.label,
                    color: item.backgroundColor
                };
                series.push(serie);
            })

            let xAxis = {
                type: 'category',
                data: data.labels,
                splitLine: {
                    show: true
                },
                axisLabel: {
                    interval: 0
                }
            }

            options.series = series;
            options.xAxis = xAxis;

            calcCanvasSize(canvas);

            eChart = echarts.init(canvas, 'donorfy');
            
            DonorfyCharts.CreateAndSetStandardOptions(eChart, title, options)

            let handler = () => {
                calcCanvasSize(canvas);
                eChart.resize();
            };

            window.addEventListener('resize', handler);
            
            $(canvas).on('remove', () => {
                DonorfyCharts.Dispose(eChart);
                window.removeEventListener('resize', handler);
            });
        }
        catch (e) {
            console.log('Exception in CreateBarChart ' + e);
        }
        return eChart;
    },

    CreateAndSetStandardOptions: (chart, title, optionOverrides) => {
        let option = {
            toolbox: {
                show: true,
                itemSize: 20,
                showTitle: false,
                feature: {
                    saveAsImage: {
                        name: title,
                        icon: 'path://M144 480C64.5 480 0 415.5 0 336c0-62.8 40.2-116.2 96.2-135.9c-.1-2.7-.2-5.4-.2-8.1c0-88.4 71.6-160 160-160c59.3 0 111 32.2 138.7 80.2C409.9 102 428.3 96 448 96c53 0 96 43 96 96c0 12.2-2.3 23.8-6.4 34.6C596 238.4 640 290.1 640 352c0 70.7-57.3 128-128 128H144zm79-167l80 80c9.4 9.4 24.6 9.4 33.9 0l80-80c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-39 39V184c0-13.3-10.7-24-24-24s-24 10.7-24 24V318.1l-39-39c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9z',
                        iconStyle: {
                            color: 'Black',
                            borderWidth: 0
                        }
                    }
                }
            },
            grid: {
                containLabel: true
            }
        };
        $.extend(option, optionOverrides);
        // Display the chart using the configuration items and data just specified.
        chart.setOption(option, true);
    },

    Dispose: (element) => {
        if (element) {
            let chart = echarts.getInstanceByDom(element);
            if (chart) {
                chart.dispose();
            }
        }
    }
}; ;
	/*
	 *
	 *  Ben 4 June 2021
	 *  This is a copy of app.js with a few minor changes to make it compatible with Jquery v3
	 *
	 *
	 *
	 * 
	 * VARIABLES
	 * Description: All Global Vars
	 */
	// Impacts the responce rate of some of the responsive elements (lower value affects CPU but improves speed)
	$.throttle_delay = 350;
	
	// The rate at which the menu expands revealing child elements on click
	$.menu_speed = 235;
	
	// Note: You will also need to change this variable in the "variable.less" file.
	$.navbar_height = 49; 

	/*
	 * APP DOM REFERENCES
	 * Description: Obj DOM reference, please try to avoid changing these
	 */	
	$.root_ = $('body');
	$.left_panel = $('#left-panel');
	$.shortcut_dropdown = $('#shortcut');
	$.bread_crumb = $('#ribbon ol.breadcrumb');

	// desktop or mobile
	$.device = null;

	/*
	 * APP CONFIGURATION
	 * Description: Enable / disable certain theme features here
	 */		
	$.navAsAjax = false; // Your left nav in your app will no longer fire ajax calls
	
	// Please make sure you have included "jarvis.widget.js" for this below feature to work
	$.enableJarvisWidgets = true;
	
	// Warning: Enabling mobile widgets could potentially crash your webApp if you have too many 
	// 			widgets running at once (must have $.enableJarvisWidgets = true)
	$.enableMobileWidgets = false;


	/*
	 * DETECT MOBILE DEVICES
	 * Description: Detects mobile device - if any of the listed device is detected
	 * a class is inserted to $.root_ and the variable $.device is decleard. 
	 */	
	
	/* so far this is covering most hand held devices */
	var ismobile = (/iphone|ipad|ipod|android|blackberry|mini|windows\sce|palm/i.test(navigator.userAgent.toLowerCase()));

	if (!ismobile) {
		// Desktop
		$.root_.addClass("desktop-detected");
		$.device = "desktop";
	} else {
		// Mobile
		$.root_.addClass("mobile-detected");
		$.device = "mobile";
		
		// Removes the tap delay in idevices
		// dependency: js/plugin/fastclick/fastclick.js 
		//FastClick.attach(document.body);
	}

/* ~ END: CHECK MOBILE DEVICE */

/*
 * DOCUMENT LOADED EVENT
 * Description: Fire when DOM is ready
 */

$(document).ready(function() {
	/*
	 * Fire tooltips
	 */
	if ($("[rel=tooltip]").length) {
		$("[rel=tooltip]").tooltip();
	}

	//TODO: was moved from window.load due to IE not firing consist
	nav_page_height();

	// INITIALIZE LEFT NAV
	// bb 27 Aug 14 - added data-animate check to allow control over whether menus should be animated or not
	if (!null) {
		$('nav ul').each( function ()
		{
			if ($(this).data('animate', 'yes')) {
				$(this).jarvismenu({
						accordion: true,
						speed: $.menu_speed,
						closedSign: '<em class="fa fa-expand-o"></em>',
						openedSign: '<em class="fa fa-collapse-o"></em>'
					}
				);
			}
		});

		//$('nav ul[data-animate="yes"').jarvismenu({
		//	accordion: true,
		//	speed: $.menu_speed,
		//	closedSign: '<em class="fa fa-expand-o"></em>',
		//	openedSign: '<em class="fa fa-collapse-o"></em>'
		//});
	}
	//} else {
	//	alert("Error - menu anchor does not exist");
	//}

	// COLLAPSE LEFT NAV
	$('.minifyme').click(function(e) {
		$('body').toggleClass("minified");
		$(this).effect("highlight", {}, 500);
		e.preventDefault();
	});

	// HIDE MENU
	$('#hide-menu >:first-child > a').click(function(e) {
		$('body').toggleClass("hidden-menu");
		e.preventDefault();
	});
	
	$('#show-shortcut').click(function(e) {
		if ($.shortcut_dropdown.is(":visible")) {
			shortcut_buttons_hide();
		} else {
			shortcut_buttons_show();
		}
		e.preventDefault();
	});

	// SHOW & HIDE MOBILE SEARCH FIELD
	$('#search-mobile').click(function() {
		$.root_.addClass('search-mobile');
	});

	$('#cancel-search-js').click(function() {
		$.root_.removeClass('search-mobile');
	});

	// ACTIVITY
	$('#task-reminders').click(function(e) {
		var $this = $(this);

		//if ($this.find('.badge').hasClass('bg-color-red')) {
		//	$this.find('.badge').removeClassPrefix('bg-color-');
		//	$this.find('.badge').text("0");
		//}
		if (!$this.next('.reminders-box').is(':visible')) {
		    $this.next('.reminders-box').fadeIn(150);
		    $this.addClass('active');
		    setTimeout(function() {
		        if (!$.trim($('.task-list').html()).length) {
		            Donorfy.RefreshTaskList();
		        }
		    }, 500);

		} else {
		    $this.next('.reminders-box').fadeOut(150);
		    $this.removeClass('active');
		}

		e.preventDefault();
	});

	$('div.reminders-box input[name="tasksButton"]').change(function () {
	    var tasksType = $(this).val();
	    Donorfy.LoadTaskList(tasksType);
	});   

	$(document).mouseup(function(e) {
	    if (!$('.reminders-box').is(e.target)// if the target of the click isn't the container...
		&& $('.reminders-box').has(e.target).length === 0) {
	        $('.reminders-box').fadeOut(150);
	        $('.reminders-box').prev().removeClass("active");
		}
	});

	$('button[data-loading-text]').on('click', function() {
	    var btn = $(this);
	    btn.button('loading');
		setTimeout(function() {
		    btn.button('reset');
		}, 3000)
	});

	// NOTIFICATION IS PRESENT

	//function notification_check() {
	//	$this = $('#activity > .badge');

	//	if (parseInt($this.text()) > 0) {
	//		$this.addClass("bg-color-red bounceIn animated")
	//	}
	//}

	//notification_check();

	// RESET WIDGETS
	$('#refresh').click(function(e) {
		$.SmartMessageBox({
			title : "<i class='fa fa-refresh' style='color:green'></i> Clear Local Storage",
			content : "Would you like to RESET all your saved widgets and clear LocalStorage?",
			buttons : '[No][Yes]'
		}, function(ButtonPressed) {
			if (ButtonPressed == "Yes" && localStorage) {
				localStorage.clear();
				location.reload();
			}

		});
		e.preventDefault();
	});

	// LOGOUT BUTTON
	$('#logout a').click(function(e) {
		//get the link
		var $this = $(this);
		$.loginURL = $this.attr('href');
		$.logoutMSG = $this.data('logout-msg');

		// ask verification
		$.SmartMessageBox({
			title : "<i class='fa fa-sign-out txt-color-orangeDark'></i> Logout <span class='txt-color-orangeDark'><strong>" + $('#show-shortcut').text() + "</strong></span> ?",
			content : $.logoutMSG || "You can improve your security further after logging out by closing this opened browser",
			buttons : '[No][Yes]'

		}, function(ButtonPressed) {
			if (ButtonPressed == "Yes") {
				$.root_.addClass('animated fadeOutUp');
				setTimeout(logout, 1000)
			}

		});
		e.preventDefault();
	});

	/*
	 * LOGOUT ACTION
	 */

	function logout() {
		window.location = $.loginURL;
	}

	/*
	* SHORTCUTS
	*/

	// SHORT CUT (buttons that appear when clicked on user name)
	$.shortcut_dropdown.find('a').click(function(e) {

		e.preventDefault();

		window.location = $(this).attr('href');
		setTimeout(shortcut_buttons_hide, 300);

	});

	// SHORTCUT buttons goes away if mouse is clicked outside of the area
	$(document).mouseup(function (e) {
	    try {
            // BRB 7 June 2017
	        if (!$.shortcut_dropdown.is(e.target) // if the target of the click isn't the container...
	            &&
	            $.shortcut_dropdown.has(e.target).length === 0) {
	            shortcut_buttons_hide();
	        }
	    } catch (e) {
	        console.log('Ex 123' + e);
	    }

	});

	// SHORTCUT ANIMATE HIDE
	function shortcut_buttons_hide() {
		$.shortcut_dropdown.animate({
			height : "hide"
		}, 300, "easeOutCirc");
		$.root_.removeClass('shortcut-on');

	}

	// SHORTCUT ANIMATE SHOW
	function shortcut_buttons_show() {
		$.shortcut_dropdown.animate({
			height : "show"
		}, 200, "easeOutCirc")
		$.root_.addClass('shortcut-on');
	}

});

/*
 * RESIZER WITH THROTTLE
 * Source: http://benalman.com/code/projects/jquery-resize/examples/resize/
 */

(function($, window, undefined) {

	var elems = $([]), jq_resize = $.resize = $.extend($.resize, {}), timeout_id, str_setTimeout = 'setTimeout', str_resize = 'resize', str_data = str_resize + '-special-event', str_delay = 'delay', str_throttle = 'throttleWindow';

	jq_resize[str_delay] = $.throttle_delay;

	jq_resize[str_throttle] = true;

	$.event.special[str_resize] = {

		setup : function() {
			if (!jq_resize[str_throttle] && this[str_setTimeout]) {
				return false;
			}

			var elem = $(this);
			elems = elems.add(elem);
			$.data(this, str_data, {
				w : elem.width(),
				h : elem.height()
			});
			if (elems.length === 1) {
				loopy();
			}
		},
		teardown : function() {
			if (!jq_resize[str_throttle] && this[str_setTimeout]) {
				return false;
			}

			var elem = $(this);
			elems = elems.not(elem);
			elem.removeData(str_data);
			if (!elems.length) {
				clearTimeout(timeout_id);
			}
		},

		add : function(handleObj) {
			if (!jq_resize[str_throttle] && this[str_setTimeout]) {
				return false;
			}
			var old_handler;

			function new_handler(e, w, h) {
				var elem = $(this), data = $.data(this, str_data);
				data.w = w !== undefined ? w : elem.width();
				data.h = h !== undefined ? h : elem.height();

				old_handler.apply(this, arguments);
			};
			if ($.isFunction(handleObj)) {
				old_handler = handleObj;
				return new_handler;
			} else {
				old_handler = handleObj.handler;
				handleObj.handler = new_handler;
			}
		}
	};

	function loopy() {
		timeout_id = window[str_setTimeout](function() {
			elems.each(function() {
				var elem = $(this), width = elem.width(), height = elem.height(), data = $.data(this, str_data);
				if (width !== data.w || height !== data.h) {
					elem.trigger(str_resize, [data.w = width, data.h = height]);
				}

			});
			loopy();

		}, jq_resize[str_delay]);

	};

})(jQuery, this);

/*
* NAV OR #LEFT-BAR RESIZE DETECT
* Description: changes the page min-width of #CONTENT and NAV when navigation is resized.
* This is to counter bugs for min page width on many desktop and mobile devices.
* Note: This script uses JSthrottle technique so don't worry about memory/CPU usage
*/

// Fix page and nav height
function nav_page_height() {
    try {
        

	var setHeight = $('#main').height();
	//menuHeight = $.left_panel.height();
	
	var windowHeight = $(window).height() - $.navbar_height;
	//set height

	if (setHeight > windowHeight) {// if content height exceedes actual window height and menuHeight
		$.left_panel.css('min-height', setHeight + 'px');
		$.root_.css('min-height', setHeight + $.navbar_height + 'px');

	} else {
		$.left_panel.css('min-height', windowHeight + 'px');
		$.root_.css('min-height', windowHeight + 'px');
		}
            } catch(e) {
        console.log('Exception in nav_page_height ' + e);
    }
}

$('#main').resize(function() {
	nav_page_height();
	check_if_mobile_width();
})

$('nav').resize(function() {
	nav_page_height();
})

function check_if_mobile_width() {
	if ($(window).width() < 979) {
		$.root_.addClass('mobile-view-activated')
	} else if ($.root_.hasClass('mobile-view-activated')) {
		$.root_.removeClass('mobile-view-activated');
	}
}

/* ~ END: NAV OR #LEFT-BAR RESIZE DETECT */

/*
 * DETECT IE VERSION
 * Description: A short snippet for detecting versions of IE in JavaScript
 * without resorting to user-agent sniffing
 * RETURNS:
 * If you're not in IE (or IE version is less than 5) then:
 * //ie === undefined
 *
 * If you're in IE (>=5) then you can determine which version:
 * // ie === 7; // IE7
 *
 * Thus, to detect IE:
 * // if (ie) {}
 *
 * And to detect the version:
 * ie === 6 // IE6
 * ie > 7 // IE8, IE9 ...
 * ie < 9 // Anything less than IE9
 */

// TODO: delete this function later on - no longer needed (?)
var ie = ( function() {

		var undef, v = 3, div = document.createElement('div'), all = div.getElementsByTagName('i');

		while (div.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->', all[0]);

		return v > 4 ? v : undef;

	}()); // do we need this? 

/* ~ END: DETECT IE VERSION */

/*
 * CUSTOM MENU PLUGIN
 */

$.fn.extend({

	//pass the options variable to the function
	jarvismenu : function(options) {

		var defaults = {
			accordion : 'true',
			speed : 200,
			closedSign : '[+]',
			openedSign : '[-]'
		};

		// Extend our default options with those provided.
		var opts = $.extend(defaults, options);
		//Assign current element to variable, in this case is UL element
		var $this = $(this);

		//add a mark [+] to a multilevel menu
		$this.find("li").each(function() {
			if ($(this).find("ul").length != 0) {
				//add the multilevel sign next to the link
				$(this).find("a:first").append("<b class='collapse-sign'>" + opts.closedSign + "</b>");

				//avoid jumping to the top of the page when the href is an #
				if ($(this).find("a:first").attr('href') == "#") {
					$(this).find("a:first").click(function() {
						return false;
					});
				}
			}
		});

		//open active level
		$this.find("li.active").each(function() {
			$(this).parents("ul").slideDown(opts.speed);
			$(this).parents("ul").parent("li").find("b:first").html(opts.openedSign);
			$(this).parents("ul").parent("li").addClass("open")
		});

		$this.find("li a").click(function() {

			if ($(this).parent().find("ul").length != 0) {

				if (opts.accordion) {
					//Do nothing when the list is open
					if (!$(this).parent().find("ul").is(':visible')) {
						parents = $(this).parent().parents("ul");
						visible = $this.find("ul:visible");
						visible.each(function(visibleIndex) {
							var close = true;
							parents.each(function(parentIndex) {
								if (parents[parentIndex] == visible[visibleIndex]) {
									close = false;
									return false;
								}
							});
							if (close) {
								if ($(this).parent().find("ul") != visible[visibleIndex]) {
									$(visible[visibleIndex]).slideUp(opts.speed, function() {
										$(this).parent("li").find("b:first").html(opts.closedSign);
										$(this).parent("li").removeClass("open");
									});

								}
							}
						});
					}
				}// end if
				if ($(this).parent().find("ul:first").is(":visible") && !$(this).parent().find("ul:first").hasClass("active")) {
					$(this).parent().find("ul:first").slideUp(opts.speed, function() {
						$(this).parent("li").removeClass("open");
						$(this).parent("li").find("b:first").delay(opts.speed).html(opts.closedSign);
					});

				} else {
					$(this).parent().find("ul:first").slideDown(opts.speed, function() {
						/*$(this).effect("highlight", {color : '#616161'}, 500); - disabled due to CPU clocking on phones*/
						$(this).parent("li").addClass("open");
						$(this).parent("li").find("b:first").delay(opts.speed).html(opts.openedSign);
					});
				} // end else
			} // end if
		});
	} // end function
});

/* ~ END: CUSTOM MENU PLUGIN */

/*
 * ELEMENT EXIST OR NOT
 * Description: returns true or false
 * Usage: $('#myDiv').doesExist();
 */

jQuery.fn.doesExist = function() {
	return jQuery(this).length > 0;
};

/* ~ END: ELEMENT EXIST OR NOT */

/*
 * FULL SCREEN FUNCTION
 */

// Find the right method, call on correct element
function launchFullscreen(element) {

	if (!$.root_.hasClass("full-screen")) {

		$.root_.addClass("full-screen");

		if (element.requestFullscreen) {
			element.requestFullscreen();
		} else if (element.mozRequestFullScreen) {
			element.mozRequestFullScreen();
		} else if (element.webkitRequestFullscreen) {
			element.webkitRequestFullscreen();
		} else if (element.msRequestFullscreen) {
			element.msRequestFullscreen();
		}

	} else {
		
		$.root_.removeClass("full-screen");
		
		if (document.exitFullscreen) {
			document.exitFullscreen();
		} else if (document.mozCancelFullScreen) {
			document.mozCancelFullScreen();
		} else if (document.webkitExitFullscreen) {
			document.webkitExitFullscreen();
		}

	}

}

/*
 * ~ END: FULL SCREEN FUNCTION
 */

/*
 * INITIALIZE FORMS
 * Description: Select2, Masking, Datepicker, Autocomplete
 */

function runAllForms() {

	/*
	 * BOOTSTRAP SLIDER PLUGIN
	 * Usage:
	 * Dependency: js/plugin/bootstrap-slider
	 */
	if ($.fn.slider) {
		$('.slider').slider();
	}

	/*
	 * SELECT2 PLUGIN
	 * Usage:
	 * Dependency: js/plugin/select2/
	 */
	if ($.fn.select2) {
		$('.select2').each(function() {
			var $this = $(this);
			var width = $this.attr('data-select-width') || '100%';
			//, _showSearchInput = $this.attr('data-select-search') === 'true';
			$this.select2({
				//showSearchInput : _showSearchInput,
				allowClear : true,
				width : width
			})
		})
	}

	/*
	 * MASKING
	 * Dependency: js/plugin/masked-input/
	 */
	if ($.fn.mask) {
		$('[data-mask]').each(function() {

			var $this = $(this);
			var mask = $this.attr('data-mask') || 'error...', mask_placeholder = $this.attr('data-mask-placeholder') || 'X';

			$this.mask(mask, {
				placeholder : mask_placeholder
			});
		})
	}

	/*
	 * Autocomplete
	 * Dependency: js/jqui
	 */
	if ($.fn.autocomplete) {
		$('[data-autocomplete]').each(function() {

			var $this = $(this);
			var availableTags = $this.data('autocomplete') || ["The", "Quick", "Brown", "Fox", "Jumps", "Over", "Three", "Lazy", "Dogs"];

			$this.autocomplete({
				source : availableTags
			});
		})
	}

	/*
	 * JQUERY UI DATE
	 * Dependency: js/libs/jquery-ui-1.10.3.min.js
	 * Usage:
	 */
	if ($.fn.datepicker) {
		$('.datepicker').each(function() {

			var $this = $(this);
			var dataDateFormat = $this.attr('data-dateformat') || 'dd.mm.yy';

			$this.datepicker({
				dateFormat : dataDateFormat,
				prevText : '<i class="fa fa-chevron-left"></i>',
				nextText : '<i class="fa fa-chevron-right"></i>',
			});
		})
	}

	/*
	 * AJAX BUTTON LOADING TEXT
	 * Usage: <button type="button" data-loading-text="Loading..." class="btn btn-xs btn-default ajax-refresh"> .. </button>
	 */
	$('button[data-loading-text]').on('click', function() {
		var btn = $(this)
		btn.button('loading')
		setTimeout(function() {
			btn.button('reset')
		}, 3000)
	});

}

/* ~ END: INITIALIZE FORMS */

/*
 * INITIALIZE CHARTS
 * Description: Sparklines, PieCharts
 */

function runAllCharts() {
	/*
	 * SPARKLINES
	 * DEPENDENCY: js/plugins/sparkline/jquery.sparkline.min.js
	 * See usage example below...
	 */

	/* Usage:
	 * 		<div class="sparkline-line txt-color-blue" data-fill-color="transparent" data-sparkline-height="26px">
	 *			5,6,7,9,9,5,9,6,5,6,6,7,7,6,7,8,9,7
	 *		</div>
	 */
	if ($.fn.sparkline) {

		$('.sparkline').each(function() {
			var $this = $(this);
			var sparklineType = $this.data('sparkline-type') || 'bar';

			// BAR CHART
			if (sparklineType == 'bar') {

				var barColor = $this.data('sparkline-bar-color') || $this.css('color') || '#0000f0', sparklineHeight = $this.data('sparkline-height') || '26px', sparklineBarWidth = $this.data('sparkline-barwidth') || 5, sparklineBarSpacing = $this.data('sparkline-barspacing') || 2, sparklineNegBarColor = $this.data('sparkline-negbar-color') || '#A90329', sparklineStackedColor = $this.data('sparkline-barstacked-color') || ["#A90329", "#0099c6", "#98AA56", "#da532c", "#4490B1", "#6E9461", "#990099", "#B4CAD3"];

				$this.sparkline('html', {
					type : 'bar',
					barColor : barColor,
					type : sparklineType,
					height : sparklineHeight,
					barWidth : sparklineBarWidth,
					barSpacing : sparklineBarSpacing,
					stackedBarColor : sparklineStackedColor,
					negBarColor : sparklineNegBarColor,
					zeroAxis : 'false'
				});

			}

			//LINE CHART
			if (sparklineType == 'line') {

				var sparklineHeight = $this.data('sparkline-height') || '20px', sparklineWidth = $this.data('sparkline-width') || '90px', thisLineColor = $this.data('sparkline-line-color') || $this.css('color') || '#0000f0', thisLineWidth = $this.data('sparkline-line-width') || 1, thisFill = $this.data('fill-color') || '#c0d0f0', thisSpotColor = $this.data('sparkline-spot-color') || '#f08000', thisMinSpotColor = $this.data('sparkline-minspot-color') || '#ed1c24', thisMaxSpotColor = $this.data('sparkline-maxspot-color') || '#f08000', thishighlightSpotColor = $this.data('sparkline-highlightspot-color') || '#50f050', thisHighlightLineColor = $this.data('sparkline-highlightline-color') || 'f02020', thisSpotRadius = $this.data('sparkline-spotradius') || 1.5;
				thisChartMinYRange = $this.data('sparkline-min-y') || 'undefined', thisChartMaxYRange = $this.data('sparkline-max-y') || 'undefined', thisChartMinXRange = $this.data('sparkline-min-x') || 'undefined', thisChartMaxXRange = $this.data('sparkline-max-x') || 'undefined', thisMinNormValue = $this.data('min-val') || 'undefined', thisMaxNormValue = $this.data('max-val') || 'undefined', thisNormColor = $this.data('norm-color') || '#c0c0c0', thisDrawNormalOnTop = $this.data('draw-normal') || false;

				$this.sparkline('html', {
					type : 'line',
					width : sparklineWidth,
					height : sparklineHeight,
					lineWidth : thisLineWidth,
					lineColor : thisLineColor,
					fillColor : thisFill,
					spotColor : thisSpotColor,
					minSpotColor : thisMinSpotColor,
					maxSpotColor : thisMaxSpotColor,
					highlightSpotColor : thishighlightSpotColor,
					highlightLineColor : thisHighlightLineColor,
					spotRadius : thisSpotRadius,
					chartRangeMin : thisChartMinYRange,
					chartRangeMax : thisChartMaxYRange,
					chartRangeMinX : thisChartMinXRange,
					chartRangeMaxX : thisChartMaxXRange,
					normalRangeMin : thisMinNormValue,
					normalRangeMax : thisMaxNormValue,
					normalRangeColor : thisNormColor,
					drawNormalOnTop : thisDrawNormalOnTop

				});

			}

			//PIE CHART
			if (sparklineType == 'pie') {

				var pieColors = $this.data('sparkline-piecolor') || ["#B4CAD3", "#4490B1", "#98AA56", "#da532c", "#6E9461", "#0099c6", "#990099", "#717D8A"], pieWidthHeight = $this.data('sparkline-piesize') || 90, pieBorderColor = $this.data('border-color') || '#45494C', pieOffset = $this.data('sparkline-offset') || 0;

				$this.sparkline('html', {
					type : 'pie',
					width : pieWidthHeight,
					height : pieWidthHeight,
					tooltipFormat : '<span style="color: {{color}}">&#9679;</span> ({{percent.1}}%)',
					sliceColors : pieColors,
					offset : 0,
					borderWidth : 1,
					offset : pieOffset,
					borderColor : pieBorderColor
				});

			}

			//BOX PLOT
			if (sparklineType == 'box') {

				var thisBoxWidth = $this.data('sparkline-width') || 'auto', thisBoxHeight = $this.data('sparkline-height') || 'auto', thisBoxRaw = $this.data('sparkline-boxraw') || false, thisBoxTarget = $this.data('sparkline-targetval') || 'undefined', thisBoxMin = $this.data('sparkline-min') || 'undefined', thisBoxMax = $this.data('sparkline-max') || 'undefined', thisShowOutlier = $this.data('sparkline-showoutlier') || true, thisIQR = $this.data('sparkline-outlier-iqr') || 1.5, thisBoxSpotRadius = $this.data('sparkline-spotradius') || 1.5, thisBoxLineColor = $this.css('color') || '#000000', thisBoxFillColor = $this.data('fill-color') || '#c0d0f0', thisBoxWhisColor = $this.data('sparkline-whis-color') || '#000000', thisBoxOutlineColor = $this.data('sparkline-outline-color') || '#303030', thisBoxOutlineFill = $this.data('sparkline-outlinefill-color') || '#f0f0f0', thisBoxMedianColor = $this.data('sparkline-outlinemedian-color') || '#f00000', thisBoxTargetColor = $this.data('sparkline-outlinetarget-color') || '#40a020';

				$this.sparkline('html', {
					type : 'box',
					width : thisBoxWidth,
					height : thisBoxHeight,
					raw : thisBoxRaw,
					target : thisBoxTarget,
					minValue : thisBoxMin,
					maxValue : thisBoxMax,
					showOutliers : thisShowOutlier,
					outlierIQR : thisIQR,
					spotRadius : thisBoxSpotRadius,
					boxLineColor : thisBoxLineColor,
					boxFillColor : thisBoxFillColor,
					whiskerColor : thisBoxWhisColor,
					outlierLineColor : thisBoxOutlineColor,
					outlierFillColor : thisBoxOutlineFill,
					medianColor : thisBoxMedianColor,
					targetColor : thisBoxTargetColor

				})

			}

			//BULLET
			if (sparklineType == 'bullet') {

				var thisBulletHeight = $this.data('sparkline-height') || 'auto', thisBulletWidth = $this.data('sparkline-width') || 2, thisBulletColor = $this.data('sparkline-bullet-color') || '#ed1c24', thisBulletPerformanceColor = $this.data('sparkline-performance-color') || '#3030f0', thisBulletRangeColors = $this.data('sparkline-bulletrange-color') || ["#d3dafe", "#a8b6ff", "#7f94ff"]

				$this.sparkline('html', {

					type : 'bullet',
					height : thisBulletHeight,
					targetWidth : thisBulletWidth,
					targetColor : thisBulletColor,
					performanceColor : thisBulletPerformanceColor,
					rangeColors : thisBulletRangeColors

				})

			}

			//DISCRETE
			if (sparklineType == 'discrete') {

				var thisDiscreteHeight = $this.data('sparkline-height') || 26, thisDiscreteWidth = $this.data('sparkline-width') || 50, thisDiscreteLineColor = $this.css('color'), thisDiscreteLineHeight = $this.data('sparkline-line-height') || 5, thisDiscreteThrushold = $this.data('sparkline-threshold') || 'undefined', thisDiscreteThrusholdColor = $this.data('sparkline-threshold-color') || '#ed1c24';

				$this.sparkline('html', {

					type : 'discrete',
					width : thisDiscreteWidth,
					height : thisDiscreteHeight,
					lineColor : thisDiscreteLineColor,
					lineHeight : thisDiscreteLineHeight,
					thresholdValue : thisDiscreteThrushold,
					thresholdColor : thisDiscreteThrusholdColor

				})

			}

			//TRISTATE
			if (sparklineType == 'tristate') {

				var thisTristateHeight = $this.data('sparkline-height') || 26, thisTristatePosBarColor = $this.data('sparkline-posbar-color') || '#60f060', thisTristateNegBarColor = $this.data('sparkline-negbar-color') || '#f04040', thisTristateZeroBarColor = $this.data('sparkline-zerobar-color') || '#909090', thisTristateBarWidth = $this.data('sparkline-barwidth') || 5, thisTristateBarSpacing = $this.data('sparkline-barspacing') || 2, thisZeroAxis = $this.data('sparkline-zeroaxis') || false;

				$this.sparkline('html', {

					type : 'tristate',
					height : thisTristateHeight,
					posBarColor : thisBarColor,
					negBarColor : thisTristateNegBarColor,
					zeroBarColor : thisTristateZeroBarColor,
					barWidth : thisTristateBarWidth,
					barSpacing : thisTristateBarSpacing,
					zeroAxis : thisZeroAxis

				})

			}

			//COMPOSITE: BAR
			if (sparklineType == 'compositebar') {

				var sparklineHeight = $this.data('sparkline-height') || '20px', sparklineWidth = $this.data('sparkline-width') || '100%', sparklineBarWidth = $this.data('sparkline-barwidth') || 3, thisLineWidth = $this.data('sparkline-line-width') || 1, thisLineColor = $this.data('sparkline-color-top') || '#ed1c24', thisBarColor = $this.data('sparkline-color-bottom') || '#333333'

				$this.sparkline($this.data('sparkline-bar-val'), {

					type : 'bar',
					width : sparklineWidth,
					height : sparklineHeight,
					barColor : thisBarColor,
					barWidth : sparklineBarWidth
					//barSpacing: 5

				})

				$this.sparkline($this.data('sparkline-line-val'), {

					width : sparklineWidth,
					height : sparklineHeight,
					lineColor : thisLineColor,
					lineWidth : thisLineWidth,
					composite : true,
					fillColor : false

				})

			}

			//COMPOSITE: LINE
			if (sparklineType == 'compositeline') {

				var sparklineHeight = $this.data('sparkline-height') || '20px', sparklineWidth = $this.data('sparkline-width') || '90px', sparklineValue = $this.data('sparkline-bar-val'), sparklineValueSpots1 = $this.data('sparkline-bar-val-spots-top') || null, sparklineValueSpots2 = $this.data('sparkline-bar-val-spots-bottom') || null, thisLineWidth1 = $this.data('sparkline-line-width-top') || 1, thisLineWidth2 = $this.data('sparkline-line-width-bottom') || 1, thisLineColor1 = $this.data('sparkline-color-top') || '#333333', thisLineColor2 = $this.data('sparkline-color-bottom') || '#ed1c24', thisSpotRadius1 = $this.data('sparkline-spotradius-top') || 1.5, thisSpotRadius2 = $this.data('sparkline-spotradius-bottom') || thisSpotRadius1, thisSpotColor = $this.data('sparkline-spot-color') || '#f08000', thisMinSpotColor1 = $this.data('sparkline-minspot-color-top') || '#ed1c24', thisMaxSpotColor1 = $this.data('sparkline-maxspot-color-top') || '#f08000', thisMinSpotColor2 = $this.data('sparkline-minspot-color-bottom') || thisMinSpotColor1, thisMaxSpotColor2 = $this.data('sparkline-maxspot-color-bottom') || thisMaxSpotColor1, thishighlightSpotColor1 = $this.data('sparkline-highlightspot-color-top') || '#50f050', thisHighlightLineColor1 = $this.data('sparkline-highlightline-color-top') || '#f02020', thishighlightSpotColor2 = $this.data('sparkline-highlightspot-color-bottom') || thishighlightSpotColor1, thisHighlightLineColor2 = $this.data('sparkline-highlightline-color-bottom') || thisHighlightLineColor1, thisFillColor1 = $this.data('sparkline-fillcolor-top') || 'transparent', thisFillColor2 = $this.data('sparkline-fillcolor-bottom') || 'transparent';

				$this.sparkline(sparklineValue, {

					type : 'line',
					spotRadius : thisSpotRadius1,

					spotColor : thisSpotColor,
					minSpotColor : thisMinSpotColor1,
					maxSpotColor : thisMaxSpotColor1,
					highlightSpotColor : thishighlightSpotColor1,
					highlightLineColor : thisHighlightLineColor1,

					valueSpots : sparklineValueSpots1,

					lineWidth : thisLineWidth1,
					width : sparklineWidth,
					height : sparklineHeight,
					lineColor : thisLineColor1,
					fillColor : thisFillColor1

				})

				$this.sparkline($this.data('sparkline-line-val'), {

					type : 'line',
					spotRadius : thisSpotRadius2,

					spotColor : thisSpotColor,
					minSpotColor : thisMinSpotColor2,
					maxSpotColor : thisMaxSpotColor2,
					highlightSpotColor : thishighlightSpotColor2,
					highlightLineColor : thisHighlightLineColor2,

					valueSpots : sparklineValueSpots2,

					lineWidth : thisLineWidth2,
					width : sparklineWidth,
					height : sparklineHeight,
					lineColor : thisLineColor2,
					composite : true,
					fillColor : thisFillColor2

				})

			}

		});

	}// end if

	/*
	 * EASY PIE CHARTS
	 * DEPENDENCY: js/plugins/easy-pie-chart/jquery.easy-pie-chart.min.js
	 * Usage: <div class="easy-pie-chart txt-color-orangeDark" data-pie-percent="33" data-pie-size="72" data-size="72">
	 *			<span class="percent percent-sign">35</span>
	 * 	  	  </div>
	 */

	if ($.fn.easyPieChart) {

		$('.easy-pie-chart').each(function() {
			var $this = $(this);
			var barColor = $this.css('color') || $this.data('pie-color'), trackColor = $this.data('pie-track-color') || '#eeeeee', size = parseInt($this.data('pie-size')) || 25;
			$this.easyPieChart({
				barColor : barColor,
				trackColor : trackColor,
				scaleColor : false,
				lineCap : 'butt',
				lineWidth : parseInt(size / 8.5),
				animate : 1500,
				rotate : -90,
				size : size,
				onStep : function(value) {
					this.$el.find('span').text(~~value);
				}
			});
		});

	} // end if

}

/* ~ END: INITIALIZE CHARTS */

/*
 * INITIALIZE JARVIS WIDGETS
 */

// Setup Desktop Widgets
function setup_widgets_desktop() {

	if ($.fn.jarvisWidgets && $.enableJarvisWidgets) {

		$('#widget-grid').jarvisWidgets({

			grid : 'article',
			widgets : '.jarviswidget',
			localStorage : true,
			deleteSettingsKey : '#deletesettingskey-options',
			settingsKeyLabel : 'Reset settings?',
			deletePositionKey : '#deletepositionkey-options',
			positionKeyLabel : 'Reset position?',
			sortable : true,
			buttonsHidden : false,
			// toggle button
			toggleButton : true,
			toggleClass : 'fa fa-minus | fa fa-plus',
			toggleSpeed : 200,
			onToggle: function (widget) {

				/* N.B. This line added by Donorfy on 20/10/2020 
				  to support notifications in the app of the widget toggle event */
                $(document).trigger("widget-toggle", [widget]);
            },
			// delete btn
			deleteButton : false,
			deleteClass : 'fa fa-times',
			deleteSpeed : 200,
			onDelete : function() {
			},
			// edit btn
			editButton : true,
			editPlaceholder : '.jarviswidget-editbox',
			editClass : 'fa fa-cog | fa fa-save',
			editSpeed : 200,
			onEdit : function() {
			},
			// color button
			colorButton : false,
			// full screen
			fullscreenButton : true,
			fullscreenClass: 'glyphicon glyphicon-resize-full | glyphicon glyphicon-resize-small',
			fullscreenDiff : 3,
			onFullscreen : function() {
			},
			// custom btn
			customButton : false,
			customClass : 'folder-10 | next-10',
			customStart : function() {
				alert('Hello you, this is a custom button...')
			},
			customEnd : function() {
				alert('bye, till next time...')
			},
			// order
			buttonOrder : '%refresh% %custom% %edit% %toggle% %fullscreen% %delete%',
			opacity : 1.0,
			dragHandle : '> header',
			placeholderClass : 'jarviswidget-placeholder',
			indicator : true,
			indicatorTime : 600,
			ajax : true,
			timestampPlaceholder : '.jarviswidget-timestamp',
			timestampFormat : 'Last update: %m%/%d%/%y% %h%:%i%:%s%',
			refreshButton : true,
			refreshButtonClass : 'fa fa-refresh',
			labelError : 'Sorry but there was a error:',
			labelUpdated : 'Last Update:',
			labelRefresh : 'Refresh',
			labelDelete : 'Delete widget:',
			afterLoad: function () {
			 //   console.log('setup_widgets_desktop after load');
			},
			rtl : false, // best not to toggle this!
			onChange : function() {
			//    console.log('setup_widgets_desktop on change');
			},
			ajaxnav : $.navAsAjax // declears how the localstorage should be saved

		});
	}
}

// Setup Desktop Widgets
function setup_widgets_mobile() {

	if ($.enableMobileWidgets && $.enableJarvisWidgets) {
		setup_widgets_desktop();
	}

}

/* ~ END: INITIALIZE JARVIS WIDGETS */

/*
 * LOAD SCRIPTS
 * Usage:
 * Define function = myPrettyCode ()...
 * loadScript("js/my_lovely_script.js", myPrettyCode);
 */

var jsArray = {};

function loadScript(scriptName, callback) {

	if (!jsArray[scriptName]) {
		jsArray[scriptName] = true;

		// adding the script tag to the head as suggested before
		var body = document.getElementsByTagName('body')[0];
		var script = document.createElement('script');
		script.type = 'text/javascript';
		script.src = scriptName;

		// then bind the event to the callback function
		// there are several events for cross browser compatibility
		//script.onreadystatechange = callback;
		script.onload = callback;

		// fire the loading
		body.appendChild(script);

	} else if (callback) {// changed else to else if(callback)
		//console.log("JS file already added!");
		//execute function
		callback();
	}

}

/* ~ END: LOAD SCRIPTS */

/*
* APP AJAX REQUEST SETUP
* Description: Executes and fetches all ajax requests also
* updates naivgation elements to active
*/
if($.navAsAjax)
{
	// fire this on page load if nav exists
	if ($('nav').length) {
		checkURL();
	};

	$(document).on('click', 'nav a[href!="#"]', function(e) {
		e.preventDefault();
		var $this = $(e.currentTarget);

		// if parent is not active then get hash, or else page is assumed to be loaded
		if (!$this.parent().hasClass("active") && !$this.attr('target')) {

			// update window with hash
			// you could also do here:  $.device === "mobile" - and save a little more memory

			if ($.root_.hasClass('mobile-view-activated')) {
				$.root_.removeClass('hidden-menu');
				window.setTimeout(function() {
					if (window.location.search) {
						window.location.href =
							window.location.href.replace(window.location.search, '')
								.replace(window.location.hash, '') + '#' + $this.attr('href');
					} else {
						window.location.hash = $this.attr('href')
					}
				}, 150);
				// it may not need this delay...
			} else {
				if (window.location.search) {
					window.location.href =
						window.location.href.replace(window.location.search, '')
							.replace(window.location.hash, '') + '#' + $this.attr('href');
				} else {
					window.location.hash = $this.attr('href');
				}
			}
		}

	});

	// fire links with targets on different window
	$(document).on('click', 'nav a[target="_blank"]', function(e) {
		e.preventDefault();
		var $this = $(e.currentTarget);

		window.open($this.attr('href'));
	});

	// fire links with targets on same window
	$(document).on('click', 'nav a[target="_top"]', function(e) {
		e.preventDefault();
		var $this = $(e.currentTarget);

		window.location = ($this.attr('href'));
	});

	// all links with hash tags are ignored
	$(document).on('click', 'nav a[href="#"]', function(e) {
		e.preventDefault();
	});

	// DO on hash change
	$(window).on('hashchange', function() {
		checkURL();
	});
}

// CHECK TO SEE IF URL EXISTS
function checkURL() {

	//get the url by removing the hash
	var url = location.hash.replace(/^#/, '');

	container = $('#content');
	// Do this if url exists (for page refresh, etc...)
	if (url) {
		// remove all active class
		$('nav li.active').removeClass("active");
		// match the url and add the active class
		$('nav li:has(a[href="' + url + '"])').addClass("active");
		var title = ($('nav a[href="' + url + '"]').attr('title'))

		// change page title from global var
		document.title = (title || document.title);
		//console.log("page title: " + document.title);

		// parse url to jquery
		loadURL(url + location.search, container);
	} else {

		// grab the first URL from nav
		var $this = $('nav > ul > li:first-child > a[href!="#"]');

		//update hash
		window.location.hash = $this.attr('href');

	}

}

// LOAD AJAX PAGES

function loadURL(url, container) {
	//console.log(container)

	$.ajax({
		type : "GET",
		url : url,
		dataType : 'html',
		cache : true, // (warning: this will cause a timestamp and will call the request twice)
		beforeSend : function() {
			// cog placed
			container.html('<h1><i class="fa fa-cog fa-spin"></i> Loading...</h1>');
		
			// Only draw breadcrumb if it is main content material
			// TODO: see the framerate for the animation in touch devices
			
			if (container[0] == $("#content")[0]) {
				drawBreadCrumb();
				// scroll up
				$("html").animate({
					scrollTop : 0
				}, "fast");
			} 
		},
		/*complete: function(){
			// Handle the complete event
			// alert("complete")
		},*/
		success : function(data) {
			// cog replaced here...
			// alert("success")
			
			container.css({
				opacity : '0.0'
			}).html(data).delay(50).animate({
				opacity : '1.0'
			}, 300);
			

		},
		error : function(xhr, ajaxOptions, thrownError) {
			container.html('<h4 style="margin-top:10px; display:block; text-align:left"><i class="fa fa-warning txt-color-orangeDark"></i> Error 404! Page not found.</h4>');
		},
		async : false
	});

	//console.log("ajax request sent");
}

// UPDATE BREADCRUMB
function drawBreadCrumb() {
	var nav_elems = $('nav li.active > a'), count = nav_elems.length;
	
	//console.log("breadcrumb")
	$.bread_crumb.empty();
	$.bread_crumb.append($("<li>Home</li>"));
	nav_elems.each(function() {
		$.bread_crumb.append($("<li></li>").html($.trim($(this).clone().children(".badge").remove().end().text())));
		// update title when breadcrumb is finished...
		if (!--count) document.title = $.bread_crumb.find("li:last-child").text();
	});

}

/* ~ END: APP AJAX REQUEST SETUP */

/*
 * PAGE SETUP
 * Description: fire certain scripts that run through the page
 * to check for form elements, tooltip activation, popovers, etc...
 */
function pageSetUp() {

	if ($.device === "desktop"){
		// is desktop
		
		// activate tooltips
		$("[rel=tooltip]").tooltip();
	
		// activate popovers
		$("[rel=popover]").popover();
	
		// activate popovers with hover states
		$("[rel=popover-hover]").popover({
			trigger : "hover"
		});
	
		// activate inline charts
		// runAllCharts();
	
		// setup widgets
		setup_widgets_desktop();
	
		//setup nav height (dynamic)
		nav_page_height();
	
		// run form elements
		// runAllForms();

	} else {
		
		// is mobile
		
		// activate popovers
		$("[rel=popover]").popover();
	
		// activate popovers with hover states
		$("[rel=popover-hover]").popover({
			trigger : "hover"
		});
	
		// activate inline charts
		// runAllCharts();
	
		// setup widgets
		setup_widgets_mobile();
	
		//setup nav height (dynamic)
		nav_page_height();
	
		// run form elements
		// runAllForms();
		
	}

}

// Keep only 1 active popover per trigger - also check and hide active popover if user clicks on document
$('body').on('click', function(e) {
	$('[rel="popover"]').each(function() {
		//the 'is' for buttons that trigger popups
		//the 'has' for icons within a button that triggers a popup
		if (!$(this).is(e.target) && $(this).has(e.target).length === 0 && $('.popover').has(e.target).length === 0) {
			$(this).popover('hide');
		}
	});
});

//checks to see if a string value is null or empty
function IsNullOrEmpty(val) {
    return (val == null || val == '');
}

;
/*! Respond.js v1.4.2: min/max-width media query polyfill * Copyright 2013 Scott Jehl
 * Licensed under https://github.com/scottjehl/Respond/blob/master/LICENSE-MIT
 *  */

!function(a){"use strict";a.matchMedia=a.matchMedia||function(a){var b,c=a.documentElement,d=c.firstElementChild||c.firstChild,e=a.createElement("body"),f=a.createElement("div");return f.id="mq-test-1",f.style.cssText="position:absolute;top:-100em",e.style.background="none",e.appendChild(f),function(a){return f.innerHTML='&shy;<style media="'+a+'"> #mq-test-1 { width: 42px; }</style>',c.insertBefore(e,d),b=42===f.offsetWidth,c.removeChild(e),{matches:b,media:a}}}(a.document)}(this),function(a){"use strict";function b(){u(!0)}var c={};a.respond=c,c.update=function(){};var d=[],e=function(){var b=!1;try{b=new a.XMLHttpRequest}catch(c){b=new a.ActiveXObject("Microsoft.XMLHTTP")}return function(){return b}}(),f=function(a,b){var c=e();c&&(c.open("GET",a,!0),c.onreadystatechange=function(){4!==c.readyState||200!==c.status&&304!==c.status||b(c.responseText)},4!==c.readyState&&c.send(null))};if(c.ajax=f,c.queue=d,c.regex={media:/@media[^\{]+\{([^\{\}]*\{[^\}\{]*\})+/gi,keyframes:/@(?:\-(?:o|moz|webkit)\-)?keyframes[^\{]+\{(?:[^\{\}]*\{[^\}\{]*\})+[^\}]*\}/gi,urls:/(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g,findStyles:/@media *([^\{]+)\{([\S\s]+?)$/,only:/(only\s+)?([a-zA-Z]+)\s?/,minw:/\([\s]*min\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/,maxw:/\([\s]*max\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/},c.mediaQueriesSupported=a.matchMedia&&null!==a.matchMedia("only all")&&a.matchMedia("only all").matches,!c.mediaQueriesSupported){var g,h,i,j=a.document,k=j.documentElement,l=[],m=[],n=[],o={},p=30,q=j.getElementsByTagName("head")[0]||k,r=j.getElementsByTagName("base")[0],s=q.getElementsByTagName("link"),t=function(){var a,b=j.createElement("div"),c=j.body,d=k.style.fontSize,e=c&&c.style.fontSize,f=!1;return b.style.cssText="position:absolute;font-size:1em;width:1em",c||(c=f=j.createElement("body"),c.style.background="none"),k.style.fontSize="100%",c.style.fontSize="100%",c.appendChild(b),f&&k.insertBefore(c,k.firstChild),a=b.offsetWidth,f?k.removeChild(c):c.removeChild(b),k.style.fontSize=d,e&&(c.style.fontSize=e),a=i=parseFloat(a)},u=function(b){var c="clientWidth",d=k[c],e="CSS1Compat"===j.compatMode&&d||j.body[c]||d,f={},o=s[s.length-1],r=(new Date).getTime();if(b&&g&&p>r-g)return a.clearTimeout(h),h=a.setTimeout(u,p),void 0;g=r;for(var v in l)if(l.hasOwnProperty(v)){var w=l[v],x=w.minw,y=w.maxw,z=null===x,A=null===y,B="em";x&&(x=parseFloat(x)*(x.indexOf(B)>-1?i||t():1)),y&&(y=parseFloat(y)*(y.indexOf(B)>-1?i||t():1)),w.hasquery&&(z&&A||!(z||e>=x)||!(A||y>=e))||(f[w.media]||(f[w.media]=[]),f[w.media].push(m[w.rules]))}for(var C in n)n.hasOwnProperty(C)&&n[C]&&n[C].parentNode===q&&q.removeChild(n[C]);n.length=0;for(var D in f)if(f.hasOwnProperty(D)){var E=j.createElement("style"),F=f[D].join("\n");E.type="text/css",E.media=D,q.insertBefore(E,o.nextSibling),E.styleSheet?E.styleSheet.cssText=F:E.appendChild(j.createTextNode(F)),n.push(E)}},v=function(a,b,d){var e=a.replace(c.regex.keyframes,"").match(c.regex.media),f=e&&e.length||0;b=b.substring(0,b.lastIndexOf("/"));var g=function(a){return a.replace(c.regex.urls,"$1"+b+"$2$3")},h=!f&&d;b.length&&(b+="/"),h&&(f=1);for(var i=0;f>i;i++){var j,k,n,o;h?(j=d,m.push(g(a))):(j=e[i].match(c.regex.findStyles)&&RegExp.$1,m.push(RegExp.$2&&g(RegExp.$2))),n=j.split(","),o=n.length;for(var p=0;o>p;p++)k=n[p],l.push({media:k.split("(")[0].match(c.regex.only)&&RegExp.$2||"all",rules:m.length-1,hasquery:k.indexOf("(")>-1,minw:k.match(c.regex.minw)&&parseFloat(RegExp.$1)+(RegExp.$2||""),maxw:k.match(c.regex.maxw)&&parseFloat(RegExp.$1)+(RegExp.$2||"")})}u()},w=function(){if(d.length){var b=d.shift();f(b.href,function(c){v(c,b.href,b.media),o[b.href]=!0,a.setTimeout(function(){w()},0)})}},x=function(){for(var b=0;b<s.length;b++){var c=s[b],e=c.href,f=c.media,g=c.rel&&"stylesheet"===c.rel.toLowerCase();e&&g&&!o[e]&&(c.styleSheet&&c.styleSheet.rawCssText?(v(c.styleSheet.rawCssText,e,f),o[e]=!0):(!/^([a-zA-Z:]*\/\/)/.test(e)&&!r||e.replace(RegExp.$1,"").split("/")[0]===a.location.host)&&("//"===e.substring(0,2)&&(e=a.location.protocol+e),d.push({href:e,media:f})))}w()};x(),c.update=x,c.getEmValue=t,a.addEventListener?a.addEventListener("resize",b,!1):a.attachEvent&&a.attachEvent("onresize",b)}}(this);;
/*!
 * Intro.js v4.0.0
 * https://introjs.com
 *
 * Copyright (C) 2012-2021 Afshin Mehrabani (@afshinmeh).
 * https://raw.githubusercontent.com/usablica/intro.js/master/license.md
 *
 * Date: Sun, 13 Jun 2021 08:16:17 GMT
 */

(function (global, factory) {
  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
  typeof define === 'function' && define.amd ? define(factory) :
  (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.introJs = factory());
}(this, (function () { 'use strict';

  function _typeof(obj) {
    "@babel/helpers - typeof";

    if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
      _typeof = function (obj) {
        return typeof obj;
      };
    } else {
      _typeof = function (obj) {
        return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
      };
    }

    return _typeof(obj);
  }

  /**
   * Overwrites obj1's values with obj2's and adds obj2's if non existent in obj1
   * via: http://stackoverflow.com/questions/171251/how-can-i-merge-properties-of-two-javascript-objects-dynamically
   *
   * @param obj1
   * @param obj2
   * @returns obj3 a new object based on obj1 and obj2
   */
  function mergeOptions(obj1, obj2) {
    var obj3 = {};
    var attrname;

    for (attrname in obj1) {
      obj3[attrname] = obj1[attrname];
    }

    for (attrname in obj2) {
      obj3[attrname] = obj2[attrname];
    }

    return obj3;
  }

  /**
   * Mark any object with an incrementing number
   * used for keeping track of objects
   *
   * @param Object obj   Any object or DOM Element
   * @param String key
   * @return Object
   */
  var stamp = function () {
    var keys = {};
    return function stamp(obj) {
      var key = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "introjs-stamp";
      // each group increments from 0
      keys[key] = keys[key] || 0; // stamp only once per object

      if (obj[key] === undefined) {
        // increment key for each new object
        obj[key] = keys[key]++;
      }

      return obj[key];
    };
  }();

  /**
   * Iterates arrays
   *
   * @param {Array} arr
   * @param {Function} forEachFnc
   * @param {Function} [completeFnc]
   * @return {Null}
   */
  function forEach(arr, forEachFnc, completeFnc) {
    // in case arr is an empty query selector node list
    if (arr) {
      for (var i = 0, len = arr.length; i < len; i++) {
        forEachFnc(arr[i], i);
      }
    }

    if (typeof completeFnc === "function") {
      completeFnc();
    }
  }

  /**
   * DOMEvent Handles all DOM events
   *
   * methods:
   *
   * on - add event handler
   * off - remove event
   */

  var DOMEvent = function () {
    function DOMEvent() {
      var events_key = "introjs_event";
      /**
       * Gets a unique ID for an event listener
       *
       * @param obj Object
       * @param type event type
       * @param listener Function
       * @param context Object
       * @return String
       */

      this._id = function (obj, type, listener, context) {
        return type + stamp(listener) + (context ? "_".concat(stamp(context)) : "");
      };
      /**
       * Adds event listener
       *
       * @param obj Object obj
       * @param type String
       * @param listener Function
       * @param context Object
       * @param useCapture Boolean
       * @return null
       */


      this.on = function (obj, type, listener, context, useCapture) {
        var id = this._id.apply(this, arguments);

        var handler = function handler(e) {
          return listener.call(context || obj, e || window.event);
        };

        if ("addEventListener" in obj) {
          obj.addEventListener(type, handler, useCapture);
        } else if ("attachEvent" in obj) {
          obj.attachEvent("on".concat(type), handler);
        }

        obj[events_key] = obj[events_key] || {};
        obj[events_key][id] = handler;
      };
      /**
       * Removes event listener
       *
       * @param obj Object
       * @param type String
       * @param listener Function
       * @param context Object
       * @param useCapture Boolean
       * @return null
       */


      this.off = function (obj, type, listener, context, useCapture) {
        var id = this._id.apply(this, arguments);

        var handler = obj[events_key] && obj[events_key][id];

        if (!handler) {
          return;
        }

        if ("removeEventListener" in obj) {
          obj.removeEventListener(type, handler, useCapture);
        } else if ("detachEvent" in obj) {
          obj.detachEvent("on".concat(type), handler);
        }

        obj[events_key][id] = null;
      };
    }

    return new DOMEvent();
  }();

  var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};

  function createCommonjsModule(fn, module) {
  	return module = { exports: {} }, fn(module, module.exports), module.exports;
  }

  var check = function (it) {
    return it && it.Math == Math && it;
  };

  // https://github.com/zloirock/core-js/issues/86#issuecomment-115759028
  var global_1 =
    // eslint-disable-next-line es/no-global-this -- safe
    check(typeof globalThis == 'object' && globalThis) ||
    check(typeof window == 'object' && window) ||
    // eslint-disable-next-line no-restricted-globals -- safe
    check(typeof self == 'object' && self) ||
    check(typeof commonjsGlobal == 'object' && commonjsGlobal) ||
    // eslint-disable-next-line no-new-func -- fallback
    (function () { return this; })() || Function('return this')();

  var fails = function (exec) {
    try {
      return !!exec();
    } catch (error) {
      return true;
    }
  };

  // Detect IE8's incomplete defineProperty implementation
  var descriptors = !fails(function () {
    // eslint-disable-next-line es/no-object-defineproperty -- required for testing
    return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] != 7;
  });

  var $propertyIsEnumerable = {}.propertyIsEnumerable;
  // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe
  var getOwnPropertyDescriptor$1 = Object.getOwnPropertyDescriptor;

  // Nashorn ~ JDK8 bug
  var NASHORN_BUG = getOwnPropertyDescriptor$1 && !$propertyIsEnumerable.call({ 1: 2 }, 1);

  // `Object.prototype.propertyIsEnumerable` method implementation
  // https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable
  var f$4 = NASHORN_BUG ? function propertyIsEnumerable(V) {
    var descriptor = getOwnPropertyDescriptor$1(this, V);
    return !!descriptor && descriptor.enumerable;
  } : $propertyIsEnumerable;

  var objectPropertyIsEnumerable = {
  	f: f$4
  };

  var createPropertyDescriptor = function (bitmap, value) {
    return {
      enumerable: !(bitmap & 1),
      configurable: !(bitmap & 2),
      writable: !(bitmap & 4),
      value: value
    };
  };

  var toString = {}.toString;

  var classofRaw = function (it) {
    return toString.call(it).slice(8, -1);
  };

  var split = ''.split;

  // fallback for non-array-like ES3 and non-enumerable old V8 strings
  var indexedObject = fails(function () {
    // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346
    // eslint-disable-next-line no-prototype-builtins -- safe
    return !Object('z').propertyIsEnumerable(0);
  }) ? function (it) {
    return classofRaw(it) == 'String' ? split.call(it, '') : Object(it);
  } : Object;

  // `RequireObjectCoercible` abstract operation
  // https://tc39.es/ecma262/#sec-requireobjectcoercible
  var requireObjectCoercible = function (it) {
    if (it == undefined) throw TypeError("Can't call method on " + it);
    return it;
  };

  // toObject with fallback for non-array-like ES3 strings



  var toIndexedObject = function (it) {
    return indexedObject(requireObjectCoercible(it));
  };

  var isObject = function (it) {
    return typeof it === 'object' ? it !== null : typeof it === 'function';
  };

  // `ToPrimitive` abstract operation
  // https://tc39.es/ecma262/#sec-toprimitive
  // instead of the ES6 spec version, we didn't implement @@toPrimitive case
  // and the second argument - flag - preferred type is a string
  var toPrimitive = function (input, PREFERRED_STRING) {
    if (!isObject(input)) return input;
    var fn, val;
    if (PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
    if (typeof (fn = input.valueOf) == 'function' && !isObject(val = fn.call(input))) return val;
    if (!PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
    throw TypeError("Can't convert object to primitive value");
  };

  // `ToObject` abstract operation
  // https://tc39.es/ecma262/#sec-toobject
  var toObject = function (argument) {
    return Object(requireObjectCoercible(argument));
  };

  var hasOwnProperty = {}.hasOwnProperty;

  var has$1 = Object.hasOwn || function hasOwn(it, key) {
    return hasOwnProperty.call(toObject(it), key);
  };

  var document$1 = global_1.document;
  // typeof document.createElement is 'object' in old IE
  var EXISTS = isObject(document$1) && isObject(document$1.createElement);

  var documentCreateElement = function (it) {
    return EXISTS ? document$1.createElement(it) : {};
  };

  // Thank's IE8 for his funny defineProperty
  var ie8DomDefine = !descriptors && !fails(function () {
    // eslint-disable-next-line es/no-object-defineproperty -- requied for testing
    return Object.defineProperty(documentCreateElement('div'), 'a', {
      get: function () { return 7; }
    }).a != 7;
  });

  // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe
  var $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;

  // `Object.getOwnPropertyDescriptor` method
  // https://tc39.es/ecma262/#sec-object.getownpropertydescriptor
  var f$3 = descriptors ? $getOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {
    O = toIndexedObject(O);
    P = toPrimitive(P, true);
    if (ie8DomDefine) try {
      return $getOwnPropertyDescriptor(O, P);
    } catch (error) { /* empty */ }
    if (has$1(O, P)) return createPropertyDescriptor(!objectPropertyIsEnumerable.f.call(O, P), O[P]);
  };

  var objectGetOwnPropertyDescriptor = {
  	f: f$3
  };

  var anObject = function (it) {
    if (!isObject(it)) {
      throw TypeError(String(it) + ' is not an object');
    } return it;
  };

  // eslint-disable-next-line es/no-object-defineproperty -- safe
  var $defineProperty = Object.defineProperty;

  // `Object.defineProperty` method
  // https://tc39.es/ecma262/#sec-object.defineproperty
  var f$2 = descriptors ? $defineProperty : function defineProperty(O, P, Attributes) {
    anObject(O);
    P = toPrimitive(P, true);
    anObject(Attributes);
    if (ie8DomDefine) try {
      return $defineProperty(O, P, Attributes);
    } catch (error) { /* empty */ }
    if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported');
    if ('value' in Attributes) O[P] = Attributes.value;
    return O;
  };

  var objectDefineProperty = {
  	f: f$2
  };

  var createNonEnumerableProperty = descriptors ? function (object, key, value) {
    return objectDefineProperty.f(object, key, createPropertyDescriptor(1, value));
  } : function (object, key, value) {
    object[key] = value;
    return object;
  };

  var setGlobal = function (key, value) {
    try {
      createNonEnumerableProperty(global_1, key, value);
    } catch (error) {
      global_1[key] = value;
    } return value;
  };

  var SHARED = '__core-js_shared__';
  var store$1 = global_1[SHARED] || setGlobal(SHARED, {});

  var sharedStore = store$1;

  var functionToString = Function.toString;

  // this helper broken in `core-js@3.4.1-3.4.4`, so we can't use `shared` helper
  if (typeof sharedStore.inspectSource != 'function') {
    sharedStore.inspectSource = function (it) {
      return functionToString.call(it);
    };
  }

  var inspectSource = sharedStore.inspectSource;

  var WeakMap$1 = global_1.WeakMap;

  var nativeWeakMap = typeof WeakMap$1 === 'function' && /native code/.test(inspectSource(WeakMap$1));

  var shared = createCommonjsModule(function (module) {
  (module.exports = function (key, value) {
    return sharedStore[key] || (sharedStore[key] = value !== undefined ? value : {});
  })('versions', []).push({
    version: '3.14.0',
    mode: 'global',
    copyright: '© 2021 Denis Pushkarev (zloirock.ru)'
  });
  });

  var id = 0;
  var postfix = Math.random();

  var uid = function (key) {
    return 'Symbol(' + String(key === undefined ? '' : key) + ')_' + (++id + postfix).toString(36);
  };

  var keys = shared('keys');

  var sharedKey = function (key) {
    return keys[key] || (keys[key] = uid(key));
  };

  var hiddenKeys$1 = {};

  var OBJECT_ALREADY_INITIALIZED = 'Object already initialized';
  var WeakMap = global_1.WeakMap;
  var set, get, has;

  var enforce = function (it) {
    return has(it) ? get(it) : set(it, {});
  };

  var getterFor = function (TYPE) {
    return function (it) {
      var state;
      if (!isObject(it) || (state = get(it)).type !== TYPE) {
        throw TypeError('Incompatible receiver, ' + TYPE + ' required');
      } return state;
    };
  };

  if (nativeWeakMap || sharedStore.state) {
    var store = sharedStore.state || (sharedStore.state = new WeakMap());
    var wmget = store.get;
    var wmhas = store.has;
    var wmset = store.set;
    set = function (it, metadata) {
      if (wmhas.call(store, it)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);
      metadata.facade = it;
      wmset.call(store, it, metadata);
      return metadata;
    };
    get = function (it) {
      return wmget.call(store, it) || {};
    };
    has = function (it) {
      return wmhas.call(store, it);
    };
  } else {
    var STATE = sharedKey('state');
    hiddenKeys$1[STATE] = true;
    set = function (it, metadata) {
      if (has$1(it, STATE)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);
      metadata.facade = it;
      createNonEnumerableProperty(it, STATE, metadata);
      return metadata;
    };
    get = function (it) {
      return has$1(it, STATE) ? it[STATE] : {};
    };
    has = function (it) {
      return has$1(it, STATE);
    };
  }

  var internalState = {
    set: set,
    get: get,
    has: has,
    enforce: enforce,
    getterFor: getterFor
  };

  var redefine = createCommonjsModule(function (module) {
  var getInternalState = internalState.get;
  var enforceInternalState = internalState.enforce;
  var TEMPLATE = String(String).split('String');

  (module.exports = function (O, key, value, options) {
    var unsafe = options ? !!options.unsafe : false;
    var simple = options ? !!options.enumerable : false;
    var noTargetGet = options ? !!options.noTargetGet : false;
    var state;
    if (typeof value == 'function') {
      if (typeof key == 'string' && !has$1(value, 'name')) {
        createNonEnumerableProperty(value, 'name', key);
      }
      state = enforceInternalState(value);
      if (!state.source) {
        state.source = TEMPLATE.join(typeof key == 'string' ? key : '');
      }
    }
    if (O === global_1) {
      if (simple) O[key] = value;
      else setGlobal(key, value);
      return;
    } else if (!unsafe) {
      delete O[key];
    } else if (!noTargetGet && O[key]) {
      simple = true;
    }
    if (simple) O[key] = value;
    else createNonEnumerableProperty(O, key, value);
  // add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative
  })(Function.prototype, 'toString', function toString() {
    return typeof this == 'function' && getInternalState(this).source || inspectSource(this);
  });
  });

  var path = global_1;

  var aFunction$1 = function (variable) {
    return typeof variable == 'function' ? variable : undefined;
  };

  var getBuiltIn = function (namespace, method) {
    return arguments.length < 2 ? aFunction$1(path[namespace]) || aFunction$1(global_1[namespace])
      : path[namespace] && path[namespace][method] || global_1[namespace] && global_1[namespace][method];
  };

  var ceil = Math.ceil;
  var floor$2 = Math.floor;

  // `ToInteger` abstract operation
  // https://tc39.es/ecma262/#sec-tointeger
  var toInteger = function (argument) {
    return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor$2 : ceil)(argument);
  };

  var min$4 = Math.min;

  // `ToLength` abstract operation
  // https://tc39.es/ecma262/#sec-tolength
  var toLength = function (argument) {
    return argument > 0 ? min$4(toInteger(argument), 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991
  };

  var max$3 = Math.max;
  var min$3 = Math.min;

  // Helper for a popular repeating case of the spec:
  // Let integer be ? ToInteger(index).
  // If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).
  var toAbsoluteIndex = function (index, length) {
    var integer = toInteger(index);
    return integer < 0 ? max$3(integer + length, 0) : min$3(integer, length);
  };

  // `Array.prototype.{ indexOf, includes }` methods implementation
  var createMethod$2 = function (IS_INCLUDES) {
    return function ($this, el, fromIndex) {
      var O = toIndexedObject($this);
      var length = toLength(O.length);
      var index = toAbsoluteIndex(fromIndex, length);
      var value;
      // Array#includes uses SameValueZero equality algorithm
      // eslint-disable-next-line no-self-compare -- NaN check
      if (IS_INCLUDES && el != el) while (length > index) {
        value = O[index++];
        // eslint-disable-next-line no-self-compare -- NaN check
        if (value != value) return true;
      // Array#indexOf ignores holes, Array#includes - not
      } else for (;length > index; index++) {
        if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;
      } return !IS_INCLUDES && -1;
    };
  };

  var arrayIncludes = {
    // `Array.prototype.includes` method
    // https://tc39.es/ecma262/#sec-array.prototype.includes
    includes: createMethod$2(true),
    // `Array.prototype.indexOf` method
    // https://tc39.es/ecma262/#sec-array.prototype.indexof
    indexOf: createMethod$2(false)
  };

  var indexOf = arrayIncludes.indexOf;


  var objectKeysInternal = function (object, names) {
    var O = toIndexedObject(object);
    var i = 0;
    var result = [];
    var key;
    for (key in O) !has$1(hiddenKeys$1, key) && has$1(O, key) && result.push(key);
    // Don't enum bug & hidden keys
    while (names.length > i) if (has$1(O, key = names[i++])) {
      ~indexOf(result, key) || result.push(key);
    }
    return result;
  };

  // IE8- don't enum bug keys
  var enumBugKeys = [
    'constructor',
    'hasOwnProperty',
    'isPrototypeOf',
    'propertyIsEnumerable',
    'toLocaleString',
    'toString',
    'valueOf'
  ];

  var hiddenKeys = enumBugKeys.concat('length', 'prototype');

  // `Object.getOwnPropertyNames` method
  // https://tc39.es/ecma262/#sec-object.getownpropertynames
  // eslint-disable-next-line es/no-object-getownpropertynames -- safe
  var f$1 = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {
    return objectKeysInternal(O, hiddenKeys);
  };

  var objectGetOwnPropertyNames = {
  	f: f$1
  };

  // eslint-disable-next-line es/no-object-getownpropertysymbols -- safe
  var f = Object.getOwnPropertySymbols;

  var objectGetOwnPropertySymbols = {
  	f: f
  };

  // all object keys, includes non-enumerable and symbols
  var ownKeys = getBuiltIn('Reflect', 'ownKeys') || function ownKeys(it) {
    var keys = objectGetOwnPropertyNames.f(anObject(it));
    var getOwnPropertySymbols = objectGetOwnPropertySymbols.f;
    return getOwnPropertySymbols ? keys.concat(getOwnPropertySymbols(it)) : keys;
  };

  var copyConstructorProperties = function (target, source) {
    var keys = ownKeys(source);
    var defineProperty = objectDefineProperty.f;
    var getOwnPropertyDescriptor = objectGetOwnPropertyDescriptor.f;
    for (var i = 0; i < keys.length; i++) {
      var key = keys[i];
      if (!has$1(target, key)) defineProperty(target, key, getOwnPropertyDescriptor(source, key));
    }
  };

  var replacement = /#|\.prototype\./;

  var isForced = function (feature, detection) {
    var value = data[normalize(feature)];
    return value == POLYFILL ? true
      : value == NATIVE ? false
      : typeof detection == 'function' ? fails(detection)
      : !!detection;
  };

  var normalize = isForced.normalize = function (string) {
    return String(string).replace(replacement, '.').toLowerCase();
  };

  var data = isForced.data = {};
  var NATIVE = isForced.NATIVE = 'N';
  var POLYFILL = isForced.POLYFILL = 'P';

  var isForced_1 = isForced;

  var getOwnPropertyDescriptor = objectGetOwnPropertyDescriptor.f;






  /*
    options.target      - name of the target object
    options.global      - target is the global object
    options.stat        - export as static methods of target
    options.proto       - export as prototype methods of target
    options.real        - real prototype method for the `pure` version
    options.forced      - export even if the native feature is available
    options.bind        - bind methods to the target, required for the `pure` version
    options.wrap        - wrap constructors to preventing global pollution, required for the `pure` version
    options.unsafe      - use the simple assignment of property instead of delete + defineProperty
    options.sham        - add a flag to not completely full polyfills
    options.enumerable  - export as enumerable property
    options.noTargetGet - prevent calling a getter on target
  */
  var _export = function (options, source) {
    var TARGET = options.target;
    var GLOBAL = options.global;
    var STATIC = options.stat;
    var FORCED, target, key, targetProperty, sourceProperty, descriptor;
    if (GLOBAL) {
      target = global_1;
    } else if (STATIC) {
      target = global_1[TARGET] || setGlobal(TARGET, {});
    } else {
      target = (global_1[TARGET] || {}).prototype;
    }
    if (target) for (key in source) {
      sourceProperty = source[key];
      if (options.noTargetGet) {
        descriptor = getOwnPropertyDescriptor(target, key);
        targetProperty = descriptor && descriptor.value;
      } else targetProperty = target[key];
      FORCED = isForced_1(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);
      // contained in target
      if (!FORCED && targetProperty !== undefined) {
        if (typeof sourceProperty === typeof targetProperty) continue;
        copyConstructorProperties(sourceProperty, targetProperty);
      }
      // add a flag to not completely full polyfills
      if (options.sham || (targetProperty && targetProperty.sham)) {
        createNonEnumerableProperty(sourceProperty, 'sham', true);
      }
      // extend global
      redefine(target, key, sourceProperty, options);
    }
  };

  // `RegExp.prototype.flags` getter implementation
  // https://tc39.es/ecma262/#sec-get-regexp.prototype.flags
  var regexpFlags = function () {
    var that = anObject(this);
    var result = '';
    if (that.global) result += 'g';
    if (that.ignoreCase) result += 'i';
    if (that.multiline) result += 'm';
    if (that.dotAll) result += 's';
    if (that.unicode) result += 'u';
    if (that.sticky) result += 'y';
    return result;
  };

  // babel-minify transpiles RegExp('a', 'y') -> /a/y and it causes SyntaxError,
  // so we use an intermediate function.
  function RE(s, f) {
    return RegExp(s, f);
  }

  var UNSUPPORTED_Y$2 = fails(function () {
    // babel-minify transpiles RegExp('a', 'y') -> /a/y and it causes SyntaxError
    var re = RE('a', 'y');
    re.lastIndex = 2;
    return re.exec('abcd') != null;
  });

  var BROKEN_CARET = fails(function () {
    // https://bugzilla.mozilla.org/show_bug.cgi?id=773687
    var re = RE('^r', 'gy');
    re.lastIndex = 2;
    return re.exec('str') != null;
  });

  var regexpStickyHelpers = {
  	UNSUPPORTED_Y: UNSUPPORTED_Y$2,
  	BROKEN_CARET: BROKEN_CARET
  };

  /* eslint-disable regexp/no-assertion-capturing-group, regexp/no-empty-group, regexp/no-lazy-ends -- testing */
  /* eslint-disable regexp/no-useless-quantifier -- testing */




  var nativeExec = RegExp.prototype.exec;
  var nativeReplace = shared('native-string-replace', String.prototype.replace);

  var patchedExec = nativeExec;

  var UPDATES_LAST_INDEX_WRONG = (function () {
    var re1 = /a/;
    var re2 = /b*/g;
    nativeExec.call(re1, 'a');
    nativeExec.call(re2, 'a');
    return re1.lastIndex !== 0 || re2.lastIndex !== 0;
  })();

  var UNSUPPORTED_Y$1 = regexpStickyHelpers.UNSUPPORTED_Y || regexpStickyHelpers.BROKEN_CARET;

  // nonparticipating capturing group, copied from es5-shim's String#split patch.
  var NPCG_INCLUDED = /()??/.exec('')[1] !== undefined;

  var PATCH = UPDATES_LAST_INDEX_WRONG || NPCG_INCLUDED || UNSUPPORTED_Y$1;

  if (PATCH) {
    patchedExec = function exec(str) {
      var re = this;
      var lastIndex, reCopy, match, i;
      var sticky = UNSUPPORTED_Y$1 && re.sticky;
      var flags = regexpFlags.call(re);
      var source = re.source;
      var charsAdded = 0;
      var strCopy = str;

      if (sticky) {
        flags = flags.replace('y', '');
        if (flags.indexOf('g') === -1) {
          flags += 'g';
        }

        strCopy = String(str).slice(re.lastIndex);
        // Support anchored sticky behavior.
        if (re.lastIndex > 0 && (!re.multiline || re.multiline && str[re.lastIndex - 1] !== '\n')) {
          source = '(?: ' + source + ')';
          strCopy = ' ' + strCopy;
          charsAdded++;
        }
        // ^(? + rx + ) is needed, in combination with some str slicing, to
        // simulate the 'y' flag.
        reCopy = new RegExp('^(?:' + source + ')', flags);
      }

      if (NPCG_INCLUDED) {
        reCopy = new RegExp('^' + source + '$(?!\\s)', flags);
      }
      if (UPDATES_LAST_INDEX_WRONG) lastIndex = re.lastIndex;

      match = nativeExec.call(sticky ? reCopy : re, strCopy);

      if (sticky) {
        if (match) {
          match.input = match.input.slice(charsAdded);
          match[0] = match[0].slice(charsAdded);
          match.index = re.lastIndex;
          re.lastIndex += match[0].length;
        } else re.lastIndex = 0;
      } else if (UPDATES_LAST_INDEX_WRONG && match) {
        re.lastIndex = re.global ? match.index + match[0].length : lastIndex;
      }
      if (NPCG_INCLUDED && match && match.length > 1) {
        // Fix browsers whose `exec` methods don't consistently return `undefined`
        // for NPCG, like IE8. NOTE: This doesn' work for /(.?)?/
        nativeReplace.call(match[0], reCopy, function () {
          for (i = 1; i < arguments.length - 2; i++) {
            if (arguments[i] === undefined) match[i] = undefined;
          }
        });
      }

      return match;
    };
  }

  var regexpExec = patchedExec;

  // `RegExp.prototype.exec` method
  // https://tc39.es/ecma262/#sec-regexp.prototype.exec
  _export({ target: 'RegExp', proto: true, forced: /./.exec !== regexpExec }, {
    exec: regexpExec
  });

  var engineUserAgent = getBuiltIn('navigator', 'userAgent') || '';

  var process = global_1.process;
  var versions = process && process.versions;
  var v8 = versions && versions.v8;
  var match, version$1;

  if (v8) {
    match = v8.split('.');
    version$1 = match[0] < 4 ? 1 : match[0] + match[1];
  } else if (engineUserAgent) {
    match = engineUserAgent.match(/Edge\/(\d+)/);
    if (!match || match[1] >= 74) {
      match = engineUserAgent.match(/Chrome\/(\d+)/);
      if (match) version$1 = match[1];
    }
  }

  var engineV8Version = version$1 && +version$1;

  /* eslint-disable es/no-symbol -- required for testing */



  // eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing
  var nativeSymbol = !!Object.getOwnPropertySymbols && !fails(function () {
    var symbol = Symbol();
    // Chrome 38 Symbol has incorrect toString conversion
    // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances
    return !String(symbol) || !(Object(symbol) instanceof Symbol) ||
      // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances
      !Symbol.sham && engineV8Version && engineV8Version < 41;
  });

  /* eslint-disable es/no-symbol -- required for testing */


  var useSymbolAsUid = nativeSymbol
    && !Symbol.sham
    && typeof Symbol.iterator == 'symbol';

  var WellKnownSymbolsStore = shared('wks');
  var Symbol$1 = global_1.Symbol;
  var createWellKnownSymbol = useSymbolAsUid ? Symbol$1 : Symbol$1 && Symbol$1.withoutSetter || uid;

  var wellKnownSymbol = function (name) {
    if (!has$1(WellKnownSymbolsStore, name) || !(nativeSymbol || typeof WellKnownSymbolsStore[name] == 'string')) {
      if (nativeSymbol && has$1(Symbol$1, name)) {
        WellKnownSymbolsStore[name] = Symbol$1[name];
      } else {
        WellKnownSymbolsStore[name] = createWellKnownSymbol('Symbol.' + name);
      }
    } return WellKnownSymbolsStore[name];
  };

  // TODO: Remove from `core-js@4` since it's moved to entry points







  var SPECIES$4 = wellKnownSymbol('species');
  var RegExpPrototype$1 = RegExp.prototype;

  var REPLACE_SUPPORTS_NAMED_GROUPS = !fails(function () {
    // #replace needs built-in support for named groups.
    // #match works fine because it just return the exec results, even if it has
    // a "grops" property.
    var re = /./;
    re.exec = function () {
      var result = [];
      result.groups = { a: '7' };
      return result;
    };
    return ''.replace(re, '$<a>') !== '7';
  });

  // IE <= 11 replaces $0 with the whole match, as if it was $&
  // https://stackoverflow.com/questions/6024666/getting-ie-to-replace-a-regex-with-the-literal-string-0
  var REPLACE_KEEPS_$0 = (function () {
    // eslint-disable-next-line regexp/prefer-escape-replacement-dollar-char -- required for testing
    return 'a'.replace(/./, '$0') === '$0';
  })();

  var REPLACE = wellKnownSymbol('replace');
  // Safari <= 13.0.3(?) substitutes nth capture where n>m with an empty string
  var REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE = (function () {
    if (/./[REPLACE]) {
      return /./[REPLACE]('a', '$0') === '';
    }
    return false;
  })();

  // Chrome 51 has a buggy "split" implementation when RegExp#exec !== nativeExec
  // Weex JS has frozen built-in prototypes, so use try / catch wrapper
  var SPLIT_WORKS_WITH_OVERWRITTEN_EXEC = !fails(function () {
    // eslint-disable-next-line regexp/no-empty-group -- required for testing
    var re = /(?:)/;
    var originalExec = re.exec;
    re.exec = function () { return originalExec.apply(this, arguments); };
    var result = 'ab'.split(re);
    return result.length !== 2 || result[0] !== 'a' || result[1] !== 'b';
  });

  var fixRegexpWellKnownSymbolLogic = function (KEY, length, exec, sham) {
    var SYMBOL = wellKnownSymbol(KEY);

    var DELEGATES_TO_SYMBOL = !fails(function () {
      // String methods call symbol-named RegEp methods
      var O = {};
      O[SYMBOL] = function () { return 7; };
      return ''[KEY](O) != 7;
    });

    var DELEGATES_TO_EXEC = DELEGATES_TO_SYMBOL && !fails(function () {
      // Symbol-named RegExp methods call .exec
      var execCalled = false;
      var re = /a/;

      if (KEY === 'split') {
        // We can't use real regex here since it causes deoptimization
        // and serious performance degradation in V8
        // https://github.com/zloirock/core-js/issues/306
        re = {};
        // RegExp[@@split] doesn't call the regex's exec method, but first creates
        // a new one. We need to return the patched regex when creating the new one.
        re.constructor = {};
        re.constructor[SPECIES$4] = function () { return re; };
        re.flags = '';
        re[SYMBOL] = /./[SYMBOL];
      }

      re.exec = function () { execCalled = true; return null; };

      re[SYMBOL]('');
      return !execCalled;
    });

    if (
      !DELEGATES_TO_SYMBOL ||
      !DELEGATES_TO_EXEC ||
      (KEY === 'replace' && !(
        REPLACE_SUPPORTS_NAMED_GROUPS &&
        REPLACE_KEEPS_$0 &&
        !REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE
      )) ||
      (KEY === 'split' && !SPLIT_WORKS_WITH_OVERWRITTEN_EXEC)
    ) {
      var nativeRegExpMethod = /./[SYMBOL];
      var methods = exec(SYMBOL, ''[KEY], function (nativeMethod, regexp, str, arg2, forceStringMethod) {
        var $exec = regexp.exec;
        if ($exec === regexpExec || $exec === RegExpPrototype$1.exec) {
          if (DELEGATES_TO_SYMBOL && !forceStringMethod) {
            // The native String method already delegates to @@method (this
            // polyfilled function), leasing to infinite recursion.
            // We avoid it by directly calling the native @@method method.
            return { done: true, value: nativeRegExpMethod.call(regexp, str, arg2) };
          }
          return { done: true, value: nativeMethod.call(str, regexp, arg2) };
        }
        return { done: false };
      }, {
        REPLACE_KEEPS_$0: REPLACE_KEEPS_$0,
        REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE: REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE
      });
      var stringMethod = methods[0];
      var regexMethod = methods[1];

      redefine(String.prototype, KEY, stringMethod);
      redefine(RegExpPrototype$1, SYMBOL, length == 2
        // 21.2.5.8 RegExp.prototype[@@replace](string, replaceValue)
        // 21.2.5.11 RegExp.prototype[@@split](string, limit)
        ? function (string, arg) { return regexMethod.call(string, this, arg); }
        // 21.2.5.6 RegExp.prototype[@@match](string)
        // 21.2.5.9 RegExp.prototype[@@search](string)
        : function (string) { return regexMethod.call(string, this); }
      );
    }

    if (sham) createNonEnumerableProperty(RegExpPrototype$1[SYMBOL], 'sham', true);
  };

  // `String.prototype.{ codePointAt, at }` methods implementation
  var createMethod$1 = function (CONVERT_TO_STRING) {
    return function ($this, pos) {
      var S = String(requireObjectCoercible($this));
      var position = toInteger(pos);
      var size = S.length;
      var first, second;
      if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;
      first = S.charCodeAt(position);
      return first < 0xD800 || first > 0xDBFF || position + 1 === size
        || (second = S.charCodeAt(position + 1)) < 0xDC00 || second > 0xDFFF
          ? CONVERT_TO_STRING ? S.charAt(position) : first
          : CONVERT_TO_STRING ? S.slice(position, position + 2) : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;
    };
  };

  var stringMultibyte = {
    // `String.prototype.codePointAt` method
    // https://tc39.es/ecma262/#sec-string.prototype.codepointat
    codeAt: createMethod$1(false),
    // `String.prototype.at` method
    // https://github.com/mathiasbynens/String.prototype.at
    charAt: createMethod$1(true)
  };

  var charAt = stringMultibyte.charAt;

  // `AdvanceStringIndex` abstract operation
  // https://tc39.es/ecma262/#sec-advancestringindex
  var advanceStringIndex = function (S, index, unicode) {
    return index + (unicode ? charAt(S, index).length : 1);
  };

  // `RegExpExec` abstract operation
  // https://tc39.es/ecma262/#sec-regexpexec
  var regexpExecAbstract = function (R, S) {
    var exec = R.exec;
    if (typeof exec === 'function') {
      var result = exec.call(R, S);
      if (typeof result !== 'object') {
        throw TypeError('RegExp exec method returned something other than an Object or null');
      }
      return result;
    }

    if (classofRaw(R) !== 'RegExp') {
      throw TypeError('RegExp#exec called on incompatible receiver');
    }

    return regexpExec.call(R, S);
  };

  // @@match logic
  fixRegexpWellKnownSymbolLogic('match', 1, function (MATCH, nativeMatch, maybeCallNative) {
    return [
      // `String.prototype.match` method
      // https://tc39.es/ecma262/#sec-string.prototype.match
      function match(regexp) {
        var O = requireObjectCoercible(this);
        var matcher = regexp == undefined ? undefined : regexp[MATCH];
        return matcher !== undefined ? matcher.call(regexp, O) : new RegExp(regexp)[MATCH](String(O));
      },
      // `RegExp.prototype[@@match]` method
      // https://tc39.es/ecma262/#sec-regexp.prototype-@@match
      function (regexp) {
        var res = maybeCallNative(nativeMatch, regexp, this);
        if (res.done) return res.value;

        var rx = anObject(regexp);
        var S = String(this);

        if (!rx.global) return regexpExecAbstract(rx, S);

        var fullUnicode = rx.unicode;
        rx.lastIndex = 0;
        var A = [];
        var n = 0;
        var result;
        while ((result = regexpExecAbstract(rx, S)) !== null) {
          var matchStr = String(result[0]);
          A[n] = matchStr;
          if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);
          n++;
        }
        return n === 0 ? null : A;
      }
    ];
  });

  // `IsArray` abstract operation
  // https://tc39.es/ecma262/#sec-isarray
  // eslint-disable-next-line es/no-array-isarray -- safe
  var isArray = Array.isArray || function isArray(arg) {
    return classofRaw(arg) == 'Array';
  };

  var createProperty = function (object, key, value) {
    var propertyKey = toPrimitive(key);
    if (propertyKey in object) objectDefineProperty.f(object, propertyKey, createPropertyDescriptor(0, value));
    else object[propertyKey] = value;
  };

  var SPECIES$3 = wellKnownSymbol('species');

  // `ArraySpeciesCreate` abstract operation
  // https://tc39.es/ecma262/#sec-arrayspeciescreate
  var arraySpeciesCreate = function (originalArray, length) {
    var C;
    if (isArray(originalArray)) {
      C = originalArray.constructor;
      // cross-realm fallback
      if (typeof C == 'function' && (C === Array || isArray(C.prototype))) C = undefined;
      else if (isObject(C)) {
        C = C[SPECIES$3];
        if (C === null) C = undefined;
      }
    } return new (C === undefined ? Array : C)(length === 0 ? 0 : length);
  };

  var SPECIES$2 = wellKnownSymbol('species');

  var arrayMethodHasSpeciesSupport = function (METHOD_NAME) {
    // We can't use this feature detection in V8 since it causes
    // deoptimization and serious performance degradation
    // https://github.com/zloirock/core-js/issues/677
    return engineV8Version >= 51 || !fails(function () {
      var array = [];
      var constructor = array.constructor = {};
      constructor[SPECIES$2] = function () {
        return { foo: 1 };
      };
      return array[METHOD_NAME](Boolean).foo !== 1;
    });
  };

  var IS_CONCAT_SPREADABLE = wellKnownSymbol('isConcatSpreadable');
  var MAX_SAFE_INTEGER$1 = 0x1FFFFFFFFFFFFF;
  var MAXIMUM_ALLOWED_INDEX_EXCEEDED = 'Maximum allowed index exceeded';

  // We can't use this feature detection in V8 since it causes
  // deoptimization and serious performance degradation
  // https://github.com/zloirock/core-js/issues/679
  var IS_CONCAT_SPREADABLE_SUPPORT = engineV8Version >= 51 || !fails(function () {
    var array = [];
    array[IS_CONCAT_SPREADABLE] = false;
    return array.concat()[0] !== array;
  });

  var SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('concat');

  var isConcatSpreadable = function (O) {
    if (!isObject(O)) return false;
    var spreadable = O[IS_CONCAT_SPREADABLE];
    return spreadable !== undefined ? !!spreadable : isArray(O);
  };

  var FORCED$1 = !IS_CONCAT_SPREADABLE_SUPPORT || !SPECIES_SUPPORT;

  // `Array.prototype.concat` method
  // https://tc39.es/ecma262/#sec-array.prototype.concat
  // with adding support of @@isConcatSpreadable and @@species
  _export({ target: 'Array', proto: true, forced: FORCED$1 }, {
    // eslint-disable-next-line no-unused-vars -- required for `.length`
    concat: function concat(arg) {
      var O = toObject(this);
      var A = arraySpeciesCreate(O, 0);
      var n = 0;
      var i, k, length, len, E;
      for (i = -1, length = arguments.length; i < length; i++) {
        E = i === -1 ? O : arguments[i];
        if (isConcatSpreadable(E)) {
          len = toLength(E.length);
          if (n + len > MAX_SAFE_INTEGER$1) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
          for (k = 0; k < len; k++, n++) if (k in E) createProperty(A, n, E[k]);
        } else {
          if (n >= MAX_SAFE_INTEGER$1) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
          createProperty(A, n++, E);
        }
      }
      A.length = n;
      return A;
    }
  });

  var TO_STRING_TAG$1 = wellKnownSymbol('toStringTag');
  var test$1 = {};

  test$1[TO_STRING_TAG$1] = 'z';

  var toStringTagSupport = String(test$1) === '[object z]';

  var TO_STRING_TAG = wellKnownSymbol('toStringTag');
  // ES3 wrong here
  var CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) == 'Arguments';

  // fallback for IE11 Script Access Denied error
  var tryGet = function (it, key) {
    try {
      return it[key];
    } catch (error) { /* empty */ }
  };

  // getting tag from ES6+ `Object.prototype.toString`
  var classof = toStringTagSupport ? classofRaw : function (it) {
    var O, tag, result;
    return it === undefined ? 'Undefined' : it === null ? 'Null'
      // @@toStringTag case
      : typeof (tag = tryGet(O = Object(it), TO_STRING_TAG)) == 'string' ? tag
      // builtinTag case
      : CORRECT_ARGUMENTS ? classofRaw(O)
      // ES3 arguments fallback
      : (result = classofRaw(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : result;
  };

  // `Object.prototype.toString` method implementation
  // https://tc39.es/ecma262/#sec-object.prototype.tostring
  var objectToString = toStringTagSupport ? {}.toString : function toString() {
    return '[object ' + classof(this) + ']';
  };

  // `Object.prototype.toString` method
  // https://tc39.es/ecma262/#sec-object.prototype.tostring
  if (!toStringTagSupport) {
    redefine(Object.prototype, 'toString', objectToString, { unsafe: true });
  }

  var TO_STRING = 'toString';
  var RegExpPrototype = RegExp.prototype;
  var nativeToString = RegExpPrototype[TO_STRING];

  var NOT_GENERIC = fails(function () { return nativeToString.call({ source: 'a', flags: 'b' }) != '/a/b'; });
  // FF44- RegExp#toString has a wrong name
  var INCORRECT_NAME = nativeToString.name != TO_STRING;

  // `RegExp.prototype.toString` method
  // https://tc39.es/ecma262/#sec-regexp.prototype.tostring
  if (NOT_GENERIC || INCORRECT_NAME) {
    redefine(RegExp.prototype, TO_STRING, function toString() {
      var R = anObject(this);
      var p = String(R.source);
      var rf = R.flags;
      var f = String(rf === undefined && R instanceof RegExp && !('flags' in RegExpPrototype) ? regexpFlags.call(R) : rf);
      return '/' + p + '/' + f;
    }, { unsafe: true });
  }

  var MATCH$1 = wellKnownSymbol('match');

  // `IsRegExp` abstract operation
  // https://tc39.es/ecma262/#sec-isregexp
  var isRegexp = function (it) {
    var isRegExp;
    return isObject(it) && ((isRegExp = it[MATCH$1]) !== undefined ? !!isRegExp : classofRaw(it) == 'RegExp');
  };

  var aFunction = function (it) {
    if (typeof it != 'function') {
      throw TypeError(String(it) + ' is not a function');
    } return it;
  };

  var SPECIES$1 = wellKnownSymbol('species');

  // `SpeciesConstructor` abstract operation
  // https://tc39.es/ecma262/#sec-speciesconstructor
  var speciesConstructor = function (O, defaultConstructor) {
    var C = anObject(O).constructor;
    var S;
    return C === undefined || (S = anObject(C)[SPECIES$1]) == undefined ? defaultConstructor : aFunction(S);
  };

  var UNSUPPORTED_Y = regexpStickyHelpers.UNSUPPORTED_Y;
  var arrayPush = [].push;
  var min$2 = Math.min;
  var MAX_UINT32 = 0xFFFFFFFF;

  // @@split logic
  fixRegexpWellKnownSymbolLogic('split', 2, function (SPLIT, nativeSplit, maybeCallNative) {
    var internalSplit;
    if (
      'abbc'.split(/(b)*/)[1] == 'c' ||
      // eslint-disable-next-line regexp/no-empty-group -- required for testing
      'test'.split(/(?:)/, -1).length != 4 ||
      'ab'.split(/(?:ab)*/).length != 2 ||
      '.'.split(/(.?)(.?)/).length != 4 ||
      // eslint-disable-next-line regexp/no-assertion-capturing-group, regexp/no-empty-group -- required for testing
      '.'.split(/()()/).length > 1 ||
      ''.split(/.?/).length
    ) {
      // based on es5-shim implementation, need to rework it
      internalSplit = function (separator, limit) {
        var string = String(requireObjectCoercible(this));
        var lim = limit === undefined ? MAX_UINT32 : limit >>> 0;
        if (lim === 0) return [];
        if (separator === undefined) return [string];
        // If `separator` is not a regex, use native split
        if (!isRegexp(separator)) {
          return nativeSplit.call(string, separator, lim);
        }
        var output = [];
        var flags = (separator.ignoreCase ? 'i' : '') +
                    (separator.multiline ? 'm' : '') +
                    (separator.unicode ? 'u' : '') +
                    (separator.sticky ? 'y' : '');
        var lastLastIndex = 0;
        // Make `global` and avoid `lastIndex` issues by working with a copy
        var separatorCopy = new RegExp(separator.source, flags + 'g');
        var match, lastIndex, lastLength;
        while (match = regexpExec.call(separatorCopy, string)) {
          lastIndex = separatorCopy.lastIndex;
          if (lastIndex > lastLastIndex) {
            output.push(string.slice(lastLastIndex, match.index));
            if (match.length > 1 && match.index < string.length) arrayPush.apply(output, match.slice(1));
            lastLength = match[0].length;
            lastLastIndex = lastIndex;
            if (output.length >= lim) break;
          }
          if (separatorCopy.lastIndex === match.index) separatorCopy.lastIndex++; // Avoid an infinite loop
        }
        if (lastLastIndex === string.length) {
          if (lastLength || !separatorCopy.test('')) output.push('');
        } else output.push(string.slice(lastLastIndex));
        return output.length > lim ? output.slice(0, lim) : output;
      };
    // Chakra, V8
    } else if ('0'.split(undefined, 0).length) {
      internalSplit = function (separator, limit) {
        return separator === undefined && limit === 0 ? [] : nativeSplit.call(this, separator, limit);
      };
    } else internalSplit = nativeSplit;

    return [
      // `String.prototype.split` method
      // https://tc39.es/ecma262/#sec-string.prototype.split
      function split(separator, limit) {
        var O = requireObjectCoercible(this);
        var splitter = separator == undefined ? undefined : separator[SPLIT];
        return splitter !== undefined
          ? splitter.call(separator, O, limit)
          : internalSplit.call(String(O), separator, limit);
      },
      // `RegExp.prototype[@@split]` method
      // https://tc39.es/ecma262/#sec-regexp.prototype-@@split
      //
      // NOTE: This cannot be properly polyfilled in engines that don't support
      // the 'y' flag.
      function (regexp, limit) {
        var res = maybeCallNative(internalSplit, regexp, this, limit, internalSplit !== nativeSplit);
        if (res.done) return res.value;

        var rx = anObject(regexp);
        var S = String(this);
        var C = speciesConstructor(rx, RegExp);

        var unicodeMatching = rx.unicode;
        var flags = (rx.ignoreCase ? 'i' : '') +
                    (rx.multiline ? 'm' : '') +
                    (rx.unicode ? 'u' : '') +
                    (UNSUPPORTED_Y ? 'g' : 'y');

        // ^(? + rx + ) is needed, in combination with some S slicing, to
        // simulate the 'y' flag.
        var splitter = new C(UNSUPPORTED_Y ? '^(?:' + rx.source + ')' : rx, flags);
        var lim = limit === undefined ? MAX_UINT32 : limit >>> 0;
        if (lim === 0) return [];
        if (S.length === 0) return regexpExecAbstract(splitter, S) === null ? [S] : [];
        var p = 0;
        var q = 0;
        var A = [];
        while (q < S.length) {
          splitter.lastIndex = UNSUPPORTED_Y ? 0 : q;
          var z = regexpExecAbstract(splitter, UNSUPPORTED_Y ? S.slice(q) : S);
          var e;
          if (
            z === null ||
            (e = min$2(toLength(splitter.lastIndex + (UNSUPPORTED_Y ? q : 0)), S.length)) === p
          ) {
            q = advanceStringIndex(S, q, unicodeMatching);
          } else {
            A.push(S.slice(p, q));
            if (A.length === lim) return A;
            for (var i = 1; i <= z.length - 1; i++) {
              A.push(z[i]);
              if (A.length === lim) return A;
            }
            q = p = e;
          }
        }
        A.push(S.slice(p));
        return A;
      }
    ];
  }, UNSUPPORTED_Y);

  /**
   * Append a class to an element
   *
   * @api private
   * @method _addClass
   * @param {Object} element
   * @param {String} className
   * @returns null
   */

  function addClass(element, className) {
    if (element instanceof SVGElement) {
      // svg
      var pre = element.getAttribute("class") || "";

      if (!pre.match(className)) {
        // check if element doesn't already have className
        element.setAttribute("class", "".concat(pre, " ").concat(className));
      }
    } else {
      if (element.classList !== undefined) {
        // check for modern classList property
        var classes = className.split(" ");
        forEach(classes, function (cls) {
          element.classList.add(cls);
        });
      } else if (!element.className.match(className)) {
        // check if element doesn't already have className
        element.className += " ".concat(className);
      }
    }
  }

  /**
   * Get an element CSS property on the page
   * Thanks to JavaScript Kit: http://www.javascriptkit.com/dhtmltutors/dhtmlcascade4.shtml
   *
   * @api private
   * @method _getPropValue
   * @param {Object} element
   * @param {String} propName
   * @returns string property value
   */
  function getPropValue(element, propName) {
    var propValue = "";

    if (element.currentStyle) {
      //IE
      propValue = element.currentStyle[propName];
    } else if (document.defaultView && document.defaultView.getComputedStyle) {
      //Others
      propValue = document.defaultView.getComputedStyle(element, null).getPropertyValue(propName);
    } //Prevent exception in IE


    if (propValue && propValue.toLowerCase) {
      return propValue.toLowerCase();
    } else {
      return propValue;
    }
  }

  /**
   * To set the show element
   * This function set a relative (in most cases) position and changes the z-index
   *
   * @api private
   * @method _setShowElement
   * @param {Object} targetElement
   */

  function setShowElement(_ref) {
    var element = _ref.element;
    addClass(element, "introjs-showElement");
    var currentElementPosition = getPropValue(element, "position");

    if (currentElementPosition !== "absolute" && currentElementPosition !== "relative" && currentElementPosition !== "sticky" && currentElementPosition !== "fixed") {
      //change to new intro item
      addClass(element, "introjs-relativePosition");
    }
  }

  /**
   * Find the nearest scrollable parent
   * copied from https://stackoverflow.com/questions/35939886/find-first-scrollable-parent
   *
   * @param Element element
   * @return Element
   */
  function getScrollParent(element) {
    var style = window.getComputedStyle(element);
    var excludeStaticParent = style.position === "absolute";
    var overflowRegex = /(auto|scroll)/;
    if (style.position === "fixed") return document.body;

    for (var parent = element; parent = parent.parentElement;) {
      style = window.getComputedStyle(parent);

      if (excludeStaticParent && style.position === "static") {
        continue;
      }

      if (overflowRegex.test(style.overflow + style.overflowY + style.overflowX)) return parent;
    }

    return document.body;
  }

  /**
   * scroll a scrollable element to a child element
   *
   * @param {Object} targetElement
   */

  function scrollParentToElement(targetElement) {
    var element = targetElement.element;
    if (!this._options.scrollToElement) return;
    var parent = getScrollParent(element);
    if (parent === document.body) return;
    parent.scrollTop = element.offsetTop - parent.offsetTop;
  }

  /**
   * Provides a cross-browser way to get the screen dimensions
   * via: http://stackoverflow.com/questions/5864467/internet-explorer-innerheight
   *
   * @api private
   * @method _getWinSize
   * @returns {Object} width and height attributes
   */
  function getWinSize() {
    if (window.innerWidth !== undefined) {
      return {
        width: window.innerWidth,
        height: window.innerHeight
      };
    } else {
      var D = document.documentElement;
      return {
        width: D.clientWidth,
        height: D.clientHeight
      };
    }
  }

  /**
   * Check to see if the element is in the viewport or not
   * http://stackoverflow.com/questions/123999/how-to-tell-if-a-dom-element-is-visible-in-the-current-viewport
   *
   * @api private
   * @method _elementInViewport
   * @param {Object} el
   */
  function elementInViewport(el) {
    var rect = el.getBoundingClientRect();
    return rect.top >= 0 && rect.left >= 0 && rect.bottom + 80 <= window.innerHeight && // add 80 to get the text right
    rect.right <= window.innerWidth;
  }

  /**
   * To change the scroll of `window` after highlighting an element
   *
   * @api private
   * @param {String} scrollTo
   * @param {Object} targetElement
   * @param {Object} tooltipLayer
   */

  function scrollTo(scrollTo, _ref, tooltipLayer) {
    var element = _ref.element;
    if (scrollTo === "off") return;
    var rect;
    if (!this._options.scrollToElement) return;

    if (scrollTo === "tooltip") {
      rect = tooltipLayer.getBoundingClientRect();
    } else {
      rect = element.getBoundingClientRect();
    }

    if (!elementInViewport(element)) {
      var winHeight = getWinSize().height;
      var top = rect.bottom - (rect.bottom - rect.top); // TODO (afshinm): do we need scroll padding now?
      // I have changed the scroll option and now it scrolls the window to
      // the center of the target element or tooltip.

      if (top < 0 || element.clientHeight > winHeight) {
        window.scrollBy(0, rect.top - (winHeight / 2 - rect.height / 2) - this._options.scrollPadding); // 30px padding from edge to look nice
        //Scroll down
      } else {
        window.scrollBy(0, rect.top - (winHeight / 2 - rect.height / 2) + this._options.scrollPadding); // 30px padding from edge to look nice
      }
    }
  }

  /**
   * Setting anchors to behave like buttons
   *
   * @api private
   * @method _setAnchorAsButton
   */
  function setAnchorAsButton(anchor) {
    anchor.setAttribute("role", "button");
    anchor.tabIndex = 0;
  }

  // `Object.keys` method
  // https://tc39.es/ecma262/#sec-object.keys
  // eslint-disable-next-line es/no-object-keys -- safe
  var objectKeys = Object.keys || function keys(O) {
    return objectKeysInternal(O, enumBugKeys);
  };

  // eslint-disable-next-line es/no-object-assign -- safe
  var $assign = Object.assign;
  // eslint-disable-next-line es/no-object-defineproperty -- required for testing
  var defineProperty = Object.defineProperty;

  // `Object.assign` method
  // https://tc39.es/ecma262/#sec-object.assign
  var objectAssign = !$assign || fails(function () {
    // should have correct order of operations (Edge bug)
    if (descriptors && $assign({ b: 1 }, $assign(defineProperty({}, 'a', {
      enumerable: true,
      get: function () {
        defineProperty(this, 'b', {
          value: 3,
          enumerable: false
        });
      }
    }), { b: 2 })).b !== 1) return true;
    // should work with symbols and should have deterministic property order (V8 bug)
    var A = {};
    var B = {};
    // eslint-disable-next-line es/no-symbol -- safe
    var symbol = Symbol();
    var alphabet = 'abcdefghijklmnopqrst';
    A[symbol] = 7;
    alphabet.split('').forEach(function (chr) { B[chr] = chr; });
    return $assign({}, A)[symbol] != 7 || objectKeys($assign({}, B)).join('') != alphabet;
  }) ? function assign(target, source) { // eslint-disable-line no-unused-vars -- required for `.length`
    var T = toObject(target);
    var argumentsLength = arguments.length;
    var index = 1;
    var getOwnPropertySymbols = objectGetOwnPropertySymbols.f;
    var propertyIsEnumerable = objectPropertyIsEnumerable.f;
    while (argumentsLength > index) {
      var S = indexedObject(arguments[index++]);
      var keys = getOwnPropertySymbols ? objectKeys(S).concat(getOwnPropertySymbols(S)) : objectKeys(S);
      var length = keys.length;
      var j = 0;
      var key;
      while (length > j) {
        key = keys[j++];
        if (!descriptors || propertyIsEnumerable.call(S, key)) T[key] = S[key];
      }
    } return T;
  } : $assign;

  // `Object.assign` method
  // https://tc39.es/ecma262/#sec-object.assign
  // eslint-disable-next-line es/no-object-assign -- required for testing
  _export({ target: 'Object', stat: true, forced: Object.assign !== objectAssign }, {
    assign: objectAssign
  });

  /**
   * Get an element position on the page relative to another element (or body)
   * Thanks to `meouw`: http://stackoverflow.com/a/442474/375966
   *
   * @api private
   * @method getOffset
   * @param {Object} element
   * @param {Object} relativeEl
   * @returns Element's position info
   */

  function getOffset(element, relativeEl) {
    var body = document.body;
    var docEl = document.documentElement;
    var scrollTop = window.pageYOffset || docEl.scrollTop || body.scrollTop;
    var scrollLeft = window.pageXOffset || docEl.scrollLeft || body.scrollLeft;
    relativeEl = relativeEl || body;
    var x = element.getBoundingClientRect();
    var xr = relativeEl.getBoundingClientRect();
    var relativeElPosition = getPropValue(relativeEl, "position");
    var obj = {
      width: x.width,
      height: x.height
    };

    if (relativeEl.tagName.toLowerCase() !== "body" && relativeElPosition === "relative" || relativeElPosition === "sticky") {
      // when the container of our target element is _not_ body and has either "relative" or "sticky" position, we should not
      // consider the scroll position but we need to include the relative x/y of the container element
      return Object.assign(obj, {
        top: x.top - xr.top,
        left: x.left - xr.left
      });
    } else {
      return Object.assign(obj, {
        top: x.top + scrollTop,
        left: x.left + scrollLeft
      });
    }
  }

  /**
   * Checks to see if target element (or parents) position is fixed or not
   *
   * @api private
   * @method _isFixed
   * @param {Object} element
   * @returns Boolean
   */

  function isFixed(element) {
    var p = element.parentNode;

    if (!p || p.nodeName === "HTML") {
      return false;
    }

    if (getPropValue(element, "position") === "fixed") {
      return true;
    }

    return isFixed(p);
  }

  var floor$1 = Math.floor;
  var replace = ''.replace;
  var SUBSTITUTION_SYMBOLS = /\$([$&'`]|\d{1,2}|<[^>]*>)/g;
  var SUBSTITUTION_SYMBOLS_NO_NAMED = /\$([$&'`]|\d{1,2})/g;

  // `GetSubstitution` abstract operation
  // https://tc39.es/ecma262/#sec-getsubstitution
  var getSubstitution = function (matched, str, position, captures, namedCaptures, replacement) {
    var tailPos = position + matched.length;
    var m = captures.length;
    var symbols = SUBSTITUTION_SYMBOLS_NO_NAMED;
    if (namedCaptures !== undefined) {
      namedCaptures = toObject(namedCaptures);
      symbols = SUBSTITUTION_SYMBOLS;
    }
    return replace.call(replacement, symbols, function (match, ch) {
      var capture;
      switch (ch.charAt(0)) {
        case '$': return '$';
        case '&': return matched;
        case '`': return str.slice(0, position);
        case "'": return str.slice(tailPos);
        case '<':
          capture = namedCaptures[ch.slice(1, -1)];
          break;
        default: // \d\d?
          var n = +ch;
          if (n === 0) return match;
          if (n > m) {
            var f = floor$1(n / 10);
            if (f === 0) return match;
            if (f <= m) return captures[f - 1] === undefined ? ch.charAt(1) : captures[f - 1] + ch.charAt(1);
            return match;
          }
          capture = captures[n - 1];
      }
      return capture === undefined ? '' : capture;
    });
  };

  var max$2 = Math.max;
  var min$1 = Math.min;

  var maybeToString = function (it) {
    return it === undefined ? it : String(it);
  };

  // @@replace logic
  fixRegexpWellKnownSymbolLogic('replace', 2, function (REPLACE, nativeReplace, maybeCallNative, reason) {
    var REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE = reason.REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE;
    var REPLACE_KEEPS_$0 = reason.REPLACE_KEEPS_$0;
    var UNSAFE_SUBSTITUTE = REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE ? '$' : '$0';

    return [
      // `String.prototype.replace` method
      // https://tc39.es/ecma262/#sec-string.prototype.replace
      function replace(searchValue, replaceValue) {
        var O = requireObjectCoercible(this);
        var replacer = searchValue == undefined ? undefined : searchValue[REPLACE];
        return replacer !== undefined
          ? replacer.call(searchValue, O, replaceValue)
          : nativeReplace.call(String(O), searchValue, replaceValue);
      },
      // `RegExp.prototype[@@replace]` method
      // https://tc39.es/ecma262/#sec-regexp.prototype-@@replace
      function (regexp, replaceValue) {
        if (
          (!REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE && REPLACE_KEEPS_$0) ||
          (typeof replaceValue === 'string' && replaceValue.indexOf(UNSAFE_SUBSTITUTE) === -1)
        ) {
          var res = maybeCallNative(nativeReplace, regexp, this, replaceValue);
          if (res.done) return res.value;
        }

        var rx = anObject(regexp);
        var S = String(this);

        var functionalReplace = typeof replaceValue === 'function';
        if (!functionalReplace) replaceValue = String(replaceValue);

        var global = rx.global;
        if (global) {
          var fullUnicode = rx.unicode;
          rx.lastIndex = 0;
        }
        var results = [];
        while (true) {
          var result = regexpExecAbstract(rx, S);
          if (result === null) break;

          results.push(result);
          if (!global) break;

          var matchStr = String(result[0]);
          if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);
        }

        var accumulatedResult = '';
        var nextSourcePosition = 0;
        for (var i = 0; i < results.length; i++) {
          result = results[i];

          var matched = String(result[0]);
          var position = max$2(min$1(toInteger(result.index), S.length), 0);
          var captures = [];
          // NOTE: This is equivalent to
          //   captures = result.slice(1).map(maybeToString)
          // but for some reason `nativeSlice.call(result, 1, result.length)` (called in
          // the slice polyfill when slicing native arrays) "doesn't work" in safari 9 and
          // causes a crash (https://pastebin.com/N21QzeQA) when trying to debug it.
          for (var j = 1; j < result.length; j++) captures.push(maybeToString(result[j]));
          var namedCaptures = result.groups;
          if (functionalReplace) {
            var replacerArgs = [matched].concat(captures, position, S);
            if (namedCaptures !== undefined) replacerArgs.push(namedCaptures);
            var replacement = String(replaceValue.apply(undefined, replacerArgs));
          } else {
            replacement = getSubstitution(matched, S, position, captures, namedCaptures, replaceValue);
          }
          if (position >= nextSourcePosition) {
            accumulatedResult += S.slice(nextSourcePosition, position) + replacement;
            nextSourcePosition = position + matched.length;
          }
        }
        return accumulatedResult + S.slice(nextSourcePosition);
      }
    ];
  });

  /**
   * Remove a class from an element
   *
   * @api private
   * @method _removeClass
   * @param {Object} element
   * @param {RegExp|String} classNameRegex can be regex or string
   * @returns null
   */
  function removeClass(element, classNameRegex) {
    if (element instanceof SVGElement) {
      var pre = element.getAttribute("class") || "";
      element.setAttribute("class", pre.replace(classNameRegex, "").replace(/^\s+|\s+$/g, ""));
    } else {
      element.className = element.className.replace(classNameRegex, "").replace(/^\s+|\s+$/g, "");
    }
  }

  /**
   * Sets the style of an DOM element
   *
   * @param {Object} element
   * @param {Object|string} style
   * @return null
   */
  function setStyle(element, style) {
    var cssText = "";

    if (element.style.cssText) {
      cssText += element.style.cssText;
    }

    if (typeof style === "string") {
      cssText += style;
    } else {
      for (var rule in style) {
        cssText += "".concat(rule, ":").concat(style[rule], ";");
      }
    }

    element.style.cssText = cssText;
  }

  /**
   * Update the position of the helper layer on the screen
   *
   * @api private
   * @method _setHelperLayerPosition
   * @param {Object} helperLayer
   */

  function setHelperLayerPosition(helperLayer) {
    if (helperLayer) {
      //prevent error when `this._currentStep` in undefined
      if (!this._introItems[this._currentStep]) return;
      var currentElement = this._introItems[this._currentStep];
      var elementPosition = getOffset(currentElement.element, this._targetElement);
      var widthHeightPadding = this._options.helperElementPadding; // If the target element is fixed, the tooltip should be fixed as well.
      // Otherwise, remove a fixed class that may be left over from the previous
      // step.

      if (isFixed(currentElement.element)) {
        addClass(helperLayer, "introjs-fixedTooltip");
      } else {
        removeClass(helperLayer, "introjs-fixedTooltip");
      }

      if (currentElement.position === "floating") {
        widthHeightPadding = 0;
      } //set new position to helper layer


      setStyle(helperLayer, {
        width: "".concat(elementPosition.width + widthHeightPadding, "px"),
        height: "".concat(elementPosition.height + widthHeightPadding, "px"),
        top: "".concat(elementPosition.top - widthHeightPadding / 2, "px"),
        left: "".concat(elementPosition.left - widthHeightPadding / 2, "px")
      });
    }
  }

  // `Object.defineProperties` method
  // https://tc39.es/ecma262/#sec-object.defineproperties
  // eslint-disable-next-line es/no-object-defineproperties -- safe
  var objectDefineProperties = descriptors ? Object.defineProperties : function defineProperties(O, Properties) {
    anObject(O);
    var keys = objectKeys(Properties);
    var length = keys.length;
    var index = 0;
    var key;
    while (length > index) objectDefineProperty.f(O, key = keys[index++], Properties[key]);
    return O;
  };

  var html = getBuiltIn('document', 'documentElement');

  var GT = '>';
  var LT = '<';
  var PROTOTYPE = 'prototype';
  var SCRIPT = 'script';
  var IE_PROTO = sharedKey('IE_PROTO');

  var EmptyConstructor = function () { /* empty */ };

  var scriptTag = function (content) {
    return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;
  };

  // Create object with fake `null` prototype: use ActiveX Object with cleared prototype
  var NullProtoObjectViaActiveX = function (activeXDocument) {
    activeXDocument.write(scriptTag(''));
    activeXDocument.close();
    var temp = activeXDocument.parentWindow.Object;
    activeXDocument = null; // avoid memory leak
    return temp;
  };

  // Create object with fake `null` prototype: use iframe Object with cleared prototype
  var NullProtoObjectViaIFrame = function () {
    // Thrash, waste and sodomy: IE GC bug
    var iframe = documentCreateElement('iframe');
    var JS = 'java' + SCRIPT + ':';
    var iframeDocument;
    iframe.style.display = 'none';
    html.appendChild(iframe);
    // https://github.com/zloirock/core-js/issues/475
    iframe.src = String(JS);
    iframeDocument = iframe.contentWindow.document;
    iframeDocument.open();
    iframeDocument.write(scriptTag('document.F=Object'));
    iframeDocument.close();
    return iframeDocument.F;
  };

  // Check for document.domain and active x support
  // No need to use active x approach when document.domain is not set
  // see https://github.com/es-shims/es5-shim/issues/150
  // variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346
  // avoid IE GC bug
  var activeXDocument;
  var NullProtoObject = function () {
    try {
      /* global ActiveXObject -- old IE */
      activeXDocument = document.domain && new ActiveXObject('htmlfile');
    } catch (error) { /* ignore */ }
    NullProtoObject = activeXDocument ? NullProtoObjectViaActiveX(activeXDocument) : NullProtoObjectViaIFrame();
    var length = enumBugKeys.length;
    while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];
    return NullProtoObject();
  };

  hiddenKeys$1[IE_PROTO] = true;

  // `Object.create` method
  // https://tc39.es/ecma262/#sec-object.create
  var objectCreate = Object.create || function create(O, Properties) {
    var result;
    if (O !== null) {
      EmptyConstructor[PROTOTYPE] = anObject(O);
      result = new EmptyConstructor();
      EmptyConstructor[PROTOTYPE] = null;
      // add "__proto__" for Object.getPrototypeOf polyfill
      result[IE_PROTO] = O;
    } else result = NullProtoObject();
    return Properties === undefined ? result : objectDefineProperties(result, Properties);
  };

  var UNSCOPABLES = wellKnownSymbol('unscopables');
  var ArrayPrototype = Array.prototype;

  // Array.prototype[@@unscopables]
  // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables
  if (ArrayPrototype[UNSCOPABLES] == undefined) {
    objectDefineProperty.f(ArrayPrototype, UNSCOPABLES, {
      configurable: true,
      value: objectCreate(null)
    });
  }

  // add a key to Array.prototype[@@unscopables]
  var addToUnscopables = function (key) {
    ArrayPrototype[UNSCOPABLES][key] = true;
  };

  var $includes = arrayIncludes.includes;


  // `Array.prototype.includes` method
  // https://tc39.es/ecma262/#sec-array.prototype.includes
  _export({ target: 'Array', proto: true }, {
    includes: function includes(el /* , fromIndex = 0 */) {
      return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined);
    }
  });

  // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables
  addToUnscopables('includes');

  var HAS_SPECIES_SUPPORT$2 = arrayMethodHasSpeciesSupport('slice');

  var SPECIES = wellKnownSymbol('species');
  var nativeSlice = [].slice;
  var max$1 = Math.max;

  // `Array.prototype.slice` method
  // https://tc39.es/ecma262/#sec-array.prototype.slice
  // fallback for not array-like ES3 strings and DOM objects
  _export({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT$2 }, {
    slice: function slice(start, end) {
      var O = toIndexedObject(this);
      var length = toLength(O.length);
      var k = toAbsoluteIndex(start, length);
      var fin = toAbsoluteIndex(end === undefined ? length : end, length);
      // inline `ArraySpeciesCreate` for usage native `Array#slice` where it's possible
      var Constructor, result, n;
      if (isArray(O)) {
        Constructor = O.constructor;
        // cross-realm fallback
        if (typeof Constructor == 'function' && (Constructor === Array || isArray(Constructor.prototype))) {
          Constructor = undefined;
        } else if (isObject(Constructor)) {
          Constructor = Constructor[SPECIES];
          if (Constructor === null) Constructor = undefined;
        }
        if (Constructor === Array || Constructor === undefined) {
          return nativeSlice.call(O, k, fin);
        }
      }
      result = new (Constructor === undefined ? Array : Constructor)(max$1(fin - k, 0));
      for (n = 0; k < fin; k++, n++) if (k in O) createProperty(result, n, O[k]);
      result.length = n;
      return result;
    }
  });

  var notARegexp = function (it) {
    if (isRegexp(it)) {
      throw TypeError("The method doesn't accept regular expressions");
    } return it;
  };

  var MATCH = wellKnownSymbol('match');

  var correctIsRegexpLogic = function (METHOD_NAME) {
    var regexp = /./;
    try {
      '/./'[METHOD_NAME](regexp);
    } catch (error1) {
      try {
        regexp[MATCH] = false;
        return '/./'[METHOD_NAME](regexp);
      } catch (error2) { /* empty */ }
    } return false;
  };

  // `String.prototype.includes` method
  // https://tc39.es/ecma262/#sec-string.prototype.includes
  _export({ target: 'String', proto: true, forced: !correctIsRegexpLogic('includes') }, {
    includes: function includes(searchString /* , position = 0 */) {
      return !!~String(requireObjectCoercible(this))
        .indexOf(notARegexp(searchString), arguments.length > 1 ? arguments[1] : undefined);
    }
  });

  var arrayMethodIsStrict = function (METHOD_NAME, argument) {
    var method = [][METHOD_NAME];
    return !!method && fails(function () {
      // eslint-disable-next-line no-useless-call,no-throw-literal -- required for testing
      method.call(null, argument || function () { throw 1; }, 1);
    });
  };

  var nativeJoin = [].join;

  var ES3_STRINGS = indexedObject != Object;
  var STRICT_METHOD$1 = arrayMethodIsStrict('join', ',');

  // `Array.prototype.join` method
  // https://tc39.es/ecma262/#sec-array.prototype.join
  _export({ target: 'Array', proto: true, forced: ES3_STRINGS || !STRICT_METHOD$1 }, {
    join: function join(separator) {
      return nativeJoin.call(toIndexedObject(this), separator === undefined ? ',' : separator);
    }
  });

  // optional / simple context binding
  var functionBindContext = function (fn, that, length) {
    aFunction(fn);
    if (that === undefined) return fn;
    switch (length) {
      case 0: return function () {
        return fn.call(that);
      };
      case 1: return function (a) {
        return fn.call(that, a);
      };
      case 2: return function (a, b) {
        return fn.call(that, a, b);
      };
      case 3: return function (a, b, c) {
        return fn.call(that, a, b, c);
      };
    }
    return function (/* ...args */) {
      return fn.apply(that, arguments);
    };
  };

  var push = [].push;

  // `Array.prototype.{ forEach, map, filter, some, every, find, findIndex, filterOut }` methods implementation
  var createMethod = function (TYPE) {
    var IS_MAP = TYPE == 1;
    var IS_FILTER = TYPE == 2;
    var IS_SOME = TYPE == 3;
    var IS_EVERY = TYPE == 4;
    var IS_FIND_INDEX = TYPE == 6;
    var IS_FILTER_OUT = TYPE == 7;
    var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;
    return function ($this, callbackfn, that, specificCreate) {
      var O = toObject($this);
      var self = indexedObject(O);
      var boundFunction = functionBindContext(callbackfn, that, 3);
      var length = toLength(self.length);
      var index = 0;
      var create = specificCreate || arraySpeciesCreate;
      var target = IS_MAP ? create($this, length) : IS_FILTER || IS_FILTER_OUT ? create($this, 0) : undefined;
      var value, result;
      for (;length > index; index++) if (NO_HOLES || index in self) {
        value = self[index];
        result = boundFunction(value, index, O);
        if (TYPE) {
          if (IS_MAP) target[index] = result; // map
          else if (result) switch (TYPE) {
            case 3: return true;              // some
            case 5: return value;             // find
            case 6: return index;             // findIndex
            case 2: push.call(target, value); // filter
          } else switch (TYPE) {
            case 4: return false;             // every
            case 7: push.call(target, value); // filterOut
          }
        }
      }
      return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target;
    };
  };

  var arrayIteration = {
    // `Array.prototype.forEach` method
    // https://tc39.es/ecma262/#sec-array.prototype.foreach
    forEach: createMethod(0),
    // `Array.prototype.map` method
    // https://tc39.es/ecma262/#sec-array.prototype.map
    map: createMethod(1),
    // `Array.prototype.filter` method
    // https://tc39.es/ecma262/#sec-array.prototype.filter
    filter: createMethod(2),
    // `Array.prototype.some` method
    // https://tc39.es/ecma262/#sec-array.prototype.some
    some: createMethod(3),
    // `Array.prototype.every` method
    // https://tc39.es/ecma262/#sec-array.prototype.every
    every: createMethod(4),
    // `Array.prototype.find` method
    // https://tc39.es/ecma262/#sec-array.prototype.find
    find: createMethod(5),
    // `Array.prototype.findIndex` method
    // https://tc39.es/ecma262/#sec-array.prototype.findIndex
    findIndex: createMethod(6),
    // `Array.prototype.filterOut` method
    // https://github.com/tc39/proposal-array-filtering
    filterOut: createMethod(7)
  };

  var $filter = arrayIteration.filter;


  var HAS_SPECIES_SUPPORT$1 = arrayMethodHasSpeciesSupport('filter');

  // `Array.prototype.filter` method
  // https://tc39.es/ecma262/#sec-array.prototype.filter
  // with adding support of @@species
  _export({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT$1 }, {
    filter: function filter(callbackfn /* , thisArg */) {
      return $filter(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
    }
  });

  /**
   * Set tooltip left so it doesn't go off the right side of the window
   *
   * @return boolean true, if tooltipLayerStyleLeft is ok.  false, otherwise.
   */
  function checkRight(targetOffset, tooltipLayerStyleLeft, tooltipOffset, windowSize, tooltipLayer) {
    if (targetOffset.left + tooltipLayerStyleLeft + tooltipOffset.width > windowSize.width) {
      // off the right side of the window
      tooltipLayer.style.left = "".concat(windowSize.width - tooltipOffset.width - targetOffset.left, "px");
      return false;
    }

    tooltipLayer.style.left = "".concat(tooltipLayerStyleLeft, "px");
    return true;
  }

  /**
   * Set tooltip right so it doesn't go off the left side of the window
   *
   * @return boolean true, if tooltipLayerStyleRight is ok.  false, otherwise.
   */
  function checkLeft(targetOffset, tooltipLayerStyleRight, tooltipOffset, tooltipLayer) {
    if (targetOffset.left + targetOffset.width - tooltipLayerStyleRight - tooltipOffset.width < 0) {
      // off the left side of the window
      tooltipLayer.style.left = "".concat(-targetOffset.left, "px");
      return false;
    }

    tooltipLayer.style.right = "".concat(tooltipLayerStyleRight, "px");
    return true;
  }

  var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('splice');

  var max = Math.max;
  var min = Math.min;
  var MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF;
  var MAXIMUM_ALLOWED_LENGTH_EXCEEDED = 'Maximum allowed length exceeded';

  // `Array.prototype.splice` method
  // https://tc39.es/ecma262/#sec-array.prototype.splice
  // with adding support of @@species
  _export({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT }, {
    splice: function splice(start, deleteCount /* , ...items */) {
      var O = toObject(this);
      var len = toLength(O.length);
      var actualStart = toAbsoluteIndex(start, len);
      var argumentsLength = arguments.length;
      var insertCount, actualDeleteCount, A, k, from, to;
      if (argumentsLength === 0) {
        insertCount = actualDeleteCount = 0;
      } else if (argumentsLength === 1) {
        insertCount = 0;
        actualDeleteCount = len - actualStart;
      } else {
        insertCount = argumentsLength - 2;
        actualDeleteCount = min(max(toInteger(deleteCount), 0), len - actualStart);
      }
      if (len + insertCount - actualDeleteCount > MAX_SAFE_INTEGER) {
        throw TypeError(MAXIMUM_ALLOWED_LENGTH_EXCEEDED);
      }
      A = arraySpeciesCreate(O, actualDeleteCount);
      for (k = 0; k < actualDeleteCount; k++) {
        from = actualStart + k;
        if (from in O) createProperty(A, k, O[from]);
      }
      A.length = actualDeleteCount;
      if (insertCount < actualDeleteCount) {
        for (k = actualStart; k < len - actualDeleteCount; k++) {
          from = k + actualDeleteCount;
          to = k + insertCount;
          if (from in O) O[to] = O[from];
          else delete O[to];
        }
        for (k = len; k > len - actualDeleteCount + insertCount; k--) delete O[k - 1];
      } else if (insertCount > actualDeleteCount) {
        for (k = len - actualDeleteCount; k > actualStart; k--) {
          from = k + actualDeleteCount - 1;
          to = k + insertCount - 1;
          if (from in O) O[to] = O[from];
          else delete O[to];
        }
      }
      for (k = 0; k < insertCount; k++) {
        O[k + actualStart] = arguments[k + 2];
      }
      O.length = len - actualDeleteCount + insertCount;
      return A;
    }
  });

  /**
   * Remove an entry from a string array if it's there, does nothing if it isn't there.
   *
   * @param {Array} stringArray
   * @param {String} stringToRemove
   */
  function removeEntry(stringArray, stringToRemove) {
    if (stringArray.includes(stringToRemove)) {
      stringArray.splice(stringArray.indexOf(stringToRemove), 1);
    }
  }

  /**
   * auto-determine alignment
   * @param {Integer}  offsetLeft
   * @param {Integer}  tooltipWidth
   * @param {Object}   windowSize
   * @param {String}   desiredAlignment
   * @return {String}  calculatedAlignment
   */

  function _determineAutoAlignment(offsetLeft, tooltipWidth, _ref, desiredAlignment) {
    var width = _ref.width;
    var halfTooltipWidth = tooltipWidth / 2;
    var winWidth = Math.min(width, window.screen.width);
    var possibleAlignments = ["-left-aligned", "-middle-aligned", "-right-aligned"];
    var calculatedAlignment = ""; // valid left must be at least a tooltipWidth
    // away from right side

    if (winWidth - offsetLeft < tooltipWidth) {
      removeEntry(possibleAlignments, "-left-aligned");
    } // valid middle must be at least half
    // width away from both sides


    if (offsetLeft < halfTooltipWidth || winWidth - offsetLeft < halfTooltipWidth) {
      removeEntry(possibleAlignments, "-middle-aligned");
    } // valid right must be at least a tooltipWidth
    // width away from left side


    if (offsetLeft < tooltipWidth) {
      removeEntry(possibleAlignments, "-right-aligned");
    }

    if (possibleAlignments.length) {
      if (possibleAlignments.includes(desiredAlignment)) {
        // the desired alignment is valid
        calculatedAlignment = desiredAlignment;
      } else {
        // pick the first valid position, in order
        calculatedAlignment = possibleAlignments[0];
      }
    } else {
      // if screen width is too small
      // for ANY alignment, middle is
      // probably the best for visibility
      calculatedAlignment = "-middle-aligned";
    }

    return calculatedAlignment;
  }
  /**
   * Determines the position of the tooltip based on the position precedence and availability
   * of screen space.
   *
   * @param {Object}    targetElement
   * @param {Object}    tooltipLayer
   * @param {String}    desiredTooltipPosition
   * @return {String}   calculatedPosition
   */


  function _determineAutoPosition(targetElement, tooltipLayer, desiredTooltipPosition) {
    // Take a clone of position precedence. These will be the available
    var possiblePositions = this._options.positionPrecedence.slice();

    var windowSize = getWinSize();
    var tooltipHeight = getOffset(tooltipLayer).height + 10;
    var tooltipWidth = getOffset(tooltipLayer).width + 20;
    var targetElementRect = targetElement.getBoundingClientRect(); // If we check all the possible areas, and there are no valid places for the tooltip, the element
    // must take up most of the screen real estate. Show the tooltip floating in the middle of the screen.

    var calculatedPosition = "floating";
    /*
     * auto determine position
     */
    // Check for space below

    if (targetElementRect.bottom + tooltipHeight > windowSize.height) {
      removeEntry(possiblePositions, "bottom");
    } // Check for space above


    if (targetElementRect.top - tooltipHeight < 0) {
      removeEntry(possiblePositions, "top");
    } // Check for space to the right


    if (targetElementRect.right + tooltipWidth > windowSize.width) {
      removeEntry(possiblePositions, "right");
    } // Check for space to the left


    if (targetElementRect.left - tooltipWidth < 0) {
      removeEntry(possiblePositions, "left");
    } // @var {String}  ex: 'right-aligned'


    var desiredAlignment = function (pos) {
      var hyphenIndex = pos.indexOf("-");

      if (hyphenIndex !== -1) {
        // has alignment
        return pos.substr(hyphenIndex);
      }

      return "";
    }(desiredTooltipPosition || ""); // strip alignment from position


    if (desiredTooltipPosition) {
      // ex: "bottom-right-aligned"
      // should return 'bottom'
      desiredTooltipPosition = desiredTooltipPosition.split("-")[0];
    }

    if (possiblePositions.length) {
      if (possiblePositions.includes(desiredTooltipPosition)) {
        // If the requested position is in the list, choose that
        calculatedPosition = desiredTooltipPosition;
      } else {
        // Pick the first valid position, in order
        calculatedPosition = possiblePositions[0];
      }
    } // only top and bottom positions have optional alignments


    if (["top", "bottom"].includes(calculatedPosition)) {
      calculatedPosition += _determineAutoAlignment(targetElementRect.left, tooltipWidth, windowSize, desiredAlignment);
    }

    return calculatedPosition;
  }
  /**
   * Render tooltip box in the page
   *
   * @api private
   * @method placeTooltip
   * @param {HTMLElement} targetElement
   * @param {HTMLElement} tooltipLayer
   * @param {HTMLElement} arrowLayer
   * @param {Boolean} hintMode
   */


  function placeTooltip(targetElement, tooltipLayer, arrowLayer, hintMode) {
    var tooltipCssClass = "";
    var currentStepObj;
    var tooltipOffset;
    var targetOffset;
    var windowSize;
    var currentTooltipPosition;
    hintMode = hintMode || false; //reset the old style

    tooltipLayer.style.top = null;
    tooltipLayer.style.right = null;
    tooltipLayer.style.bottom = null;
    tooltipLayer.style.left = null;
    tooltipLayer.style.marginLeft = null;
    tooltipLayer.style.marginTop = null;
    arrowLayer.style.display = "inherit"; //prevent error when `this._currentStep` is undefined

    if (!this._introItems[this._currentStep]) return; //if we have a custom css class for each step

    currentStepObj = this._introItems[this._currentStep];

    if (typeof currentStepObj.tooltipClass === "string") {
      tooltipCssClass = currentStepObj.tooltipClass;
    } else {
      tooltipCssClass = this._options.tooltipClass;
    }

    tooltipLayer.className = ["introjs-tooltip", tooltipCssClass].filter(Boolean).join(" ");
    tooltipLayer.setAttribute("role", "dialog");
    currentTooltipPosition = this._introItems[this._currentStep].position; // Floating is always valid, no point in calculating

    if (currentTooltipPosition !== "floating" && this._options.autoPosition) {
      currentTooltipPosition = _determineAutoPosition.call(this, targetElement, tooltipLayer, currentTooltipPosition);
    }

    var tooltipLayerStyleLeft;
    targetOffset = getOffset(targetElement);
    tooltipOffset = getOffset(tooltipLayer);
    windowSize = getWinSize();
    addClass(tooltipLayer, "introjs-".concat(currentTooltipPosition));

    switch (currentTooltipPosition) {
      case "top-right-aligned":
        arrowLayer.className = "introjs-arrow bottom-right";
        var tooltipLayerStyleRight = 0;
        checkLeft(targetOffset, tooltipLayerStyleRight, tooltipOffset, tooltipLayer);
        tooltipLayer.style.bottom = "".concat(targetOffset.height + 20, "px");
        break;

      case "top-middle-aligned":
        arrowLayer.className = "introjs-arrow bottom-middle";
        var tooltipLayerStyleLeftRight = targetOffset.width / 2 - tooltipOffset.width / 2; // a fix for middle aligned hints

        if (hintMode) {
          tooltipLayerStyleLeftRight += 5;
        }

        if (checkLeft(targetOffset, tooltipLayerStyleLeftRight, tooltipOffset, tooltipLayer)) {
          tooltipLayer.style.right = null;
          checkRight(targetOffset, tooltipLayerStyleLeftRight, tooltipOffset, windowSize, tooltipLayer);
        }

        tooltipLayer.style.bottom = "".concat(targetOffset.height + 20, "px");
        break;

      case "top-left-aligned": // top-left-aligned is the same as the default top

      case "top":
        arrowLayer.className = "introjs-arrow bottom";
        tooltipLayerStyleLeft = hintMode ? 0 : 15;
        checkRight(targetOffset, tooltipLayerStyleLeft, tooltipOffset, windowSize, tooltipLayer);
        tooltipLayer.style.bottom = "".concat(targetOffset.height + 20, "px");
        break;

      case "right":
        tooltipLayer.style.left = "".concat(targetOffset.width + 20, "px");

        if (targetOffset.top + tooltipOffset.height > windowSize.height) {
          // In this case, right would have fallen below the bottom of the screen.
          // Modify so that the bottom of the tooltip connects with the target
          arrowLayer.className = "introjs-arrow left-bottom";
          tooltipLayer.style.top = "-".concat(tooltipOffset.height - targetOffset.height - 20, "px");
        } else {
          arrowLayer.className = "introjs-arrow left";
        }

        break;

      case "left":
        if (!hintMode && this._options.showStepNumbers === true) {
          tooltipLayer.style.top = "15px";
        }

        if (targetOffset.top + tooltipOffset.height > windowSize.height) {
          // In this case, left would have fallen below the bottom of the screen.
          // Modify so that the bottom of the tooltip connects with the target
          tooltipLayer.style.top = "-".concat(tooltipOffset.height - targetOffset.height - 20, "px");
          arrowLayer.className = "introjs-arrow right-bottom";
        } else {
          arrowLayer.className = "introjs-arrow right";
        }

        tooltipLayer.style.right = "".concat(targetOffset.width + 20, "px");
        break;

      case "floating":
        arrowLayer.style.display = "none"; //we have to adjust the top and left of layer manually for intro items without element

        tooltipLayer.style.left = "50%";
        tooltipLayer.style.top = "50%";
        tooltipLayer.style.marginLeft = "-".concat(tooltipOffset.width / 2, "px");
        tooltipLayer.style.marginTop = "-".concat(tooltipOffset.height / 2, "px");
        break;

      case "bottom-right-aligned":
        arrowLayer.className = "introjs-arrow top-right";
        tooltipLayerStyleRight = 0;
        checkLeft(targetOffset, tooltipLayerStyleRight, tooltipOffset, tooltipLayer);
        tooltipLayer.style.top = "".concat(targetOffset.height + 20, "px");
        break;

      case "bottom-middle-aligned":
        arrowLayer.className = "introjs-arrow top-middle";
        tooltipLayerStyleLeftRight = targetOffset.width / 2 - tooltipOffset.width / 2; // a fix for middle aligned hints

        if (hintMode) {
          tooltipLayerStyleLeftRight += 5;
        }

        if (checkLeft(targetOffset, tooltipLayerStyleLeftRight, tooltipOffset, tooltipLayer)) {
          tooltipLayer.style.right = null;
          checkRight(targetOffset, tooltipLayerStyleLeftRight, tooltipOffset, windowSize, tooltipLayer);
        }

        tooltipLayer.style.top = "".concat(targetOffset.height + 20, "px");
        break;
      // case 'bottom-left-aligned':
      // Bottom-left-aligned is the same as the default bottom
      // case 'bottom':
      // Bottom going to follow the default behavior

      default:
        arrowLayer.className = "introjs-arrow top";
        tooltipLayerStyleLeft = 0;
        checkRight(targetOffset, tooltipLayerStyleLeft, tooltipOffset, windowSize, tooltipLayer);
        tooltipLayer.style.top = "".concat(targetOffset.height + 20, "px");
    }
  }

  /**
   * To remove all show element(s)
   *
   * @api private
   * @method _removeShowElement
   */

  function removeShowElement() {
    var elms = document.querySelectorAll(".introjs-showElement");
    forEach(elms, function (elm) {
      removeClass(elm, /introjs-[a-zA-Z]+/g);
    });
  }

  function _createElement(tagname, attrs) {
    var element = document.createElement(tagname);
    attrs = attrs || {}; // regex for matching attributes that need to be set with setAttribute

    var setAttRegex = /^(?:role|data-|aria-)/;

    for (var k in attrs) {
      var v = attrs[k];

      if (k === "style") {
        setStyle(element, v);
      } else if (k.match(setAttRegex)) {
        element.setAttribute(k, v);
      } else {
        element[k] = v;
      }
    }

    return element;
  }

  /**
   * Appends `element` to `parentElement`
   *
   * @param {Element} parentElement
   * @param {Element} element
   * @param {Boolean} [animate=false]
   */

  function appendChild(parentElement, element, animate) {
    if (animate) {
      var existingOpacity = element.style.opacity || "1";
      setStyle(element, {
        opacity: "0"
      });
      window.setTimeout(function () {
        setStyle(element, {
          opacity: existingOpacity
        });
      }, 10);
    }

    parentElement.appendChild(element);
  }

  /**
   * Gets the current progress percentage
   *
   * @api private
   * @method _getProgress
   * @returns current progress percentage
   */

  function _getProgress() {
    // Steps are 0 indexed
    var currentStep = parseInt(this._currentStep + 1, 10);
    return currentStep / this._introItems.length * 100;
  }
  /**
   * Add disableinteraction layer and adjust the size and position of the layer
   *
   * @api private
   * @method _disableInteraction
   */


  function _disableInteraction() {
    var disableInteractionLayer = document.querySelector(".introjs-disableInteraction");

    if (disableInteractionLayer === null) {
      disableInteractionLayer = _createElement("div", {
        className: "introjs-disableInteraction"
      });

      this._targetElement.appendChild(disableInteractionLayer);
    }

    setHelperLayerPosition.call(this, disableInteractionLayer);
  }
  /**
   * Show an element on the page
   *
   * @api private
   * @method _showElement
   * @param {Object} targetElement
   */


  function _showElement(targetElement) {
    var _this = this;

    if (typeof this._introChangeCallback !== "undefined") {
      this._introChangeCallback.call(this, targetElement.element);
    }

    var self = this;
    var oldHelperLayer = document.querySelector(".introjs-helperLayer");
    var oldReferenceLayer = document.querySelector(".introjs-tooltipReferenceLayer");
    var highlightClass = "introjs-helperLayer";
    var nextTooltipButton;
    var prevTooltipButton;
    var skipTooltipButton;

    if (typeof targetElement.highlightClass === "string") {
      highlightClass += " ".concat(targetElement.highlightClass);
    } //check for options highlight class


    if (typeof this._options.highlightClass === "string") {
      highlightClass += " ".concat(this._options.highlightClass);
    }

    if (oldHelperLayer !== null) {
      var oldHelperNumberLayer = oldReferenceLayer.querySelector(".introjs-helperNumberLayer");
      var oldtooltipLayer = oldReferenceLayer.querySelector(".introjs-tooltiptext");
      var oldTooltipTitleLayer = oldReferenceLayer.querySelector(".introjs-tooltip-title");
      var oldArrowLayer = oldReferenceLayer.querySelector(".introjs-arrow");
      var oldtooltipContainer = oldReferenceLayer.querySelector(".introjs-tooltip");
      skipTooltipButton = oldReferenceLayer.querySelector(".introjs-skipbutton");
      prevTooltipButton = oldReferenceLayer.querySelector(".introjs-prevbutton");
      nextTooltipButton = oldReferenceLayer.querySelector(".introjs-nextbutton"); //update or reset the helper highlight class

      oldHelperLayer.className = highlightClass; //hide the tooltip

      oldtooltipContainer.style.opacity = 0;
      oldtooltipContainer.style.display = "none"; // if the target element is within a scrollable element

      scrollParentToElement.call(self, targetElement); // set new position to helper layer

      setHelperLayerPosition.call(self, oldHelperLayer);
      setHelperLayerPosition.call(self, oldReferenceLayer); //remove old classes if the element still exist

      removeShowElement(); //we should wait until the CSS3 transition is competed (it's 0.3 sec) to prevent incorrect `height` and `width` calculation

      if (self._lastShowElementTimer) {
        window.clearTimeout(self._lastShowElementTimer);
      }

      self._lastShowElementTimer = window.setTimeout(function () {
        // set current step to the label
        if (oldHelperNumberLayer !== null) {
          oldHelperNumberLayer.innerHTML = "".concat(targetElement.step, " of ").concat(_this._introItems.length);
        } // set current tooltip text


        oldtooltipLayer.innerHTML = targetElement.intro; // set current tooltip title

        oldTooltipTitleLayer.innerHTML = targetElement.title; //set the tooltip position

        oldtooltipContainer.style.display = "block";
        placeTooltip.call(self, targetElement.element, oldtooltipContainer, oldArrowLayer); //change active bullet

        if (self._options.showBullets) {
          oldReferenceLayer.querySelector(".introjs-bullets li > a.active").className = "";
          oldReferenceLayer.querySelector(".introjs-bullets li > a[data-stepnumber=\"".concat(targetElement.step, "\"]")).className = "active";
        }

        oldReferenceLayer.querySelector(".introjs-progress .introjs-progressbar").style.cssText = "width:".concat(_getProgress.call(self), "%;");
        oldReferenceLayer.querySelector(".introjs-progress .introjs-progressbar").setAttribute("aria-valuenow", _getProgress.call(self)); //show the tooltip

        oldtooltipContainer.style.opacity = 1; //reset button focus

        if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null && /introjs-donebutton/gi.test(nextTooltipButton.className)) {
          // skip button is now "done" button
          nextTooltipButton.focus();
        } else if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
          //still in the tour, focus on next
          nextTooltipButton.focus();
        } // change the scroll of the window, if needed


        scrollTo.call(self, targetElement.scrollTo, targetElement, oldtooltipLayer);
      }, 350); // end of old element if-else condition
    } else {
      var helperLayer = _createElement("div", {
        className: highlightClass
      });
      var referenceLayer = _createElement("div", {
        className: "introjs-tooltipReferenceLayer"
      });
      var arrowLayer = _createElement("div", {
        className: "introjs-arrow"
      });
      var tooltipLayer = _createElement("div", {
        className: "introjs-tooltip"
      });
      var tooltipTextLayer = _createElement("div", {
        className: "introjs-tooltiptext"
      });
      var tooltipHeaderLayer = _createElement("div", {
        className: "introjs-tooltip-header"
      });
      var tooltipTitleLayer = _createElement("h1", {
        className: "introjs-tooltip-title"
      });
      var bulletsLayer = _createElement("div", {
        className: "introjs-bullets"
      });
      var progressLayer = _createElement("div");
      var buttonsLayer = _createElement("div");
      setStyle(helperLayer, {
        "box-shadow": "0 0 1px 2px rgba(33, 33, 33, 0.8), rgba(33, 33, 33, ".concat(self._options.overlayOpacity.toString(), ") 0 0 0 5000px")
      }); // target is within a scrollable element

      scrollParentToElement.call(self, targetElement); //set new position to helper layer

      setHelperLayerPosition.call(self, helperLayer);
      setHelperLayerPosition.call(self, referenceLayer); //add helper layer to target element

      appendChild(this._targetElement, helperLayer, true);
      appendChild(this._targetElement, referenceLayer);
      tooltipTextLayer.innerHTML = targetElement.intro;
      tooltipTitleLayer.innerHTML = targetElement.title;

      if (this._options.showBullets === false) {
        bulletsLayer.style.display = "none";
      }

      var ulContainer = _createElement("ul");
      ulContainer.setAttribute("role", "tablist");

      var anchorClick = function anchorClick() {
        self.goToStep(this.getAttribute("data-stepnumber"));
      };

      forEach(this._introItems, function (_ref, i) {
        var step = _ref.step;
        var innerLi = _createElement("li");
        var anchorLink = _createElement("a");
        innerLi.setAttribute("role", "presentation");
        anchorLink.setAttribute("role", "tab");
        anchorLink.onclick = anchorClick;

        if (i === targetElement.step - 1) {
          anchorLink.className = "active";
        }

        setAnchorAsButton(anchorLink);
        anchorLink.innerHTML = "&nbsp;";
        anchorLink.setAttribute("data-stepnumber", step);
        innerLi.appendChild(anchorLink);
        ulContainer.appendChild(innerLi);
      });
      bulletsLayer.appendChild(ulContainer);
      progressLayer.className = "introjs-progress";

      if (this._options.showProgress === false) {
        progressLayer.style.display = "none";
      }

      var progressBar = _createElement("div", {
        className: "introjs-progressbar"
      });

      if (this._options.progressBarAdditionalClass) {
        progressBar.className += " " + this._options.progressBarAdditionalClass;
      }

      progressBar.setAttribute("role", "progress");
      progressBar.setAttribute("aria-valuemin", 0);
      progressBar.setAttribute("aria-valuemax", 100);
      progressBar.setAttribute("aria-valuenow", _getProgress.call(this));
      progressBar.style.cssText = "width:".concat(_getProgress.call(this), "%;");
      progressLayer.appendChild(progressBar);
      buttonsLayer.className = "introjs-tooltipbuttons";

      if (this._options.showButtons === false) {
        buttonsLayer.style.display = "none";
      }

      tooltipHeaderLayer.appendChild(tooltipTitleLayer);
      tooltipLayer.appendChild(tooltipHeaderLayer);
      tooltipLayer.appendChild(tooltipTextLayer);
      tooltipLayer.appendChild(bulletsLayer);
      tooltipLayer.appendChild(progressLayer); // add helper layer number

      var helperNumberLayer = _createElement("div");

      if (this._options.showStepNumbers === true) {
        helperNumberLayer.className = "introjs-helperNumberLayer";
        helperNumberLayer.innerHTML = "".concat(targetElement.step, " of ").concat(this._introItems.length);
        tooltipLayer.appendChild(helperNumberLayer);
      }

      tooltipLayer.appendChild(arrowLayer);
      referenceLayer.appendChild(tooltipLayer); //next button

      nextTooltipButton = _createElement("a");

      nextTooltipButton.onclick = function () {
        if (self._introItems.length - 1 !== self._currentStep) {
          nextStep.call(self);
        } else if (/introjs-donebutton/gi.test(nextTooltipButton.className)) {
          if (typeof self._introCompleteCallback === "function") {
            self._introCompleteCallback.call(self);
          }

          exitIntro.call(self, self._targetElement);
        }
      };

      setAnchorAsButton(nextTooltipButton);
      nextTooltipButton.innerHTML = this._options.nextLabel; //previous button

      prevTooltipButton = _createElement("a");

      prevTooltipButton.onclick = function () {
        if (self._currentStep !== 0) {
          previousStep.call(self);
        }
      };

      setAnchorAsButton(prevTooltipButton);
      prevTooltipButton.innerHTML = this._options.prevLabel; //skip button

      skipTooltipButton = _createElement("a", {
        className: "introjs-skipbutton"
      });
      setAnchorAsButton(skipTooltipButton);
      skipTooltipButton.innerHTML = this._options.skipLabel;

      skipTooltipButton.onclick = function () {
        if (self._introItems.length - 1 === self._currentStep && typeof self._introCompleteCallback === "function") {
          self._introCompleteCallback.call(self);
        }

        if (typeof self._introSkipCallback === "function") {
          self._introSkipCallback.call(self);
        }

        exitIntro.call(self, self._targetElement);
      };

      tooltipHeaderLayer.appendChild(skipTooltipButton); //in order to prevent displaying previous button always

      if (this._introItems.length > 1) {
        buttonsLayer.appendChild(prevTooltipButton);
      } // we always need the next button because this
      // button changes to "Done" in the last step of the tour


      buttonsLayer.appendChild(nextTooltipButton);
      tooltipLayer.appendChild(buttonsLayer); //set proper position

      placeTooltip.call(self, targetElement.element, tooltipLayer, arrowLayer); // change the scroll of the window, if needed

      scrollTo.call(this, targetElement.scrollTo, targetElement, tooltipLayer); //end of new element if-else condition
    } // removing previous disable interaction layer


    var disableInteractionLayer = self._targetElement.querySelector(".introjs-disableInteraction");

    if (disableInteractionLayer) {
      disableInteractionLayer.parentNode.removeChild(disableInteractionLayer);
    } //disable interaction


    if (targetElement.disableInteraction) {
      _disableInteraction.call(self);
    } // when it's the first step of tour


    if (this._currentStep === 0 && this._introItems.length > 1) {
      if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
        nextTooltipButton.className = "".concat(this._options.buttonClass, " introjs-nextbutton");
        nextTooltipButton.innerHTML = this._options.nextLabel;
      }

      if (this._options.hidePrev === true) {
        if (typeof prevTooltipButton !== "undefined" && prevTooltipButton !== null) {
          prevTooltipButton.className = "".concat(this._options.buttonClass, " introjs-prevbutton introjs-hidden");
        }

        if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
          addClass(nextTooltipButton, "introjs-fullbutton");
        }
      } else {
        if (typeof prevTooltipButton !== "undefined" && prevTooltipButton !== null) {
          prevTooltipButton.className = "".concat(this._options.buttonClass, " introjs-prevbutton introjs-disabled");
        }
      }
    } else if (this._introItems.length - 1 === this._currentStep || this._introItems.length === 1) {
      // last step of tour
      if (typeof prevTooltipButton !== "undefined" && prevTooltipButton !== null) {
        prevTooltipButton.className = "".concat(this._options.buttonClass, " introjs-prevbutton");
      }

      if (this._options.hideNext === true) {
        if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
          nextTooltipButton.className = "".concat(this._options.buttonClass, " introjs-nextbutton introjs-hidden");
        }

        if (typeof prevTooltipButton !== "undefined" && prevTooltipButton !== null) {
          addClass(prevTooltipButton, "introjs-fullbutton");
        }
      } else {
        if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
          if (this._options.nextToDone === true) {
            nextTooltipButton.innerHTML = this._options.doneLabel;
            addClass(nextTooltipButton, "".concat(this._options.buttonClass, " introjs-nextbutton introjs-donebutton"));
          } else {
            nextTooltipButton.className = "".concat(this._options.buttonClass, " introjs-nextbutton introjs-disabled");
          }
        }
      }
    } else {
      // steps between start and end
      if (typeof prevTooltipButton !== "undefined" && prevTooltipButton !== null) {
        prevTooltipButton.className = "".concat(this._options.buttonClass, " introjs-prevbutton");
      }

      if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
        nextTooltipButton.className = "".concat(this._options.buttonClass, " introjs-nextbutton");
        nextTooltipButton.innerHTML = this._options.nextLabel;
      }
    }

    if (typeof prevTooltipButton !== "undefined" && prevTooltipButton !== null) {
      prevTooltipButton.setAttribute("role", "button");
    }

    if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
      nextTooltipButton.setAttribute("role", "button");
    }

    if (typeof skipTooltipButton !== "undefined" && skipTooltipButton !== null) {
      skipTooltipButton.setAttribute("role", "button");
    } //Set focus on "next" button, so that hitting Enter always moves you onto the next step


    if (typeof nextTooltipButton !== "undefined" && nextTooltipButton !== null) {
      nextTooltipButton.focus();
    }

    setShowElement(targetElement);

    if (typeof this._introAfterChangeCallback !== "undefined") {
      this._introAfterChangeCallback.call(this, targetElement.element);
    }
  }

  /**
   * Go to specific step of introduction
   *
   * @api private
   * @method _goToStep
   */

  function goToStep(step) {
    //because steps starts with zero
    this._currentStep = step - 2;

    if (typeof this._introItems !== "undefined") {
      nextStep.call(this);
    }
  }
  /**
   * Go to the specific step of introduction with the explicit [data-step] number
   *
   * @api private
   * @method _goToStepNumber
   */

  function goToStepNumber(step) {
    this._currentStepNumber = step;

    if (typeof this._introItems !== "undefined") {
      nextStep.call(this);
    }
  }
  /**
   * Go to next step on intro
   *
   * @api private
   * @method _nextStep
   */

  function nextStep() {
    var _this = this;

    this._direction = "forward";

    if (typeof this._currentStepNumber !== "undefined") {
      forEach(this._introItems, function (_ref, i) {
        var step = _ref.step;

        if (step === _this._currentStepNumber) {
          _this._currentStep = i - 1;
          _this._currentStepNumber = undefined;
        }
      });
    }

    if (typeof this._currentStep === "undefined") {
      this._currentStep = 0;
    } else {
      ++this._currentStep;
    }

    var nextStep = this._introItems[this._currentStep];
    var continueStep = true;

    if (typeof this._introBeforeChangeCallback !== "undefined") {
      continueStep = this._introBeforeChangeCallback.call(this, nextStep && nextStep.element);
    } // if `onbeforechange` returned `false`, stop displaying the element


    if (continueStep === false) {
      --this._currentStep;
      return false;
    }

    if (this._introItems.length <= this._currentStep) {
      //end of the intro
      //check if any callback is defined
      if (typeof this._introCompleteCallback === "function") {
        this._introCompleteCallback.call(this);
      }

      exitIntro.call(this, this._targetElement);
      return;
    }

    _showElement.call(this, nextStep);
  }
  /**
   * Go to previous step on intro
   *
   * @api private
   * @method _previousStep
   */

  function previousStep() {
    this._direction = "backward";

    if (this._currentStep === 0) {
      return false;
    }

    --this._currentStep;
    var nextStep = this._introItems[this._currentStep];
    var continueStep = true;

    if (typeof this._introBeforeChangeCallback !== "undefined") {
      continueStep = this._introBeforeChangeCallback.call(this, nextStep && nextStep.element);
    } // if `onbeforechange` returned `false`, stop displaying the element


    if (continueStep === false) {
      ++this._currentStep;
      return false;
    }

    _showElement.call(this, nextStep);
  }
  /**
   * Returns the current step of the intro
   *
   * @returns {number | boolean}
   */

  function currentStep() {
    return this._currentStep;
  }

  /**
   * on keyCode:
   * https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/keyCode
   * This feature has been removed from the Web standards.
   * Though some browsers may still support it, it is in
   * the process of being dropped.
   * Instead, you should use KeyboardEvent.code,
   * if it's implemented.
   *
   * jQuery's approach is to test for
   *   (1) e.which, then
   *   (2) e.charCode, then
   *   (3) e.keyCode
   * https://github.com/jquery/jquery/blob/a6b0705294d336ae2f63f7276de0da1195495363/src/event.js#L638
   *
   * @param type var
   * @return type
   */

  function onKeyDown(e) {
    var code = e.code === undefined ? e.which : e.code; // if e.which is null

    if (code === null) {
      code = e.charCode === null ? e.keyCode : e.charCode;
    }

    if ((code === "Escape" || code === 27) && this._options.exitOnEsc === true) {
      //escape key pressed, exit the intro
      //check if exit callback is defined
      exitIntro.call(this, this._targetElement);
    } else if (code === "ArrowLeft" || code === 37) {
      //left arrow
      previousStep.call(this);
    } else if (code === "ArrowRight" || code === 39) {
      //right arrow
      nextStep.call(this);
    } else if (code === "Enter" || code === "NumpadEnter" || code === 13) {
      //srcElement === ie
      var target = e.target || e.srcElement;

      if (target && target.className.match("introjs-prevbutton")) {
        //user hit enter while focusing on previous button
        previousStep.call(this);
      } else if (target && target.className.match("introjs-skipbutton")) {
        //user hit enter while focusing on skip button
        if (this._introItems.length - 1 === this._currentStep && typeof this._introCompleteCallback === "function") {
          this._introCompleteCallback.call(this);
        }

        exitIntro.call(this, this._targetElement);
      } else if (target && target.getAttribute("data-stepnumber")) {
        // user hit enter while focusing on step bullet
        target.click();
      } else {
        //default behavior for responding to enter
        nextStep.call(this);
      } //prevent default behaviour on hitting Enter, to prevent steps being skipped in some browsers


      if (e.preventDefault) {
        e.preventDefault();
      } else {
        e.returnValue = false;
      }
    }
  }

  /*
   * makes a copy of the object
   * @api private
   * @method _cloneObject
   */
  function cloneObject(object) {
    if (object === null || _typeof(object) !== "object" || typeof object.nodeType !== "undefined") {
      return object;
    }

    var temp = {};

    for (var key in object) {
      if (typeof window.jQuery !== "undefined" && object[key] instanceof window.jQuery) {
        temp[key] = object[key];
      } else {
        temp[key] = cloneObject(object[key]);
      }
    }

    return temp;
  }

  /**
   * Get a queryselector within the hint wrapper
   *
   * @param {String} selector
   * @return {NodeList|Array}
   */

  function hintQuerySelectorAll(selector) {
    var hintsWrapper = document.querySelector(".introjs-hints");
    return hintsWrapper ? hintsWrapper.querySelectorAll(selector) : [];
  }
  /**
   * Hide a hint
   *
   * @api private
   * @method hideHint
   */

  function hideHint(stepId) {
    var hint = hintQuerySelectorAll(".introjs-hint[data-step=\"".concat(stepId, "\"]"))[0];
    removeHintTooltip.call(this);

    if (hint) {
      addClass(hint, "introjs-hidehint");
    } // call the callback function (if any)


    if (typeof this._hintCloseCallback !== "undefined") {
      this._hintCloseCallback.call(this, stepId);
    }
  }
  /**
   * Hide all hints
   *
   * @api private
   * @method hideHints
   */

  function hideHints() {
    var _this = this;

    var hints = hintQuerySelectorAll(".introjs-hint");
    forEach(hints, function (hint) {
      hideHint.call(_this, hint.getAttribute("data-step"));
    });
  }
  /**
   * Show all hints
   *
   * @api private
   * @method _showHints
   */

  function showHints() {
    var _this2 = this;

    var hints = hintQuerySelectorAll(".introjs-hint");

    if (hints && hints.length) {
      forEach(hints, function (hint) {
        showHint.call(_this2, hint.getAttribute("data-step"));
      });
    } else {
      populateHints.call(this, this._targetElement);
    }
  }
  /**
   * Show a hint
   *
   * @api private
   * @method showHint
   */

  function showHint(stepId) {
    var hint = hintQuerySelectorAll(".introjs-hint[data-step=\"".concat(stepId, "\"]"))[0];

    if (hint) {
      removeClass(hint, /introjs-hidehint/g);
    }
  }
  /**
   * Removes all hint elements on the page
   * Useful when you want to destroy the elements and add them again (e.g. a modal or popup)
   *
   * @api private
   * @method removeHints
   */

  function removeHints() {
    var _this3 = this;

    var hints = hintQuerySelectorAll(".introjs-hint");
    forEach(hints, function (hint) {
      removeHint.call(_this3, hint.getAttribute("data-step"));
    });
  }
  /**
   * Remove one single hint element from the page
   * Useful when you want to destroy the element and add them again (e.g. a modal or popup)
   * Use removeHints if you want to remove all elements.
   *
   * @api private
   * @method removeHint
   */

  function removeHint(stepId) {
    var hint = hintQuerySelectorAll(".introjs-hint[data-step=\"".concat(stepId, "\"]"))[0];

    if (hint) {
      hint.parentNode.removeChild(hint);
    }
  }
  /**
   * Add all available hints to the page
   *
   * @api private
   * @method addHints
   */

  function addHints() {
    var _this4 = this;

    var self = this;
    var hintsWrapper = document.querySelector(".introjs-hints");

    if (hintsWrapper === null) {
      hintsWrapper = _createElement("div", {
        className: "introjs-hints"
      });
    }
    /**
     * Returns an event handler unique to the hint iteration
     *
     * @param {Integer} i
     * @return {Function}
     */


    var getHintClick = function getHintClick(i) {
      return function (e) {
        var evt = e ? e : window.event;

        if (evt.stopPropagation) {
          evt.stopPropagation();
        }

        if (evt.cancelBubble !== null) {
          evt.cancelBubble = true;
        }

        showHintDialog.call(self, i);
      };
    };

    forEach(this._introItems, function (item, i) {
      // avoid append a hint twice
      if (document.querySelector(".introjs-hint[data-step=\"".concat(i, "\"]"))) {
        return;
      }

      var hint = _createElement("a", {
        className: "introjs-hint"
      });
      setAnchorAsButton(hint);
      hint.onclick = getHintClick(i);

      if (!item.hintAnimation) {
        addClass(hint, "introjs-hint-no-anim");
      } // hint's position should be fixed if the target element's position is fixed


      if (isFixed(item.element)) {
        addClass(hint, "introjs-fixedhint");
      }

      var hintDot = _createElement("div", {
        className: "introjs-hint-dot"
      });
      var hintPulse = _createElement("div", {
        className: "introjs-hint-pulse"
      });
      hint.appendChild(hintDot);
      hint.appendChild(hintPulse);
      hint.setAttribute("data-step", i); // we swap the hint element with target element
      // because _setHelperLayerPosition uses `element` property

      item.targetElement = item.element;
      item.element = hint; // align the hint position

      alignHintPosition.call(_this4, item.hintPosition, hint, item.targetElement);
      hintsWrapper.appendChild(hint);
    }); // adding the hints wrapper

    document.body.appendChild(hintsWrapper); // call the callback function (if any)

    if (typeof this._hintsAddedCallback !== "undefined") {
      this._hintsAddedCallback.call(this);
    }
  }
  /**
   * Aligns hint position
   *
   * @api private
   * @method alignHintPosition
   * @param {String} position
   * @param {Object} hint
   * @param {Object} element
   */

  function alignHintPosition(position, _ref, element) {
    var style = _ref.style;
    // get/calculate offset of target element
    var offset = getOffset.call(this, element);
    var iconWidth = 20;
    var iconHeight = 20; // align the hint element

    switch (position) {
      default:
      case "top-left":
        style.left = "".concat(offset.left, "px");
        style.top = "".concat(offset.top, "px");
        break;

      case "top-right":
        style.left = "".concat(offset.left + offset.width - iconWidth, "px");
        style.top = "".concat(offset.top, "px");
        break;

      case "bottom-left":
        style.left = "".concat(offset.left, "px");
        style.top = "".concat(offset.top + offset.height - iconHeight, "px");
        break;

      case "bottom-right":
        style.left = "".concat(offset.left + offset.width - iconWidth, "px");
        style.top = "".concat(offset.top + offset.height - iconHeight, "px");
        break;

      case "middle-left":
        style.left = "".concat(offset.left, "px");
        style.top = "".concat(offset.top + (offset.height - iconHeight) / 2, "px");
        break;

      case "middle-right":
        style.left = "".concat(offset.left + offset.width - iconWidth, "px");
        style.top = "".concat(offset.top + (offset.height - iconHeight) / 2, "px");
        break;

      case "middle-middle":
        style.left = "".concat(offset.left + (offset.width - iconWidth) / 2, "px");
        style.top = "".concat(offset.top + (offset.height - iconHeight) / 2, "px");
        break;

      case "bottom-middle":
        style.left = "".concat(offset.left + (offset.width - iconWidth) / 2, "px");
        style.top = "".concat(offset.top + offset.height - iconHeight, "px");
        break;

      case "top-middle":
        style.left = "".concat(offset.left + (offset.width - iconWidth) / 2, "px");
        style.top = "".concat(offset.top, "px");
        break;
    }
  }
  /**
   * Triggers when user clicks on the hint element
   *
   * @api private
   * @method _showHintDialog
   * @param {Number} stepId
   */

  function showHintDialog(stepId) {
    var hintElement = document.querySelector(".introjs-hint[data-step=\"".concat(stepId, "\"]"));
    var item = this._introItems[stepId]; // call the callback function (if any)

    if (typeof this._hintClickCallback !== "undefined") {
      this._hintClickCallback.call(this, hintElement, item, stepId);
    } // remove all open tooltips


    var removedStep = removeHintTooltip.call(this); // to toggle the tooltip

    if (parseInt(removedStep, 10) === stepId) {
      return;
    }

    var tooltipLayer = _createElement("div", {
      className: "introjs-tooltip"
    });
    var tooltipTextLayer = _createElement("div");
    var arrowLayer = _createElement("div");
    var referenceLayer = _createElement("div");

    tooltipLayer.onclick = function (e) {
      //IE9 & Other Browsers
      if (e.stopPropagation) {
        e.stopPropagation();
      } //IE8 and Lower
      else {
          e.cancelBubble = true;
        }
    };

    tooltipTextLayer.className = "introjs-tooltiptext";
    var tooltipWrapper = _createElement("p");
    tooltipWrapper.innerHTML = item.hint;
    var closeButton = _createElement("a");
    closeButton.className = this._options.buttonClass;
    closeButton.setAttribute("role", "button");
    closeButton.innerHTML = this._options.hintButtonLabel;
    closeButton.onclick = hideHint.bind(this, stepId);
    tooltipTextLayer.appendChild(tooltipWrapper);
    tooltipTextLayer.appendChild(closeButton);
    arrowLayer.className = "introjs-arrow";
    tooltipLayer.appendChild(arrowLayer);
    tooltipLayer.appendChild(tooltipTextLayer); // set current step for _placeTooltip function

    this._currentStep = hintElement.getAttribute("data-step"); // align reference layer position

    referenceLayer.className = "introjs-tooltipReferenceLayer introjs-hintReference";
    referenceLayer.setAttribute("data-step", hintElement.getAttribute("data-step"));
    setHelperLayerPosition.call(this, referenceLayer);
    referenceLayer.appendChild(tooltipLayer);
    document.body.appendChild(referenceLayer); //set proper position

    placeTooltip.call(this, hintElement, tooltipLayer, arrowLayer, true);
  }
  /**
   * Removes open hint (tooltip hint)
   *
   * @api private
   * @method _removeHintTooltip
   */

  function removeHintTooltip() {
    var tooltip = document.querySelector(".introjs-hintReference");

    if (tooltip) {
      var step = tooltip.getAttribute("data-step");
      tooltip.parentNode.removeChild(tooltip);
      return step;
    }
  }
  /**
   * Start parsing hint items
   *
   * @api private
   * @param {Object} targetElm
   * @method _startHint
   */

  function populateHints(targetElm) {
    var _this5 = this;

    this._introItems = [];

    if (this._options.hints) {
      forEach(this._options.hints, function (hint) {
        var currentItem = cloneObject(hint);

        if (typeof currentItem.element === "string") {
          //grab the element with given selector from the page
          currentItem.element = document.querySelector(currentItem.element);
        }

        currentItem.hintPosition = currentItem.hintPosition || _this5._options.hintPosition;
        currentItem.hintAnimation = currentItem.hintAnimation || _this5._options.hintAnimation;

        if (currentItem.element !== null) {
          _this5._introItems.push(currentItem);
        }
      });
    } else {
      var hints = targetElm.querySelectorAll("*[data-hint]");

      if (!hints || !hints.length) {
        return false;
      } //first add intro items with data-step


      forEach(hints, function (currentElement) {
        // hint animation
        var hintAnimation = currentElement.getAttribute("data-hintanimation");

        if (hintAnimation) {
          hintAnimation = hintAnimation === "true";
        } else {
          hintAnimation = _this5._options.hintAnimation;
        }

        _this5._introItems.push({
          element: currentElement,
          hint: currentElement.getAttribute("data-hint"),
          hintPosition: currentElement.getAttribute("data-hintposition") || _this5._options.hintPosition,
          hintAnimation: hintAnimation,
          tooltipClass: currentElement.getAttribute("data-tooltipclass"),
          position: currentElement.getAttribute("data-position") || _this5._options.tooltipPosition
        });
      });
    }

    addHints.call(this);
    /*
    todo:
    these events should be removed at some point
    */

    DOMEvent.on(document, "click", removeHintTooltip, this, false);
    DOMEvent.on(window, "resize", reAlignHints, this, true);
  }
  /**
   * Re-aligns all hint elements
   *
   * @api private
   * @method _reAlignHints
   */

  function reAlignHints() {
    var _this6 = this;

    forEach(this._introItems, function (_ref2) {
      var targetElement = _ref2.targetElement,
          hintPosition = _ref2.hintPosition,
          element = _ref2.element;

      if (typeof targetElement === "undefined") {
        return;
      }

      alignHintPosition.call(_this6, hintPosition, element, targetElement);
    });
  }

  // TODO: use something more complex like timsort?
  var floor = Math.floor;

  var mergeSort = function (array, comparefn) {
    var length = array.length;
    var middle = floor(length / 2);
    return length < 8 ? insertionSort(array, comparefn) : merge(
      mergeSort(array.slice(0, middle), comparefn),
      mergeSort(array.slice(middle), comparefn),
      comparefn
    );
  };

  var insertionSort = function (array, comparefn) {
    var length = array.length;
    var i = 1;
    var element, j;

    while (i < length) {
      j = i;
      element = array[i];
      while (j && comparefn(array[j - 1], element) > 0) {
        array[j] = array[--j];
      }
      if (j !== i++) array[j] = element;
    } return array;
  };

  var merge = function (left, right, comparefn) {
    var llength = left.length;
    var rlength = right.length;
    var lindex = 0;
    var rindex = 0;
    var result = [];

    while (lindex < llength || rindex < rlength) {
      if (lindex < llength && rindex < rlength) {
        result.push(comparefn(left[lindex], right[rindex]) <= 0 ? left[lindex++] : right[rindex++]);
      } else {
        result.push(lindex < llength ? left[lindex++] : right[rindex++]);
      }
    } return result;
  };

  var arraySort = mergeSort;

  var firefox = engineUserAgent.match(/firefox\/(\d+)/i);

  var engineFfVersion = !!firefox && +firefox[1];

  var engineIsIeOrEdge = /MSIE|Trident/.test(engineUserAgent);

  var webkit = engineUserAgent.match(/AppleWebKit\/(\d+)\./);

  var engineWebkitVersion = !!webkit && +webkit[1];

  var test = [];
  var nativeSort = test.sort;

  // IE8-
  var FAILS_ON_UNDEFINED = fails(function () {
    test.sort(undefined);
  });
  // V8 bug
  var FAILS_ON_NULL = fails(function () {
    test.sort(null);
  });
  // Old WebKit
  var STRICT_METHOD = arrayMethodIsStrict('sort');

  var STABLE_SORT = !fails(function () {
    // feature detection can be too slow, so check engines versions
    if (engineV8Version) return engineV8Version < 70;
    if (engineFfVersion && engineFfVersion > 3) return;
    if (engineIsIeOrEdge) return true;
    if (engineWebkitVersion) return engineWebkitVersion < 603;

    var result = '';
    var code, chr, value, index;

    // generate an array with more 512 elements (Chakra and old V8 fails only in this case)
    for (code = 65; code < 76; code++) {
      chr = String.fromCharCode(code);

      switch (code) {
        case 66: case 69: case 70: case 72: value = 3; break;
        case 68: case 71: value = 4; break;
        default: value = 2;
      }

      for (index = 0; index < 47; index++) {
        test.push({ k: chr + index, v: value });
      }
    }

    test.sort(function (a, b) { return b.v - a.v; });

    for (index = 0; index < test.length; index++) {
      chr = test[index].k.charAt(0);
      if (result.charAt(result.length - 1) !== chr) result += chr;
    }

    return result !== 'DGBEFHACIJK';
  });

  var FORCED = FAILS_ON_UNDEFINED || !FAILS_ON_NULL || !STRICT_METHOD || !STABLE_SORT;

  var getSortCompare = function (comparefn) {
    return function (x, y) {
      if (y === undefined) return -1;
      if (x === undefined) return 1;
      if (comparefn !== undefined) return +comparefn(x, y) || 0;
      return String(x) > String(y) ? 1 : -1;
    };
  };

  // `Array.prototype.sort` method
  // https://tc39.es/ecma262/#sec-array.prototype.sort
  _export({ target: 'Array', proto: true, forced: FORCED }, {
    sort: function sort(comparefn) {
      if (comparefn !== undefined) aFunction(comparefn);

      var array = toObject(this);

      if (STABLE_SORT) return comparefn === undefined ? nativeSort.call(array) : nativeSort.call(array, comparefn);

      var items = [];
      var arrayLength = toLength(array.length);
      var itemsLength, index;

      for (index = 0; index < arrayLength; index++) {
        if (index in array) items.push(array[index]);
      }

      items = arraySort(items, getSortCompare(comparefn));
      itemsLength = items.length;
      index = 0;

      while (index < itemsLength) array[index] = items[index++];
      while (index < arrayLength) delete array[index++];

      return array;
    }
  });

  /**
   * Finds all Intro steps from the data-* attributes and the options.steps array
   *
   * @api private
   * @param targetElm
   * @returns {[]}
   */

  function fetchIntroSteps(targetElm) {
    var _this = this;

    var allIntroSteps = targetElm.querySelectorAll("*[data-intro]");
    var introItems = [];

    if (this._options.steps) {
      //use steps passed programmatically
      forEach(this._options.steps, function (step) {
        var currentItem = cloneObject(step); //set the step

        currentItem.step = introItems.length + 1;
        currentItem.title = currentItem.title || ""; //use querySelector function only when developer used CSS selector

        if (typeof currentItem.element === "string") {
          //grab the element with given selector from the page
          currentItem.element = document.querySelector(currentItem.element);
        } //intro without element


        if (typeof currentItem.element === "undefined" || currentItem.element === null) {
          var floatingElementQuery = document.querySelector(".introjsFloatingElement");

          if (floatingElementQuery === null) {
            floatingElementQuery = _createElement("div", {
              className: "introjsFloatingElement"
            });
            document.body.appendChild(floatingElementQuery);
          }

          currentItem.element = floatingElementQuery;
          currentItem.position = "floating";
        }

        currentItem.position = currentItem.position || _this._options.tooltipPosition;
        currentItem.scrollTo = currentItem.scrollTo || _this._options.scrollTo;

        if (typeof currentItem.disableInteraction === "undefined") {
          currentItem.disableInteraction = _this._options.disableInteraction;
        }

        if (currentItem.element !== null) {
          introItems.push(currentItem);
        }
      });
    } else {
      //use steps from data-* annotations
      var elmsLength = allIntroSteps.length;
      var disableInteraction; //if there's no element to intro

      if (elmsLength < 1) {
        return [];
      }

      forEach(allIntroSteps, function (currentElement) {
        // start intro for groups of elements
        if (_this._options.group && currentElement.getAttribute("data-intro-group") !== _this._options.group) {
          return;
        } // skip hidden elements


        if (currentElement.style.display === "none") {
          return;
        }

        var step = parseInt(currentElement.getAttribute("data-step"), 10);

        if (currentElement.hasAttribute("data-disable-interaction")) {
          disableInteraction = !!currentElement.getAttribute("data-disable-interaction");
        } else {
          disableInteraction = _this._options.disableInteraction;
        }

        if (step > 0) {
          introItems[step - 1] = {
            element: currentElement,
            title: currentElement.getAttribute("data-title") || "",
            intro: currentElement.getAttribute("data-intro"),
            step: parseInt(currentElement.getAttribute("data-step"), 10),
            tooltipClass: currentElement.getAttribute("data-tooltipclass"),
            highlightClass: currentElement.getAttribute("data-highlightclass"),
            position: currentElement.getAttribute("data-position") || _this._options.tooltipPosition,
            scrollTo: currentElement.getAttribute("data-scrollto") || _this._options.scrollTo,
            disableInteraction: disableInteraction
          };
        }
      }); //next add intro items without data-step
      //todo: we need a cleanup here, two loops are redundant

      var nextStep = 0;
      forEach(allIntroSteps, function (currentElement) {
        // start intro for groups of elements
        if (_this._options.group && currentElement.getAttribute("data-intro-group") !== _this._options.group) {
          return;
        }

        if (currentElement.getAttribute("data-step") === null) {
          while (true) {
            if (typeof introItems[nextStep] === "undefined") {
              break;
            } else {
              nextStep++;
            }
          }

          if (currentElement.hasAttribute("data-disable-interaction")) {
            disableInteraction = !!currentElement.getAttribute("data-disable-interaction");
          } else {
            disableInteraction = _this._options.disableInteraction;
          }

          introItems[nextStep] = {
            element: currentElement,
            title: currentElement.getAttribute("data-title") || "",
            intro: currentElement.getAttribute("data-intro"),
            step: nextStep + 1,
            tooltipClass: currentElement.getAttribute("data-tooltipclass"),
            highlightClass: currentElement.getAttribute("data-highlightclass"),
            position: currentElement.getAttribute("data-position") || _this._options.tooltipPosition,
            scrollTo: currentElement.getAttribute("data-scrollto") || _this._options.scrollTo,
            disableInteraction: disableInteraction
          };
        }
      });
    } //removing undefined/null elements


    var tempIntroItems = [];

    for (var z = 0; z < introItems.length; z++) {
      if (introItems[z]) {
        // copy non-falsy values to the end of the array
        tempIntroItems.push(introItems[z]);
      }
    }

    introItems = tempIntroItems; //Ok, sort all items with given steps

    introItems.sort(function (a, b) {
      return a.step - b.step;
    });
    return introItems;
  }

  /**
   * Update placement of the intro objects on the screen
   * @api private
   * @param {boolean} refreshSteps to refresh the intro steps as well
   */

  function refresh(refreshSteps) {
    // re-align intros
    setHelperLayerPosition.call(this, document.querySelector(".introjs-helperLayer"));
    setHelperLayerPosition.call(this, document.querySelector(".introjs-tooltipReferenceLayer"));
    setHelperLayerPosition.call(this, document.querySelector(".introjs-disableInteraction"));

    if (refreshSteps) {
      this._introItems = fetchIntroSteps.call(this, this._targetElement);
    } // re-align tooltip


    if (this._currentStep !== undefined && this._currentStep !== null) {
      var oldArrowLayer = document.querySelector(".introjs-arrow");
      var oldtooltipContainer = document.querySelector(".introjs-tooltip");
      placeTooltip.call(this, this._introItems[this._currentStep].element, oldtooltipContainer, oldArrowLayer);
    } //re-align hints


    reAlignHints.call(this);
    return this;
  }

  function onResize() {
    refresh.call(this);
  }

  /**
   * Removes `element` from `parentElement`
   *
   * @param {Element} element
   * @param {Boolean} [animate=false]
   */

  function removeChild(element, animate) {
    if (!element || !element.parentElement) return;
    var parentElement = element.parentElement;

    if (animate) {
      setStyle(element, {
        opacity: "0"
      });
      window.setTimeout(function () {
        parentElement.removeChild(element);
      }, 500);
    } else {
      parentElement.removeChild(element);
    }
  }

  /**
   * Exit from intro
   *
   * @api private
   * @method _exitIntro
   * @param {Object} targetElement
   * @param {Boolean} force - Setting to `true` will skip the result of beforeExit callback
   */

  function exitIntro(targetElement, force) {
    var continueExit = true; // calling onbeforeexit callback
    //
    // If this callback return `false`, it would halt the process

    if (this._introBeforeExitCallback !== undefined) {
      continueExit = this._introBeforeExitCallback.call(this);
    } // skip this check if `force` parameter is `true`
    // otherwise, if `onbeforeexit` returned `false`, don't exit the intro


    if (!force && continueExit === false) return; // remove overlay layers from the page

    var overlayLayers = targetElement.querySelectorAll(".introjs-overlay");

    if (overlayLayers && overlayLayers.length) {
      forEach(overlayLayers, function (overlayLayer) {
        return removeChild(overlayLayer);
      });
    } //remove all helper layers


    var helperLayer = targetElement.querySelector(".introjs-helperLayer");
    removeChild(helperLayer, true);
    var referenceLayer = targetElement.querySelector(".introjs-tooltipReferenceLayer");
    removeChild(referenceLayer); //remove disableInteractionLayer

    var disableInteractionLayer = targetElement.querySelector(".introjs-disableInteraction");
    removeChild(disableInteractionLayer); //remove intro floating element

    var floatingElement = document.querySelector(".introjsFloatingElement");
    removeChild(floatingElement);
    removeShowElement(); //clean listeners

    DOMEvent.off(window, "keydown", onKeyDown, this, true);
    DOMEvent.off(window, "resize", onResize, this, true); //check if any callback is defined

    if (this._introExitCallback !== undefined) {
      this._introExitCallback.call(this);
    } //set the step to zero


    this._currentStep = undefined;
  }

  /**
   * Add overlay layer to the page
   *
   * @api private
   * @method _addOverlayLayer
   * @param {Object} targetElm
   */

  function addOverlayLayer(targetElm) {
    var _this = this;

    var overlayLayer = _createElement("div", {
      className: "introjs-overlay"
    });
    setStyle(overlayLayer, {
      top: 0,
      bottom: 0,
      left: 0,
      right: 0,
      position: "fixed"
    });
    targetElm.appendChild(overlayLayer);

    if (this._options.exitOnOverlayClick === true) {
      setStyle(overlayLayer, {
        cursor: "pointer"
      });

      overlayLayer.onclick = function () {
        exitIntro.call(_this, targetElm);
      };
    }

    return true;
  }

  /**
   * Initiate a new introduction/guide from an element in the page
   *
   * @api private
   * @method introForElement
   * @param {Object} targetElm
   * @returns {Boolean} Success or not?
   */

  function introForElement(targetElm) {
    //set it to the introJs object
    var steps = fetchIntroSteps.call(this, targetElm);

    if (steps.length === 0) {
      return false;
    }

    this._introItems = steps; //add overlay layer to the page

    if (addOverlayLayer.call(this, targetElm)) {
      //then, start the show
      nextStep.call(this);

      if (this._options.keyboardNavigation) {
        DOMEvent.on(window, "keydown", onKeyDown, this, true);
      } //for window resize


      DOMEvent.on(window, "resize", onResize, this, true);
    }

    return false;
  }

  var version = "4.0.0";

  /**
   * IntroJs main class
   *
   * @class IntroJs
   */

  function IntroJs(obj) {
    this._targetElement = obj;
    this._introItems = [];
    this._options = {
      /* Next button label in tooltip box */
      nextLabel: "Next",

      /* Previous button label in tooltip box */
      prevLabel: "Back",

      /* Skip button label in tooltip box */
      skipLabel: "×",

      /* Done button label in tooltip box */
      doneLabel: "Done",

      /* Hide previous button in the first step? Otherwise, it will be disabled button. */
      hidePrev: false,

      /* Hide next button in the last step? Otherwise, it will be disabled button (note: this will also hide the "Done" button) */
      hideNext: false,

      /* Change the Next button to Done in the last step of the intro? otherwise, it will render a disabled button */
      nextToDone: true,

      /* Default tooltip box position */
      tooltipPosition: "bottom",

      /* Next CSS class for tooltip boxes */
      tooltipClass: "",

      /* Start intro for a group of elements */
      group: "",

      /* CSS class that is added to the helperLayer */
      highlightClass: "",

      /* Close introduction when pressing Escape button? */
      exitOnEsc: true,

      /* Close introduction when clicking on overlay layer? */
      exitOnOverlayClick: true,

      /* Show step numbers in introduction? */
      showStepNumbers: false,

      /* Let user use keyboard to navigate the tour? */
      keyboardNavigation: true,

      /* Show tour control buttons? */
      showButtons: true,

      /* Show tour bullets? */
      showBullets: true,

      /* Show tour progress? */
      showProgress: false,

      /* Scroll to highlighted element? */
      scrollToElement: true,

      /*
       * Should we scroll the tooltip or target element?
       *
       * Options are: 'element' or 'tooltip'
       */
      scrollTo: "element",

      /* Padding to add after scrolling when element is not in the viewport (in pixels) */
      scrollPadding: 30,

      /* Set the overlay opacity */
      overlayOpacity: 0.5,

      /* To determine the tooltip position automatically based on the window.width/height */
      autoPosition: true,

      /* Precedence of positions, when auto is enabled */
      positionPrecedence: ["bottom", "top", "right", "left"],

      /* Disable an interaction with element? */
      disableInteraction: false,

      /* Set how much padding to be used around helper element */
      helperElementPadding: 10,

      /* Default hint position */
      hintPosition: "top-middle",

      /* Hint button label */
      hintButtonLabel: "Got it",

      /* Adding animation to hints? */
      hintAnimation: true,

      /* additional classes to put on the buttons */
      buttonClass: "introjs-button",

      /* additional classes to put on progress bar */
      progressBarAdditionalClass: false
    };
  }

  var introJs = function introJs(targetElm) {
    var instance;

    if (_typeof(targetElm) === "object") {
      //Ok, create a new instance
      instance = new IntroJs(targetElm);
    } else if (typeof targetElm === "string") {
      //select the target element with query selector
      var targetElement = document.querySelector(targetElm);

      if (targetElement) {
        instance = new IntroJs(targetElement);
      } else {
        throw new Error("There is no element with given selector.");
      }
    } else {
      instance = new IntroJs(document.body);
    } // add instance to list of _instances
    // passing group to stamp to increment
    // from 0 onward somewhat reliably


    introJs.instances[stamp(instance, "introjs-instance")] = instance;
    return instance;
  };
  /**
   * Current IntroJs version
   *
   * @property version
   * @type String
   */


  introJs.version = version;
  /**
   * key-val object helper for introJs instances
   *
   * @property instances
   * @type Object
   */

  introJs.instances = {}; //Prototype

  introJs.fn = IntroJs.prototype = {
    clone: function clone() {
      return new IntroJs(this);
    },
    setOption: function setOption(option, value) {
      this._options[option] = value;
      return this;
    },
    setOptions: function setOptions(options) {
      this._options = mergeOptions(this._options, options);
      return this;
    },
    start: function start() {
      introForElement.call(this, this._targetElement);
      return this;
    },
    goToStep: function goToStep$1(step) {
      goToStep.call(this, step);

      return this;
    },
    addStep: function addStep(options) {
      if (!this._options.steps) {
        this._options.steps = [];
      }

      this._options.steps.push(options);

      return this;
    },
    addSteps: function addSteps(steps) {
      if (!steps.length) return;

      for (var index = 0; index < steps.length; index++) {
        this.addStep(steps[index]);
      }

      return this;
    },
    goToStepNumber: function goToStepNumber$1(step) {
      goToStepNumber.call(this, step);

      return this;
    },
    nextStep: function nextStep$1() {
      nextStep.call(this);

      return this;
    },
    previousStep: function previousStep$1() {
      previousStep.call(this);

      return this;
    },
    currentStep: function currentStep$1() {
      return currentStep.call(this);
    },
    exit: function exit(force) {
      exitIntro.call(this, this._targetElement, force);
      return this;
    },
    refresh: function refresh$1(refreshSteps) {
      refresh.call(this, refreshSteps);

      return this;
    },
    onbeforechange: function onbeforechange(providedCallback) {
      if (typeof providedCallback === "function") {
        this._introBeforeChangeCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onbeforechange was not a function");
      }

      return this;
    },
    onchange: function onchange(providedCallback) {
      if (typeof providedCallback === "function") {
        this._introChangeCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onchange was not a function.");
      }

      return this;
    },
    onafterchange: function onafterchange(providedCallback) {
      if (typeof providedCallback === "function") {
        this._introAfterChangeCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onafterchange was not a function");
      }

      return this;
    },
    oncomplete: function oncomplete(providedCallback) {
      if (typeof providedCallback === "function") {
        this._introCompleteCallback = providedCallback;
      } else {
        throw new Error("Provided callback for oncomplete was not a function.");
      }

      return this;
    },
    onhintsadded: function onhintsadded(providedCallback) {
      if (typeof providedCallback === "function") {
        this._hintsAddedCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onhintsadded was not a function.");
      }

      return this;
    },
    onhintclick: function onhintclick(providedCallback) {
      if (typeof providedCallback === "function") {
        this._hintClickCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onhintclick was not a function.");
      }

      return this;
    },
    onhintclose: function onhintclose(providedCallback) {
      if (typeof providedCallback === "function") {
        this._hintCloseCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onhintclose was not a function.");
      }

      return this;
    },
    onexit: function onexit(providedCallback) {
      if (typeof providedCallback === "function") {
        this._introExitCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onexit was not a function.");
      }

      return this;
    },
    onskip: function onskip(providedCallback) {
      if (typeof providedCallback === "function") {
        this._introSkipCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onskip was not a function.");
      }

      return this;
    },
    onbeforeexit: function onbeforeexit(providedCallback) {
      if (typeof providedCallback === "function") {
        this._introBeforeExitCallback = providedCallback;
      } else {
        throw new Error("Provided callback for onbeforeexit was not a function.");
      }

      return this;
    },
    addHints: function addHints() {
      populateHints.call(this, this._targetElement);
      return this;
    },
    hideHint: function hideHint$1(stepId) {
      hideHint.call(this, stepId);

      return this;
    },
    hideHints: function hideHints$1() {
      hideHints.call(this);

      return this;
    },
    showHint: function showHint$1(stepId) {
      showHint.call(this, stepId);

      return this;
    },
    showHints: function showHints$1() {
      showHints.call(this);

      return this;
    },
    removeHints: function removeHints$1() {
      removeHints.call(this);

      return this;
    },
    removeHint: function removeHint$1(stepId) {
      removeHint().call(this, stepId);

      return this;
    },
    showHintDialog: function showHintDialog$1(stepId) {
      showHintDialog.call(this, stepId);

      return this;
    }
  };

  return introJs;

})));
;
(function(n,t,i,r){function f(t,i){this.obj=n(t);this.o=n.extend({},n.fn[u].defaults,i);this.objId=this.obj.attr("id");this.pwCtrls=".jarviswidget-ctrls";this.widget=this.obj.find(this.o.widgets);this.toggleClass=this.o.toggleClass.split("|");this.editClass=this.o.editClass.split("|");this.fullscreenClass=this.o.fullscreenClass.split("|");this.customClass=this.o.customClass.split("|");this.init()}var u="jarvisWidgets";f.prototype={_settings:function(){var n=this;storage=!!function(){var t,n=+new Date;try{return localStorage.setItem(n,n),t=localStorage.getItem(n)==n,localStorage.removeItem(n),t}catch(i){}}()&&localStorage;storage&&n.o.localStorage&&(n.o.ajaxnav===!0?(widget_url=location.hash.replace(/^#/,""),keySettings="Plugin_settings_"+widget_url+"_"+n.objId,getKeySettings=localStorage.getItem(keySettings),keyPosition="Plugin_position_"+widget_url+"_"+n.objId,getKeyPosition=localStorage.getItem(keyPosition)):(keySettings="jarvisWidgets_settings_"+location.pathname+"_"+n.objId,getKeySettings=localStorage.getItem(keySettings),keyPosition="jarvisWidgets_position_"+location.pathname+"_"+n.objId,getKeyPosition=localStorage.getItem(keyPosition)));clickEvent="ontouchstart"in t||t.DocumentTouch&&i instanceof DocumentTouch?"touchstart":"click"},_runLoaderWidget:function(n){var t=this;t.o.indicator===!0&&n.parents(t.o.widgets).find(".jarviswidget-loader").stop(!0,!0).fadeIn(100).delay(t.o.indicatorTime).fadeOut(100)},_getPastTimestamp:function(n){var o=this,t=new Date(n),i,r,u,f,e;return i=t.getMonth()+1,r=t.getDate(),tsYear=t.getFullYear(),u=t.getHours(),f=t.getMinutes(),e=t.getUTCSeconds(),i<10&&(i="0"+i),r<10&&(r="0"+r),u<10&&(u="0"+u),f<10&&(f="0"+f),e<10&&(e="0"+e),o.o.timestampFormat.replace(/%d%/g,r).replace(/%m%/g,i).replace(/%y%/g,tsYear).replace(/%h%/g,u).replace(/%i%/g,f).replace(/%s%/g,e)},_loadAjaxFile:function(t,i,r){var u=this;t.find(".widget-body").load(i,function(i,r,f){if($this=n(this),r=="error"&&$this.html('<h4 class="alert alert-danger">'+u.o.labelError+"<b> "+f.status+" "+f.statusText+"<\/b><\/h4>"),r=="success"){var e=t.find(u.o.timestampPlaceholder);e.length&&e.html(u._getPastTimestamp(new Date));typeof u.o.afterLoad=="function"&&u.o.afterLoad.call(this,t)}});u._runLoaderWidget(r)},_saveSettingsWidget:function(){var t=this,r,i;t._settings();storage&&t.o.localStorage&&(r=[],t.obj.find(t.o.widgets).each(function(){var t={};t.id=n(this).attr("id");t.style=n(this).attr("data-widget-attstyle");t.title=n(this).children("header").children("h2").text();t.hidden=n(this).is(":hidden")?1:0;t.collapsed=n(this).hasClass("jarviswidget-collapsed")?1:0;r.push(t)}),i=JSON.stringify({widget:r}),getKeySettings!=i&&localStorage.setItem(keySettings,i));typeof t.o.onSave=="function"&&t.o.onSave.call(this,null,i)},_savePositionWidget:function(){var t=this,r,i;t._settings();storage&&t.o.localStorage&&(r=[],t.obj.find(t.o.grid+".sortable-grid").each(function(){var i=[],u;n(this).children(t.o.widgets).each(function(){var t={};t.id=n(this).attr("id");i.push(t)});u={section:i};r.push(u)}),i=JSON.stringify({grid:r}),getKeyPosition!=i&&localStorage.setItem(keyPosition,i,null));typeof t.o.onSave=="function"&&t.o.onSave.call(this,i)},init:function(){var t=this,e,s,h,u,i,f,o;if(t._settings(),n("#"+t.objId).length||alert("It looks like your using a class instead of an ID, dont do that!"),t.o.rtl===!0&&n("body").addClass("rtl"),n(t.o.grid).each(function(){n(this).find(t.o.widgets).length&&n(this).addClass("sortable-grid")}),storage&&t.o.localStorage&&getKeyPosition){e=JSON.parse(getKeyPosition);for(i in e.grid){s=t.obj.find(t.o.grid+".sortable-grid").eq(i);for(h in e.grid[i].section)s.append(n("#"+e.grid[i].section[h].id))}}if(storage&&t.o.localStorage&&getKeySettings){u=JSON.parse(getKeySettings);for(i in u.widget)f=n("#"+u.widget[i].id),u.widget[i].style&&f.removeClassPrefix("jarviswidget-color-").addClass(u.widget[i].style).attr("data-widget-attstyle",""+u.widget[i].style+""),u.widget[i].hidden==1?f.hide(1):f.show(1).removeAttr("data-widget-hidden"),u.widget[i].collapsed==1&&f.addClass("jarviswidget-collapsed").children("div").hide(1),f.children("header").children("h2").text()!=u.widget[i].title&&f.children("header").children("h2").text(u.widget[i].title)}t.widget.each(function(){var i=n(this),u=n(this).children("header"),e,o,s,h,c,a,f,l,v;u.parent().attr("role")||(i.data("widget-hidden")===!0&&i.hide(),i.data("widget-collapsed")===!0&&i.addClass("jarviswidget-collapsed").children("div").hide(),e=t.o.customButton===!0&&i.data("widget-custombutton")===r&&t.customClass[0].length!=0?'<a href="javascript:void(0);" class="button-icon jarviswidget-custom-btn"><i class="'+t.customClass[0]+'"><\/i><\/a>':"",o=t.o.deleteButton===!0&&i.data("widget-deletebutton")===r?'<a href="javascript:void(0);" class="button-icon jarviswidget-delete-btn" rel="tooltip" title="Delete" data-placement="bottom"><i class="'+t.o.deleteClass+'"><\/i><\/a>':"",s=t.o.editButton===!0&&i.data("widget-editbutton")===r?'<a href="javascript:void(0);" class="button-icon jarviswidget-edit-btn" rel="tooltip" title="Edit Title" data-placement="bottom"><i class="'+t.editClass[0]+'"><\/i><\/a>':"",h=t.o.fullscreenButton===!0&&i.data("widget-fullscreenbutton")===r?'<a href="javascript:void(0);" class="button-icon jarviswidget-fullscreen-btn" rel="tooltip" title="Fullscreen" data-placement="bottom"><i class="'+t.fullscreenClass[0]+'"><\/i><\/a>':"",t.o.colorButton===!0&&i.data("widget-colorbutton")===r?(c='<a data-toggle="dropdown" class="dropdown-toggle color-box selector" href="javascript:void(0);"><\/a><ul class="dropdown-menu arrow-box-up-right color-select pull-right"><li><span class="bg-color-green" data-widget-setstyle="jarviswidget-color-green" rel="tooltip" data-placement="left" data-original-title="Green Grass"><\/span><\/li><li><span class="bg-color-greenDark" data-widget-setstyle="jarviswidget-color-greenDark" rel="tooltip" data-placement="top" data-original-title="Dark Green"><\/span><\/li><li><span class="bg-color-greenLight" data-widget-setstyle="jarviswidget-color-greenLight" rel="tooltip" data-placement="top" data-original-title="Light Green"><\/span><\/li><li><span class="bg-color-purple" data-widget-setstyle="jarviswidget-color-purple" rel="tooltip" data-placement="top" data-original-title="Purple"><\/span><\/li><li><span class="bg-color-magenta" data-widget-setstyle="jarviswidget-color-magenta" rel="tooltip" data-placement="top" data-original-title="Magenta"><\/span><\/li><li><span class="bg-color-pink" data-widget-setstyle="jarviswidget-color-pink" rel="tooltip" data-placement="right" data-original-title="Pink"><\/span><\/li><li><span class="bg-color-pinkDark" data-widget-setstyle="jarviswidget-color-pinkDark" rel="tooltip" data-placement="left" data-original-title="Fade Pink"><\/span><\/li><li><span class="bg-color-blueLight" data-widget-setstyle="jarviswidget-color-blueLight" rel="tooltip" data-placement="top" data-original-title="Light Blue"><\/span><\/li><li><span class="bg-color-teal" data-widget-setstyle="jarviswidget-color-teal" rel="tooltip" data-placement="top" data-original-title="Teal"><\/span><\/li><li><span class="bg-color-blue" data-widget-setstyle="jarviswidget-color-blue" rel="tooltip" data-placement="top" data-original-title="Ocean Blue"><\/span><\/li><li><span class="bg-color-blueDark" data-widget-setstyle="jarviswidget-color-blueDark" rel="tooltip" data-placement="top" data-original-title="Night Sky"><\/span><\/li><li><span class="bg-color-darken" data-widget-setstyle="jarviswidget-color-darken" rel="tooltip" data-placement="right" data-original-title="Night"><\/span><\/li><li><span class="bg-color-yellow" data-widget-setstyle="jarviswidget-color-yellow" rel="tooltip" data-placement="left" data-original-title="Day Light"><\/span><\/li><li><span class="bg-color-orange" data-widget-setstyle="jarviswidget-color-orange" rel="tooltip" data-placement="bottom" data-original-title="Orange"><\/span><\/li><li><span class="bg-color-orangeDark" data-widget-setstyle="jarviswidget-color-orangeDark" rel="tooltip" data-placement="bottom" data-original-title="Dark Orange"><\/span><\/li><li><span class="bg-color-red" data-widget-setstyle="jarviswidget-color-red" rel="tooltip" data-placement="bottom" data-original-title="Red Rose"><\/span><\/li><li><span class="bg-color-redLight" data-widget-setstyle="jarviswidget-color-redLight" rel="tooltip" data-placement="bottom" data-original-title="Light Red"><\/span><\/li><li><span class="bg-color-white" data-widget-setstyle="jarviswidget-color-white" rel="tooltip" data-placement="right" data-original-title="Purity"><\/span><\/li><li><a href="javascript:void(0);" class="jarviswidget-remove-colors" data-widget-setstyle="" rel="tooltip" data-placement="bottom" data-original-title="Reset widget color to default">Remove<\/a><\/li><\/ul>',u.prepend('<div class="widget-toolbar">'+c+"<\/div>")):c="",t.o.toggleButton===!0&&i.data("widget-togglebutton")===r?(a=i.data("widget-collapsed")===!0||i.hasClass("jarviswidget-collapsed")?t.toggleClass[1]:t.toggleClass[0],f='<a href="#" class="button-icon jarviswidget-toggle-btn" rel="tooltip" title="Collapse" data-placement="bottom"><i class="'+a+'"><\/i><\/a>'):f="",l=t.o.refreshButton===!0&&i.data("widget-refreshbutton")!=!1&&i.data("widget-load")?'<a href="#" class="button-icon jarviswidget-refresh-btn" data-loading-text="&nbsp;&nbsp;Loading...&nbsp;" rel="tooltip" title="Refresh" data-placement="bottom"><i class="'+t.o.refreshButtonClass+'"><\/i><\/a>':"",v=t.o.buttonOrder.replace(/%refresh%/g,l).replace(/%delete%/g,o).replace(/%custom%/g,e).replace(/%fullscreen%/g,h).replace(/%edit%/g,s).replace(/%toggle%/g,f),(l!=""||o!=""||e!=""||h!=""||s!=""||f!="")&&u.prepend('<div class="jarviswidget-ctrls">'+v+"<\/div>"),t.o.sortable===!0&&i.data("widget-sortable")===r&&i.addClass("jarviswidget-sortable"),i.find(t.o.editPlaceholder).length&&i.find(t.o.editPlaceholder).find("input").val(n.trim(u.children("h2").text())),u.append('<span class="jarviswidget-loader"><i class="fa fa-refresh fa-spin"><\/i><\/span>'),i.attr("role","widget").children("div").attr("role","content").prev("header").attr("role","heading").children("div").attr("role","menu"))});t.o.buttonsHidden===!0&&n(t.o.pwCtrls).hide();n(".jarviswidget header [rel=tooltip]").tooltip();t.obj.find("[data-widget-load]").each(function(){var i=n(this),r=i.children(),u=i.data("widget-load"),f=i.data("widget-refresh")*1e3,e=i.children();i.find(".jarviswidget-ajax-placeholder").length||(i.children("widget-body").append('<div class="jarviswidget-ajax-placeholder">'+t.o.loadingLabel+"<\/div>"),i.data("widget-refresh")>0?(t._loadAjaxFile(i,u,r),setInterval(function(){t._loadAjaxFile(i,u,r)},f)):t._loadAjaxFile(i,u,r))});t.o.sortable===!0&&jQuery.ui&&(o=t.obj.find(".sortable-grid").not("[data-widget-excludegrid]"),o.sortable({items:o.find(".jarviswidget-sortable"),connectWith:o,placeholder:t.o.placeholderClass,cursor:"move",revert:!0,opacity:t.o.opacity,delay:200,cancel:".button-icon, #jarviswidget-fullscreen-mode > div",zIndex:1e4,handle:t.o.dragHandle,forcePlaceholderSize:!0,forceHelperSize:!0,update:function(n,i){t._runLoaderWidget(i.item.children());t._savePositionWidget();typeof t.o.onChange=="function"&&t.o.onChange.call(this,i.item)}}));t.o.buttonsHidden===!0&&t.widget.children("header").hover(function(){n(this).children(t.o.pwCtrls).stop(!0,!0).fadeTo(100,1)},function(){n(this).children(t.o.pwCtrls).stop(!0,!0).fadeTo(100,0)});t._clickEvents();n(t.o.deleteSettingsKey).on(clickEvent,this,function(n){if(storage&&t.o.localStorage){var i=confirm(t.o.settingsKeyLabel);i&&localStorage.removeItem(keySettings)}n.preventDefault()});n(t.o.deletePositionKey).on(clickEvent,this,function(n){if(storage&&t.o.localStorage){var i=confirm(t.o.positionKeyLabel);i&&localStorage.removeItem(keyPosition)}n.preventDefault()});storage&&t.o.localStorage&&((getKeySettings===null||getKeySettings.length<1)&&t._saveSettingsWidget(),(getKeyPosition===null||getKeyPosition.length<1)&&t._savePositionWidget())},_clickEvents:function(){function r(){if(n("#jarviswidget-fullscreen-mode").length){var r=n(t).height(),u=n("#jarviswidget-fullscreen-mode").find(i.o.widgets).children("header").height();n("#jarviswidget-fullscreen-mode").find(i.o.widgets).children("div").height(r-u-15)}}var i=this;i._settings();i.widget.on(clickEvent,".jarviswidget-toggle-btn",function(t){var r=n(this),u=r.parents(i.o.widgets);i._runLoaderWidget(r);u.hasClass("jarviswidget-collapsed")?r.children().removeClass(i.toggleClass[1]).addClass(i.toggleClass[0]).parents(i.o.widgets).removeClass("jarviswidget-collapsed").children("[role=content]").slideDown(i.o.toggleSpeed,function(){i._saveSettingsWidget()}):r.children().removeClass(i.toggleClass[0]).addClass(i.toggleClass[1]).parents(i.o.widgets).addClass("jarviswidget-collapsed").children("[role=content]").slideUp(i.o.toggleSpeed,function(){i._saveSettingsWidget()});typeof i.o.onToggle=="function"&&i.o.onToggle.call(this,u);t.preventDefault()});i.widget.on(clickEvent,".jarviswidget-fullscreen-btn",function(t){var u=n(this).parents(i.o.widgets),f=u.children("div");i._runLoaderWidget(n(this));n("#jarviswidget-fullscreen-mode").length?(n(".nooverflow").removeClass("nooverflow"),u.unwrap("<div>").children("div").removeAttr("style").end().find(".jarviswidget-fullscreen-btn").children().removeClass(i.fullscreenClass[1]).addClass(i.fullscreenClass[0]).parents(i.pwCtrls).children("a").show(),f.hasClass("jarviswidget-visible")&&f.hide().removeClass("jarviswidget-visible"),n(this).trigger("fullscreen",[!1])):(n("body").addClass("nooverflow"),u.wrap('<div id="jarviswidget-fullscreen-mode"/>').parent().find(".jarviswidget-fullscreen-btn").children().removeClass(i.fullscreenClass[0]).addClass(i.fullscreenClass[1]).parents(i.pwCtrls).children("a:not(.jarviswidget-fullscreen-btn)").hide(),f.is(":hidden")&&f.show().addClass("jarviswidget-visible"),n(this).trigger("fullscreen",[!0]));r();typeof i.o.onFullscreen=="function"&&i.o.onFullscreen.call(this,u);t.preventDefault()});n(t).resize(function(){r()});i.widget.on(clickEvent,".jarviswidget-edit-btn",function(t){var r=n(this).parents(i.o.widgets);i._runLoaderWidget(n(this));r.find(i.o.editPlaceholder).is(":visible")?n(this).children().removeClass(i.editClass[1]).addClass(i.editClass[0]).parents(i.o.widgets).find(i.o.editPlaceholder).slideUp(i.o.editSpeed,function(){i._saveSettingsWidget()}):n(this).children().removeClass(i.editClass[0]).addClass(i.editClass[1]).parents(i.o.widgets).find(i.o.editPlaceholder).slideDown(i.o.editSpeed);typeof i.o.onEdit=="function"&&i.o.onEdit.call(this,r);t.preventDefault()});n(i.o.editPlaceholder).find("input").keyup(function(){n(this).parents(i.o.widgets).children("header").children("h2").text(n(this).val())});i.widget.on(clickEvent,"[data-widget-setstyle]",function(t){var r=n(this).data("widget-setstyle"),u="";n(this).parents(i.o.editPlaceholder).find("[data-widget-setstyle]").each(function(){u+=n(this).data("widget-setstyle")+" "});n(this).parents(i.o.widgets).attr("data-widget-attstyle",""+r+"").removeClassPrefix("jarviswidget-color-").addClass(r);i._runLoaderWidget(n(this));i._saveSettingsWidget();t.preventDefault()});i.widget.on(clickEvent,".jarviswidget-custom-btn",function(t){var r=n(this).parents(i.o.widgets);i._runLoaderWidget(n(this));n(this).children("."+i.customClass[0]).length?(n(this).children().removeClass(i.customClass[0]).addClass(i.customClass[1]),typeof i.o.customStart=="function"&&i.o.customStart.call(this,r)):(n(this).children().removeClass(i.customClass[1]).addClass(i.customClass[0]),typeof i.o.customEnd=="function"&&i.o.customEnd.call(this,r));i._saveSettingsWidget();t.preventDefault()});i.widget.on(clickEvent,".jarviswidget-delete-btn",function(t){var r=n(this).parents(i.o.widgets),u=r.attr("id"),f=r.children("header").children("h2").text();n.SmartMessageBox({title:"<i class='fa fa-times' style='color:#ed1c24'><\/i> "+i.o.labelDelete+' "'+f+'"',content:"Warning: This action cannot be undone",buttons:"[No][Yes]"},function(t){t=="Yes"&&(i._runLoaderWidget(n(this)),n("#"+u).fadeOut(i.o.deleteSpeed,function(){n(this).remove();typeof i.o.onDelete=="function"&&i.o.onDelete.call(this,r)}))});t.preventDefault()});i.widget.on(clickEvent,".jarviswidget-refresh-btn",function(t){var r=n(this).parents(i.o.widgets),e=r.data("widget-load"),u=r.children(),f=n(this);f.button("loading");u.addClass("widget-body-ajax-loading");setTimeout(function(){f.button("reset");u.removeClass("widget-body-ajax-loading");i._loadAjaxFile(r,e,u)},1e3);t.preventDefault()})},destroy:function(){var n=this;n.widget.off("click",n._clickEvents());n.obj.removeData(u)}};n.fn[u]=function(t){return this.each(function(){var r=n(this),i=r.data(u),e=typeof t=="object"&&t;i||r.data(u,i=new f(this,e));typeof t=="string"&&i[t]()})};n.fn[u].defaults={grid:"section",widgets:".jarviswidget",localStorage:!0,deleteSettingsKey:"",settingsKeyLabel:"Reset settings?",deletePositionKey:"",positionKeyLabel:"Reset position?",sortable:!0,buttonsHidden:!1,toggleButton:!0,toggleClass:"min-10 | plus-10",toggleSpeed:200,onToggle:function(){},deleteButton:!0,deleteClass:"trashcan-10",deleteSpeed:200,onDelete:function(){},editButton:!0,editPlaceholder:".jarviswidget-editbox",editClass:"pencil-10 | delete-10",editSpeed:200,onEdit:function(){},colorButton:!0,fullscreenButton:!0,fullscreenClass:"fullscreen-10 | normalscreen-10",fullscreenDiff:3,onFullscreen:function(){},customButton:!0,customClass:"",customStart:function(){},customEnd:function(){},buttonOrder:"%refresh% %delete% %custom% %edit% %fullscreen% %toggle%",opacity:1,dragHandle:"> header",placeholderClass:"jarviswidget-placeholder",indicator:!0,indicatorTime:600,ajax:!0,loadingLabel:"loading...",timestampPlaceholder:".jarviswidget-timestamp",timestampFormat:"Last update: %m%/%d%/%y% %h%:%i%:%s%",refreshButton:!0,refreshButtonClass:"refresh-10",labelError:"Sorry but there was a error:",labelUpdated:"Last Update:",labelRefresh:"Refresh",labelDelete:"Delete widget:",afterLoad:function(){},rtl:!1,onChange:function(){},onSave:function(){},ajaxnav:!0};n.fn.removeClassPrefix=function(t){return this.each(function(i,r){var u=r.className.split(" ").map(function(n){return n.indexOf(t)===0?"":n});r.className=n.trim(u.join(" "))}),this}})(jQuery,window,document);
//# sourceMappingURL=jarvis.widget.min.js.map
;
/* jquery.sparkline 2.1.1 - http://omnipotent.net/jquery.sparkline/ 
** Licensed under the New BSD License - see above site for details */

(function(a){typeof define=="function"&&define.amd?define(["jquery"],a):a(jQuery)})(function(a){"use strict";var b={},c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I=0;c=function(){return{common:{type:"line",lineColor:"#00f",fillColor:"#cdf",defaultPixelsPerValue:3,width:"auto",height:"auto",composite:!1,tagValuesAttribute:"values",tagOptionsPrefix:"spark",enableTagOptions:!1,enableHighlight:!0,highlightLighten:1.4,tooltipSkipNull:!0,tooltipPrefix:"",tooltipSuffix:"",disableHiddenCheck:!1,numberFormatter:!1,numberDigitGroupCount:3,numberDigitGroupSep:",",numberDecimalMark:".",disableTooltips:!1,disableInteraction:!1},line:{spotColor:"#f80",highlightSpotColor:"#5f5",highlightLineColor:"#f22",spotRadius:1.5,minSpotColor:"#f80",maxSpotColor:"#f80",lineWidth:1,normalRangeMin:undefined,normalRangeMax:undefined,normalRangeColor:"#ccc",drawNormalOnTop:!1,chartRangeMin:undefined,chartRangeMax:undefined,chartRangeMinX:undefined,chartRangeMaxX:undefined,tooltipFormat:new e('<span style="color: {{color}}">&#9679;</span> {{prefix}}{{y}}{{suffix}}')},bar:{barColor:"#3366cc",negBarColor:"#f44",stackedBarColor:["#3366cc","#dc3912","#ff9900","#109618","#66aa00","#dd4477","#0099c6","#990099"],zeroColor:undefined,nullColor:undefined,zeroAxis:!0,barWidth:4,barSpacing:1,chartRangeMax:undefined,chartRangeMin:undefined,chartRangeClip:!1,colorMap:undefined,tooltipFormat:new e('<span style="color: {{color}}">&#9679;</span> {{prefix}}{{value}}{{suffix}}')},tristate:{barWidth:4,barSpacing:1,posBarColor:"#6f6",negBarColor:"#f44",zeroBarColor:"#999",colorMap:{},tooltipFormat:new e('<span style="color: {{color}}">&#9679;</span> {{value:map}}'),tooltipValueLookups:{map:{"-1":"Loss",0:"Draw",1:"Win"}}},discrete:{lineHeight:"auto",thresholdColor:undefined,thresholdValue:0,chartRangeMax:undefined,chartRangeMin:undefined,chartRangeClip:!1,tooltipFormat:new e("{{prefix}}{{value}}{{suffix}}")},bullet:{targetColor:"#f33",targetWidth:3,performanceColor:"#33f",rangeColors:["#d3dafe","#a8b6ff","#7f94ff"],base:undefined,tooltipFormat:new e("{{fieldkey:fields}} - {{value}}"),tooltipValueLookups:{fields:{r:"Range",p:"Performance",t:"Target"}}},pie:{offset:0,sliceColors:["#3366cc","#dc3912","#ff9900","#109618","#66aa00","#dd4477","#0099c6","#990099"],borderWidth:0,borderColor:"#000",tooltipFormat:new e('<span style="color: {{color}}">&#9679;</span> {{value}} ({{percent.1}}%)')},box:{raw:!1,boxLineColor:"#000",boxFillColor:"#cdf",whiskerColor:"#000",outlierLineColor:"#333",outlierFillColor:"#fff",medianColor:"#f00",showOutliers:!0,outlierIQR:1.5,spotRadius:1.5,target:undefined,targetColor:"#4a2",chartRangeMax:undefined,chartRangeMin:undefined,tooltipFormat:new e("{{field:fields}}: {{value}}"),tooltipFormatFieldlistKey:"field",tooltipValueLookups:{fields:{lq:"Lower Quartile",med:"Median",uq:"Upper Quartile",lo:"Left Outlier",ro:"Right Outlier",lw:"Left Whisker",rw:"Right Whisker"}}}}},B='.jqstooltip { position: absolute;left: 0px;top: 0px;visibility: hidden;background: rgb(0, 0, 0) transparent;background-color: rgba(0,0,0,0.6);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#99000000, endColorstr=#99000000);-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#99000000, endColorstr=#99000000)";color: white;font: 10px arial, san serif;text-align: left;white-space: nowrap;padding: 5px;border: 1px solid white;z-index: 10000;}.jqsfield { color: white;font: 10px arial, san serif;text-align: left;}',d=function(){var b,c;return b=function(){this.init.apply(this,arguments)},arguments.length>1?(arguments[0]?(b.prototype=a.extend(new arguments[0],arguments[arguments.length-1]),b._super=arguments[0].prototype):b.prototype=arguments[arguments.length-1],arguments.length>2&&(c=Array.prototype.slice.call(arguments,1,-1),c.unshift(b.prototype),a.extend.apply(a,c))):b.prototype=arguments[0],b.prototype.cls=b,b},a.SPFormatClass=e=d({fre:/\{\{([\w.]+?)(:(.+?))?\}\}/g,precre:/(\w+)\.(\d+)/,init:function(a,b){this.format=a,this.fclass=b},render:function(a,b,c){var d=this,e=a,f,g,h,i,j;return this.format.replace(this.fre,function(){var a;return g=arguments[1],h=arguments[3],f=d.precre.exec(g),f?(j=f[2],g=f[1]):j=!1,i=e[g],i===undefined?"":h&&b&&b[h]?(a=b[h],a.get?b[h].get(i)||i:b[h][i]||i):(k(i)&&(c.get("numberFormatter")?i=c.get("numberFormatter")(i):i=p(i,j,c.get("numberDigitGroupCount"),c.get("numberDigitGroupSep"),c.get("numberDecimalMark"))),i)})}}),a.spformat=function(a,b){return new e(a,b)},f=function(a,b,c){return a<b?b:a>c?c:a},g=function(a,b){var c;return b===2?(c=Math.floor(a.length/2),a.length%2?a[c]:(a[c-1]+a[c])/2):a.length%2?(c=(a.length*b+b)/4,c%1?(a[Math.floor(c)]+a[Math.floor(c)-1])/2:a[c-1]):(c=(a.length*b+2)/4,c%1?(a[Math.floor(c)]+a[Math.floor(c)-1])/2:a[c-1])},h=function(a){var b;switch(a){case"undefined":a=undefined;break;case"null":a=null;break;case"true":a=!0;break;case"false":a=!1;break;default:b=parseFloat(a),a==b&&(a=b)}return a},i=function(a){var b,c=[];for(b=a.length;b--;)c[b]=h(a[b]);return c},j=function(a,b){var c,d,e=[];for(c=0,d=a.length;c<d;c++)a[c]!==b&&e.push(a[c]);return e},k=function(a){return!isNaN(parseFloat(a))&&isFinite(a)},p=function(b,c,d,e,f){var g,h;b=(c===!1?parseFloat(b).toString():b.toFixed(c)).split(""),g=(g=a.inArray(".",b))<0?b.length:g,g<b.length&&(b[g]=f);for(h=g-d;h>0;h-=d)b.splice(h,0,e);return b.join("")},l=function(a,b,c){var d;for(d=b.length;d--;){if(c&&b[d]===null)continue;if(b[d]!==a)return!1}return!0},m=function(a){var b=0,c;for(c=a.length;c--;)b+=typeof a[c]=="number"?a[c]:0;return b},o=function(b){return a.isArray(b)?b:[b]},n=function(a){var b;document.createStyleSheet?document.createStyleSheet().cssText=a:(b=document.createElement("style"),b.type="text/css",document.getElementsByTagName("head")[0].appendChild(b),b[typeof document.body.style.WebkitAppearance=="string"?"innerText":"innerHTML"]=a)},a.fn.simpledraw=function(b,c,d,e){var f,g;if(d&&(f=this.data("_jqs_vcanvas")))return f;b===undefined&&(b=a(this).innerWidth()),c===undefined&&(c=a(this).innerHeight());if(a.fn.sparkline.hasCanvas)f=new F(b,c,this,e);else{if(!a.fn.sparkline.hasVML)return!1;f=new G(b,c,this)}return g=a(this).data("_jqs_mhandler"),g&&g.registerCanvas(f),f},a.fn.cleardraw=function(){var a=this.data("_jqs_vcanvas");a&&a.reset()},a.RangeMapClass=q=d({init:function(a){var b,c,d=[];for(b in a)a.hasOwnProperty(b)&&typeof b=="string"&&b.indexOf(":")>-1&&(c=b.split(":"),c[0]=c[0].length===0?-Infinity:parseFloat(c[0]),c[1]=c[1].length===0?Infinity:parseFloat(c[1]),c[2]=a[b],d.push(c));this.map=a,this.rangelist=d||!1},get:function(a){var b=this.rangelist,c,d,e;if((e=this.map[a])!==undefined)return e;if(b)for(c=b.length;c--;){d=b[c];if(d[0]<=a&&d[1]>=a)return d[2]}return undefined}}),a.range_map=function(a){return new q(a)},r=d({init:function(b,c){var d=a(b);this.$el=d,this.options=c,this.currentPageX=0,this.currentPageY=0,this.el=b,this.splist=[],this.tooltip=null,this.over=!1,this.displayTooltips=!c.get("disableTooltips"),this.highlightEnabled=!c.get("disableHighlight")},registerSparkline:function(a){this.splist.push(a),this.over&&this.updateDisplay()},registerCanvas:function(b){var c=a(b.canvas);this.canvas=b,this.$canvas=c,c.mouseenter(a.proxy(this.mouseenter,this)),c.mouseleave(a.proxy(this.mouseleave,this)),c.click(a.proxy(this.mouseclick,this))},reset:function(a){this.splist=[],this.tooltip&&a&&(this.tooltip.remove(),this.tooltip=undefined)},mouseclick:function(b){var c=a.Event("sparklineClick");c.originalEvent=b,c.sparklines=this.splist,this.$el.trigger(c)},mouseenter:function(b){a(document.body).unbind("mousemove.jqs"),a(document.body).bind("mousemove.jqs",a.proxy(this.mousemove,this)),this.over=!0,this.currentPageX=b.pageX,this.currentPageY=b.pageY,this.currentEl=b.target,!this.tooltip&&this.displayTooltips&&(this.tooltip=new s(this.options),this.tooltip.updatePosition(b.pageX,b.pageY)),this.updateDisplay()},mouseleave:function(){a(document.body).unbind("mousemove.jqs");var b=this.splist,c=b.length,d=!1,e,f;this.over=!1,this.currentEl=null,this.tooltip&&(this.tooltip.remove(),this.tooltip=null);for(f=0;f<c;f++)e=b[f],e.clearRegionHighlight()&&(d=!0);d&&this.canvas.render()},mousemove:function(a){this.currentPageX=a.pageX,this.currentPageY=a.pageY,this.currentEl=a.target,this.tooltip&&this.tooltip.updatePosition(a.pageX,a.pageY),this.updateDisplay()},updateDisplay:function(){var b=this.splist,c=b.length,d=!1,e=this.$canvas.offset(),f=this.currentPageX-e.left,g=this.currentPageY-e.top,h,i,j,k,l;if(!this.over)return;for(j=0;j<c;j++)i=b[j],k=i.setRegionHighlight(this.currentEl,f,g),k&&(d=!0);if(d){l=a.Event("sparklineRegionChange"),l.sparklines=this.splist,this.$el.trigger(l);if(this.tooltip){h="";for(j=0;j<c;j++)i=b[j],h+=i.getCurrentRegionTooltip();this.tooltip.setContent(h)}this.disableHighlight||this.canvas.render()}k===null&&this.mouseleave()}}),s=d({sizeStyle:"position: static !important;display: block !important;visibility: hidden !important;float: left !important;",init:function(b){var c=b.get("tooltipClassname","jqstooltip"),d=this.sizeStyle,e;this.container=b.get("tooltipContainer")||document.body,this.tooltipOffsetX=b.get("tooltipOffsetX",10),this.tooltipOffsetY=b.get("tooltipOffsetY",12),a("#jqssizetip").remove(),a("#jqstooltip").remove(),this.sizetip=a("<div/>",{id:"jqssizetip",style:d,"class":c}),this.tooltip=a("<div/>",{id:"jqstooltip","class":c}).appendTo(this.container),e=this.tooltip.offset(),this.offsetLeft=e.left,this.offsetTop=e.top,this.hidden=!0,a(window).unbind("resize.jqs scroll.jqs"),a(window).bind("resize.jqs scroll.jqs",a.proxy(this.updateWindowDims,this)),this.updateWindowDims()},updateWindowDims:function(){this.scrollTop=a(window).scrollTop(),this.scrollLeft=a(window).scrollLeft(),this.scrollRight=this.scrollLeft+a(window).width(),this.updatePosition()},getSize:function(a){this.sizetip.html(a).appendTo(this.container),this.width=this.sizetip.width()+1,this.height=this.sizetip.height(),this.sizetip.remove()},setContent:function(a){if(!a){this.tooltip.css("visibility","hidden"),this.hidden=!0;return}this.getSize(a),this.tooltip.html(a).css({width:this.width,height:this.height,visibility:"visible"}),this.hidden&&(this.hidden=!1,this.updatePosition())},updatePosition:function(a,b){if(a===undefined){if(this.mousex===undefined)return;a=this.mousex-this.offsetLeft,b=this.mousey-this.offsetTop}else this.mousex=a-=this.offsetLeft,this.mousey=b-=this.offsetTop;if(!this.height||!this.width||this.hidden)return;b-=this.height+this.tooltipOffsetY,a+=this.tooltipOffsetX,b<this.scrollTop&&(b=this.scrollTop),a<this.scrollLeft?a=this.scrollLeft:a+this.width>this.scrollRight&&(a=this.scrollRight-this.width),this.tooltip.css({left:a,top:b})},remove:function(){this.tooltip.remove(),this.sizetip.remove(),this.sizetip=this.tooltip=undefined,a(window).unbind("resize.jqs scroll.jqs")}}),C=function(){n(B)},a(C),H=[],a.fn.sparkline=function(b,c){return this.each(function(){var d=new a.fn.sparkline.options(this,c),e=a(this),f,g;f=function(){var c,f,g,h,i,j,k;if(b==="html"||b===undefined){k=this.getAttribute(d.get("tagValuesAttribute"));if(k===undefined||k===null)k=e.html();c=k.replace(/(^\s*<!--)|(-->\s*$)|\s+/g,"").split(",")}else c=b;f=d.get("width")==="auto"?c.length*d.get("defaultPixelsPerValue"):d.get("width");if(d.get("height")==="auto"){if(!d.get("composite")||!a.data(this,"_jqs_vcanvas"))h=document.createElement("span"),h.innerHTML="a",e.html(h),g=a(h).innerHeight()||a(h).height(),a(h).remove(),h=null}else g=d.get("height");d.get("disableInteraction")?i=!1:(i=a.data(this,"_jqs_mhandler"),i?d.get("composite")||i.reset():(i=new r(this,d),a.data(this,"_jqs_mhandler",i)));if(d.get("composite")&&!a.data(this,"_jqs_vcanvas")){a.data(this,"_jqs_errnotify")||(alert("Attempted to attach a composite sparkline to an element with no existing sparkline"),a.data(this,"_jqs_errnotify",!0));return}j=new(a.fn.sparkline[d.get("type")])(this,c,d,f,g),j.render(),i&&i.registerSparkline(j)};if(a(this).html()&&!d.get("disableHiddenCheck")&&a(this).is(":hidden")||a.fn.jquery<"1.3.0"&&a(this).parents().is(":hidden")||!a(this).parents("body").length){if(!d.get("composite")&&a.data(this,"_jqs_pending"))for(g=H.length;g;g--)H[g-1][0]==this&&H.splice(g-1,1);H.push([this,f]),a.data(this,"_jqs_pending",!0)}else f.call(this)})},a.fn.sparkline.defaults=c(),a.sparkline_display_visible=function(){var b,c,d,e=[];for(c=0,d=H.length;c<d;c++)b=H[c][0],a(b).is(":visible")&&!a(b).parents().is(":hidden")?(H[c][1].call(b),a.data(H[c][0],"_jqs_pending",!1),e.push(c)):!a(b).closest("html").length&&!a.data(b,"_jqs_pending")&&(a.data(H[c][0],"_jqs_pending",!1),e.push(c));for(c=e.length;c;c--)H.splice(e[c-1],1)},a.fn.sparkline.options=d({init:function(c,d){var e,f,g,h;this.userOptions=d=d||{},this.tag=c,this.tagValCache={},f=a.fn.sparkline.defaults,g=f.common,this.tagOptionsPrefix=d.enableTagOptions&&(d.tagOptionsPrefix||g.tagOptionsPrefix),h=this.getTagSetting("type"),h===b?e=f[d.type||g.type]:e=f[h],this.mergedOptions=a.extend({},g,e,d)},getTagSetting:function(a){var c=this.tagOptionsPrefix,d,e,f,g;if(c===!1||c===undefined)return b;if(this.tagValCache.hasOwnProperty(a))d=this.tagValCache.key;else{d=this.tag.getAttribute(c+a);if(d===undefined||d===null)d=b;else if(d.substr(0,1)==="["){d=d.substr(1,d.length-2).split(",");for(e=d.length;e--;)d[e]=h(d[e].replace(/(^\s*)|(\s*$)/g,""))}else if(d.substr(0,1)==="{"){f=d.substr(1,d.length-2).split(","),d={};for(e=f.length;e--;)g=f[e].split(":",2),d[g[0].replace(/(^\s*)|(\s*$)/g,"")]=h(g[1].replace(/(^\s*)|(\s*$)/g,""))}else d=h(d);this.tagValCache.key=d}return d},get:function(a,c){var d=this.getTagSetting(a),e;return d!==b?d:(e=this.mergedOptions[a])===undefined?c:e}}),a.fn.sparkline._base=d({disabled:!1,init:function(b,c,d,e,f){this.el=b,this.$el=a(b),this.values=c,this.options=d,this.width=e,this.height=f,this.currentRegion=undefined},initTarget:function(){var a=!this.options.get("disableInteraction");(this.target=this.$el.simpledraw(this.width,this.height,this.options.get("composite"),a))?(this.canvasWidth=this.target.pixelWidth,this.canvasHeight=this.target.pixelHeight):this.disabled=!0},render:function(){return this.disabled?(this.el.innerHTML="",!1):!0},getRegion:function(a,b){},setRegionHighlight:function(a,b,c){var d=this.currentRegion,e=!this.options.get("disableHighlight"),f;return b>this.canvasWidth||c>this.canvasHeight||b<0||c<0?null:(f=this.getRegion(a,b,c),d!==f?(d!==undefined&&e&&this.removeHighlight(),this.currentRegion=f,f!==undefined&&e&&this.renderHighlight(),!0):!1)},clearRegionHighlight:function(){return this.currentRegion!==undefined?(this.removeHighlight(),this.currentRegion=undefined,!0):!1},renderHighlight:function(){this.changeHighlight(!0)},removeHighlight:function(){this.changeHighlight(!1)},changeHighlight:function(a){},getCurrentRegionTooltip:function(){var b=this.options,c="",d=[],f,g,h,i,j,k,l,m,n,o,p,q,r,s;if(this.currentRegion===undefined)return"";f=this.getCurrentRegionFields(),p=b.get("tooltipFormatter");if(p)return p(this,b,f);b.get("tooltipChartTitle")&&(c+='<div class="jqs jqstitle">'+b.get("tooltipChartTitle")+"</div>\n"),g=this.options.get("tooltipFormat");if(!g)return"";a.isArray(g)||(g=[g]),a.isArray(f)||(f=[f]),l=this.options.get("tooltipFormatFieldlist"),m=this.options.get("tooltipFormatFieldlistKey");if(l&&m){n=[];for(k=f.length;k--;)o=f[k][m],(s=a.inArray(o,l))!=-1&&(n[s]=f[k]);f=n}h=g.length,r=f.length;for(k=0;k<h;k++){q=g[k],typeof q=="string"&&(q=new e(q)),i=q.fclass||"jqsfield";for(s=0;s<r;s++)if(!f[s].isNull||!b.get("tooltipSkipNull"))a.extend(f[s],{prefix:b.get("tooltipPrefix"),suffix:b.get("tooltipSuffix")}),j=q.render(f[s],b.get("tooltipValueLookups"),b),d.push('<div class="'+i+'">'+j+"</div>")}return d.length?c+d.join("\n"):""},getCurrentRegionFields:function(){},calcHighlightColor:function(a,b){var c=b.get("highlightColor"),d=b.get("highlightLighten"),e,g,h,i;if(c)return c;if(d){e=/^#([0-9a-f])([0-9a-f])([0-9a-f])$/i.exec(a)||/^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})$/i.exec(a);if(e){h=[],g=a.length===4?16:1;for(i=0;i<3;i++)h[i]=f(Math.round(parseInt(e[i+1],16)*g*d),0,255);return"rgb("+h.join(",")+")"}}return a}}),t={changeHighlight:function(b){var c=this.currentRegion,d=this.target,e=this.regionShapes[c],f;e&&(f=this.renderRegion(c,b),a.isArray(f)||a.isArray(e)?(d.replaceWithShapes(e,f),this.regionShapes[c]=a.map(f,function(a){return a.id})):(d.replaceWithShape(e,f),this.regionShapes[c]=f.id))},render:function(){var b=this.values,c=this.target,d=this.regionShapes,e,f,g,h;if(!this.cls._super.render.call(this))return;for(g=b.length;g--;){e=this.renderRegion(g);if(e)if(a.isArray(e)){f=[];for(h=e.length;h--;)e[h].append(),f.push(e[h].id);d[g]=f}else e.append(),d[g]=e.id;else d[g]=null}c.render()}},a.fn.sparkline.line=u=d(a.fn.sparkline._base,{type:"line",init:function(a,b,c,d,e){u._super.init.call(this,a,b,c,d,e),this.vertices=[],this.regionMap=[],this.xvalues=[],this.yvalues=[],this.yminmax=[],this.hightlightSpotId=null,this.lastShapeId=null,this.initTarget()},getRegion:function(a,b,c){var d,e=this.regionMap;for(d=e.length;d--;)if(e[d]!==null&&b>=e[d][0]&&b<=e[d][1])return e[d][2];return undefined},getCurrentRegionFields:function(){var a=this.currentRegion;return{isNull:this.yvalues[a]===null,x:this.xvalues[a],y:this.yvalues[a],color:this.options.get("lineColor"),fillColor:this.options.get("fillColor"),offset:a}},renderHighlight:function(){var a=this.currentRegion,b=this.target,c=this.vertices[a],d=this.options,e=d.get("spotRadius"),f=d.get("highlightSpotColor"),g=d.get("highlightLineColor"),h,i;if(!c)return;e&&f&&(h=b.drawCircle(c[0],c[1],e,undefined,f),this.highlightSpotId=h.id,b.insertAfterShape(this.lastShapeId,h)),g&&(i=b.drawLine(c[0],this.canvasTop,c[0],this.canvasTop+this.canvasHeight,g),this.highlightLineId=i.id,b.insertAfterShape(this.lastShapeId,i))},removeHighlight:function(){var a=this.target;this.highlightSpotId&&(a.removeShapeId(this.highlightSpotId),this.highlightSpotId=null),this.highlightLineId&&(a.removeShapeId(this.highlightLineId),this.highlightLineId=null)},scanValues:function(){var a=this.values,b=a.length,c=this.xvalues,d=this.yvalues,e=this.yminmax,f,g,h,i,j;for(f=0;f<b;f++)g=a[f],h=typeof a[f]=="string",i=typeof a[f]=="object"&&a[f]instanceof Array,j=h&&a[f].split(":"),h&&j.length===2?(c.push(Number(j[0])),d.push(Number(j[1])),e.push(Number(j[1]))):i?(c.push(g[0]),d.push(g[1]),e.push(g[1])):(c.push(f),a[f]===null||a[f]==="null"?d.push(null):(d.push(Number(g)),e.push(Number(g))));this.options.get("xvalues")&&(c=this.options.get("xvalues")),this.maxy=this.maxyorg=Math.max.apply(Math,e),this.miny=this.minyorg=Math.min.apply(Math,e),this.maxx=Math.max.apply(Math,c),this.minx=Math.min.apply(Math,c),this.xvalues=c,this.yvalues=d,this.yminmax=e},processRangeOptions:function(){var a=this.options,b=a.get("normalRangeMin"),c=a.get("normalRangeMax");b!==undefined&&(b<this.miny&&(this.miny=b),c>this.maxy&&(this.maxy=c)),a.get("chartRangeMin")!==undefined&&(a.get("chartRangeClip")||a.get("chartRangeMin")<this.miny)&&(this.miny=a.get("chartRangeMin")),a.get("chartRangeMax")!==undefined&&(a.get("chartRangeClip")||a.get("chartRangeMax")>this.maxy)&&(this.maxy=a.get("chartRangeMax")),a.get("chartRangeMinX")!==undefined&&(a.get("chartRangeClipX")||a.get("chartRangeMinX")<this.minx)&&(this.minx=a.get("chartRangeMinX")),a.get("chartRangeMaxX")!==undefined&&(a.get("chartRangeClipX")||a.get("chartRangeMaxX")>this.maxx)&&(this.maxx=a.get("chartRangeMaxX"))},drawNormalRange:function(a,b,c,d,e){var f=this.options.get("normalRangeMin"),g=this.options.get("normalRangeMax"),h=b+Math.round(c-c*((g-this.miny)/e)),i=Math.round(c*(g-f)/e);this.target.drawRect(a,h,d,i,undefined,this.options.get("normalRangeColor")).append()},render:function(){var b=this.options,c=this.target,d=this.canvasWidth,e=this.canvasHeight,f=this.vertices,g=b.get("spotRadius"),h=this.regionMap,i,j,k,l,m,n,o,p,r,s,t,v,w,x,y,z,A,B,C,D,E,F,G,H,I;if(!u._super.render.call(this))return;this.scanValues(),this.processRangeOptions(),G=this.xvalues,H=this.yvalues;if(!this.yminmax.length||this.yvalues.length<2)return;l=m=0,i=this.maxx-this.minx===0?1:this.maxx-this.minx,j=this.maxy-this.miny===0?1:this.maxy-this.miny,k=this.yvalues.length-1,g&&(d<g*4||e<g*4)&&(g=0);if(g){E=b.get("highlightSpotColor")&&!b.get("disableInteraction");if(E||b.get("minSpotColor")||b.get("spotColor")&&H[k]===this.miny)e-=Math.ceil(g);if(E||b.get("maxSpotColor")||b.get("spotColor")&&H[k]===this.maxy)e-=Math.ceil(g),l+=Math.ceil(g);if(E||(b.get("minSpotColor")||b.get("maxSpotColor"))&&(H[0]===this.miny||H[0]===this.maxy))m+=Math.ceil(g),d-=Math.ceil(g);if(E||b.get("spotColor")||b.get("minSpotColor")||b.get("maxSpotColor")&&(H[k]===this.miny||H[k]===this.maxy))d-=Math.ceil(g)}e--,b.get("normalRangeMin")!==undefined&&!b.get("drawNormalOnTop")&&this.drawNormalRange(m,l,e,d,j),o=[],p=[o],x=y=null,z=H.length;for(I=0;I<z;I++)r=G[I],t=G[I+1],s=H[I],v=m+Math.round((r-this.minx)*(d/i)),w=I<z-1?m+Math.round((t-this.minx)*(d/i)):d,y=v+(w-v)/2,h[I]=[x||0,y,I],x=y,s===null?I&&(H[I-1]!==null&&(o=[],p.push(o)),f.push(null)):(s<this.miny&&(s=this.miny),s>this.maxy&&(s=this.maxy),o.length||o.push([v,l+e]),n=[v,l+Math.round(e-e*((s-this.miny)/j))],o.push(n),f.push(n));A=[],B=[],C=p.length;for(I=0;I<C;I++)o=p[I],o.length&&(b.get("fillColor")&&(o.push([o[o.length-1][0],l+e]),B.push(o.slice(0)),o.pop()),o.length>2&&(o[0]=[o[0][0],o[1][1]]),A.push(o));C=B.length;for(I=0;I<C;I++)c.drawShape(B[I],b.get("fillColor"),b.get("fillColor")).append();b.get("normalRangeMin")!==undefined&&b.get("drawNormalOnTop")&&this.drawNormalRange(m,l,e,d,j),C=A.length;for(I=0;I<C;I++)c.drawShape(A[I],b.get("lineColor"),undefined,b.get("lineWidth")).append();if(g&&b.get("valueSpots")){D=b.get("valueSpots"),D.get===undefined&&(D=new q(D));for(I=0;I<z;I++)F=D.get(H[I]),F&&c.drawCircle(m+Math.round((G[I]-this.minx)*(d/i)),l+Math.round(e-e*((H[I]-this.miny)/j)),g,undefined,F).append()}g&&b.get("spotColor")&&H[k]!==null&&c.drawCircle(m+Math.round((G[G.length-1]-this.minx)*(d/i)),l+Math.round(e-e*((H[k]-this.miny)/j)),g,undefined,b.get("spotColor")).append(),this.maxy!==this.minyorg&&(g&&b.get("minSpotColor")&&(r=G[a.inArray(this.minyorg,H)],c.drawCircle(m+Math.round((r-this.minx)*(d/i)),l+Math.round(e-e*((this.minyorg-this.miny)/j)),g,undefined,b.get("minSpotColor")).append()),g&&b.get("maxSpotColor")&&(r=G[a.inArray(this.maxyorg,H)],c.drawCircle(m+Math.round((r-this.minx)*(d/i)),l+Math.round(e-e*((this.maxyorg-this.miny)/j)),g,undefined,b.get("maxSpotColor")).append())),this.lastShapeId=c.getLastShapeId(),this.canvasTop=l,c.render()}}),a.fn.sparkline.bar=v=d(a.fn.sparkline._base,t,{type:"bar",init:function(b,c,d,e,g){var k=parseInt(d.get("barWidth"),10),l=parseInt(d.get("barSpacing"),10),m=d.get("chartRangeMin"),n=d.get("chartRangeMax"),o=d.get("chartRangeClip"),p=Infinity,r=-Infinity,s,t,u,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P;v._super.init.call(this,b,c,d,e,g);for(y=0,z=c.length;y<z;y++){M=c[y],s=typeof M=="string"&&M.indexOf(":")>-1;if(s||a.isArray(M))H=!0,s&&(M=c[y]=i(M.split(":"))),M=j(M,null),t=Math.min.apply(Math,M),u=Math.max.apply(Math,M),t<p&&(p=t),u>r&&(r=u)}this.stacked=H,this.regionShapes={},this.barWidth=k,this.barSpacing=l,this.totalBarWidth=k+l,this.width=e=c.length*k+(c.length-1)*l,this.initTarget(),o&&(F=m===undefined?-Infinity:m,G=n===undefined?Infinity:n),x=[],w=H?[]:x;var Q=[],R=[];for(y=0,z=c.length;y<z;y++)if(H){I=c[y],c[y]=L=[],Q[y]=0,w[y]=R[y]=0;for(J=0,K=I.length;J<K;J++)M=L[J]=o?f(I[J],F,G):I[J],M!==null&&(M>0&&(Q[y]+=M),p<0&&r>0?M<0?R[y]+=Math.abs(M):w[y]+=M:w[y]+=Math.abs(M-(M<0?r:p)),x.push(M))}else M=o?f(c[y],F,G):c[y],M=c[y]=h(M),M!==null&&x.push(M);this.max=E=Math.max.apply(Math,x),this.min=D=Math.min.apply(Math,x),this.stackMax=r=H?Math.max.apply(Math,Q):E,this.stackMin=p=H?Math.min.apply(Math,x):D,d.get("chartRangeMin")!==undefined&&(d.get("chartRangeClip")||d.get("chartRangeMin")<D)&&(D=d.get("chartRangeMin")),d.get("chartRangeMax")!==undefined&&(d.get("chartRangeClip")||d.get("chartRangeMax")>E)&&(E=d.get("chartRangeMax")),this.zeroAxis=B=d.get("zeroAxis",!0),D<=0&&E>=0&&B?C=0:B==0?C=D:D>0?C=D:C=E,this.xaxisOffset=C,A=H?Math.max.apply(Math,w)+Math.max.apply(Math,R):E-D,this.canvasHeightEf=B&&D<0?this.canvasHeight-2:this.canvasHeight-1,D<C?(O=H&&E>=0?r:E,N=(O-C)/A*this.canvasHeight,N!==Math.ceil(N)&&(this.canvasHeightEf-=2,N=Math.ceil(N))):N=this.canvasHeight,this.yoffset=N,a.isArray(d.get("colorMap"))?(this.colorMapByIndex=d.get("colorMap"),this.colorMapByValue=null):(this.colorMapByIndex=null,this.colorMapByValue=d.get("colorMap"),this.colorMapByValue&&this.colorMapByValue.get===undefined&&(this.colorMapByValue=new q(this.colorMapByValue))),this.range=A},getRegion:function(a,b,c){var d=Math.floor(b/this.totalBarWidth);return d<0||d>=this.values.length?undefined:d},getCurrentRegionFields:function(){var a=this.currentRegion,b=o(this.values[a]),c=[],d,e;for(e=b.length;e--;)d=b[e],c.push({isNull:d===null,value:d,color:this.calcColor(e,d,a),offset:a});return c},calcColor:function(b,c,d){var e=this.colorMapByIndex,f=this.colorMapByValue,g=this.options,h,i;return this.stacked?h=g.get("stackedBarColor"):h=c<0?g.get("negBarColor"):g.get("barColor"),c===0&&g.get("zeroColor")!==undefined&&(h=g.get("zeroColor")),f&&(i=f.get(c))?h=i:e&&e.length>d&&(h=e[d]),a.isArray(h)?h[b%h.length]:h},renderRegion:function(b,c){var d=this.values[b],e=this.options,f=this.xaxisOffset,g=[],h=this.range,i=this.stacked,j=this.target,k=b*this.totalBarWidth,m=this.canvasHeightEf,n=this.yoffset,o,p,q,r,s,t,u,v,w,x;d=a.isArray(d)?d:[d],u=d.length,v=d[0],r=l(null,d),x=l(f,d,!0);if(r)return e.get("nullColor")?(q=c?e.get("nullColor"):this.calcHighlightColor(e.get("nullColor"),e),o=n>0?n-1:n,j.drawRect(k,o,this.barWidth-1,0,q,q)):undefined;s=n;for(t=0;t<u;t++){v=d[t];if(i&&v===f){if(!x||w)continue;w=!0}h>0?p=Math.floor(m*(Math.abs(v-f)/h))+1:p=1,v<f||v===f&&n===0?(o=s,s+=p):(o=n-p,n-=p),q=this.calcColor(t,v,b),c&&(q=this.calcHighlightColor(q,e)),g.push(j.drawRect(k,o,this.barWidth-1,p-1,q,q))}return g.length===1?g[0]:g}}),a.fn.sparkline.tristate=w=d(a.fn.sparkline._base,t,{type:"tristate",init:function(b,c,d,e,f){var g=parseInt(d.get("barWidth"),10),h=parseInt(d.get("barSpacing"),10);w._super.init.call(this,b,c,d,e,f),this.regionShapes={},this.barWidth=g,this.barSpacing=h,this.totalBarWidth=g+h,this.values=a.map(c,Number),this.width=e=c.length*g+(c.length-1)*h,a.isArray(d.get("colorMap"))?(this.colorMapByIndex=d.get("colorMap"),this.colorMapByValue=null):(this.colorMapByIndex=null,this.colorMapByValue=d.get("colorMap"),this.colorMapByValue&&this.colorMapByValue.get===undefined&&(this.colorMapByValue=new q(this.colorMapByValue))),this.initTarget()},getRegion:function(a,b,c){return Math.floor(b/this.totalBarWidth)},getCurrentRegionFields:function(){var a=this.currentRegion;return{isNull:this.values[a]===undefined,value:this.values[a],color:this.calcColor(this.values[a],a),offset:a}},calcColor:function(a,b){var c=this.values,d=this.options,e=this.colorMapByIndex,f=this.colorMapByValue,g,h;return f&&(h=f.get(a))?g=h:e&&e.length>b?g=e[b]:c[b]<0?g=d.get("negBarColor"):c[b]>0?g=d.get("posBarColor"):g=d.get("zeroBarColor"),g},renderRegion:function(a,b){var c=this.values,d=this.options,e=this.target,f,g,h,i,j,k;f=e.pixelHeight,h=Math.round(f/2),i=a*this.totalBarWidth,c[a]<0?(j=h,g=h-1):c[a]>0?(j=0,g=h-1):(j=h-1,g=2),k=this.calcColor(c[a],a);if(k===null)return;return b&&(k=this.calcHighlightColor(k,d)),e.drawRect(i,j,this.barWidth-1,g-1,k,k)}}),a.fn.sparkline.discrete=x=d(a.fn.sparkline._base,t,{type:"discrete",init:function(b,c,d,e,f){x._super.init.call(this,b,c,d,e,f),this.regionShapes={},this.values=c=a.map(c,Number),this.min=Math.min.apply(Math,c),this.max=Math.max.apply(Math,c),this.range=this.max-this.min,this.width=e=d.get("width")==="auto"?c.length*2:this.width,this.interval=Math.floor(e/c.length),this.itemWidth=e/c.length,d.get("chartRangeMin")!==undefined&&(d.get("chartRangeClip")||d.get("chartRangeMin")<this.min)&&(this.min=d.get("chartRangeMin")),d.get("chartRangeMax")!==undefined&&(d.get("chartRangeClip")||d.get("chartRangeMax")>this.max)&&(this.max=d.get("chartRangeMax")),this.initTarget(),this.target&&(this.lineHeight=d.get("lineHeight")==="auto"?Math.round(this.canvasHeight*.3):d.get("lineHeight"))},getRegion:function(a,b,c){return Math.floor(b/this.itemWidth)},getCurrentRegionFields:function(){var a=this.currentRegion;return{isNull:this.values[a]===undefined,value:this.values[a],offset:a}},renderRegion:function(a,b){var c=this.values,d=this.options,e=this.min,g=this.max,h=this.range,i=this.interval,j=this.target,k=this.canvasHeight,l=this.lineHeight,m=k-l,n,o,p,q;return o=f(c[a],e,g),q=a*i,n=Math.round(m-m*((o-e)/h)),p=d.get("thresholdColor")&&o<d.get("thresholdValue")?d.get("thresholdColor"):d.get("lineColor"),b&&(p=this.calcHighlightColor(p,d)),j.drawLine(q,n,q,n+l,p)}}),a.fn.sparkline.bullet=y=d(a.fn.sparkline._base,{type:"bullet",init:function(a,b,c,d,e){var f,g,h;y._super.init.call(this,a,b,c,d,e),this.values=b=i(b),h=b.slice(),h[0]=h[0]===null?h[2]:h[0],h[1]=b[1]===null?h[2]:h[1],f=Math.min.apply(Math,b),g=Math.max.apply(Math,b),c.get("base")===undefined?f=f<0?f:0:f=c.get("base"),this.min=f,this.max=g,this.range=g-f,this.shapes={},this.valueShapes={},this.regiondata={},this.width=d=c.get("width")==="auto"?"4.0em":d,this.target=this.$el.simpledraw(d,e,c.get("composite")),b.length||(this.disabled=!0),this.initTarget()},getRegion:function(a,b,c){var d=this.target.getShapeAt(a,b,c);return d!==undefined&&this.shapes[d]!==undefined?this.shapes[d]:undefined},getCurrentRegionFields:function(){var a=this.currentRegion;return{fieldkey:a.substr(0,1),value:this.values[a.substr(1)],region:a}},changeHighlight:function(a){var b=this.currentRegion,c=this.valueShapes[b],d;delete this.shapes[c];switch(b.substr(0,1)){case"r":d=this.renderRange(b.substr(1),a);break;case"p":d=this.renderPerformance(a);break;case"t":d=this.renderTarget(a)}this.valueShapes[b]=d.id,this.shapes[d.id]=b,this.target.replaceWithShape(c,d)},renderRange:function(a,b){var c=this.values[a],d=Math.round(this.canvasWidth*((c-this.min)/this.range)),e=this.options.get("rangeColors")[a-2];return b&&(e=this.calcHighlightColor(e,this.options)),this.target.drawRect(0,0,d-1,this.canvasHeight-1,e,e)},renderPerformance:function(a){var b=this.values[1],c=Math.round(this.canvasWidth*((b-this.min)/this.range)),d=this.options.get("performanceColor");return a&&(d=this.calcHighlightColor(d,this.options)),this.target.drawRect(0,Math.round(this.canvasHeight*.3),c-1,Math.round(this.canvasHeight*.4)-1,d,d)},renderTarget:function(a){var b=this.values[0],c=Math.round(this.canvasWidth*((b-this.min)/this.range)-this.options.get("targetWidth")/2),d=Math.round(this.canvasHeight*.1),e=this.canvasHeight-d*2,f=this.options.get("targetColor");return a&&(f=this.calcHighlightColor(f,this.options)),this.target.drawRect(c,d,this.options.get("targetWidth")-1,e-1,f,f)},render:function(){var a=this.values.length,b=this.target,c,d;if(!y._super.render.call(this))return;for(c=2;c<a;c++)d=this.renderRange(c).append(),this.shapes[d.id]="r"+c,this.valueShapes["r"+c]=d.id;this.values[1]!==null&&(d=this.renderPerformance().append(),this.shapes[d.id]="p1",this.valueShapes.p1=d.id),this.values[0]!==null&&(d=this.renderTarget().append(),this.shapes[d.id]="t0",this.valueShapes.t0=d.id),b.render()}}),a.fn.sparkline.pie=z=d(a.fn.sparkline._base,{type:"pie",init:function(b,c,d,e,f){var g=0,h;z._super.init.call(this,b,c,d,e,f),this.shapes={},this.valueShapes={},this.values=c=a.map(c,Number),d.get("width")==="auto"&&(this.width=this.height);if(c.length>0)for(h=c.length;h--;)g+=c[h];this.total=g,this.initTarget(),this.radius=Math.floor(Math.min(this.canvasWidth,this.canvasHeight)/2)},getRegion:function(a,b,c){var d=this.target.getShapeAt(a,b,c);return d!==undefined&&this.shapes[d]!==undefined?this.shapes[d]:undefined},getCurrentRegionFields:function(){var a=this.currentRegion;return{isNull:this.values[a]===undefined,value:this.values[a],percent:this.values[a]/this.total*100,color:this.options.get("sliceColors")[a%this.options.get("sliceColors").length],offset:a}},changeHighlight:function(a){var b=this.currentRegion,c=this.renderSlice(b,a),d=this.valueShapes[b];delete this.shapes[d],this.target.replaceWithShape(d,c),this.valueShapes[b]=c.id,this.shapes[c.id]=b},renderSlice:function(a,b){var c=this.target,d=this.options,e=this.radius,f=d.get("borderWidth"),g=d.get("offset"),h=2*Math.PI,i=this.values,j=this.total,k=g?2*Math.PI*(g/360):0,l,m,n,o,p;o=i.length;for(n=0;n<o;n++){l=k,m=k,j>0&&(m=k+h*(i[n]/j));if(a===n)return p=d.get("sliceColors")[n%d.get("sliceColors").length],b&&(p=this.calcHighlightColor(p,d)),c.drawPieSlice(e,e,e-f,l,m,undefined,p);k=m}},render:function(){var a=this.target,b=this.values,c=this.options,d=this.radius,e=c.get("borderWidth"),f,g;if(!z._super.
render.call(this))return;e&&a.drawCircle(d,d,Math.floor(d-e/2),c.get("borderColor"),undefined,e).append();for(g=b.length;g--;)b[g]&&(f=this.renderSlice(g).append(),this.valueShapes[g]=f.id,this.shapes[f.id]=g);a.render()}}),a.fn.sparkline.box=A=d(a.fn.sparkline._base,{type:"box",init:function(b,c,d,e,f){A._super.init.call(this,b,c,d,e,f),this.values=a.map(c,Number),this.width=d.get("width")==="auto"?"4.0em":e,this.initTarget(),this.values.length||(this.disabled=1)},getRegion:function(){return 1},getCurrentRegionFields:function(){var a=[{field:"lq",value:this.quartiles[0]},{field:"med",value:this.quartiles[1]},{field:"uq",value:this.quartiles[2]}];return this.loutlier!==undefined&&a.push({field:"lo",value:this.loutlier}),this.routlier!==undefined&&a.push({field:"ro",value:this.routlier}),this.lwhisker!==undefined&&a.push({field:"lw",value:this.lwhisker}),this.rwhisker!==undefined&&a.push({field:"rw",value:this.rwhisker}),a},render:function(){var a=this.target,b=this.values,c=b.length,d=this.options,e=this.canvasWidth,f=this.canvasHeight,h=d.get("chartRangeMin")===undefined?Math.min.apply(Math,b):d.get("chartRangeMin"),i=d.get("chartRangeMax")===undefined?Math.max.apply(Math,b):d.get("chartRangeMax"),j=0,k,l,m,n,o,p,q,r,s,t,u;if(!A._super.render.call(this))return;if(d.get("raw"))d.get("showOutliers")&&b.length>5?(l=b[0],k=b[1],n=b[2],o=b[3],p=b[4],q=b[5],r=b[6]):(k=b[0],n=b[1],o=b[2],p=b[3],q=b[4]);else{b.sort(function(a,b){return a-b}),n=g(b,1),o=g(b,2),p=g(b,3),m=p-n;if(d.get("showOutliers")){k=q=undefined;for(s=0;s<c;s++)k===undefined&&b[s]>n-m*d.get("outlierIQR")&&(k=b[s]),b[s]<p+m*d.get("outlierIQR")&&(q=b[s]);l=b[0],r=b[c-1]}else k=b[0],q=b[c-1]}this.quartiles=[n,o,p],this.lwhisker=k,this.rwhisker=q,this.loutlier=l,this.routlier=r,u=e/(i-h+1),d.get("showOutliers")&&(j=Math.ceil(d.get("spotRadius")),e-=2*Math.ceil(d.get("spotRadius")),u=e/(i-h+1),l<k&&a.drawCircle((l-h)*u+j,f/2,d.get("spotRadius"),d.get("outlierLineColor"),d.get("outlierFillColor")).append(),r>q&&a.drawCircle((r-h)*u+j,f/2,d.get("spotRadius"),d.get("outlierLineColor"),d.get("outlierFillColor")).append()),a.drawRect(Math.round((n-h)*u+j),Math.round(f*.1),Math.round((p-n)*u),Math.round(f*.8),d.get("boxLineColor"),d.get("boxFillColor")).append(),a.drawLine(Math.round((k-h)*u+j),Math.round(f/2),Math.round((n-h)*u+j),Math.round(f/2),d.get("lineColor")).append(),a.drawLine(Math.round((k-h)*u+j),Math.round(f/4),Math.round((k-h)*u+j),Math.round(f-f/4),d.get("whiskerColor")).append(),a.drawLine(Math.round((q-h)*u+j),Math.round(f/2),Math.round((p-h)*u+j),Math.round(f/2),d.get("lineColor")).append(),a.drawLine(Math.round((q-h)*u+j),Math.round(f/4),Math.round((q-h)*u+j),Math.round(f-f/4),d.get("whiskerColor")).append(),a.drawLine(Math.round((o-h)*u+j),Math.round(f*.1),Math.round((o-h)*u+j),Math.round(f*.9),d.get("medianColor")).append(),d.get("target")&&(t=Math.ceil(d.get("spotRadius")),a.drawLine(Math.round((d.get("target")-h)*u+j),Math.round(f/2-t),Math.round((d.get("target")-h)*u+j),Math.round(f/2+t),d.get("targetColor")).append(),a.drawLine(Math.round((d.get("target")-h)*u+j-t),Math.round(f/2),Math.round((d.get("target")-h)*u+j+t),Math.round(f/2),d.get("targetColor")).append()),a.render()}}),function(){document.namespaces&&!document.namespaces.v?(a.fn.sparkline.hasVML=!0,document.namespaces.add("v","urn:schemas-microsoft-com:vml","#default#VML")):a.fn.sparkline.hasVML=!1;var b=document.createElement("canvas");a.fn.sparkline.hasCanvas=!!b.getContext&&!!b.getContext("2d")}(),D=d({init:function(a,b,c,d){this.target=a,this.id=b,this.type=c,this.args=d},append:function(){return this.target.appendShape(this),this}}),E=d({_pxregex:/(\d+)(px)?\s*$/i,init:function(b,c,d){if(!b)return;this.width=b,this.height=c,this.target=d,this.lastShapeId=null,d[0]&&(d=d[0]),a.data(d,"_jqs_vcanvas",this)},drawLine:function(a,b,c,d,e,f){return this.drawShape([[a,b],[c,d]],e,f)},drawShape:function(a,b,c,d){return this._genShape("Shape",[a,b,c,d])},drawCircle:function(a,b,c,d,e,f){return this._genShape("Circle",[a,b,c,d,e,f])},drawPieSlice:function(a,b,c,d,e,f,g){return this._genShape("PieSlice",[a,b,c,d,e,f,g])},drawRect:function(a,b,c,d,e,f){return this._genShape("Rect",[a,b,c,d,e,f])},getElement:function(){return this.canvas},getLastShapeId:function(){return this.lastShapeId},reset:function(){alert("reset not implemented")},_insert:function(b,c){a(c).html(b)},_calculatePixelDims:function(b,c,d){var e;e=this._pxregex.exec(c),e?this.pixelHeight=e[1]:this.pixelHeight=a(d).height(),e=this._pxregex.exec(b),e?this.pixelWidth=e[1]:this.pixelWidth=a(d).width()},_genShape:function(a,b){var c=I++;return b.unshift(c),new D(this,c,a,b)},appendShape:function(a){alert("appendShape not implemented")},replaceWithShape:function(a,b){alert("replaceWithShape not implemented")},insertAfterShape:function(a,b){alert("insertAfterShape not implemented")},removeShapeId:function(a){alert("removeShapeId not implemented")},getShapeAt:function(a,b,c){alert("getShapeAt not implemented")},render:function(){alert("render not implemented")}}),F=d(E,{init:function(b,c,d,e){F._super.init.call(this,b,c,d),this.canvas=document.createElement("canvas"),d[0]&&(d=d[0]),a.data(d,"_jqs_vcanvas",this),a(this.canvas).css({display:"inline-block",width:b,height:c,verticalAlign:"top"}),this._insert(this.canvas,d),this._calculatePixelDims(b,c,this.canvas),this.canvas.width=this.pixelWidth,this.canvas.height=this.pixelHeight,this.interact=e,this.shapes={},this.shapeseq=[],this.currentTargetShapeId=undefined,a(this.canvas).css({width:this.pixelWidth,height:this.pixelHeight})},_getContext:function(a,b,c){var d=this.canvas.getContext("2d");return a!==undefined&&(d.strokeStyle=a),d.lineWidth=c===undefined?1:c,b!==undefined&&(d.fillStyle=b),d},reset:function(){var a=this._getContext();a.clearRect(0,0,this.pixelWidth,this.pixelHeight),this.shapes={},this.shapeseq=[],this.currentTargetShapeId=undefined},_drawShape:function(a,b,c,d,e){var f=this._getContext(c,d,e),g,h;f.beginPath(),f.moveTo(b[0][0]+.5,b[0][1]+.5);for(g=1,h=b.length;g<h;g++)f.lineTo(b[g][0]+.5,b[g][1]+.5);c!==undefined&&f.stroke(),d!==undefined&&f.fill(),this.targetX!==undefined&&this.targetY!==undefined&&f.isPointInPath(this.targetX,this.targetY)&&(this.currentTargetShapeId=a)},_drawCircle:function(a,b,c,d,e,f,g){var h=this._getContext(e,f,g);h.beginPath(),h.arc(b,c,d,0,2*Math.PI,!1),this.targetX!==undefined&&this.targetY!==undefined&&h.isPointInPath(this.targetX,this.targetY)&&(this.currentTargetShapeId=a),e!==undefined&&h.stroke(),f!==undefined&&h.fill()},_drawPieSlice:function(a,b,c,d,e,f,g,h){var i=this._getContext(g,h);i.beginPath(),i.moveTo(b,c),i.arc(b,c,d,e,f,!1),i.lineTo(b,c),i.closePath(),g!==undefined&&i.stroke(),h&&i.fill(),this.targetX!==undefined&&this.targetY!==undefined&&i.isPointInPath(this.targetX,this.targetY)&&(this.currentTargetShapeId=a)},_drawRect:function(a,b,c,d,e,f,g){return this._drawShape(a,[[b,c],[b+d,c],[b+d,c+e],[b,c+e],[b,c]],f,g)},appendShape:function(a){return this.shapes[a.id]=a,this.shapeseq.push(a.id),this.lastShapeId=a.id,a.id},replaceWithShape:function(a,b){var c=this.shapeseq,d;this.shapes[b.id]=b;for(d=c.length;d--;)c[d]==a&&(c[d]=b.id);delete this.shapes[a]},replaceWithShapes:function(a,b){var c=this.shapeseq,d={},e,f,g;for(f=a.length;f--;)d[a[f]]=!0;for(f=c.length;f--;)e=c[f],d[e]&&(c.splice(f,1),delete this.shapes[e],g=f);for(f=b.length;f--;)c.splice(g,0,b[f].id),this.shapes[b[f].id]=b[f]},insertAfterShape:function(a,b){var c=this.shapeseq,d;for(d=c.length;d--;)if(c[d]===a){c.splice(d+1,0,b.id),this.shapes[b.id]=b;return}},removeShapeId:function(a){var b=this.shapeseq,c;for(c=b.length;c--;)if(b[c]===a){b.splice(c,1);break}delete this.shapes[a]},getShapeAt:function(a,b,c){return this.targetX=b,this.targetY=c,this.render(),this.currentTargetShapeId},render:function(){var a=this.shapeseq,b=this.shapes,c=a.length,d=this._getContext(),e,f,g;d.clearRect(0,0,this.pixelWidth,this.pixelHeight);for(g=0;g<c;g++)e=a[g],f=b[e],this["_draw"+f.type].apply(this,f.args);this.interact||(this.shapes={},this.shapeseq=[])}}),G=d(E,{init:function(b,c,d){var e;G._super.init.call(this,b,c,d),d[0]&&(d=d[0]),a.data(d,"_jqs_vcanvas",this),this.canvas=document.createElement("span"),a(this.canvas).css({display:"inline-block",position:"relative",overflow:"hidden",width:b,height:c,margin:"0px",padding:"0px",verticalAlign:"top"}),this._insert(this.canvas,d),this._calculatePixelDims(b,c,this.canvas),this.canvas.width=this.pixelWidth,this.canvas.height=this.pixelHeight,e='<v:group coordorigin="0 0" coordsize="'+this.pixelWidth+" "+this.pixelHeight+'"'+' style="position:absolute;top:0;left:0;width:'+this.pixelWidth+"px;height="+this.pixelHeight+'px;"></v:group>',this.canvas.insertAdjacentHTML("beforeEnd",e),this.group=a(this.canvas).children()[0],this.rendered=!1,this.prerender=""},_drawShape:function(a,b,c,d,e){var f=[],g,h,i,j,k,l,m;for(m=0,l=b.length;m<l;m++)f[m]=""+b[m][0]+","+b[m][1];return g=f.splice(0,1),e=e===undefined?1:e,h=c===undefined?' stroked="false" ':' strokeWeight="'+e+'px" strokeColor="'+c+'" ',i=d===undefined?' filled="false"':' fillColor="'+d+'" filled="true" ',j=f[0]===f[f.length-1]?"x ":"",k='<v:shape coordorigin="0 0" coordsize="'+this.pixelWidth+" "+this.pixelHeight+'" '+' id="jqsshape'+a+'" '+h+i+' style="position:absolute;left:0px;top:0px;height:'+this.pixelHeight+"px;width:"+this.pixelWidth+'px;padding:0px;margin:0px;" '+' path="m '+g+" l "+f.join(", ")+" "+j+'e">'+" </v:shape>",k},_drawCircle:function(a,b,c,d,e,f,g){var h,i,j;return b-=d,c-=d,h=e===undefined?' stroked="false" ':' strokeWeight="'+g+'px" strokeColor="'+e+'" ',i=f===undefined?' filled="false"':' fillColor="'+f+'" filled="true" ',j='<v:oval  id="jqsshape'+a+'" '+h+i+' style="position:absolute;top:'+c+"px; left:"+b+"px; width:"+d*2+"px; height:"+d*2+'px"></v:oval>',j},_drawPieSlice:function(a,b,c,d,e,f,g,h){var i,j,k,l,m,n,o,p;if(e===f)return"";f-e===2*Math.PI&&(e=0,f=2*Math.PI),j=b+Math.round(Math.cos(e)*d),k=c+Math.round(Math.sin(e)*d),l=b+Math.round(Math.cos(f)*d),m=c+Math.round(Math.sin(f)*d);if(j===l&&k===m){if(f-e<Math.PI)return"";j=l=b+d,k=m=c}return j===l&&k===m&&f-e<Math.PI?"":(i=[b-d,c-d,b+d,c+d,j,k,l,m],n=g===undefined?' stroked="false" ':' strokeWeight="1px" strokeColor="'+g+'" ',o=h===undefined?' filled="false"':' fillColor="'+h+'" filled="true" ',p='<v:shape coordorigin="0 0" coordsize="'+this.pixelWidth+" "+this.pixelHeight+'" '+' id="jqsshape'+a+'" '+n+o+' style="position:absolute;left:0px;top:0px;height:'+this.pixelHeight+"px;width:"+this.pixelWidth+'px;padding:0px;margin:0px;" '+' path="m '+b+","+c+" wa "+i.join(", ")+' x e">'+" </v:shape>",p)},_drawRect:function(a,b,c,d,e,f,g){return this._drawShape(a,[[b,c],[b,c+e],[b+d,c+e],[b+d,c],[b,c]],f,g)},reset:function(){this.group.innerHTML=""},appendShape:function(a){var b=this["_draw"+a.type].apply(this,a.args);return this.rendered?this.group.insertAdjacentHTML("beforeEnd",b):this.prerender+=b,this.lastShapeId=a.id,a.id},replaceWithShape:function(b,c){var d=a("#jqsshape"+b),e=this["_draw"+c.type].apply(this,c.args);d[0].outerHTML=e},replaceWithShapes:function(b,c){var d=a("#jqsshape"+b[0]),e="",f=c.length,g;for(g=0;g<f;g++)e+=this["_draw"+c[g].type].apply(this,c[g].args);d[0].outerHTML=e;for(g=1;g<b.length;g++)a("#jqsshape"+b[g]).remove()},insertAfterShape:function(b,c){var d=a("#jqsshape"+b),e=this["_draw"+c.type].apply(this,c.args);d[0].insertAdjacentHTML("afterEnd",e)},removeShapeId:function(b){var c=a("#jqsshape"+b);this.group.removeChild(c[0])},getShapeAt:function(a,b,c){var d=a.id.substr(8);return d},render:function(){this.rendered||(this.group.innerHTML=this.prerender,this.rendered=!0)}})});;
/*
Copyright 2012 Igor Vaynberg

Version: 3.4.5 Timestamp: Mon Nov  4 08:22:42 PST 2013

This software is licensed under the Apache License, Version 2.0 (the "Apache License") or the GNU
General Public License version 2 (the "GPL License"). You may choose either license to govern your
use of this software only upon the condition that you accept all of the terms of either the Apache
License or the GPL License.

You may obtain a copy of the Apache License and the GPL License at:

http://www.apache.org/licenses/LICENSE-2.0
http://www.gnu.org/licenses/gpl-2.0.html

Unless required by applicable law or agreed to in writing, software distributed under the Apache License
or the GPL Licesnse is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
either express or implied. See the Apache License and the GPL License for the specific language governing
permissions and limitations under the Apache License and the GPL License.
*/
!function(a){"undefined"==typeof a.fn.each2&&a.extend(a.fn,{each2:function(b){for(var c=a([0]),d=-1,e=this.length;++d<e&&(c.context=c[0]=this[d])&&b.call(c[0],d,c)!==!1;);return this}})}(jQuery),function(a,b){"use strict";function n(a){var b,c,d,e;if(!a||a.length<1)return a;for(b="",c=0,d=a.length;d>c;c++)e=a.charAt(c),b+=m[e]||e;return b}function o(a,b){for(var c=0,d=b.length;d>c;c+=1)if(q(a,b[c]))return c;return-1}function p(){var b=a(l);b.appendTo("body");var c={width:b.width()-b[0].clientWidth,height:b.height()-b[0].clientHeight};return b.remove(),c}function q(a,c){return a===c?!0:a===b||c===b?!1:null===a||null===c?!1:a.constructor===String?a+""==c+"":c.constructor===String?c+""==a+"":!1}function r(b,c){var d,e,f;if(null===b||b.length<1)return[];for(d=b.split(c),e=0,f=d.length;f>e;e+=1)d[e]=a.trim(d[e]);return d}function s(a){return a.outerWidth(!1)-a.width()}function t(c){var d="keyup-change-value";c.on("keydown",function(){a.data(c,d)===b&&a.data(c,d,c.val())}),c.on("keyup",function(){var e=a.data(c,d);e!==b&&c.val()!==e&&(a.removeData(c,d),c.trigger("keyup-change"))})}function u(c){c.on("mousemove",function(c){var d=i;(d===b||d.x!==c.pageX||d.y!==c.pageY)&&a(c.target).trigger("mousemove-filtered",c)})}function v(a,c,d){d=d||b;var e;return function(){var b=arguments;window.clearTimeout(e),e=window.setTimeout(function(){c.apply(d,b)},a)}}function w(a){var c,b=!1;return function(){return b===!1&&(c=a(),b=!0),c}}function x(a,b){var c=v(a,function(a){b.trigger("scroll-debounced",a)});b.on("scroll",function(a){o(a.target,b.get())>=0&&c(a)})}function y(a){a[0]!==document.activeElement&&window.setTimeout(function(){var d,b=a[0],c=a.val().length;a.focus(),a.is(":visible")&&b===document.activeElement&&(b.setSelectionRange?b.setSelectionRange(c,c):b.createTextRange&&(d=b.createTextRange(),d.collapse(!1),d.select()))},0)}function z(b){b=a(b)[0];var c=0,d=0;if("selectionStart"in b)c=b.selectionStart,d=b.selectionEnd-c;else if("selection"in document){b.focus();var e=document.selection.createRange();d=document.selection.createRange().text.length,e.moveStart("character",-b.value.length),c=e.text.length-d}return{offset:c,length:d}}function A(a){a.preventDefault(),a.stopPropagation()}function B(a){a.preventDefault(),a.stopImmediatePropagation()}function C(b){if(!h){var c=b[0].currentStyle||window.getComputedStyle(b[0],null);h=a(document.createElement("div")).css({position:"absolute",left:"-10000px",top:"-10000px",display:"none",fontSize:c.fontSize,fontFamily:c.fontFamily,fontStyle:c.fontStyle,fontWeight:c.fontWeight,letterSpacing:c.letterSpacing,textTransform:c.textTransform,whiteSpace:"nowrap"}),h.attr("class","select2-sizer"),a("body").append(h)}return h.text(b.val()),h.width()}function D(b,c,d){var e,g,f=[];e=b.attr("class"),e&&(e=""+e,a(e.split(" ")).each2(function(){0===this.indexOf("select2-")&&f.push(this)})),e=c.attr("class"),e&&(e=""+e,a(e.split(" ")).each2(function(){0!==this.indexOf("select2-")&&(g=d(this),g&&f.push(g))})),b.attr("class",f.join(" "))}function E(a,b,c,d){var e=n(a.toUpperCase()).indexOf(n(b.toUpperCase())),f=b.length;return 0>e?(c.push(d(a)),void 0):(c.push(d(a.substring(0,e))),c.push("<span class='select2-match'>"),c.push(d(a.substring(e,e+f))),c.push("</span>"),c.push(d(a.substring(e+f,a.length))),void 0)}function F(a){var b={"\\":"&#92;","&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;","/":"&#47;"};return String(a).replace(/[&<>"'\/\\]/g,function(a){return b[a]})}function G(c){var d,e=null,f=c.quietMillis||100,g=c.url,h=this;return function(i){window.clearTimeout(d),d=window.setTimeout(function(){var d=c.data,f=g,j=c.transport||a.fn.select2.ajaxDefaults.transport,k={type:c.type||"GET",cache:c.cache||!1,jsonpCallback:c.jsonpCallback||b,dataType:c.dataType||"json"},l=a.extend({},a.fn.select2.ajaxDefaults.params,k);d=d?d.call(h,i.term,i.page,i.context):null,f="function"==typeof f?f.call(h,i.term,i.page,i.context):f,e&&e.abort(),c.params&&(a.isFunction(c.params)?a.extend(l,c.params.call(h)):a.extend(l,c.params)),a.extend(l,{url:f,dataType:c.dataType,data:d,success:function(a){var b=c.results(a,i.page);i.callback(b)}}),e=j.call(h,l)},f)}}function H(b){var d,e,c=b,f=function(a){return""+a.text};a.isArray(c)&&(e=c,c={results:e}),a.isFunction(c)===!1&&(e=c,c=function(){return e});var g=c();return g.text&&(f=g.text,a.isFunction(f)||(d=g.text,f=function(a){return a[d]})),function(b){var g,d=b.term,e={results:[]};return""===d?(b.callback(c()),void 0):(g=function(c,e){var h,i;if(c=c[0],c.children){h={};for(i in c)c.hasOwnProperty(i)&&(h[i]=c[i]);h.children=[],a(c.children).each2(function(a,b){g(b,h.children)}),(h.children.length||b.matcher(d,f(h),c))&&e.push(h)}else b.matcher(d,f(c),c)&&e.push(c)},a(c().results).each2(function(a,b){g(b,e.results)}),b.callback(e),void 0)}}function I(c){var d=a.isFunction(c);return function(e){var f=e.term,g={results:[]};a(d?c():c).each(function(){var a=this.text!==b,c=a?this.text:this;(""===f||e.matcher(f,c))&&g.results.push(a?this:{id:this,text:this})}),e.callback(g)}}function J(b,c){if(a.isFunction(b))return!0;if(!b)return!1;throw new Error(c+" must be a function or a falsy value")}function K(b){return a.isFunction(b)?b():b}function L(b){var c=0;return a.each(b,function(a,b){b.children?c+=L(b.children):c++}),c}function M(a,c,d,e){var h,i,j,k,l,f=a,g=!1;if(!e.createSearchChoice||!e.tokenSeparators||e.tokenSeparators.length<1)return b;for(;;){for(i=-1,j=0,k=e.tokenSeparators.length;k>j&&(l=e.tokenSeparators[j],i=a.indexOf(l),!(i>=0));j++);if(0>i)break;if(h=a.substring(0,i),a=a.substring(i+l.length),h.length>0&&(h=e.createSearchChoice.call(this,h,c),h!==b&&null!==h&&e.id(h)!==b&&null!==e.id(h))){for(g=!1,j=0,k=c.length;k>j;j++)if(q(e.id(h),e.id(c[j]))){g=!0;break}g||d(h)}}return f!==a?a:void 0}function N(b,c){var d=function(){};return d.prototype=new b,d.prototype.constructor=d,d.prototype.parent=b.prototype,d.prototype=a.extend(d.prototype,c),d}if(window.Select2===b){var c,d,e,f,g,h,j,k,i={x:0,y:0},c={TAB:9,ENTER:13,ESC:27,SPACE:32,LEFT:37,UP:38,RIGHT:39,DOWN:40,SHIFT:16,CTRL:17,ALT:18,PAGE_UP:33,PAGE_DOWN:34,HOME:36,END:35,BACKSPACE:8,DELETE:46,isArrow:function(a){switch(a=a.which?a.which:a){case c.LEFT:case c.RIGHT:case c.UP:case c.DOWN:return!0}return!1},isControl:function(a){var b=a.which;switch(b){case c.SHIFT:case c.CTRL:case c.ALT:return!0}return a.metaKey?!0:!1},isFunctionKey:function(a){return a=a.which?a.which:a,a>=112&&123>=a}},l="<div class='select2-measure-scrollbar'></div>",m={"\u24b6":"A","\uff21":"A","\xc0":"A","\xc1":"A","\xc2":"A","\u1ea6":"A","\u1ea4":"A","\u1eaa":"A","\u1ea8":"A","\xc3":"A","\u0100":"A","\u0102":"A","\u1eb0":"A","\u1eae":"A","\u1eb4":"A","\u1eb2":"A","\u0226":"A","\u01e0":"A","\xc4":"A","\u01de":"A","\u1ea2":"A","\xc5":"A","\u01fa":"A","\u01cd":"A","\u0200":"A","\u0202":"A","\u1ea0":"A","\u1eac":"A","\u1eb6":"A","\u1e00":"A","\u0104":"A","\u023a":"A","\u2c6f":"A","\ua732":"AA","\xc6":"AE","\u01fc":"AE","\u01e2":"AE","\ua734":"AO","\ua736":"AU","\ua738":"AV","\ua73a":"AV","\ua73c":"AY","\u24b7":"B","\uff22":"B","\u1e02":"B","\u1e04":"B","\u1e06":"B","\u0243":"B","\u0182":"B","\u0181":"B","\u24b8":"C","\uff23":"C","\u0106":"C","\u0108":"C","\u010a":"C","\u010c":"C","\xc7":"C","\u1e08":"C","\u0187":"C","\u023b":"C","\ua73e":"C","\u24b9":"D","\uff24":"D","\u1e0a":"D","\u010e":"D","\u1e0c":"D","\u1e10":"D","\u1e12":"D","\u1e0e":"D","\u0110":"D","\u018b":"D","\u018a":"D","\u0189":"D","\ua779":"D","\u01f1":"DZ","\u01c4":"DZ","\u01f2":"Dz","\u01c5":"Dz","\u24ba":"E","\uff25":"E","\xc8":"E","\xc9":"E","\xca":"E","\u1ec0":"E","\u1ebe":"E","\u1ec4":"E","\u1ec2":"E","\u1ebc":"E","\u0112":"E","\u1e14":"E","\u1e16":"E","\u0114":"E","\u0116":"E","\xcb":"E","\u1eba":"E","\u011a":"E","\u0204":"E","\u0206":"E","\u1eb8":"E","\u1ec6":"E","\u0228":"E","\u1e1c":"E","\u0118":"E","\u1e18":"E","\u1e1a":"E","\u0190":"E","\u018e":"E","\u24bb":"F","\uff26":"F","\u1e1e":"F","\u0191":"F","\ua77b":"F","\u24bc":"G","\uff27":"G","\u01f4":"G","\u011c":"G","\u1e20":"G","\u011e":"G","\u0120":"G","\u01e6":"G","\u0122":"G","\u01e4":"G","\u0193":"G","\ua7a0":"G","\ua77d":"G","\ua77e":"G","\u24bd":"H","\uff28":"H","\u0124":"H","\u1e22":"H","\u1e26":"H","\u021e":"H","\u1e24":"H","\u1e28":"H","\u1e2a":"H","\u0126":"H","\u2c67":"H","\u2c75":"H","\ua78d":"H","\u24be":"I","\uff29":"I","\xcc":"I","\xcd":"I","\xce":"I","\u0128":"I","\u012a":"I","\u012c":"I","\u0130":"I","\xcf":"I","\u1e2e":"I","\u1ec8":"I","\u01cf":"I","\u0208":"I","\u020a":"I","\u1eca":"I","\u012e":"I","\u1e2c":"I","\u0197":"I","\u24bf":"J","\uff2a":"J","\u0134":"J","\u0248":"J","\u24c0":"K","\uff2b":"K","\u1e30":"K","\u01e8":"K","\u1e32":"K","\u0136":"K","\u1e34":"K","\u0198":"K","\u2c69":"K","\ua740":"K","\ua742":"K","\ua744":"K","\ua7a2":"K","\u24c1":"L","\uff2c":"L","\u013f":"L","\u0139":"L","\u013d":"L","\u1e36":"L","\u1e38":"L","\u013b":"L","\u1e3c":"L","\u1e3a":"L","\u0141":"L","\u023d":"L","\u2c62":"L","\u2c60":"L","\ua748":"L","\ua746":"L","\ua780":"L","\u01c7":"LJ","\u01c8":"Lj","\u24c2":"M","\uff2d":"M","\u1e3e":"M","\u1e40":"M","\u1e42":"M","\u2c6e":"M","\u019c":"M","\u24c3":"N","\uff2e":"N","\u01f8":"N","\u0143":"N","\xd1":"N","\u1e44":"N","\u0147":"N","\u1e46":"N","\u0145":"N","\u1e4a":"N","\u1e48":"N","\u0220":"N","\u019d":"N","\ua790":"N","\ua7a4":"N","\u01ca":"NJ","\u01cb":"Nj","\u24c4":"O","\uff2f":"O","\xd2":"O","\xd3":"O","\xd4":"O","\u1ed2":"O","\u1ed0":"O","\u1ed6":"O","\u1ed4":"O","\xd5":"O","\u1e4c":"O","\u022c":"O","\u1e4e":"O","\u014c":"O","\u1e50":"O","\u1e52":"O","\u014e":"O","\u022e":"O","\u0230":"O","\xd6":"O","\u022a":"O","\u1ece":"O","\u0150":"O","\u01d1":"O","\u020c":"O","\u020e":"O","\u01a0":"O","\u1edc":"O","\u1eda":"O","\u1ee0":"O","\u1ede":"O","\u1ee2":"O","\u1ecc":"O","\u1ed8":"O","\u01ea":"O","\u01ec":"O","\xd8":"O","\u01fe":"O","\u0186":"O","\u019f":"O","\ua74a":"O","\ua74c":"O","\u01a2":"OI","\ua74e":"OO","\u0222":"OU","\u24c5":"P","\uff30":"P","\u1e54":"P","\u1e56":"P","\u01a4":"P","\u2c63":"P","\ua750":"P","\ua752":"P","\ua754":"P","\u24c6":"Q","\uff31":"Q","\ua756":"Q","\ua758":"Q","\u024a":"Q","\u24c7":"R","\uff32":"R","\u0154":"R","\u1e58":"R","\u0158":"R","\u0210":"R","\u0212":"R","\u1e5a":"R","\u1e5c":"R","\u0156":"R","\u1e5e":"R","\u024c":"R","\u2c64":"R","\ua75a":"R","\ua7a6":"R","\ua782":"R","\u24c8":"S","\uff33":"S","\u1e9e":"S","\u015a":"S","\u1e64":"S","\u015c":"S","\u1e60":"S","\u0160":"S","\u1e66":"S","\u1e62":"S","\u1e68":"S","\u0218":"S","\u015e":"S","\u2c7e":"S","\ua7a8":"S","\ua784":"S","\u24c9":"T","\uff34":"T","\u1e6a":"T","\u0164":"T","\u1e6c":"T","\u021a":"T","\u0162":"T","\u1e70":"T","\u1e6e":"T","\u0166":"T","\u01ac":"T","\u01ae":"T","\u023e":"T","\ua786":"T","\ua728":"TZ","\u24ca":"U","\uff35":"U","\xd9":"U","\xda":"U","\xdb":"U","\u0168":"U","\u1e78":"U","\u016a":"U","\u1e7a":"U","\u016c":"U","\xdc":"U","\u01db":"U","\u01d7":"U","\u01d5":"U","\u01d9":"U","\u1ee6":"U","\u016e":"U","\u0170":"U","\u01d3":"U","\u0214":"U","\u0216":"U","\u01af":"U","\u1eea":"U","\u1ee8":"U","\u1eee":"U","\u1eec":"U","\u1ef0":"U","\u1ee4":"U","\u1e72":"U","\u0172":"U","\u1e76":"U","\u1e74":"U","\u0244":"U","\u24cb":"V","\uff36":"V","\u1e7c":"V","\u1e7e":"V","\u01b2":"V","\ua75e":"V","\u0245":"V","\ua760":"VY","\u24cc":"W","\uff37":"W","\u1e80":"W","\u1e82":"W","\u0174":"W","\u1e86":"W","\u1e84":"W","\u1e88":"W","\u2c72":"W","\u24cd":"X","\uff38":"X","\u1e8a":"X","\u1e8c":"X","\u24ce":"Y","\uff39":"Y","\u1ef2":"Y","\xdd":"Y","\u0176":"Y","\u1ef8":"Y","\u0232":"Y","\u1e8e":"Y","\u0178":"Y","\u1ef6":"Y","\u1ef4":"Y","\u01b3":"Y","\u024e":"Y","\u1efe":"Y","\u24cf":"Z","\uff3a":"Z","\u0179":"Z","\u1e90":"Z","\u017b":"Z","\u017d":"Z","\u1e92":"Z","\u1e94":"Z","\u01b5":"Z","\u0224":"Z","\u2c7f":"Z","\u2c6b":"Z","\ua762":"Z","\u24d0":"a","\uff41":"a","\u1e9a":"a","\xe0":"a","\xe1":"a","\xe2":"a","\u1ea7":"a","\u1ea5":"a","\u1eab":"a","\u1ea9":"a","\xe3":"a","\u0101":"a","\u0103":"a","\u1eb1":"a","\u1eaf":"a","\u1eb5":"a","\u1eb3":"a","\u0227":"a","\u01e1":"a","\xe4":"a","\u01df":"a","\u1ea3":"a","\xe5":"a","\u01fb":"a","\u01ce":"a","\u0201":"a","\u0203":"a","\u1ea1":"a","\u1ead":"a","\u1eb7":"a","\u1e01":"a","\u0105":"a","\u2c65":"a","\u0250":"a","\ua733":"aa","\xe6":"ae","\u01fd":"ae","\u01e3":"ae","\ua735":"ao","\ua737":"au","\ua739":"av","\ua73b":"av","\ua73d":"ay","\u24d1":"b","\uff42":"b","\u1e03":"b","\u1e05":"b","\u1e07":"b","\u0180":"b","\u0183":"b","\u0253":"b","\u24d2":"c","\uff43":"c","\u0107":"c","\u0109":"c","\u010b":"c","\u010d":"c","\xe7":"c","\u1e09":"c","\u0188":"c","\u023c":"c","\ua73f":"c","\u2184":"c","\u24d3":"d","\uff44":"d","\u1e0b":"d","\u010f":"d","\u1e0d":"d","\u1e11":"d","\u1e13":"d","\u1e0f":"d","\u0111":"d","\u018c":"d","\u0256":"d","\u0257":"d","\ua77a":"d","\u01f3":"dz","\u01c6":"dz","\u24d4":"e","\uff45":"e","\xe8":"e","\xe9":"e","\xea":"e","\u1ec1":"e","\u1ebf":"e","\u1ec5":"e","\u1ec3":"e","\u1ebd":"e","\u0113":"e","\u1e15":"e","\u1e17":"e","\u0115":"e","\u0117":"e","\xeb":"e","\u1ebb":"e","\u011b":"e","\u0205":"e","\u0207":"e","\u1eb9":"e","\u1ec7":"e","\u0229":"e","\u1e1d":"e","\u0119":"e","\u1e19":"e","\u1e1b":"e","\u0247":"e","\u025b":"e","\u01dd":"e","\u24d5":"f","\uff46":"f","\u1e1f":"f","\u0192":"f","\ua77c":"f","\u24d6":"g","\uff47":"g","\u01f5":"g","\u011d":"g","\u1e21":"g","\u011f":"g","\u0121":"g","\u01e7":"g","\u0123":"g","\u01e5":"g","\u0260":"g","\ua7a1":"g","\u1d79":"g","\ua77f":"g","\u24d7":"h","\uff48":"h","\u0125":"h","\u1e23":"h","\u1e27":"h","\u021f":"h","\u1e25":"h","\u1e29":"h","\u1e2b":"h","\u1e96":"h","\u0127":"h","\u2c68":"h","\u2c76":"h","\u0265":"h","\u0195":"hv","\u24d8":"i","\uff49":"i","\xec":"i","\xed":"i","\xee":"i","\u0129":"i","\u012b":"i","\u012d":"i","\xef":"i","\u1e2f":"i","\u1ec9":"i","\u01d0":"i","\u0209":"i","\u020b":"i","\u1ecb":"i","\u012f":"i","\u1e2d":"i","\u0268":"i","\u0131":"i","\u24d9":"j","\uff4a":"j","\u0135":"j","\u01f0":"j","\u0249":"j","\u24da":"k","\uff4b":"k","\u1e31":"k","\u01e9":"k","\u1e33":"k","\u0137":"k","\u1e35":"k","\u0199":"k","\u2c6a":"k","\ua741":"k","\ua743":"k","\ua745":"k","\ua7a3":"k","\u24db":"l","\uff4c":"l","\u0140":"l","\u013a":"l","\u013e":"l","\u1e37":"l","\u1e39":"l","\u013c":"l","\u1e3d":"l","\u1e3b":"l","\u017f":"l","\u0142":"l","\u019a":"l","\u026b":"l","\u2c61":"l","\ua749":"l","\ua781":"l","\ua747":"l","\u01c9":"lj","\u24dc":"m","\uff4d":"m","\u1e3f":"m","\u1e41":"m","\u1e43":"m","\u0271":"m","\u026f":"m","\u24dd":"n","\uff4e":"n","\u01f9":"n","\u0144":"n","\xf1":"n","\u1e45":"n","\u0148":"n","\u1e47":"n","\u0146":"n","\u1e4b":"n","\u1e49":"n","\u019e":"n","\u0272":"n","\u0149":"n","\ua791":"n","\ua7a5":"n","\u01cc":"nj","\u24de":"o","\uff4f":"o","\xf2":"o","\xf3":"o","\xf4":"o","\u1ed3":"o","\u1ed1":"o","\u1ed7":"o","\u1ed5":"o","\xf5":"o","\u1e4d":"o","\u022d":"o","\u1e4f":"o","\u014d":"o","\u1e51":"o","\u1e53":"o","\u014f":"o","\u022f":"o","\u0231":"o","\xf6":"o","\u022b":"o","\u1ecf":"o","\u0151":"o","\u01d2":"o","\u020d":"o","\u020f":"o","\u01a1":"o","\u1edd":"o","\u1edb":"o","\u1ee1":"o","\u1edf":"o","\u1ee3":"o","\u1ecd":"o","\u1ed9":"o","\u01eb":"o","\u01ed":"o","\xf8":"o","\u01ff":"o","\u0254":"o","\ua74b":"o","\ua74d":"o","\u0275":"o","\u01a3":"oi","\u0223":"ou","\ua74f":"oo","\u24df":"p","\uff50":"p","\u1e55":"p","\u1e57":"p","\u01a5":"p","\u1d7d":"p","\ua751":"p","\ua753":"p","\ua755":"p","\u24e0":"q","\uff51":"q","\u024b":"q","\ua757":"q","\ua759":"q","\u24e1":"r","\uff52":"r","\u0155":"r","\u1e59":"r","\u0159":"r","\u0211":"r","\u0213":"r","\u1e5b":"r","\u1e5d":"r","\u0157":"r","\u1e5f":"r","\u024d":"r","\u027d":"r","\ua75b":"r","\ua7a7":"r","\ua783":"r","\u24e2":"s","\uff53":"s","\xdf":"s","\u015b":"s","\u1e65":"s","\u015d":"s","\u1e61":"s","\u0161":"s","\u1e67":"s","\u1e63":"s","\u1e69":"s","\u0219":"s","\u015f":"s","\u023f":"s","\ua7a9":"s","\ua785":"s","\u1e9b":"s","\u24e3":"t","\uff54":"t","\u1e6b":"t","\u1e97":"t","\u0165":"t","\u1e6d":"t","\u021b":"t","\u0163":"t","\u1e71":"t","\u1e6f":"t","\u0167":"t","\u01ad":"t","\u0288":"t","\u2c66":"t","\ua787":"t","\ua729":"tz","\u24e4":"u","\uff55":"u","\xf9":"u","\xfa":"u","\xfb":"u","\u0169":"u","\u1e79":"u","\u016b":"u","\u1e7b":"u","\u016d":"u","\xfc":"u","\u01dc":"u","\u01d8":"u","\u01d6":"u","\u01da":"u","\u1ee7":"u","\u016f":"u","\u0171":"u","\u01d4":"u","\u0215":"u","\u0217":"u","\u01b0":"u","\u1eeb":"u","\u1ee9":"u","\u1eef":"u","\u1eed":"u","\u1ef1":"u","\u1ee5":"u","\u1e73":"u","\u0173":"u","\u1e77":"u","\u1e75":"u","\u0289":"u","\u24e5":"v","\uff56":"v","\u1e7d":"v","\u1e7f":"v","\u028b":"v","\ua75f":"v","\u028c":"v","\ua761":"vy","\u24e6":"w","\uff57":"w","\u1e81":"w","\u1e83":"w","\u0175":"w","\u1e87":"w","\u1e85":"w","\u1e98":"w","\u1e89":"w","\u2c73":"w","\u24e7":"x","\uff58":"x","\u1e8b":"x","\u1e8d":"x","\u24e8":"y","\uff59":"y","\u1ef3":"y","\xfd":"y","\u0177":"y","\u1ef9":"y","\u0233":"y","\u1e8f":"y","\xff":"y","\u1ef7":"y","\u1e99":"y","\u1ef5":"y","\u01b4":"y","\u024f":"y","\u1eff":"y","\u24e9":"z","\uff5a":"z","\u017a":"z","\u1e91":"z","\u017c":"z","\u017e":"z","\u1e93":"z","\u1e95":"z","\u01b6":"z","\u0225":"z","\u0240":"z","\u2c6c":"z","\ua763":"z"};j=a(document),g=function(){var a=1;return function(){return a++}}(),j.on("mousemove",function(a){i.x=a.pageX,i.y=a.pageY}),d=N(Object,{bind:function(a){var b=this;return function(){a.apply(b,arguments)}},init:function(c){var d,e,f=".select2-results";this.opts=c=this.prepareOpts(c),this.id=c.id,c.element.data("select2")!==b&&null!==c.element.data("select2")&&c.element.data("select2").destroy(),this.container=this.createContainer(),this.containerId="s2id_"+(c.element.attr("id")||"autogen"+g()),this.containerSelector="#"+this.containerId.replace(/([;&,\.\+\*\~':"\!\^#$%@\[\]\(\)=>\|])/g,"\\$1"),this.container.attr("id",this.containerId),this.body=w(function(){return c.element.closest("body")}),D(this.container,this.opts.element,this.opts.adaptContainerCssClass),this.container.attr("style",c.element.attr("style")),this.container.css(K(c.containerCss)),this.container.addClass(K(c.containerCssClass)),this.elementTabIndex=this.opts.element.attr("tabindex"),this.opts.element.data("select2",this).attr("tabindex","-1").before(this.container).on("click.select2",A),this.container.data("select2",this),this.dropdown=this.container.find(".select2-drop"),D(this.dropdown,this.opts.element,this.opts.adaptDropdownCssClass),this.dropdown.addClass(K(c.dropdownCssClass)),this.dropdown.data("select2",this),this.dropdown.on("click",A),this.results=d=this.container.find(f),this.search=e=this.container.find("input.select2-input"),this.queryCount=0,this.resultsPage=0,this.context=null,this.initContainer(),this.container.on("click",A),u(this.results),this.dropdown.on("mousemove-filtered touchstart touchmove touchend",f,this.bind(this.highlightUnderEvent)),x(80,this.results),this.dropdown.on("scroll-debounced",f,this.bind(this.loadMoreIfNeeded)),a(this.container).on("change",".select2-input",function(a){a.stopPropagation()}),a(this.dropdown).on("change",".select2-input",function(a){a.stopPropagation()}),a.fn.mousewheel&&d.mousewheel(function(a,b,c,e){var f=d.scrollTop();e>0&&0>=f-e?(d.scrollTop(0),A(a)):0>e&&d.get(0).scrollHeight-d.scrollTop()+e<=d.height()&&(d.scrollTop(d.get(0).scrollHeight-d.height()),A(a))}),t(e),e.on("keyup-change input paste",this.bind(this.updateResults)),e.on("focus",function(){e.addClass("select2-focused")}),e.on("blur",function(){e.removeClass("select2-focused")}),this.dropdown.on("mouseup",f,this.bind(function(b){a(b.target).closest(".select2-result-selectable").length>0&&(this.highlightUnderEvent(b),this.selectHighlighted(b))})),this.dropdown.on("click mouseup mousedown",function(a){a.stopPropagation()}),a.isFunction(this.opts.initSelection)&&(this.initSelection(),this.monitorSource()),null!==c.maximumInputLength&&this.search.attr("maxlength",c.maximumInputLength);var h=c.element.prop("disabled");h===b&&(h=!1),this.enable(!h);var i=c.element.prop("readonly");i===b&&(i=!1),this.readonly(i),k=k||p(),this.autofocus=c.element.prop("autofocus"),c.element.prop("autofocus",!1),this.autofocus&&this.focus(),this.nextSearchTerm=b},destroy:function(){var a=this.opts.element,c=a.data("select2");this.close(),this.propertyObserver&&(delete this.propertyObserver,this.propertyObserver=null),c!==b&&(c.container.remove(),c.dropdown.remove(),a.removeClass("select2-offscreen").removeData("select2").off(".select2").prop("autofocus",this.autofocus||!1),this.elementTabIndex?a.attr({tabindex:this.elementTabIndex}):a.removeAttr("tabindex"),a.show())},optionToData:function(a){return a.is("option")?{id:a.prop("value"),text:a.text(),element:a.get(),css:a.attr("class"),disabled:a.prop("disabled"),locked:q(a.attr("locked"),"locked")||q(a.data("locked"),!0)}:a.is("optgroup")?{text:a.attr("label"),children:[],element:a.get(),css:a.attr("class")}:void 0},prepareOpts:function(c){var d,e,f,g,h=this;if(d=c.element,"select"===d.get(0).tagName.toLowerCase()&&(this.select=e=c.element),e&&a.each(["id","multiple","ajax","query","createSearchChoice","initSelection","data","tags"],function(){if(this in c)throw new Error("Option '"+this+"' is not allowed for Select2 when attached to a <select> element.")}),c=a.extend({},{populateResults:function(d,e,f){var g,i=this.opts.id;g=function(d,e,j){var k,l,m,n,o,p,q,r,s,t;for(d=c.sortResults(d,e,f),k=0,l=d.length;l>k;k+=1)m=d[k],o=m.disabled===!0,n=!o&&i(m)!==b,p=m.children&&m.children.length>0,q=a("<li></li>"),q.addClass("select2-results-dept-"+j),q.addClass("select2-result"),q.addClass(n?"select2-result-selectable":"select2-result-unselectable"),o&&q.addClass("select2-disabled"),p&&q.addClass("select2-result-with-children"),q.addClass(h.opts.formatResultCssClass(m)),r=a(document.createElement("div")),r.addClass("select2-result-label"),t=c.formatResult(m,r,f,h.opts.escapeMarkup),t!==b&&r.html(t),q.append(r),p&&(s=a("<ul></ul>"),s.addClass("select2-result-sub"),g(m.children,s,j+1),q.append(s)),q.data("select2-data",m),e.append(q)},g(e,d,0)}},a.fn.select2.defaults,c),"function"!=typeof c.id&&(f=c.id,c.id=function(a){return a[f]}),a.isArray(c.element.data("select2Tags"))){if("tags"in c)throw"tags specified as both an attribute 'data-select2-tags' and in options of Select2 "+c.element.attr("id");c.tags=c.element.data("select2Tags")}if(e?(c.query=this.bind(function(a){var f,g,i,c={results:[],more:!1},e=a.term;i=function(b,c){var d;b.is("option")?a.matcher(e,b.text(),b)&&c.push(h.optionToData(b)):b.is("optgroup")&&(d=h.optionToData(b),b.children().each2(function(a,b){i(b,d.children)}),d.children.length>0&&c.push(d))},f=d.children(),this.getPlaceholder()!==b&&f.length>0&&(g=this.getPlaceholderOption(),g&&(f=f.not(g))),f.each2(function(a,b){i(b,c.results)}),a.callback(c)}),c.id=function(a){return a.id},c.formatResultCssClass=function(a){return a.css}):"query"in c||("ajax"in c?(g=c.element.data("ajax-url"),g&&g.length>0&&(c.ajax.url=g),c.query=G.call(c.element,c.ajax)):"data"in c?c.query=H(c.data):"tags"in c&&(c.query=I(c.tags),c.createSearchChoice===b&&(c.createSearchChoice=function(b){return{id:a.trim(b),text:a.trim(b)}}),c.initSelection===b&&(c.initSelection=function(b,d){var e=[];a(r(b.val(),c.separator)).each(function(){var b={id:this,text:this},d=c.tags;a.isFunction(d)&&(d=d()),a(d).each(function(){return q(this.id,b.id)?(b=this,!1):void 0}),e.push(b)}),d(e)}))),"function"!=typeof c.query)throw"query function not defined for Select2 "+c.element.attr("id");return c},monitorSource:function(){var c,d,a=this.opts.element;a.on("change.select2",this.bind(function(){this.opts.element.data("select2-change-triggered")!==!0&&this.initSelection()})),c=this.bind(function(){var c=a.prop("disabled");c===b&&(c=!1),this.enable(!c);var d=a.prop("readonly");d===b&&(d=!1),this.readonly(d),D(this.container,this.opts.element,this.opts.adaptContainerCssClass),this.container.addClass(K(this.opts.containerCssClass)),D(this.dropdown,this.opts.element,this.opts.adaptDropdownCssClass),this.dropdown.addClass(K(this.opts.dropdownCssClass))}),a.on("propertychange.select2",c),this.mutationCallback===b&&(this.mutationCallback=function(a){a.forEach(c)}),d=window.MutationObserver||window.WebKitMutationObserver||window.MozMutationObserver,d!==b&&(this.propertyObserver&&(delete this.propertyObserver,this.propertyObserver=null),this.propertyObserver=new d(this.mutationCallback),this.propertyObserver.observe(a.get(0),{attributes:!0,subtree:!1}))},triggerSelect:function(b){var c=a.Event("select2-selecting",{val:this.id(b),object:b});return this.opts.element.trigger(c),!c.isDefaultPrevented()},triggerChange:function(b){b=b||{},b=a.extend({},b,{type:"change",val:this.val()}),this.opts.element.data("select2-change-triggered",!0),this.opts.element.trigger(b),this.opts.element.data("select2-change-triggered",!1),this.opts.element.click(),this.opts.blurOnChange&&this.opts.element.blur()},isInterfaceEnabled:function(){return this.enabledInterface===!0},enableInterface:function(){var a=this._enabled&&!this._readonly,b=!a;return a===this.enabledInterface?!1:(this.container.toggleClass("select2-container-disabled",b),this.close(),this.enabledInterface=a,!0)},enable:function(a){a===b&&(a=!0),this._enabled!==a&&(this._enabled=a,this.opts.element.prop("disabled",!a),this.enableInterface())},disable:function(){this.enable(!1)},readonly:function(a){return a===b&&(a=!1),this._readonly===a?!1:(this._readonly=a,this.opts.element.prop("readonly",a),this.enableInterface(),!0)},opened:function(){return this.container.hasClass("select2-dropdown-open")},positionDropdown:function(){var t,u,v,w,x,b=this.dropdown,c=this.container.offset(),d=this.container.outerHeight(!1),e=this.container.outerWidth(!1),f=b.outerHeight(!1),g=a(window),h=g.width(),i=g.height(),j=g.scrollLeft()+h,l=g.scrollTop()+i,m=c.top+d,n=c.left,o=l>=m+f,p=c.top-f>=this.body().scrollTop(),q=b.outerWidth(!1),r=j>=n+q,s=b.hasClass("select2-drop-above");s?(u=!0,!p&&o&&(v=!0,u=!1)):(u=!1,!o&&p&&(v=!0,u=!0)),v&&(b.hide(),c=this.container.offset(),d=this.container.outerHeight(!1),e=this.container.outerWidth(!1),f=b.outerHeight(!1),j=g.scrollLeft()+h,l=g.scrollTop()+i,m=c.top+d,n=c.left,q=b.outerWidth(!1),r=j>=n+q,b.show()),this.opts.dropdownAutoWidth?(x=a(".select2-results",b)[0],b.addClass("select2-drop-auto-width"),b.css("width",""),q=b.outerWidth(!1)+(x.scrollHeight===x.clientHeight?0:k.width),q>e?e=q:q=e,r=j>=n+q):this.container.removeClass("select2-drop-auto-width"),"static"!==this.body().css("position")&&(t=this.body().offset(),m-=t.top,n-=t.left),r||(n=c.left+e-q),w={left:n,width:e},u?(w.bottom=i-c.top,w.top="auto",this.container.addClass("select2-drop-above"),b.addClass("select2-drop-above")):(w.top=m,w.bottom="auto",this.container.removeClass("select2-drop-above"),b.removeClass("select2-drop-above")),w=a.extend(w,K(this.opts.dropdownCss)),b.css(w)},shouldOpen:function(){var b;return this.opened()?!1:this._enabled===!1||this._readonly===!0?!1:(b=a.Event("select2-opening"),this.opts.element.trigger(b),!b.isDefaultPrevented())},clearDropdownAlignmentPreference:function(){this.container.removeClass("select2-drop-above"),this.dropdown.removeClass("select2-drop-above")},open:function(){return this.shouldOpen()?(this.opening(),!0):!1},opening:function(){var f,b=this.containerId,c="scroll."+b,d="resize."+b,e="orientationchange."+b;this.container.addClass("select2-dropdown-open").addClass("select2-container-active"),this.clearDropdownAlignmentPreference(),this.dropdown[0]!==this.body().children().last()[0]&&this.dropdown.detach().appendTo(this.body()),f=a("#select2-drop-mask"),0==f.length&&(f=a(document.createElement("div")),f.attr("id","select2-drop-mask").attr("class","select2-drop-mask"),f.hide(),f.appendTo(this.body()),f.on("mousedown touchstart click",function(b){var d,c=a("#select2-drop");c.length>0&&(d=c.data("select2"),d.opts.selectOnBlur&&d.selectHighlighted({noFocus:!0}),d.close({focus:!0}),b.preventDefault(),b.stopPropagation())})),this.dropdown.prev()[0]!==f[0]&&this.dropdown.before(f),a("#select2-drop").removeAttr("id"),this.dropdown.attr("id","select2-drop"),f.show(),this.positionDropdown(),this.dropdown.show(),this.positionDropdown(),this.dropdown.addClass("select2-drop-active");var g=this;this.container.parents().add(window).each(function(){a(this).on(d+" "+c+" "+e,function(){g.positionDropdown()})})},close:function(){if(this.opened()){var b=this.containerId,c="scroll."+b,d="resize."+b,e="orientationchange."+b;this.container.parents().add(window).each(function(){a(this).off(c).off(d).off(e)}),this.clearDropdownAlignmentPreference(),a("#select2-drop-mask").hide(),this.dropdown.removeAttr("id"),this.dropdown.hide(),this.container.removeClass("select2-dropdown-open").removeClass("select2-container-active"),this.results.empty(),this.clearSearch(),this.search.removeClass("select2-active"),this.opts.element.trigger(a.Event("select2-close"))}},externalSearch:function(a){this.open(),this.search.val(a),this.updateResults(!1)},clearSearch:function(){},getMaximumSelectionSize:function(){return K(this.opts.maximumSelectionSize)},ensureHighlightVisible:function(){var c,d,e,f,g,h,i,b=this.results;if(d=this.highlight(),!(0>d)){if(0==d)return b.scrollTop(0),void 0;c=this.findHighlightableChoices().find(".select2-result-label"),e=a(c[d]),f=e.offset().top+e.outerHeight(!0),d===c.length-1&&(i=b.find("li.select2-more-results"),i.length>0&&(f=i.offset().top+i.outerHeight(!0))),g=b.offset().top+b.outerHeight(!0),f>g&&b.scrollTop(b.scrollTop()+(f-g)),h=e.offset().top-b.offset().top,0>h&&"none"!=e.css("display")&&b.scrollTop(b.scrollTop()+h)}},findHighlightableChoices:function(){return this.results.find(".select2-result-selectable:not(.select2-disabled, .select2-selected)")},moveHighlight:function(b){for(var c=this.findHighlightableChoices(),d=this.highlight();d>-1&&d<c.length;){d+=b;var e=a(c[d]);if(e.hasClass("select2-result-selectable")&&!e.hasClass("select2-disabled")&&!e.hasClass("select2-selected")){this.highlight(d);break}}},highlight:function(b){var d,e,c=this.findHighlightableChoices();return 0===arguments.length?o(c.filter(".select2-highlighted")[0],c.get()):(b>=c.length&&(b=c.length-1),0>b&&(b=0),this.removeHighlight(),d=a(c[b]),d.addClass("select2-highlighted"),this.ensureHighlightVisible(),e=d.data("select2-data"),e&&this.opts.element.trigger({type:"select2-highlight",val:this.id(e),choice:e}),void 0)},removeHighlight:function(){this.results.find(".select2-highlighted").removeClass("select2-highlighted")},countSelectableResults:function(){return this.findHighlightableChoices().length},highlightUnderEvent:function(b){var c=a(b.target).closest(".select2-result-selectable");if(c.length>0&&!c.is(".select2-highlighted")){var d=this.findHighlightableChoices();this.highlight(d.index(c))}else 0==c.length&&this.removeHighlight()},loadMoreIfNeeded:function(){var c,a=this.results,b=a.find("li.select2-more-results"),d=this.resultsPage+1,e=this,f=this.search.val(),g=this.context;0!==b.length&&(c=b.offset().top-a.offset().top-a.height(),c<=this.opts.loadMorePadding&&(b.addClass("select2-active"),this.opts.query({element:this.opts.element,term:f,page:d,context:g,matcher:this.opts.matcher,callback:this.bind(function(c){e.opened()&&(e.opts.populateResults.call(this,a,c.results,{term:f,page:d,context:g}),e.postprocessResults(c,!1,!1),c.more===!0?(b.detach().appendTo(a).text(e.opts.formatLoadMore(d+1)),window.setTimeout(function(){e.loadMoreIfNeeded()},10)):b.remove(),e.positionDropdown(),e.resultsPage=d,e.context=c.context,this.opts.element.trigger({type:"select2-loaded",items:c}))})})))},tokenize:function(){},updateResults:function(c){function m(){d.removeClass("select2-active"),h.positionDropdown()}function n(a){e.html(a),m()}var g,i,l,d=this.search,e=this.results,f=this.opts,h=this,j=d.val(),k=a.data(this.container,"select2-last-term");if((c===!0||!k||!q(j,k))&&(a.data(this.container,"select2-last-term",j),c===!0||this.showSearchInput!==!1&&this.opened())){l=++this.queryCount;var o=this.getMaximumSelectionSize();if(o>=1&&(g=this.data(),a.isArray(g)&&g.length>=o&&J(f.formatSelectionTooBig,"formatSelectionTooBig")))return n("<li class='select2-selection-limit'>"+f.formatSelectionTooBig(o)+"</li>"),void 0;if(d.val().length<f.minimumInputLength)return J(f.formatInputTooShort,"formatInputTooShort")?n("<li class='select2-no-results'>"+f.formatInputTooShort(d.val(),f.minimumInputLength)+"</li>"):n(""),c&&this.showSearch&&this.showSearch(!0),void 0;
if(f.maximumInputLength&&d.val().length>f.maximumInputLength)return J(f.formatInputTooLong,"formatInputTooLong")?n("<li class='select2-no-results'>"+f.formatInputTooLong(d.val(),f.maximumInputLength)+"</li>"):n(""),void 0;f.formatSearching&&0===this.findHighlightableChoices().length&&n("<li class='select2-searching'>"+f.formatSearching()+"</li>"),d.addClass("select2-active"),this.removeHighlight(),i=this.tokenize(),i!=b&&null!=i&&d.val(i),this.resultsPage=1,f.query({element:f.element,term:d.val(),page:this.resultsPage,context:null,matcher:f.matcher,callback:this.bind(function(g){var i;if(l==this.queryCount){if(!this.opened())return this.search.removeClass("select2-active"),void 0;if(this.context=g.context===b?null:g.context,this.opts.createSearchChoice&&""!==d.val()&&(i=this.opts.createSearchChoice.call(h,d.val(),g.results),i!==b&&null!==i&&h.id(i)!==b&&null!==h.id(i)&&0===a(g.results).filter(function(){return q(h.id(this),h.id(i))}).length&&g.results.unshift(i)),0===g.results.length&&J(f.formatNoMatches,"formatNoMatches"))return n("<li class='select2-no-results'>"+f.formatNoMatches(d.val())+"</li>"),void 0;e.empty(),h.opts.populateResults.call(this,e,g.results,{term:d.val(),page:this.resultsPage,context:null}),g.more===!0&&J(f.formatLoadMore,"formatLoadMore")&&(e.append("<li class='select2-more-results'>"+h.opts.escapeMarkup(f.formatLoadMore(this.resultsPage))+"</li>"),window.setTimeout(function(){h.loadMoreIfNeeded()},10)),this.postprocessResults(g,c),m(),this.opts.element.trigger({type:"select2-loaded",items:g})}})})}},cancel:function(){this.close()},blur:function(){this.opts.selectOnBlur&&this.selectHighlighted({noFocus:!0}),this.close(),this.container.removeClass("select2-container-active"),this.search[0]===document.activeElement&&this.search.blur(),this.clearSearch(),this.selection.find(".select2-search-choice-focus").removeClass("select2-search-choice-focus")},focusSearch:function(){y(this.search)},selectHighlighted:function(a){var b=this.highlight(),c=this.results.find(".select2-highlighted"),d=c.closest(".select2-result").data("select2-data");d?(this.highlight(b),this.onSelect(d,a)):a&&a.noFocus&&this.close()},getPlaceholder:function(){var a;return this.opts.element.attr("placeholder")||this.opts.element.attr("data-placeholder")||this.opts.element.data("placeholder")||this.opts.placeholder||((a=this.getPlaceholderOption())!==b?a.text():b)},getPlaceholderOption:function(){if(this.select){var a=this.select.children("option").first();if(this.opts.placeholderOption!==b)return"first"===this.opts.placeholderOption&&a||"function"==typeof this.opts.placeholderOption&&this.opts.placeholderOption(this.select);if(""===a.text()&&""===a.val())return a}},initContainerWidth:function(){function c(){var c,d,e,f,g,h;if("off"===this.opts.width)return null;if("element"===this.opts.width)return 0===this.opts.element.outerWidth(!1)?"auto":this.opts.element.outerWidth(!1)+"px";if("copy"===this.opts.width||"resolve"===this.opts.width){if(c=this.opts.element.attr("style"),c!==b)for(d=c.split(";"),f=0,g=d.length;g>f;f+=1)if(h=d[f].replace(/\s/g,""),e=h.match(/^width:(([-+]?([0-9]*\.)?[0-9]+)(px|em|ex|%|in|cm|mm|pt|pc))/i),null!==e&&e.length>=1)return e[1];return"resolve"===this.opts.width?(c=this.opts.element.css("width"),c.indexOf("%")>0?c:0===this.opts.element.outerWidth(!1)?"auto":this.opts.element.outerWidth(!1)+"px"):null}return a.isFunction(this.opts.width)?this.opts.width():this.opts.width}var d=c.call(this);null!==d&&this.container.css("width",d)}}),e=N(d,{createContainer:function(){var b=a(document.createElement("div")).attr({"class":"select2-container"}).html(["<a href='javascript:void(0)' onclick='return false;' class='select2-choice' tabindex='-1'>","   <span class='select2-chosen'>&nbsp;</span><abbr class='select2-search-choice-close'></abbr>","   <span class='select2-arrow'><b></b></span>","</a>","<input class='select2-focusser select2-offscreen' type='text'/>","<div class='select2-drop select2-display-none'>","   <div class='select2-search'>","       <input type='text' autocomplete='off' autocorrect='off' autocapitalize='off' spellcheck='false' class='select2-input'/>","   </div>","   <ul class='select2-results'>","   </ul>","</div>"].join(""));return b},enableInterface:function(){this.parent.enableInterface.apply(this,arguments)&&this.focusser.prop("disabled",!this.isInterfaceEnabled())},opening:function(){var c,d,e;this.opts.minimumResultsForSearch>=0&&this.showSearch(!0),this.parent.opening.apply(this,arguments),this.showSearchInput!==!1&&this.search.val(this.focusser.val()),this.search.focus(),c=this.search.get(0),c.createTextRange?(d=c.createTextRange(),d.collapse(!1),d.select()):c.setSelectionRange&&(e=this.search.val().length,c.setSelectionRange(e,e)),""===this.search.val()&&this.nextSearchTerm!=b&&(this.search.val(this.nextSearchTerm),this.search.select()),this.focusser.prop("disabled",!0).val(""),this.updateResults(!0),this.opts.element.trigger(a.Event("select2-open"))},close:function(a){this.opened()&&(this.parent.close.apply(this,arguments),a=a||{focus:!0},this.focusser.removeAttr("disabled"),a.focus&&this.focusser.focus())},focus:function(){this.opened()?this.close():(this.focusser.removeAttr("disabled"),this.focusser.focus())},isFocused:function(){return this.container.hasClass("select2-container-active")},cancel:function(){this.parent.cancel.apply(this,arguments),this.focusser.removeAttr("disabled"),this.focusser.focus()},destroy:function(){a("label[for='"+this.focusser.attr("id")+"']").attr("for",this.opts.element.attr("id")),this.parent.destroy.apply(this,arguments)},initContainer:function(){var b,d=this.container,e=this.dropdown;this.opts.minimumResultsForSearch<0?this.showSearch(!1):this.showSearch(!0),this.selection=b=d.find(".select2-choice"),this.focusser=d.find(".select2-focusser"),this.focusser.attr("id","s2id_autogen"+g()),a("label[for='"+this.opts.element.attr("id")+"']").attr("for",this.focusser.attr("id")),this.focusser.attr("tabindex",this.elementTabIndex),this.search.on("keydown",this.bind(function(a){if(this.isInterfaceEnabled()){if(a.which===c.PAGE_UP||a.which===c.PAGE_DOWN)return A(a),void 0;switch(a.which){case c.UP:case c.DOWN:return this.moveHighlight(a.which===c.UP?-1:1),A(a),void 0;case c.ENTER:return this.selectHighlighted(),A(a),void 0;case c.TAB:return this.selectHighlighted({noFocus:!0}),void 0;case c.ESC:return this.cancel(a),A(a),void 0}}})),this.search.on("blur",this.bind(function(){document.activeElement===this.body().get(0)&&window.setTimeout(this.bind(function(){this.search.focus()}),0)})),this.focusser.on("keydown",this.bind(function(a){if(this.isInterfaceEnabled()&&a.which!==c.TAB&&!c.isControl(a)&&!c.isFunctionKey(a)&&a.which!==c.ESC){if(this.opts.openOnEnter===!1&&a.which===c.ENTER)return A(a),void 0;if(a.which==c.DOWN||a.which==c.UP||a.which==c.ENTER&&this.opts.openOnEnter){if(a.altKey||a.ctrlKey||a.shiftKey||a.metaKey)return;return this.open(),A(a),void 0}return a.which==c.DELETE||a.which==c.BACKSPACE?(this.opts.allowClear&&this.clear(),A(a),void 0):void 0}})),t(this.focusser),this.focusser.on("keyup-change input",this.bind(function(a){if(this.opts.minimumResultsForSearch>=0){if(a.stopPropagation(),this.opened())return;this.open()}})),b.on("mousedown","abbr",this.bind(function(a){this.isInterfaceEnabled()&&(this.clear(),B(a),this.close(),this.selection.focus())})),b.on("mousedown",this.bind(function(b){this.container.hasClass("select2-container-active")||this.opts.element.trigger(a.Event("select2-focus")),this.opened()?this.close():this.isInterfaceEnabled()&&this.open(),A(b)})),e.on("mousedown",this.bind(function(){this.search.focus()})),b.on("focus",this.bind(function(a){A(a)})),this.focusser.on("focus",this.bind(function(){this.container.hasClass("select2-container-active")||this.opts.element.trigger(a.Event("select2-focus")),this.container.addClass("select2-container-active")})).on("blur",this.bind(function(){this.opened()||(this.container.removeClass("select2-container-active"),this.opts.element.trigger(a.Event("select2-blur")))})),this.search.on("focus",this.bind(function(){this.container.hasClass("select2-container-active")||this.opts.element.trigger(a.Event("select2-focus")),this.container.addClass("select2-container-active")})),this.initContainerWidth(),this.opts.element.addClass("select2-offscreen"),this.setPlaceholder()},clear:function(b){var c=this.selection.data("select2-data");if(c){var d=a.Event("select2-clearing");if(this.opts.element.trigger(d),d.isDefaultPrevented())return;var e=this.getPlaceholderOption();this.opts.element.val(e?e.val():""),this.selection.find(".select2-chosen").empty(),this.selection.removeData("select2-data"),this.setPlaceholder(),b!==!1&&(this.opts.element.trigger({type:"select2-removed",val:this.id(c),choice:c}),this.triggerChange({removed:c}))}},initSelection:function(){if(this.isPlaceholderOptionSelected())this.updateSelection(null),this.close(),this.setPlaceholder();else{var c=this;this.opts.initSelection.call(null,this.opts.element,function(a){a!==b&&null!==a&&(c.updateSelection(a),c.close(),c.setPlaceholder())})}},isPlaceholderOptionSelected:function(){var a;return this.getPlaceholder()?(a=this.getPlaceholderOption())!==b&&a.prop("selected")||""===this.opts.element.val()||this.opts.element.val()===b||null===this.opts.element.val():!1},prepareOpts:function(){var b=this.parent.prepareOpts.apply(this,arguments),c=this;return"select"===b.element.get(0).tagName.toLowerCase()?b.initSelection=function(a,b){var d=a.find("option").filter(function(){return this.selected});b(c.optionToData(d))}:"data"in b&&(b.initSelection=b.initSelection||function(c,d){var e=c.val(),f=null;b.query({matcher:function(a,c,d){var g=q(e,b.id(d));return g&&(f=d),g},callback:a.isFunction(d)?function(){d(f)}:a.noop})}),b},getPlaceholder:function(){return this.select&&this.getPlaceholderOption()===b?b:this.parent.getPlaceholder.apply(this,arguments)},setPlaceholder:function(){var a=this.getPlaceholder();if(this.isPlaceholderOptionSelected()&&a!==b){if(this.select&&this.getPlaceholderOption()===b)return;this.selection.find(".select2-chosen").html(this.opts.escapeMarkup(a)),this.selection.addClass("select2-default"),this.container.removeClass("select2-allowclear")}},postprocessResults:function(a,b,c){var d=0,e=this;if(this.findHighlightableChoices().each2(function(a,b){return q(e.id(b.data("select2-data")),e.opts.element.val())?(d=a,!1):void 0}),c!==!1&&(b===!0&&d>=0?this.highlight(d):this.highlight(0)),b===!0){var g=this.opts.minimumResultsForSearch;g>=0&&this.showSearch(L(a.results)>=g)}},showSearch:function(b){this.showSearchInput!==b&&(this.showSearchInput=b,this.dropdown.find(".select2-search").toggleClass("select2-search-hidden",!b),this.dropdown.find(".select2-search").toggleClass("select2-offscreen",!b),a(this.dropdown,this.container).toggleClass("select2-with-searchbox",b))},onSelect:function(a,b){if(this.triggerSelect(a)){var c=this.opts.element.val(),d=this.data();this.opts.element.val(this.id(a)),this.updateSelection(a),this.opts.element.trigger({type:"select2-selected",val:this.id(a),choice:a}),this.nextSearchTerm=this.opts.nextSearchTerm(a,this.search.val()),this.close(),b&&b.noFocus||this.focusser.focus(),q(c,this.id(a))||this.triggerChange({added:a,removed:d})}},updateSelection:function(a){var d,e,c=this.selection.find(".select2-chosen");this.selection.data("select2-data",a),c.empty(),null!==a&&(d=this.opts.formatSelection(a,c,this.opts.escapeMarkup)),d!==b&&c.append(d),e=this.opts.formatSelectionCssClass(a,c),e!==b&&c.addClass(e),this.selection.removeClass("select2-default"),this.opts.allowClear&&this.getPlaceholder()!==b&&this.container.addClass("select2-allowclear")},val:function(){var a,c=!1,d=null,e=this,f=this.data();if(0===arguments.length)return this.opts.element.val();if(a=arguments[0],arguments.length>1&&(c=arguments[1]),this.select)this.select.val(a).find("option").filter(function(){return this.selected}).each2(function(a,b){return d=e.optionToData(b),!1}),this.updateSelection(d),this.setPlaceholder(),c&&this.triggerChange({added:d,removed:f});else{if(!a&&0!==a)return this.clear(c),void 0;if(this.opts.initSelection===b)throw new Error("cannot call val() if initSelection() is not defined");this.opts.element.val(a),this.opts.initSelection(this.opts.element,function(a){e.opts.element.val(a?e.id(a):""),e.updateSelection(a),e.setPlaceholder(),c&&e.triggerChange({added:a,removed:f})})}},clearSearch:function(){this.search.val(""),this.focusser.val("")},data:function(a){var c,d=!1;return 0===arguments.length?(c=this.selection.data("select2-data"),c==b&&(c=null),c):(arguments.length>1&&(d=arguments[1]),a?(c=this.data(),this.opts.element.val(a?this.id(a):""),this.updateSelection(a),d&&this.triggerChange({added:a,removed:c})):this.clear(d),void 0)}}),f=N(d,{createContainer:function(){var b=a(document.createElement("div")).attr({"class":"select2-container select2-container-multi"}).html(["<ul class='select2-choices'>","  <li class='select2-search-field'>","    <input type='text' autocomplete='off' autocorrect='off' autocapitalize='off' spellcheck='false' class='select2-input'>","  </li>","</ul>","<div class='select2-drop select2-drop-multi select2-display-none'>","   <ul class='select2-results'>","   </ul>","</div>"].join(""));return b},prepareOpts:function(){var b=this.parent.prepareOpts.apply(this,arguments),c=this;return"select"===b.element.get(0).tagName.toLowerCase()?b.initSelection=function(a,b){var d=[];a.find("option").filter(function(){return this.selected}).each2(function(a,b){d.push(c.optionToData(b))}),b(d)}:"data"in b&&(b.initSelection=b.initSelection||function(c,d){var e=r(c.val(),b.separator),f=[];b.query({matcher:function(c,d,g){var h=a.grep(e,function(a){return q(a,b.id(g))}).length;return h&&f.push(g),h},callback:a.isFunction(d)?function(){for(var a=[],c=0;c<e.length;c++)for(var g=e[c],h=0;h<f.length;h++){var i=f[h];if(q(g,b.id(i))){a.push(i),f.splice(h,1);break}}d(a)}:a.noop})}),b},selectChoice:function(a){var b=this.container.find(".select2-search-choice-focus");b.length&&a&&a[0]==b[0]||(b.length&&this.opts.element.trigger("choice-deselected",b),b.removeClass("select2-search-choice-focus"),a&&a.length&&(this.close(),a.addClass("select2-search-choice-focus"),this.opts.element.trigger("choice-selected",a)))},destroy:function(){a("label[for='"+this.search.attr("id")+"']").attr("for",this.opts.element.attr("id")),this.parent.destroy.apply(this,arguments)},initContainer:function(){var d,b=".select2-choices";this.searchContainer=this.container.find(".select2-search-field"),this.selection=d=this.container.find(b);var e=this;this.selection.on("click",".select2-search-choice:not(.select2-locked)",function(){e.search[0].focus(),e.selectChoice(a(this))}),this.search.attr("id","s2id_autogen"+g()),a("label[for='"+this.opts.element.attr("id")+"']").attr("for",this.search.attr("id")),this.search.on("input paste",this.bind(function(){this.isInterfaceEnabled()&&(this.opened()||this.open())})),this.search.attr("tabindex",this.elementTabIndex),this.keydowns=0,this.search.on("keydown",this.bind(function(a){if(this.isInterfaceEnabled()){++this.keydowns;var b=d.find(".select2-search-choice-focus"),e=b.prev(".select2-search-choice:not(.select2-locked)"),f=b.next(".select2-search-choice:not(.select2-locked)"),g=z(this.search);if(b.length&&(a.which==c.LEFT||a.which==c.RIGHT||a.which==c.BACKSPACE||a.which==c.DELETE||a.which==c.ENTER)){var h=b;return a.which==c.LEFT&&e.length?h=e:a.which==c.RIGHT?h=f.length?f:null:a.which===c.BACKSPACE?(this.unselect(b.first()),this.search.width(10),h=e.length?e:f):a.which==c.DELETE?(this.unselect(b.first()),this.search.width(10),h=f.length?f:null):a.which==c.ENTER&&(h=null),this.selectChoice(h),A(a),h&&h.length||this.open(),void 0}if((a.which===c.BACKSPACE&&1==this.keydowns||a.which==c.LEFT)&&0==g.offset&&!g.length)return this.selectChoice(d.find(".select2-search-choice:not(.select2-locked)").last()),A(a),void 0;if(this.selectChoice(null),this.opened())switch(a.which){case c.UP:case c.DOWN:return this.moveHighlight(a.which===c.UP?-1:1),A(a),void 0;case c.ENTER:return this.selectHighlighted(),A(a),void 0;case c.TAB:return this.selectHighlighted({noFocus:!0}),this.close(),void 0;case c.ESC:return this.cancel(a),A(a),void 0}if(a.which!==c.TAB&&!c.isControl(a)&&!c.isFunctionKey(a)&&a.which!==c.BACKSPACE&&a.which!==c.ESC){if(a.which===c.ENTER){if(this.opts.openOnEnter===!1)return;if(a.altKey||a.ctrlKey||a.shiftKey||a.metaKey)return}this.open(),(a.which===c.PAGE_UP||a.which===c.PAGE_DOWN)&&A(a),a.which===c.ENTER&&A(a)}}})),this.search.on("keyup",this.bind(function(){this.keydowns=0,this.resizeSearch()})),this.search.on("blur",this.bind(function(b){this.container.removeClass("select2-container-active"),this.search.removeClass("select2-focused"),this.selectChoice(null),this.opened()||this.clearSearch(),b.stopImmediatePropagation(),this.opts.element.trigger(a.Event("select2-blur"))})),this.container.on("click",b,this.bind(function(b){this.isInterfaceEnabled()&&(a(b.target).closest(".select2-search-choice").length>0||(this.selectChoice(null),this.clearPlaceholder(),this.container.hasClass("select2-container-active")||this.opts.element.trigger(a.Event("select2-focus")),this.open(),this.focusSearch(),b.preventDefault()))})),this.container.on("focus",b,this.bind(function(){this.isInterfaceEnabled()&&(this.container.hasClass("select2-container-active")||this.opts.element.trigger(a.Event("select2-focus")),this.container.addClass("select2-container-active"),this.dropdown.addClass("select2-drop-active"),this.clearPlaceholder())})),this.initContainerWidth(),this.opts.element.addClass("select2-offscreen"),this.clearSearch()},enableInterface:function(){this.parent.enableInterface.apply(this,arguments)&&this.search.prop("disabled",!this.isInterfaceEnabled())},initSelection:function(){if(""===this.opts.element.val()&&""===this.opts.element.text()&&(this.updateSelection([]),this.close(),this.clearSearch()),this.select||""!==this.opts.element.val()){var c=this;this.opts.initSelection.call(null,this.opts.element,function(a){a!==b&&null!==a&&(c.updateSelection(a),c.close(),c.clearSearch())})}},clearSearch:function(){var a=this.getPlaceholder(),c=this.getMaxSearchWidth();a!==b&&0===this.getVal().length&&this.search.hasClass("select2-focused")===!1?(this.search.val(a).addClass("select2-default"),this.search.width(c>0?c:this.container.css("width"))):this.search.val("").width(10)},clearPlaceholder:function(){this.search.hasClass("select2-default")&&this.search.val("").removeClass("select2-default")},opening:function(){this.clearPlaceholder(),this.resizeSearch(),this.parent.opening.apply(this,arguments),this.focusSearch(),this.updateResults(!0),this.search.focus(),this.opts.element.trigger(a.Event("select2-open"))},close:function(){this.opened()&&this.parent.close.apply(this,arguments)},focus:function(){this.close(),this.search.focus()},isFocused:function(){return this.search.hasClass("select2-focused")},updateSelection:function(b){var c=[],d=[],e=this;a(b).each(function(){o(e.id(this),c)<0&&(c.push(e.id(this)),d.push(this))}),b=d,this.selection.find(".select2-search-choice").remove(),a(b).each(function(){e.addSelectedChoice(this)}),e.postprocessResults()},tokenize:function(){var a=this.search.val();a=this.opts.tokenizer.call(this,a,this.data(),this.bind(this.onSelect),this.opts),null!=a&&a!=b&&(this.search.val(a),a.length>0&&this.open())},onSelect:function(a,b){this.triggerSelect(a)&&(this.addSelectedChoice(a),this.opts.element.trigger({type:"selected",val:this.id(a),choice:a}),(this.select||!this.opts.closeOnSelect)&&this.postprocessResults(a,!1,this.opts.closeOnSelect===!0),this.opts.closeOnSelect?(this.close(),this.search.width(10)):this.countSelectableResults()>0?(this.search.width(10),this.resizeSearch(),this.getMaximumSelectionSize()>0&&this.val().length>=this.getMaximumSelectionSize()&&this.updateResults(!0),this.positionDropdown()):(this.close(),this.search.width(10)),this.triggerChange({added:a}),b&&b.noFocus||this.focusSearch())},cancel:function(){this.close(),this.focusSearch()},addSelectedChoice:function(c){var j,k,d=!c.locked,e=a("<li class='select2-search-choice'>    <div></div>    <a href='#' onclick='return false;' class='select2-search-choice-close' tabindex='-1'></a></li>"),f=a("<li class='select2-search-choice select2-locked'><div></div></li>"),g=d?e:f,h=this.id(c),i=this.getVal();j=this.opts.formatSelection(c,g.find("div"),this.opts.escapeMarkup),j!=b&&g.find("div").replaceWith("<div>"+j+"</div>"),k=this.opts.formatSelectionCssClass(c,g.find("div")),k!=b&&g.addClass(k),d&&g.find(".select2-search-choice-close").on("mousedown",A).on("click dblclick",this.bind(function(b){this.isInterfaceEnabled()&&(a(b.target).closest(".select2-search-choice").fadeOut("fast",this.bind(function(){this.unselect(a(b.target)),this.selection.find(".select2-search-choice-focus").removeClass("select2-search-choice-focus"),this.close(),this.focusSearch()})).dequeue(),A(b))})).on("focus",this.bind(function(){this.isInterfaceEnabled()&&(this.container.addClass("select2-container-active"),this.dropdown.addClass("select2-drop-active"))})),g.data("select2-data",c),g.insertBefore(this.searchContainer),i.push(h),this.setVal(i)},unselect:function(b){var d,e,c=this.getVal();if(b=b.closest(".select2-search-choice"),0===b.length)throw"Invalid argument: "+b+". Must be .select2-search-choice";if(d=b.data("select2-data")){for(;(e=o(this.id(d),c))>=0;)c.splice(e,1),this.setVal(c),this.select&&this.postprocessResults();var f=a.Event("select2-removing");f.val=this.id(d),f.choice=d,this.opts.element.trigger(f),f.isDefaultPrevented()||(b.remove(),this.opts.element.trigger({type:"select2-removed",val:this.id(d),choice:d}),this.triggerChange({removed:d}))}},postprocessResults:function(a,b,c){var d=this.getVal(),e=this.results.find(".select2-result"),f=this.results.find(".select2-result-with-children"),g=this;e.each2(function(a,b){var c=g.id(b.data("select2-data"));o(c,d)>=0&&(b.addClass("select2-selected"),b.find(".select2-result-selectable").addClass("select2-selected"))}),f.each2(function(a,b){b.is(".select2-result-selectable")||0!==b.find(".select2-result-selectable:not(.select2-selected)").length||b.addClass("select2-selected")}),-1==this.highlight()&&c!==!1&&g.highlight(0),!this.opts.createSearchChoice&&!e.filter(".select2-result:not(.select2-selected)").length>0&&(!a||a&&!a.more&&0===this.results.find(".select2-no-results").length)&&J(g.opts.formatNoMatches,"formatNoMatches")&&this.results.append("<li class='select2-no-results'>"+g.opts.formatNoMatches(g.search.val())+"</li>")},getMaxSearchWidth:function(){return this.selection.width()-s(this.search)},resizeSearch:function(){var a,b,c,d,e,f=s(this.search);a=C(this.search)+10,b=this.search.offset().left,c=this.selection.width(),d=this.selection.offset().left,e=c-(b-d)-f,a>e&&(e=c-f),40>e&&(e=c-f),0>=e&&(e=a),this.search.width(Math.floor(e))},getVal:function(){var a;return this.select?(a=this.select.val(),null===a?[]:a):(a=this.opts.element.val(),r(a,this.opts.separator))},setVal:function(b){var c;this.select?this.select.val(b):(c=[],a(b).each(function(){o(this,c)<0&&c.push(this)}),this.opts.element.val(0===c.length?"":c.join(this.opts.separator)))},buildChangeDetails:function(a,b){for(var b=b.slice(0),a=a.slice(0),c=0;c<b.length;c++)for(var d=0;d<a.length;d++)q(this.opts.id(b[c]),this.opts.id(a[d]))&&(b.splice(c,1),c>0&&c--,a.splice(d,1),d--);return{added:b,removed:a}},val:function(c,d){var e,f=this;if(0===arguments.length)return this.getVal();if(e=this.data(),e.length||(e=[]),!c&&0!==c)return this.opts.element.val(""),this.updateSelection([]),this.clearSearch(),d&&this.triggerChange({added:this.data(),removed:e}),void 0;if(this.setVal(c),this.select)this.opts.initSelection(this.select,this.bind(this.updateSelection)),d&&this.triggerChange(this.buildChangeDetails(e,this.data()));else{if(this.opts.initSelection===b)throw new Error("val() cannot be called if initSelection() is not defined");this.opts.initSelection(this.opts.element,function(b){var c=a.map(b,f.id);f.setVal(c),f.updateSelection(b),f.clearSearch(),d&&f.triggerChange(f.buildChangeDetails(e,f.data()))})}this.clearSearch()},onSortStart:function(){if(this.select)throw new Error("Sorting of elements is not supported when attached to <select>. Attach to <input type='hidden'/> instead.");this.search.width(0),this.searchContainer.hide()},onSortEnd:function(){var b=[],c=this;this.searchContainer.show(),this.searchContainer.appendTo(this.searchContainer.parent()),this.resizeSearch(),this.selection.find(".select2-search-choice").each(function(){b.push(c.opts.id(a(this).data("select2-data")))}),this.setVal(b),this.triggerChange()},data:function(b,c){var e,f,d=this;return 0===arguments.length?this.selection.find(".select2-search-choice").map(function(){return a(this).data("select2-data")}).get():(f=this.data(),b||(b=[]),e=a.map(b,function(a){return d.opts.id(a)}),this.setVal(e),this.updateSelection(b),this.clearSearch(),c&&this.triggerChange(this.buildChangeDetails(f,this.data())),void 0)}}),a.fn.select2=function(){var d,g,h,i,j,c=Array.prototype.slice.call(arguments,0),k=["val","destroy","opened","open","close","focus","isFocused","container","dropdown","onSortStart","onSortEnd","enable","disable","readonly","positionDropdown","data","search"],l=["opened","isFocused","container","dropdown"],m=["val","data"],n={search:"externalSearch"};return this.each(function(){if(0===c.length||"object"==typeof c[0])d=0===c.length?{}:a.extend({},c[0]),d.element=a(this),"select"===d.element.get(0).tagName.toLowerCase()?j=d.element.prop("multiple"):(j=d.multiple||!1,"tags"in d&&(d.multiple=j=!0)),g=j?new f:new e,g.init(d);else{if("string"!=typeof c[0])throw"Invalid arguments to select2 plugin: "+c;if(o(c[0],k)<0)throw"Unknown method: "+c[0];if(i=b,g=a(this).data("select2"),g===b)return;if(h=c[0],"container"===h?i=g.container:"dropdown"===h?i=g.dropdown:(n[h]&&(h=n[h]),i=g[h].apply(g,c.slice(1))),o(c[0],l)>=0||o(c[0],m)&&1==c.length)return!1}}),i===b?this:i},a.fn.select2.defaults={width:"copy",loadMorePadding:0,closeOnSelect:!0,openOnEnter:!0,containerCss:{},dropdownCss:{},containerCssClass:"",dropdownCssClass:"",formatResult:function(a,b,c,d){var e=[];return E(a.text,c.term,e,d),e.join("")},formatSelection:function(a,c,d){return a?d(a.text):b},sortResults:function(a){return a},formatResultCssClass:function(){return b},formatSelectionCssClass:function(){return b},formatNoMatches:function(){return"No matches found"},formatInputTooShort:function(a,b){var c=b-a.length;return"Please enter "+c+" more character"+(1==c?"":"s")},formatInputTooLong:function(a,b){var c=a.length-b;return"Please delete "+c+" character"+(1==c?"":"s")},formatSelectionTooBig:function(a){return"You can only select "+a+" item"+(1==a?"":"s")},formatLoadMore:function(){return"Loading more results..."},formatSearching:function(){return"Searching..."},minimumResultsForSearch:0,minimumInputLength:0,maximumInputLength:null,maximumSelectionSize:0,id:function(a){return a.id},matcher:function(a,b){return n(""+b).toUpperCase().indexOf(n(""+a).toUpperCase())>=0},separator:",",tokenSeparators:[],tokenizer:M,escapeMarkup:F,blurOnChange:!1,selectOnBlur:!1,adaptContainerCssClass:function(a){return a},adaptDropdownCssClass:function(){return null},nextSearchTerm:function(){return b}},a.fn.select2.ajaxDefaults={transport:a.ajax,params:{type:"GET",cache:!1,dataType:"json"}},window.Select2={query:{ajax:G,local:H,tags:I},util:{debounce:v,markMatch:E,escapeMarkup:F,stripDiacritics:n},"class":{"abstract":d,single:e,multi:f}}}}(jQuery);;
/**
* autoNumeric.js
* @author: Bob Knothe
* @author: Sokolov Yura
* @version: 1.9.22 - 2014-04-20 GMT 7:00 PM
*
* Created by Robert J. Knothe on 2010-10-25. Please report any bugs to https://github.com/BobKnothe/autoNumeric
* Created by Sokolov Yura on 2010-11-07
*
* Copyright (c) 2011 Robert J. Knothe http://www.decorplanit.com/plugin/
*
* The MIT License (http://www.opensource.org/licenses/mit-license.php)
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
(function ($) {
    "use strict";
    /*jslint browser: true*/
    /*global jQuery: false*/
    /* Cross browser routine for getting selected range/cursor position
     */
    function getElementSelection(that) {
        var position = {};
        if (that.selectionStart === undefined) {
            that.focus();
            var select = document.selection.createRange();
            position.length = select.text.length;
            select.moveStart('character', -that.value.length);
            position.end = select.text.length;
            position.start = position.end - position.length;
        } else {
            position.start = that.selectionStart;
            position.end = that.selectionEnd;
            position.length = position.end - position.start;
        }
        return position;
    }
    /**
     * Cross browser routine for setting selected range/cursor position
     */
    function setElementSelection(that, start, end) {
        if (that.selectionStart === undefined) {
            that.focus();
            var r = that.createTextRange();
            r.collapse(true);
            r.moveEnd('character', end);
            r.moveStart('character', start);
            r.select();
        } else {
            that.selectionStart = start;
            that.selectionEnd = end;
        }
    }
    /**
     * run callbacks in parameters if any
     * any parameter could be a callback:
     * - a function, which invoked with jQuery element, parameters and this parameter name and returns parameter value
     * - a name of function, attached to $(selector).autoNumeric.functionName(){} - which was called previously
     */
    function runCallbacks($this, settings) {
        /**
         * loops through the settings object (option array) to find the following
         * k = option name example k=aNum
         * val = option value example val=0123456789
         */
        $.each(settings, function (k, val) {
            if (typeof val === 'function') {
                settings[k] = val($this, settings, k);
            } else if (typeof $this.autoNumeric[val] === 'function') {
                /**
                 * calls the attached function from the html5 data example: data-a-sign="functionName"
                 */
                settings[k] = $this.autoNumeric[val]($this, settings, k);
            }
        });
    }
    function convertKeyToNumber(settings, key) {
        if (typeof (settings[key]) === 'string') {
            settings[key] *= 1;
        }
    }
    /**
     * Preparing user defined options for further usage
     * merge them with defaults appropriately
     */
    function autoCode($this, settings) {
        runCallbacks($this, settings);
        settings.oEvent = null;
        settings.tagList = ['B', 'CAPTION', 'CITE', 'CODE', 'DD', 'DEL', 'DIV', 'DFN', 'DT', 'EM', 'H1', 'H2', 'H3', 'H4', 'H5', 'H6', 'INS', 'KDB', 'LABEL', 'LI', 'OUTPUT', 'P', 'Q', 'S', 'SAMPLE', 'SPAN', 'STRONG', 'TD', 'TH', 'U', 'VAR'];
        var vmax = settings.vMax.toString().split('.'),
            vmin = (!settings.vMin && settings.vMin !== 0) ? [] : settings.vMin.toString().split('.');
        convertKeyToNumber(settings, 'vMax');
        convertKeyToNumber(settings, 'vMin');
        convertKeyToNumber(settings, 'mDec'); /** set mDec if not defined by user */
        settings.mDec = (settings.mRound === 'CHF') ? '2' : settings.mDec;
        settings.allowLeading = true;
        settings.aNeg = settings.vMin < 0 ? '-' : '';
        vmax[0] = vmax[0].replace('-', '');
        vmin[0] = vmin[0].replace('-', '');
        settings.mInt = Math.max(vmax[0].length, vmin[0].length, 1);
        if (settings.mDec === null) {
            var vmaxLength = 0,
                vminLength = 0;
            if (vmax[1]) {
                vmaxLength = vmax[1].length;
            }
            if (vmin[1]) {
                vminLength = vmin[1].length;
            }
            settings.mDec = Math.max(vmaxLength, vminLength);
        } /** set alternative decimal separator key */
        if (settings.altDec === null && settings.mDec > 0) {
            if (settings.aDec === '.' && settings.aSep !== ',') {
                settings.altDec = ',';
            } else if (settings.aDec === ',' && settings.aSep !== '.') {
                settings.altDec = '.';
            }
        }
        /** cache regexps for autoStrip */
        var aNegReg = settings.aNeg ? '([-\\' + settings.aNeg + ']?)' : '(-?)';
        settings.aNegRegAutoStrip = aNegReg;
        settings.skipFirstAutoStrip = new RegExp(aNegReg + '[^-' + (settings.aNeg ? '\\' + settings.aNeg : '') + '\\' + settings.aDec + '\\d]' + '.*?(\\d|\\' + settings.aDec + '\\d)');
        settings.skipLastAutoStrip = new RegExp('(\\d\\' + settings.aDec + '?)[^\\' + settings.aDec + '\\d]\\D*$');
        var allowed = '-' + settings.aNum + '\\' + settings.aDec;
        settings.allowedAutoStrip = new RegExp('[^' + allowed + ']', 'gi');
        settings.numRegAutoStrip = new RegExp(aNegReg + '(?:\\' + settings.aDec + '?(\\d+\\' + settings.aDec + '\\d+)|(\\d*(?:\\' + settings.aDec + '\\d*)?))');
        return settings;
    }
    /**
     * strip all unwanted characters and leave only a number alert
     */
    function autoStrip(s, settings, strip_zero) {
        if (settings.aSign) { /** remove currency sign */
            while (s.indexOf(settings.aSign) > -1) {
                s = s.replace(settings.aSign, '');
            }
        }
        s = s.replace(settings.skipFirstAutoStrip, '$1$2'); /** first replace anything before digits */
        s = s.replace(settings.skipLastAutoStrip, '$1'); /** then replace anything after digits */
        s = s.replace(settings.allowedAutoStrip, ''); /** then remove any uninterested characters */
        if (settings.altDec) {
            s = s.replace(settings.altDec, settings.aDec);
        } /** get only number string */
        var m = s.match(settings.numRegAutoStrip);
        s = m ? [m[1], m[2], m[3]].join('') : '';
        if ((settings.lZero === 'allow' || settings.lZero === 'keep') && strip_zero !== 'strip') {
            var parts = [],
                nSign = '';
            parts = s.split(settings.aDec);
            if (parts[0].indexOf('-') !== -1) {
                nSign = '-';
                parts[0] = parts[0].replace('-', '');
            }
            if (parts[0].length > settings.mInt && parts[0].charAt(0) === '0') { /** strip leading zero if need */
                parts[0] = parts[0].slice(1);
            }
            s = nSign + parts.join(settings.aDec);
        }
        if ((strip_zero && settings.lZero === 'deny') || (strip_zero && settings.lZero === 'allow' && settings.allowLeading === false)) {
            var strip_reg = '^' + settings.aNegRegAutoStrip + '0*(\\d' + (strip_zero === 'leading' ? ')' : '|$)');
            strip_reg = new RegExp(strip_reg);
            s = s.replace(strip_reg, '$1$2');
        }
        return s;
    }
    /**
     * places or removes brackets on negative values
     */
    function negativeBracket(s, nBracket, oEvent) { /** oEvent = settings.oEvent */
        nBracket = nBracket.split(',');
        if (oEvent === 'set' || oEvent === 'focusout') {
            s = s.replace('-', '');
            s = nBracket[0] + s + nBracket[1];
        } else if ((oEvent === 'get' || oEvent === 'focusin' || oEvent === 'pageLoad') && s.charAt(0) === nBracket[0]) {
            s = s.replace(nBracket[0], '-');
            s = s.replace(nBracket[1], '');
        }
        return s;
    }
    /**
     * truncate decimal part of a number
     */
    function truncateDecimal(s, aDec, mDec) {
        if (aDec && mDec) {
            var parts = s.split(aDec);
            /** truncate decimal part to satisfying length
             * cause we would round it anyway */
            if (parts[1] && parts[1].length > mDec) {
                if (mDec > 0) {
                    parts[1] = parts[1].substring(0, mDec);
                    s = parts.join(aDec);
                } else {
                    s = parts[0];
                }
            }
        }
        return s;
    }
    /**
     * prepare number string to be converted to real number
     */
    function fixNumber(s, aDec, aNeg) {
        if (aDec && aDec !== '.') {
            s = s.replace(aDec, '.');
        }
        if (aNeg && aNeg !== '-') {
            s = s.replace(aNeg, '-');
        }
        if (!s.match(/\d/)) {
            s += '0';
        }
        return s;
    }
    /**
     * function to handle numbers less than 0 that are stored in Exponential notation ex: .0000001 stored as 1e-7
     */
    function checkValue(value, settings) {
        if (value) {
            var checkSmall = +value;
            if (checkSmall < 0.000001 && checkSmall > -1) {
                value = +value;
                if (value < 0.000001 && value > 0) {
                    value = (value + 10).toString();
                    value = value.substring(1);
                }
                if (value < 0 && value > -1) {
                    value = (value - 10).toString();
                    value = '-' + value.substring(2);
                }
                value = value.toString();
            } else {
                var parts = value.split('.');
                if (parts[1] !== undefined) {
                    if (+parts[1] === 0) {
                        value = parts[0];
                    } else {
                        parts[1] = parts[1].replace(/0*$/, '');
                        value = parts.join('.');
                    }
                }
            }
        }
        return (settings.lZero === 'keep') ? value : value.replace(/^0*(\d)/, '$1');
    }
    /**
     * prepare real number to be converted to our format
     */
    function presentNumber(s, aDec, aNeg) {
        if (aNeg && aNeg !== '-') {
            s = s.replace('-', aNeg);
        }
        if (aDec && aDec !== '.') {
            s = s.replace('.', aDec);
        }
        return s;
    }
    /**
     * checking that number satisfy format conditions
     * and lays between settings.vMin and settings.vMax
     * and the string length does not exceed the digits in settings.vMin and settings.vMax
     */
    function autoCheck(s, settings) {
        s = autoStrip(s, settings);
        s = truncateDecimal(s, settings.aDec, settings.mDec);
        s = fixNumber(s, settings.aDec, settings.aNeg);
        var value = +s;
        if (settings.oEvent === 'set' && (value < settings.vMin || value > settings.vMax)) {
            $.error("The value (" + value + ") from the 'set' method falls outside of the vMin / vMax range");
        }
        return value >= settings.vMin && value <= settings.vMax;
    }
    /**
     * private function to check for empty value
     */
    function checkEmpty(iv, settings, signOnEmpty) {
        if (iv === '' || iv === settings.aNeg) {
            if (settings.wEmpty === 'zero') {
                return iv + '0';
            }
            if (settings.wEmpty === 'sign' || signOnEmpty) {
                return iv + settings.aSign;
            }
            return iv;
        }
        return null;
    }
    /**
     * private function that formats our number
     */
    function autoGroup(iv, settings) {
        iv = autoStrip(iv, settings);
        var testNeg = iv.replace(',', '.'),
            empty = checkEmpty(iv, settings, true);
        if (empty !== null) {
            return empty;
        }
        var digitalGroup = '';
        if (settings.dGroup === 2) {
            digitalGroup = /(\d)((\d)(\d{2}?)+)$/;
        } else if (settings.dGroup === 4) {
            digitalGroup = /(\d)((\d{4}?)+)$/;
        } else {
            digitalGroup = /(\d)((\d{3}?)+)$/;
        } /** splits the string at the decimal string */
        var ivSplit = iv.split(settings.aDec);
        if (settings.altDec && ivSplit.length === 1) {
            ivSplit = iv.split(settings.altDec);
        } /** assigns the whole number to the a varibale (s) */
        var s = ivSplit[0];
        if (settings.aSep) {
            while (digitalGroup.test(s)) { /** re-inserts the thousand sepparator via a regualer expression */
                s = s.replace(digitalGroup, '$1' + settings.aSep + '$2');
            }
        }
        if (settings.mDec !== 0 && ivSplit.length > 1) {
            if (ivSplit[1].length > settings.mDec) {
                ivSplit[1] = ivSplit[1].substring(0, settings.mDec);
            } /** joins the whole number with the deciaml value */
            iv = s + settings.aDec + ivSplit[1];
        } else { /** if whole numbers only */
            iv = s;
        }
        if (settings.aSign) {
            var has_aNeg = iv.indexOf(settings.aNeg) !== -1;
            iv = iv.replace(settings.aNeg, '');
            iv = settings.pSign === 'p' ? settings.aSign + iv : iv + settings.aSign;
            if (has_aNeg) {
                iv = settings.aNeg + iv;
            }
        }
        if (settings.oEvent === 'set' && testNeg < 0 && settings.nBracket !== null) { /** removes the negative sign and places brackets */
            iv = negativeBracket(iv, settings.nBracket, settings.oEvent);
        }
        return iv;
    }
    /**
     * round number after setting by pasting or $().autoNumericSet()
     * private function for round the number
     * please note this handled as text - JavaScript math function can return inaccurate values
     * also this offers multiple rounding methods that are not easily accomplished in JavaScript
     */
    function autoRound(iv, settings) { /** value to string */
        iv = (iv === '') ? '0' : iv.toString();
        convertKeyToNumber(settings, 'mDec'); /** set mDec to number needed when mDec set by 'update method */
        if (settings.mRound === 'CHF') {
            iv = (Math.round(iv * 20) / 20).toString();
        }
        var ivRounded = '',
            i = 0,
            nSign = '',
            rDec = (typeof (settings.aPad) === 'boolean' || settings.aPad === null) ? (settings.aPad ? settings.mDec : 0) : +settings.aPad;
        var truncateZeros = function (ivRounded) { /** truncate not needed zeros */
            var regex = (rDec === 0) ? (/(\.(?:\d*[1-9])?)0*$/) : rDec === 1 ? (/(\.\d(?:\d*[1-9])?)0*$/) : new RegExp('(\\.\\d{' + rDec + '}(?:\\d*[1-9])?)0*$');
            ivRounded = ivRounded.replace(regex, '$1'); /** If there are no decimal places, we don't need a decimal point at the end */
            if (rDec === 0) {
                ivRounded = ivRounded.replace(/\.$/, '');
            }
            return ivRounded;
        };
        if (iv.charAt(0) === '-') { /** Checks if the iv (input Value)is a negative value */
            nSign = '-';
            iv = iv.replace('-', ''); /** removes the negative sign will be added back later if required */
        }
        if (!iv.match(/^\d/)) { /** append a zero if first character is not a digit (then it is likely to be a dot)*/
            iv = '0' + iv;
        }
        if (nSign === '-' && +iv === 0) { /** determines if the value is zero - if zero no negative sign */
            nSign = '';
        }
        if ((+iv > 0 && settings.lZero !== 'keep') || (iv.length > 0 && settings.lZero === 'allow')) { /** trims leading zero's if needed */
            iv = iv.replace(/^0*(\d)/, '$1');
        }
        var dPos = iv.lastIndexOf('.'), /** virtual decimal position */
            vdPos = (dPos === -1) ? iv.length - 1 : dPos, /** checks decimal places to determine if rounding is required */
            cDec = (iv.length - 1) - vdPos; /** check if no rounding is required */
        if (cDec <= settings.mDec) {
            ivRounded = iv; /** check if we need to pad with zeros */
            if (cDec < rDec) {
                if (dPos === -1) {
                    ivRounded += '.';
                }
                var zeros = '000000';
                while (cDec < rDec) {
                    zeros = zeros.substring(0, rDec - cDec);
                    ivRounded += zeros;
                    cDec += zeros.length;
                }
            } else if (cDec > rDec) {
                ivRounded = truncateZeros(ivRounded);
            } else if (cDec === 0 && rDec === 0) {
                ivRounded = ivRounded.replace(/\.$/, '');
            }
            if (settings.mRound !== 'CHF') {
                return (+ivRounded === 0) ? ivRounded : nSign + ivRounded;
            }
            if (settings.mRound === 'CHF') {
                dPos = ivRounded.lastIndexOf('.');
                iv = ivRounded;
            }

        } /** rounded length of the string after rounding */
        var rLength = dPos + settings.mDec,
            tRound = +iv.charAt(rLength + 1),
            ivArray = iv.substring(0, rLength + 1).split(''),
            odd = (iv.charAt(rLength) === '.') ? (iv.charAt(rLength - 1) % 2) : (iv.charAt(rLength) % 2),
            onePass = true;
        odd = (odd === 0 && (iv.substring(rLength + 2, iv.length) > 0)) ? 1 : 0;
        if ((tRound > 4 && settings.mRound === 'S') || /** Round half up symmetric */
                (tRound > 4 && settings.mRound === 'A' && nSign === '') || /** Round half up asymmetric positive values */
                (tRound > 5 && settings.mRound === 'A' && nSign === '-') || /** Round half up asymmetric negative values */
                (tRound > 5 && settings.mRound === 's') || /** Round half down symmetric */
                (tRound > 5 && settings.mRound === 'a' && nSign === '') || /** Round half down asymmetric positive values */
                (tRound > 4 && settings.mRound === 'a' && nSign === '-') || /** Round half down asymmetric negative values */
                (tRound > 5 && settings.mRound === 'B') || /** Round half even "Banker's Rounding" */
                (tRound === 5 && settings.mRound === 'B' && odd === 1) || /** Round half even "Banker's Rounding" */
                (tRound > 0 && settings.mRound === 'C' && nSign === '') || /** Round to ceiling toward positive infinite */
                (tRound > 0 && settings.mRound === 'F' && nSign === '-') || /** Round to floor toward negative infinite */
                (tRound > 0 && settings.mRound === 'U') ||
                (settings.mRound === 'CHF')) { /** round up away from zero */
            for (i = (ivArray.length - 1); i >= 0; i -= 1) { /** Round up the last digit if required, and continue until no more 9's are found */
                if (ivArray[i] !== '.') {
                    if (settings.mRound === 'CHF' && ivArray[i] <= 2 && onePass) {
                        ivArray[i] = 0;
                        onePass = false;
                        break;
                    }
                    if (settings.mRound === 'CHF' && ivArray[i] <= 7 && onePass) {
                        ivArray[i] = 5;
                        onePass = false;
                        break;
                    }
                    if (settings.mRound === 'CHF' && onePass) {
                        ivArray[i] = 10;
                        onePass = false;
                    } else {
                        ivArray[i] = +ivArray[i] + 1;
                    }
                    if (ivArray[i] < 10) {
                        break;
                    }
                    if (i > 0) {
                        ivArray[i] = '0';
                    }
                }
            }
        }
        ivArray = ivArray.slice(0, rLength + 1); /** Reconstruct the string, converting any 10's to 0's */
        ivRounded = truncateZeros(ivArray.join('')); /** return rounded value */
        return (+ivRounded === 0) ? ivRounded : nSign + ivRounded;
    }
    /**
     * Holder object for field properties
     */
    function AutoNumericHolder(that, settings) {
        this.settings = settings;
        this.that = that;
        this.$that = $(that);
        this.formatted = false;
        this.settingsClone = autoCode(this.$that, this.settings);
        this.value = that.value;
    }
    AutoNumericHolder.prototype = {
        init: function (e) {
            this.value = this.that.value;
            this.settingsClone = autoCode(this.$that, this.settings);
            this.ctrlKey = e.ctrlKey;
            this.cmdKey = e.metaKey;
            this.shiftKey = e.shiftKey;
            this.selection = getElementSelection(this.that); /** keypress event overwrites meaningful value of e.keyCode */
            if (e.type === 'keydown' || e.type === 'keyup') {
                this.kdCode = e.keyCode;
            }
            this.which = e.which;
            this.processed = false;
            this.formatted = false;
        },
        setSelection: function (start, end, setReal) {
            start = Math.max(start, 0);
            end = Math.min(end, this.that.value.length);
            this.selection = {
                start: start,
                end: end,
                length: end - start
            };
            if (setReal === undefined || setReal) {
                setElementSelection(this.that, start, end);
            }
        },
        setPosition: function (pos, setReal) {
            this.setSelection(pos, pos, setReal);
        },
        getBeforeAfter: function () {
            var value = this.value,
                left = value.substring(0, this.selection.start),
                right = value.substring(this.selection.end, value.length);
            return [left, right];
        },
        getBeforeAfterStriped: function () {
            var parts = this.getBeforeAfter();
            parts[0] = autoStrip(parts[0], this.settingsClone);
            parts[1] = autoStrip(parts[1], this.settingsClone);
            return parts;
        },
        /**
         * strip parts from excess characters and leading zeroes
         */
        normalizeParts: function (left, right) {
            var settingsClone = this.settingsClone;
            right = autoStrip(right, settingsClone); /** if right is not empty and first character is not aDec, */
            /** we could strip all zeros, otherwise only leading */
            var strip = right.match(/^\d/) ? true : 'leading';
            left = autoStrip(left, settingsClone, strip); /** prevents multiple leading zeros from being entered */
            if ((left === '' || left === settingsClone.aNeg) && settingsClone.lZero === 'deny') {
                if (right > '') {
                    right = right.replace(/^0*(\d)/, '$1');
                }
            }
            var new_value = left + right; /** insert zero if has leading dot */
            if (settingsClone.aDec) {
                var m = new_value.match(new RegExp('^' + settingsClone.aNegRegAutoStrip + '\\' + settingsClone.aDec));
                if (m) {
                    left = left.replace(m[1], m[1] + '0');
                    new_value = left + right;
                }
            } /** insert zero if number is empty and io.wEmpty == 'zero' */
            if (settingsClone.wEmpty === 'zero' && (new_value === settingsClone.aNeg || new_value === '')) {
                left += '0';
            }
            return [left, right];
        },
        /**
         * set part of number to value keeping position of cursor
         */
        setValueParts: function (left, right) {
            var settingsClone = this.settingsClone,
                parts = this.normalizeParts(left, right),
                new_value = parts.join(''),
                position = parts[0].length;
            if (autoCheck(new_value, settingsClone)) {
                new_value = truncateDecimal(new_value, settingsClone.aDec, settingsClone.mDec);
                if (position > new_value.length) {
                    position = new_value.length;
                }
                this.value = new_value;
                this.setPosition(position, false);
                return true;
            }
            return false;
        },
        /**
         * helper function for expandSelectionOnSign
         * returns sign position of a formatted value
         */
        signPosition: function () {
            var settingsClone = this.settingsClone,
                aSign = settingsClone.aSign,
                that = this.that;
            if (aSign) {
                var aSignLen = aSign.length;
                if (settingsClone.pSign === 'p') {
                    var hasNeg = settingsClone.aNeg && that.value && that.value.charAt(0) === settingsClone.aNeg;
                    return hasNeg ? [1, aSignLen + 1] : [0, aSignLen];
                }
                var valueLen = that.value.length;
                return [valueLen - aSignLen, valueLen];
            }
            return [1000, -1];
        },
        /**
         * expands selection to cover whole sign
         * prevents partial deletion/copying/overwriting of a sign
         */
        expandSelectionOnSign: function (setReal) {
            var sign_position = this.signPosition(),
                selection = this.selection;
            if (selection.start < sign_position[1] && selection.end > sign_position[0]) { /** if selection catches something except sign and catches only space from sign */
                if ((selection.start < sign_position[0] || selection.end > sign_position[1]) && this.value.substring(Math.max(selection.start, sign_position[0]), Math.min(selection.end, sign_position[1])).match(/^\s*$/)) { /** then select without empty space */
                    if (selection.start < sign_position[0]) {
                        this.setSelection(selection.start, sign_position[0], setReal);
                    } else {
                        this.setSelection(sign_position[1], selection.end, setReal);
                    }
                } else { /** else select with whole sign */
                    this.setSelection(Math.min(selection.start, sign_position[0]), Math.max(selection.end, sign_position[1]), setReal);
                }
            }
        },
        /**
         * try to strip pasted value to digits
         */
        checkPaste: function () {
            if (this.valuePartsBeforePaste !== undefined) {
                var parts = this.getBeforeAfter(),
                    oldParts = this.valuePartsBeforePaste;
                delete this.valuePartsBeforePaste; /** try to strip pasted value first */
                parts[0] = parts[0].substr(0, oldParts[0].length) + autoStrip(parts[0].substr(oldParts[0].length), this.settingsClone);
                if (!this.setValueParts(parts[0], parts[1])) {
                    this.value = oldParts.join('');
                    this.setPosition(oldParts[0].length, false);
                }
            }
        },
        /**
         * process pasting, cursor moving and skipping of not interesting keys
         * if returns true, futher processing is not performed
         */
        skipAllways: function (e) {
            var kdCode = this.kdCode,
                which = this.which,
                ctrlKey = this.ctrlKey,
                cmdKey = this.cmdKey,
                shiftKey = this.shiftKey; /** catch the ctrl up on ctrl-v */
            if (((ctrlKey || cmdKey) && e.type === 'keyup' && this.valuePartsBeforePaste !== undefined) || (shiftKey && kdCode === 45)) {
                this.checkPaste();
                return false;
            }
            /** codes are taken from http://www.cambiaresearch.com/c4/702b8cd1-e5b0-42e6-83ac-25f0306e3e25/Javascript-Char-Codes-Key-Codes.aspx
             * skip Fx keys, windows keys, other special keys
             */
            if ((kdCode >= 112 && kdCode <= 123) || (kdCode >= 91 && kdCode <= 93) || (kdCode >= 9 && kdCode <= 31) || (kdCode < 8 && (which === 0 || which === kdCode)) || kdCode === 144 || kdCode === 145 || kdCode === 45) {
                return true;
            }
            if ((ctrlKey || cmdKey) && kdCode === 65) { /** if select all (a=65)*/
                return true;
            }
            if ((ctrlKey || cmdKey) && (kdCode === 67 || kdCode === 86 || kdCode === 88)) { /** if copy (c=67) paste (v=86) or cut (x=88) */
                if (e.type === 'keydown') {
                    this.expandSelectionOnSign();
                }
                if (kdCode === 86 || kdCode === 45) { /** try to prevent wrong paste */
                    if (e.type === 'keydown' || e.type === 'keypress') {
                        if (this.valuePartsBeforePaste === undefined) {
                            this.valuePartsBeforePaste = this.getBeforeAfter();
                        }
                    } else {
                        this.checkPaste();
                    }
                }
                return e.type === 'keydown' || e.type === 'keypress' || kdCode === 67;
            }
            if (ctrlKey || cmdKey) {
                return true;
            }
            if (kdCode === 37 || kdCode === 39) { /** jump over thousand separator */
                var aSep = this.settingsClone.aSep,
                    start = this.selection.start,
                    value = this.that.value;
                if (e.type === 'keydown' && aSep && !this.shiftKey) {
                    if (kdCode === 37 && value.charAt(start - 2) === aSep) {
                        this.setPosition(start - 1);
                    } else if (kdCode === 39 && value.charAt(start + 1) === aSep) {
                        this.setPosition(start + 1);
                    }
                }
                return true;
            }
            if (kdCode >= 34 && kdCode <= 40) {
                return true;
            }
            return false;
        },
        /**
         * process deletion of characters
         * returns true if processing performed
         */
        processAllways: function () {
            var parts; /** process backspace or delete */
            if (this.kdCode === 8 || this.kdCode === 46) {
                if (!this.selection.length) {
                    parts = this.getBeforeAfterStriped();
                    if (this.kdCode === 8) {
                        parts[0] = parts[0].substring(0, parts[0].length - 1);
                    } else {
                        parts[1] = parts[1].substring(1, parts[1].length);
                    }
                    this.setValueParts(parts[0], parts[1]);
                } else {
                    this.expandSelectionOnSign(false);
                    parts = this.getBeforeAfterStriped();
                    this.setValueParts(parts[0], parts[1]);
                }
                return true;
            }
            return false;
        },
        /**
         * process insertion of characters
         * returns true if processing performed
         */
        processKeypress: function () {
            var settingsClone = this.settingsClone,
                cCode = String.fromCharCode(this.which),
                parts = this.getBeforeAfterStriped(),
                left = parts[0],
                right = parts[1]; /** start rules when the decimal character key is pressed */
            /** always use numeric pad dot to insert decimal separator */
            if (cCode === settingsClone.aDec || (settingsClone.altDec && cCode === settingsClone.altDec) || ((cCode === '.' || cCode === ',') && this.kdCode === 110)) { /** do not allow decimal character if no decimal part allowed */
                if (!settingsClone.mDec || !settingsClone.aDec) {
                    return true;
                } /** do not allow decimal character before aNeg character */
                if (settingsClone.aNeg && right.indexOf(settingsClone.aNeg) > -1) {
                    return true;
                } /** do not allow decimal character if other decimal character present */
                if (left.indexOf(settingsClone.aDec) > -1) {
                    return true;
                }
                if (right.indexOf(settingsClone.aDec) > 0) {
                    return true;
                }
                if (right.indexOf(settingsClone.aDec) === 0) {
                    right = right.substr(1);
                }
                this.setValueParts(left + settingsClone.aDec, right);
                return true;
            } /** start rule on negative sign */

            if (cCode === '-' || cCode === '+') { /** prevent minus if not allowed */
                if (!settingsClone.aNeg) {
                    return true;
                } /** caret is always after minus */
                if (left === '' && right.indexOf(settingsClone.aNeg) > -1) {
                    left = settingsClone.aNeg;
                    right = right.substring(1, right.length);
                } /** change sign of number, remove part if should */
                if (left.charAt(0) === settingsClone.aNeg) {
                    left = left.substring(1, left.length);
                } else {
                    left = (cCode === '-') ? settingsClone.aNeg + left : left;
                }
                this.setValueParts(left, right);
                return true;
            } /** digits */
            if (cCode >= '0' && cCode <= '9') { /** if try to insert digit before minus */
                if (settingsClone.aNeg && left === '' && right.indexOf(settingsClone.aNeg) > -1) {
                    left = settingsClone.aNeg;
                    right = right.substring(1, right.length);
                }
                if (settingsClone.vMax <= 0 && settingsClone.vMin < settingsClone.vMax && this.value.indexOf(settingsClone.aNeg) === -1 && cCode !== '0') {
                    left = settingsClone.aNeg + left;
                }
                this.setValueParts(left + cCode, right);
                return true;
            } /** prevent any other character */
            return true;
        },
        /**
         * formatting of just processed value with keeping of cursor position
         */
        formatQuick: function () {
            var settingsClone = this.settingsClone,
                parts = this.getBeforeAfterStriped(),
                leftLength = this.value;
            if ((settingsClone.aSep === '' || (settingsClone.aSep !== '' && leftLength.indexOf(settingsClone.aSep) === -1)) && (settingsClone.aSign === '' || (settingsClone.aSign !== '' && leftLength.indexOf(settingsClone.aSign) === -1))) {
                var subParts = [],
                    nSign = '';
                subParts = leftLength.split(settingsClone.aDec);
                if (subParts[0].indexOf('-') > -1) {
                    nSign = '-';
                    subParts[0] = subParts[0].replace('-', '');
                    parts[0] = parts[0].replace('-', '');
                }
                if (subParts[0].length > settingsClone.mInt && parts[0].charAt(0) === '0') { /** strip leading zero if need */
                    parts[0] = parts[0].slice(1);
                }
                parts[0] = nSign + parts[0];
            }
            var value = autoGroup(this.value, this.settingsClone),
                position = value.length;
            if (value) {
                /** prepare regexp which searches for cursor position from unformatted left part */
                var left_ar = parts[0].split(''),
                    i = 0;
                for (i; i < left_ar.length; i += 1) { /** thanks Peter Kovari */
                    if (!left_ar[i].match('\\d')) {
                        left_ar[i] = '\\' + left_ar[i];
                    }
                }
                var leftReg = new RegExp('^.*?' + left_ar.join('.*?'));
                /** search cursor position in formatted value */
                var newLeft = value.match(leftReg);
                if (newLeft) {
                    position = newLeft[0].length;
                    /** if we are just before sign which is in prefix position */
                    if (((position === 0 && value.charAt(0) !== settingsClone.aNeg) || (position === 1 && value.charAt(0) === settingsClone.aNeg)) && settingsClone.aSign && settingsClone.pSign === 'p') {
                        /** place carret after prefix sign */
                        position = this.settingsClone.aSign.length + (value.charAt(0) === '-' ? 1 : 0);
                    }
                } else if (settingsClone.aSign && settingsClone.pSign === 's') {
                    /** if we could not find a place for cursor and have a sign as a suffix */
                    /** place carret before suffix currency sign */
                    position -= settingsClone.aSign.length;
                }
            }
            this.that.value = value;
            this.setPosition(position);
            this.formatted = true;
        }
    };
    /** thanks to Anthony & Evan C */
    function autoGet(obj) {
        if (typeof obj === 'string') {
            obj = obj.replace(/\[/g, "\\[").replace(/\]/g, "\\]");
            obj = '#' + obj.replace(/(:|\.)/g, '\\$1');
            /** obj = '#' + obj.replace(/([;&,\.\+\*\~':"\!\^#$%@\[\]\(\)=>\|])/g, '\\$1'); */
            /** possible modification to replace the above 2 lines */
        }
        return $(obj);
    }

    function getHolder($that, settings, update) {
        var data = $that.data('autoNumeric');
        if (!data) {
            data = {};
            $that.data('autoNumeric', data);
        }
        var holder = data.holder;
        if ((holder === undefined && settings) || update) {
            holder = new AutoNumericHolder($that.get(0), settings);
            data.holder = holder;
        }
        return holder;
    }
    var methods = {
        init: function (options) {
            return this.each(function () {
                var $this = $(this),
                    settings = $this.data('autoNumeric'), /** attempt to grab 'autoNumeric' settings, if they don't exist returns "undefined". */
                    tagData = $this.data(); /** attempt to grab HTML5 data, if they don't exist we'll get "undefined".*/
                if (typeof settings !== 'object') { /** If we couldn't grab settings, create them from defaults and passed options. */
                    var defaults = {
                        /** allowed numeric values
                         * please do not modify
                         */
                        aNum: '0123456789',
                        /** allowed thousand separator characters
                         * comma = ','
                         * period "full stop" = '.'
                         * apostrophe is escaped = '\''
                         * space = ' '
                         * none = ''
                         * NOTE: do not use numeric characters
                         */
                        aSep: ',',
                        /** digital grouping for the thousand separator used in Format
                         * dGroup: '2', results in 99,99,99,999 common in India for values less than 1 billion and greater than -1 billion
                         * dGroup: '3', results in 999,999,999 default
                         * dGroup: '4', results in 9999,9999,9999 used in some Asian countries
                         */
                        dGroup: '3',
                        /** allowed decimal separator characters
                         * period "full stop" = '.'
                         * comma = ','
                         */
                        aDec: '.',
                        /** allow to declare alternative decimal separator which is automatically replaced by aDec
                         * developed for countries the use a comma ',' as the decimal character
                         * and have keyboards\numeric pads that have a period 'full stop' as the decimal characters (Spain is an example)
                         */
                        altDec: null,
                        /** allowed currency symbol
                         * Must be in quotes aSign: '$', a space is allowed aSign: '$ '
                         */
                        aSign: '',
                        /** placement of currency sign
                         * for prefix pSign: 'p',
                         * for suffix pSign: 's',
                         */
                        pSign: 'p',
                        /** maximum possible value
                         * value must be enclosed in quotes and use the period for the decimal point
                         * value must be larger than vMin
                         */
                        vMax: '9999999999999.99',
                        /** minimum possible value
                         * value must be enclosed in quotes and use the period for the decimal point
                         * value must be smaller than vMax
                         */
                        vMin: '0.00',
                        /** max number of decimal places = used to override decimal places set by the vMin & vMax values
                         * value must be enclosed in quotes example mDec: '3',
                         * This can also set the value via a call back function mDec: 'css:#
                         */
                        mDec: null,
                        /** method used for rounding
                         * mRound: 'S', Round-Half-Up Symmetric (default)
                         * mRound: 'A', Round-Half-Up Asymmetric
                         * mRound: 's', Round-Half-Down Symmetric (lower case s)
                         * mRound: 'a', Round-Half-Down Asymmetric (lower case a)
                         * mRound: 'B', Round-Half-Even "Bankers Rounding"
                         * mRound: 'U', Round Up "Round-Away-From-Zero"
                         * mRound: 'D', Round Down "Round-Toward-Zero" - same as truncate
                         * mRound: 'C', Round to Ceiling "Toward Positive Infinity"
                         * mRound: 'F', Round to Floor "Toward Negative Infinity"
                         */
                        mRound: 'S',
                        /** controls decimal padding
                         * aPad: true - always Pad decimals with zeros
                         * aPad: false - does not pad with zeros.
                         * aPad: `some number` - pad decimals with zero to number different from mDec
                         * thanks to Jonas Johansson for the suggestion
                         */
                        aPad: true,
                        /** places brackets on negative value -$ 999.99 to (999.99)
                         * visible only when the field does NOT have focus the left and right symbols should be enclosed in quotes and seperated by a comma
                         * nBracket: null, nBracket: '(,)', nBracket: '[,]', nBracket: '<,>' or nBracket: '{,}'
                         */
                        nBracket: null,
                        /** Displayed on empty string
                         * wEmpty: 'empty', - input can be blank
                         * wEmpty: 'zero', - displays zero
                         * wEmpty: 'sign', - displays the currency sign
                         */
                        wEmpty: 'empty',
                        /** controls leading zero behavior
                         * lZero: 'allow', - allows leading zeros to be entered. Zeros will be truncated when entering additional digits. On focusout zeros will be deleted.
                         * lZero: 'deny', - allows only one leading zero on values less than one
                         * lZero: 'keep', - allows leading zeros to be entered. on fousout zeros will be retained.
                         */
                        lZero: 'allow',
                        /** determine if the default value will be formatted on page ready.
                         * true = automatically formats the default value on page ready
                         * false = will not format the default value
                         */
                        aForm: true,
                        /** future use */
                        onSomeEvent: function () {}
                    };
                    settings = $.extend({}, defaults, tagData, options); /** Merge defaults, tagData and options */
                    if (settings.aDec === settings.aSep) {
                        $.error("autoNumeric will not function properly when the decimal character aDec: '" + settings.aDec + "' and thousand separator aSep: '" + settings.aSep + "' are the same character");
                        return this;
                    }
                    $this.data('autoNumeric', settings); /** Save our new settings */
                } else {
                    return this;
                }
                settings.runOnce = false;
                var holder = getHolder($this, settings);
                if ($.inArray($this.prop('tagName'), settings.tagList) === -1 && $this.prop('tagName') !== 'INPUT') {
                    $.error("The <" + $this.prop('tagName') + "> is not supported by autoNumeric()");
                    return this;
                }
                if (settings.runOnce === false && settings.aForm) {/** routine to format default value on page load */
                    if ($this.is('input[type=text], input[type=hidden], input[type=tel], input:not([type])')) {
                        var setValue = true;
                        if ($this[0].value === '' && settings.wEmpty === 'empty') {
                            $this[0].value = '';
                            setValue = false;
                        }
                        if ($this[0].value === '' && settings.wEmpty === 'sign') {
                            $this[0].value = settings.aSign;
                            setValue = false;
                        }
                        if (setValue) {
                            $this.autoNumeric('set', $this.val());
                        }
                    }
                    if ($.inArray($this.prop('tagName'), settings.tagList) !== -1 && $this.text() !== '') {
                        $this.autoNumeric('set', $this.text());
                    }
                }
                settings.runOnce = true;
                if ($this.is('input[type=text], input[type=hidden], input[type=tel], input:not([type])')) { /**added hidden type */
                    $this.on('keydown.autoNumeric', function (e) {
                        holder = getHolder($this);
                        if (holder.settings.aDec === holder.settings.aSep) {
                            $.error("autoNumeric will not function properly when the decimal character aDec: '" + holder.settings.aDec + "' and thousand separator aSep: '" + holder.settings.aSep + "' are the same character");
                            return this;
                        }
                        if (holder.that.readOnly) {
                            holder.processed = true;
                            return true;
                        }
                        /** The below streamed code / comment allows the "enter" keydown to throw a change() event */
                        /** if (e.keyCode === 13 && holder.inVal !== $this.val()){
                            $this.change();
                            holder.inVal = $this.val();
                        }*/
                        holder.init(e);
                        holder.settings.oEvent = 'keydown';
                        if (holder.skipAllways(e)) {
                            holder.processed = true;
                            return true;
                        }
                        if (holder.processAllways()) {
                            holder.processed = true;
                            holder.formatQuick();
                            e.preventDefault();
                            return false;
                        }
                        holder.formatted = false;
                        return true;
                    });
                    $this.on('keypress.autoNumeric', function (e) {
                        var holder = getHolder($this),
                            processed = holder.processed;
                        holder.init(e);
                        holder.settings.oEvent = 'keypress';
                        if (holder.skipAllways(e)) {
                            return true;
                        }
                        if (processed) {
                            e.preventDefault();
                            return false;
                        }
                        if (holder.processAllways() || holder.processKeypress()) {
                            holder.formatQuick();
                            e.preventDefault();
                            return false;
                        }
                        holder.formatted = false;
                    });
                    $this.on('keyup.autoNumeric', function (e) {
                        var holder = getHolder($this);
                        holder.init(e);
                        holder.settings.oEvent = 'keyup';
                        var skip = holder.skipAllways(e);
                        holder.kdCode = 0;
                        delete holder.valuePartsBeforePaste;
                        if ($this[0].value === holder.settings.aSign) { /** added to properly place the caret when only the currency is present */
                            if (holder.settings.pSign === 's') {
                                setElementSelection(this, 0, 0);
                            } else {
                                setElementSelection(this, holder.settings.aSign.length, holder.settings.aSign.length);
                            }
                        }
                        if (skip) {
                            return true;
                        }
                        if (this.value === '') {
                            return true;
                        }
                        if (!holder.formatted) {
                            holder.formatQuick();
                        }
                    });
                    $this.on('focusin.autoNumeric', function () {
                        var holder = getHolder($this);
                        holder.settingsClone.oEvent = 'focusin';
                        if (holder.settingsClone.nBracket !== null) {
                            var checkVal = $this.val();
                            $this.val(negativeBracket(checkVal, holder.settingsClone.nBracket, holder.settingsClone.oEvent));
                        }
                        holder.inVal = $this.val();
                        var onempty = checkEmpty(holder.inVal, holder.settingsClone, true);
                        if (onempty !== null) {
                            $this.val(onempty);
                            if (holder.settings.pSign === 's') {
                                setElementSelection(this, 0, 0);
                            } else {
                                setElementSelection(this, holder.settings.aSign.length, holder.settings.aSign.length);
                            }
                        }
                    });
                    $this.on('focusout.autoNumeric', function () {
                        var holder = getHolder($this),
                            settingsClone = holder.settingsClone,
                            value = $this.val(),
                            origValue = value;
                        holder.settingsClone.oEvent = 'focusout';
                        var strip_zero = ''; /** added to control leading zero */
                        if (settingsClone.lZero === 'allow') { /** added to control leading zero */
                            settingsClone.allowLeading = false;
                            strip_zero = 'leading';
                        }
                        if (value !== '') {
                            value = autoStrip(value, settingsClone, strip_zero);
                            if (checkEmpty(value, settingsClone) === null && autoCheck(value, settingsClone, $this[0])) {
                                value = fixNumber(value, settingsClone.aDec, settingsClone.aNeg);
                                value = autoRound(value, settingsClone);
                                value = presentNumber(value, settingsClone.aDec, settingsClone.aNeg);
                            } else {
                                value = '';
                            }
                        }
                        var groupedValue = checkEmpty(value, settingsClone, false);
                        if (groupedValue === null) {
                            groupedValue = autoGroup(value, settingsClone);
                        }
                        if (groupedValue !== origValue) {
                            $this.val(groupedValue);
                        }
                        if (groupedValue !== holder.inVal) {
                            $this.change();
                            delete holder.inVal;
                        }
                        if (settingsClone.nBracket !== null && $this.autoNumeric('get') < 0) {
                            holder.settingsClone.oEvent = 'focusout';
                            $this.val(negativeBracket($this.val(), settingsClone.nBracket, settingsClone.oEvent));
                        }
                    });
                }
            });
        },
        /** method to remove settings and stop autoNumeric() */
        destroy: function () {
            return $(this).each(function () {
                var $this = $(this);
                $this.off('.autoNumeric');
                $this.removeData('autoNumeric');
            });
        },
        /** method to update settings - can call as many times */
        update: function (options) {
            return $(this).each(function () {
                var $this = autoGet($(this)),
                    settings = $this.data('autoNumeric');
                if (typeof settings !== 'object') {
                    $.error("You must initialize autoNumeric('init', {options}) prior to calling the 'update' method");
                    return this;
                }
                var strip = $this.autoNumeric('get');
                settings = $.extend(settings, options);
                getHolder($this, settings, true);
                if (settings.aDec === settings.aSep) {
                    $.error("autoNumeric will not function properly when the decimal character aDec: '" + settings.aDec + "' and thousand separator aSep: '" + settings.aSep + "' are the same character");
                    return this;
                }
                $this.data('autoNumeric', settings);
                if ($this.val() !== '' || $this.text() !== '') {
                    return $this.autoNumeric('set', strip);
                }
                return;
            });
        },
        /** returns a formatted strings for "input:text" fields Uses jQuery's .val() method*/
        set: function (valueIn) {
            return $(this).each(function () {
                var $this = autoGet($(this)),
                    settings = $this.data('autoNumeric'),
                    value = valueIn.toString(),
                    testValue = valueIn.toString();
                if (typeof settings !== 'object') {
                    $.error("You must initialize autoNumeric('init', {options}) prior to calling the 'set' method");
                    return this;
                }
                /** routine to handle page re-load from back button */
                if (testValue !== $this.attr('value') && $this.prop('tagName') === 'INPUT' && settings.runOnce === false) {
                    value = (settings.nBracket !== null) ? negativeBracket($this.val(), settings.nBracket, 'pageLoad') : value;
                    value = autoStrip(value, settings);
                }
               /** allows locale decimal separator to be a comma */
                if ((testValue === $this.attr('value') || testValue === $this.text()) && settings.runOnce === false) {
                    value = value.replace(',', '.');
                }
                /** returns a empty string if the value being 'set' contains non-numeric characters and or more than decimal point (full stop) and will not be formatted */
                if (!$.isNumeric(+value)) {
                    return '';
                }
                value = checkValue(value, settings);
                settings.oEvent = 'set';
                value.toString();
                if (value !== '') {
                    value = autoRound(value, settings);
                }
                value = presentNumber(value, settings.aDec, settings.aNeg);
                if (!autoCheck(value, settings)) {
                    value = autoRound('', settings);
                }
                value = autoGroup(value, settings);
                if ($this.is('input[type=text], input[type=hidden], input[type=tel], input:not([type])')) { /**added hidden type */
                    return $this.val(value);
                }
                if ($.inArray($this.prop('tagName'), settings.tagList) !== -1) {
                    return $this.text(value);
                }
                $.error("The <" + $this.prop('tagName') + "> is not supported by autoNumeric()");
                return false;
            });
        },
        /** method to get the unformatted value from a specific input field, returns a numeric value */
        get: function () {
            var $this = autoGet($(this)),
                settings = $this.data('autoNumeric');
            if (typeof settings !== 'object') {
                $.error("You must initialize autoNumeric('init', {options}) prior to calling the 'get' method");
                return this;
            }
            settings.oEvent = 'get';
            var getValue = '';
            /** determine the element type then use .eq(0) selector to grab the value of the first element in selector */
            if ($this.is('input[type=text], input[type=hidden], input[type=tel], input:not([type])')) { /**added hidden type */
                getValue = $this.eq(0).val();
            } else if ($.inArray($this.prop('tagName'), settings.tagList) !== -1) {
                getValue = $this.eq(0).text();
            } else {
                $.error("The <" + $this.prop('tagName') + "> is not supported by autoNumeric()");
                return false;
            }
            if ((getValue === '' && settings.wEmpty === 'empty') || (getValue === settings.aSign && (settings.wEmpty === 'sign' || settings.wEmpty === 'empty'))) {
                return '';
            }
            if (settings.nBracket !== null && getValue !== '') {
                getValue = negativeBracket(getValue, settings.nBracket, settings.oEvent);
            }
            if (settings.runOnce || settings.aForm === false) {
                getValue = autoStrip(getValue, settings);
            }
            getValue = fixNumber(getValue, settings.aDec, settings.aNeg);
            if (+getValue === 0 && settings.lZero !== 'keep') {
                getValue = '0';
            }
            if (settings.lZero === 'keep') {
                return getValue;
            }
            getValue = checkValue(getValue, settings);
            return getValue; /** returned Numeric String */
        },
        /** method to get the unformatted value from multiple fields */
        getString: function () {
            var isAutoNumeric = false,
                $this = autoGet($(this)),
                str = $this.serialize(),
                parts = str.split('&'),
                i = 0;
            for (i; i < parts.length; i += 1) {
                var miniParts = parts[i].split('=');
                var settings = $('*[name="' + decodeURIComponent(miniParts[0]) + '"]').data('autoNumeric');
                if (typeof settings === 'object') {
                    if (miniParts[1] !== null && $('*[name="' + decodeURIComponent(miniParts[0]) + '"]').data('autoNumeric') !== undefined) {
                        miniParts[1] = $('input[name="' + decodeURIComponent(miniParts[0]) + '"]').autoNumeric('get');
                        parts[i] = miniParts.join('=');
                        isAutoNumeric = true;
                    }
                }
            }
            if (isAutoNumeric === true) {
                return parts.join('&');
            }
            $.error("You must initialize autoNumeric('init', {options}) prior to calling the 'getString' method");
            return this;
        },
        /** method to get the unformatted value from multiple fields */
        getArray: function () {
            var isAutoNumeric = false,
                $this = autoGet($(this)),
                formFields = $this.serializeArray();
            $.each(formFields, function (i, field) {
                var settings = $('*[name="' + decodeURIComponent(field.name) + '"]').data('autoNumeric');
                if (typeof settings === 'object') {
                    if (field.value !== '' && $('*[name="' + decodeURIComponent(field.name) + '"]').data('autoNumeric') !== undefined) {
                        field.value = $('input[name="' + decodeURIComponent(field.name) + '"]').autoNumeric('get').toString();
                    }
                    isAutoNumeric = true;
                }
            });
            if (isAutoNumeric === true) {
                return formFields;
            }
            $.error("You must initialize autoNumeric('init', {options}) prior to calling the 'getArray' method");
            return this;
        },
        /** returns the settings object for those who need to look under the hood */
        getSettings: function () {
            var $this = autoGet($(this));
            return $this.eq(0).data('autoNumeric');
        }
    };
    $.fn.autoNumeric = function (method) {
        if (methods[method]) {
            return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
        }
        if (typeof method === 'object' || !method) {
            return methods.init.apply(this, arguments);
        }
        $.error('Method "' + method + '" is not supported by autoNumeric()');
    };
}(jQuery));;
(function(){var a,b,c,d,e,f,g,h,i=[].slice,j={}.hasOwnProperty,k=function(a,b){function c(){this.constructor=a}for(var d in b)j.call(b,d)&&(a[d]=b[d]);return c.prototype=b.prototype,a.prototype=new c,a.__super__=b.prototype,a};g=function(){},b=function(){function a(){}return a.prototype.addEventListener=a.prototype.on,a.prototype.on=function(a,b){return this._callbacks=this._callbacks||{},this._callbacks[a]||(this._callbacks[a]=[]),this._callbacks[a].push(b),this},a.prototype.emit=function(){var a,b,c,d,e,f;if(d=arguments[0],a=2<=arguments.length?i.call(arguments,1):[],this._callbacks=this._callbacks||{},c=this._callbacks[d])for(e=0,f=c.length;f>e;e++)b=c[e],b.apply(this,a);return this},a.prototype.removeListener=a.prototype.off,a.prototype.removeAllListeners=a.prototype.off,a.prototype.removeEventListener=a.prototype.off,a.prototype.off=function(a,b){var c,d,e,f,g;if(!this._callbacks||0===arguments.length)return this._callbacks={},this;if(d=this._callbacks[a],!d)return this;if(1===arguments.length)return delete this._callbacks[a],this;for(e=f=0,g=d.length;g>f;e=++f)if(c=d[e],c===b){d.splice(e,1);break}return this},a}(),a=function(a){function c(a,b){var e,f,g;if(this.element=a,this.version=c.version,this.defaultOptions.previewTemplate=this.defaultOptions.previewTemplate.replace(/\n*/g,""),this.clickableElements=[],this.listeners=[],this.files=[],"string"==typeof this.element&&(this.element=document.querySelector(this.element)),!this.element||null==this.element.nodeType)throw new Error("Invalid dropzone element.");if(this.element.dropzone)throw new Error("Dropzone already attached.");if(c.instances.push(this),this.element.dropzone=this,e=null!=(g=c.optionsForElement(this.element))?g:{},this.options=d({},this.defaultOptions,e,null!=b?b:{}),this.options.forceFallback||!c.isBrowserSupported())return this.options.fallback.call(this);if(null==this.options.url&&(this.options.url=this.element.getAttribute("action")),!this.options.url)throw new Error("No URL provided.");if(this.options.acceptedFiles&&this.options.acceptedMimeTypes)throw new Error("You can't provide both 'acceptedFiles' and 'acceptedMimeTypes'. 'acceptedMimeTypes' is deprecated.");this.options.acceptedMimeTypes&&(this.options.acceptedFiles=this.options.acceptedMimeTypes,delete this.options.acceptedMimeTypes),this.options.method=this.options.method.toUpperCase(),(f=this.getExistingFallback())&&f.parentNode&&f.parentNode.removeChild(f),this.options.previewsContainer!==!1&&(this.previewsContainer=this.options.previewsContainer?c.getElement(this.options.previewsContainer,"previewsContainer"):this.element),this.options.clickable&&(this.clickableElements=this.options.clickable===!0?[this.element]:c.getElements(this.options.clickable,"clickable")),this.init()}var d,e;return k(c,a),c.prototype.Emitter=b,c.prototype.events=["drop","dragstart","dragend","dragenter","dragover","dragleave","addedfile","addedfiles","removedfile","thumbnail","error","errormultiple","processing","processingmultiple","uploadprogress","totaluploadprogress","sending","sendingmultiple","success","successmultiple","canceled","canceledmultiple","complete","completemultiple","reset","maxfilesexceeded","maxfilesreached","queuecomplete"],c.prototype.defaultOptions={url:null,method:"post",withCredentials:!1,parallelUploads:2,uploadMultiple:!1,maxFilesize:256,paramName:"file",createImageThumbnails:!0,maxThumbnailFilesize:10,thumbnailWidth:120,thumbnailHeight:120,filesizeBase:1e3,maxFiles:null,params:{},clickable:!0,ignoreHiddenFiles:!0,acceptedFiles:null,acceptedMimeTypes:null,autoProcessQueue:!0,autoQueue:!0,addRemoveLinks:!1,previewsContainer:null,hiddenInputContainer:"body",capture:null,dictDefaultMessage:"Drop files here to upload",dictFallbackMessage:"Your browser does not support drag'n'drop file uploads.",dictFallbackText:"Please use the fallback form below to upload your files like in the olden days.",dictFileTooBig:"File is too big ({{filesize}}MiB). Max filesize: {{maxFilesize}}MiB.",dictInvalidFileType:"You can't upload files of this type.",dictResponseError:"Server responded with {{statusCode}} code.",dictCancelUpload:"Cancel upload",dictCancelUploadConfirmation:"Are you sure you want to cancel this upload?",dictRemoveFile:"Remove file",dictRemoveFileConfirmation:null,dictMaxFilesExceeded:"You can not upload any more files.",accept:function(a,b){return b()},init:function(){return g},forceFallback:!1,fallback:function(){var a,b,d,e,f,g;for(this.element.className=""+this.element.className+" dz-browser-not-supported",g=this.element.getElementsByTagName("div"),e=0,f=g.length;f>e;e++)a=g[e],/(^| )dz-message($| )/.test(a.className)&&(b=a,a.className="dz-message");return b||(b=c.createElement('<div class="dz-message"><span></span></div>'),this.element.appendChild(b)),d=b.getElementsByTagName("span")[0],d&&(null!=d.textContent?d.textContent=this.options.dictFallbackMessage:null!=d.innerText&&(d.innerText=this.options.dictFallbackMessage)),this.element.appendChild(this.getFallbackForm())},resize:function(a){var b,c,d;return b={srcX:0,srcY:0,srcWidth:a.width,srcHeight:a.height},c=a.width/a.height,b.optWidth=this.options.thumbnailWidth,b.optHeight=this.options.thumbnailHeight,null==b.optWidth&&null==b.optHeight?(b.optWidth=b.srcWidth,b.optHeight=b.srcHeight):null==b.optWidth?b.optWidth=c*b.optHeight:null==b.optHeight&&(b.optHeight=1/c*b.optWidth),d=b.optWidth/b.optHeight,a.height<b.optHeight||a.width<b.optWidth?(b.trgHeight=b.srcHeight,b.trgWidth=b.srcWidth):c>d?(b.srcHeight=a.height,b.srcWidth=b.srcHeight*d):(b.srcWidth=a.width,b.srcHeight=b.srcWidth/d),b.srcX=(a.width-b.srcWidth)/2,b.srcY=(a.height-b.srcHeight)/2,b},drop:function(){return this.element.classList.remove("dz-drag-hover")},dragstart:g,dragend:function(){return this.element.classList.remove("dz-drag-hover")},dragenter:function(){return this.element.classList.add("dz-drag-hover")},dragover:function(){return this.element.classList.add("dz-drag-hover")},dragleave:function(){return this.element.classList.remove("dz-drag-hover")},paste:g,reset:function(){return this.element.classList.remove("dz-started")},addedfile:function(a){var b,d,e,f,g,h,i,j,k,l,m,n,o;if(this.element===this.previewsContainer&&this.element.classList.add("dz-started"),this.previewsContainer){for(a.previewElement=c.createElement(this.options.previewTemplate.trim()),a.previewTemplate=a.previewElement,this.previewsContainer.appendChild(a.previewElement),l=a.previewElement.querySelectorAll("[data-dz-name]"),f=0,i=l.length;i>f;f++)b=l[f],b.textContent=a.name;for(m=a.previewElement.querySelectorAll("[data-dz-size]"),g=0,j=m.length;j>g;g++)b=m[g],b.innerHTML=this.filesize(a.size);for(this.options.addRemoveLinks&&(a._removeLink=c.createElement('<a class="dz-remove" href="javascript:undefined;" data-dz-remove>'+this.options.dictRemoveFile+"</a>"),a.previewElement.appendChild(a._removeLink)),d=function(b){return function(d){return d.preventDefault(),d.stopPropagation(),a.status===c.UPLOADING?c.confirm(b.options.dictCancelUploadConfirmation,function(){return b.removeFile(a)}):b.options.dictRemoveFileConfirmation?c.confirm(b.options.dictRemoveFileConfirmation,function(){return b.removeFile(a)}):b.removeFile(a)}}(this),n=a.previewElement.querySelectorAll("[data-dz-remove]"),o=[],h=0,k=n.length;k>h;h++)e=n[h],o.push(e.addEventListener("click",d));return o}},removedfile:function(a){var b;return a.previewElement&&null!=(b=a.previewElement)&&b.parentNode.removeChild(a.previewElement),this._updateMaxFilesReachedClass()},thumbnail:function(a,b){var c,d,e,f;if(a.previewElement){for(a.previewElement.classList.remove("dz-file-preview"),f=a.previewElement.querySelectorAll("[data-dz-thumbnail]"),d=0,e=f.length;e>d;d++)c=f[d],c.alt=a.name,c.src=b;return setTimeout(function(){return function(){return a.previewElement.classList.add("dz-image-preview")}}(this),1)}},error:function(a,b){var c,d,e,f,g;if(a.previewElement){for(a.previewElement.classList.add("dz-error"),"String"!=typeof b&&b.error&&(b=b.error),f=a.previewElement.querySelectorAll("[data-dz-errormessage]"),g=[],d=0,e=f.length;e>d;d++)c=f[d],g.push(c.textContent=b);return g}},errormultiple:g,processing:function(a){return a.previewElement&&(a.previewElement.classList.add("dz-processing"),a._removeLink)?a._removeLink.textContent=this.options.dictCancelUpload:void 0},processingmultiple:g,uploadprogress:function(a,b){var c,d,e,f,g;if(a.previewElement){for(f=a.previewElement.querySelectorAll("[data-dz-uploadprogress]"),g=[],d=0,e=f.length;e>d;d++)c=f[d],g.push("PROGRESS"===c.nodeName?c.value=b:c.style.width=""+b+"%");return g}},totaluploadprogress:g,sending:g,sendingmultiple:g,success:function(a){return a.previewElement?a.previewElement.classList.add("dz-success"):void 0},successmultiple:g,canceled:function(a){return this.emit("error",a,"Upload canceled.")},canceledmultiple:g,complete:function(a){return a._removeLink&&(a._removeLink.textContent=this.options.dictRemoveFile),a.previewElement?a.previewElement.classList.add("dz-complete"):void 0},completemultiple:g,maxfilesexceeded:g,maxfilesreached:g,queuecomplete:g,addedfiles:g,previewTemplate:'<div class="dz-preview dz-file-preview">\n  <div class="dz-image"><img data-dz-thumbnail /></div>\n  <div class="dz-details">\n    <div class="dz-size"><span data-dz-size></span></div>\n    <div class="dz-filename"><span data-dz-name></span></div>\n  </div>\n  <div class="dz-progress"><span class="dz-upload" data-dz-uploadprogress></span></div>\n  <div class="dz-error-message"><span data-dz-errormessage></span></div>\n  <div class="dz-success-mark">\n    <svg width="54px" height="54px" viewBox="0 0 54 54" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">\n      <title>Check</title>\n      <defs></defs>\n      <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">\n        <path d="M23.5,31.8431458 L17.5852419,25.9283877 C16.0248253,24.3679711 13.4910294,24.366835 11.9289322,25.9289322 C10.3700136,27.4878508 10.3665912,30.0234455 11.9283877,31.5852419 L20.4147581,40.0716123 C20.5133999,40.1702541 20.6159315,40.2626649 20.7218615,40.3488435 C22.2835669,41.8725651 24.794234,41.8626202 26.3461564,40.3106978 L43.3106978,23.3461564 C44.8771021,21.7797521 44.8758057,19.2483887 43.3137085,17.6862915 C41.7547899,16.1273729 39.2176035,16.1255422 37.6538436,17.6893022 L23.5,31.8431458 Z M27,53 C41.3594035,53 53,41.3594035 53,27 C53,12.6405965 41.3594035,1 27,1 C12.6405965,1 1,12.6405965 1,27 C1,41.3594035 12.6405965,53 27,53 Z" id="Oval-2" stroke-opacity="0.198794158" stroke="#747474" fill-opacity="0.816519475" fill="#FFFFFF" sketch:type="MSShapeGroup"></path>\n      </g>\n    </svg>\n  </div>\n  <div class="dz-error-mark">\n    <svg width="54px" height="54px" viewBox="0 0 54 54" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">\n      <title>Error</title>\n      <defs></defs>\n      <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">\n        <g id="Check-+-Oval-2" sketch:type="MSLayerGroup" stroke="#747474" stroke-opacity="0.198794158" fill="#FFFFFF" fill-opacity="0.816519475">\n          <path d="M32.6568542,29 L38.3106978,23.3461564 C39.8771021,21.7797521 39.8758057,19.2483887 38.3137085,17.6862915 C36.7547899,16.1273729 34.2176035,16.1255422 32.6538436,17.6893022 L27,23.3431458 L21.3461564,17.6893022 C19.7823965,16.1255422 17.2452101,16.1273729 15.6862915,17.6862915 C14.1241943,19.2483887 14.1228979,21.7797521 15.6893022,23.3461564 L21.3431458,29 L15.6893022,34.6538436 C14.1228979,36.2202479 14.1241943,38.7516113 15.6862915,40.3137085 C17.2452101,41.8726271 19.7823965,41.8744578 21.3461564,40.3106978 L27,34.6568542 L32.6538436,40.3106978 C34.2176035,41.8744578 36.7547899,41.8726271 38.3137085,40.3137085 C39.8758057,38.7516113 39.8771021,36.2202479 38.3106978,34.6538436 L32.6568542,29 Z M27,53 C41.3594035,53 53,41.3594035 53,27 C53,12.6405965 41.3594035,1 27,1 C12.6405965,1 1,12.6405965 1,27 C1,41.3594035 12.6405965,53 27,53 Z" id="Oval-2" sketch:type="MSShapeGroup"></path>\n        </g>\n      </g>\n    </svg>\n  </div>\n</div>'},d=function(){var a,b,c,d,e,f,g;for(d=arguments[0],c=2<=arguments.length?i.call(arguments,1):[],f=0,g=c.length;g>f;f++){b=c[f];for(a in b)e=b[a],d[a]=e}return d},c.prototype.getAcceptedFiles=function(){var a,b,c,d,e;for(d=this.files,e=[],b=0,c=d.length;c>b;b++)a=d[b],a.accepted&&e.push(a);return e},c.prototype.getRejectedFiles=function(){var a,b,c,d,e;for(d=this.files,e=[],b=0,c=d.length;c>b;b++)a=d[b],a.accepted||e.push(a);return e},c.prototype.getFilesWithStatus=function(a){var b,c,d,e,f;for(e=this.files,f=[],c=0,d=e.length;d>c;c++)b=e[c],b.status===a&&f.push(b);return f},c.prototype.getQueuedFiles=function(){return this.getFilesWithStatus(c.QUEUED)},c.prototype.getUploadingFiles=function(){return this.getFilesWithStatus(c.UPLOADING)},c.prototype.getAddedFiles=function(){return this.getFilesWithStatus(c.ADDED)},c.prototype.getActiveFiles=function(){var a,b,d,e,f;for(e=this.files,f=[],b=0,d=e.length;d>b;b++)a=e[b],(a.status===c.UPLOADING||a.status===c.QUEUED)&&f.push(a);return f},c.prototype.init=function(){var a,b,d,e,f,g,h;for("form"===this.element.tagName&&this.element.setAttribute("enctype","multipart/form-data"),this.element.classList.contains("dropzone")&&!this.element.querySelector(".dz-message")&&this.element.appendChild(c.createElement('<div class="dz-default dz-message"><span>'+this.options.dictDefaultMessage+"</span></div>")),this.clickableElements.length&&(d=function(a){return function(){return a.hiddenFileInput&&a.hiddenFileInput.parentNode.removeChild(a.hiddenFileInput),a.hiddenFileInput=document.createElement("input"),a.hiddenFileInput.setAttribute("type","file"),(null==a.options.maxFiles||a.options.maxFiles>1)&&a.hiddenFileInput.setAttribute("multiple","multiple"),a.hiddenFileInput.className="dz-hidden-input",null!=a.options.acceptedFiles&&a.hiddenFileInput.setAttribute("accept",a.options.acceptedFiles),null!=a.options.capture&&a.hiddenFileInput.setAttribute("capture",a.options.capture),a.hiddenFileInput.style.visibility="hidden",a.hiddenFileInput.style.position="absolute",a.hiddenFileInput.style.top="0",a.hiddenFileInput.style.left="0",a.hiddenFileInput.style.height="0",a.hiddenFileInput.style.width="0",document.querySelector(a.options.hiddenInputContainer).appendChild(a.hiddenFileInput),a.hiddenFileInput.addEventListener("change",function(){var b,c,e,f;if(c=a.hiddenFileInput.files,c.length)for(e=0,f=c.length;f>e;e++)b=c[e],a.addFile(b);return a.emit("addedfiles",c),d()})}}(this))(),this.URL=null!=(g=window.URL)?g:window.webkitURL,h=this.events,e=0,f=h.length;f>e;e++)a=h[e],this.on(a,this.options[a]);return this.on("uploadprogress",function(a){return function(){return a.updateTotalUploadProgress()}}(this)),this.on("removedfile",function(a){return function(){return a.updateTotalUploadProgress()}}(this)),this.on("canceled",function(a){return function(b){return a.emit("complete",b)}}(this)),this.on("complete",function(a){return function(){return 0===a.getAddedFiles().length&&0===a.getUploadingFiles().length&&0===a.getQueuedFiles().length?setTimeout(function(){return a.emit("queuecomplete")},0):void 0}}(this)),b=function(a){return a.stopPropagation(),a.preventDefault?a.preventDefault():a.returnValue=!1},this.listeners=[{element:this.element,events:{dragstart:function(a){return function(b){return a.emit("dragstart",b)}}(this),dragenter:function(a){return function(c){return b(c),a.emit("dragenter",c)}}(this),dragover:function(a){return function(c){var d;try{d=c.dataTransfer.effectAllowed}catch(e){}return c.dataTransfer.dropEffect="move"===d||"linkMove"===d?"move":"copy",b(c),a.emit("dragover",c)}}(this),dragleave:function(a){return function(b){return a.emit("dragleave",b)}}(this),drop:function(a){return function(c){return b(c),a.drop(c)}}(this),dragend:function(a){return function(b){return a.emit("dragend",b)}}(this)}}],this.clickableElements.forEach(function(a){return function(b){return a.listeners.push({element:b,events:{click:function(d){return(b!==a.element||d.target===a.element||c.elementInside(d.target,a.element.querySelector(".dz-message")))&&a.hiddenFileInput.click(),!0}}})}}(this)),this.enable(),this.options.init.call(this)},c.prototype.destroy=function(){var a;return this.disable(),this.removeAllFiles(!0),(null!=(a=this.hiddenFileInput)?a.parentNode:void 0)&&(this.hiddenFileInput.parentNode.removeChild(this.hiddenFileInput),this.hiddenFileInput=null),delete this.element.dropzone,c.instances.splice(c.instances.indexOf(this),1)},c.prototype.updateTotalUploadProgress=function(){var a,b,c,d,e,f,g,h;if(d=0,c=0,a=this.getActiveFiles(),a.length){for(h=this.getActiveFiles(),f=0,g=h.length;g>f;f++)b=h[f],d+=b.upload.bytesSent,c+=b.upload.total;e=100*d/c}else e=100;return this.emit("totaluploadprogress",e,c,d)},c.prototype._getParamName=function(a){return"function"==typeof this.options.paramName?this.options.paramName(a):""+this.options.paramName+(this.options.uploadMultiple?"["+a+"]":"")},c.prototype.getFallbackForm=function(){var a,b,d,e;return(a=this.getExistingFallback())?a:(d='<div class="dz-fallback">',this.options.dictFallbackText&&(d+="<p>"+this.options.dictFallbackText+"</p>"),d+='<input type="file" name="'+this._getParamName(0)+'" '+(this.options.uploadMultiple?'multiple="multiple"':void 0)+' /><input type="submit" value="Upload!"></div>',b=c.createElement(d),"FORM"!==this.element.tagName?(e=c.createElement('<form action="'+this.options.url+'" enctype="multipart/form-data" method="'+this.options.method+'"></form>'),e.appendChild(b)):(this.element.setAttribute("enctype","multipart/form-data"),this.element.setAttribute("method",this.options.method)),null!=e?e:b)},c.prototype.getExistingFallback=function(){var a,b,c,d,e,f;for(b=function(a){var b,c,d;for(c=0,d=a.length;d>c;c++)if(b=a[c],/(^| )fallback($| )/.test(b.className))return b},f=["div","form"],d=0,e=f.length;e>d;d++)if(c=f[d],a=b(this.element.getElementsByTagName(c)))return a},c.prototype.setupEventListeners=function(){var a,b,c,d,e,f,g;for(f=this.listeners,g=[],d=0,e=f.length;e>d;d++)a=f[d],g.push(function(){var d,e;d=a.events,e=[];for(b in d)c=d[b],e.push(a.element.addEventListener(b,c,!1));return e}());return g},c.prototype.removeEventListeners=function(){var a,b,c,d,e,f,g;for(f=this.listeners,g=[],d=0,e=f.length;e>d;d++)a=f[d],g.push(function(){var d,e;d=a.events,e=[];for(b in d)c=d[b],e.push(a.element.removeEventListener(b,c,!1));return e}());return g},c.prototype.disable=function(){var a,b,c,d,e;for(this.clickableElements.forEach(function(a){return a.classList.remove("dz-clickable")}),this.removeEventListeners(),d=this.files,e=[],b=0,c=d.length;c>b;b++)a=d[b],e.push(this.cancelUpload(a));return e},c.prototype.enable=function(){return this.clickableElements.forEach(function(a){return a.classList.add("dz-clickable")}),this.setupEventListeners()},c.prototype.filesize=function(a){var b,c,d,e,f,g,h,i;if(d=0,e="b",a>0){for(g=["TB","GB","MB","KB","b"],c=h=0,i=g.length;i>h;c=++h)if(f=g[c],b=Math.pow(this.options.filesizeBase,4-c)/10,a>=b){d=a/Math.pow(this.options.filesizeBase,4-c),e=f;break}d=Math.round(10*d)/10}return"<strong>"+d+"</strong> "+e},c.prototype._updateMaxFilesReachedClass=function(){return null!=this.options.maxFiles&&this.getAcceptedFiles().length>=this.options.maxFiles?(this.getAcceptedFiles().length===this.options.maxFiles&&this.emit("maxfilesreached",this.files),this.element.classList.add("dz-max-files-reached")):this.element.classList.remove("dz-max-files-reached")},c.prototype.drop=function(a){var b,c;a.dataTransfer&&(this.emit("drop",a),b=a.dataTransfer.files,this.emit("addedfiles",b),b.length&&(c=a.dataTransfer.items,c&&c.length&&null!=c[0].webkitGetAsEntry?this._addFilesFromItems(c):this.handleFiles(b)))},c.prototype.paste=function(a){var b,c;if(null!=(null!=a&&null!=(c=a.clipboardData)?c.items:void 0))return this.emit("paste",a),b=a.clipboardData.items,b.length?this._addFilesFromItems(b):void 0},c.prototype.handleFiles=function(a){var b,c,d,e;for(e=[],c=0,d=a.length;d>c;c++)b=a[c],e.push(this.addFile(b));return e},c.prototype._addFilesFromItems=function(a){var b,c,d,e,f;for(f=[],d=0,e=a.length;e>d;d++)c=a[d],f.push(null!=c.webkitGetAsEntry&&(b=c.webkitGetAsEntry())?b.isFile?this.addFile(c.getAsFile()):b.isDirectory?this._addFilesFromDirectory(b,b.name):void 0:null!=c.getAsFile?null==c.kind||"file"===c.kind?this.addFile(c.getAsFile()):void 0:void 0);return f},c.prototype._addFilesFromDirectory=function(a,b){var c,d;return c=a.createReader(),d=function(a){return function(c){var d,e,f;for(e=0,f=c.length;f>e;e++)d=c[e],d.isFile?d.file(function(c){return a.options.ignoreHiddenFiles&&"."===c.name.substring(0,1)?void 0:(c.fullPath=""+b+"/"+c.name,a.addFile(c))}):d.isDirectory&&a._addFilesFromDirectory(d,""+b+"/"+d.name)}}(this),c.readEntries(d,function(a){return"undefined"!=typeof console&&null!==console&&"function"==typeof console.log?console.log(a):void 0})},c.prototype.accept=function(a,b){return a.size>1024*this.options.maxFilesize*1024?b(this.options.dictFileTooBig.replace("{{filesize}}",Math.round(a.size/1024/10.24)/100).replace("{{maxFilesize}}",this.options.maxFilesize)):c.isValidFile(a,this.options.acceptedFiles)?null!=this.options.maxFiles&&this.getAcceptedFiles().length>=this.options.maxFiles?(b(this.options.dictMaxFilesExceeded.replace("{{maxFiles}}",this.options.maxFiles)),this.emit("maxfilesexceeded",a)):this.options.accept.call(this,a,b):b(this.options.dictInvalidFileType)},c.prototype.addFile=function(a){return a.upload={progress:0,total:a.size,bytesSent:0},this.files.push(a),a.status=c.ADDED,this.emit("addedfile",a),this._enqueueThumbnail(a),this.accept(a,function(b){return function(c){return c?(a.accepted=!1,b._errorProcessing([a],c)):(a.accepted=!0,b.options.autoQueue&&b.enqueueFile(a)),b._updateMaxFilesReachedClass()}}(this))},c.prototype.enqueueFiles=function(a){var b,c,d;for(c=0,d=a.length;d>c;c++)b=a[c],this.enqueueFile(b);return null},c.prototype.enqueueFile=function(a){if(a.status!==c.ADDED||a.accepted!==!0)throw new Error("This file can't be queued because it has already been processed or was rejected.");return a.status=c.QUEUED,this.options.autoProcessQueue?setTimeout(function(a){return function(){return a.processQueue()}}(this),0):void 0},c.prototype._thumbnailQueue=[],c.prototype._processingThumbnail=!1,c.prototype._enqueueThumbnail=function(a){return this.options.createImageThumbnails&&a.type.match(/image.*/)&&a.size<=1024*this.options.maxThumbnailFilesize*1024?(this._thumbnailQueue.push(a),setTimeout(function(a){return function(){return a._processThumbnailQueue()}}(this),0)):void 0},c.prototype._processThumbnailQueue=function(){return this._processingThumbnail||0===this._thumbnailQueue.length?void 0:(this._processingThumbnail=!0,this.createThumbnail(this._thumbnailQueue.shift(),function(a){return function(){return a._processingThumbnail=!1,a._processThumbnailQueue()}}(this)))},c.prototype.removeFile=function(a){return a.status===c.UPLOADING&&this.cancelUpload(a),this.files=h(this.files,a),this.emit("removedfile",a),0===this.files.length?this.emit("reset"):void 0},c.prototype.removeAllFiles=function(a){var b,d,e,f;for(null==a&&(a=!1),f=this.files.slice(),d=0,e=f.length;e>d;d++)b=f[d],(b.status!==c.UPLOADING||a)&&this.removeFile(b);return null},c.prototype.createThumbnail=function(a,b){var c;return c=new FileReader,c.onload=function(d){return function(){return"image/svg+xml"===a.type?(d.emit("thumbnail",a,c.result),void(null!=b&&b())):d.createThumbnailFromUrl(a,c.result,b)}}(this),c.readAsDataURL(a)},c.prototype.createThumbnailFromUrl=function(a,b,c,d){var e;return e=document.createElement("img"),d&&(e.crossOrigin=d),e.onload=function(b){return function(){var d,g,h,i,j,k,l,m;return a.width=e.width,a.height=e.height,h=b.options.resize.call(b,a),null==h.trgWidth&&(h.trgWidth=h.optWidth),null==h.trgHeight&&(h.trgHeight=h.optHeight),d=document.createElement("canvas"),g=d.getContext("2d"),d.width=h.trgWidth,d.height=h.trgHeight,f(g,e,null!=(j=h.srcX)?j:0,null!=(k=h.srcY)?k:0,h.srcWidth,h.srcHeight,null!=(l=h.trgX)?l:0,null!=(m=h.trgY)?m:0,h.trgWidth,h.trgHeight),i=d.toDataURL("image/png"),b.emit("thumbnail",a,i),null!=c?c():void 0}}(this),null!=c&&(e.onerror=c),e.src=b},c.prototype.processQueue=function(){var a,b,c,d;if(b=this.options.parallelUploads,c=this.getUploadingFiles().length,a=c,!(c>=b)&&(d=this.getQueuedFiles(),d.length>0)){if(this.options.uploadMultiple)return this.processFiles(d.slice(0,b-c));for(;b>a;){if(!d.length)return;this.processFile(d.shift()),a++}}},c.prototype.processFile=function(a){return this.processFiles([a])},c.prototype.processFiles=function(a){var b,d,e;for(d=0,e=a.length;e>d;d++)b=a[d],b.processing=!0,b.status=c.UPLOADING,this.emit("processing",b);return this.options.uploadMultiple&&this.emit("processingmultiple",a),this.uploadFiles(a)},c.prototype._getFilesWithXhr=function(a){var b,c;return c=function(){var c,d,e,f;for(e=this.files,f=[],c=0,d=e.length;d>c;c++)b=e[c],b.xhr===a&&f.push(b);return f}.call(this)},c.prototype.cancelUpload=function(a){var b,d,e,f,g,h,i;if(a.status===c.UPLOADING){for(d=this._getFilesWithXhr(a.xhr),e=0,g=d.length;g>e;e++)b=d[e],b.status=c.CANCELED;for(a.xhr.abort(),f=0,h=d.length;h>f;f++)b=d[f],this.emit("canceled",b);this.options.uploadMultiple&&this.emit("canceledmultiple",d)}else((i=a.status)===c.ADDED||i===c.QUEUED)&&(a.status=c.CANCELED,this.emit("canceled",a),this.options.uploadMultiple&&this.emit("canceledmultiple",[a]));return this.options.autoProcessQueue?this.processQueue():void 0},e=function(){var a,b;return b=arguments[0],a=2<=arguments.length?i.call(arguments,1):[],"function"==typeof b?b.apply(this,a):b},c.prototype.uploadFile=function(a){return this.uploadFiles([a])},c.prototype.uploadFiles=function(a){var b,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L;for(w=new XMLHttpRequest,x=0,B=a.length;B>x;x++)b=a[x],b.xhr=w;p=e(this.options.method,a),u=e(this.options.url,a),w.open(p,u,!0),w.withCredentials=!!this.options.withCredentials,s=null,g=function(c){return function(){var d,e,f;for(f=[],d=0,e=a.length;e>d;d++)b=a[d],f.push(c._errorProcessing(a,s||c.options.dictResponseError.replace("{{statusCode}}",w.status),w));return f}}(this),t=function(c){return function(d){var e,f,g,h,i,j,k,l,m;if(null!=d)for(f=100*d.loaded/d.total,g=0,j=a.length;j>g;g++)b=a[g],b.upload={progress:f,total:d.total,bytesSent:d.loaded};else{for(e=!0,f=100,h=0,k=a.length;k>h;h++)b=a[h],(100!==b.upload.progress||b.upload.bytesSent!==b.upload.total)&&(e=!1),b.upload.progress=f,b.upload.bytesSent=b.upload.total;if(e)return}for(m=[],i=0,l=a.length;l>i;i++)b=a[i],m.push(c.emit("uploadprogress",b,f,b.upload.bytesSent));return m}}(this),w.onload=function(b){return function(d){var e;if(a[0].status!==c.CANCELED&&4===w.readyState){if(s=w.responseText,w.getResponseHeader("content-type")&&~w.getResponseHeader("content-type").indexOf("application/json"))try{s=JSON.parse(s)}catch(f){d=f,s="Invalid JSON response from server."}return t(),200<=(e=w.status)&&300>e?b._finished(a,s,d):g()}}}(this),w.onerror=function(){return function(){return a[0].status!==c.CANCELED?g():void 0}}(this),r=null!=(G=w.upload)?G:w,r.onprogress=t,j={Accept:"application/json","Cache-Control":"no-cache","X-Requested-With":"XMLHttpRequest"},this.options.headers&&d(j,this.options.headers);for(h in j)i=j[h],i&&w.setRequestHeader(h,i);if(f=new FormData,this.options.params){H=this.options.params;for(o in H)v=H[o],f.append(o,v)}for(y=0,C=a.length;C>y;y++)b=a[y],this.emit("sending",b,w,f);if(this.options.uploadMultiple&&this.emit("sendingmultiple",a,w,f),"FORM"===this.element.tagName)for(I=this.element.querySelectorAll("input, textarea, select, button"),z=0,D=I.length;D>z;z++)if(l=I[z],m=l.getAttribute("name"),n=l.getAttribute("type"),"SELECT"===l.tagName&&l.hasAttribute("multiple"))for(J=l.options,A=0,E=J.length;E>A;A++)q=J[A],q.selected&&f.append(m,q.value);else(!n||"checkbox"!==(K=n.toLowerCase())&&"radio"!==K||l.checked)&&f.append(m,l.value);for(k=F=0,L=a.length-1;L>=0?L>=F:F>=L;k=L>=0?++F:--F)f.append(this._getParamName(k),a[k],a[k].name);return this.submitRequest(w,f,a)},c.prototype.submitRequest=function(a,b){return a.send(b)},c.prototype._finished=function(a,b,d){var e,f,g;for(f=0,g=a.length;g>f;f++)e=a[f],e.status=c.SUCCESS,this.emit("success",e,b,d),this.emit("complete",e);return this.options.uploadMultiple&&(this.emit("successmultiple",a,b,d),this.emit("completemultiple",a)),this.options.autoProcessQueue?this.processQueue():void 0},c.prototype._errorProcessing=function(a,b,d){var e,f,g;for(f=0,g=a.length;g>f;f++)e=a[f],e.status=c.ERROR,this.emit("error",e,b,d),this.emit("complete",e);return this.options.uploadMultiple&&(this.emit("errormultiple",a,b,d),this.emit("completemultiple",a)),this.options.autoProcessQueue?this.processQueue():void 0},c}(b),a.version="4.2.0",a.options={},a.optionsForElement=function(b){return b.getAttribute("id")?a.options[c(b.getAttribute("id"))]:void 0},a.instances=[],a.forElement=function(a){if("string"==typeof a&&(a=document.querySelector(a)),null==(null!=a?a.dropzone:void 0))throw new Error("No Dropzone found for given element. This is probably because you're trying to access it before Dropzone had the time to initialize. Use the `init` option to setup any additional observers on your Dropzone.");return a.dropzone},a.autoDiscover=!0,a.discover=function(){var b,c,d,e,f,g;for(document.querySelectorAll?d=document.querySelectorAll(".dropzone"):(d=[],b=function(a){var b,c,e,f;for(f=[],c=0,e=a.length;e>c;c++)b=a[c],f.push(/(^| )dropzone($| )/.test(b.className)?d.push(b):void 0);return f},b(document.getElementsByTagName("div")),b(document.getElementsByTagName("form"))),g=[],e=0,f=d.length;f>e;e++)c=d[e],g.push(a.optionsForElement(c)!==!1?new a(c):void 0);return g},a.blacklistedBrowsers=[/opera.*Macintosh.*version\/12/i],a.isBrowserSupported=function(){var b,c,d,e,f;if(b=!0,window.File&&window.FileReader&&window.FileList&&window.Blob&&window.FormData&&document.querySelector)if("classList"in document.createElement("a"))for(f=a.blacklistedBrowsers,d=0,e=f.length;e>d;d++)c=f[d],c.test(navigator.userAgent)&&(b=!1);else b=!1;else b=!1;return b},h=function(a,b){var c,d,e,f;for(f=[],d=0,e=a.length;e>d;d++)c=a[d],c!==b&&f.push(c);return f},c=function(a){return a.replace(/[\-_](\w)/g,function(a){return a.charAt(1).toUpperCase()})},a.createElement=function(a){var b;return b=document.createElement("div"),b.innerHTML=a,b.childNodes[0]},a.elementInside=function(a,b){if(a===b)return!0;for(;a=a.parentNode;)if(a===b)return!0;return!1},a.getElement=function(a,b){var c;if("string"==typeof a?c=document.querySelector(a):null!=a.nodeType&&(c=a),null==c)throw new Error("Invalid `"+b+"` option provided. Please provide a CSS selector or a plain HTML element.");return c},a.getElements=function(a,b){var c,d,e,f,g,h,i,j;if(a instanceof Array){e=[];try{for(f=0,h=a.length;h>f;f++)d=a[f],e.push(this.getElement(d,b))}catch(k){c=k,e=null}}else if("string"==typeof a)for(e=[],j=document.querySelectorAll(a),g=0,i=j.length;i>g;g++)d=j[g],e.push(d);else null!=a.nodeType&&(e=[a]);if(null==e||!e.length)throw new Error("Invalid `"+b+"` option provided. Please provide a CSS selector, a plain HTML element or a list of those.");return e},a.confirm=function(a,b,c){return window.confirm(a)?b():null!=c?c():void 0},a.isValidFile=function(a,b){var c,d,e,f,g;if(!b)return!0;for(b=b.split(","),d=a.type,c=d.replace(/\/.*$/,""),f=0,g=b.length;g>f;f++)if(e=b[f],e=e.trim(),"."===e.charAt(0)){if(-1!==a.name.toLowerCase().indexOf(e.toLowerCase(),a.name.length-e.length))return!0}else if(/\/\*$/.test(e)){if(c===e.replace(/\/.*$/,""))return!0}else if(d===e)return!0;return!1},"undefined"!=typeof jQuery&&null!==jQuery&&(jQuery.fn.dropzone=function(b){return this.each(function(){return new a(this,b)})}),"undefined"!=typeof module&&null!==module?module.exports=a:window.Dropzone=a,a.ADDED="added",a.QUEUED="queued",a.ACCEPTED=a.QUEUED,a.UPLOADING="uploading",a.PROCESSING=a.UPLOADING,a.CANCELED="canceled",a.ERROR="error",a.SUCCESS="success",e=function(a){var b,c,d,e,f,g,h,i,j,k;
for(h=a.naturalWidth,g=a.naturalHeight,c=document.createElement("canvas"),c.width=1,c.height=g,d=c.getContext("2d"),d.drawImage(a,0,0),e=d.getImageData(0,0,1,g).data,k=0,f=g,i=g;i>k;)b=e[4*(i-1)+3],0===b?f=i:k=i,i=f+k>>1;return j=i/g,0===j?1:j},f=function(a,b,c,d,f,g,h,i,j,k){var l;return l=e(b),a.drawImage(b,c,d,f,g,h,i,j,k/l)},d=function(a,b){var c,d,e,f,g,h,i,j,k;if(e=!1,k=!0,d=a.document,j=d.documentElement,c=d.addEventListener?"addEventListener":"attachEvent",i=d.addEventListener?"removeEventListener":"detachEvent",h=d.addEventListener?"":"on",f=function(c){return"readystatechange"!==c.type||"complete"===d.readyState?(("load"===c.type?a:d)[i](h+c.type,f,!1),!e&&(e=!0)?b.call(a,c.type||c):void 0):void 0},g=function(){var a;try{j.doScroll("left")}catch(b){return a=b,void setTimeout(g,50)}return f("poll")},"complete"!==d.readyState){if(d.createEventObject&&j.doScroll){try{k=!a.frameElement}catch(l){}k&&g()}return d[c](h+"DOMContentLoaded",f,!1),d[c](h+"readystatechange",f,!1),a[c](h+"load",f,!1)}},a._autoDiscoverFunction=function(){return a.autoDiscover?a.discover():void 0},d(window,a._autoDiscoverFunction)}).call(this);;
/*! X-editable - v1.5.0 
* In-place editing with Twitter Bootstrap, jQuery UI or pure jQuery
* http://github.com/vitalets/x-editable
* Copyright (c) 2013 Vitaliy Potapov; Licensed MIT */
!function(a){"use strict";var b=function(b,c){this.options=a.extend({},a.fn.editableform.defaults,c),this.$div=a(b),this.options.scope||(this.options.scope=this)};b.prototype={constructor:b,initInput:function(){this.input=this.options.input,this.value=this.input.str2value(this.options.value),this.input.prerender()},initTemplate:function(){this.$form=a(a.fn.editableform.template)},initButtons:function(){var b=this.$form.find(".editable-buttons");b.append(a.fn.editableform.buttons),"bottom"===this.options.showbuttons&&b.addClass("editable-buttons-bottom")},render:function(){this.$loading=a(a.fn.editableform.loading),this.$div.empty().append(this.$loading),this.initTemplate(),this.options.showbuttons?this.initButtons():this.$form.find(".editable-buttons").remove(),this.showLoading(),this.isSaving=!1,this.$div.triggerHandler("rendering"),this.initInput(),this.$form.find("div.editable-input").append(this.input.$tpl),this.$div.append(this.$form),a.when(this.input.render()).then(a.proxy(function(){if(this.options.showbuttons||this.input.autosubmit(),this.$form.find(".editable-cancel").click(a.proxy(this.cancel,this)),this.input.error)this.error(this.input.error),this.$form.find(".editable-submit").attr("disabled",!0),this.input.$input.attr("disabled",!0),this.$form.submit(function(a){a.preventDefault()});else{this.error(!1),this.input.$input.removeAttr("disabled"),this.$form.find(".editable-submit").removeAttr("disabled");var b=null===this.value||void 0===this.value||""===this.value?this.options.defaultValue:this.value;this.input.value2input(b),this.$form.submit(a.proxy(this.submit,this))}this.$div.triggerHandler("rendered"),this.showForm(),this.input.postrender&&this.input.postrender()},this))},cancel:function(){this.$div.triggerHandler("cancel")},showLoading:function(){var a,b;this.$form?(a=this.$form.outerWidth(),b=this.$form.outerHeight(),a&&this.$loading.width(a),b&&this.$loading.height(b),this.$form.hide()):(a=this.$loading.parent().width(),a&&this.$loading.width(a)),this.$loading.show()},showForm:function(a){this.$loading.hide(),this.$form.show(),a!==!1&&this.input.activate(),this.$div.triggerHandler("show")},error:function(b){var c,d=this.$form.find(".control-group"),e=this.$form.find(".editable-error-block");if(b===!1)d.removeClass(a.fn.editableform.errorGroupClass),e.removeClass(a.fn.editableform.errorBlockClass).empty().hide();else{if(b){c=b.split("\n");for(var f=0;f<c.length;f++)c[f]=a("<div>").text(c[f]).html();b=c.join("<br>")}d.addClass(a.fn.editableform.errorGroupClass),e.addClass(a.fn.editableform.errorBlockClass).html(b).show()}},submit:function(b){b.stopPropagation(),b.preventDefault();var c,d=this.input.input2value();if(c=this.validate(d))return this.error(c),this.showForm(),void 0;if(!this.options.savenochange&&this.input.value2str(d)==this.input.value2str(this.value))return this.$div.triggerHandler("nochange"),void 0;var e=this.input.value2submit(d);this.isSaving=!0,a.when(this.save(e)).done(a.proxy(function(a){this.isSaving=!1;var b="function"==typeof this.options.success?this.options.success.call(this.options.scope,a,d):null;return b===!1?(this.error(!1),this.showForm(!1),void 0):"string"==typeof b?(this.error(b),this.showForm(),void 0):(b&&"object"==typeof b&&b.hasOwnProperty("newValue")&&(d=b.newValue),this.error(!1),this.value=d,this.$div.triggerHandler("save",{newValue:d,submitValue:e,response:a}),void 0)},this)).fail(a.proxy(function(a){this.isSaving=!1;var b;b="function"==typeof this.options.error?this.options.error.call(this.options.scope,a,d):"string"==typeof a?a:a.responseText||a.statusText||"Unknown error!",this.error(b),this.showForm()},this))},save:function(b){this.options.pk=a.fn.editableutils.tryParseJson(this.options.pk,!0);var c,d="function"==typeof this.options.pk?this.options.pk.call(this.options.scope):this.options.pk,e=!!("function"==typeof this.options.url||this.options.url&&("always"===this.options.send||"auto"===this.options.send&&null!==d&&void 0!==d));return e?(this.showLoading(),c={name:this.options.name||"",value:b,pk:d},"function"==typeof this.options.params?c=this.options.params.call(this.options.scope,c):(this.options.params=a.fn.editableutils.tryParseJson(this.options.params,!0),a.extend(c,this.options.params)),"function"==typeof this.options.url?this.options.url.call(this.options.scope,c):a.ajax(a.extend({url:this.options.url,data:c,type:"POST"},this.options.ajaxOptions))):void 0},validate:function(a){return void 0===a&&(a=this.value),"function"==typeof this.options.validate?this.options.validate.call(this.options.scope,a):void 0},option:function(a,b){a in this.options&&(this.options[a]=b),"value"===a&&this.setValue(b)},setValue:function(a,b){this.value=b?this.input.str2value(a):a,this.$form&&this.$form.is(":visible")&&this.input.value2input(this.value)}},a.fn.editableform=function(c){var d=arguments;return this.each(function(){var e=a(this),f=e.data("editableform"),g="object"==typeof c&&c;f||e.data("editableform",f=new b(this,g)),"string"==typeof c&&f[c].apply(f,Array.prototype.slice.call(d,1))})},a.fn.editableform.Constructor=b,a.fn.editableform.defaults={type:"text",url:null,params:null,name:null,pk:null,value:null,defaultValue:null,send:"auto",validate:null,success:null,error:null,ajaxOptions:null,showbuttons:!0,scope:null,savenochange:!1},a.fn.editableform.template='<form class="form-inline editableform"><div class="control-group"><div><div class="editable-input"></div><div class="editable-buttons"></div></div><div class="editable-error-block"></div></div></form>',a.fn.editableform.loading='<div class="editableform-loading"></div>',a.fn.editableform.buttons='<button type="submit" class="editable-submit">ok</button><button type="button" class="editable-cancel">cancel</button>',a.fn.editableform.errorGroupClass=null,a.fn.editableform.errorBlockClass="editable-error",a.fn.editableform.engine="jquery"}(window.jQuery),function(a){"use strict";a.fn.editableutils={inherit:function(a,b){var c=function(){};c.prototype=b.prototype,a.prototype=new c,a.prototype.constructor=a,a.superclass=b.prototype},setCursorPosition:function(a,b){if(a.setSelectionRange)a.setSelectionRange(b,b);else if(a.createTextRange){var c=a.createTextRange();c.collapse(!0),c.moveEnd("character",b),c.moveStart("character",b),c.select()}},tryParseJson:function(a,b){if("string"==typeof a&&a.length&&a.match(/^[\{\[].*[\}\]]$/))if(b)try{a=new Function("return "+a)()}catch(c){}finally{return a}else a=new Function("return "+a)();return a},sliceObj:function(b,c,d){var e,f,g={};if(!a.isArray(c)||!c.length)return g;for(var h=0;h<c.length;h++)e=c[h],b.hasOwnProperty(e)&&(g[e]=b[e]),d!==!0&&(f=e.toLowerCase(),b.hasOwnProperty(f)&&(g[e]=b[f]));return g},getConfigData:function(b){var c={};return a.each(b.data(),function(a,b){("object"!=typeof b||b&&"object"==typeof b&&(b.constructor===Object||b.constructor===Array))&&(c[a]=b)}),c},objectKeys:function(a){if(Object.keys)return Object.keys(a);if(a!==Object(a))throw new TypeError("Object.keys called on a non-object");var b,c=[];for(b in a)Object.prototype.hasOwnProperty.call(a,b)&&c.push(b);return c},escape:function(b){return a("<div>").text(b).html()},itemsByValue:function(b,c,d){if(!c||null===b)return[];if("function"!=typeof d){var e=d||"value";d=function(a){return a[e]}}var f=a.isArray(b),g=[],h=this;return a.each(c,function(c,e){if(e.children)g=g.concat(h.itemsByValue(b,e.children,d));else if(f)a.grep(b,function(a){return a==(e&&"object"==typeof e?d(e):e)}).length&&g.push(e);else{var i=e&&"object"==typeof e?d(e):e;b==i&&g.push(e)}}),g},createInput:function(b){var c,d,e,f=b.type;return"date"===f&&("inline"===b.mode?a.fn.editabletypes.datefield?f="datefield":a.fn.editabletypes.dateuifield&&(f="dateuifield"):a.fn.editabletypes.date?f="date":a.fn.editabletypes.dateui&&(f="dateui"),"date"!==f||a.fn.editabletypes.date||(f="combodate")),"datetime"===f&&"inline"===b.mode&&(f="datetimefield"),"wysihtml5"!==f||a.fn.editabletypes[f]||(f="textarea"),"function"==typeof a.fn.editabletypes[f]?(c=a.fn.editabletypes[f],d=this.sliceObj(b,this.objectKeys(c.defaults)),e=new c(d)):(a.error("Unknown type: "+f),!1)},supportsTransitions:function(){var a=document.body||document.documentElement,b=a.style,c="transition",d=["Moz","Webkit","Khtml","O","ms"];if("string"==typeof b[c])return!0;c=c.charAt(0).toUpperCase()+c.substr(1);for(var e=0;e<d.length;e++)if("string"==typeof b[d[e]+c])return!0;return!1}}}(window.jQuery),function(a){"use strict";var b=function(a,b){this.init(a,b)},c=function(a,b){this.init(a,b)};b.prototype={containerName:null,containerDataName:null,innerCss:null,containerClass:"editable-container editable-popup",defaults:{},init:function(c,d){this.$element=a(c),this.options=a.extend({},a.fn.editableContainer.defaults,d),this.splitOptions(),this.formOptions.scope=this.$element[0],this.initContainer(),this.delayedHide=!1,this.$element.on("destroyed",a.proxy(function(){this.destroy()},this)),a(document).data("editable-handlers-attached")||(a(document).on("keyup.editable",function(b){27===b.which&&a(".editable-open").editableContainer("hide")}),a(document).on("click.editable",function(c){var d,e=a(c.target),f=[".editable-container",".ui-datepicker-header",".datepicker",".modal-backdrop",".bootstrap-wysihtml5-insert-image-modal",".bootstrap-wysihtml5-insert-link-modal"];if(a.contains(document.documentElement,c.target)&&!e.is(document)){for(d=0;d<f.length;d++)if(e.is(f[d])||e.parents(f[d]).length)return;b.prototype.closeOthers(c.target)}}),a(document).data("editable-handlers-attached",!0))},splitOptions:function(){if(this.containerOptions={},this.formOptions={},!a.fn[this.containerName])throw new Error(this.containerName+" not found. Have you included corresponding js file?");for(var b in this.options)b in this.defaults?this.containerOptions[b]=this.options[b]:this.formOptions[b]=this.options[b]},tip:function(){return this.container()?this.container().$tip:null},container:function(){var a;return this.containerDataName&&(a=this.$element.data(this.containerDataName))?a:a=this.$element.data(this.containerName)},call:function(){this.$element[this.containerName].apply(this.$element,arguments)},initContainer:function(){this.call(this.containerOptions)},renderForm:function(){this.$form.editableform(this.formOptions).on({save:a.proxy(this.save,this),nochange:a.proxy(function(){this.hide("nochange")},this),cancel:a.proxy(function(){this.hide("cancel")},this),show:a.proxy(function(){this.delayedHide?(this.hide(this.delayedHide.reason),this.delayedHide=!1):this.setPosition()},this),rendering:a.proxy(this.setPosition,this),resize:a.proxy(this.setPosition,this),rendered:a.proxy(function(){this.$element.triggerHandler("shown",a(this.options.scope).data("editable"))},this)}).editableform("render")},show:function(b){this.$element.addClass("editable-open"),b!==!1&&this.closeOthers(this.$element[0]),this.innerShow(),this.tip().addClass(this.containerClass),this.$form,this.$form=a("<div>"),this.tip().is(this.innerCss)?this.tip().append(this.$form):this.tip().find(this.innerCss).append(this.$form),this.renderForm()},hide:function(a){if(this.tip()&&this.tip().is(":visible")&&this.$element.hasClass("editable-open")){if(this.$form.data("editableform").isSaving)return this.delayedHide={reason:a},void 0;this.delayedHide=!1,this.$element.removeClass("editable-open"),this.innerHide(),this.$element.triggerHandler("hidden",a||"manual")}},innerShow:function(){},innerHide:function(){},toggle:function(a){this.container()&&this.tip()&&this.tip().is(":visible")?this.hide():this.show(a)},setPosition:function(){},save:function(a,b){this.$element.triggerHandler("save",b),this.hide("save")},option:function(a,b){this.options[a]=b,a in this.containerOptions?(this.containerOptions[a]=b,this.setContainerOption(a,b)):(this.formOptions[a]=b,this.$form&&this.$form.editableform("option",a,b))},setContainerOption:function(a,b){this.call("option",a,b)},destroy:function(){this.hide(),this.innerDestroy(),this.$element.off("destroyed"),this.$element.removeData("editableContainer")},innerDestroy:function(){},closeOthers:function(b){a(".editable-open").each(function(c,d){if(d!==b&&!a(d).find(b).length){var e=a(d),f=e.data("editableContainer");f&&("cancel"===f.options.onblur?e.data("editableContainer").hide("onblur"):"submit"===f.options.onblur&&e.data("editableContainer").tip().find("form").submit())}})},activate:function(){this.tip&&this.tip().is(":visible")&&this.$form&&this.$form.data("editableform").input.activate()}},a.fn.editableContainer=function(d){var e=arguments;return this.each(function(){var f=a(this),g="editableContainer",h=f.data(g),i="object"==typeof d&&d,j="inline"===i.mode?c:b;h||f.data(g,h=new j(this,i)),"string"==typeof d&&h[d].apply(h,Array.prototype.slice.call(e,1))})},a.fn.editableContainer.Popup=b,a.fn.editableContainer.Inline=c,a.fn.editableContainer.defaults={value:null,placement:"top",autohide:!0,onblur:"cancel",anim:!1,mode:"popup"},jQuery.event.special.destroyed={remove:function(a){a.handler&&a.handler()}}}(window.jQuery),function(a){"use strict";a.extend(a.fn.editableContainer.Inline.prototype,a.fn.editableContainer.Popup.prototype,{containerName:"editableform",innerCss:".editable-inline",containerClass:"editable-container editable-inline",initContainer:function(){this.$tip=a("<span></span>"),this.options.anim||(this.options.anim=0)},splitOptions:function(){this.containerOptions={},this.formOptions=this.options},tip:function(){return this.$tip},innerShow:function(){this.$element.hide(),this.tip().insertAfter(this.$element).show()},innerHide:function(){this.$tip.hide(this.options.anim,a.proxy(function(){this.$element.show(),this.innerDestroy()},this))},innerDestroy:function(){this.tip()&&this.tip().empty().remove()}})}(window.jQuery),function(a){"use strict";var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.editable.defaults,c,a.fn.editableutils.getConfigData(this.$element)),this.options.selector?this.initLive():this.init(),this.options.highlight&&!a.fn.editableutils.supportsTransitions()&&(this.options.highlight=!1)};b.prototype={constructor:b,init:function(){var b,c=!1;if(this.options.name=this.options.name||this.$element.attr("id"),this.options.scope=this.$element[0],this.input=a.fn.editableutils.createInput(this.options),this.input){switch(void 0===this.options.value||null===this.options.value?(this.value=this.input.html2value(a.trim(this.$element.html())),c=!0):(this.options.value=a.fn.editableutils.tryParseJson(this.options.value,!0),this.value="string"==typeof this.options.value?this.input.str2value(this.options.value):this.options.value),this.$element.addClass("editable"),"textarea"===this.input.type&&this.$element.addClass("editable-pre-wrapped"),"manual"!==this.options.toggle?(this.$element.addClass("editable-click"),this.$element.on(this.options.toggle+".editable",a.proxy(function(a){if(this.options.disabled||a.preventDefault(),"mouseenter"===this.options.toggle)this.show();else{var b="click"!==this.options.toggle;this.toggle(b)}},this))):this.$element.attr("tabindex",-1),"function"==typeof this.options.display&&(this.options.autotext="always"),this.options.autotext){case"always":b=!0;break;case"auto":b=!a.trim(this.$element.text()).length&&null!==this.value&&void 0!==this.value&&!c;break;default:b=!1}a.when(b?this.render():!0).then(a.proxy(function(){this.options.disabled?this.disable():this.enable(),this.$element.triggerHandler("init",this)},this))}},initLive:function(){var b=this.options.selector;this.options.selector=!1,this.options.autotext="never",this.$element.on(this.options.toggle+".editable",b,a.proxy(function(b){var c=a(b.target);c.data("editable")||(c.hasClass(this.options.emptyclass)&&c.empty(),c.editable(this.options).trigger(b))},this))},render:function(a){return this.options.display!==!1?this.input.value2htmlFinal?this.input.value2html(this.value,this.$element[0],this.options.display,a):"function"==typeof this.options.display?this.options.display.call(this.$element[0],this.value,a):this.input.value2html(this.value,this.$element[0]):void 0},enable:function(){this.options.disabled=!1,this.$element.removeClass("editable-disabled"),this.handleEmpty(this.isEmpty),"manual"!==this.options.toggle&&"-1"===this.$element.attr("tabindex")&&this.$element.removeAttr("tabindex")},disable:function(){this.options.disabled=!0,this.hide(),this.$element.addClass("editable-disabled"),this.handleEmpty(this.isEmpty),this.$element.attr("tabindex",-1)},toggleDisabled:function(){this.options.disabled?this.enable():this.disable()},option:function(b,c){return b&&"object"==typeof b?(a.each(b,a.proxy(function(b,c){this.option(a.trim(b),c)},this)),void 0):(this.options[b]=c,"disabled"===b?c?this.disable():this.enable():("value"===b&&this.setValue(c),this.container&&this.container.option(b,c),this.input.option&&this.input.option(b,c),void 0))},handleEmpty:function(b){this.options.display!==!1&&(this.isEmpty=void 0!==b?b:"function"==typeof this.input.isEmpty?this.input.isEmpty(this.$element):""===a.trim(this.$element.html()),this.options.disabled?this.isEmpty&&(this.$element.empty(),this.options.emptyclass&&this.$element.removeClass(this.options.emptyclass)):this.isEmpty?(this.$element.html(this.options.emptytext),this.options.emptyclass&&this.$element.addClass(this.options.emptyclass)):this.options.emptyclass&&this.$element.removeClass(this.options.emptyclass))},show:function(b){if(!this.options.disabled){if(this.container){if(this.container.tip().is(":visible"))return}else{var c=a.extend({},this.options,{value:this.value,input:this.input});this.$element.editableContainer(c),this.$element.on("save.internal",a.proxy(this.save,this)),this.container=this.$element.data("editableContainer")}this.container.show(b)}},hide:function(){this.container&&this.container.hide()},toggle:function(a){this.container&&this.container.tip().is(":visible")?this.hide():this.show(a)},save:function(a,b){if(this.options.unsavedclass){var c=!1;c=c||"function"==typeof this.options.url,c=c||this.options.display===!1,c=c||void 0!==b.response,c=c||this.options.savenochange&&this.input.value2str(this.value)!==this.input.value2str(b.newValue),c?this.$element.removeClass(this.options.unsavedclass):this.$element.addClass(this.options.unsavedclass)}if(this.options.highlight){var d=this.$element,e=d.css("background-color");d.css("background-color",this.options.highlight),setTimeout(function(){"transparent"===e&&(e=""),d.css("background-color",e),d.addClass("editable-bg-transition"),setTimeout(function(){d.removeClass("editable-bg-transition")},1700)},10)}this.setValue(b.newValue,!1,b.response)},validate:function(){return"function"==typeof this.options.validate?this.options.validate.call(this,this.value):void 0},setValue:function(b,c,d){this.value=c?this.input.str2value(b):b,this.container&&this.container.option("value",this.value),a.when(this.render(d)).then(a.proxy(function(){this.handleEmpty()},this))},activate:function(){this.container&&this.container.activate()},destroy:function(){this.disable(),this.container&&this.container.destroy(),this.input.destroy(),"manual"!==this.options.toggle&&(this.$element.removeClass("editable-click"),this.$element.off(this.options.toggle+".editable")),this.$element.off("save.internal"),this.$element.removeClass("editable editable-open editable-disabled"),this.$element.removeData("editable")}},a.fn.editable=function(c){var d={},e=arguments,f="editable";switch(c){case"validate":return this.each(function(){var b,c=a(this),e=c.data(f);e&&(b=e.validate())&&(d[e.options.name]=b)}),d;case"getValue":return 2===arguments.length&&arguments[1]===!0?d=this.eq(0).data(f).value:this.each(function(){var b=a(this),c=b.data(f);c&&void 0!==c.value&&null!==c.value&&(d[c.options.name]=c.input.value2submit(c.value))}),d;case"submit":var g,h=arguments[1]||{},i=this,j=this.editable("validate");return a.isEmptyObject(j)?(g=this.editable("getValue"),h.data&&a.extend(g,h.data),a.ajax(a.extend({url:h.url,data:g,type:"POST"},h.ajaxOptions)).success(function(a){"function"==typeof h.success&&h.success.call(i,a,h)}).error(function(){"function"==typeof h.error&&h.error.apply(i,arguments)})):"function"==typeof h.error&&h.error.call(i,j),this}return this.each(function(){var d=a(this),g=d.data(f),h="object"==typeof c&&c;return h&&h.selector?(g=new b(this,h),void 0):(g||d.data(f,g=new b(this,h)),"string"==typeof c&&g[c].apply(g,Array.prototype.slice.call(e,1)),void 0)})},a.fn.editable.defaults={type:"text",disabled:!1,toggle:"click",emptytext:"Empty",autotext:"auto",value:null,display:null,emptyclass:"editable-empty",unsavedclass:"editable-unsaved",selector:null,highlight:"#FFFF80"}}(window.jQuery),function(a){"use strict";a.fn.editabletypes={};var b=function(){};b.prototype={init:function(b,c,d){this.type=b,this.options=a.extend({},d,c)},prerender:function(){this.$tpl=a(this.options.tpl),this.$input=this.$tpl,this.$clear=null,this.error=null},render:function(){},value2html:function(b,c){a(c)[this.options.escape?"text":"html"](a.trim(b))},html2value:function(b){return a("<div>").html(b).text()},value2str:function(a){return a},str2value:function(a){return a},value2submit:function(a){return a},value2input:function(a){this.$input.val(a)},input2value:function(){return this.$input.val()},activate:function(){this.$input.is(":visible")&&this.$input.focus()},clear:function(){this.$input.val(null)},escape:function(b){return a("<div>").text(b).html()},autosubmit:function(){},destroy:function(){},setClass:function(){this.options.inputclass&&this.$input.addClass(this.options.inputclass)},setAttr:function(a){void 0!==this.options[a]&&null!==this.options[a]&&this.$input.attr(a,this.options[a])},option:function(a,b){this.options[a]=b}},b.defaults={tpl:"",inputclass:null,escape:!0,scope:null,showbuttons:!0},a.extend(a.fn.editabletypes,{abstractinput:b})}(window.jQuery),function(a){"use strict";var b=function(){};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{render:function(){var b=a.Deferred();return this.error=null,this.onSourceReady(function(){this.renderList(),b.resolve()},function(){this.error=this.options.sourceError,b.resolve()}),b.promise()},html2value:function(){return null},value2html:function(b,c,d,e){var f=a.Deferred(),g=function(){"function"==typeof d?d.call(c,b,this.sourceData,e):this.value2htmlFinal(b,c),f.resolve()};return null===b?g.call(this):this.onSourceReady(g,function(){f.resolve()}),f.promise()},onSourceReady:function(b,c){var d;if(a.isFunction(this.options.source)?(d=this.options.source.call(this.options.scope),this.sourceData=null):d=this.options.source,this.options.sourceCache&&a.isArray(this.sourceData))return b.call(this),void 0;try{d=a.fn.editableutils.tryParseJson(d,!1)}catch(e){return c.call(this),void 0}if("string"==typeof d){if(this.options.sourceCache){var f,g=d;if(a(document).data(g)||a(document).data(g,{}),f=a(document).data(g),f.loading===!1&&f.sourceData)return this.sourceData=f.sourceData,this.doPrepend(),b.call(this),void 0;if(f.loading===!0)return f.callbacks.push(a.proxy(function(){this.sourceData=f.sourceData,this.doPrepend(),b.call(this)},this)),f.err_callbacks.push(a.proxy(c,this)),void 0;f.loading=!0,f.callbacks=[],f.err_callbacks=[]}var h=a.extend({url:d,type:"get",cache:!1,dataType:"json",success:a.proxy(function(d){f&&(f.loading=!1),this.sourceData=this.makeArray(d),a.isArray(this.sourceData)?(f&&(f.sourceData=this.sourceData,a.each(f.callbacks,function(){this.call()})),this.doPrepend(),b.call(this)):(c.call(this),f&&a.each(f.err_callbacks,function(){this.call()}))},this),error:a.proxy(function(){c.call(this),f&&(f.loading=!1,a.each(f.err_callbacks,function(){this.call()}))},this)},this.options.sourceOptions);a.ajax(h)}else this.sourceData=this.makeArray(d),a.isArray(this.sourceData)?(this.doPrepend(),b.call(this)):c.call(this)},doPrepend:function(){null!==this.options.prepend&&void 0!==this.options.prepend&&(a.isArray(this.prependData)||(a.isFunction(this.options.prepend)&&(this.options.prepend=this.options.prepend.call(this.options.scope)),this.options.prepend=a.fn.editableutils.tryParseJson(this.options.prepend,!0),"string"==typeof this.options.prepend&&(this.options.prepend={"":this.options.prepend}),this.prependData=this.makeArray(this.options.prepend)),a.isArray(this.prependData)&&a.isArray(this.sourceData)&&(this.sourceData=this.prependData.concat(this.sourceData)))},renderList:function(){},value2htmlFinal:function(){},makeArray:function(b){var c,d,e,f,g=[];if(!b||"string"==typeof b)return null;if(a.isArray(b)){f=function(a,b){return d={value:a,text:b},c++>=2?!1:void 0};for(var h=0;h<b.length;h++)e=b[h],"object"==typeof e?(c=0,a.each(e,f),1===c?g.push(d):c>1&&(e.children&&(e.children=this.makeArray(e.children)),g.push(e))):g.push({value:e,text:e})}else a.each(b,function(a,b){g.push({value:a,text:b})});return g},option:function(a,b){this.options[a]=b,"source"===a&&(this.sourceData=null),"prepend"===a&&(this.prependData=null)}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{source:null,prepend:!1,sourceError:"Error when loading list",sourceCache:!0,sourceOptions:null}),a.fn.editabletypes.list=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("text",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{render:function(){this.renderClear(),this.setClass(),this.setAttr("placeholder")},activate:function(){this.$input.is(":visible")&&(this.$input.focus(),a.fn.editableutils.setCursorPosition(this.$input.get(0),this.$input.val().length),this.toggleClear&&this.toggleClear())},renderClear:function(){this.options.clear&&(this.$clear=a('<span class="editable-clear-x"></span>'),this.$input.after(this.$clear).css("padding-right",24).keyup(a.proxy(function(b){if(!~a.inArray(b.keyCode,[40,38,9,13,27])){clearTimeout(this.t);var c=this;this.t=setTimeout(function(){c.toggleClear(b)},100)}},this)).parent().css("position","relative"),this.$clear.click(a.proxy(this.clear,this)))},postrender:function(){},toggleClear:function(){if(this.$clear){var a=this.$input.val().length,b=this.$clear.is(":visible");a&&!b&&this.$clear.show(),!a&&b&&this.$clear.hide()}},clear:function(){this.$clear.hide(),this.$input.val("").focus()}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{tpl:'<input type="text">',placeholder:null,clear:!0}),a.fn.editabletypes.text=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("textarea",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{render:function(){this.setClass(),this.setAttr("placeholder"),this.setAttr("rows"),this.$input.keydown(function(b){b.ctrlKey&&13===b.which&&a(this).closest("form").submit()})},activate:function(){a.fn.editabletypes.text.prototype.activate.call(this)}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{tpl:"<textarea></textarea>",inputclass:"input-large",placeholder:null,rows:7}),a.fn.editabletypes.textarea=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("select",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.list),a.extend(b.prototype,{renderList:function(){this.$input.empty();var b=function(c,d){var e;if(a.isArray(d))for(var f=0;f<d.length;f++)e={},d[f].children?(e.label=d[f].text,c.append(b(a("<optgroup>",e),d[f].children))):(e.value=d[f].value,d[f].disabled&&(e.disabled=!0),c.append(a("<option>",e).text(d[f].text)));return c};b(this.$input,this.sourceData),this.setClass(),this.$input.on("keydown.editable",function(b){13===b.which&&a(this).closest("form").submit()})},value2htmlFinal:function(b,c){var d="",e=a.fn.editableutils.itemsByValue(b,this.sourceData);e.length&&(d=e[0].text),a.fn.editabletypes.abstractinput.prototype.value2html.call(this,d,c)},autosubmit:function(){this.$input.off("keydown.editable").on("change.editable",function(){a(this).closest("form").submit()})}}),b.defaults=a.extend({},a.fn.editabletypes.list.defaults,{tpl:"<select></select>"}),a.fn.editabletypes.select=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("checklist",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.list),a.extend(b.prototype,{renderList:function(){var b;if(this.$tpl.empty(),a.isArray(this.sourceData)){for(var c=0;c<this.sourceData.length;c++)b=a("<label>").append(a("<input>",{type:"checkbox",value:this.sourceData[c].value})).append(a("<span>").text(" "+this.sourceData[c].text)),a("<div>").append(b).appendTo(this.$tpl);this.$input=this.$tpl.find('input[type="checkbox"]'),this.setClass()}},value2str:function(b){return a.isArray(b)?b.sort().join(a.trim(this.options.separator)):""},str2value:function(b){var c,d=null;return"string"==typeof b&&b.length?(c=new RegExp("\\s*"+a.trim(this.options.separator)+"\\s*"),d=b.split(c)):d=a.isArray(b)?b:[b],d},value2input:function(b){this.$input.prop("checked",!1),a.isArray(b)&&b.length&&this.$input.each(function(c,d){var e=a(d);a.each(b,function(a,b){e.val()==b&&e.prop("checked",!0)})})},input2value:function(){var b=[];return this.$input.filter(":checked").each(function(c,d){b.push(a(d).val())}),b},value2htmlFinal:function(b,c){var d=[],e=a.fn.editableutils.itemsByValue(b,this.sourceData),f=this.options.escape;e.length?(a.each(e,function(b,c){var e=f?a.fn.editableutils.escape(c.text):c.text;d.push(e)}),a(c).html(d.join("<br>"))):a(c).empty()},activate:function(){this.$input.first().focus()},autosubmit:function(){this.$input.on("keydown",function(b){13===b.which&&a(this).closest("form").submit()})}}),b.defaults=a.extend({},a.fn.editabletypes.list.defaults,{tpl:'<div class="editable-checklist"></div>',inputclass:null,separator:","}),a.fn.editabletypes.checklist=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("password",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.text),a.extend(b.prototype,{value2html:function(b,c){b?a(c).text("[hidden]"):a(c).empty()},html2value:function(){return null}}),b.defaults=a.extend({},a.fn.editabletypes.text.defaults,{tpl:'<input type="password">'}),a.fn.editabletypes.password=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("email",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.text),b.defaults=a.extend({},a.fn.editabletypes.text.defaults,{tpl:'<input type="email">'}),a.fn.editabletypes.email=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("url",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.text),b.defaults=a.extend({},a.fn.editabletypes.text.defaults,{tpl:'<input type="url">'}),a.fn.editabletypes.url=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("tel",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.text),b.defaults=a.extend({},a.fn.editabletypes.text.defaults,{tpl:'<input type="tel">'}),a.fn.editabletypes.tel=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("number",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.text),a.extend(b.prototype,{render:function(){b.superclass.render.call(this),this.setAttr("min"),this.setAttr("max"),this.setAttr("step")},postrender:function(){this.$clear&&this.$clear.css({right:24})}}),b.defaults=a.extend({},a.fn.editabletypes.text.defaults,{tpl:'<input type="number">',inputclass:"input-mini",min:null,max:null,step:null}),a.fn.editabletypes.number=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("range",a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.number),a.extend(b.prototype,{render:function(){this.$input=this.$tpl.filter("input"),this.setClass(),this.setAttr("min"),this.setAttr("max"),this.setAttr("step"),this.$input.on("input",function(){a(this).siblings("output").text(a(this).val())})},activate:function(){this.$input.focus()}}),b.defaults=a.extend({},a.fn.editabletypes.number.defaults,{tpl:'<input type="range"><output style="width: 30px; display: inline-block"></output>',inputclass:"input-medium"}),a.fn.editabletypes.range=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("time",a,b.defaults)
};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{render:function(){this.setClass()}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{tpl:'<input type="time">'}),a.fn.editabletypes.time=b}(window.jQuery),function(a){"use strict";var b=function(c){if(this.init("select2",c,b.defaults),c.select2=c.select2||{},this.sourceData=null,c.placeholder&&(c.select2.placeholder=c.placeholder),!c.select2.tags&&c.source){var d=c.source;a.isFunction(c.source)&&(d=c.source.call(c.scope)),"string"==typeof d?(c.select2.ajax=c.select2.ajax||{},c.select2.ajax.data||(c.select2.ajax.data=function(a){return{query:a}}),c.select2.ajax.results||(c.select2.ajax.results=function(a){return{results:a}}),c.select2.ajax.url=d):(this.sourceData=this.convertSource(d),c.select2.data=this.sourceData)}if(this.options.select2=a.extend({},b.defaults.select2,c.select2),this.isMultiple=this.options.select2.tags||this.options.select2.multiple,this.isRemote="ajax"in this.options.select2,this.idFunc=this.options.select2.id,"function"!=typeof this.idFunc){var e=this.idFunc||"id";this.idFunc=function(a){return a[e]}}this.formatSelection=this.options.select2.formatSelection,"function"!=typeof this.formatSelection&&(this.formatSelection=function(a){return a.text})};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{render:function(){this.setClass(),this.isRemote&&this.$input.on("select2-loaded",a.proxy(function(a){this.sourceData=a.items.results},this)),this.isMultiple&&this.$input.on("change",function(){a(this).closest("form").parent().triggerHandler("resize")})},value2html:function(c,d){var e,f="",g=this;this.options.select2.tags?e=c:this.sourceData&&(e=a.fn.editableutils.itemsByValue(c,this.sourceData,this.idFunc)),a.isArray(e)?(f=[],a.each(e,function(a,b){f.push(b&&"object"==typeof b?g.formatSelection(b):b)})):e&&(f=g.formatSelection(e)),f=a.isArray(f)?f.join(this.options.viewseparator):f,b.superclass.value2html.call(this,f,d)},html2value:function(a){return this.options.select2.tags?this.str2value(a,this.options.viewseparator):null},value2input:function(b){if(this.$input.data("select2")?this.$input.val(b).trigger("change",!0):(this.$input.val(b),this.$input.select2(this.options.select2)),this.isRemote&&!this.isMultiple&&!this.options.select2.initSelection){var c=this.options.select2.id,d=this.options.select2.formatSelection;if(!c&&!d){var e={id:b,text:a(this.options.scope).text()};this.$input.select2("data",e)}}},input2value:function(){return this.$input.select2("val")},str2value:function(b,c){if("string"!=typeof b||!this.isMultiple)return b;c=c||this.options.select2.separator||a.fn.select2.defaults.separator;var d,e,f;if(null===b||b.length<1)return null;for(d=b.split(c),e=0,f=d.length;f>e;e+=1)d[e]=a.trim(d[e]);return d},autosubmit:function(){this.$input.on("change",function(b,c){c||a(this).closest("form").submit()})},convertSource:function(b){if(a.isArray(b)&&b.length&&void 0!==b[0].value)for(var c=0;c<b.length;c++)void 0!==b[c].value&&(b[c].id=b[c].value,delete b[c].value);return b},destroy:function(){this.$input.data("select2")&&this.$input.select2("destroy")}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{tpl:'<input type="hidden">',select2:null,placeholder:null,source:null,viewseparator:", "}),a.fn.editabletypes.select2=b}(window.jQuery),function(a){var b=function(b,c){return this.$element=a(b),this.$element.is("input")?(this.options=a.extend({},a.fn.combodate.defaults,c,this.$element.data()),this.init(),void 0):(a.error("Combodate should be applied to INPUT element"),void 0)};b.prototype={constructor:b,init:function(){this.map={day:["D","date"],month:["M","month"],year:["Y","year"],hour:["[Hh]","hours"],minute:["m","minutes"],second:["s","seconds"],ampm:["[Aa]",""]},this.$widget=a('<span class="combodate"></span>').html(this.getTemplate()),this.initCombos(),this.$widget.on("change","select",a.proxy(function(){this.$element.val(this.getValue())},this)),this.$widget.find("select").css("width","auto"),this.$element.hide().after(this.$widget),this.setValue(this.$element.val()||this.options.value)},getTemplate:function(){var b=this.options.template;return a.each(this.map,function(a,c){c=c[0];var d=new RegExp(c+"+"),e=c.length>1?c.substring(1,2):c;b=b.replace(d,"{"+e+"}")}),b=b.replace(/ /g,"&nbsp;"),a.each(this.map,function(a,c){c=c[0];var d=c.length>1?c.substring(1,2):c;b=b.replace("{"+d+"}",'<select class="'+a+'"></select>')}),b},initCombos:function(){var b=this;a.each(this.map,function(a){var c,d,e=b.$widget.find("."+a);e.length&&(b["$"+a]=e,c="fill"+a.charAt(0).toUpperCase()+a.slice(1),d=b[c](),b["$"+a].html(b.renderItems(d)))})},initItems:function(a){var b,c=[];if("name"===this.options.firstItem){b=moment.relativeTime||moment.langData()._relativeTime;var d="function"==typeof b[a]?b[a](1,!0,a,!1):b[a];d=d.split(" ").reverse()[0],c.push(["",d])}else"empty"===this.options.firstItem&&c.push(["",""]);return c},renderItems:function(a){for(var b=[],c=0;c<a.length;c++)b.push('<option value="'+a[c][0]+'">'+a[c][1]+"</option>");return b.join("\n")},fillDay:function(){var a,b,c=this.initItems("d"),d=-1!==this.options.template.indexOf("DD");for(b=1;31>=b;b++)a=d?this.leadZero(b):b,c.push([b,a]);return c},fillMonth:function(){var a,b,c=this.initItems("M"),d=-1!==this.options.template.indexOf("MMMM"),e=-1!==this.options.template.indexOf("MMM"),f=-1!==this.options.template.indexOf("MM");for(b=0;11>=b;b++)a=d?moment().date(1).month(b).format("MMMM"):e?moment().date(1).month(b).format("MMM"):f?this.leadZero(b+1):b+1,c.push([b,a]);return c},fillYear:function(){var a,b,c=[],d=-1!==this.options.template.indexOf("YYYY");for(b=this.options.maxYear;b>=this.options.minYear;b--)a=d?b:(b+"").substring(2),c[this.options.yearDescending?"push":"unshift"]([b,a]);return c=this.initItems("y").concat(c)},fillHour:function(){var a,b,c=this.initItems("h"),d=-1!==this.options.template.indexOf("h"),e=(-1!==this.options.template.indexOf("H"),-1!==this.options.template.toLowerCase().indexOf("hh")),f=d?1:0,g=d?12:23;for(b=f;g>=b;b++)a=e?this.leadZero(b):b,c.push([b,a]);return c},fillMinute:function(){var a,b,c=this.initItems("m"),d=-1!==this.options.template.indexOf("mm");for(b=0;59>=b;b+=this.options.minuteStep)a=d?this.leadZero(b):b,c.push([b,a]);return c},fillSecond:function(){var a,b,c=this.initItems("s"),d=-1!==this.options.template.indexOf("ss");for(b=0;59>=b;b+=this.options.secondStep)a=d?this.leadZero(b):b,c.push([b,a]);return c},fillAmpm:function(){var a=-1!==this.options.template.indexOf("a"),b=(-1!==this.options.template.indexOf("A"),[["am",a?"am":"AM"],["pm",a?"pm":"PM"]]);return b},getValue:function(b){var c,d={},e=this,f=!1;return a.each(this.map,function(a){if("ampm"!==a){var b="day"===a?1:0;return d[a]=e["$"+a]?parseInt(e["$"+a].val(),10):b,isNaN(d[a])?(f=!0,!1):void 0}}),f?"":(this.$ampm&&(d.hour=12===d.hour?"am"===this.$ampm.val()?0:12:"am"===this.$ampm.val()?d.hour:d.hour+12),c=moment([d.year,d.month,d.day,d.hour,d.minute,d.second]),this.highlight(c),b=void 0===b?this.options.format:b,null===b?c.isValid()?c:null:c.isValid()?c.format(b):"")},setValue:function(b){function c(b,c){var d={};return b.children("option").each(function(b,e){var f,g=a(e).attr("value");""!==g&&(f=Math.abs(g-c),("undefined"==typeof d.distance||f<d.distance)&&(d={value:g,distance:f}))}),d.value}if(b){var d="string"==typeof b?moment(b,this.options.format):moment(b),e=this,f={};d.isValid()&&(a.each(this.map,function(a,b){"ampm"!==a&&(f[a]=d[b[1]]())}),this.$ampm&&(f.hour>=12?(f.ampm="pm",f.hour>12&&(f.hour-=12)):(f.ampm="am",0===f.hour&&(f.hour=12))),a.each(f,function(a,b){e["$"+a]&&("minute"===a&&e.options.minuteStep>1&&e.options.roundTime&&(b=c(e["$"+a],b)),"second"===a&&e.options.secondStep>1&&e.options.roundTime&&(b=c(e["$"+a],b)),e["$"+a].val(b))}),this.$element.val(d.format(this.options.format)))}},highlight:function(a){a.isValid()?this.options.errorClass?this.$widget.removeClass(this.options.errorClass):this.$widget.find("select").css("border-color",this.borderColor):this.options.errorClass?this.$widget.addClass(this.options.errorClass):(this.borderColor||(this.borderColor=this.$widget.find("select").css("border-color")),this.$widget.find("select").css("border-color","red"))},leadZero:function(a){return 9>=a?"0"+a:a},destroy:function(){this.$widget.remove(),this.$element.removeData("combodate").show()}},a.fn.combodate=function(c){var d,e=Array.apply(null,arguments);return e.shift(),"getValue"===c&&this.length&&(d=this.eq(0).data("combodate"))?d.getValue.apply(d,e):this.each(function(){var d=a(this),f=d.data("combodate"),g="object"==typeof c&&c;f||d.data("combodate",f=new b(this,g)),"string"==typeof c&&"function"==typeof f[c]&&f[c].apply(f,e)})},a.fn.combodate.defaults={format:"DD-MM-YYYY HH:mm",template:"D / MMM / YYYY   H : mm",value:null,minYear:1970,maxYear:2015,yearDescending:!0,minuteStep:5,secondStep:1,firstItem:"empty",errorClass:null,roundTime:!0}}(window.jQuery),function(a){"use strict";var b=function(c){this.init("combodate",c,b.defaults),this.options.viewformat||(this.options.viewformat=this.options.format),c.combodate=a.fn.editableutils.tryParseJson(c.combodate,!0),this.options.combodate=a.extend({},b.defaults.combodate,c.combodate,{format:this.options.format,template:this.options.template})};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{render:function(){this.$input.combodate(this.options.combodate),"bs3"===a.fn.editableform.engine&&this.$input.siblings().find("select").addClass("form-control"),this.options.inputclass&&this.$input.siblings().find("select").addClass(this.options.inputclass)},value2html:function(a,c){var d=a?a.format(this.options.viewformat):"";b.superclass.value2html.call(this,d,c)},html2value:function(a){return a?moment(a,this.options.viewformat):null},value2str:function(a){return a?a.format(this.options.format):""},str2value:function(a){return a?moment(a,this.options.format):null},value2submit:function(a){return this.value2str(a)},value2input:function(a){this.$input.combodate("setValue",a)},input2value:function(){return this.$input.combodate("getValue",null)},activate:function(){this.$input.siblings(".combodate").find("select").eq(0).focus()},autosubmit:function(){}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{tpl:'<input type="text">',inputclass:null,format:"YYYY-MM-DD",viewformat:null,template:"D / MMM / YYYY",combodate:null}),a.fn.editabletypes.combodate=b}(window.jQuery),function(a){"use strict";var b=a.fn.editableform.Constructor.prototype.initInput;a.extend(a.fn.editableform.Constructor.prototype,{initTemplate:function(){this.$form=a(a.fn.editableform.template),this.$form.find(".control-group").addClass("form-group"),this.$form.find(".editable-error-block").addClass("help-block")},initInput:function(){b.apply(this);var c=null===this.input.options.inputclass||this.input.options.inputclass===!1,d="input-sm",e="text,select,textarea,password,email,url,tel,number,range,time,typeaheadjs".split(",");~a.inArray(this.input.type,e)&&(this.input.$input.addClass("form-control"),c&&(this.input.options.inputclass=d,this.input.$input.addClass(d)));for(var f=this.$form.find(".editable-buttons"),g=c?[d]:this.input.options.inputclass.split(" "),h=0;h<g.length;h++)"input-lg"===g[h].toLowerCase()&&f.find("button").removeClass("btn-sm").addClass("btn-lg")}}),a.fn.editableform.buttons='<button type="submit" class="btn btn-primary btn-sm editable-submit"><i class="glyphicon glyphicon-ok"></i></button><button type="button" class="btn btn-default btn-sm editable-cancel"><i class="glyphicon glyphicon-remove"></i></button>',a.fn.editableform.errorGroupClass="has-error",a.fn.editableform.errorBlockClass=null,a.fn.editableform.engine="bs3"}(window.jQuery),function(a){"use strict";a.extend(a.fn.editableContainer.Popup.prototype,{containerName:"popover",containerDataName:"bs.popover",innerCss:".popover-content",defaults:a.fn.popover.Constructor.DEFAULTS,initContainer:function(){a.extend(this.containerOptions,{trigger:"manual",selector:!1,content:" ",template:this.defaults.template});var b;this.$element.data("template")&&(b=this.$element.data("template"),this.$element.removeData("template")),this.call(this.containerOptions),b&&this.$element.data("template",b)},innerShow:function(){this.call("show")},innerHide:function(){this.call("hide")},innerDestroy:function(){this.call("destroy")},setContainerOption:function(a,b){this.container().options[a]=b},setPosition:function(){!function(){var a=this.tip(),b="function"==typeof this.options.placement?this.options.placement.call(this,a[0],this.$element[0]):this.options.placement,c=this.getPosition(),d=a[0].offsetWidth,e=a[0].offsetHeight,f=this.getCalculatedOffset(b,c,d,e);this.applyPlacement(f,b)}.call(this.container())}})}(window.jQuery),function(a){function b(){return new Date(Date.UTC.apply(Date,arguments))}function c(b,c){var d,e=a(b).data(),f={},g=new RegExp("^"+c.toLowerCase()+"([A-Z])"),c=new RegExp("^"+c.toLowerCase());for(var h in e)c.test(h)&&(d=h.replace(g,function(a,b){return b.toLowerCase()}),f[d]=e[h]);return f}function d(b){var c={};if(k[b]||(b=b.split("-")[0],k[b])){var d=k[b];return a.each(j,function(a,b){b in d&&(c[b]=d[b])}),c}}var e=function(b,c){this._process_options(c),this.element=a(b),this.isInline=!1,this.isInput=this.element.is("input"),this.component=this.element.is(".date")?this.element.find(".add-on, .btn"):!1,this.hasInput=this.component&&this.element.find("input").length,this.component&&0===this.component.length&&(this.component=!1),this.picker=a(l.template),this._buildEvents(),this._attachEvents(),this.isInline?this.picker.addClass("datepicker-inline").appendTo(this.element):this.picker.addClass("datepicker-dropdown dropdown-menu"),this.o.rtl&&(this.picker.addClass("datepicker-rtl"),this.picker.find(".prev i, .next i").toggleClass("icon-arrow-left icon-arrow-right")),this.viewMode=this.o.startView,this.o.calendarWeeks&&this.picker.find("tfoot th.today").attr("colspan",function(a,b){return parseInt(b)+1}),this._allow_update=!1,this.setStartDate(this.o.startDate),this.setEndDate(this.o.endDate),this.setDaysOfWeekDisabled(this.o.daysOfWeekDisabled),this.fillDow(),this.fillMonths(),this._allow_update=!0,this.update(),this.showMode(),this.isInline&&this.show()};e.prototype={constructor:e,_process_options:function(b){this._o=a.extend({},this._o,b);var c=this.o=a.extend({},this._o),d=c.language;switch(k[d]||(d=d.split("-")[0],k[d]||(d=i.language)),c.language=d,c.startView){case 2:case"decade":c.startView=2;break;case 1:case"year":c.startView=1;break;default:c.startView=0}switch(c.minViewMode){case 1:case"months":c.minViewMode=1;break;case 2:case"years":c.minViewMode=2;break;default:c.minViewMode=0}c.startView=Math.max(c.startView,c.minViewMode),c.weekStart%=7,c.weekEnd=(c.weekStart+6)%7;var e=l.parseFormat(c.format);c.startDate!==-1/0&&(c.startDate=l.parseDate(c.startDate,e,c.language)),1/0!==c.endDate&&(c.endDate=l.parseDate(c.endDate,e,c.language)),c.daysOfWeekDisabled=c.daysOfWeekDisabled||[],a.isArray(c.daysOfWeekDisabled)||(c.daysOfWeekDisabled=c.daysOfWeekDisabled.split(/[,\s]*/)),c.daysOfWeekDisabled=a.map(c.daysOfWeekDisabled,function(a){return parseInt(a,10)})},_events:[],_secondaryEvents:[],_applyEvents:function(a){for(var b,c,d=0;d<a.length;d++)b=a[d][0],c=a[d][1],b.on(c)},_unapplyEvents:function(a){for(var b,c,d=0;d<a.length;d++)b=a[d][0],c=a[d][1],b.off(c)},_buildEvents:function(){this.isInput?this._events=[[this.element,{focus:a.proxy(this.show,this),keyup:a.proxy(this.update,this),keydown:a.proxy(this.keydown,this)}]]:this.component&&this.hasInput?this._events=[[this.element.find("input"),{focus:a.proxy(this.show,this),keyup:a.proxy(this.update,this),keydown:a.proxy(this.keydown,this)}],[this.component,{click:a.proxy(this.show,this)}]]:this.element.is("div")?this.isInline=!0:this._events=[[this.element,{click:a.proxy(this.show,this)}]],this._secondaryEvents=[[this.picker,{click:a.proxy(this.click,this)}],[a(window),{resize:a.proxy(this.place,this)}],[a(document),{mousedown:a.proxy(function(a){this.element.is(a.target)||this.element.find(a.target).size()||this.picker.is(a.target)||this.picker.find(a.target).size()||this.hide()},this)}]]},_attachEvents:function(){this._detachEvents(),this._applyEvents(this._events)},_detachEvents:function(){this._unapplyEvents(this._events)},_attachSecondaryEvents:function(){this._detachSecondaryEvents(),this._applyEvents(this._secondaryEvents)},_detachSecondaryEvents:function(){this._unapplyEvents(this._secondaryEvents)},_trigger:function(b,c){var d=c||this.date,e=new Date(d.getTime()+6e4*d.getTimezoneOffset());this.element.trigger({type:b,date:e,format:a.proxy(function(a){var b=a||this.o.format;return l.formatDate(d,b,this.o.language)},this)})},show:function(a){this.isInline||this.picker.appendTo("body"),this.picker.show(),this.height=this.component?this.component.outerHeight():this.element.outerHeight(),this.place(),this._attachSecondaryEvents(),a&&a.preventDefault(),this._trigger("show")},hide:function(){this.isInline||this.picker.is(":visible")&&(this.picker.hide().detach(),this._detachSecondaryEvents(),this.viewMode=this.o.startView,this.showMode(),this.o.forceParse&&(this.isInput&&this.element.val()||this.hasInput&&this.element.find("input").val())&&this.setValue(),this._trigger("hide"))},remove:function(){this.hide(),this._detachEvents(),this._detachSecondaryEvents(),this.picker.remove(),delete this.element.data().datepicker,this.isInput||delete this.element.data().date},getDate:function(){var a=this.getUTCDate();return new Date(a.getTime()+6e4*a.getTimezoneOffset())},getUTCDate:function(){return this.date},setDate:function(a){this.setUTCDate(new Date(a.getTime()-6e4*a.getTimezoneOffset()))},setUTCDate:function(a){this.date=a,this.setValue()},setValue:function(){var a=this.getFormattedDate();this.isInput?this.element.val(a):this.component&&this.element.find("input").val(a)},getFormattedDate:function(a){return void 0===a&&(a=this.o.format),l.formatDate(this.date,a,this.o.language)},setStartDate:function(a){this._process_options({startDate:a}),this.update(),this.updateNavArrows()},setEndDate:function(a){this._process_options({endDate:a}),this.update(),this.updateNavArrows()},setDaysOfWeekDisabled:function(a){this._process_options({daysOfWeekDisabled:a}),this.update(),this.updateNavArrows()},place:function(){if(!this.isInline){var b=parseInt(this.element.parents().filter(function(){return"auto"!=a(this).css("z-index")}).first().css("z-index"))+10,c=this.component?this.component.parent().offset():this.element.offset(),d=this.component?this.component.outerHeight(!0):this.element.outerHeight(!0);this.picker.css({top:c.top+d,left:c.left,zIndex:b})}},_allow_update:!0,update:function(){if(this._allow_update){var a,b=!1;arguments&&arguments.length&&("string"==typeof arguments[0]||arguments[0]instanceof Date)?(a=arguments[0],b=!0):(a=this.isInput?this.element.val():this.element.data("date")||this.element.find("input").val(),delete this.element.data().date),this.date=l.parseDate(a,this.o.format,this.o.language),b&&this.setValue(),this.viewDate=this.date<this.o.startDate?new Date(this.o.startDate):this.date>this.o.endDate?new Date(this.o.endDate):new Date(this.date),this.fill()}},fillDow:function(){var a=this.o.weekStart,b="<tr>";if(this.o.calendarWeeks){var c='<th class="cw">&nbsp;</th>';b+=c,this.picker.find(".datepicker-days thead tr:first-child").prepend(c)}for(;a<this.o.weekStart+7;)b+='<th class="dow">'+k[this.o.language].daysMin[a++%7]+"</th>";b+="</tr>",this.picker.find(".datepicker-days thead").append(b)},fillMonths:function(){for(var a="",b=0;12>b;)a+='<span class="month">'+k[this.o.language].monthsShort[b++]+"</span>";this.picker.find(".datepicker-months td").html(a)},setRange:function(b){b&&b.length?this.range=a.map(b,function(a){return a.valueOf()}):delete this.range,this.fill()},getClassNames:function(b){var c=[],d=this.viewDate.getUTCFullYear(),e=this.viewDate.getUTCMonth(),f=this.date.valueOf(),g=new Date;return b.getUTCFullYear()<d||b.getUTCFullYear()==d&&b.getUTCMonth()<e?c.push("old"):(b.getUTCFullYear()>d||b.getUTCFullYear()==d&&b.getUTCMonth()>e)&&c.push("new"),this.o.todayHighlight&&b.getUTCFullYear()==g.getFullYear()&&b.getUTCMonth()==g.getMonth()&&b.getUTCDate()==g.getDate()&&c.push("today"),f&&b.valueOf()==f&&c.push("active"),(b.valueOf()<this.o.startDate||b.valueOf()>this.o.endDate||-1!==a.inArray(b.getUTCDay(),this.o.daysOfWeekDisabled))&&c.push("disabled"),this.range&&(b>this.range[0]&&b<this.range[this.range.length-1]&&c.push("range"),-1!=a.inArray(b.valueOf(),this.range)&&c.push("selected")),c},fill:function(){var c,d=new Date(this.viewDate),e=d.getUTCFullYear(),f=d.getUTCMonth(),g=this.o.startDate!==-1/0?this.o.startDate.getUTCFullYear():-1/0,h=this.o.startDate!==-1/0?this.o.startDate.getUTCMonth():-1/0,i=1/0!==this.o.endDate?this.o.endDate.getUTCFullYear():1/0,j=1/0!==this.o.endDate?this.o.endDate.getUTCMonth():1/0;this.date&&this.date.valueOf(),this.picker.find(".datepicker-days thead th.datepicker-switch").text(k[this.o.language].months[f]+" "+e),this.picker.find("tfoot th.today").text(k[this.o.language].today).toggle(this.o.todayBtn!==!1),this.picker.find("tfoot th.clear").text(k[this.o.language].clear).toggle(this.o.clearBtn!==!1),this.updateNavArrows(),this.fillMonths();var m=b(e,f-1,28,0,0,0,0),n=l.getDaysInMonth(m.getUTCFullYear(),m.getUTCMonth());m.setUTCDate(n),m.setUTCDate(n-(m.getUTCDay()-this.o.weekStart+7)%7);var o=new Date(m);o.setUTCDate(o.getUTCDate()+42),o=o.valueOf();for(var p,q=[];m.valueOf()<o;){if(m.getUTCDay()==this.o.weekStart&&(q.push("<tr>"),this.o.calendarWeeks)){var r=new Date(+m+864e5*((this.o.weekStart-m.getUTCDay()-7)%7)),s=new Date(+r+864e5*((11-r.getUTCDay())%7)),t=new Date(+(t=b(s.getUTCFullYear(),0,1))+864e5*((11-t.getUTCDay())%7)),u=(s-t)/864e5/7+1;q.push('<td class="cw">'+u+"</td>")}p=this.getClassNames(m),p.push("day");var v=this.o.beforeShowDay(m);void 0===v?v={}:"boolean"==typeof v?v={enabled:v}:"string"==typeof v&&(v={classes:v}),v.enabled===!1&&p.push("disabled"),v.classes&&(p=p.concat(v.classes.split(/\s+/))),v.tooltip&&(c=v.tooltip),p=a.unique(p),q.push('<td class="'+p.join(" ")+'"'+(c?' title="'+c+'"':"")+">"+m.getUTCDate()+"</td>"),m.getUTCDay()==this.o.weekEnd&&q.push("</tr>"),m.setUTCDate(m.getUTCDate()+1)}this.picker.find(".datepicker-days tbody").empty().append(q.join(""));var w=this.date&&this.date.getUTCFullYear(),x=this.picker.find(".datepicker-months").find("th:eq(1)").text(e).end().find("span").removeClass("active");w&&w==e&&x.eq(this.date.getUTCMonth()).addClass("active"),(g>e||e>i)&&x.addClass("disabled"),e==g&&x.slice(0,h).addClass("disabled"),e==i&&x.slice(j+1).addClass("disabled"),q="",e=10*parseInt(e/10,10);var y=this.picker.find(".datepicker-years").find("th:eq(1)").text(e+"-"+(e+9)).end().find("td");e-=1;for(var z=-1;11>z;z++)q+='<span class="year'+(-1==z?" old":10==z?" new":"")+(w==e?" active":"")+(g>e||e>i?" disabled":"")+'">'+e+"</span>",e+=1;y.html(q)},updateNavArrows:function(){if(this._allow_update){var a=new Date(this.viewDate),b=a.getUTCFullYear(),c=a.getUTCMonth();switch(this.viewMode){case 0:this.o.startDate!==-1/0&&b<=this.o.startDate.getUTCFullYear()&&c<=this.o.startDate.getUTCMonth()?this.picker.find(".prev").css({visibility:"hidden"}):this.picker.find(".prev").css({visibility:"visible"}),1/0!==this.o.endDate&&b>=this.o.endDate.getUTCFullYear()&&c>=this.o.endDate.getUTCMonth()?this.picker.find(".next").css({visibility:"hidden"}):this.picker.find(".next").css({visibility:"visible"});break;case 1:case 2:this.o.startDate!==-1/0&&b<=this.o.startDate.getUTCFullYear()?this.picker.find(".prev").css({visibility:"hidden"}):this.picker.find(".prev").css({visibility:"visible"}),1/0!==this.o.endDate&&b>=this.o.endDate.getUTCFullYear()?this.picker.find(".next").css({visibility:"hidden"}):this.picker.find(".next").css({visibility:"visible"})}}},click:function(c){c.preventDefault();var d=a(c.target).closest("span, td, th");if(1==d.length)switch(d[0].nodeName.toLowerCase()){case"th":switch(d[0].className){case"datepicker-switch":this.showMode(1);break;case"prev":case"next":var e=l.modes[this.viewMode].navStep*("prev"==d[0].className?-1:1);switch(this.viewMode){case 0:this.viewDate=this.moveMonth(this.viewDate,e);break;case 1:case 2:this.viewDate=this.moveYear(this.viewDate,e)}this.fill();break;case"today":var f=new Date;f=b(f.getFullYear(),f.getMonth(),f.getDate(),0,0,0),this.showMode(-2);var g="linked"==this.o.todayBtn?null:"view";this._setDate(f,g);break;case"clear":var h;this.isInput?h=this.element:this.component&&(h=this.element.find("input")),h&&h.val("").change(),this._trigger("changeDate"),this.update(),this.o.autoclose&&this.hide()}break;case"span":if(!d.is(".disabled")){if(this.viewDate.setUTCDate(1),d.is(".month")){var i=1,j=d.parent().find("span").index(d),k=this.viewDate.getUTCFullYear();this.viewDate.setUTCMonth(j),this._trigger("changeMonth",this.viewDate),1===this.o.minViewMode&&this._setDate(b(k,j,i,0,0,0,0))}else{var k=parseInt(d.text(),10)||0,i=1,j=0;this.viewDate.setUTCFullYear(k),this._trigger("changeYear",this.viewDate),2===this.o.minViewMode&&this._setDate(b(k,j,i,0,0,0,0))}this.showMode(-1),this.fill()}break;case"td":if(d.is(".day")&&!d.is(".disabled")){var i=parseInt(d.text(),10)||1,k=this.viewDate.getUTCFullYear(),j=this.viewDate.getUTCMonth();d.is(".old")?0===j?(j=11,k-=1):j-=1:d.is(".new")&&(11==j?(j=0,k+=1):j+=1),this._setDate(b(k,j,i,0,0,0,0))}}},_setDate:function(a,b){b&&"date"!=b||(this.date=new Date(a)),b&&"view"!=b||(this.viewDate=new Date(a)),this.fill(),this.setValue(),this._trigger("changeDate");var c;this.isInput?c=this.element:this.component&&(c=this.element.find("input")),c&&(c.change(),!this.o.autoclose||b&&"date"!=b||this.hide())},moveMonth:function(a,b){if(!b)return a;var c,d,e=new Date(a.valueOf()),f=e.getUTCDate(),g=e.getUTCMonth(),h=Math.abs(b);if(b=b>0?1:-1,1==h)d=-1==b?function(){return e.getUTCMonth()==g}:function(){return e.getUTCMonth()!=c},c=g+b,e.setUTCMonth(c),(0>c||c>11)&&(c=(c+12)%12);else{for(var i=0;h>i;i++)e=this.moveMonth(e,b);c=e.getUTCMonth(),e.setUTCDate(f),d=function(){return c!=e.getUTCMonth()}}for(;d();)e.setUTCDate(--f),e.setUTCMonth(c);return e},moveYear:function(a,b){return this.moveMonth(a,12*b)},dateWithinRange:function(a){return a>=this.o.startDate&&a<=this.o.endDate},keydown:function(a){if(this.picker.is(":not(:visible)"))return 27==a.keyCode&&this.show(),void 0;var b,c,d,e=!1;switch(a.keyCode){case 27:this.hide(),a.preventDefault();break;case 37:case 39:if(!this.o.keyboardNavigation)break;b=37==a.keyCode?-1:1,a.ctrlKey?(c=this.moveYear(this.date,b),d=this.moveYear(this.viewDate,b)):a.shiftKey?(c=this.moveMonth(this.date,b),d=this.moveMonth(this.viewDate,b)):(c=new Date(this.date),c.setUTCDate(this.date.getUTCDate()+b),d=new Date(this.viewDate),d.setUTCDate(this.viewDate.getUTCDate()+b)),this.dateWithinRange(c)&&(this.date=c,this.viewDate=d,this.setValue(),this.update(),a.preventDefault(),e=!0);break;case 38:case 40:if(!this.o.keyboardNavigation)break;b=38==a.keyCode?-1:1,a.ctrlKey?(c=this.moveYear(this.date,b),d=this.moveYear(this.viewDate,b)):a.shiftKey?(c=this.moveMonth(this.date,b),d=this.moveMonth(this.viewDate,b)):(c=new Date(this.date),c.setUTCDate(this.date.getUTCDate()+7*b),d=new Date(this.viewDate),d.setUTCDate(this.viewDate.getUTCDate()+7*b)),this.dateWithinRange(c)&&(this.date=c,this.viewDate=d,this.setValue(),this.update(),a.preventDefault(),e=!0);break;case 13:this.hide(),a.preventDefault();break;case 9:this.hide()}if(e){this._trigger("changeDate");var f;this.isInput?f=this.element:this.component&&(f=this.element.find("input")),f&&f.change()}},showMode:function(a){a&&(this.viewMode=Math.max(this.o.minViewMode,Math.min(2,this.viewMode+a))),this.picker.find(">div").hide().filter(".datepicker-"+l.modes[this.viewMode].clsName).css("display","block"),this.updateNavArrows()}};var f=function(b,c){this.element=a(b),this.inputs=a.map(c.inputs,function(a){return a.jquery?a[0]:a}),delete c.inputs,a(this.inputs).datepicker(c).bind("changeDate",a.proxy(this.dateUpdated,this)),this.pickers=a.map(this.inputs,function(b){return a(b).data("datepicker")}),this.updateDates()};f.prototype={updateDates:function(){this.dates=a.map(this.pickers,function(a){return a.date}),this.updateRanges()},updateRanges:function(){var b=a.map(this.dates,function(a){return a.valueOf()});a.each(this.pickers,function(a,c){c.setRange(b)})},dateUpdated:function(b){var c=a(b.target).data("datepicker"),d=c.getUTCDate(),e=a.inArray(b.target,this.inputs),f=this.inputs.length;if(-1!=e){if(d<this.dates[e])for(;e>=0&&d<this.dates[e];)this.pickers[e--].setUTCDate(d);else if(d>this.dates[e])for(;f>e&&d>this.dates[e];)this.pickers[e++].setUTCDate(d);this.updateDates()}},remove:function(){a.map(this.pickers,function(a){a.remove()}),delete this.element.data().datepicker}};var g=a.fn.datepicker,h=a.fn.datepicker=function(b){var g=Array.apply(null,arguments);g.shift();var h;return this.each(function(){var j=a(this),k=j.data("datepicker"),l="object"==typeof b&&b;if(!k){var m=c(this,"date"),n=a.extend({},i,m,l),o=d(n.language),p=a.extend({},i,o,m,l);if(j.is(".input-daterange")||p.inputs){var q={inputs:p.inputs||j.find("input").toArray()};j.data("datepicker",k=new f(this,a.extend(p,q)))}else j.data("datepicker",k=new e(this,p))}return"string"==typeof b&&"function"==typeof k[b]&&(h=k[b].apply(k,g),void 0!==h)?!1:void 0}),void 0!==h?h:this},i=a.fn.datepicker.defaults={autoclose:!1,beforeShowDay:a.noop,calendarWeeks:!1,clearBtn:!1,daysOfWeekDisabled:[],endDate:1/0,forceParse:!0,format:"mm/dd/yyyy",keyboardNavigation:!0,language:"en",minViewMode:0,rtl:!1,startDate:-1/0,startView:0,todayBtn:!1,todayHighlight:!1,weekStart:0},j=a.fn.datepicker.locale_opts=["format","rtl","weekStart"];a.fn.datepicker.Constructor=e;var k=a.fn.datepicker.dates={en:{days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"],daysShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat","Sun"],daysMin:["Su","Mo","Tu","We","Th","Fr","Sa","Su"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],monthsShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],today:"Today",clear:"Clear"}},l={modes:[{clsName:"days",navFnc:"Month",navStep:1},{clsName:"months",navFnc:"FullYear",navStep:1},{clsName:"years",navFnc:"FullYear",navStep:10}],isLeapYear:function(a){return 0===a%4&&0!==a%100||0===a%400},getDaysInMonth:function(a,b){return[31,l.isLeapYear(a)?29:28,31,30,31,30,31,31,30,31,30,31][b]},validParts:/dd?|DD?|mm?|MM?|yy(?:yy)?/g,nonpunctuation:/[^ -\/:-@\[\u3400-\u9fff-`{-~\t\n\r]+/g,parseFormat:function(a){var b=a.replace(this.validParts,"\0").split("\0"),c=a.match(this.validParts);if(!b||!b.length||!c||0===c.length)throw new Error("Invalid date format.");return{separators:b,parts:c}},parseDate:function(c,d,f){if(c instanceof Date)return c;if("string"==typeof d&&(d=l.parseFormat(d)),/^[\-+]\d+[dmwy]([\s,]+[\-+]\d+[dmwy])*$/.test(c)){var g,h,i=/([\-+]\d+)([dmwy])/,j=c.match(/([\-+]\d+)([dmwy])/g);c=new Date;for(var m=0;m<j.length;m++)switch(g=i.exec(j[m]),h=parseInt(g[1]),g[2]){case"d":c.setUTCDate(c.getUTCDate()+h);break;case"m":c=e.prototype.moveMonth.call(e.prototype,c,h);break;case"w":c.setUTCDate(c.getUTCDate()+7*h);break;case"y":c=e.prototype.moveYear.call(e.prototype,c,h)}return b(c.getUTCFullYear(),c.getUTCMonth(),c.getUTCDate(),0,0,0)}var n,o,g,j=c&&c.match(this.nonpunctuation)||[],c=new Date,p={},q=["yyyy","yy","M","MM","m","mm","d","dd"],r={yyyy:function(a,b){return a.setUTCFullYear(b)},yy:function(a,b){return a.setUTCFullYear(2e3+b)},m:function(a,b){for(b-=1;0>b;)b+=12;for(b%=12,a.setUTCMonth(b);a.getUTCMonth()!=b;)a.setUTCDate(a.getUTCDate()-1);return a},d:function(a,b){return a.setUTCDate(b)}};r.M=r.MM=r.mm=r.m,r.dd=r.d,c=b(c.getFullYear(),c.getMonth(),c.getDate(),0,0,0);var s=d.parts.slice();if(j.length!=s.length&&(s=a(s).filter(function(b,c){return-1!==a.inArray(c,q)}).toArray()),j.length==s.length){for(var m=0,t=s.length;t>m;m++){if(n=parseInt(j[m],10),g=s[m],isNaN(n))switch(g){case"MM":o=a(k[f].months).filter(function(){var a=this.slice(0,j[m].length),b=j[m].slice(0,a.length);
return a==b}),n=a.inArray(o[0],k[f].months)+1;break;case"M":o=a(k[f].monthsShort).filter(function(){var a=this.slice(0,j[m].length),b=j[m].slice(0,a.length);return a==b}),n=a.inArray(o[0],k[f].monthsShort)+1}p[g]=n}for(var u,m=0;m<q.length;m++)u=q[m],u in p&&!isNaN(p[u])&&r[u](c,p[u])}return c},formatDate:function(b,c,d){"string"==typeof c&&(c=l.parseFormat(c));var e={d:b.getUTCDate(),D:k[d].daysShort[b.getUTCDay()],DD:k[d].days[b.getUTCDay()],m:b.getUTCMonth()+1,M:k[d].monthsShort[b.getUTCMonth()],MM:k[d].months[b.getUTCMonth()],yy:b.getUTCFullYear().toString().substring(2),yyyy:b.getUTCFullYear()};e.dd=(e.d<10?"0":"")+e.d,e.mm=(e.m<10?"0":"")+e.m;for(var b=[],f=a.extend([],c.separators),g=0,h=c.parts.length;h>=g;g++)f.length&&b.push(f.shift()),b.push(e[c.parts[g]]);return b.join("")},headTemplate:'<thead><tr><th class="prev"><i class="icon-arrow-left"/></th><th colspan="5" class="datepicker-switch"></th><th class="next"><i class="icon-arrow-right"/></th></tr></thead>',contTemplate:'<tbody><tr><td colspan="7"></td></tr></tbody>',footTemplate:'<tfoot><tr><th colspan="7" class="today"></th></tr><tr><th colspan="7" class="clear"></th></tr></tfoot>'};l.template='<div class="datepicker"><div class="datepicker-days"><table class=" table-condensed">'+l.headTemplate+"<tbody></tbody>"+l.footTemplate+"</table>"+"</div>"+'<div class="datepicker-months">'+'<table class="table-condensed">'+l.headTemplate+l.contTemplate+l.footTemplate+"</table>"+"</div>"+'<div class="datepicker-years">'+'<table class="table-condensed">'+l.headTemplate+l.contTemplate+l.footTemplate+"</table>"+"</div>"+"</div>",a.fn.datepicker.DPGlobal=l,a.fn.datepicker.noConflict=function(){return a.fn.datepicker=g,this},a(document).on("focus.datepicker.data-api click.datepicker.data-api",'[data-provide="datepicker"]',function(b){var c=a(this);c.data("datepicker")||(b.preventDefault(),h.call(c,"show"))}),a(function(){h.call(a('[data-provide="datepicker-inline"]'))})}(window.jQuery),function(a){"use strict";a.fn.bdatepicker=a.fn.datepicker.noConflict(),a.fn.datepicker||(a.fn.datepicker=a.fn.bdatepicker);var b=function(a){this.init("date",a,b.defaults),this.initPicker(a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{initPicker:function(b,c){this.options.viewformat||(this.options.viewformat=this.options.format),b.datepicker=a.fn.editableutils.tryParseJson(b.datepicker,!0),this.options.datepicker=a.extend({},c.datepicker,b.datepicker,{format:this.options.viewformat}),this.options.datepicker.language=this.options.datepicker.language||"en",this.dpg=a.fn.bdatepicker.DPGlobal,this.parsedFormat=this.dpg.parseFormat(this.options.format),this.parsedViewFormat=this.dpg.parseFormat(this.options.viewformat)},render:function(){this.$input.bdatepicker(this.options.datepicker),this.options.clear&&(this.$clear=a('<a href="#"></a>').html(this.options.clear).click(a.proxy(function(a){a.preventDefault(),a.stopPropagation(),this.clear()},this)),this.$tpl.parent().append(a('<div class="editable-clear">').append(this.$clear)))},value2html:function(a,c){var d=a?this.dpg.formatDate(a,this.parsedViewFormat,this.options.datepicker.language):"";b.superclass.value2html.call(this,d,c)},html2value:function(a){return this.parseDate(a,this.parsedViewFormat)},value2str:function(a){return a?this.dpg.formatDate(a,this.parsedFormat,this.options.datepicker.language):""},str2value:function(a){return this.parseDate(a,this.parsedFormat)},value2submit:function(a){return this.value2str(a)},value2input:function(a){this.$input.bdatepicker("update",a)},input2value:function(){return this.$input.data("datepicker").date},activate:function(){},clear:function(){this.$input.data("datepicker").date=null,this.$input.find(".active").removeClass("active"),this.options.showbuttons||this.$input.closest("form").submit()},autosubmit:function(){this.$input.on("mouseup",".day",function(b){if(!a(b.currentTarget).is(".old")&&!a(b.currentTarget).is(".new")){var c=a(this).closest("form");setTimeout(function(){c.submit()},200)}})},parseDate:function(a,b){var c,d=null;return a&&(d=this.dpg.parseDate(a,b,this.options.datepicker.language),"string"==typeof a&&(c=this.dpg.formatDate(d,b,this.options.datepicker.language),a!==c&&(d=null))),d}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{tpl:'<div class="editable-date well"></div>',inputclass:null,format:"yyyy-mm-dd",viewformat:null,datepicker:{weekStart:0,startView:0,minViewMode:0,autoclose:!1},clear:"&times; clear"}),a.fn.editabletypes.date=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("datefield",a,b.defaults),this.initPicker(a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.date),a.extend(b.prototype,{render:function(){this.$input=this.$tpl.find("input"),this.setClass(),this.setAttr("placeholder"),this.$tpl.bdatepicker(this.options.datepicker),this.$input.off("focus keydown"),this.$input.keyup(a.proxy(function(){this.$tpl.removeData("date"),this.$tpl.bdatepicker("update")},this))},value2input:function(a){this.$input.val(a?this.dpg.formatDate(a,this.parsedViewFormat,this.options.datepicker.language):""),this.$tpl.bdatepicker("update")},input2value:function(){return this.html2value(this.$input.val())},activate:function(){a.fn.editabletypes.text.prototype.activate.call(this)},autosubmit:function(){}}),b.defaults=a.extend({},a.fn.editabletypes.date.defaults,{tpl:'<div class="input-append date"><input type="text"/><span class="add-on"><i class="icon-th"></i></span></div>',inputclass:"input-small",datepicker:{weekStart:0,startView:0,minViewMode:0,autoclose:!0}}),a.fn.editabletypes.datefield=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("datetime",a,b.defaults),this.initPicker(a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.abstractinput),a.extend(b.prototype,{initPicker:function(b,c){this.options.viewformat||(this.options.viewformat=this.options.format),b.datetimepicker=a.fn.editableutils.tryParseJson(b.datetimepicker,!0),this.options.datetimepicker=a.extend({},c.datetimepicker,b.datetimepicker,{format:this.options.viewformat}),this.options.datetimepicker.language=this.options.datetimepicker.language||"en",this.dpg=a.fn.datetimepicker.DPGlobal,this.parsedFormat=this.dpg.parseFormat(this.options.format,this.options.formatType),this.parsedViewFormat=this.dpg.parseFormat(this.options.viewformat,this.options.formatType)},render:function(){this.$input.datetimepicker(this.options.datetimepicker),this.$input.on("changeMode",function(){var b=a(this).closest("form").parent();setTimeout(function(){b.triggerHandler("resize")},0)}),this.options.clear&&(this.$clear=a('<a href="#"></a>').html(this.options.clear).click(a.proxy(function(a){a.preventDefault(),a.stopPropagation(),this.clear()},this)),this.$tpl.parent().append(a('<div class="editable-clear">').append(this.$clear)))},value2html:function(a,c){var d=a?this.dpg.formatDate(this.toUTC(a),this.parsedViewFormat,this.options.datetimepicker.language,this.options.formatType):"";return c?(b.superclass.value2html.call(this,d,c),void 0):d},html2value:function(a){var b=this.parseDate(a,this.parsedViewFormat);return b?this.fromUTC(b):null},value2str:function(a){return a?this.dpg.formatDate(this.toUTC(a),this.parsedFormat,this.options.datetimepicker.language,this.options.formatType):""},str2value:function(a){var b=this.parseDate(a,this.parsedFormat);return b?this.fromUTC(b):null},value2submit:function(a){return this.value2str(a)},value2input:function(a){a&&this.$input.data("datetimepicker").setDate(a)},input2value:function(){var a=this.$input.data("datetimepicker");return a.date?a.getDate():null},activate:function(){},clear:function(){this.$input.data("datetimepicker").date=null,this.$input.find(".active").removeClass("active"),this.options.showbuttons||this.$input.closest("form").submit()},autosubmit:function(){this.$input.on("mouseup",".minute",function(){var b=a(this).closest("form");setTimeout(function(){b.submit()},200)})},toUTC:function(a){return a?new Date(a.valueOf()-6e4*a.getTimezoneOffset()):a},fromUTC:function(a){return a?new Date(a.valueOf()+6e4*a.getTimezoneOffset()):a},parseDate:function(a,b){var c,d=null;return a&&(d=this.dpg.parseDate(a,b,this.options.datetimepicker.language,this.options.formatType),"string"==typeof a&&(c=this.dpg.formatDate(d,b,this.options.datetimepicker.language,this.options.formatType),a!==c&&(d=null))),d}}),b.defaults=a.extend({},a.fn.editabletypes.abstractinput.defaults,{tpl:'<div class="editable-date well"></div>',inputclass:null,format:"yyyy-mm-dd hh:ii",formatType:"standard",viewformat:null,datetimepicker:{todayHighlight:!1,autoclose:!1},clear:"&times; clear"}),a.fn.editabletypes.datetime=b}(window.jQuery),function(a){"use strict";var b=function(a){this.init("datetimefield",a,b.defaults),this.initPicker(a,b.defaults)};a.fn.editableutils.inherit(b,a.fn.editabletypes.datetime),a.extend(b.prototype,{render:function(){this.$input=this.$tpl.find("input"),this.setClass(),this.setAttr("placeholder"),this.$tpl.datetimepicker(this.options.datetimepicker),this.$input.off("focus keydown"),this.$input.keyup(a.proxy(function(){this.$tpl.removeData("date"),this.$tpl.datetimepicker("update")},this))},value2input:function(a){this.$input.val(this.value2html(a)),this.$tpl.datetimepicker("update")},input2value:function(){return this.html2value(this.$input.val())},activate:function(){a.fn.editabletypes.text.prototype.activate.call(this)},autosubmit:function(){}}),b.defaults=a.extend({},a.fn.editabletypes.datetime.defaults,{tpl:'<div class="input-append date"><input type="text"/><span class="add-on"><i class="icon-th"></i></span></div>',inputclass:"input-medium",datetimepicker:{todayHighlight:!1,autoclose:!0}}),a.fn.editabletypes.datetimefield=b}(window.jQuery);;
/* Masked Input plugin for jQuery
Copyright (c) 2007-2013 Josh Bush (digitalbush.com)
Licensed under the MIT license (http://digitalbush.com/projects/masked-input-plugin/#license)
Version: 1.3.1 */
(function(e){function t(){var e=document.createElement("input"),t="onpaste";return e.setAttribute(t,""),"function"==typeof e[t]?"paste":"input"}var n,a=t()+".mask",r=navigator.userAgent,i=/iphone/i.test(r),o=/android/i.test(r);e.mask={definitions:{9:"[0-9]",a:"[A-Za-z]","*":"[A-Za-z0-9]"},dataName:"rawMaskFn",placeholder:"_"},e.fn.extend({caret:function(e,t){var n;if(0!==this.length&&!this.is(":hidden"))return"number"==typeof e?(t="number"==typeof t?t:e,this.each(function(){this.setSelectionRange?this.setSelectionRange(e,t):this.createTextRange&&(n=this.createTextRange(),n.collapse(!0),n.moveEnd("character",t),n.moveStart("character",e),n.select())})):(this[0].setSelectionRange?(e=this[0].selectionStart,t=this[0].selectionEnd):document.selection&&document.selection.createRange&&(n=document.selection.createRange(),e=0-n.duplicate().moveStart("character",-1e5),t=e+n.text.length),{begin:e,end:t})},unmask:function(){return this.trigger("unmask")},mask:function(t,r){var c,l,s,u,f,h;return!t&&this.length>0?(c=e(this[0]),c.data(e.mask.dataName)()):(r=e.extend({placeholder:e.mask.placeholder,completed:null},r),l=e.mask.definitions,s=[],u=h=t.length,f=null,e.each(t.split(""),function(e,t){"?"==t?(h--,u=e):l[t]?(s.push(RegExp(l[t])),null===f&&(f=s.length-1)):s.push(null)}),this.trigger("unmask").each(function(){function c(e){for(;h>++e&&!s[e];);return e}function d(e){for(;--e>=0&&!s[e];);return e}function m(e,t){var n,a;if(!(0>e)){for(n=e,a=c(t);h>n;n++)if(s[n]){if(!(h>a&&s[n].test(R[a])))break;R[n]=R[a],R[a]=r.placeholder,a=c(a)}b(),x.caret(Math.max(f,e))}}function p(e){var t,n,a,i;for(t=e,n=r.placeholder;h>t;t++)if(s[t]){if(a=c(t),i=R[t],R[t]=n,!(h>a&&s[a].test(i)))break;n=i}}function g(e){var t,n,a,r=e.which;8===r||46===r||i&&127===r?(t=x.caret(),n=t.begin,a=t.end,0===a-n&&(n=46!==r?d(n):a=c(n-1),a=46===r?c(a):a),k(n,a),m(n,a-1),e.preventDefault()):27==r&&(x.val(S),x.caret(0,y()),e.preventDefault())}function v(t){var n,a,i,l=t.which,u=x.caret();t.ctrlKey||t.altKey||t.metaKey||32>l||l&&(0!==u.end-u.begin&&(k(u.begin,u.end),m(u.begin,u.end-1)),n=c(u.begin-1),h>n&&(a=String.fromCharCode(l),s[n].test(a)&&(p(n),R[n]=a,b(),i=c(n),o?setTimeout(e.proxy(e.fn.caret,x,i),0):x.caret(i),r.completed&&i>=h&&r.completed.call(x))),t.preventDefault())}function k(e,t){var n;for(n=e;t>n&&h>n;n++)s[n]&&(R[n]=r.placeholder)}function b(){x.val(R.join(""))}function y(e){var t,n,a=x.val(),i=-1;for(t=0,pos=0;h>t;t++)if(s[t]){for(R[t]=r.placeholder;pos++<a.length;)if(n=a.charAt(pos-1),s[t].test(n)){R[t]=n,i=t;break}if(pos>a.length)break}else R[t]===a.charAt(pos)&&t!==u&&(pos++,i=t);return e?b():u>i+1?(x.val(""),k(0,h)):(b(),x.val(x.val().substring(0,i+1))),u?t:f}var x=e(this),R=e.map(t.split(""),function(e){return"?"!=e?l[e]?r.placeholder:e:void 0}),S=x.val();x.data(e.mask.dataName,function(){return e.map(R,function(e,t){return s[t]&&e!=r.placeholder?e:null}).join("")}),x.attr("readonly")||x.one("unmask",function(){x.unbind(".mask").removeData(e.mask.dataName)}).bind("focus.mask",function(){clearTimeout(n);var e;S=x.val(),e=y(),n=setTimeout(function(){b(),e==t.length?x.caret(0,e):x.caret(e)},10)}).bind("blur.mask",function(){y(),x.val()!=S&&x.change()}).bind("keydown.mask",g).bind("keypress.mask",v).bind(a,function(){setTimeout(function(){var e=y(!0);x.caret(e),r.completed&&e==x.val().length&&r.completed.call(x)},0)}),y()}))}})})(jQuery);;
/*

 FullCalendar v1.5.4
 http://arshaw.com/fullcalendar/

 Use fullcalendar.css for basic styling.
 For event drag & drop, requires jQuery UI draggable.
 For event resizing, requires jQuery UI resizable.

 Copyright (c) 2011 Adam Shaw
 Dual licensed under the MIT and GPL licenses, located in
 MIT-LICENSE.txt and GPL-LICENSE.txt respectively.

 Date: Tue Sep 4 23:38:33 2012 -0700

*/
(function(m,ma){function wb(a){m.extend(true,Ya,a)}function Yb(a,b,e){function d(k){if(E){u();q();na();S(k)}else f()}function f(){B=b.theme?"ui":"fc";a.addClass("fc");b.isRTL&&a.addClass("fc-rtl");b.theme&&a.addClass("ui-widget");E=m("<div class='fc-content' style='position:relative'/>").prependTo(a);C=new Zb(X,b);(P=C.render())&&a.prepend(P);y(b.defaultView);m(window).resize(oa);t()||g()}function g(){setTimeout(function(){!n.start&&t()&&S()},0)}function l(){m(window).unbind("resize",oa);C.destroy();
E.remove();a.removeClass("fc fc-rtl ui-widget")}function j(){return i.offsetWidth!==0}function t(){return m("body")[0].offsetWidth!==0}function y(k){if(!n||k!=n.name){F++;pa();var D=n,Z;if(D){(D.beforeHide||xb)();Za(E,E.height());D.element.hide()}else Za(E,1);E.css("overflow","hidden");if(n=Y[k])n.element.show();else n=Y[k]=new Ja[k](Z=s=m("<div class='fc-view fc-view-"+k+"' style='position:absolute'/>").appendTo(E),X);D&&C.deactivateButton(D.name);C.activateButton(k);S();E.css("overflow","");D&&
Za(E,1);Z||(n.afterShow||xb)();F--}}function S(k){if(j()){F++;pa();o===ma&&u();var D=false;if(!n.start||k||r<n.start||r>=n.end){n.render(r,k||0);fa(true);D=true}else if(n.sizeDirty){n.clearEvents();fa();D=true}else if(n.eventsDirty){n.clearEvents();D=true}n.sizeDirty=false;n.eventsDirty=false;ga(D);W=a.outerWidth();C.updateTitle(n.title);k=new Date;k>=n.start&&k<n.end?C.disableButton("today"):C.enableButton("today");F--;n.trigger("viewDisplay",i)}}function Q(){q();if(j()){u();fa();pa();n.clearEvents();
n.renderEvents(J);n.sizeDirty=false}}function q(){m.each(Y,function(k,D){D.sizeDirty=true})}function u(){o=b.contentHeight?b.contentHeight:b.height?b.height-(P?P.height():0)-Sa(E):Math.round(E.width()/Math.max(b.aspectRatio,0.5))}function fa(k){F++;n.setHeight(o,k);if(s){s.css("position","relative");s=null}n.setWidth(E.width(),k);F--}function oa(){if(!F)if(n.start){var k=++v;setTimeout(function(){if(k==v&&!F&&j())if(W!=(W=a.outerWidth())){F++;Q();n.trigger("windowResize",i);F--}},200)}else g()}function ga(k){if(!b.lazyFetching||
ya(n.visStart,n.visEnd))ra();else k&&da()}function ra(){K(n.visStart,n.visEnd)}function sa(k){J=k;da()}function ha(k){da(k)}function da(k){na();if(j()){n.clearEvents();n.renderEvents(J,k);n.eventsDirty=false}}function na(){m.each(Y,function(k,D){D.eventsDirty=true})}function ua(k,D,Z){n.select(k,D,Z===ma?true:Z)}function pa(){n&&n.unselect()}function U(){S(-1)}function ca(){S(1)}function ka(){gb(r,-1);S()}function qa(){gb(r,1);S()}function G(){r=new Date;S()}function p(k,D,Z){if(k instanceof Date)r=
N(k);else yb(r,k,D,Z);S()}function L(k,D,Z){k!==ma&&gb(r,k);D!==ma&&hb(r,D);Z!==ma&&ba(r,Z);S()}function c(){return N(r)}function z(){return n}function H(k,D){if(D===ma)return b[k];if(k=="height"||k=="contentHeight"||k=="aspectRatio"){b[k]=D;Q()}}function T(k,D){if(b[k])return b[k].apply(D||i,Array.prototype.slice.call(arguments,2))}var X=this;X.options=b;X.render=d;X.destroy=l;X.refetchEvents=ra;X.reportEvents=sa;X.reportEventChange=ha;X.rerenderEvents=da;X.changeView=y;X.select=ua;X.unselect=pa;
X.prev=U;X.next=ca;X.prevYear=ka;X.nextYear=qa;X.today=G;X.gotoDate=p;X.incrementDate=L;X.formatDate=function(k,D){return Oa(k,D,b)};X.formatDates=function(k,D,Z){return ib(k,D,Z,b)};X.getDate=c;X.getView=z;X.option=H;X.trigger=T;$b.call(X,b,e);var ya=X.isFetchNeeded,K=X.fetchEvents,i=a[0],C,P,E,B,n,Y={},W,o,s,v=0,F=0,r=new Date,J=[],M;yb(r,b.year,b.month,b.date);b.droppable&&m(document).bind("dragstart",function(k,D){var Z=k.target,ja=m(Z);if(!ja.parents(".fc").length){var ia=b.dropAccept;if(m.isFunction(ia)?
ia.call(Z,ja):ja.is(ia)){M=Z;n.dragStart(M,k,D)}}}).bind("dragstop",function(k,D){if(M){n.dragStop(M,k,D);M=null}})}function Zb(a,b){function e(){q=b.theme?"ui":"fc";if(b.header)return Q=m("<table class='fc-header' style='width:100%'/>").append(m("<tr/>").append(f("left")).append(f("center")).append(f("right")))}function d(){Q.remove()}function f(u){var fa=m("<td class='fc-header-"+u+"'/>");(u=b.header[u])&&m.each(u.split(" "),function(oa){oa>0&&fa.append("<span class='fc-header-space'/>");var ga;
m.each(this.split(","),function(ra,sa){if(sa=="title"){fa.append("<span class='fc-header-title'><h2>&nbsp;</h2></span>");ga&&ga.addClass(q+"-corner-right");ga=null}else{var ha;if(a[sa])ha=a[sa];else if(Ja[sa])ha=function(){na.removeClass(q+"-state-hover");a.changeView(sa)};if(ha){ra=b.theme?jb(b.buttonIcons,sa):null;var da=jb(b.buttonText,sa),na=m("<span class='fc-button fc-button-"+sa+" "+q+"-state-default'><span class='fc-button-inner'><span class='fc-button-content'>"+(ra?"<span class='fc-icon-wrap'><span class='ui-icon ui-icon-"+
ra+"'/></span>":da)+"</span><span class='fc-button-effect'><span></span></span></span></span>");if(na){na.click(function(){na.hasClass(q+"-state-disabled")||ha()}).mousedown(function(){na.not("."+q+"-state-active").not("."+q+"-state-disabled").addClass(q+"-state-down")}).mouseup(function(){na.removeClass(q+"-state-down")}).hover(function(){na.not("."+q+"-state-active").not("."+q+"-state-disabled").addClass(q+"-state-hover")},function(){na.removeClass(q+"-state-hover").removeClass(q+"-state-down")}).appendTo(fa);
ga||na.addClass(q+"-corner-left");ga=na}}}});ga&&ga.addClass(q+"-corner-right")});return fa}function g(u){Q.find("h2").html(u)}function l(u){Q.find("span.fc-button-"+u).addClass(q+"-state-active")}function j(u){Q.find("span.fc-button-"+u).removeClass(q+"-state-active")}function t(u){Q.find("span.fc-button-"+u).addClass(q+"-state-disabled")}function y(u){Q.find("span.fc-button-"+u).removeClass(q+"-state-disabled")}var S=this;S.render=e;S.destroy=d;S.updateTitle=g;S.activateButton=l;S.deactivateButton=
j;S.disableButton=t;S.enableButton=y;var Q=m([]),q}function $b(a,b){function e(c,z){return!ca||c<ca||z>ka}function d(c,z){ca=c;ka=z;L=[];c=++qa;G=z=U.length;for(var H=0;H<z;H++)f(U[H],c)}function f(c,z){g(c,function(H){if(z==qa){if(H){for(var T=0;T<H.length;T++){H[T].source=c;oa(H[T])}L=L.concat(H)}G--;G||ua(L)}})}function g(c,z){var H,T=Aa.sourceFetchers,X;for(H=0;H<T.length;H++){X=T[H](c,ca,ka,z);if(X===true)return;else if(typeof X=="object"){g(X,z);return}}if(H=c.events)if(m.isFunction(H)){u();
H(N(ca),N(ka),function(C){z(C);fa()})}else m.isArray(H)?z(H):z();else if(c.url){var ya=c.success,K=c.error,i=c.complete;H=m.extend({},c.data||{});T=Ta(c.startParam,a.startParam);X=Ta(c.endParam,a.endParam);if(T)H[T]=Math.round(+ca/1E3);if(X)H[X]=Math.round(+ka/1E3);u();m.ajax(m.extend({},ac,c,{data:H,success:function(C){C=C||[];var P=$a(ya,this,arguments);if(m.isArray(P))C=P;z(C)},error:function(){$a(K,this,arguments);z()},complete:function(){$a(i,this,arguments);fa()}}))}else z()}function l(c){if(c=
j(c)){G++;f(c,qa)}}function j(c){if(m.isFunction(c)||m.isArray(c))c={events:c};else if(typeof c=="string")c={url:c};if(typeof c=="object"){ga(c);U.push(c);return c}}function t(c){U=m.grep(U,function(z){return!ra(z,c)});L=m.grep(L,function(z){return!ra(z.source,c)});ua(L)}function y(c){var z,H=L.length,T,X=na().defaultEventEnd,ya=c.start-c._start,K=c.end?c.end-(c._end||X(c)):0;for(z=0;z<H;z++){T=L[z];if(T._id==c._id&&T!=c){T.start=new Date(+T.start+ya);T.end=c.end?T.end?new Date(+T.end+K):new Date(+X(T)+
K):null;T.title=c.title;T.url=c.url;T.allDay=c.allDay;T.className=c.className;T.editable=c.editable;T.color=c.color;T.backgroudColor=c.backgroudColor;T.borderColor=c.borderColor;T.textColor=c.textColor;oa(T)}}oa(c);ua(L)}function S(c,z){oa(c);if(!c.source){if(z){pa.events.push(c);c.source=pa}L.push(c)}ua(L)}function Q(c){if(c){if(!m.isFunction(c)){var z=c+"";c=function(T){return T._id==z}}L=m.grep(L,c,true);for(H=0;H<U.length;H++)if(m.isArray(U[H].events))U[H].events=m.grep(U[H].events,c,true)}else{L=
[];for(var H=0;H<U.length;H++)if(m.isArray(U[H].events))U[H].events=[]}ua(L)}function q(c){if(m.isFunction(c))return m.grep(L,c);else if(c){c+="";return m.grep(L,function(z){return z._id==c})}return L}function u(){p++||da("loading",null,true)}function fa(){--p||da("loading",null,false)}function oa(c){var z=c.source||{},H=Ta(z.ignoreTimezone,a.ignoreTimezone);c._id=c._id||(c.id===ma?"_fc"+bc++:c.id+"");if(c.date){if(!c.start)c.start=c.date;delete c.date}c._start=N(c.start=kb(c.start,H));c.end=kb(c.end,
H);if(c.end&&c.end<=c.start)c.end=null;c._end=c.end?N(c.end):null;if(c.allDay===ma)c.allDay=Ta(z.allDayDefault,a.allDayDefault);if(c.className){if(typeof c.className=="string")c.className=c.className.split(/\s+/)}else c.className=[]}function ga(c){if(c.className){if(typeof c.className=="string")c.className=c.className.split(/\s+/)}else c.className=[];for(var z=Aa.sourceNormalizers,H=0;H<z.length;H++)z[H](c)}function ra(c,z){return c&&z&&sa(c)==sa(z)}function sa(c){return(typeof c=="object"?c.events||
c.url:"")||c}var ha=this;ha.isFetchNeeded=e;ha.fetchEvents=d;ha.addEventSource=l;ha.removeEventSource=t;ha.updateEvent=y;ha.renderEvent=S;ha.removeEvents=Q;ha.clientEvents=q;ha.normalizeEvent=oa;var da=ha.trigger,na=ha.getView,ua=ha.reportEvents,pa={events:[]},U=[pa],ca,ka,qa=0,G=0,p=0,L=[];for(ha=0;ha<b.length;ha++)j(b[ha])}function gb(a,b,e){a.setFullYear(a.getFullYear()+b);e||Ka(a);return a}function hb(a,b,e){if(+a){b=a.getMonth()+b;var d=N(a);d.setDate(1);d.setMonth(b);a.setMonth(b);for(e||Ka(a);a.getMonth()!=
d.getMonth();)a.setDate(a.getDate()+(a<d?1:-1))}return a}function ba(a,b,e){if(+a){b=a.getDate()+b;var d=N(a);d.setHours(9);d.setDate(b);a.setDate(b);e||Ka(a);lb(a,d)}return a}function lb(a,b){if(+a)for(;a.getDate()!=b.getDate();)a.setTime(+a+(a<b?1:-1)*cc)}function xa(a,b){a.setMinutes(a.getMinutes()+b);return a}function Ka(a){a.setHours(0);a.setMinutes(0);a.setSeconds(0);a.setMilliseconds(0);return a}function N(a,b){if(b)return Ka(new Date(+a));return new Date(+a)}function zb(){var a=0,b;do b=new Date(1970,
a++,1);while(b.getHours());return b}function Fa(a,b,e){for(b=b||1;!a.getDay()||e&&a.getDay()==1||!e&&a.getDay()==6;)ba(a,b);return a}function Ca(a,b){return Math.round((N(a,true)-N(b,true))/Ab)}function yb(a,b,e,d){if(b!==ma&&b!=a.getFullYear()){a.setDate(1);a.setMonth(0);a.setFullYear(b)}if(e!==ma&&e!=a.getMonth()){a.setDate(1);a.setMonth(e)}d!==ma&&a.setDate(d)}function kb(a,b){if(typeof a=="object")return a;if(typeof a=="number")return new Date(a*1E3);if(typeof a=="string"){if(a.match(/^\d+(\.\d+)?$/))return new Date(parseFloat(a)*
1E3);if(b===ma)b=true;return Bb(a,b)||(a?new Date(a):null)}return null}function Bb(a,b){a=a.match(/^([0-9]{4})(-([0-9]{2})(-([0-9]{2})([T ]([0-9]{2}):([0-9]{2})(:([0-9]{2})(\.([0-9]+))?)?(Z|(([-+])([0-9]{2})(:?([0-9]{2}))?))?)?)?)?$/);if(!a)return null;var e=new Date(a[1],0,1);if(b||!a[13]){b=new Date(a[1],0,1,9,0);if(a[3]){e.setMonth(a[3]-1);b.setMonth(a[3]-1)}if(a[5]){e.setDate(a[5]);b.setDate(a[5])}lb(e,b);a[7]&&e.setHours(a[7]);a[8]&&e.setMinutes(a[8]);a[10]&&e.setSeconds(a[10]);a[12]&&e.setMilliseconds(Number("0."+
a[12])*1E3);lb(e,b)}else{e.setUTCFullYear(a[1],a[3]?a[3]-1:0,a[5]||1);e.setUTCHours(a[7]||0,a[8]||0,a[10]||0,a[12]?Number("0."+a[12])*1E3:0);if(a[14]){b=Number(a[16])*60+(a[18]?Number(a[18]):0);b*=a[15]=="-"?1:-1;e=new Date(+e+b*60*1E3)}}return e}function mb(a){if(typeof a=="number")return a*60;if(typeof a=="object")return a.getHours()*60+a.getMinutes();if(a=a.match(/(\d+)(?::(\d+))?\s*(\w+)?/)){var b=parseInt(a[1],10);if(a[3]){b%=12;if(a[3].toLowerCase().charAt(0)=="p")b+=12}return b*60+(a[2]?parseInt(a[2],
10):0)}}function Oa(a,b,e){return ib(a,null,b,e)}function ib(a,b,e,d){d=d||Ya;var f=a,g=b,l,j=e.length,t,y,S,Q="";for(l=0;l<j;l++){t=e.charAt(l);if(t=="'")for(y=l+1;y<j;y++){if(e.charAt(y)=="'"){if(f){Q+=y==l+1?"'":e.substring(l+1,y);l=y}break}}else if(t=="(")for(y=l+1;y<j;y++){if(e.charAt(y)==")"){l=Oa(f,e.substring(l+1,y),d);if(parseInt(l.replace(/\D/,""),10))Q+=l;l=y;break}}else if(t=="[")for(y=l+1;y<j;y++){if(e.charAt(y)=="]"){t=e.substring(l+1,y);l=Oa(f,t,d);if(l!=Oa(g,t,d))Q+=l;l=y;break}}else if(t==
"{"){f=b;g=a}else if(t=="}"){f=a;g=b}else{for(y=j;y>l;y--)if(S=dc[e.substring(l,y)]){if(f)Q+=S(f,d);l=y-1;break}if(y==l)if(f)Q+=t}}return Q}function Ua(a){return a.end?ec(a.end,a.allDay):ba(N(a.start),1)}function ec(a,b){a=N(a);return b||a.getHours()||a.getMinutes()?ba(a,1):Ka(a)}function fc(a,b){return(b.msLength-a.msLength)*100+(a.event.start-b.event.start)}function Cb(a,b){return a.end>b.start&&a.start<b.end}function nb(a,b,e,d){var f=[],g,l=a.length,j,t,y,S,Q;for(g=0;g<l;g++){j=a[g];t=j.start;
y=b[g];if(y>e&&t<d){if(t<e){t=N(e);S=false}else{t=t;S=true}if(y>d){y=N(d);Q=false}else{y=y;Q=true}f.push({event:j,start:t,end:y,isStart:S,isEnd:Q,msLength:y-t})}}return f.sort(fc)}function ob(a){var b=[],e,d=a.length,f,g,l,j;for(e=0;e<d;e++){f=a[e];for(g=0;;){l=false;if(b[g])for(j=0;j<b[g].length;j++)if(Cb(b[g][j],f)){l=true;break}if(l)g++;else break}if(b[g])b[g].push(f);else b[g]=[f]}return b}function Db(a,b,e){a.unbind("mouseover").mouseover(function(d){for(var f=d.target,g;f!=this;){g=f;f=f.parentNode}if((f=
g._fci)!==ma){g._fci=ma;g=b[f];e(g.event,g.element,g);m(d.target).trigger(d)}d.stopPropagation()})}function Va(a,b,e){for(var d=0,f;d<a.length;d++){f=m(a[d]);f.width(Math.max(0,b-pb(f,e)))}}function Eb(a,b,e){for(var d=0,f;d<a.length;d++){f=m(a[d]);f.height(Math.max(0,b-Sa(f,e)))}}function pb(a,b){return gc(a)+hc(a)+(b?ic(a):0)}function gc(a){return(parseFloat(m.css(a[0],"paddingLeft",true))||0)+(parseFloat(m.css(a[0],"paddingRight",true))||0)}function ic(a){return(parseFloat(m.css(a[0],"marginLeft",
true))||0)+(parseFloat(m.css(a[0],"marginRight",true))||0)}function hc(a){return(parseFloat(m.css(a[0],"borderLeftWidth",true))||0)+(parseFloat(m.css(a[0],"borderRightWidth",true))||0)}function Sa(a,b){return jc(a)+kc(a)+(b?Fb(a):0)}function jc(a){return(parseFloat(m.css(a[0],"paddingTop",true))||0)+(parseFloat(m.css(a[0],"paddingBottom",true))||0)}function Fb(a){return(parseFloat(m.css(a[0],"marginTop",true))||0)+(parseFloat(m.css(a[0],"marginBottom",true))||0)}function kc(a){return(parseFloat(m.css(a[0],
"borderTopWidth",true))||0)+(parseFloat(m.css(a[0],"borderBottomWidth",true))||0)}function Za(a,b){b=typeof b=="number"?b+"px":b;a.each(function(e,d){d.style.cssText+=";min-height:"+b+";_height:"+b})}function xb(){}function Gb(a,b){return a-b}function Hb(a){return Math.max.apply(Math,a)}function Pa(a){return(a<10?"0":"")+a}function jb(a,b){if(a[b]!==ma)return a[b];b=b.split(/(?=[A-Z])/);for(var e=b.length-1,d;e>=0;e--){d=a[b[e].toLowerCase()];if(d!==ma)return d}return a[""]}function Qa(a){return a.replace(/&/g,
"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/'/g,"&#039;").replace(/"/g,"&quot;").replace(/\n/g,"<br />")}function Ib(a){return a.id+"/"+a.className+"/"+a.style.cssText.replace(/(^|;)\s*(top|left|width|height)\s*:[^;]*/ig,"")}function qb(a){a.attr("unselectable","on").css("MozUserSelect","none").bind("selectstart.ui",function(){return false})}function ab(a){a.children().removeClass("fc-first fc-last").filter(":first-child").addClass("fc-first").end().filter(":last-child").addClass("fc-last")}
function rb(a,b){a.each(function(e,d){d.className=d.className.replace(/^fc-\w*/,"fc-"+lc[b.getDay()])})}function Jb(a,b){var e=a.source||{},d=a.color,f=e.color,g=b("eventColor"),l=a.backgroundColor||d||e.backgroundColor||f||b("eventBackgroundColor")||g;d=a.borderColor||d||e.borderColor||f||b("eventBorderColor")||g;a=a.textColor||e.textColor||b("eventTextColor");b=[];l&&b.push("background-color:"+l);d&&b.push("border-color:"+d);a&&b.push("color:"+a);return b.join(";")}function $a(a,b,e){if(m.isFunction(a))a=
[a];if(a){var d,f;for(d=0;d<a.length;d++)f=a[d].apply(b,e)||f;return f}}function Ta(){for(var a=0;a<arguments.length;a++)if(arguments[a]!==ma)return arguments[a]}function mc(a,b){function e(j,t){if(t){hb(j,t);j.setDate(1)}j=N(j,true);j.setDate(1);t=hb(N(j),1);var y=N(j),S=N(t),Q=f("firstDay"),q=f("weekends")?0:1;if(q){Fa(y);Fa(S,-1,true)}ba(y,-((y.getDay()-Math.max(Q,q)+7)%7));ba(S,(7-S.getDay()+Math.max(Q,q))%7);Q=Math.round((S-y)/(Ab*7));if(f("weekMode")=="fixed"){ba(S,(6-Q)*7);Q=6}d.title=l(j,
f("titleFormat"));d.start=j;d.end=t;d.visStart=y;d.visEnd=S;g(6,Q,q?5:7,true)}var d=this;d.render=e;sb.call(d,a,b,"month");var f=d.opt,g=d.renderBasic,l=b.formatDate}function nc(a,b){function e(j,t){t&&ba(j,t*7);j=ba(N(j),-((j.getDay()-f("firstDay")+7)%7));t=ba(N(j),7);var y=N(j),S=N(t),Q=f("weekends");if(!Q){Fa(y);Fa(S,-1,true)}d.title=l(y,ba(N(S),-1),f("titleFormat"));d.start=j;d.end=t;d.visStart=y;d.visEnd=S;g(1,1,Q?7:5,false)}var d=this;d.render=e;sb.call(d,a,b,"basicWeek");var f=d.opt,g=d.renderBasic,
l=b.formatDates}function oc(a,b){function e(j,t){if(t){ba(j,t);f("weekends")||Fa(j,t<0?-1:1)}d.title=l(j,f("titleFormat"));d.start=d.visStart=N(j,true);d.end=d.visEnd=ba(N(d.start),1);g(1,1,1,false)}var d=this;d.render=e;sb.call(d,a,b,"basicDay");var f=d.opt,g=d.renderBasic,l=b.formatDate}function sb(a,b,e){function d(w,I,R,V){v=I;F=R;f();(I=!C)?g(w,V):z();l(I)}function f(){if(k=L("isRTL")){D=-1;Z=F-1}else{D=1;Z=0}ja=L("firstDay");ia=L("weekends")?0:1;la=L("theme")?"ui":"fc";$=L("columnFormat")}function g(w,
I){var R,V=la+"-widget-header",ea=la+"-widget-content",aa;R="<table class='fc-border-separate' style='width:100%' cellspacing='0'><thead><tr>";for(aa=0;aa<F;aa++)R+="<th class='fc- "+V+"'/>";R+="</tr></thead><tbody>";for(aa=0;aa<w;aa++){R+="<tr class='fc-week"+aa+"'>";for(V=0;V<F;V++)R+="<td class='fc- "+ea+" fc-day"+(aa*F+V)+"'><div>"+(I?"<div class='fc-day-number'/>":"")+"<div class='fc-day-content'><div style='position:relative'>&nbsp;</div></div></div></td>";R+="</tr>"}R+="</tbody></table>";w=
m(R).appendTo(a);K=w.find("thead");i=K.find("th");C=w.find("tbody");P=C.find("tr");E=C.find("td");B=E.filter(":first-child");n=P.eq(0).find("div.fc-day-content div");ab(K.add(K.find("tr")));ab(P);P.eq(0).addClass("fc-first");y(E);Y=m("<div style='position:absolute;z-index:8;top:0;left:0'/>").appendTo(a)}function l(w){var I=w||v==1,R=p.start.getMonth(),V=Ka(new Date),ea,aa,va;I&&i.each(function(wa,Ga){ea=m(Ga);aa=ca(wa);ea.html(ya(aa,$));rb(ea,aa)});E.each(function(wa,Ga){ea=m(Ga);aa=ca(wa);aa.getMonth()==
R?ea.removeClass("fc-other-month"):ea.addClass("fc-other-month");+aa==+V?ea.addClass(la+"-state-highlight fc-today"):ea.removeClass(la+"-state-highlight fc-today");ea.find("div.fc-day-number").text(aa.getDate());I&&rb(ea,aa)});P.each(function(wa,Ga){va=m(Ga);if(wa<v){va.show();wa==v-1?va.addClass("fc-last"):va.removeClass("fc-last")}else va.hide()})}function j(w){o=w;w=o-K.height();var I,R,V;if(L("weekMode")=="variable")I=R=Math.floor(w/(v==1?2:6));else{I=Math.floor(w/v);R=w-I*(v-1)}B.each(function(ea,
aa){if(ea<v){V=m(aa);Za(V.find("> div"),(ea==v-1?R:I)-Sa(V))}})}function t(w){W=w;M.clear();s=Math.floor(W/F);Va(i.slice(0,-1),s)}function y(w){w.click(S).mousedown(X)}function S(w){if(!L("selectable")){var I=parseInt(this.className.match(/fc\-day(\d+)/)[1]);I=ca(I);c("dayClick",this,I,true,w)}}function Q(w,I,R){R&&r.build();R=N(p.visStart);for(var V=ba(N(R),F),ea=0;ea<v;ea++){var aa=new Date(Math.max(R,w)),va=new Date(Math.min(V,I));if(aa<va){var wa;if(k){wa=Ca(va,R)*D+Z+1;aa=Ca(aa,R)*D+Z+1}else{wa=
Ca(aa,R);aa=Ca(va,R)}y(q(ea,wa,ea,aa-1))}ba(R,7);ba(V,7)}}function q(w,I,R,V){w=r.rect(w,I,R,V,a);return H(w,a)}function u(w){return N(w)}function fa(w,I){Q(w,ba(N(I),1),true)}function oa(){T()}function ga(w,I,R){var V=ua(w);c("dayClick",E[V.row*F+V.col],w,I,R)}function ra(w,I){J.start(function(R){T();R&&q(R.row,R.col,R.row,R.col)},I)}function sa(w,I,R){var V=J.stop();T();if(V){V=pa(V);c("drop",w,V,true,I,R)}}function ha(w){return N(w.start)}function da(w){return M.left(w)}function na(w){return M.right(w)}
function ua(w){return{row:Math.floor(Ca(w,p.visStart)/7),col:ka(w.getDay())}}function pa(w){return U(w.row,w.col)}function U(w,I){return ba(N(p.visStart),w*7+I*D+Z)}function ca(w){return U(Math.floor(w/F),w%F)}function ka(w){return(w-Math.max(ja,ia)+F)%F*D+Z}function qa(w){return P.eq(w)}function G(){return{left:0,right:W}}var p=this;p.renderBasic=d;p.setHeight=j;p.setWidth=t;p.renderDayOverlay=Q;p.defaultSelectionEnd=u;p.renderSelection=fa;p.clearSelection=oa;p.reportDayClick=ga;p.dragStart=ra;p.dragStop=
sa;p.defaultEventEnd=ha;p.getHoverListener=function(){return J};p.colContentLeft=da;p.colContentRight=na;p.dayOfWeekCol=ka;p.dateCell=ua;p.cellDate=pa;p.cellIsAllDay=function(){return true};p.allDayRow=qa;p.allDayBounds=G;p.getRowCnt=function(){return v};p.getColCnt=function(){return F};p.getColWidth=function(){return s};p.getDaySegmentContainer=function(){return Y};Kb.call(p,a,b,e);Lb.call(p);Mb.call(p);pc.call(p);var L=p.opt,c=p.trigger,z=p.clearEvents,H=p.renderOverlay,T=p.clearOverlays,X=p.daySelectionMousedown,
ya=b.formatDate,K,i,C,P,E,B,n,Y,W,o,s,v,F,r,J,M,k,D,Z,ja,ia,la,$;qb(a.addClass("fc-grid"));r=new Nb(function(w,I){var R,V,ea;i.each(function(aa,va){R=m(va);V=R.offset().left;if(aa)ea[1]=V;ea=[V];I[aa]=ea});ea[1]=V+R.outerWidth();P.each(function(aa,va){if(aa<v){R=m(va);V=R.offset().top;if(aa)ea[1]=V;ea=[V];w[aa]=ea}});ea[1]=V+R.outerHeight()});J=new Ob(r);M=new Pb(function(w){return n.eq(w)})}function pc(){function a(U,ca){S(U);ua(e(U),ca)}function b(){Q();ga().empty()}function e(U){var ca=da(),ka=
na(),qa=N(g.visStart);ka=ba(N(qa),ka);var G=m.map(U,Ua),p,L,c,z,H,T,X=[];for(p=0;p<ca;p++){L=ob(nb(U,G,qa,ka));for(c=0;c<L.length;c++){z=L[c];for(H=0;H<z.length;H++){T=z[H];T.row=p;T.level=c;X.push(T)}}ba(qa,7);ba(ka,7)}return X}function d(U,ca,ka){t(U)&&f(U,ca);ka.isEnd&&y(U)&&pa(U,ca,ka);q(U,ca)}function f(U,ca){var ka=ra(),qa;ca.draggable({zIndex:9,delay:50,opacity:l("dragOpacity"),revertDuration:l("dragRevertDuration"),start:function(G,p){j("eventDragStart",ca,U,G,p);fa(U,ca);ka.start(function(L,
c,z,H){ca.draggable("option","revert",!L||!z&&!H);ha();if(L){qa=z*7+H*(l("isRTL")?-1:1);sa(ba(N(U.start),qa),ba(Ua(U),qa))}else qa=0},G,"drag")},stop:function(G,p){ka.stop();ha();j("eventDragStop",ca,U,G,p);if(qa)oa(this,U,qa,0,U.allDay,G,p);else{ca.css("filter","");u(U,ca)}}})}var g=this;g.renderEvents=a;g.compileDaySegs=e;g.clearEvents=b;g.bindDaySeg=d;Qb.call(g);var l=g.opt,j=g.trigger,t=g.isEventDraggable,y=g.isEventResizable,S=g.reportEvents,Q=g.reportEventClear,q=g.eventElementHandlers,u=g.showEvents,
fa=g.hideEvents,oa=g.eventDrop,ga=g.getDaySegmentContainer,ra=g.getHoverListener,sa=g.renderDayOverlay,ha=g.clearOverlays,da=g.getRowCnt,na=g.getColCnt,ua=g.renderDaySegs,pa=g.resizableDayEvent}function qc(a,b){function e(j,t){t&&ba(j,t*7);j=ba(N(j),-((j.getDay()-f("firstDay")+7)%7));t=ba(N(j),7);var y=N(j),S=N(t),Q=f("weekends");if(!Q){Fa(y);Fa(S,-1,true)}d.title=l(y,ba(N(S),-1),f("titleFormat"));d.start=j;d.end=t;d.visStart=y;d.visEnd=S;g(Q?7:5)}var d=this;d.render=e;Rb.call(d,a,b,"agendaWeek");
var f=d.opt,g=d.renderAgenda,l=b.formatDates}function rc(a,b){function e(j,t){if(t){ba(j,t);f("weekends")||Fa(j,t<0?-1:1)}t=N(j,true);var y=ba(N(t),1);d.title=l(j,f("titleFormat"));d.start=d.visStart=t;d.end=d.visEnd=y;g(1)}var d=this;d.render=e;Rb.call(d,a,b,"agendaDay");var f=d.opt,g=d.renderAgenda,l=b.formatDate}function Rb(a,b,e){function d(h){Ba=h;f();v?P():g();l()}function f(){Wa=i("theme")?"ui":"fc";Sb=i("weekends")?0:1;Tb=i("firstDay");if(Ub=i("isRTL")){Ha=-1;Ia=Ba-1}else{Ha=1;Ia=0}La=mb(i("minTime"));
bb=mb(i("maxTime"));Vb=i("columnFormat")}function g(){var h=Wa+"-widget-header",O=Wa+"-widget-content",x,A,ta,za,Da,Ea=i("slotMinutes")%15==0;x="<table style='width:100%' class='fc-agenda-days fc-border-separate' cellspacing='0'><thead><tr><th class='fc-agenda-axis "+h+"'>&nbsp;</th>";for(A=0;A<Ba;A++)x+="<th class='fc- fc-col"+A+" "+h+"'/>";x+="<th class='fc-agenda-gutter "+h+"'>&nbsp;</th></tr></thead><tbody><tr><th class='fc-agenda-axis "+h+"'>&nbsp;</th>";for(A=0;A<Ba;A++)x+="<td class='fc- fc-col"+
A+" "+O+"'><div><div class='fc-day-content'><div style='position:relative'>&nbsp;</div></div></div></td>";x+="<td class='fc-agenda-gutter "+O+"'>&nbsp;</td></tr></tbody></table>";v=m(x).appendTo(a);F=v.find("thead");r=F.find("th").slice(1,-1);J=v.find("tbody");M=J.find("td").slice(0,-1);k=M.find("div.fc-day-content div");D=M.eq(0);Z=D.find("> div");ab(F.add(F.find("tr")));ab(J.add(J.find("tr")));aa=F.find("th:first");va=v.find(".fc-agenda-gutter");ja=m("<div style='position:absolute;z-index:2;left:0;width:100%'/>").appendTo(a);
if(i("allDaySlot")){ia=m("<div style='position:absolute;z-index:8;top:0;left:0'/>").appendTo(ja);x="<table style='width:100%' class='fc-agenda-allday' cellspacing='0'><tr><th class='"+h+" fc-agenda-axis'>"+i("allDayText")+"</th><td><div class='fc-day-content'><div style='position:relative'/></div></td><th class='"+h+" fc-agenda-gutter'>&nbsp;</th></tr></table>";la=m(x).appendTo(ja);$=la.find("tr");q($.find("td"));aa=aa.add(la.find("th:first"));va=va.add(la.find("th.fc-agenda-gutter"));ja.append("<div class='fc-agenda-divider "+
h+"'><div class='fc-agenda-divider-inner'/></div>")}else ia=m([]);w=m("<div style='position:absolute;width:100%;overflow-x:hidden;overflow-y:auto'/>").appendTo(ja);I=m("<div style='position:relative;width:100%;overflow:hidden'/>").appendTo(w);R=m("<div style='position:absolute;z-index:8;top:0;left:0'/>").appendTo(I);x="<table class='fc-agenda-slots' style='width:100%' cellspacing='0'><tbody>";ta=zb();za=xa(N(ta),bb);xa(ta,La);for(A=tb=0;ta<za;A++){Da=ta.getMinutes();x+="<tr class='fc-slot"+A+" "+
(!Da?"":"fc-minor")+"'><th class='fc-agenda-axis "+h+"'>"+(!Ea||!Da?s(ta,i("axisFormat")):"&nbsp;")+"</th><td class='"+O+"'><div style='position:relative'>&nbsp;</div></td></tr>";xa(ta,i("slotMinutes"));tb++}x+="</tbody></table>";V=m(x).appendTo(I);ea=V.find("div:first");u(V.find("td"));aa=aa.add(V.find("th:first"))}function l(){var h,O,x,A,ta=Ka(new Date);for(h=0;h<Ba;h++){A=ua(h);O=r.eq(h);O.html(s(A,Vb));x=M.eq(h);+A==+ta?x.addClass(Wa+"-state-highlight fc-today"):x.removeClass(Wa+"-state-highlight fc-today");
rb(O.add(x),A)}}function j(h,O){if(h===ma)h=Wb;Wb=h;ub={};var x=J.position().top,A=w.position().top;h=Math.min(h-x,V.height()+A+1);Z.height(h-Sa(D));ja.css("top",x);w.height(h-A-1);Xa=ea.height()+1;O&&y()}function t(h){Ga=h;cb.clear();Ma=0;Va(aa.width("").each(function(O,x){Ma=Math.max(Ma,m(x).outerWidth())}),Ma);h=w[0].clientWidth;if(vb=w.width()-h){Va(va,vb);va.show().prev().removeClass("fc-last")}else va.hide().prev().addClass("fc-last");db=Math.floor((h-Ma)/Ba);Va(r.slice(0,-1),db)}function y(){function h(){w.scrollTop(A)}
var O=zb(),x=N(O);x.setHours(i("firstHour"));var A=ca(O,x)+1;h();setTimeout(h,0)}function S(){Xb=w.scrollTop()}function Q(){w.scrollTop(Xb)}function q(h){h.click(fa).mousedown(W)}function u(h){h.click(fa).mousedown(H)}function fa(h){if(!i("selectable")){var O=Math.min(Ba-1,Math.floor((h.pageX-v.offset().left-Ma)/db)),x=ua(O),A=this.parentNode.className.match(/fc-slot(\d+)/);if(A){A=parseInt(A[1])*i("slotMinutes");var ta=Math.floor(A/60);x.setHours(ta);x.setMinutes(A%60+La);C("dayClick",M[O],x,false,
h)}else C("dayClick",M[O],x,true,h)}}function oa(h,O,x){x&&Na.build();var A=N(K.visStart);if(Ub){x=Ca(O,A)*Ha+Ia+1;h=Ca(h,A)*Ha+Ia+1}else{x=Ca(h,A);h=Ca(O,A)}x=Math.max(0,x);h=Math.min(Ba,h);x<h&&q(ga(0,x,0,h-1))}function ga(h,O,x,A){h=Na.rect(h,O,x,A,ja);return E(h,ja)}function ra(h,O){for(var x=N(K.visStart),A=ba(N(x),1),ta=0;ta<Ba;ta++){var za=new Date(Math.max(x,h)),Da=new Date(Math.min(A,O));if(za<Da){var Ea=ta*Ha+Ia;Ea=Na.rect(0,Ea,0,Ea,I);za=ca(x,za);Da=ca(x,Da);Ea.top=za;Ea.height=Da-za;u(E(Ea,
I))}ba(x,1);ba(A,1)}}function sa(h){return cb.left(h)}function ha(h){return cb.right(h)}function da(h){return{row:Math.floor(Ca(h,K.visStart)/7),col:U(h.getDay())}}function na(h){var O=ua(h.col);h=h.row;i("allDaySlot")&&h--;h>=0&&xa(O,La+h*i("slotMinutes"));return O}function ua(h){return ba(N(K.visStart),h*Ha+Ia)}function pa(h){return i("allDaySlot")&&!h.row}function U(h){return(h-Math.max(Tb,Sb)+Ba)%Ba*Ha+Ia}function ca(h,O){h=N(h,true);if(O<xa(N(h),La))return 0;if(O>=xa(N(h),bb))return V.height();
h=i("slotMinutes");O=O.getHours()*60+O.getMinutes()-La;var x=Math.floor(O/h),A=ub[x];if(A===ma)A=ub[x]=V.find("tr:eq("+x+") td div")[0].offsetTop;return Math.max(0,Math.round(A-1+Xa*(O%h/h)))}function ka(){return{left:Ma,right:Ga-vb}}function qa(){return $}function G(h){var O=N(h.start);if(h.allDay)return O;return xa(O,i("defaultEventMinutes"))}function p(h,O){if(O)return N(h);return xa(N(h),i("slotMinutes"))}function L(h,O,x){if(x)i("allDaySlot")&&oa(h,ba(N(O),1),true);else c(h,O)}function c(h,O){var x=
i("selectHelper");Na.build();if(x){var A=Ca(h,K.visStart)*Ha+Ia;if(A>=0&&A<Ba){A=Na.rect(0,A,0,A,I);var ta=ca(h,h),za=ca(h,O);if(za>ta){A.top=ta;A.height=za-ta;A.left+=2;A.width-=5;if(m.isFunction(x)){if(h=x(h,O)){A.position="absolute";A.zIndex=8;wa=m(h).css(A).appendTo(I)}}else{A.isStart=true;A.isEnd=true;wa=m(o({title:"",start:h,end:O,className:["fc-select-helper"],editable:false},A));wa.css("opacity",i("dragOpacity"))}if(wa){u(wa);I.append(wa);Va(wa,A.width,true);Eb(wa,A.height,true)}}}}else ra(h,
O)}function z(){B();if(wa){wa.remove();wa=null}}function H(h){if(h.which==1&&i("selectable")){Y(h);var O;Ra.start(function(x,A){z();if(x&&x.col==A.col&&!pa(x)){A=na(A);x=na(x);O=[A,xa(N(A),i("slotMinutes")),x,xa(N(x),i("slotMinutes"))].sort(Gb);c(O[0],O[3])}else O=null},h);m(document).one("mouseup",function(x){Ra.stop();if(O){+O[0]==+O[1]&&T(O[0],false,x);n(O[0],O[3],false,x)}})}}function T(h,O,x){C("dayClick",M[U(h.getDay())],h,O,x)}function X(h,O){Ra.start(function(x){B();if(x)if(pa(x))ga(x.row,
x.col,x.row,x.col);else{x=na(x);var A=xa(N(x),i("defaultEventMinutes"));ra(x,A)}},O)}function ya(h,O,x){var A=Ra.stop();B();A&&C("drop",h,na(A),pa(A),O,x)}var K=this;K.renderAgenda=d;K.setWidth=t;K.setHeight=j;K.beforeHide=S;K.afterShow=Q;K.defaultEventEnd=G;K.timePosition=ca;K.dayOfWeekCol=U;K.dateCell=da;K.cellDate=na;K.cellIsAllDay=pa;K.allDayRow=qa;K.allDayBounds=ka;K.getHoverListener=function(){return Ra};K.colContentLeft=sa;K.colContentRight=ha;K.getDaySegmentContainer=function(){return ia};
K.getSlotSegmentContainer=function(){return R};K.getMinMinute=function(){return La};K.getMaxMinute=function(){return bb};K.getBodyContent=function(){return I};K.getRowCnt=function(){return 1};K.getColCnt=function(){return Ba};K.getColWidth=function(){return db};K.getSlotHeight=function(){return Xa};K.defaultSelectionEnd=p;K.renderDayOverlay=oa;K.renderSelection=L;K.clearSelection=z;K.reportDayClick=T;K.dragStart=X;K.dragStop=ya;Kb.call(K,a,b,e);Lb.call(K);Mb.call(K);sc.call(K);var i=K.opt,C=K.trigger,
P=K.clearEvents,E=K.renderOverlay,B=K.clearOverlays,n=K.reportSelection,Y=K.unselect,W=K.daySelectionMousedown,o=K.slotSegHtml,s=b.formatDate,v,F,r,J,M,k,D,Z,ja,ia,la,$,w,I,R,V,ea,aa,va,wa,Ga,Wb,Ma,db,vb,Xa,Xb,Ba,tb,Na,Ra,cb,ub={},Wa,Tb,Sb,Ub,Ha,Ia,La,bb,Vb;qb(a.addClass("fc-agenda"));Na=new Nb(function(h,O){function x(eb){return Math.max(Ea,Math.min(tc,eb))}var A,ta,za;r.each(function(eb,uc){A=m(uc);ta=A.offset().left;if(eb)za[1]=ta;za=[ta];O[eb]=za});za[1]=ta+A.outerWidth();if(i("allDaySlot")){A=
$;ta=A.offset().top;h[0]=[ta,ta+A.outerHeight()]}for(var Da=I.offset().top,Ea=w.offset().top,tc=Ea+w.outerHeight(),fb=0;fb<tb;fb++)h.push([x(Da+Xa*fb),x(Da+Xa*(fb+1))])});Ra=new Ob(Na);cb=new Pb(function(h){return k.eq(h)})}function sc(){function a(o,s){sa(o);var v,F=o.length,r=[],J=[];for(v=0;v<F;v++)o[v].allDay?r.push(o[v]):J.push(o[v]);if(u("allDaySlot")){L(e(r),s);na()}g(d(J),s)}function b(){ha();ua().empty();pa().empty()}function e(o){o=ob(nb(o,m.map(o,Ua),q.visStart,q.visEnd));var s,v=o.length,
F,r,J,M=[];for(s=0;s<v;s++){F=o[s];for(r=0;r<F.length;r++){J=F[r];J.row=0;J.level=s;M.push(J)}}return M}function d(o){var s=z(),v=ka(),F=ca(),r=xa(N(q.visStart),v),J=m.map(o,f),M,k,D,Z,ja,ia,la=[];for(M=0;M<s;M++){k=ob(nb(o,J,r,xa(N(r),F-v)));vc(k);for(D=0;D<k.length;D++){Z=k[D];for(ja=0;ja<Z.length;ja++){ia=Z[ja];ia.col=M;ia.level=D;la.push(ia)}}ba(r,1,true)}return la}function f(o){return o.end?N(o.end):xa(N(o.start),u("defaultEventMinutes"))}function g(o,s){var v,F=o.length,r,J,M,k,D,Z,ja,ia,la,
$="",w,I,R={},V={},ea=pa(),aa;v=z();if(w=u("isRTL")){I=-1;aa=v-1}else{I=1;aa=0}for(v=0;v<F;v++){r=o[v];J=r.event;M=qa(r.start,r.start);k=qa(r.start,r.end);D=r.col;Z=r.level;ja=r.forward||0;ia=G(D*I+aa);la=p(D*I+aa)-ia;la=Math.min(la-6,la*0.95);D=Z?la/(Z+ja+1):ja?(la/(ja+1)-6)*2:la;Z=ia+la/(Z+ja+1)*Z*I+(w?la-D:0);r.top=M;r.left=Z;r.outerWidth=D;r.outerHeight=k-M;$+=l(J,r)}ea[0].innerHTML=$;w=ea.children();for(v=0;v<F;v++){r=o[v];J=r.event;$=m(w[v]);I=fa("eventRender",J,J,$);if(I===false)$.remove();
else{if(I&&I!==true){$.remove();$=m(I).css({position:"absolute",top:r.top,left:r.left}).appendTo(ea)}r.element=$;if(J._id===s)t(J,$,r);else $[0]._fci=v;ya(J,$)}}Db(ea,o,t);for(v=0;v<F;v++){r=o[v];if($=r.element){J=R[s=r.key=Ib($[0])];r.vsides=J===ma?(R[s]=Sa($,true)):J;J=V[s];r.hsides=J===ma?(V[s]=pb($,true)):J;s=$.find("div.fc-event-content");if(s.length)r.contentTop=s[0].offsetTop}}for(v=0;v<F;v++){r=o[v];if($=r.element){$[0].style.width=Math.max(0,r.outerWidth-r.hsides)+"px";R=Math.max(0,r.outerHeight-
r.vsides);$[0].style.height=R+"px";J=r.event;if(r.contentTop!==ma&&R-r.contentTop<10){$.find("div.fc-event-time").text(Y(J.start,u("timeFormat"))+" - "+J.title);$.find("div.fc-event-title").remove()}fa("eventAfterRender",J,J,$)}}}function l(o,s){var v="<",F=o.url,r=Jb(o,u),J=r?" style='"+r+"'":"",M=["fc-event","fc-event-skin","fc-event-vert"];oa(o)&&M.push("fc-event-draggable");s.isStart&&M.push("fc-corner-top");s.isEnd&&M.push("fc-corner-bottom");M=M.concat(o.className);if(o.source)M=M.concat(o.source.className||
[]);v+=F?"a href='"+Qa(o.url)+"'":"div";v+=" class='"+M.join(" ")+"' style='position:absolute;z-index:8;top:"+s.top+"px;left:"+s.left+"px;"+r+"'><div class='fc-event-inner fc-event-skin'"+J+"><div class='fc-event-head fc-event-skin'"+J+"><div class='fc-event-time'>"+Qa(W(o.start,o.end,u("timeFormat")))+"</div></div><div class='fc-event-content'><div class='fc-event-title'>"+Qa(o.title)+"</div></div><div class='fc-event-bg'></div></div>";if(s.isEnd&&ga(o))v+="<div class='ui-resizable-handle ui-resizable-s'>=</div>";
v+="</"+(F?"a":"div")+">";return v}function j(o,s,v){oa(o)&&y(o,s,v.isStart);v.isEnd&&ga(o)&&c(o,s,v);da(o,s)}function t(o,s,v){var F=s.find("div.fc-event-time");oa(o)&&S(o,s,F);v.isEnd&&ga(o)&&Q(o,s,F);da(o,s)}function y(o,s,v){function F(){if(!M){s.width(r).height("").draggable("option","grid",null);M=true}}var r,J,M=true,k,D=u("isRTL")?-1:1,Z=U(),ja=H(),ia=T(),la=ka();s.draggable({zIndex:9,opacity:u("dragOpacity","month"),revertDuration:u("dragRevertDuration"),start:function($,w){fa("eventDragStart",
s,o,$,w);i(o,s);r=s.width();Z.start(function(I,R,V,ea){B();if(I){J=false;k=ea*D;if(I.row)if(v){if(M){s.width(ja-10);Eb(s,ia*Math.round((o.end?(o.end-o.start)/wc:u("defaultEventMinutes"))/u("slotMinutes")));s.draggable("option","grid",[ja,1]);M=false}}else J=true;else{E(ba(N(o.start),k),ba(Ua(o),k));F()}J=J||M&&!k}else{F();J=true}s.draggable("option","revert",J)},$,"drag")},stop:function($,w){Z.stop();B();fa("eventDragStop",s,o,$,w);if(J){F();s.css("filter","");K(o,s)}else{var I=0;M||(I=Math.round((s.offset().top-
X().offset().top)/ia)*u("slotMinutes")+la-(o.start.getHours()*60+o.start.getMinutes()));C(this,o,k,I,M,$,w)}}})}function S(o,s,v){function F(I){var R=xa(N(o.start),I),V;if(o.end)V=xa(N(o.end),I);v.text(W(R,V,u("timeFormat")))}function r(){if(M){v.css("display","");s.draggable("option","grid",[$,w]);M=false}}var J,M=false,k,D,Z,ja=u("isRTL")?-1:1,ia=U(),la=z(),$=H(),w=T();s.draggable({zIndex:9,scroll:false,grid:[$,w],axis:la==1?"y":false,opacity:u("dragOpacity"),revertDuration:u("dragRevertDuration"),
start:function(I,R){fa("eventDragStart",s,o,I,R);i(o,s);J=s.position();D=Z=0;ia.start(function(V,ea,aa,va){s.draggable("option","revert",!V);B();if(V){k=va*ja;if(u("allDaySlot")&&!V.row){if(!M){M=true;v.hide();s.draggable("option","grid",null)}E(ba(N(o.start),k),ba(Ua(o),k))}else r()}},I,"drag")},drag:function(I,R){D=Math.round((R.position.top-J.top)/w)*u("slotMinutes");if(D!=Z){M||F(D);Z=D}},stop:function(I,R){var V=ia.stop();B();fa("eventDragStop",s,o,I,R);if(V&&(k||D||M))C(this,o,k,M?0:D,M,I,R);
else{r();s.css("filter","");s.css(J);F(0);K(o,s)}}})}function Q(o,s,v){var F,r,J=T();s.resizable({handles:{s:"div.ui-resizable-s"},grid:J,start:function(M,k){F=r=0;i(o,s);s.css("z-index",9);fa("eventResizeStart",this,o,M,k)},resize:function(M,k){F=Math.round((Math.max(J,s.height())-k.originalSize.height)/J);if(F!=r){v.text(W(o.start,!F&&!o.end?null:xa(ra(o),u("slotMinutes")*F),u("timeFormat")));r=F}},stop:function(M,k){fa("eventResizeStop",this,o,M,k);if(F)P(this,o,0,u("slotMinutes")*F,M,k);else{s.css("z-index",
8);K(o,s)}}})}var q=this;q.renderEvents=a;q.compileDaySegs=e;q.clearEvents=b;q.slotSegHtml=l;q.bindDaySeg=j;Qb.call(q);var u=q.opt,fa=q.trigger,oa=q.isEventDraggable,ga=q.isEventResizable,ra=q.eventEnd,sa=q.reportEvents,ha=q.reportEventClear,da=q.eventElementHandlers,na=q.setHeight,ua=q.getDaySegmentContainer,pa=q.getSlotSegmentContainer,U=q.getHoverListener,ca=q.getMaxMinute,ka=q.getMinMinute,qa=q.timePosition,G=q.colContentLeft,p=q.colContentRight,L=q.renderDaySegs,c=q.resizableDayEvent,z=q.getColCnt,
H=q.getColWidth,T=q.getSlotHeight,X=q.getBodyContent,ya=q.reportEventElement,K=q.showEvents,i=q.hideEvents,C=q.eventDrop,P=q.eventResize,E=q.renderDayOverlay,B=q.clearOverlays,n=q.calendar,Y=n.formatDate,W=n.formatDates}function vc(a){var b,e,d,f,g,l;for(b=a.length-1;b>0;b--){f=a[b];for(e=0;e<f.length;e++){g=f[e];for(d=0;d<a[b-1].length;d++){l=a[b-1][d];if(Cb(g,l))l.forward=Math.max(l.forward||0,(g.forward||0)+1)}}}}function Kb(a,b,e){function d(G,p){G=qa[G];if(typeof G=="object")return jb(G,p||e);
return G}function f(G,p){return b.trigger.apply(b,[G,p||da].concat(Array.prototype.slice.call(arguments,2),[da]))}function g(G){return j(G)&&!d("disableDragging")}function l(G){return j(G)&&!d("disableResizing")}function j(G){return Ta(G.editable,(G.source||{}).editable,d("editable"))}function t(G){U={};var p,L=G.length,c;for(p=0;p<L;p++){c=G[p];if(U[c._id])U[c._id].push(c);else U[c._id]=[c]}}function y(G){return G.end?N(G.end):na(G)}function S(G,p){ca.push(p);if(ka[G._id])ka[G._id].push(p);else ka[G._id]=
[p]}function Q(){ca=[];ka={}}function q(G,p){p.click(function(L){if(!p.hasClass("ui-draggable-dragging")&&!p.hasClass("ui-resizable-resizing"))return f("eventClick",this,G,L)}).hover(function(L){f("eventMouseover",this,G,L)},function(L){f("eventMouseout",this,G,L)})}function u(G,p){oa(G,p,"show")}function fa(G,p){oa(G,p,"hide")}function oa(G,p,L){G=ka[G._id];var c,z=G.length;for(c=0;c<z;c++)if(!p||G[c][0]!=p[0])G[c][L]()}function ga(G,p,L,c,z,H,T){var X=p.allDay,ya=p._id;sa(U[ya],L,c,z);f("eventDrop",
G,p,L,c,z,function(){sa(U[ya],-L,-c,X);pa(ya)},H,T);pa(ya)}function ra(G,p,L,c,z,H){var T=p._id;ha(U[T],L,c);f("eventResize",G,p,L,c,function(){ha(U[T],-L,-c);pa(T)},z,H);pa(T)}function sa(G,p,L,c){L=L||0;for(var z,H=G.length,T=0;T<H;T++){z=G[T];if(c!==ma)z.allDay=c;xa(ba(z.start,p,true),L);if(z.end)z.end=xa(ba(z.end,p,true),L);ua(z,qa)}}function ha(G,p,L){L=L||0;for(var c,z=G.length,H=0;H<z;H++){c=G[H];c.end=xa(ba(y(c),p,true),L);ua(c,qa)}}var da=this;da.element=a;da.calendar=b;da.name=e;da.opt=
d;da.trigger=f;da.isEventDraggable=g;da.isEventResizable=l;da.reportEvents=t;da.eventEnd=y;da.reportEventElement=S;da.reportEventClear=Q;da.eventElementHandlers=q;da.showEvents=u;da.hideEvents=fa;da.eventDrop=ga;da.eventResize=ra;var na=da.defaultEventEnd,ua=b.normalizeEvent,pa=b.reportEventChange,U={},ca=[],ka={},qa=b.options}function Qb(){function a(i,C){var P=z(),E=pa(),B=U(),n=0,Y,W,o=i.length,s,v;P[0].innerHTML=e(i);d(i,P.children());f(i);g(i,P,C);l(i);j(i);t(i);C=y();for(P=0;P<E;P++){Y=[];for(W=
0;W<B;W++)Y[W]=0;for(;n<o&&(s=i[n]).row==P;){W=Hb(Y.slice(s.startCol,s.endCol));s.top=W;W+=s.outerHeight;for(v=s.startCol;v<s.endCol;v++)Y[v]=W;n++}C[P].height(Hb(Y))}Q(i,S(C))}function b(i,C,P){var E=m("<div/>"),B=z(),n=i.length,Y;E[0].innerHTML=e(i);E=E.children();B.append(E);d(i,E);l(i);j(i);t(i);Q(i,S(y()));E=[];for(B=0;B<n;B++)if(Y=i[B].element){i[B].row===C&&Y.css("top",P);E.push(Y[0])}return m(E)}function e(i){var C=fa("isRTL"),P,E=i.length,B,n,Y,W;P=ka();var o=P.left,s=P.right,v,F,r,J,M,k=
"";for(P=0;P<E;P++){B=i[P];n=B.event;W=["fc-event","fc-event-skin","fc-event-hori"];ga(n)&&W.push("fc-event-draggable");if(C){B.isStart&&W.push("fc-corner-right");B.isEnd&&W.push("fc-corner-left");v=p(B.end.getDay()-1);F=p(B.start.getDay());r=B.isEnd?qa(v):o;J=B.isStart?G(F):s}else{B.isStart&&W.push("fc-corner-left");B.isEnd&&W.push("fc-corner-right");v=p(B.start.getDay());F=p(B.end.getDay()-1);r=B.isStart?qa(v):o;J=B.isEnd?G(F):s}W=W.concat(n.className);if(n.source)W=W.concat(n.source.className||
[]);Y=n.url;M=Jb(n,fa);k+=Y?"<a href='"+Qa(Y)+"'":"<div";k+=" class='"+W.join(" ")+"' style='position:absolute;z-index:8;left:"+r+"px;"+M+"'><div class='fc-event-inner fc-event-skin'"+(M?" style='"+M+"'":"")+">";if(!n.allDay&&B.isStart)k+="<span class='fc-event-time'>"+Qa(T(n.start,n.end,fa("timeFormat")))+"</span>";k+="<span class='fc-event-title'>"+Qa(n.title)+"</span></div>";if(B.isEnd&&ra(n))k+="<div class='ui-resizable-handle ui-resizable-"+(C?"w":"e")+"'>&nbsp;&nbsp;&nbsp;</div>";k+="</"+(Y?
"a":"div")+">";B.left=r;B.outerWidth=J-r;B.startCol=v;B.endCol=F+1}return k}function d(i,C){var P,E=i.length,B,n,Y;for(P=0;P<E;P++){B=i[P];n=B.event;Y=m(C[P]);n=oa("eventRender",n,n,Y);if(n===false)Y.remove();else{if(n&&n!==true){n=m(n).css({position:"absolute",left:B.left});Y.replaceWith(n);Y=n}B.element=Y}}}function f(i){var C,P=i.length,E,B;for(C=0;C<P;C++){E=i[C];(B=E.element)&&ha(E.event,B)}}function g(i,C,P){var E,B=i.length,n,Y,W;for(E=0;E<B;E++){n=i[E];if(Y=n.element){W=n.event;if(W._id===
P)H(W,Y,n);else Y[0]._fci=E}}Db(C,i,H)}function l(i){var C,P=i.length,E,B,n,Y,W={};for(C=0;C<P;C++){E=i[C];if(B=E.element){n=E.key=Ib(B[0]);Y=W[n];if(Y===ma)Y=W[n]=pb(B,true);E.hsides=Y}}}function j(i){var C,P=i.length,E,B;for(C=0;C<P;C++){E=i[C];if(B=E.element)B[0].style.width=Math.max(0,E.outerWidth-E.hsides)+"px"}}function t(i){var C,P=i.length,E,B,n,Y,W={};for(C=0;C<P;C++){E=i[C];if(B=E.element){n=E.key;Y=W[n];if(Y===ma)Y=W[n]=Fb(B);E.outerHeight=B[0].offsetHeight+Y}}}function y(){var i,C=pa(),
P=[];for(i=0;i<C;i++)P[i]=ca(i).find("td:first div.fc-day-content > div");return P}function S(i){var C,P=i.length,E=[];for(C=0;C<P;C++)E[C]=i[C][0].offsetTop;return E}function Q(i,C){var P,E=i.length,B,n;for(P=0;P<E;P++){B=i[P];if(n=B.element){n[0].style.top=C[B.row]+(B.top||0)+"px";B=B.event;oa("eventAfterRender",B,B,n)}}}function q(i,C,P){var E=fa("isRTL"),B=E?"w":"e",n=C.find("div.ui-resizable-"+B),Y=false;qb(C);C.mousedown(function(W){W.preventDefault()}).click(function(W){if(Y){W.preventDefault();
W.stopImmediatePropagation()}});n.mousedown(function(W){function o(ia){oa("eventResizeStop",this,i,ia);m("body").css("cursor","");s.stop();ya();k&&ua(this,i,k,0,ia);setTimeout(function(){Y=false},0)}if(W.which==1){Y=true;var s=u.getHoverListener(),v=pa(),F=U(),r=E?-1:1,J=E?F-1:0,M=C.css("top"),k,D,Z=m.extend({},i),ja=L(i.start);K();m("body").css("cursor",B+"-resize").one("mouseup",o);oa("eventResizeStart",this,i,W);s.start(function(ia,la){if(ia){var $=Math.max(ja.row,ia.row);ia=ia.col;if(v==1)$=0;
if($==ja.row)ia=E?Math.min(ja.col,ia):Math.max(ja.col,ia);k=$*7+ia*r+J-(la.row*7+la.col*r+J);la=ba(sa(i),k,true);if(k){Z.end=la;$=D;D=b(c([Z]),P.row,M);D.find("*").css("cursor",B+"-resize");$&&$.remove();na(i)}else if(D){da(i);D.remove();D=null}ya();X(i.start,ba(N(la),1))}},W)}})}var u=this;u.renderDaySegs=a;u.resizableDayEvent=q;var fa=u.opt,oa=u.trigger,ga=u.isEventDraggable,ra=u.isEventResizable,sa=u.eventEnd,ha=u.reportEventElement,da=u.showEvents,na=u.hideEvents,ua=u.eventResize,pa=u.getRowCnt,
U=u.getColCnt,ca=u.allDayRow,ka=u.allDayBounds,qa=u.colContentLeft,G=u.colContentRight,p=u.dayOfWeekCol,L=u.dateCell,c=u.compileDaySegs,z=u.getDaySegmentContainer,H=u.bindDaySeg,T=u.calendar.formatDates,X=u.renderDayOverlay,ya=u.clearOverlays,K=u.clearSelection}function Mb(){function a(Q,q,u){b();q||(q=j(Q,u));t(Q,q,u);e(Q,q,u)}function b(Q){if(S){S=false;y();l("unselect",null,Q)}}function e(Q,q,u,fa){S=true;l("select",null,Q,q,u,fa)}function d(Q){var q=f.cellDate,u=f.cellIsAllDay,fa=f.getHoverListener(),
oa=f.reportDayClick;if(Q.which==1&&g("selectable")){b(Q);var ga;fa.start(function(ra,sa){y();if(ra&&u(ra)){ga=[q(sa),q(ra)].sort(Gb);t(ga[0],ga[1],true)}else ga=null},Q);m(document).one("mouseup",function(ra){fa.stop();if(ga){+ga[0]==+ga[1]&&oa(ga[0],true,ra);e(ga[0],ga[1],true,ra)}})}}var f=this;f.select=a;f.unselect=b;f.reportSelection=e;f.daySelectionMousedown=d;var g=f.opt,l=f.trigger,j=f.defaultSelectionEnd,t=f.renderSelection,y=f.clearSelection,S=false;g("selectable")&&g("unselectAuto")&&m(document).mousedown(function(Q){var q=
g("unselectCancel");if(q)if(m(Q.target).parents(q).length)return;b(Q)})}function Lb(){function a(g,l){var j=f.shift();j||(j=m("<div class='fc-cell-overlay' style='position:absolute;z-index:3'/>"));j[0].parentNode!=l[0]&&j.appendTo(l);d.push(j.css(g).show());return j}function b(){for(var g;g=d.shift();)f.push(g.hide().unbind())}var e=this;e.renderOverlay=a;e.clearOverlays=b;var d=[],f=[]}function Nb(a){var b=this,e,d;b.build=function(){e=[];d=[];a(e,d)};b.cell=function(f,g){var l=e.length,j=d.length,
t,y=-1,S=-1;for(t=0;t<l;t++)if(g>=e[t][0]&&g<e[t][1]){y=t;break}for(t=0;t<j;t++)if(f>=d[t][0]&&f<d[t][1]){S=t;break}return y>=0&&S>=0?{row:y,col:S}:null};b.rect=function(f,g,l,j,t){t=t.offset();return{top:e[f][0]-t.top,left:d[g][0]-t.left,width:d[j][1]-d[g][0],height:e[l][1]-e[f][0]}}}function Ob(a){function b(j){xc(j);j=a.cell(j.pageX,j.pageY);if(!j!=!l||j&&(j.row!=l.row||j.col!=l.col)){if(j){g||(g=j);f(j,g,j.row-g.row,j.col-g.col)}else f(j,g);l=j}}var e=this,d,f,g,l;e.start=function(j,t,y){f=j;
g=l=null;a.build();b(t);d=y||"mousemove";m(document).bind(d,b)};e.stop=function(){m(document).unbind(d,b);return l}}function xc(a){if(a.pageX===ma){a.pageX=a.originalEvent.pageX;a.pageY=a.originalEvent.pageY}}function Pb(a){function b(l){return d[l]=d[l]||a(l)}var e=this,d={},f={},g={};e.left=function(l){return f[l]=f[l]===ma?b(l).position().left:f[l]};e.right=function(l){return g[l]=g[l]===ma?e.left(l)+b(l).width():g[l]};e.clear=function(){d={};f={};g={}}}var Ya={defaultView:"month",aspectRatio:1.35,
header:{left:"title",center:"",right:"today prev,next"},weekends:true,allDayDefault:true,ignoreTimezone:true,lazyFetching:true,startParam:"start",endParam:"end",titleFormat:{month:"MMMM yyyy",week:"MMM d[ yyyy]{ '&#8212;'[ MMM] d yyyy}",day:"dddd, MMM d, yyyy"},columnFormat:{month:"ddd",week:"ddd M/d",day:"dddd M/d"},timeFormat:{"":"h(:mm)t"},isRTL:false,firstDay:0,monthNames:["January","February","March","April","May","June","July","August","September","October","November","December"],monthNamesShort:["Jan",
"Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],dayNames:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],dayNamesShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],buttonText:{prev:"&nbsp;&#9668;&nbsp;",next:"&nbsp;&#9658;&nbsp;",prevYear:"&nbsp;&lt;&lt;&nbsp;",nextYear:"&nbsp;&gt;&gt;&nbsp;",today:"today",month:"month",week:"week",day:"day"},theme:false,buttonIcons:{prev:"circle-triangle-w",next:"circle-triangle-e"},unselectAuto:true,dropAccept:"*"},yc=
{header:{left:"next,prev today",center:"",right:"title"},buttonText:{prev:"&nbsp;&#9658;&nbsp;",next:"&nbsp;&#9668;&nbsp;",prevYear:"&nbsp;&gt;&gt;&nbsp;",nextYear:"&nbsp;&lt;&lt;&nbsp;"},buttonIcons:{prev:"circle-triangle-e",next:"circle-triangle-w"}},Aa=m.fullCalendar={version:"1.5.4"},Ja=Aa.views={};m.fn.fullCalendar=function(a){if(typeof a=="string"){var b=Array.prototype.slice.call(arguments,1),e;this.each(function(){var f=m.data(this,"fullCalendar");if(f&&m.isFunction(f[a])){f=f[a].apply(f,
b);if(e===ma)e=f;a=="destroy"&&m.removeData(this,"fullCalendar")}});if(e!==ma)return e;return this}var d=a.eventSources||[];delete a.eventSources;if(a.events){d.push(a.events);delete a.events}a=m.extend(true,{},Ya,a.isRTL||a.isRTL===ma&&Ya.isRTL?yc:{},a);this.each(function(f,g){f=m(g);g=new Yb(f,a,d);f.data("fullCalendar",g);g.render()});return this};Aa.sourceNormalizers=[];Aa.sourceFetchers=[];var ac={dataType:"json",cache:false},bc=1;Aa.addDays=ba;Aa.cloneDate=N;Aa.parseDate=kb;Aa.parseISO8601=
Bb;Aa.parseTime=mb;Aa.formatDate=Oa;Aa.formatDates=ib;var lc=["sun","mon","tue","wed","thu","fri","sat"],Ab=864E5,cc=36E5,wc=6E4,dc={s:function(a){return a.getSeconds()},ss:function(a){return Pa(a.getSeconds())},m:function(a){return a.getMinutes()},mm:function(a){return Pa(a.getMinutes())},h:function(a){return a.getHours()%12||12},hh:function(a){return Pa(a.getHours()%12||12)},H:function(a){return a.getHours()},HH:function(a){return Pa(a.getHours())},d:function(a){return a.getDate()},dd:function(a){return Pa(a.getDate())},
ddd:function(a,b){return b.dayNamesShort[a.getDay()]},dddd:function(a,b){return b.dayNames[a.getDay()]},M:function(a){return a.getMonth()+1},MM:function(a){return Pa(a.getMonth()+1)},MMM:function(a,b){return b.monthNamesShort[a.getMonth()]},MMMM:function(a,b){return b.monthNames[a.getMonth()]},yy:function(a){return(a.getFullYear()+"").substring(2)},yyyy:function(a){return a.getFullYear()},t:function(a){return a.getHours()<12?"a":"p"},tt:function(a){return a.getHours()<12?"am":"pm"},T:function(a){return a.getHours()<
12?"A":"P"},TT:function(a){return a.getHours()<12?"AM":"PM"},u:function(a){return Oa(a,"yyyy-MM-dd'T'HH:mm:ss'Z'")},S:function(a){a=a.getDate();if(a>10&&a<20)return"th";return["st","nd","rd"][a%10-1]||"th"}};Aa.applyAll=$a;Ja.month=mc;Ja.basicWeek=nc;Ja.basicDay=oc;wb({weekMode:"fixed"});Ja.agendaWeek=qc;Ja.agendaDay=rc;wb({allDaySlot:true,allDayText:"all-day",firstHour:6,slotMinutes:30,defaultEventMinutes:120,axisFormat:"h(:mm)tt",timeFormat:{agenda:"h:mm{ - h:mm}"},dragOpacity:{agenda:0.5},minTime:0,
maxTime:24})})(jQuery);
;
/*!
 * jQuery Plugin: Are-You-Sure (Dirty Form Detection)
 * https://github.com/codedance/jquery.AreYouSure/
 *
 * Copyright (c) 2012-2014, Chris Dance and PaperCut Software http://www.papercut.com/
 * Dual licensed under the MIT or GPL Version 2 licenses.
 * http://jquery.org/license
 *
 * Author:  chris.dance@papercut.com
 * Version: 1.9.0
 * Date:    13th August 2014
 */
(function ($) {

    $.fn.areYouSure = function (options) {

        var settings = $.extend(
            {
                'message': 'You have unsaved changes!',
                'dirtyClass': 'dirty',
                'change': null,
                'silent': false,
                'addRemoveFieldsMarksDirty': false,
                'fieldEvents': 'change keyup propertychange input',
                'fieldSelector': ":input:not(input[type=submit]):not(input[type=button])"
            }, options);

        var getValue = function ($field) {
            if ($field.hasClass('ays-ignore')
                || $field.hasClass('aysIgnore')
                || $field.attr('data-ays-ignore')
                || $field.attr('name') === undefined) {
                return null;
            }

            if ($field.is(':disabled')) {
                return 'ays-disabled';
            }

            var val;
            var type = $field.attr('type');
            if ($field.is('select')) {
                type = 'select';
            }

            switch (type) {
                case 'checkbox':
                case 'radio':
                    val = $field.is(':checked');
                    break;
                case 'select':
                    val = '';
                    $field.find('option').each(function (o) {
                        var $option = $(this);
                        if ($option.is(':selected')) {
                            val += $option.val();
                        }
                    });
                    break;
                default:
                    val = $field.val();
            }

            return val;
        };

        var storeOrigValue = function ($field) {
            $field.data('ays-orig', getValue($field));
        };

        var checkForm = function (evt) {

            var isFieldDirty = function ($field) {
                var origValue = $field.data('ays-orig');
                if (undefined === origValue) {
                    return false;
                }
                return (getValue($field) != origValue);
            };

            var $form = ($(this).is('form'))
                ? $(this)
                : $(this).parents('form');

            // Test on the target first as it's the most likely to be dirty
            if (isFieldDirty($(evt.target))) {
                setDirtyStatus($form, true);
                return;
            }

            $fields = $form.find(settings.fieldSelector);

            if (settings.addRemoveFieldsMarksDirty) {
                // Check if field count has changed
                var origCount = $form.data("ays-orig-field-count");
                if (origCount != $fields.length) {
                    setDirtyStatus($form, true);
                    return;
                }
            }

            // Brute force - check each field
            var isDirty = false;
            $fields.each(function () {
                var $field = $(this);
                if (isFieldDirty($field)) {
                    isDirty = true;
                    return false; // break
                }
            });

            setDirtyStatus($form, isDirty);
        };

        var initForm = function ($form) {
            var fields = $form.find(settings.fieldSelector);
            $(fields).each(function () { storeOrigValue($(this)); });
            $(fields).unbind(settings.fieldEvents, checkForm);
            $(fields).bind(settings.fieldEvents, checkForm);
            $form.data("ays-orig-field-count", $(fields).length);
            setDirtyStatus($form, false);
        };

        var setDirtyStatus = function ($form, isDirty) {
            var changed = isDirty != $form.hasClass(settings.dirtyClass);
            $form.toggleClass(settings.dirtyClass, isDirty);

            // Fire change event if required
            if (changed) {
                if (settings.change) settings.change.call($form, $form);

                if (isDirty) $form.trigger('dirty.areYouSure', [$form]);
                if (!isDirty) $form.trigger('clean.areYouSure', [$form]);
                $form.trigger('change.areYouSure', [$form]);
            }
        };

        var rescan = function () {
            var $form = $(this);
            var fields = $form.find(settings.fieldSelector);
            $(fields).each(function () {
                var $field = $(this);
                if (!$field.data('ays-orig')) {
                    storeOrigValue($field);
                    $field.bind(settings.fieldEvents, checkForm);
                }
            });
            // Check for changes while we're here
            $form.trigger('checkform.areYouSure');
        };

        var reinitialize = function () {
            initForm($(this));
        }

        if (!settings.silent && !window.aysUnloadSet) {
            window.aysUnloadSet = true;
            $(window).bind('beforeunload', function () {
                $dirtyForms = $("form").filter('.' + settings.dirtyClass);
                if ($dirtyForms.length == 0) {
                    return;
                }
                // Prevent multiple prompts - seen on Chrome and IE
                if (navigator.userAgent.toLowerCase().match(/msie|chrome/)) {
                    if (window.aysHasPrompted) {
                        return;
                    }
                    window.aysHasPrompted = true;
                    window.setTimeout(function () { window.aysHasPrompted = false; }, 900);
                }
                return settings.message;
            });
        }

        return this.each(function (elem) {
            if (!$(this).is('form')) {
                return;
            }
            var $form = $(this);

            $form.submit(function () {
                $form.removeClass(settings.dirtyClass);
            });
            $form.bind('reset', function () { setDirtyStatus($form, false); });
            // Add a custom events
            $form.bind('rescan.areYouSure', rescan);
            $form.bind('reinitialize.areYouSure', reinitialize);
            $form.bind('checkform.areYouSure', checkForm);
            initForm($form);
        });
    };
})(jQuery);
;
!function($){var Slider=function(element,options){this.element=$(element);this.picker=$('<div class="slider"><div class="slider-track"><div class="slider-selection"></div><div class="slider-handle"></div><div class="slider-handle"></div></div><div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div></div>').insertBefore(this.element).prepend(this.element);this.id=this.element.data("slider-id")||options.id;if(this.id){this.picker[0].id=this.id}if(typeof Modernizr!=="undefined"&&Modernizr.touch){this.touchCapable=true}var tooltip=this.element.data("slider-tooltip")||options.tooltip;this.tooltip=this.picker.find(".tooltip");this.tooltipInner=this.tooltip.find("div.tooltip-inner");this.orientation=this.element.data("slider-orientation")||options.orientation;switch(this.orientation){case"vertical":this.picker.addClass("slider-vertical");this.stylePos="top";this.mousePos="pageY";this.sizePos="offsetHeight";this.tooltip.addClass("right")[0].style.left="100%";break;default:this.picker.addClass("slider-horizontal").css("width",this.element.outerWidth());this.orientation="horizontal";this.stylePos="left";this.mousePos="pageX";this.sizePos="offsetWidth";this.tooltip.addClass("top")[0].style.top=-this.tooltip.outerHeight()-14+"px";break}this.min=this.element.data("slider-min")||options.min;this.max=this.element.data("slider-max")||options.max;this.step=this.element.data("slider-step")||options.step;this.value=this.element.data("slider-value")||options.value;if(this.value[1]){this.range=true}this.selection=this.element.data("slider-selection")||options.selection;this.selectionEl=this.picker.find(".slider-selection");if(this.selection==="none"){this.selectionEl.addClass("hide")}this.selectionElStyle=this.selectionEl[0].style;this.handle1=this.picker.find(".slider-handle:first");this.handle1Stype=this.handle1[0].style;this.handle2=this.picker.find(".slider-handle:last");this.handle2Stype=this.handle2[0].style;var handle=this.element.data("slider-handle")||options.handle;switch(handle){case"round":this.handle1.addClass("round");this.handle2.addClass("round");break;case"triangle":this.handle1.addClass("triangle");this.handle2.addClass("triangle");break}if(this.range){this.value[0]=Math.max(this.min,Math.min(this.max,this.value[0]));this.value[1]=Math.max(this.min,Math.min(this.max,this.value[1]))}else{this.value=[Math.max(this.min,Math.min(this.max,this.value))];this.handle2.addClass("hide");if(this.selection=="after"){this.value[1]=this.max}else{this.value[1]=this.min}}this.diff=this.max-this.min;this.percentage=[(this.value[0]-this.min)*100/this.diff,(this.value[1]-this.min)*100/this.diff,this.step*100/this.diff];this.offset=this.picker.offset();this.size=this.picker[0][this.sizePos];this.formater=options.formater;this.layout();if(this.touchCapable){this.picker.on({touchstart:$.proxy(this.mousedown,this)})}else{this.picker.on({mousedown:$.proxy(this.mousedown,this)})}if(tooltip==="show"){this.picker.on({mouseenter:$.proxy(this.showTooltip,this),mouseleave:$.proxy(this.hideTooltip,this)})}else{this.tooltip.addClass("hide")}};Slider.prototype={constructor:Slider,over:false,inDrag:false,showTooltip:function(){this.tooltip.addClass("in");this.over=true},hideTooltip:function(){if(this.inDrag===false){this.tooltip.removeClass("in")}this.over=false},layout:function(){this.handle1Stype[this.stylePos]=this.percentage[0]+"%";this.handle2Stype[this.stylePos]=this.percentage[1]+"%";if(this.orientation=="vertical"){this.selectionElStyle.top=Math.min(this.percentage[0],this.percentage[1])+"%";this.selectionElStyle.height=Math.abs(this.percentage[0]-this.percentage[1])+"%"}else{this.selectionElStyle.left=Math.min(this.percentage[0],this.percentage[1])+"%";this.selectionElStyle.width=Math.abs(this.percentage[0]-this.percentage[1])+"%"}if(this.range){this.tooltipInner.text(this.formater(this.value[0])+" : "+this.formater(this.value[1]));this.tooltip[0].style[this.stylePos]=this.size*(this.percentage[0]+(this.percentage[1]-this.percentage[0])/2)/100-(this.orientation==="vertical"?this.tooltip.outerHeight()/2:this.tooltip.outerWidth()/2)+"px"}else{this.tooltipInner.text(this.formater(this.value[0]));this.tooltip[0].style[this.stylePos]=this.size*this.percentage[0]/100-(this.orientation==="vertical"?this.tooltip.outerHeight()/2:this.tooltip.outerWidth()/2)+"px"}},mousedown:function(ev){if(this.touchCapable&&ev.type==="touchstart"){ev=ev.originalEvent}this.offset=this.picker.offset();this.size=this.picker[0][this.sizePos];var percentage=this.getPercentage(ev);if(this.range){var diff1=Math.abs(this.percentage[0]-percentage);var diff2=Math.abs(this.percentage[1]-percentage);this.dragged=(diff1<diff2)?0:1}else{this.dragged=0}this.percentage[this.dragged]=percentage;this.layout();if(this.touchCapable){$(document).on({touchmove:$.proxy(this.mousemove,this),touchend:$.proxy(this.mouseup,this)})}else{$(document).on({mousemove:$.proxy(this.mousemove,this),mouseup:$.proxy(this.mouseup,this)})}this.inDrag=true;var val=this.calculateValue();this.element.trigger({type:"slideStart",value:val}).trigger({type:"slide",value:val});return false},mousemove:function(ev){if(this.touchCapable&&ev.type==="touchmove"){ev=ev.originalEvent}var percentage=this.getPercentage(ev);if(this.range){if(this.dragged===0&&this.percentage[1]<percentage){this.percentage[0]=this.percentage[1];this.dragged=1}else{if(this.dragged===1&&this.percentage[0]>percentage){this.percentage[1]=this.percentage[0];this.dragged=0}}}this.percentage[this.dragged]=percentage;this.layout();var val=this.calculateValue();this.element.trigger({type:"slide",value:val}).data("value",val).prop("value",val);return false},mouseup:function(ev){if(this.touchCapable){$(document).off({touchmove:this.mousemove,touchend:this.mouseup})}else{$(document).off({mousemove:this.mousemove,mouseup:this.mouseup})}this.inDrag=false;if(this.over==false){this.hideTooltip()}this.element;var val=this.calculateValue();this.element.trigger({type:"slideStop",value:val}).data("value",val).prop("value",val);return false},calculateValue:function(){var val;if(this.range){val=[(this.min+Math.round((this.diff*this.percentage[0]/100)/this.step)*this.step),(this.min+Math.round((this.diff*this.percentage[1]/100)/this.step)*this.step)];this.value=val}else{val=(this.min+Math.round((this.diff*this.percentage[0]/100)/this.step)*this.step);this.value=[val,this.value[1]]}return val},getPercentage:function(ev){if(this.touchCapable){ev=ev.touches[0]}var percentage=(ev[this.mousePos]-this.offset[this.stylePos])*100/this.size;percentage=Math.round(percentage/this.percentage[2])*this.percentage[2];return Math.max(0,Math.min(100,percentage))},getValue:function(){if(this.range){return this.value}return this.value[0]},setValue:function(val){this.value=val;if(this.range){this.value[0]=Math.max(this.min,Math.min(this.max,this.value[0]));this.value[1]=Math.max(this.min,Math.min(this.max,this.value[1]))}else{this.value=[Math.max(this.min,Math.min(this.max,this.value))];this.handle2.addClass("hide");if(this.selection=="after"){this.value[1]=this.max}else{this.value[1]=this.min}}this.diff=this.max-this.min;this.percentage=[(this.value[0]-this.min)*100/this.diff,(this.value[1]-this.min)*100/this.diff,this.step*100/this.diff];this.layout()}};$.fn.slider=function(option,val){return this.each(function(){var $this=$(this),data=$this.data("slider"),options=typeof option==="object"&&option;if(!data){$this.data("slider",(data=new Slider(this,$.extend({},$.fn.slider.defaults,options))))}if(typeof option=="string"){data[option](val)}})};$.fn.slider.defaults={min:0,max:10,step:1,orientation:"horizontal",value:5,selection:"before",tooltip:"show",handle:"round",formater:function(value){return value}};$.fn.slider.Constructor=Slider}(window.jQuery);;
/*! Copyright © 2009-2024 Postcode Anywhere (Holdings) Ltd. (http://www.postcodeanywhere.co.uk)
 *
 * Address v3.97
 * Address capture script file
 *
 * p-w-e-w2-4-qlmv 03/09/2024 11:55:05
 */
/*3.93 - recalculate the maxwidth for autocomplete control to support mobile friendly*/

/** @namespace pca */
(function (window, undefined) {
    var pca = window.pca = window.pca || {},
        document = window.document;

    //Apply some sensible defaults in case we need to run outside of a browser
    if (typeof (document) == "undefined") document = { location: {} };
    if (typeof (window.location) == "undefined") window.location = {};
    if (typeof (window.navigator) == "undefined") window.navigator = {};

    //Service target information
    pca.protocol = "https:";
    pca.host = "services.postcodeanywhere.co.uk";
    pca.endpoint = "json3ex.ws";
    pca.limit = 2000;
    pca.sourceString = pca.sourceString || "PCA-SCRIPT";

    //Synonyms for list filtering.
    //Only need to replace things at the start of item text.
    pca.synonyms = pca.synonyms || [
        { r: /\bN(?=\s)/, w: "NORTH" },
        { r: /\b(?:NE|NORTHEAST)(?=\s)/, w: "NORTH EAST" },
        { r: /\b(?:NW|NORTHWEST)(?=\s)/, w: "NORTH WEST" },
        { r: /\bS(?=\s)/, w: "SOUTH" },
        { r: /\b(?:SE|SOUTHEAST)(?=\s)/, w: "SOUTH EAST" },
        { r: /\b(?:SW|SOUTHWEST)(?=\s)/, w: "SOUTH WEST" },
        { r: /\bE(?=\s)/, w: "EAST" },
        { r: /\bW(?=\s)/, w: "WEST" },
        { r: /\bST(?=\s)/, w: "SAINT" }
    ];

    //Basic diacritic replacements.
    pca.diacritics = pca.diacritics || [
        { r: /[ÀÁÂÃ]/gi, w: "A" },
        { r: /Å/gi, w: "AA" },
        { r: /[ÆæÄ]/gi, w: "AE" },
        { r: /Ç/gi, w: "C" },
        { r: /Ð/gi, w: "DJ" },
        { r: /[ÈÉÊË]/gi, w: "E" },
        { r: /[ÌÍÏ]/gi, w: "I" },
        { r: /Ñ/gi, w: "N" },
        { r: /[ÒÓÔÕ]/gi, w: "O" },
        { r: /[ŒØÖ]/gi, w: "OE" },
        { r: /Š/gi, w: "SH" },
        { r: /ß/gi, w: "SS" },
        { r: /[ÙÚÛ]/gi, w: "U" },
        { r: /Ü/gi, w: "UE" },
        { r: /[ŸÝ]/gi, w: "ZH" },
        { r: /-/gi, w: " " },
        { r: /[.,]/gi, w: "" }
    ];

    //HTML encoded character replacements.
    pca.hypertext = pca.hypertext || [
        { r: /&/g, w: "&amp;" },
        { r: /"/g, w: "&quot;" },
        { r: /'/g, w: "&#39;" },
        { r: /</g, w: "&lt;" },
        { r: />/g, w: "&gt;" }
    ];

    //Current service requests.
    //pca.requests = [];
    pca.requestQueue = pca.requestQueue || [];
    pca.requestCache = pca.requestCache || {};
    pca.scriptRequests = pca.scriptRequests || [];
    pca.waitingRequest = pca.waitingRequest || false;
    pca.blockRequests = pca.blockRequests || false;

    //Current style fixes.
    pca.styleFixes = pca.styleFixes || [];
    pca.agent = pca.agent || (window.navigator && window.navigator.userAgent) || "";
    //mousedown issue with older galaxy devices with stock browser
    pca.galaxyFix = pca.galaxyFix || ((/Safari\/534.30/).test(pca.agent) && (/GT-I8190|GT-I9100|GT-I9305|GT-P3110/).test(pca.agent));

    //Container for page elements.
    pca.container = pca.container || null;

    //store local reference to XHR
    pca.XMLHttpRequest = pca.XMLHttpRequest || window.XMLHttpRequest;

    //Ready state.
    var ready = false,
        readyList = [];

    /** Allows regex matching on field IDs.
    * @memberof pca */
    pca.fuzzyMatch = typeof pca.fuzzyMatch === "undefined" ? true : pca.fuzzyMatch;

    /** HTML element tag types to check when fuzzy matching.
    * @memberof pca */
    pca.fuzzyTags = pca.fuzzyTags || ["*"];

    /** Called when document is ready.
    * @memberof pca
    * @param {function} delegate - a function to call when the document is ready. */
    pca.ready = pca.ready || function (delegate) {
        if (ready) {
            //process waiting handlers first
            if (readyList.length) {
                var handlers = readyList;

                readyList = [];

                for (var i = 0; i < handlers.length; i++)
                    handlers[i]();
            }

            if (delegate) delegate();
        }
        else if (typeof delegate == 'function')
            readyList.push(delegate);
    }

    //Checks document load.
    function documentLoaded() {
        if (document.addEventListener) {
            pca.ignore(document, "DOMContentLoaded", documentLoaded);
            ready = true;
            pca.ready();
        }
        else if (document.readyState === "complete") {
            pca.ignore(document, "onreadystatechange", documentLoaded);
            ready = true;
            pca.ready();
        }
    }

    //Listen for document load.
    function checkDocumentLoad() {
        if (document.readyState === "complete") {
            ready = true;
            pca.ready();
        }
        else {
            if (document.addEventListener) pca.listen(document, "DOMContentLoaded", documentLoaded);
            else pca.listen(document, "onreadystatechange", documentLoaded);
            pca.listen(window, "load", documentLoaded);
        }
    }

    /** Provides methods for event handling.
    * @memberof pca
    * @constructor
    * @mixin
    * @param {Object} [source] - The base object to inherit from. */
    pca.Eventable = pca.Eventable || function (source) {
        /** @lends pca.Eventable.prototype */
        var obj = source || this;

        /** The list of listener for the object. */
        obj.listeners = {};

        /** Listen to a PCA event.
        * @param {string} event - The name of the even to listen for.
        * @param {pca.Eventable~eventHandler} action - The handler to add.
        */
        obj.listen = function (event, action) {
            obj.listeners[event] = obj.listeners[event] || [];
            obj.listeners[event].push(action);
        }

        /** Ignore a PCA event.
        * @param {string} event - The name of the even to ignore.
        * @param {pca.Eventable~eventHandler} action - The handler to remove.
        */
        obj.ignore = function (event, action) {
            if (obj.listeners[event]) {
                for (var i = 0; i < obj.listeners[event].length; i++) {
                    if (obj.listeners[event][i] === action) {
                        obj.listeners[event].splice(i, 1);
                        break;
                    }
                }
            }
        }

        /** Fire a PCA event. Can take any number of additional parameters and pass them on to the listeners.
        * @param {string} event - The name of the event to fire.
        * @param {...*} data - The detail of the event. */
        obj.fire = function (event, data) {
            if (obj.listeners[event]) {
                for (var i = 0; i < obj.listeners[event].length; i++) {
                    var args = [data];

                    for (var a = 2; a < arguments.length; a++)
                        args.push(arguments[a]);

                    obj.listeners[event][i].apply(obj, args);
                }
            }
        }

        return obj;

        /** Callback for a successful request.
        * @callback pca.Eventable~eventHandler
        * @param {...*} data - The detail of the event. */
    }

    ///Makes a service request using a XMLHttpRequest POST method.
    function postRequestXHR(request) {
        var xhr = new pca.XMLHttpRequest();

        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200)
                request.callback(pca.parseJSON(xhr.responseText));
        }

        if (request.credentials)
            xhr.withCredentials = request.credentials;

        xhr.onerror = request.serviceError;
        xhr.ontimeout = request.timeoutError;
        xhr.open("POST", request.destination, true);
        xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
        xhr.send(request.query);
    }

    //Makes a service request using a form POST method.
    function postRequestForm(request) {
        var form = document.createElement("form"),
            iframe = document.createElement("iframe"),
            loaded = false;

        function addParameter(name, value) {
            var field = document.createElement("input");
            field.name = name;
            field.value = value;
            form.appendChild(field);
        }

        form.method = "POST";
        form.action = pca.protocol + "//" + pca.host + "/" + request.service + "/json.ws";

        for (var key in request.data)
            addParameter(key, request.data[key]);

        addParameter("CallbackVariable", "window.name");
        addParameter("CallbackWithScriptTags", "true");

        iframe.onload = function () {
            if (!loaded) {
                loaded = true;
                iframe.contentWindow.location = "about:blank";
            }
            else {
                request.callback({ Items: pca.parseJSON(iframe.contentWindow.name) });
                document.body.removeChild(iframe);
            }
        }

        iframe.style.display = "none";
        document.body.appendChild(iframe);

        var doc = iframe.contentDocument || iframe.contentWindow.document;
        doc.body ? doc.body.appendChild(form) : doc.appendChild(form);
        form.submit();
    }

    //Makes a POST request using best method available.
    //Security must be bypassed in Internet Explorer up to version 10
    function postRequest(request) {
        window.navigator.appName === "Microsoft Internet Explorer" ? postRequestForm(request) : postRequestXHR(request);
    }

    //Makes a service request using a XMLHttpRequest GET method.
    function getRequestXHR(request) {
        var xhr = new pca.XMLHttpRequest();

        //if the URL length is long and likely to cause problems with URL limits, so we should make a POST request
        if (request.url.length > pca.limit) {
            request.post = true;
            postRequest(request);
        }
        else {
            xhr.onreadystatechange = function () {
                if (xhr.readyState === 4 && xhr.status === 200)
                    request.callback(pca.parseJSON(xhr.responseText));
            }

            if (request.credentials)
                xhr.withCredentials = request.credentials;

            xhr.onerror = request.serviceError;
            xhr.ontimeout = request.timeoutError;
            xhr.open("GET", request.url, true);
            xhr.send();
        }
    }

    //Makes a service request using a script GET method.
    function getRequestScript(request) {
        var script = pca.create("script", { type: "text/javascript", async: "async" }),
            head = document.getElementsByTagName("head")[0];

        //set a callback point
        request.position = pca.scriptRequests.push(request);
        script.src = request.url + "&callback=pca.scriptRequests[" + (request.position - 1) + "].callback";

        script.onload = script.onreadystatechange = function () {
            if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete") {
                script.onload = script.onreadystatechange = null;
                if (head && script.parentNode)
                    head.removeChild(script);
            }
        }

        //if the src length is long and likely to cause problems with url limits we should make a POST request
        if (script.src.length > pca.limit) {
            request.post = true;
            postRequest(request);
        }
        else
            head.insertBefore(script, head.firstChild);
    }

    //Makes a GET request using best method available.
    //Security must be bypassed in Internet Explorer up to version 10.
    function getRequest(request) {
        window.navigator.appName === "Microsoft Internet Explorer" ? getRequestScript(request) : getRequestXHR(request);
    }

    //Decide what to do with the request.
    function processRequest(request) {

        //block requests if the flag is set, ignore all but the last request in this state
        if (pca.blockRequests && pca.waitingRequest) {
            pca.requestQueue = [request];
            return;
        }

        if (request.block)
            pca.blockRequests = true;

        //queue the request if flag is set
        if (request.queue && pca.waitingRequest) {
            pca.requestQueue.push(request);
            return;
        }

        pca.waitingRequest = true;

        //check the cache if the flag is set
        if (request.cache && pca.requestCache[request.url]) {
            function ayncCallback() {
                request.callback(pca.requestCache[request.url].response);
            }

            window.setImmediate ? window.setImmediate(ayncCallback) : window.setTimeout(ayncCallback, 1);
            return;
        }

        //make the request
        request.post ? postRequest(request) : getRequest(request);
    }

    //Receives and processes the service response.
    function processResponse(request) {
        pca.waitingRequest = false;

        if (request.block)
            pca.blockRequests = false;

        if (request.unwrapped) {
            request.success(request.response, request.response, request);
        } else {
            if (request.response.Items.length === 1 && request.response.Items[0].Error !== undefined)
                request.error(request.response.Items[0].Description, request);
            else
                request.success(request.response.Items, request.response, request);
        }

        if (request.cache)
            pca.requestCache[request.url] = request;

        if (request.position)
            pca.scriptRequests[request.position - 1] = null;

        if (pca.requestQueue.length)
            processRequest(pca.requestQueue.shift());
    }

    /** Represents a service request
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {string} service - The service name. e.g. CapturePlus/Interactive/Find/v1.00
    * @param {Object} [data] - An object containing request parameters, such as key.
    * @param {boolean} [data.$cache=false] - The request will be cached.
    * @param {boolean} [data.$queue=false] - Queue other quests and make them once a response is received.
    * @param {boolean} [data.$block=false] - Ignore other requests until a response is received.
    * @param {boolean} [data.$post=false] - Make a POST request.
    * @param {boolean} [data.$credentials=false] - Send credentials with request.
    * @param {boolean} [data.$unwrapped=false] - return data will not be wrapped in items array.
    * @param {pca.Request~successCallback} [success] - A callback function for successful requests.
    * @param {pca.Request~errorCallback} [error] - A callback function for errors. */
    pca.Request = pca.Request || function (service, data, success, error) {
        /** @lends pca.Request.prototype */
        var request = new pca.Eventable(this);

        request.service = service || "";
        request.data = data || {};
        request.success = success || function () { };
        request.error = error || function () { };
        request.response = null;

        request.source = pca.sourceString || "";
        request.sessionId = pca.sessionId || "";

        request.cache = !!request.data.$cache; //request will not be deleted, other requests for the same data will return this response
        request.queue = !!request.data.$queue; //queue this request until other request is finished
        request.block = !!request.data.$block; //other requests will be blocked until this request is finished, only the last request will be queued
        request.post = !!request.data.$post; //force the request to be made using a HTTP POST
        request.credentials = !!request.data.$credentials; //send request credentials such as cookies
        request.unwrapped = !!request.data.$unwrapped; //eturn data will not be wrapped in items array.

        //build the basic request url
        request.destination = ~request.service.indexOf("//") ? request.service : pca.protocol + "//" + pca.host + "/" + request.service + "/" + pca.endpoint;
        request.query = "";

        for (var p in request.data)
            request.query += (request.query ? "&" : "") + p + "=" + encodeURIComponent(request.data[p]);

        if (request.source) {
            request.query += (request.query ? "&" : "") + "SOURCE=" + encodeURIComponent(request.source);
        }

        if (request.sessionId) {
            request.query += (request.query ? "&" : "") + "SESSION=" + encodeURIComponent(request.sessionId);
        }

        request.url = request.destination + "?" + request.query;

        request.callback = function (response) {
            request.response = response;
            processResponse(request);
        }

        request.serviceError = function (event) {
            request.error(event && event.currentTarget && event.currentTarget.statusText ? "Webservice request error: " + event.currentTarget.statusText : "Webservice request failed.");
        }

        request.timeoutError = function () {
            request.error("Webservice request timed out.");
        }

        request.process = function () {
            pca.process(request);
        }

        /** Callback for a successful request.
        * @callback pca.Request~successCallback
        * @param {Object} items - The items returned in the response.
        * @param {Object} response - The raw response including additional fields. */

        /** Callback for a failed request.
        * @callback pca.Request~errorCallback
        * @param {string} message - The error text. */
    }

    /** Processes a webservice request
    * @memberof pca
    * @param {pca.Request} request - The request to process */
    pca.process = pca.process || function (request) {
        processRequest(request);
    }

    /** Simple method for making a Postcode Anywhere service request and processing it
    * @memberof pca
    * @param {string} service - The service name. e.g. CapturePlus/Interactive/Find/v1.00
    * @param {Object} [data] - An object containing request parameters, such as key.
    * @param {boolean} [data.$cache] - The request will be cached.
    * @param {boolean} [data.$queue] - Queue other quests and make them once a response is received.
    * @param {boolean} [data.$block] - Ignore other requests until a response is received.
    * @param {boolean} [data.$post] - Make a POST request.
    * @param {pca.Request~successCallback} [success] - A callback function for successful requests.
    * @param {pca.Request~errorCallback} [error] - A callback function for errors. */
    pca.fetch = pca.fetch || function (service, data, success, error) {
        processRequest(new pca.Request(service, data, success, error));
    }

    /** Clears blocking requests */
    pca.clearBlockingRequests = pca.clearBlockingRequests || function () {
        pca.waitingRequest = false;
        pca.blockRequests = false;
    }

    /** Dynamically load an additional script.
    * @memberof pca
    * @param {string} name - the name of the script to load.
    * @param {function} [callback] - a function to call once the script has loaded.
    * @param {HTMLDocument} [doc=document] - The document element in which to append the script. */
    pca.loadScript = pca.loadScript || function (name, callback, doc) {
        var script = pca.create("script", { type: "text/javascript" }),
            head = (doc || document).getElementsByTagName("head")[0];

        script.onload = script.onreadystatechange = function () {
            if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete") {
                script.onload = script.onreadystatechange = null;
                (callback || function () { })();
            }
        }

        script.src = (~name.indexOf("/") ? "" : pca.protocol + "//" + pca.host + "/js/") + name;
        head.insertBefore(script, head.firstChild);
    }

    /** Dynamically load an additional style sheet.
    * @memberof pca
    * @param {string} name - the name of the style sheet to load.
    * @param {function} [callback] - a function to call once the style sheet has loaded.
    * @param {HTMLDocument} [doc=document] - The document element in which to append the script. */
    pca.loadStyle = pca.loadStyle || function (name, callback, doc) {
        var style = pca.create("link", { type: "text/css", rel: "stylesheet" }),
            head = (doc || document).getElementsByTagName("head")[0];

        style.onload = style.onreadystatechange = function () {
            if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete") {
                style.onload = style.onreadystatechange = null;
                (callback || function () { })();
            }
        }

        style.href = (~name.indexOf("/") ? "" : pca.protocol + "//" + pca.host + "/css/") + name;
        head.insertBefore(style, head.firstChild);
    }

    /** Represents an item of data with a HTML element.
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {Object} data - An object containing the data for the item.
    * @param {string} format - The template string to format the item label with. */
    pca.Item = pca.Item || function (data, format) {
        /** @lends pca.Item.prototype */
        var item = new pca.Eventable(this),
            highlightClass = "pcaselected";

        /** The original data for the item. */
        item.data = data;
        /** The original formatter for the item. */
        item.format = format;
        item.html = pca.formatLine(data, format);
        item.tag = pca.formatTag(data.tag || item.html);
        /** The HTML element for the item. */

        item.element = pca.create("div", {
            className: "pcaitem",
            innerHTML: item.html,
            role: "option"
        });

        item.element.setAttribute("tabindex", -1);

        //ARIA
        item.element.addEventListener("keydown", function (evt) {
            //get correct control
            if (pca.operatingNamespace || pca.activeAddress) {
                var control = pca.activeAddress || pca[pca.operatingNamespace].controls.find(function (control) {
                    return control.autocomplete.list.collection.items.indexOf(item) > -1;
                })
                if (control) {
                    var currentAutocomplete = control.inCountryListMode
                        ? control.countrylist.autocomplete
                        : control.autocomplete;
                    //delegate to autocomplete control
                    if (currentAutocomplete.list.collection.items.indexOf(item) == 0 &&
                        evt.keyCode == 38) {
                        //is first and going up - refocus to input
                        if (currentAutocomplete.field) {
                            currentAutocomplete.field.focus();
                            setTimeout(function () {
                                pca.moveCursorToEnd(currentAutocomplete.field);
                            }, 0);
                        }
                    }
                    else if (evt.keyCode == 9 || evt.keyCode == 27) {
                        //tab
                        if (!control.inCountryListMode &&
                            control.options.bar.visible &&
                            control.options.bar.showCountry) {
                            //focus on the country button
                        } else if (currentAutocomplete.field) {
                            currentAutocomplete.field.focus();
                            pca.moveCursorToEnd(currentAutocomplete.field);
                            currentAutocomplete.hide();
                            currentAutocomplete.field.dispatchEvent(evt);
                            pca.smash(evt);
                        }
                    } else {
                        currentAutocomplete.list.navigate(evt.keyCode);
                    }

                }
            }

        });

        item.visible = true;

        /** Applies the highlight style.
        * @fires highlight */
        item.highlight = function () {
            pca.addClass(item.element, highlightClass);
            item.fire("highlight");
            item.element.focus();
            return item;
        }

        /** Removes the highlight style.
        * @fires lowlight */
        item.lowlight = function () {
            pca.removeClass(item.element, highlightClass);
            item.fire("lowlight");

            return item;
        }

        /** The user is hovering over the item.
        * @fires mouseover */
        item.mouseover = function () {
            item.fire("mouseover");
        }

        /** The user has left the item.
        * @fires mouseout */
        item.mouseout = function () {
            item.fire("mouseout");
        }

        /** The user is pressed down on the item.
        * @fires mousedown */
        item.mousedown = function () {
            item.fire("mousedown");
        }

        /** The user released the item.
        * @fires mouseup */
        item.mouseup = function () {
            item.fire("mouseup");

            if (pca.galaxyFix) item.select();
        }

        /** The user has clicked the item.
        * @fires click */
        item.click = function () {
            item.fire("click");

            if (pca.galaxyFix) return;

            item.select();
        }

        /** Selects the item.
        * @fires select */
        item.select = function () {
            item.fire("select", item.data);

            return item;
        }

        /** Makes the item invisible.
        * @fires hide */
        item.hide = function () {
            item.visible = false;
            item.element.style.display = "none";
            item.fire("hide");

            return item;
        }

        /** Makes the item visible.
        * @fires show */
        item.show = function () {
            item.visible = true;
            item.element.style.display = "";
            item.fire("show");

            return item;
        }

        pca.listen(item.element, "mouseout", item.mouseout);
        pca.listen(item.element, "mousedown", item.mousedown);
        pca.listen(item.element, "mouseup", item.mouseup);
        pca.listen(item.element, "click", item.click);

        return item;
    }

    /** Represents a collection of items.
    * @memberof pca
    * @constructor
    * @mixes Eventable */
    pca.Collection = pca.Collection || function () {
        /** @lends pca.Collection.prototype */
        var collection = new pca.Eventable(this);

        /** The list of items.
        * @type {Array.<pca.Item>} */
        collection.items = [];
        /** The index of the current highlighted item.
        * @type {number} */
        collection.highlighted = -1;
        /** The number of visible items.
        * @type {number} */
        collection.count = 0;
        collection.firstItem = null;
        collection.lastItem = null;
        collection.firstVisibleItem = null;
        collection.lastVisibleItem = null;

        /** Populates the collection with new items.
        * @param {Array.<Object>|Object} data - Data objects to add e.g. a response array from a service.
        * @param {string} format - A template string to format the label of the item.
        * @param {pca.Collection~itemCallback} callback - A callback function when the item is selected.
        * @fires add */
        collection.add = function (data, format, callback) {
            var additions = [];

            callback = callback || function () { };

            function createItem(attributes) {
                var item = new pca.Item(attributes, format);
                item.listen("mouseover", function () { collection.highlight(item); });

                item.listen("select", function (selectedItem) {
                    collection.fire("select", selectedItem);
                    callback(selectedItem);
                });

                collection.items.push(item);
                additions.push(item);
                return item;
            }

            if (data.length) {
                for (var i = 0; i < data.length; i++)
                    createItem(data[i]);
            }
            else createItem(data);

            collection.count += data.length;
            collection.firstVisibleItem = collection.firstItem = collection.items[0];
            collection.lastVisibleItem = collection.lastItem = collection.items[collection.items.length - 1];
            collection.fire("add", additions);

            return collection;
        }

        /** Sort the items in the collection.
        * @param {string} [field] - The name of the property of the item to compare.
        * @fires sort */
        collection.sort = function (field) {
            collection.items.sort(function (a, b) {
                return field ? (a.data[field] > b.data[field] ? 1 : -1) : (a.tag > b.tag ? 1 : -1);
            });

            collection.fire("sort");

            return collection;
        }

        /** Reverse the order of the items.
        * @fires reverse */
        collection.reverse = function () {
            collection.items.reverse();

            collection.fire("reverse");

            return collection;
        }

        /** Filters the items in the collection and hides all items that do not contain the term.
        * @param {string} term - The term which each item should contain.
        * @fires filter */
        collection.filter = function (term) {
            var tag = pca.formatTag(term),
                count = collection.count;

            collection.count = 0;
            collection.firstVisibleItem = null;
            collection.lastVisibleItem = null;

            collection.all(function (item) {
                if (~item.tag.indexOf(tag)) {
                    item.show();
                    collection.count++;

                    collection.firstVisibleItem = collection.firstVisibleItem || item;
                    collection.lastVisibleItem = item;
                }
                else
                    item.hide();
            });

            if (count !== collection.count)
                collection.fire("filter");

            return collection;
        }

        /** Returns the items which match the search term.
        * @param {string} term - The term which each item should contain.
        * @returns {Array.<pca.Item>} The items matching the search term. */
        collection.match = function (term) {
            var tag = pca.formatTag(term),
                matches = [];

            collection.all(function (item) {
                if (~item.tag.indexOf(tag))
                    matches.push(item);
            });

            return matches;
        }

        /** Remove all items from the collection.
        * @fires clear */
        collection.clear = function () {
            collection.items = [];
            collection.count = 0;
            collection.highlighted = -1;
            collection.firstItem = null;
            collection.lastItem = null;
            collection.firstVisibleItem = null;
            collection.lastVisibleItem = null;

            collection.fire("clear");

            return collection;
        }

        /** Runs a function for every item in the list or until false is returned.
        * @param {pca.Collection~itemDelegate} delegate - The delegate function to handle each item. */
        collection.all = function (delegate) {
            for (var i = 0; i < collection.items.length; i++) {
                if (delegate(collection.items[i], i) === false)
                    break;
            }

            return collection;
        }

        /** Sets the current highlighted item.
        * @param {pca.Item} item - The item to highlight.
        * @fires highlight */
        collection.highlight = function (item) {
            if (~collection.highlighted) collection.items[collection.highlighted].lowlight();
            collection.highlighted = collection.index(item);
            if (~collection.highlighted) collection.items[collection.highlighted].highlight();

            collection.fire("highlight", item);

            return collection;
        }

        /** Gets the index of an item.
        * @param {pca.Item} item - The item search for.
        * @returns {number} The index of the item or -1.*/
        collection.index = function (item) {
            for (var i = 0; i < collection.items.length; i++) {
                if (collection.items[i] === item)
                    return i;
            }

            return -1;
        }

        /** Returns the first matching item.
        * @param {pca.Collection~itemMatcher} [matcher] - The matcher function to handle each item.
        * @returns {pca.Item} The item found or null. */
        collection.first = function (matcher) {
            for (var i = 0; i < collection.items.length; i++) {
                if (!matcher ? collection.items[i].visible : matcher(collection.items[i]))
                    return collection.items[i];
            }

            return null;
        }

        /** Returns the last matching item.
        * @param {pca.Collection~itemMatcher} [matcher] - The matcher function to handle each item.
        * @returns {pca.Item} The item found or null. */
        collection.last = function (matcher) {
            for (var i = collection.items.length - 1; i >= 0; i--) {
                if (!matcher ? collection.items[i].visible : matcher(collection.items[i]))
                    return collection.items[i];
            }

            return null;
        }

        /** Returns the next matching item from the current selection.
        * @param {pca.Collection~itemMatcher} [matcher] - The matcher function to handle each item.
        * @returns {pca.Item} The item found or the first item. */
        collection.next = function (matcher) {
            for (var i = collection.highlighted + 1; i < collection.items.length; i++) {
                if (!matcher ? collection.items[i].visible : matcher(collection.items[i]))
                    return collection.items[i];
            }
        }

        /** Returns the previous matching item to the current selection.
        * @param {pca.Collection~itemMatcher} [matcher] - The matcher function to handle each item.
        * @returns {pca.Item} The item found or the last item. */
        collection.previous = function (matcher) {
            for (var i = collection.highlighted - 1; i >= 0; i--) {
                if (!matcher ? collection.items[i].visible : matcher(collection.items[i]))
                    return collection.items[i];
            }
        }

        /** Returns all items that are visible in the list.
        * @returns {Array.<pca.Item>} The items that are visible. */
        collection.visibleItems = function () {
            var visible = [];

            collection.all(function (item) {
                if (item.visible)
                    visible.push(item);
            });

            return visible;
        }

        return collection;

        /** Callback function for item selection.
        * @callback pca.Collection~itemCallback
        * @param {Object} data - The original data of the item. */

        /** Delegate function to handle an item.
        * @callback pca.Collection~itemDelegate
        * @param {pca.Item} item - The current item.
        * @param {number} index - The index of the current item in the collection.
        * @returns {boolean} Returns a response of false to stop the operation. */

        /** Delegate function to compare an item.
        * @callback pca.Collection~itemMatcher
        * @param {pca.Item} item - The current item.
        * @returns {boolean} Returns a response of true for a matching item. */
    }

    /**
    * List options.
    * @typedef {Object} pca.List.Options
    * @property {string} [name] - A reference for the list used an Id for ARIA.
    * @property {number} [minItems] - The minimum number of items to show in the list.
    * @property {number} [maxItems] - The maximum number of items to show in the list.
    * @property {boolean} [allowTab] - Allow the tab key to cycle through items in the list.
    */

    /** A HTML list to display items.
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {pca.List.Options} [options] - Additional options to apply to the list. */
    pca.List = pca.List || function (options) {
        /** @lends pca.List.prototype */
        var list = new pca.Eventable(this);

        list.options = options || {};
        /** The HTML parent element of the list */
        list.element = pca.create("div", { className: "pca pcalist" });
        /** The collection of items in the list
        * @type {pca.Collection} */
        list.collection = new pca.Collection();
        list.visible = true;
        list.scroll = {
            held: false,
            moved: false,
            origin: 0,
            position: 0,
            x: 0,
            y: 0,
            dx: 0,
            dy: 0
        }
        list.highlightedItem = null;
        /** An item that will always be displayed first in the list.
        * @type {pca.Item} */
        list.headerItem = null;
        /** An item that will always be displayed last in the list.
        * @type {pca.Item} */
        list.footerItem = null;
        list.firstItem = null;
        list.lastItem = null;
        list.firstItemClass = "pcafirstitem";
        list.lastItemClass = "pcalastitem";

        list.options.minItems = list.options.minItems || 0;
        list.options.maxItems = list.options.maxItems || 10;
        list.options.allowTab = list.options.allowTab || false;

        /** Shows the list.
        * @fires show */
        list.show = function () {
            list.visible = true;
            list.element.style.display = "";
            list.fire("show");
            list.resize();

            return list;
        }

        /** Hides the list.
        * @fires hide */
        list.hide = function () {
            list.visible = false;
            list.element.style.display = "none";
            list.fire("hide");

            return list;
        }

        /** Redraws the list by removing all children and adding them again.
        * @fires draw */
        list.draw = function () {
            list.destroy();

            if (list.headerItem)
                list.element.appendChild(list.headerItem.element);

            list.collection.all(function (item) {
                list.element.appendChild(item.element);
            });

            if (list.footerItem)
                list.element.appendChild(list.footerItem.element);

            list.resize();
            list.fire("draw");

            return list;
        }

        /** Marks the first and last items in the list with a CSS class */
        list.markItems = function () {
            if (list.firstItem) pca.removeClass(list.firstItem.element, list.firstItemClass);
            if (list.lastItem) pca.removeClass(list.lastItem.element, list.lastItemClass);

            if (list.collection.count) {
                list.firstItem = list.headerItem || list.collection.firstVisibleItem;
                list.lastItem = list.footerItem || list.collection.lastVisibleItem;
                pca.addClass(list.firstItem.element, list.firstItemClass);
                pca.addClass(list.lastItem.element, list.lastItemClass);
            }
        }

        /** Adds items to the list collection.
        * @param {Array.<Object>} array - An array of data objects to add e.g. a response array from a service.
        * @param {string} format - A template string to format the label of the item.
        * @param {pca.Collection~itemCallback} callback - A callback function when the item is selected.
        * @fires add */
        list.add = function (array, format, callback) {
            list.collection.add(array, format, callback);
            list.draw();

            return list;
        }

        /** Destroys all items in the list. */
        list.destroy = function () {
            while (list.element.childNodes && list.element.childNodes.length)
                list.element.removeChild(list.element.childNodes[0]);

            return list;
        }

        /** Clears all items from the list
        * @fires clear */
        list.clear = function () {
            list.collection.clear();
            list.destroy();
            list.fire("clear");

            return list;
        }

        /** Sets the scroll position of the list.
        * @param {number} position - The top scroll position in pixels.
        * @fires scroll */
        list.setScroll = function (position) {
            list.element.scrollTop = position;
            list.fire("scroll");

            return list;
        }

        /** Enables touch input for list scrolling.
        * Most mobile browsers will handle scrolling without this. */
        list.enableTouch = function () {
            //touch events
            function touchStart(event) {
                event = event || window.event;
                list.scroll.held = true;
                list.scroll.moved = false;
                list.scroll.origin = parseInt(list.scrollTop);
                list.scroll.y = parseInt(event.touches[0].pageY);
            }

            function touchEnd() {
                list.scroll.held = false;
            }

            function touchCancel() {
                list.scroll.held = false;
            }

            function touchMove(event) {
                if (list.scroll.held) {
                    event = event || window.event;

                    //Disable Gecko and Webkit image drag
                    pca.smash(event);

                    list.scroll.dy = list.scroll.y - parseInt(event.touches[0].pageY);
                    list.scroll.position = list.scroll.origin + list.scroll.dy;
                    list.setScroll(list.scroll.position);
                    list.scroll.moved = true;
                }
            }

            pca.listen(list.element, "touchstart", touchStart);
            pca.listen(list.element, "touchmove", touchMove);
            pca.listen(list.element, "touchend", touchEnd);
            pca.listen(list.element, "touchcancel", touchCancel);

            return list;
        }

        /** Moves to an item in the list */
        list.move = function (item) {
            if (item) {
                list.collection.highlight(item);

                if (item === list.headerItem || item === list.footerItem)
                    item.highlight();

                list.scrollToItem(item);
            }

            return list;
        }

        /** Moves to the next item in the list. */
        list.next = function () {
            return list.move(list.nextItem());
        }

        /** Moves to the previous item in the list */
        list.previous = function () {
            return list.move(list.previousItem());
        }

        /** Moves to the first item in the list. */
        list.first = function () {
            return list.move(list.firstItem);
        }

        /** Moves to the last item in the list. */
        list.last = function () {
            return list.move(list.lastItem);
        }

        /** Returns the next item.
        * @returns {pca.Item} The next item. */
        list.nextItem = function () {
            if (!list.highlightedItem) return list.firstItem;

            if (list.highlightedItem === list.collection.lastVisibleItem && (list.footerItem || list.headerItem))
                return list.footerItem || list.headerItem;

            if (list.footerItem && list.headerItem && list.highlightedItem === list.footerItem)
                return list.headerItem;

            return list.collection.next();
        }

        /** Returns the previous item.
        * @returns {pca.Item} The previous item. */
        list.previousItem = function () {
            if (!list.highlightedItem) return list.lastItem;

            if (list.highlightedItem === list.collection.firstVisibleItem && (list.footerItem || list.headerItem))
                return list.headerItem || list.footerItem;

            if (list.footerItem && list.headerItem && list.highlightedItem === list.headerItem)
                return list.footerItem;

            return list.collection.previous();
        }

        /** Returns the current item.
        * @returns {pca.Item} The current item. */
        list.currentItem = function () {
            return list.highlightedItem;
        }

        /** Returns true if the current item is selectable.
        * @returns {boolean} True if the current item is selectable. */
        list.selectable = function () {
            return list.visible && !!list.currentItem();
        }

        /** Calls the select function for the current item */
        list.select = function () {
            if (list.selectable())
                list.currentItem().select();

            return list;
        }

        /** Handles list navigation based upon a key code
         * @param {number} key - The keyboard key code.
         * @param {boolean} firstIfDown - Go to the first element if down key is pressed.
         * @returns {boolean} True if the list handled the key code. */
        list.navigate = function (key, firstIfDown) {
            switch (key) {
                case 40: //down
                    if (firstIfDown) {
                        list.first();
                    } else {
                        list.next();
                    }
                    return true;
                case 38: //up
                    list.previous();
                    return true;
                case 13: //enter/return
                    if (list.selectable()) {
                        list.select();
                        return true;
                    }
                case 9: //tab
                    if (list.options.allowTab) {
                        list.next();
                        return true;
                    }
            }

            return false;
        };

        /** Scrolls the list to show an item.
        * @param {pca.Item} item - The item to scroll to. */
        list.scrollToItem = function (item) {
            list.scroll.position = list.element.scrollTop;

            if (item.element.offsetTop < list.scroll.position) {
                list.scroll.position = item.element.offsetTop;
                list.setScroll(list.scroll.position);
            }
            else {
                if (item.element.offsetTop + item.element.offsetHeight > list.scroll.position + list.element.offsetHeight) {
                    list.scroll.position = item.element.offsetTop + item.element.offsetHeight - list.element.offsetHeight;
                    list.setScroll(list.scroll.position);
                }
            }

            return list;
        }

        /** Filters the list item collection.
        * @param {string} term - The term to filter the items on.
        * @fires filter */
        list.filter = function (term) {
            var current = list.collection.count;

            list.collection.filter(term);
            list.markItems();

            if (current !== list.collection.count)
                list.fire("filter", term);

            return list;
        }

        /** Calculates the height of the based on minItems, maxItems and item size.
        * @returns {number} The height required in pixels. */
        list.getHeight = function () {
            var visibleItems = list.collection.visibleItems(),
                headerItemHeight = list.headerItem ? pca.getSize(list.headerItem.element).height : 0,
                footerItemHeight = list.footerItem ? pca.getSize(list.footerItem.element).height : 0,
                lastItemHeight = 0,
                itemsHeight = 0;

            //count the height of items in the list
            for (var i = 0; i < visibleItems.length && i < list.options.maxItems; i++) {
                lastItemHeight = pca.getSize(visibleItems[i].element).height;
                itemsHeight += lastItemHeight;
            }

            //calculate the height of blank space required to keep the list height - assumes the last item has no bottom border
            if (visibleItems.length < list.options.minItems)
                itemsHeight += (lastItemHeight + 1) * (list.options.minItems - visibleItems.length);

            return itemsHeight + headerItemHeight + footerItemHeight;
        }

        /** Sizes the list based upon the maximum number of items. */
        list.resize = function () {
            var height = list.getHeight();

            if (height > 0)
                list.element.style.height = height + "px";
        }

        //Create an item for the list which is not in the main collection
        function createListItem(data, format, callback) {
            var item = new pca.Item(data, format);

            item.listen("mouseover", function () {
                list.collection.highlight(item);
                item.highlight();
            });

            list.collection.listen("highlight", item.lowlight);

            item.listen("select", function (selectedItem) {
                list.collection.fire("select", selectedItem);
                callback(selectedItem);
            });

            return item;
        }

        /** Adds an item to the list which will always appear at the bottom. */
        list.setHeaderItem = function (data, format, callback) {
            list.headerItem = createListItem(data, format, callback);
            pca.addClass(list.footerItem.element, "pcaheaderitem");
            list.markItems();
            return list;
        }

        /** Adds an item to the list which will always appear at the bottom. */
        list.setFooterItem = function (data, format, callback) {
            list.footerItem = createListItem(data, format, callback);
            pca.addClass(list.footerItem.element, "pcafooteritem");
            list.markItems();
            return list;
        }

        //store the current highlighted item
        list.collection.listen("highlight", function (item) {
            list.highlightedItem = item;
        });

        //Map collection events
        list.collection.listen("add", function (additions) {
            list.markItems();
            list.fire("add", additions);
        });

        //ARIA support
        pca.setAttributes(list.element, { id: list.options.name, role: "listbox", "aria-activedescendant": "" });
        if (list.options.ariaLabel) {
            pca.setAttributes(list.element, { "aria-label": list.options.ariaLabel });
        }

        list.collection.listen("add", function (additions) {

            function listenHighlightChange(item) {
                item.listen("highlight", function () {
                    pca.setAttributes(list.element, { "aria-activedescendant": item.id });
                });
            }

            for (var i = 0; i < additions.length; i++)
                listenHighlightChange(additions[i]);

            list.collection.all(function (item, index) {
                item.element.id = item.id = list.options.name + "_item" + index;
                pca.setAttributes(item.element, { role: "option" });
            });
        });

        return list;
    }

    /**
    * Autocomplete list options.
    * @typedef {Object} pca.AutoComplete.Options
    * @property {string} [name] - A reference for the list used an Id for ARIA.
    * @property {string} [className] - An additional class to add to the autocomplete.
    * @property {boolean} [force] - Forces the list to bind to the fields.
    * @property {boolean} [onlyDown] - Force the list to only open downwards.
    * @property {number|string} [width] - Fixes the width to the specified number of pixels.
    * @property {number|string} [height] - Fixes the height to the specified number of pixels.
    * @property {number|string} [left] - Shifts the list left by the specified number of pixels.
    * @property {number|string} [top] - Shifts the list left by the specified number of pixels.
    * @property {string} [emptyMessage] - When set an empty list will show this message rather than hiding after a filter.
    */

    /** Creates an autocomplete list which is bound to a field.
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {Array.<HTMLElement>} fields - A list of input elements to bind to.
    * @param {pca.AutoComplete.Options} [options] - Additional options to apply to the autocomplete list. */
    pca.AutoComplete = pca.AutoComplete || function (fields, options) {
        /** @lends pca.AutoComplete.prototype */
        var autocomplete = new pca.Eventable(this);

        autocomplete.options = options || {};
        autocomplete.options.force = autocomplete.options.force || false;
        autocomplete.options.allowTab = autocomplete.options.allowTab || false;
        autocomplete.options.onlyDown = autocomplete.options.onlyDown || false;
        /** The parent HTML element for the autocomplete list. */
        autocomplete.element = pca.create("div", { className: "pcaautocomplete pcatext" });
        autocomplete.anchors = [];
        /** The parent list object.
        * @type {pca.List} */
        autocomplete.list = new pca.List(autocomplete.options);
        autocomplete.fieldListeners = [];
        /** The current field that the autocomplete is bound to. */
        autocomplete.field = null;
        autocomplete.positionField = null;
        /** The visibility state of the autocomplete list.
        * @type {boolean} */
        autocomplete.visible = true;
        autocomplete.hover = false;
        autocomplete.focused = false;
        autocomplete.upwards = false;
        autocomplete.controlDown = false;
        autocomplete.altDown = false;
        /** The disabled state of the autocomplete list.
        * @type {boolean} */
        autocomplete.disabled = false;
        autocomplete.fixedWidth = false;
        /** When set an empty list will show this message rather than hiding after a filter.
        * @type {string} */
        autocomplete.emptyMessage = autocomplete.options.emptyMessage || "";
        /** When enabled list will not redraw as the user types, but filter events will still be raised.
        * @type {boolean} */
        autocomplete.skipFilter = false;
        /** Won't show the list, but it will continue to fire events in the same way. */
        autocomplete.stealth = false;

        function documentClicked() {
            autocomplete.checkHide();
        }

        function windowResized() {
            autocomplete.resize();
        }

        /** Header element. */
        autocomplete.header = {
            element: pca.create("div", { className: "pcaheader" }),
            headerText: pca.create("div", { className: "pcamessage" }),

            init: function () {
                this.hide();
            },

            setContent: function (content) {
                content = content || "";
                typeof content == 'string' ? this.element.innerHTML = content : this.element.appendChild(content);
                autocomplete.fire("header");
                return this;
            },

            setText: function (text) {
                text = text || "";
                this.element.appendChild(this.headerText);

                if (typeof text == 'string') {
                    pca.clear(this.headerText);
                    this.headerText.appendChild(pca.create("span", { className: "pcamessageicon" }));
                    this.headerText.appendChild(pca.create("span", { innerHTML: text }));
                }
                else this.headerText.appendChild(text);

                autocomplete.fire("header");
                return this;
            },

            clear: function () {
                this.setContent();
                autocomplete.fire("header");
                return this;
            },

            show: function () {
                this.element.style.display = "";
                autocomplete.fire("header");
                return this;
            },

            hide: function () {
                this.element.style.display = "none";
                autocomplete.fire("header");
                return this;
            }
        }

        /** Footer element. */
        autocomplete.footer = {
            element: pca.create("div", { className: "pcafooter" }),

            init: function () {
                this.hide();
            },

            setContent: function (content) {
                content = content || "";
                typeof content == 'string' ? this.element.innerHTML = content : this.element.appendChild(content);
                autocomplete.fire("footer");
                return this;
            },

            show: function () {
                this.element.style.display = "";
                autocomplete.fire("footer");
                return this;
            },

            hide: function () {
                this.element.style.display = "none";
                autocomplete.fire("footer");
                return this;
            }
        }

        /** Attaches the list to field or list of fields provided. */
        autocomplete.load = function () {

            if (fields.length && fields.constructor === Array) {
                for (var i = 0; i < fields.length; i++)
                    autocomplete.attach(pca.getElement(fields[i]));
            }
            else
                autocomplete.attach(pca.getElement(fields));

            pca.listen(autocomplete.element, "mouseover", function () { autocomplete.hover = true; });
            pca.listen(autocomplete.element, "mouseout", function () { autocomplete.hover = false; });

            //page events
            pca.listen(document, "click", documentClicked);
            pca.listen(window, "resize", windowResized);

            if ((document.documentMode && document.documentMode <= 7) || (/\bMSIE\s(7|6)/).test(pca.agent))
                autocomplete.setWidth(280);

            if (document.documentMode && document.documentMode <= 5) {
                pca.applyStyleFixes(".pca .pcafooter", { fontSize: "0pt" });
                pca.applyStyleFixes(".pca .pcaflag", { fontSize: "0pt" });
            }

            return autocomplete;
        }

        /** Attaches the list to a field.
        * @param {HTMLElement} field - The field to attach to. */
        autocomplete.attach = function (field) {

            function bindFieldEvent(f, event, action) {
                pca.listen(f, event, action);
                autocomplete.fieldListeners.push({ field: f, event: event, action: action });
            }

            function anchorToField(f) {
                var anchor = pca.create("table", { className: "pca pcaanchor", cellPadding: 0, cellSpacing: 0 }),
                    chain = [anchor.insertRow(0).insertCell(0), anchor.insertRow(1).insertCell(0)],
                    link = pca.create("div", { className: "pcachain" });

                function focus() {
                    link.appendChild(autocomplete.element);
                    autocomplete.focus(f);
                }

                //check the field
                if (!f || !f.tagName) {
                    pca.append(autocomplete.element);
                    return;
                }

                f.parentNode.insertBefore(anchor, f);
                chain[0].appendChild(f);
                chain[1].appendChild(link);
                autocomplete.anchors.push(anchor);

                if (pca.inputField(f)) {
                    bindFieldEvent(f, "keyup", autocomplete.keyup);
                    bindFieldEvent(f, "keydown", function (evt) {
                        autocomplete.keydown(evt, f);
                    });
                    bindFieldEvent(f, "keypress", autocomplete.keypress);
                    bindFieldEvent(f, "paste", autocomplete.paste);

                    // ReSharper disable once ConditionIsAlwaysConst
                    // IE9 bug when running within iframe
                    if (typeof document.activeElement != "unknown" && f === document.activeElement) focus();
                }

                bindFieldEvent(f, "click", function () { autocomplete.click(f); });
                bindFieldEvent(f, "dblclick", function () { autocomplete.dblclick(f); });
                bindFieldEvent(f, "change", function () { autocomplete.change(f); });
            }

            function positionAdjacentField(f) {
                function focus() {
                    autocomplete.focus(f);
                }

                pca.append(autocomplete.element);

                //check the field
                if (!f || !f.tagName) return;

                if (pca.inputField(f)) {
                    bindFieldEvent(f, "keyup", autocomplete.keyup);
                    bindFieldEvent(f, "keydown", function (evt) {
                        autocomplete.keydown(evt, f);
                    });
                    bindFieldEvent(f, "keypress", autocomplete.keypress);
                    bindFieldEvent(f, "paste", autocomplete.paste);

                    // ReSharper disable once ConditionIsAlwaysConst
                    // IE9 bug when running within iframe
                    if (typeof document.activeElement != "unknown" && f === document.activeElement) focus();
                }

                bindFieldEvent(f, "click", function () { autocomplete.click(f); });
                bindFieldEvent(f, "dblclick", function () { autocomplete.dblclick(f); });
                bindFieldEvent(f, "change", function () { autocomplete.change(f); });
            }

            autocomplete.options.force ? anchorToField(field) : positionAdjacentField(field);
        }

        /** Positions the autocomplete.
        * @param {HTMLElement} field - The field to position the list under. */
        autocomplete.position = function (field) {

            var fieldPosition = pca.getPosition(field),
                fieldSize = pca.getSize(field),
                topParent = pca.getTopOffsetParent(field),
                parentScroll = pca.getParentScroll(field),
                listSize = pca.getSize(autocomplete.element),
                windowSize = pca.getSize(window),
                windowScroll = pca.getScroll(window),
                fixed = !pca.isPage(topParent);

            //check where there is space to open the list
            var hasSpaceBelow = (fieldPosition.top + listSize.height - (fixed ? 0 : windowScroll.top)) < windowSize.height,
                hasSpaceAbove = (fieldPosition.top - (fixed ? 0 : windowScroll.top)) > listSize.height;

            //should the popup open upwards
            autocomplete.upwards = !hasSpaceBelow && hasSpaceAbove && !autocomplete.options.onlyDown;

            if (autocomplete.upwards) {
                if (autocomplete.options.force) {
                    autocomplete.element.style.top = -(listSize.height + fieldSize.height + 2) + "px";
                }
                else {
                    autocomplete.element.style.top = (fieldPosition.top - parentScroll.top - listSize.height) + (fixed ? windowScroll.top : 0) + "px";
                    autocomplete.element.style.left = (fieldPosition.left - parentScroll.left) + (fixed ? windowScroll.left : 0) + "px";
                }
            }
            else {
                if (autocomplete.options.force)
                    autocomplete.element.style.top = "auto";
                else {
                    autocomplete.element.style.top = ((fieldPosition.top - parentScroll.top) + fieldSize.height + 1) + (fixed ? windowScroll.top : 0) + "px";
                    autocomplete.element.style.left = (fieldPosition.left - parentScroll.left) + (fixed ? windowScroll.left : 0) + "px";
                }
            }

            if (autocomplete.options.left) autocomplete.element.style.left = (parseInt(autocomplete.element.style.left) + parseInt(autocomplete.options.left)) + "px";
            if (autocomplete.options.top) autocomplete.element.style.top = (parseInt(autocomplete.element.style.top) + parseInt(autocomplete.options.top)) + "px";

            var ownBorderWidth = (parseInt(pca.getStyle(autocomplete.element, "borderLeftWidth")) + parseInt(pca.getStyle(autocomplete.element, "borderRightWidth"))) || 0,
                preferredWidth = Math.max((pca.getSize(field).width - ownBorderWidth), 0);

            //set minimum width for field
            if (!autocomplete.fixedWidth) {
                autocomplete.element.style.minWidth = preferredWidth + "px";
                //recalculate the maxwidth for autocomplete control to support mobile friendly
                if (window.innerWidth < 767) {
                    var bbox = autocomplete.element.getBoundingClientRect();
                    autocomplete.element.style.maxWidth = "calc(100vw - " + (bbox.left + 10) + "px";
                }
            }

            //fix the size when there is no support for minimum width
            if ((document.documentMode && document.documentMode <= 7) || (/\bMSIE\s(7|6)/).test(pca.agent)) {
                autocomplete.setWidth(Math.max(preferredWidth, 280));
                autocomplete.element.style.left = ((parseInt(autocomplete.element.style.left) || 0) - 2) + "px";
                autocomplete.element.style.top = ((parseInt(autocomplete.element.style.top) || 0) - 2) + "px";
            }

            autocomplete.positionField = field;
            autocomplete.fire("move");

            return autocomplete;
        }

        /** Positions the list under the last field it was positioned to. */
        autocomplete.reposition = function () {
            if (autocomplete.positionField) autocomplete.position(autocomplete.positionField);
            return autocomplete;
        }

        /** Sets the value of input field to prompt the user.
        * @param {string} text - The text to show.
        * @param {number} [position] - The index at which to set the carat. */
        autocomplete.prompt = function (text, position) {
            if (typeof position == "number") {
                //insert space
                if (position === 0)
                    text = " " + text;
                else if (position >= text.length) {
                    text = text + " ";
                    position++;
                }
                else {
                    text = text.substring(0, position) + "  " + text.substring(position, text.length);
                    position++;
                }

                pca.setValue(autocomplete.field, text);

                if (autocomplete.field.setSelectionRange) {
                    autocomplete.field.focus();
                    autocomplete.field.setSelectionRange(position, position);
                }
                else if (autocomplete.field.createTextRange) {
                    var range = autocomplete.field.createTextRange();
                    range.move('character', position);
                    range.select();
                }
            }
            else
                pca.setValue(autocomplete.field, text);

            return autocomplete;
        }

        /** Shows the autocomplete.
        * @fires show */
        autocomplete.show = function () {
            if (!autocomplete.disabled && !autocomplete.stealth) {
                autocomplete.visible = true;
                autocomplete.element.style.display = "";
                //announce aria if more than 3 chars
                if (autocomplete.field.value.length > 2) {
                    var lang = autocomplete.options.language || "en";
                    var isCountryList =
                        autocomplete.options &&
                        autocomplete.options.type &&
                        autocomplete.options.type === "countrylist";
                    pca.read(
                        autocomplete.list.collection.count +
                        " " +
                        (autocomplete.list.collection.count == 1
                            ? isCountryList
                                ? pca.messages[lang].COUNTRYAVAILABLE
                                : pca.messages[lang].ADDRESSAVAILABLE
                            : isCountryList
                                ? pca.messages[lang].COUNTRIESAVAILABLE
                                : pca.messages[lang].ADDRESSESAVAILABLE)
                    );
                }
                //deal with empty list
                if (!autocomplete.list.collection.count) {
                    if (autocomplete.options.emptyMessage)
                        autocomplete.header.setText(autocomplete.options.emptyMessage).show();

                    autocomplete.list.hide();
                }
                else {
                    if (autocomplete.options.emptyMessage)
                        autocomplete.header.clear().hide();

                    autocomplete.list.show();
                }

                autocomplete.setScroll(0);
                autocomplete.reposition();
                autocomplete.fire("show");
                autocomplete.exitEvent = document.addEventListener("click", autocomplete.externalClickHandler);
            }
            return autocomplete;
        }

        autocomplete.externalClickHandler = function (evt) {
            if (!pca.closestElement(event.target, '.pca')) { autocomplete.hide(); }
        }

        /** Shows the autocomplete and all items without a filter. */
        autocomplete.showAll = function () {
            autocomplete.list.filter("");
            autocomplete.show();
        }

        /** Hides the autocomplete.
        * @fires hide */
        autocomplete.hide = function () {
            autocomplete.visible = false;
            autocomplete.element.style.display = "none";
            autocomplete.fire("hide");
            document.removeEventListener("click", autocomplete.externalClickHandler);
            return autocomplete;
        }

        /** Shows the autocomplete list under a field.
        * @param {HTMLElement} field - The field to show the list under.
        * @fires focus */
        autocomplete.focus = function (field) {
            autocomplete.field = field;
            autocomplete.focused = true;
            autocomplete.show();
            autocomplete.position(field);
            autocomplete.fire("focus");
        }

        /** Hides the list unless it has field or mouse focus */
        autocomplete.checkHide = function () {
            if (autocomplete.visible && !autocomplete.focused && !autocomplete.hover)
                autocomplete.hide();

            return autocomplete;
        }

        /** Handles a keyboard key.
        * @param {number} key - The keyboard key code to handle.
        * @param {Event} [event] - The original event to cancel if required.
        * @fires keyup */
        autocomplete.handleKey = function (key, event) {
            if (key === 27 || key === 9) {
                //escape
                autocomplete.hide();
                autocomplete.fire("escape");
            } else if (key === 17 || key === 91) {
                //ctrl
                autocomplete.controlDown = false;
            } else if (key === 18) {
                autocomplete.altDown = false;
            } else if (key === 16) {
                autocomplete.shiftDown = false;
            } else if (key === 8 || key === 46) {
                //del or backspace
                autocomplete.filter();
                autocomplete.fire("delete");
            } else if (key !== 0 && key <= 46 && key !== 32) {
                //recognised non-character key
                if (key !== 38) {
                    //do nothing on up with focus in field
                    if (autocomplete.visible && autocomplete.list.navigate(key, true)) {
                        if (event) pca.smash(event); //keys handled by the list, stop other events
                    } else if (key === 40) {
                        //up or down when list is hidden
                        autocomplete.filter();
                    }
                }
            } else if (autocomplete.visible) {
                //normal key press when list is visible
                autocomplete.filter();
            }
            autocomplete.fire("keyup", key);
        };

        //keydown event handler
        autocomplete.keydown = function (event, field) {
            if (event.keyCode == 9) {
                autocomplete.hide();
            } else {
                if (!autocomplete.visible) {
                    autocomplete.focus(field);
                }
                event = event || window.event;
                var key = event.which || event.keyCode;
                if (key === 17 || key === 91) {
                    autocomplete.controlDown = true;
                } else if (key === 16) {
                    autocomplete.shiftDown = true;
                } else if (key === 18) {
                    autocomplete.altDown = true;
                } else if (
                    key === 67 &&
                    autocomplete.shiftDown &&
                    autocomplete.controlDown
                ) {
                    if (autocomplete.address) {
                        event.preventDefault();
                        autocomplete.address.switchToCountrySelect();
                    }
                }
            }
        };

        //keyup event handler
        autocomplete.keyup = function (event) {
            event = event || window.event;
            var key = event.which || event.keyCode;
            autocomplete.handleKey(key, event);
        }

        //keypress event handler
        autocomplete.keypress = function (event) {
            var key = window.event ? window.event.keyCode : event.which;

            if (autocomplete.visible && key === 13 && autocomplete.list.selectable())
                pca.smash(event);
        }

        //paste event handler
        autocomplete.paste = function () {
            window.setTimeout(function () {
                autocomplete.filter();
                autocomplete.fire("paste");
            }, 0);
        }

        /** Handles user clicks on field.
        * @fires click */
        autocomplete.click = function (f) {
            autocomplete.fire("click", f);
        }

        /** Handles user double clicks on the field.
        * @fires dblclick */
        autocomplete.dblclick = function (f) {
            autocomplete.fire("dblclick", f);
        }

        /** Handles field value change.
        * @fires change */
        autocomplete.change = function (f) {
            autocomplete.fire("change", f);
        }

        /** Handles page resize.
        * @fires change */
        autocomplete.resize = function () {
            if (autocomplete.visible) autocomplete.reposition();
        }

        /** Add items to the autocomplete list.
        * @param {Array.<Object>} array - An array of data objects to add as items.
        * @param {string} format - A format string to display items.
        * @param {function} callback - A callback function for item select. */
        autocomplete.add = function (array, format, callback) {
            autocomplete.list.add(array, format, callback);

            return autocomplete;
        }

        /** Clears the autocomplete list. */
        autocomplete.clear = function () {
            autocomplete.list.clear();

            return autocomplete;
        }

        /** Sets the scroll position of the autocomplete list. */
        autocomplete.setScroll = function (position) {
            autocomplete.list.setScroll(position);

            return autocomplete;
        }

        /** Sets the width of the autocomplete list.
        * @param {number|string} width - The width in pixels for the list. */
        autocomplete.setWidth = function (width) {
            if (typeof width == "number") {
                width = Math.max(width, 220);
                autocomplete.element.style.width = width + "px";
                if (document.documentMode && document.documentMode <= 5) width -= 2;
                autocomplete.list.element.style.width = width + "px";
            } else {
                autocomplete.element.style.width = width;
                autocomplete.list.element.style.width = width;
            }

            autocomplete.fixedWidth = (width !== "auto");
            autocomplete.element.style.minWidth = 0;

            return autocomplete;
        }

        /** Sets the height of the autocomplete list.
        * @param {number|string} height - The height in pixels for the list. */
        autocomplete.setHeight = function (height) {
            if (typeof height == "number")
                autocomplete.list.element.style.height = height + "px";
            else
                autocomplete.list.element.style.height = height;

            return autocomplete;
        }

        /** Filters the autocomplete list for items matching the supplied term.
        * @param {string} term - The term to search for. Case insensitive.
        * @fires filter */
        autocomplete.filter = function (term) {
            term = term || pca.getValue(autocomplete.field);

            if (autocomplete.skipFilter) {
                if (autocomplete.list.collection.match(term).length < autocomplete.list.collection.count)
                    autocomplete.list.fire("filter");
            }
            else {
                autocomplete.list.filter(term, autocomplete.skipFilter);
                term && !autocomplete.list.collection.count && !autocomplete.skipFilter && !autocomplete.options.emptyMessage ? autocomplete.hide() : autocomplete.show();
            }

            autocomplete.fire("filter", term);

            return autocomplete;
        }

        /** Disables the autocomplete. */
        autocomplete.disable = function () {
            autocomplete.disabled = true;

            return autocomplete;
        }

        /** Enables the autocomplete when disabled. */
        autocomplete.enable = function () {
            autocomplete.disabled = false;

            return autocomplete;
        }

        /** Removes the autocomplete elements and event listeners from the page. */
        autocomplete.destroy = function () {
            pca.remove(autocomplete.element);

            //stop listening to page events
            pca.ignore(document, "click", documentClicked);
            pca.ignore(window, "resize", windowResized);

            for (var i = 0; i < autocomplete.fieldListeners.length; i++)
                pca.ignore(autocomplete.fieldListeners[i].field, autocomplete.fieldListeners[i].event, autocomplete.fieldListeners[i].action);
        }

        autocomplete.element.appendChild(autocomplete.header.element);
        autocomplete.element.appendChild(autocomplete.list.element);
        autocomplete.element.appendChild(autocomplete.footer.element);
        autocomplete.header.init();
        autocomplete.footer.init();

        if (fields) autocomplete.load(fields);
        if (autocomplete.options.width) autocomplete.setWidth(autocomplete.options.width);
        if (autocomplete.options.height) autocomplete.setHeight(autocomplete.options.height);
        if (autocomplete.options.className) pca.addClass(autocomplete.element, autocomplete.options.className);

        if (!autocomplete.field)
            autocomplete.hide();

        return autocomplete;
    }

    /**
    * Modal window options.
    * @typedef {Object} pca.Modal.Options
    * @property {string} [title] - The title text for the window.
    * @property {string} [titleStyle] - The CSS text to apply to the title.
    */

    /** Creates a modal popup window.
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {pca.Modal.Options} [options] - Additional options to apply to the modal window. */
    pca.Modal = pca.Modal || function (options) {
        /** @lends pca.Modal.prototype */
        var modal = new pca.Eventable(this);

        modal.options = options || {};

        /** The parent HTML element of the modal window */
        modal.element = pca.create("div", { className: "pcamodal" });
        modal.border = pca.create("div", { className: "pcaborder" });
        modal.frame = pca.create("div", { className: "pcaframe" });
        modal.content = pca.create("div", { className: "pcacontent pcatext" });
        modal.mask = pca.create("div", { className: "pcafullscreen pcamask" });
        modal.form = [];

        /** Header element. */
        modal.header = {
            element: pca.create("div", { className: "pcaheader" }),
            headerText: pca.create("div", { className: "pcatitle" }, modal.options.titleStyle || ""),

            init: function () {
                this.setText(modal.options.title || "");
            },

            setContent: function (content) {
                content = content || "";
                typeof content == 'string' ? this.element.innerHTML = content : this.element.appendChild(content);
                modal.fire("header");
                return this;
            },

            setText: function (text) {
                text = text || "";
                this.element.appendChild(this.headerText);
                typeof text == 'string' ? this.headerText.innerHTML = text : this.headerText.appendChild(text);
                modal.fire("header");
                return this;
            },

            show: function () {
                this.element.style.display = "";
                modal.fire("header");
                return this;
            },

            hide: function () {
                this.element.style.display = "none";
                modal.fire("header");
                return this;
            }
        }

        /** Footer element */
        modal.footer = {
            element: pca.create("div", { className: "pcafooter" }),

            setContent: function (content) {
                content = content || "";
                typeof content == 'string' ? this.element.innerHTML = content : this.element.appendChild(content);
                modal.fire("footer");
                return this;
            },

            show: function () {
                this.element.style.display = "";
                modal.fire("header");
                return this;
            },

            hide: function () {
                this.element.style.display = "none";
                modal.fire("header");
                return this;
            }
        }

        /** Shortcut to set the content of the modal title and show it.
        * @param {string|HTMLElement} content - The content to set in the title. */
        modal.setTitle = function (content) {
            modal.header.setText(content).show();
        }

        /** Sets the content of the modal window.
        * @param {string|HTMLElement} content - The content to set in the body of the modal.
        * @fires change */
        modal.setContent = function (content) {
            typeof content == 'string' ? modal.content.innerHTML = content : modal.content.appendChild(content);
            modal.fire("change");

            return modal;
        }

        //sets defaults for a field
        function defaultProperties(properties) {
            properties = properties || {};
            properties.type = properties.type || "text";
            return properties;
        }

        /** Adds a new field to the modal content.
        * @param {string} labelText - The text for the field label.
        * @param {Object} [properties] - Properties to set on the input field.
        * @param {Object} [properties.tag=input] - Changes the type of element to create.
        * @param {HTMLElement} The HTML field created. */
        modal.addField = function (labelText, properties) {
            properties = defaultProperties(properties);

            var row = pca.create("div", { className: "pcainputrow" }),
                input = pca.create(properties.tag || "input", properties),
                label = pca.create("label", { htmlFor: input.id || "", innerHTML: labelText || "" });

            row.appendChild(label);
            row.appendChild(input);
            modal.setContent(row);

            modal.form.push({ label: labelText, element: input });

            return input;
        }

        /** Adds two half width fields to the modal content.
        * @param {string} labelText - The text for the field label.
        * @param {Object} [firstProperties] - Properties to set on the first (left) input field.
        * @param {Object} [firstProperties.tag] - Changes the type of element to create.
        * @param {Object} [secondProperties] - Properties to set on the second (right) input field.
        * @param {Object} [secondProperties.tag] - Changes the type of element to create.
        * @return {Array.<HTMLElement>} The two HTML fields created. */
        modal.addHalfFields = function (labelText, firstProperties, secondProperties) {
            firstProperties = defaultProperties(firstProperties);
            secondProperties = defaultProperties(secondProperties);

            var row = pca.create("div", { className: "pcainputrow" }),
                firstInput = pca.create(firstProperties.tag || "input", firstProperties),
                secondInput = pca.create(secondProperties.tag || "input", secondProperties),
                label = pca.create("label", { htmlFor: firstInput.id || "", innerHTML: labelText || "" });

            pca.addClass(firstInput, "pcahalf");
            pca.addClass(secondInput, "pcahalf");

            row.appendChild(label);
            row.appendChild(firstInput);
            row.appendChild(secondInput);
            modal.setContent(row);

            modal.form.push({ label: "First " + labelText, element: firstInput });
            modal.form.push({ label: "Second " + labelText, element: secondInput });

            return [firstInput, secondInput];
        }

        /** Adds a button to the modal footer.
        * @param {string} labelText - The text for the field label.
        * @param {function} callback - A callback function which handles the button click.
        * @param {boolean} floatRight - Sets float:right on the button. Ignored by versions of IE older than 8.
        * @returns {HTMLElement} The HTML input element created. */
        modal.addButton = function (labelText, callback, floatRight) {
            var button = pca.create("input", { type: "button", value: labelText, className: "pcabutton" });

            callback = callback || function () { };

            //call the callback function with the form details
            function click() {
                var details = {};

                for (var i = 0; i < modal.form.length; i++)
                    details[modal.form[i].label] = pca.getValue(modal.form[i].element);

                callback(details);
            }

            if (floatRight && !(document.documentMode && document.documentMode <= 7))
                button.style.cssFloat = "right";

            pca.listen(button, "click", click);
            modal.footer.setContent(button);

            return button;
        }

        /** Centres the modal in the browser window */
        modal.centre = function () {
            var modalSize = pca.getSize(modal.element);

            modal.element.style.marginTop = -(modalSize.height / 2) + "px";
            modal.element.style.marginLeft = -(modalSize.width / 2) + "px";

            return modal;
        }

        /** Shows the modal window.
        * @fires show */
        modal.show = function () {
            //not supported in quirks mode or ie6 currently
            if (!(document.documentMode && document.documentMode <= 5) && !(/\bMSIE\s6/).test(pca.agent)) {
                modal.element.style.display = "";
                modal.mask.style.display = "";
                modal.centre();
                modal.fire("show");
            }

            return modal;
        }

        /** Hides the modal window.
        * @fires hide */
        modal.hide = function () {
            modal.element.style.display = "none";
            modal.mask.style.display = "none";
            modal.fire("hide");

            return modal;
        }

        /** Clears the content and buttons of the modal window.
        * @fires clear */
        modal.clear = function () {
            while (modal.content.childNodes.length)
                modal.content.removeChild(modal.content.childNodes[0]);

            while (modal.footer.element.childNodes.length)
                modal.footer.element.removeChild(modal.footer.element.childNodes[0]);

            modal.form = [];
            modal.fire("clear");

            return modal;
        }

        pca.listen(modal.mask, "click", modal.hide);

        modal.element.appendChild(modal.border);
        modal.element.appendChild(modal.frame);
        modal.frame.appendChild(modal.header.element);
        modal.frame.appendChild(modal.content);
        modal.frame.appendChild(modal.footer.element);
        modal.header.init();

        pca.append(modal.mask);
        pca.append(modal.element);

        modal.hide();

        return modal;
    }

    /** Creates a helpful tooltip when hovering over an element.
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {HTMLElement} element - The element to bind to.
    * @param {string} message - The text to show. */
    pca.Tooltip = pca.Tooltip || function (element, message) {
        /** @lends pca.Tooltip.prototype */
        var tooltip = new pca.Eventable(this);

        /** The parent HTML element for the tooltip. */
        tooltip.element = pca.create("div", { className: "pcatooltip" });
        tooltip.background = pca.create("div", { className: "pcabackground" });
        tooltip.message = pca.create("div", { className: "pcamessage", innerText: message });

        /** Shows the tooltip.
        * @fires show */
        tooltip.show = function () {
            tooltip.element.style.display = "";
            tooltip.position();
            tooltip.fire("show");
            return tooltip;
        }

        /** Hides the tooltip.
        * @fires hide */
        tooltip.hide = function () {
            tooltip.element.style.display = "none";
            tooltip.fire("hide");
            return tooltip;
        }

        /** Sets the text for the tooltip.
        * @param {string} text - The text to set. */
        tooltip.setMessage = function (text) {
            pca.setValue(tooltip.message, text);
        }

        /** Positions the tooltip centrally above the element. */
        tooltip.position = function () {
            var parentPosition = pca.getPosition(element),
                parentSize = pca.getSize(element),
                topParent = pca.getTopOffsetParent(element),
                messageSize = pca.getSize(tooltip.message),
                windowSize = pca.getSize(window),
                windowScroll = pca.getScroll(window),
                fixed = !pca.isPage(topParent);

            var top = (parentPosition.top - messageSize.height - 5) + (fixed ? windowScroll.top : 0),
                left = (parentPosition.left + (parentSize.width / 2) - (messageSize.width / 2)) + (fixed ? windowScroll.left : 0);

            top = Math.min(top, (windowSize.height + windowScroll.top) - messageSize.height);
            top = Math.max(top, 0);

            left = Math.min(left, (windowSize.width + windowScroll.left) - messageSize.width);
            left = Math.max(left, 0);

            tooltip.element.style.top = top + "px";
            tooltip.element.style.left = left + "px";
        }

        if (element = pca.getElement(element)) {
            pca.listen(element, "mouseover", tooltip.show);
            pca.listen(element, "mouseout", tooltip.hide);
        }

        tooltip.element.appendChild(tooltip.background);
        tooltip.element.appendChild(tooltip.message);
        tooltip.setMessage(message);

        pca.append(tooltip.element);

        tooltip.hide();

        return tooltip;
    }

    /** Formats a line by replacing tags in the form {Property} with the corresponding property value or method result from the item object.
    * @memberof pca
    * @param {Object} item - An object to format the parameters of.
    * @param {string} format - A template format string.
    * @returns {string} The formatted text.
    * @example pca.formatLine({"line1": "Line One", "line2": "Line Two"}, "{line1}{, {line2}}");
    * @returns "Line One, Line Two" */
    pca.formatLine = pca.formatLine || function (item, format) {
        function property(c, t) {
            var val = (typeof item[c] == "function" ? item[c]() : item[c]) || "";
            return t === "!" ? val.toUpperCase() : val;
        }

        //replace properties with conditional formatting e.g. hello{ {name}!}
        format = format.replace(/\{([^\}]*\{(\w+)([^\}\w])?\}[^\}]*)\}/g, function (m, f, c, t) {
            var val = property(c, t);
            return val ? f.replace(/\{(\w+)([^\}\w])?\}/g, val) : "";
        });

        return format.replace(/\{(\w+)([^\}\w])?\}/g, function (m, c, t) { return property(c, t); });
    }

    /** Formats a line into a simplified tag for filtering.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {string} The formatted tag. */
    pca.formatTag = pca.formatTag || function (line) {
        return line ? pca.replaceList(pca.replaceList(pca.removeHtml(line.toUpperCase()), pca.diacritics), pca.synonyms) : "";
    }

    /** Formats a line into a tag and then separate words.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {Array.<string>} The formatted tag words. */
    pca.formatTagWords = pca.formatTagWords || function (line) {
        return pca.formatTag(line).split(" ");
    }

    /** Formats camaelcase text by inserting a separator string.
    * @memberof pca
    * @param {string} line - The text to format.
    * @param {string} [separator= ] - A string used to join the parts.
    * @returns {string} The formatted text. */
    pca.formatCamel = pca.formatCamel || function (line, separator) {
        separator = separator || " ";

        function separate(m, b, a) {
            return b + separator + a;
        }

        line = line.replace(/([a-z])([A-Z0-9])/g, separate); //before an upperase letter or number
        line = line.replace(/([0-9])([A-Z])/g, separate); //before an uppercase letter after a number
        line = line.replace(/([A-Z])([A-Z][a-z])/g, separate); //after multiple capital letters

        return line;
    }

    /** Performs all replacements in a list.
    * @memberof pca
    * @param {string} line - The text to format.
    * @param {Array.<Object>} list - The list of replacements.
    * @returns {string} The formatted text. */
    pca.replaceList = pca.replaceList || function (line, list) {
        for (var i = 0; i < list.length; i++)
            line = line.toString().replace(list[i].r, list[i].w);
        return line;
    }

    /** Removes HTML tags from a string.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {string} The formatted text. */
    pca.removeHtml = pca.removeHtml || function (line) {
        return line.replace(/<(?:.|\s)*?>+/g, "");
    }

    /** Converts a html string for display.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {string} The formatted text. */
    pca.escapeHtml = pca.escapeHtml || function (line) {
        return pca.replaceList(line, pca.hypertext);
    }

    /** Returns only the valid characters for a DOM id.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {string} The formatted text. */
    pca.validId = pca.validId || function (line) {
        return /[a-z0-9\-_:\.\[\]]+/gi.exec(line);
    }

    /** Removes unnecessary spaces.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {string} The formatted text. */
    pca.trimSpaces = pca.trimSpaces || function (line) {
        return line.replace(/^\s+|\s(?=\s)|\s$/g, "");
    }

    /** Removes unnecessary duplicated characters.
    * @memberof pca
    * @param {string} line - The text to format.
    * @param {string} symbol - The text to remove duplicates of.
    * @returns {string} The formatted text. */
    pca.tidy = pca.tidy || function (line, symbol) {
        symbol = symbol.replace("\\", "\\\\");
        var rx = new RegExp("^" + symbol + "+|" + symbol + "(?=" + symbol + ")|" + symbol + "$", "gi");
        return line.replace(rx, "");
    }

    /** Gets the first words from a string.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {string} The text. */
    pca.getText = pca.getText || function (line) {
        return /[a-zA-Z][a-zA-Z\s]+[a-zA-Z]/.exec(line);
    }

    /** Gets the first number from a string.
    * @memberof pca
    * @param {string} line - The text to format.
    * @returns {string} The number. */
    pca.getNumber = pca.getNumber || function (line) {
        return /\d+/.exec(line);
    }

    /** parse a JSON string if it's safe and return an object. This has a preference for the native parser.
    * @memberof pca
    * @param {string} text - The JSON text to parse.
    * @returns {Object} The object based on the JSON. */
    pca.parseJSON = pca.parseJSON || function (text) {
        if (text && (/^[\],:{}\s]*$/.test(text.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, '@')
            .replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']')
            .replace(/(?:^|:|,)(?:\s*\[)+/g, ''))))
            return (typeof JSON != 'undefined' ? JSON.parse(text) : eval(text));

        return {};
    }

    /** Parse a formatted JSON date.
    * @memberof pca
    * @param {string|number} text - The date in milliseconds.
    * @returns {Date} The date object. */
    pca.parseJSONDate = pca.parseJSONDate || function (text) {
        return new Date(parseInt(pca.getNumber(text)));
    }

    /** Checks if a string contains a word.
    * @memberof pca
    * @param {string} text - The text to test.
    * @param {string} word - The word to test for.
    * @returns {boolean} True if the text contains the word. */
    pca.containsWord = pca.containsWord || function (text, word) {
        var rx = new RegExp("\\b" + word + "\\b", "gi");
        return rx.test(text);
    }

    /** Removes a word from a string.
    * @memberof pca
    * @param {string} text - The text to format.
    * @param {string} word - The word to replace.
    * @returns {string} The text with the word replaced. */
    pca.removeWord = pca.removeWord || function (text, word) {
        var rx = new RegExp("\\s?\\b" + word + "\\b", "gi");
        return text.replace(rx, "");
    }

    /** Merges one objects properties into another
    * @memberof pca
    * @param {Object} source - The object to take properties from.
    * @param {Object} destination - The object to add properties to.
    * @returns {Object} The destination object. */
    pca.merge = pca.merge || function (source, destination) {
        for (var i in source)
            if (!destination[i]) destination[i] = source[i];

        return destination;
    }

    /** Find a DOM element by id, name, or partial id.
    * @memberof pca
    * @param {string|HTMLElement} reference - The id, name or element to find.
    * @param {string|HTMLElement} [base=document] - The id, name or parent element to search from.
    * @returns {?HTMLElement} The first element found or null. */
    pca.getElement = pca.getElement || function (reference, base) {
        if (!reference)
            return null;

        if (typeof reference.nodeType == "number") //Is a HTML DOM Node
            return reference;

        if (typeof reference == "string") {
            base = pca.getElement(base) || document;

            var byId = base.getElementById ? base.getElementById(reference) : null;
            if (byId) return byId;

            var byName = base.getElementsByName ? base.getElementsByName(reference) : null;
            if (byName.length) return byName[0];
        }

        //try a regex match if allowed
        return pca.fuzzyMatch ? pca.getElementByRegex(reference, base) : null;
    }

    pca.matches = pca.matches || function (element, selector) {
        if (typeof window.Element.prototype.matches === 'function') {
            return element.matches(selector);
        }
        var elements = (element.document || element.ownerDocument).querySelectorAll(selector);
        var index = 0;

        while (elements[index] && elements[index] !== element) {
            ++index;
        }

        return Boolean(elements[index]);
    }

    pca.closestElement = pca.closestElement || function (element, selector) {
        if (typeof window.Element.prototype.closest === 'function') {
            return element.closest(selector);
        }
        while (element && element.nodeType === 1) {
            if (pca.matches(element, selector)) {
                return element;
            }

            element = element.parentNode;
        }

        return null;
    }

    /** Retrieves a DOM element using RegEx matching on the id.
    * @memberof pca
    * @param {Regex|string} regex - The RegExp to test search element id for.
    * @param {string|HTMLElement} base - The id, name or parent element to search from.
    * @returns {HTMLElement} The first element found or null. */
    pca.getElementByRegex = pca.getElementByRegex || function (regex, base) {
        //compile and check regex strings
        if (typeof regex == 'string') {
            try { regex = new RegExp(regex); }
            catch (e) { return null; }
        }

        //make sure its a RegExp
        if (regex && typeof regex == "object" && regex.constructor === RegExp) {
            base = pca.getElement(base) || document;

            for (var t = 0; t < pca.fuzzyTags.length; t++) {
                var elements = base.getElementsByTagName(pca.fuzzyTags[t]);

                for (var i = 0; i < elements.length; i++) {
                    var elem = elements[i];
                    if (elem.id && regex.test(elem.id))
                        return elem;
                }
            }
        }

        return null;
    }

    /** Get the value of a DOM element.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to get the value of.
    * @returns {string} The value of the element. */
    pca.getValue = pca.getValue || function (element) {
        if (element = pca.getElement(element)) {
            if (element.tagName === "INPUT" || element.tagName === "TEXTAREA") {
                if (element.type === "checkbox")
                    return element.checked;
                else if (element.type === "radio") {
                    var group = document.getElementsByName(element.name);
                    for (var r = 0; r < group.length; r++) {
                        if (group[r].checked)
                            return group[r].value;
                    }
                }
                else
                    return element.value;
            }
            if (element.tagName === "SELECT") {
                if (element.selectedIndex < 0) return "";
                var selectedOption = element.options[element.selectedIndex];
                return selectedOption.value || selectedOption.text || "";
            }
            if (element.tagName === "DIV" || element.tagName === "SPAN" || element.tagName === "TD" || element.tagName === "LABEL")
                return element.innerHTML;
        }

        return "";
    }

    /** Set the value of a DOM element.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to set the value of.
    * @param {*} value - The value to set. */
    pca.setValue = pca.setValue || function (element, value) {
        if ((value || value === "") && (element = pca.getElement(element))) {
            var valueText = value.toString(),
                valueTextMatch = pca.formatTag(valueText);

            if (element.tagName === "INPUT") {
                if (element.type === "checkbox")
                    element.checked = ((typeof (value) == "boolean" && value) || valueTextMatch === "TRUE");
                else if (element.type === "radio") {
                    var group = document.getElementsByName(element.name);
                    for (var r = 0; r < group.length; r++) {
                        if (pca.formatTag(group[r].value) === valueTextMatch) {
                            group[r].checked = true;
                            return;
                        }
                    }
                }
                else
                    element.value = pca.tidy(valueText.replace(/\\n|\n/gi, ", "), ", ");
            }
            else if (element.tagName === "TEXTAREA")
                element.value = valueText.replace(/\\n|\n/gi, "\n");
            else if (element.tagName === "SELECT") {
                for (var s = 0; s < element.options.length; s++) {
                    if (pca.formatTag(element.options[s].value) === valueTextMatch || pca.formatTag(element.options[s].text) === valueTextMatch) {
                        element.selectedIndex = s;
                        return;
                    }
                }
            }
            else if (element.tagName === "DIV" || element.tagName === "SPAN" || element.tagName === "TD" || element.tagName === "LABEL")
                element.innerHTML = valueText.replace(/\\n|\n/gi, "<br/>");
        }
    }

    /** Returns true if the element is a text input field.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to check.
    * @returns {boolean} True if the element supports text input. */
    pca.inputField = pca.inputField || function (element) {
        if (element = pca.getElement(element))
            return (element.tagName && (element.tagName === "INPUT" || element.tagName === "TEXTAREA") && element.type && (element.type === "text" || element.type === "search" || element.type === "email" || element.type === "textarea" || element.type === "number" || element.type === "tel"));

        return false;
    }

    /** Returns true if the element is a select list field.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to check.
    * @returns {boolean} True if the element in a select list field. */
    pca.selectList = pca.selectList || function (element) {
        if (element = pca.getElement(element))
            return (element.tagName && element.tagName === "SELECT");

        return false;
    }

    pca.moveCursorToEnd = pca.moveCursorToEnd || function (el) {
        if (typeof el.selectionStart == "number") {
            el.selectionStart = el.selectionEnd = el.value.length;
        } else if (typeof el.createTextRange != "undefined") {
            el.focus();
            var range = el.createTextRange();
            range.collapse(false);
            range.select();
        }
    }

    /** Returns the current selected item of a select list field.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to check.
    * @returns {HTMLOptionElement} The current selected item. */
    pca.getSelectedItem = pca.getSelectedItem || function (element) {
        if ((element = pca.getElement(element)) && element.tagName === "SELECT" && element.selectedIndex >= 0)
            return element.options[element.selectedIndex];

        return null;
    }

    /** Returns true if the element is a checkbox.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to check.
    * @returns {boolean} True if the element in a checkbox. */
    pca.checkBox = pca.checkBox || function (element) {
        if (element = pca.getElement(element))
            return (element.tagName && element.tagName === "INPUT" && element.type && element.type === "checkbox");

        return false;
    }

    /** Shortcut to clear the value of a DOM element.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to clear. */
    pca.clear = pca.clear || function (element) {
        pca.setValue(element, "");
        return pca;
    }

    /** Get the position of a DOM element.
    * @memberof pca
    * @param {string|HTMLElement} element - The element to get the position of.
    * @returns {Object} The top and left of the position. */
    pca.getPosition = pca.getPosition || function (element) {
        var empty = { left: 0, top: 0 };

        if (element = pca.getElement(element)) {
            if (!element.tagName) return empty;

            if (typeof element.getBoundingClientRect != 'undefined') {
                var bb = element.getBoundingClientRect(),
                    fixed = !pca.isPage(pca.getTopOffsetParent(element)),
                    pageScroll = pca.getScroll(window),
                    parentScroll = pca.getParentScroll(element);
                return { left: bb.left + parentScroll.left + (fixed ? 0 : pageScroll.left), top: bb.top + parentScroll.top + (fixed ? 0 : pageScroll.top) };
            }

            var x = 0, y = 0;

            do {
                x += element.offsetLeft;
                y += element.offsetTop;
            } while (element = element.offsetParent);

            return { left: x, top: y };
        }

        return empty;
    }

    //Is the element the document or window.
    pca.isPage = pca.isPage || function (element) {
        return element === window || element === document || element === document.body;
    }

    /** Gets the scroll values from an elements top offset parent.
    * @memberof pca
    * @param {HTMLElement} element - The element to get the scroll of.
    * @returns {Object} The top and left of the scroll. */
    pca.getScroll = pca.getScroll || function (element) {
        return {
            left: parseInt(element.scrollX || element.scrollLeft, 10) || (pca.isPage(element) ? parseInt(document.documentElement.scrollLeft) || 0 : 0),
            top: parseInt(element.scrollY || element.scrollTop, 10) || (pca.isPage(element) ? parseInt(document.documentElement.scrollTop) || 0 : 0)
        };
    }

    /** Get the height and width of a DOM element.
    * @memberof pca
    * @param {HTMLElement} element - The element to get the size of.
    * @returns {Object} The height and width of the element. */
    pca.getSize = pca.getSize || function (element) {
        return {
            height: (element.offsetHeight || element.innerHeight || (pca.isPage(element) ? (document.documentElement.clientHeight || document.body.clientHeight) : 0)),
            width: (element.offsetWidth || element.innerWidth || (pca.isPage(element) ? (document.documentElement.clientWidth || document.body.clientWidth) : 0))
        };
    }

    /** Get the scroll value for all parent elements.
    * @memberof pca
    * @param {HTMLElement|string} element - The child element to begin from.
    * @returns {Object} The top and left of the scroll. */
    pca.getParentScroll = pca.getParentScroll || function (element) {
        var empty = { left: 0, top: 0 };

        if (element = pca.getElement(element)) {
            if (!element.tagName) return empty;
            if (!(element = element.parentNode)) return empty;

            var x = 0, y = 0;

            do {
                if (pca.isPage(element)) break;
                x += parseInt(element.scrollLeft) || 0;
                y += parseInt(element.scrollTop) || 0;
            } while (element = element.parentNode);

            return { left: x, top: y };
        }

        return empty;
    }

    /** Get the element which an element is positioned relative to.
    * @memberof pca
    * @param {HTMLElement} element - The child element to begin from.
    * @returns {HTMLElement} The element controlling the relative position. */
    pca.getTopOffsetParent = pca.getTopOffsetParent || function (element) {
        while (element.offsetParent) {
            element = element.offsetParent;

            //fix for Firefox
            if (pca.getStyle(element, "position") === "fixed")
                break;
        }

        return element;
    }

    /** Gets the current value of a style property of an element.
    * @memberof pca
    * @param {HTMLElement} element - The element to get the style property of.
    * @param {string} property - The name of the style property to query.
    * @returns {string} The value of the style property. */
    pca.getStyle = pca.getStyle || function (element, property) {
        return ((window.getComputedStyle ? window.getComputedStyle(element) : element.currentStyle) || {})[property] || "";
    }

    /** Adds a CSS class to an element.
    * @memberof pca
    * @param {HTMLElement|string} element - The element to add the style class to.
    * @param {string} className - The name of the style class to add. */
    pca.addClass = pca.addClass || function (element, className) {
        if (element = pca.getElement(element)) {
            if (!pca.containsWord(element.className || "", className))
                element.className += (element.className ? " " : "") + className;
        }
    }

    /** Removes a CSS class from an element.
    * @memberof pca
    * @param {HTMLElement|string} element - The element to remove the style class from.
    * @param {string} className - The name of the style class to remove. */
    pca.removeClass = pca.removeClass || function (element, className) {
        if (element = pca.getElement(element))
            element.className = pca.removeWord(element.className, className);
    }

    /** Sets an attribute of an element.
    * @memberof pca
    * @param {HTMLElement|string} element - The element to set the attribute of.
    * @param {string} attribute - The element attribute to set.
    * @param {Object} attribute - The value to set. */
    pca.setAttribute = pca.setAttribute || function (element, attribute, value) {
        if (element = pca.getElement(element))
            element.setAttribute(attribute, value);
    }

    /** Sets multiple attributes of an element.
    * @memberof pca
    * @param {HTMLElement|string} element - The element to set the attributes of.
    * @param {Object} attributes - The element attributes and values to set. */
    pca.setAttributes = pca.setAttributes || function (element, attributes) {
        if (element = pca.getElement(element)) {
            for (var i in attributes)
                element.setAttribute(i, attributes[i]);
        }
    }

    /** Applies fixes to a style sheet.
    * This will add them to the fixes list for pca.reapplyStyleFixes.
    * @memberof pca
    * @param {string} selectorText - The full CSS selector text for the rule as it appears in the style sheet.
    * @param {Object} fixes - An object with JavaScript style property name and value. */
    pca.applyStyleFixes = pca.applyStyleFixes || function (selectorText, fixes) {
        for (var s = 0; s < document.styleSheets.length; s++) {
            var sheet = document.styleSheets[s],
                rules = [];

            try {
                rules = sheet.rules || sheet.cssRules || []; //possible denial of access if script and css are hosted separately
            } catch (e) { };

            for (var r = 0; r < rules.length; r++) {
                var rule = rules[r];

                if (rule.selectorText.toLowerCase() === selectorText) {
                    for (var f in fixes)
                        rule.style[f] = fixes[f];
                }
            }
        }

        pca.styleFixes.push({ selectorText: selectorText, fixes: fixes });
    }

    /** Reapplies all fixes to style sheets added by pca.applyStyleFixes.
    * @memberof pca */
    pca.reapplyStyleFixes = pca.reapplyStyleFixes || function () {
        var fixesList = pca.styleFixes;

        pca.styleFixes = [];

        for (var i = 0; i < fixesList.length; i++)
            pca.applyStyleFixes(fixesList[i].selectorText, fixesList[i].fixes);
    }

    /** Creates a style sheet from cssText.
    * @memberof pca
    * @param {string} cssText - The CSS text for the body of the style sheet. */
    pca.createStyleSheet = pca.createStyleSheet || function (cssText) {
        if (document.createStyleSheet)
            document.createStyleSheet().cssText = cssText;
        else
            document.head.appendChild(pca.create("style", { type: "text/css", innerHTML: cssText }));
    }

    /** Simple short function to create an element.
    * @memberof pca
    * @param {string} tag - The HTML tag for the element.
    * @param {Object} properties - The properties to set in JavaScript form.
    * @param {string} cssText - Any CSS to add the style property.
    * @returns {HTMLElement} The created element. */
    pca.create = pca.create || function (tag, properties, cssText) {
        var elem = document.createElement(tag);
        for (var i in properties || {})
            elem[i] = properties[i];
        if (cssText) elem.style.cssText = cssText;
        return elem;
    }

    /** Adds an element to the pca container on the page.
    * If the container does not exist it is created.
    * @memberof pca
    * @param {HTMLElement} element - The element to add to the container. */
    pca.append = pca.append || function (element) {
        if (!pca.container) {
            pca.container = pca.create("div", { className: "pca" });
            document.body.appendChild(pca.container);
            pca.liveA11y = pca.create("div", {
                className: "pca_live_a11y pca-visually-hidden"
            });
            pca.liveA11y.setAttribute("aria-live", "polite");
            pca.liveA11y.setAttribute("aria-atomic", "true");
            pca.liveA11y.setAttribute("role", "status");
            pca.container.appendChild(pca.liveA11y);
        }

        pca.container.appendChild(element);
    }

    pca.read = function (text) {
        pca.liveA11y.innerText = "";
        setTimeout(function () {
            pca.liveA11y.innerText = text;
        }, 1000);
    }

    /** Removes an element from the container on the page.
    * @memberof pca
    * @param {HTMLElement} element - The element to remove from the container. */
    pca.remove = pca.remove || function (element) {
        if (element && element.parentNode && element.parentNode === pca.container)
            pca.container.removeChild(element);
    }

    /** Listens to an event with standard DOM event handling.
    * @memberof pca
    * @param {HTMLElement} target - The element to listen to.
    * @param {string} event - The name of the event to listen for, e.g. "click".
    * @param {pca.Eventable~eventHandler} action - The callback for this event.
    * @param {boolean} capture - Use event capturing. */
    pca.listen = pca.listen || function (target, event, action, capture) {
        target.addEventListener(event, action, capture);
    }

    /** Creates and fires a standard DOM event.
    * @memberof pca
    * @param {HTMLElement} target - The element to trigger the event for.
    * @param {string} event - The name of the event, e.g. "click".
    * @returns {boolean} False is the event was stopped by any of its handlers. */
    pca.fire = pca.fire || function (target, event) {
        if (document.createEvent) {
            var e = document.createEvent("HTMLEvents");
            e.initEvent(event, true, true);
            return !target.dispatchEvent(e);
        }
        else
            return target.fireEvent("on" + event, document.createEventObject());
    }

    /** Removes listeners for an event with standard DOM event handling.
    * @memberof pca
    * @param {HTMLElement} target - The element.
    * @param {string} event - The name of the event, e.g. "click".
    * @param {pca.Eventable~eventHandler} action - The callback to remove for this event. */
    pca.ignore = pca.ignore || function (target, event, action) {
        if (window.removeEventListener)
            target.removeEventListener(event, action);
        else
            target.detachEvent("on" + event, action);
    }

    /** Stops other actions of an event.
    * @memberof pca
    * @param {Event} event - The event to stop. */
    pca.smash = pca.smash || function (event) {
        var e = event || window.event;
        e.stopPropagation ? e.stopPropagation() : e.cancelBubble = true;
        e.preventDefault ? e.preventDefault() : e.returnValue = false;
    }

    /** Debug messages to the console.
    * @memberof pca
    * @param {string} message - The debug message text. */
    pca.debug = pca.debug || function (message) {
        if (typeof console != "undefined" && console.debug) console.debug(message);
    }

    /** Creates and returns are new debounced version of the passed function, which will postpone
    * its execution until after the 'delay' milliseconds have elapsed since this last time the function was
    * invoked. (-- PORT FROM underscore.js with some tweaks to support IE8 events--)
    * @memberof pca
    * @param {function} func - The funcion to call when the timeout has elapsed.
    * @param {integer} wait - The number of milliseconds to wait between calling the function.
    * @param {integer} immediate - An ovveride to call the function immediately. */
    pca.debounce = pca.debounce || function (func, wait, immediate) {
        var timeout;
        return function () {
            var context = this;

            var args = arguments;

            if (arguments && arguments.length > 0) {
                args = [{ target: (arguments[0].target || arguments[0].srcElement) }];
            }

            var later = function () {
                timeout = null;
                if (!immediate) func.apply(context, args);
            };
            var callNow = immediate && !timeout;
            clearTimeout(timeout);
            timeout = setTimeout(later, wait);
            if (callNow) func.apply(context, args);
        };
    };

    /** Returns whether or not a particular function is defined.
    * @memberof pca
    * @param {function} func - The function to check */
    pca.defined = pca.defined || function (func) {
        return typeof (func) == "function";
    };

    /** Returns whether or not a particular function is undefined.
    * @memberof pca
    * @param {function} fn - The function to check */
    pca.fnDefined = pca.defined;

    /** Returns the label element for a given DOM element.
    * @memberof pca
    * @param {string} elementNameOrId - The name or ID of the DOM element. */
    pca.getLabel = pca.getLabel || function (elementNameOrId) {
        var labels = document.getElementsByTagName("LABEL");
        for (var i = 0; i < labels.length; i++) {
            if (labels[i].htmlFor !== "") {
                var elem = pca.getElement(labels[i].htmlFor);

                if (elem && (elem.name === elementNameOrId) || (elem.id === elementNameOrId))
                    return labels[i];
            }
        }
        return null;
    };

    //get some reference to an element that we can use later in getElement
    pca.getReferenceToElement = pca.getReferenceToElement || function (element) {
        return typeof element == "string" ? element : element ? (element.id || element.name || "") : "";
    }

    /**
     * Extends one object into another, any number of objects can be supplied
     * To create a new object supply an empty object as the first argument
     * @param {Object} obj - The object to add properties to.
     * @param {Object} [sources] - One or more objects to take properties from.
     * @returns {Object} The destination object.
     */
    pca.extend = pca.extend || function (obj /*...*/) {
        for (var i = 1; i < arguments.length; i++) {
            for (var key in arguments[i]) {
                if (arguments[i].hasOwnProperty(key))
                    obj[key] = arguments[i][key];
            }
        }

        return obj;
    };

    /**
     * Gets even inherited styles from element
     * @param {} element - The element to get the style for
     * @param {} styleProperty - The style property to be got, in the original css form
     * @returns {}
     */
    pca.getStyle = pca.getStyle || function (element, styleProperty) {
        var camelize = function (str) {
            return str.replace(/\-(\w)/g, function (str, letter) {
                return letter.toUpperCase();
            });
        };

        if (element.currentStyle) {
            return element.currentStyle[camelize(styleProperty)];
        } else if (document.defaultView && document.defaultView.getComputedStyle) {
            return document.defaultView.getComputedStyle(element, null)
                .getPropertyValue(styleProperty);
        } else {
            return element.style[camelize(styleProperty)];
        }
    };


    /**
     * Detects browser support for a predefined list of capabilities
     * @param {string} checkType - The check to perform
     * @returns {boolean} Wether the given type is supported.
     */
    pca.supports = pca.supports || function (checkType) {

        switch (checkType) {
            case "reverseGeo":
                return document.location.protocol == "https:" && window.navigator && window.navigator.geolocation;
        }
        return false;
    }

    pca.guid = pca.guid || (function () {
        /**
         * Generates a new guid
         * @method s4
         * @return CallExpression
         */
        function s4() {
            return Math.floor((1 + Math.random()) * 0x10000)
                .toString(16)
                .substring(1);
        }
        return function () {
            return s4() + s4() + '-' + s4() + '-' + s4() + '-' +
                s4() + '-' + s4() + s4() + s4();
        };
    })();

    pca.sessionId = pca.sessionId || pca.guid();

    //load when the document is ready
    checkDocumentLoad();
})(window);
/*3.91 - A11y*/
(function () {
    var pca = window.pca = window.pca || {};

    /**
    * Details of a country.
    * @typedef {Object} pca.Country
    * @property {string} iso2 - The ISO 2-char code, e.g. GB.
    * @property {string} iso3 - The ISO 3-char code, e.g. GBR.
    * @property {string} name - The full country name.
    * @property {number} flag - Flag index.
    * @property {Array.<string>} [alternates] - Any alternate names for the country.
    */

    /** The list of countries.
    * @memberof pca
    * @type {Array.<pca.Country>} */
    pca.countries = [
        { iso2: "AF", iso3: "AFG", name: "Afghanistan", name_fr: "Afghanistan", flag: 1 },
        { iso2: "AX", iso3: "ALA", name: "Åland", name_fr: "Åland(les Îles)", flag: 220 },
        { iso2: "AL", iso3: "ALB", name: "Albania", name_fr: "Albanie", alternates: ["Shqipëria"], flag: 2 },
        { iso2: "DZ", iso3: "DZA", name: "Algeria", name_fr: "Algérie", flag: 3 },
        { iso2: "AS", iso3: "ASM", name: "American Samoa", name_fr: "Samoa américaines", flag: 4 },
        { iso2: "AD", iso3: "AND", name: "Andorra", name_fr: "Andorre", flag: 5 },
        { iso2: "AO", iso3: "AGO", name: "Angola", name_fr: "Angola", flag: 6 },
        { iso2: "AI", iso3: "AIA", name: "Anguilla", name_fr: "Anguilla", flag: 7 },
        { iso2: "AQ", iso3: "ATA", name: "Antarctica", name_fr: "Antarctique", flag: 0 },
        { iso2: "AG", iso3: "ATG", name: "Antigua and Barbuda", name_fr: "Antigua-et-Barbuda", flag: 8 },
        { iso2: "AR", iso3: "ARG", name: "Argentina", name_fr: "Argentine", flag: 9 },
        { iso2: "AM", iso3: "ARM", name: "Armenia", name_fr: "Arménie", flag: 10 },
        { iso2: "AW", iso3: "ABW", name: "Aruba", name_fr: "Aruba", flag: 11 },
        { iso2: "AU", iso3: "AUS", name: "Australia", name_fr: "Australie", flag: 12 },
        { iso2: "AT", iso3: "AUT", name: "Austria", name_fr: "Autriche", alternates: ["Österreich"], flag: 13 },
        { iso2: "AZ", iso3: "AZE", name: "Azerbaijan", name_fr: "Azerbaïdjan", flag: 14 },
        { iso2: "BS", iso3: "BHS", name: "Bahamas", name_fr: "Bahamas", flag: 15 },
        { iso2: "BH", iso3: "BHR", name: "Bahrain", name_fr: "Bahreïn", flag: 16 },
        { iso2: "BD", iso3: "BGD", name: "Bangladesh", name_fr: "Bangladesh", flag: 17 },
        { iso2: "BB", iso3: "BRB", name: "Barbados", name_fr: "Barbade", flag: 18 },
        { iso2: "BY", iso3: "BLR", name: "Belarus", name_fr: "Bélarus", flag: 19 },
        { iso2: "BE", iso3: "BEL", name: "Belgium", name_fr: "Belgique", alternates: ["België"], flag: 20 },
        { iso2: "BZ", iso3: "BLZ", name: "Belize", name_fr: "Belize", flag: 21 },
        { iso2: "BJ", iso3: "BEN", name: "Benin", name_fr: "Bénin", flag: 22 },
        { iso2: "BM", iso3: "BMU", name: "Bermuda", name_fr: "Bermudes", flag: 23 },
        { iso2: "BT", iso3: "BTN", name: "Bhutan", name_fr: "Bhoutan", flag: 24 },
        { iso2: "BO", iso3: "BOL", name: "Bolivia", name_fr: "Bolivie, l'État plurinational de la", flag: 25 },
        { iso2: "BQ", iso3: "BES", name: "Bonaire, Sint Eustatius and Saba", name_fr: "Bonaire, Saint-Eustache et Saba", flag: 0 },
        { iso2: "BA", iso3: "BIH", name: "Bosnia and Herzegovina", name_fr: "Bosnie-Herzégovine", alternates: ["Bosna i Hercegovina"], flag: 26 },
        { iso2: "BW", iso3: "BWA", name: "Botswana", name_fr: "Botswana", flag: 27 },
        { iso2: "BV", iso3: "BVT", name: "Bouvet Island", name_fr: "Bouvet (l'Île)", flag: 0 },
        { iso2: "BR", iso3: "BRA", name: "Brazil", name_fr: "Brésil", alternates: ["Brasil"], flag: 28 },
        { iso2: "IO", iso3: "IOT", name: "British Indian Ocean Territory", name_fr: "Indien (le Territoire britannique de l'océan)", flag: 29 },
        { iso2: "VG", iso3: "VGB", name: "British Virgin Islands", name_fr: "Vierges britanniques (les Îles)", flag: 30 },
        { iso2: "BN", iso3: "BRN", name: "Brunei", name_fr: "Brunei", flag: 0 },
        { iso2: "BG", iso3: "BGR", name: "Bulgaria", name_fr: "Bulgarie", flag: 31 },
        { iso2: "BF", iso3: "BFA", name: "Burkina Faso", name_fr: "Burkina Faso", flag: 32 },
        { iso2: "BI", iso3: "BDI", name: "Burundi", name_fr: "Burundi", flag: 34 },
        { iso2: "KH", iso3: "KHM", name: "Cambodia", name_fr: "Cambodge", flag: 35 },
        { iso2: "CM", iso3: "CMR", name: "Cameroon", name_fr: "Cameroun", flag: 36 },
        { iso2: "CA", iso3: "CAN", name: "Canada", name_fr: "Canada", flag: 37 },
        { iso2: "CV", iso3: "CPV", name: "Cape Verde", name_fr: "Cabo Verde", flag: 38 },
        { iso2: "KY", iso3: "CYM", name: "Cayman Islands", name_fr: "Caïmans (les Îles)", flag: 39 },
        { iso2: "CF", iso3: "CAF", name: "Central African Republic", name_fr: "République centrafricaine", flag: 40 },
        { iso2: "TD", iso3: "TCD", name: "Chad", name_fr: "Tchad", flag: 41 },
        { iso2: "CL", iso3: "CHL", name: "Chile", name_fr: "Chili", flag: 42 },
        { iso2: "CN", iso3: "CHN", name: "China", name_fr: "Chine", flag: 43 },
        { iso2: "CX", iso3: "CXR", name: "Christmas Island", name_fr: "Christmas (l'Île)", flag: 0 },
        { iso2: "CC", iso3: "CCK", name: "Cocos (Keeling) Islands", name_fr: "Cocos (les Îles)/ Keeling (les Îles)", flag: 0 },
        { iso2: "CO", iso3: "COL", name: "Colombia", name_fr: "Colombie", flag: 44 },
        { iso2: "KM", iso3: "COM", name: "Comoros", name_fr: "Comores", flag: 45 },
        { iso2: "CG", iso3: "COG", name: "Congo", name_fr: "Congo", flag: 0 },
        { iso2: "CD", iso3: "COD", name: "Congo (Democratic Republic)", name_fr: "Congo (la République démocratique du)", flag: 46 },
        { iso2: "CK", iso3: "COK", name: "Cook Islands", name_fr: "Cook (les Îles)", flag: 47 },
        { iso2: "CR", iso3: "CRI", name: "Costa Rica", name_fr: "Costa Rica", flag: 48 },
        { iso2: "HR", iso3: "HRV", name: "Croatia", name_fr: "Croatie", alternates: ["Hrvatska"], flag: 50 },
        { iso2: "CU", iso3: "CUB", name: "Cuba", name_fr: "Cuba", flag: 51 },
        { iso2: "CW", iso3: "CUW", name: "Curaçao", name_fr: "Curaçao", flag: 0 },
        { iso2: "CY", iso3: "CYP", name: "Cyprus", name_fr: "Chypre", flag: 52 },
        { iso2: "CZ", iso3: "CZE", name: "Czechia", name_fr: "tchèque (la République)", alternates: ["Ceská republika"], flag: 53 },
        { iso2: "DK", iso3: "DNK", name: "Denmark", name_fr: "Danemark", flag: 54 },
        { iso2: "DJ", iso3: "DJI", name: "Djibouti", name_fr: "Djibouti", flag: 55 },
        { iso2: "DM", iso3: "DMA", name: "Dominica", name_fr: "Dominique", flag: 56 },
        { iso2: "DO", iso3: "DOM", name: "Dominican Republic", name_fr: "dominicaine (la République)", flag: 57 },
        { iso2: "TL", iso3: "TLS", name: "East Timor", name_fr: "Timor-Leste", flag: 0 },
        { iso2: "EC", iso3: "ECU", name: "Ecuador", name_fr: "Équateur", flag: 61 },
        { iso2: "EG", iso3: "EGY", name: "Egypt", name_fr: "Égypte", flag: 58 },
        { iso2: "SV", iso3: "SLV", name: "El Salvador", name_fr: "Salvador", flag: 59 },
        { iso2: "GQ", iso3: "GNQ", name: "Equatorial Guinea", name_fr: "Guinée équatoriale", flag: 62 },
        { iso2: "ER", iso3: "ERI", name: "Eritrea", name_fr: "Érythrée", flag: 63 },
        { iso2: "EE", iso3: "EST", name: "Estonia", name_fr: "Estonie", alternates: ["Eesti"], flag: 64 },
        { iso2: "SZ", iso3: "SWZ", name: "Eswatini", name_fr: "Eswatini", flag: 191 },
        { iso2: "ET", iso3: "ETH", name: "Ethiopia", name_fr: "Éthiopie", flag: 65 },
        { iso2: "FK", iso3: "FLK", name: "Falkland Islands", name_fr: "Falkland (les Îles)/Malouines (les Îles)", flag: 66 },
        { iso2: "FO", iso3: "FRO", name: "Faroe Islands", name_fr: "Féroé (les Îles)", flag: 67 },
        { iso2: "FJ", iso3: "FJI", name: "Fiji", name_fr: "Fidji", flag: 68 },
        { iso2: "FI", iso3: "FIN", name: "Finland", name_fr: "Finlande", alternates: ["Suomi"], flag: 69 },
        { iso2: "FR", iso3: "FRA", name: "France", name_fr: "France", flag: 70 },
        { iso2: "GF", iso3: "GUF", name: "French Guiana", name_fr: "Guyane française ", flag: 0 },
        { iso2: "PF", iso3: "PYF", name: "French Polynesia", name_fr: "Polynésie française", flag: 71 },
        { iso2: "TF", iso3: "ATF", name: "French Southern Territories", name_fr: "Terres australes françaises", flag: 0 },
        { iso2: "GA", iso3: "GAB", name: "Gabon", name_fr: "Gabon", flag: 72 },
        { iso2: "GM", iso3: "GMB", name: "Gambia", name_fr: "Gambie", flag: 73 },
        { iso2: "GE", iso3: "GEO", name: "Georgia", name_fr: "Géorgie", flag: 74 },
        { iso2: "DE", iso3: "DEU", name: "Germany", name_fr: "Allemagne", alternates: ["Deutschland"], flag: 75 },
        { iso2: "GH", iso3: "GHA", name: "Ghana", name_fr: "Ghana", flag: 76 },
        { iso2: "GI", iso3: "GIB", name: "Gibraltar", name_fr: "Gibraltar", flag: 77 },
        { iso2: "GR", iso3: "GRC", name: "Greece", name_fr: "Grèce", alternates: ["Hellas"], flag: 79 },
        { iso2: "GL", iso3: "GRL", name: "Greenland", name_fr: "Groenland", flag: 80 },
        { iso2: "GD", iso3: "GRD", name: "Grenada", name_fr: "Grenade", flag: 81 },
        { iso2: "GP", iso3: "GLP", name: "Guadeloupe", name_fr: "Guadeloupe", flag: 0 },
        { iso2: "GU", iso3: "GUM", name: "Guam", name_fr: "Guam", flag: 82 },
        { iso2: "GT", iso3: "GTM", name: "Guatemala", name_fr: "Guatemala", flag: 83 },
        { iso2: "GG", iso3: "GGY", name: "Guernsey", name_fr: "Guernesey", flag: 84 },
        { iso2: "GN", iso3: "GIN", name: "Guinea", name_fr: "Guinée", flag: 85 },
        { iso2: "GW", iso3: "GNB", name: "Guinea-Bissau", name_fr: "Guinée-Bissau", flag: 86 },
        { iso2: "GY", iso3: "GUY", name: "Guyana", name_fr: "Guyana", flag: 87 },
        { iso2: "HT", iso3: "HTI", name: "Haiti", name_fr: "Haïti", flag: 88 },
        { iso2: "HM", iso3: "HMD", name: "Heard Island and McDonald Islands", name_fr: "Heard-et-Îles MacDonald (l'Île)", flag: 0 },
        { iso2: "HN", iso3: "HND", name: "Honduras", name_fr: "Honduras", flag: 89 },
        { iso2: "HK", iso3: "HKG", name: "Hong Kong", name_fr: "Hong Kong", flag: 90 },
        { iso2: "HU", iso3: "HUN", name: "Hungary", name_fr: "Hongrie", alternates: ["Magyarország"], flag: 91 },
        { iso2: "IS", iso3: "ISL", name: "Iceland", name_fr: "Islande", alternates: ["Ísland"], flag: 92 },
        { iso2: "IN", iso3: "IND", name: "India", name_fr: "Inde", flag: 93 },
        { iso2: "ID", iso3: "IDN", name: "Indonesia", name_fr: "Indonésie", flag: 94 },
        { iso2: "IR", iso3: "IRN", name: "Iran", name_fr: "Iran (République Islamique d')", flag: 95 },
        { iso2: "IQ", iso3: "IRQ", name: "Iraq", name_fr: "Iraq", flag: 96 },
        { iso2: "IE", iso3: "IRL", name: "Ireland", name_fr: "Irlande", flag: 97 },
        { iso2: "IM", iso3: "IMN", name: "Isle of Man", name_fr: "Île de Man", flag: 98 },
        { iso2: "IL", iso3: "ISR", name: "Israel", name_fr: "Israël", flag: 99 },
        { iso2: "IT", iso3: "ITA", name: "Italy", name_fr: "Italie", alternates: ["Italia"], flag: 100 },
        { iso2: "CI", iso3: "CIV", name: "Ivory Coast", name_fr: "Côte d'Ivoire", flag: 49 },
        { iso2: "JM", iso3: "JAM", name: "Jamaica", name_fr: "Jamaïque", flag: 101 },
        { iso2: "JP", iso3: "JPN", name: "Japan", name_fr: "Japon", flag: 102 },
        { iso2: "JE", iso3: "JEY", name: "Jersey", name_fr: "Jersey", flag: 103 },
        { iso2: "JO", iso3: "JOR", name: "Jordan", name_fr: "Jordanie", flag: 104 },
        { iso2: "KZ", iso3: "KAZ", name: "Kazakhstan", name_fr: "Kazakhstan", flag: 105 },
        { iso2: "KE", iso3: "KEN", name: "Kenya", name_fr: "Kenya", flag: 106 },
        { iso2: "KI", iso3: "KIR", name: "Kiribati", name_fr: "Kiribati", flag: 107 },
        { iso2: "KP", iso3: "PRK", name: "Korea (the Democratic People's Republic of)", name_fr: "Corée (la République populaire démocratique de )", flag: 149 },
        { iso2: "KR", iso3: "KOR", name: "Korea (the Republic of)", name_fr: "Corée (la République de)", flag: 185 },
        { iso2: "KW", iso3: "KWT", name: "Kuwait", name_fr: "Koweït", flag: 108 },
        { iso2: "KG", iso3: "KGZ", name: "Kyrgyzstan", name_fr: "Kirghizistan", flag: 109 },
        { iso2: "LA", iso3: "LAO", name: "Laos", name_fr: "Lao, République démocratique populaire", flag: 0 },
        { iso2: "LV", iso3: "LVA", name: "Latvia", name_fr: "Lettonie", flag: 110 },
        { iso2: "LB", iso3: "LBN", name: "Lebanon", name_fr: "Liban", flag: 111 },
        { iso2: "LS", iso3: "LSO", name: "Lesotho", name_fr: "Lesotho", flag: 112 },
        { iso2: "LR", iso3: "LBR", name: "Liberia", name_fr: "Libéria", flag: 113 },
        { iso2: "LY", iso3: "LBY", name: "Libya", name_fr: "Libye", flag: 114 },
        { iso2: "LI", iso3: "LIE", name: "Liechtenstein", name_fr: "Liechtenstein", flag: 115 },
        { iso2: "LT", iso3: "LTU", name: "Lithuania", name_fr: "Lituanie", alternates: ["Lietuva"], flag: 116 },
        { iso2: "LU", iso3: "LUX", name: "Luxembourg", name_fr: "Luxembourg", flag: 117 },
        { iso2: "MO", iso3: "MAC", name: "Macao", name_fr: "Macao", flag: 118 },
        { iso2: "MG", iso3: "MDG", name: "Madagascar", name_fr: "Madagascar", flag: 120 },
        { iso2: "MW", iso3: "MWI", name: "Malawi", name_fr: "Malawi", flag: 121 },
        { iso2: "MY", iso3: "MYS", name: "Malaysia", name_fr: "Malaisie", flag: 122 },
        { iso2: "MV", iso3: "MDV", name: "Maldives", name_fr: "Maldives", flag: 123 },
        { iso2: "ML", iso3: "MLI", name: "Mali", name_fr: "Mali", flag: 124 },
        { iso2: "MT", iso3: "MLT", name: "Malta", name_fr: "Malte", flag: 125 },
        { iso2: "MH", iso3: "MHL", name: "Marshall Islands", name_fr: "Marshall (Îles)", flag: 126 },
        { iso2: "MQ", iso3: "MTQ", name: "Martinique", name_fr: "Martinique", flag: 127 },
        { iso2: "MR", iso3: "MRT", name: "Mauritania", name_fr: "Mauritanie", flag: 128 },
        { iso2: "MU", iso3: "MUS", name: "Mauritius", name_fr: "Maurice", flag: 129 },
        { iso2: "YT", iso3: "MYT", name: "Mayotte", name_fr: "Mayotte", flag: 0 },
        { iso2: "MX", iso3: "MEX", name: "Mexico", name_fr: "Mexique", flag: 130 },
        { iso2: "FM", iso3: "FSM", name: "Micronesia", name_fr: "Micronésie, États fédérés de", flag: 131 },
        { iso2: "MD", iso3: "MDA", name: "Moldova", name_fr: "Moldova , République de", flag: 132 },
        { iso2: "MC", iso3: "MCO", name: "Monaco", name_fr: "Monaco", flag: 133 },
        { iso2: "MN", iso3: "MNG", name: "Mongolia", name_fr: "Mongolie", flag: 134 },
        { iso2: "ME", iso3: "MNE", name: "Montenegro", name_fr: "Monténégro", alternates: ["Crna Gora"], flag: 0 },
        { iso2: "MS", iso3: "MSR", name: "Montserrat", name_fr: "Montserrat", flag: 135 },
        { iso2: "MA", iso3: "MAR", name: "Morocco", name_fr: "Maroc", flag: 136 },
        { iso2: "MZ", iso3: "MOZ", name: "Mozambique", name_fr: "Mozambique", flag: 137 },
        { iso2: "MM", iso3: "MMR", name: "Myanmar", name_fr: "Myanmar", flag: 33 },
        { iso2: "NA", iso3: "NAM", name: "Namibia", name_fr: "Namibie", flag: 138 },
        { iso2: "NR", iso3: "NRU", name: "Nauru", name_fr: "Nauru", flag: 139 },
        { iso2: "NP", iso3: "NPL", name: "Nepal", name_fr: "Népal", flag: 140 },
        { iso2: "NL", iso3: "NLD", name: "Netherlands", name_fr: "Pays-Bas", alternates: ["Holland"], flag: 141 },
        { iso2: "NC", iso3: "NCL", name: "New Caledonia", name_fr: "Nouvelle-Calédonie", flag: 0 },
        { iso2: "NZ", iso3: "NZL", name: "New Zealand", name_fr: "Nouvelle-Zélande", flag: 142 },
        { iso2: "NI", iso3: "NIC", name: "Nicaragua", name_fr: "Nicaragua", flag: 143 },
        { iso2: "NE", iso3: "NER", name: "Niger", name_fr: "Niger", flag: 144 },
        { iso2: "NG", iso3: "NGA", name: "Nigeria", name_fr: "Nigéria", flag: 145 },
        { iso2: "NU", iso3: "NIU", name: "Niue", name_fr: "Niue", flag: 146 },
        { iso2: "NF", iso3: "NFK", name: "Norfolk Island", name_fr: "Norfolk (l'Île)", flag: 147 },
        { iso2: "MK", iso3: "MKD", name: "North Macedonia", name_fr: "Macédoine (l'ex-République yougoslave de)", alternates: ["Poraneshna Jugoslovenska Republika Makedonija"], flag: 119 },
        { iso2: "MP", iso3: "MNP", name: "Northern Mariana Islands", name_fr: "Mariannes du Nord (les Îles)", flag: 148 },
        { iso2: "NO", iso3: "NOR", name: "Norway", name_fr: "Norvège", flag: 150 },
        { iso2: "OM", iso3: "OMN", name: "Oman", name_fr: "Oman", flag: 151 },
        { iso2: "PK", iso3: "PAK", name: "Pakistan", name_fr: "Pakistan", flag: 152 },
        { iso2: "PW", iso3: "PLW", name: "Palau", name_fr: "Palaos", flag: 153 },
        { iso2: "PS", iso3: "PSE", name: "Palestine", name_fr: "Palestine, État de", flag: 0 },
        { iso2: "PA", iso3: "PAN", name: "Panama", name_fr: "Panama", flag: 154 },
        { iso2: "PG", iso3: "PNG", name: "Papua New Guinea", name_fr: "Papouasie-Nouvelle-Guinée", flag: 155 },
        { iso2: "PY", iso3: "PRY", name: "Paraguay", name_fr: "Paraguay", flag: 156 },
        { iso2: "PE", iso3: "PER", name: "Peru", name_fr: "Pérou", flag: 157 },
        { iso2: "PH", iso3: "PHL", name: "Philippines", name_fr: "Philippines", flag: 158 },
        { iso2: "PN", iso3: "PCN", name: "Pitcairn", name_fr: "Pitcairn", flag: 0 },
        { iso2: "PL", iso3: "POL", name: "Poland", name_fr: "Pologne", alternates: ["Polska"], flag: 159 },
        { iso2: "PT", iso3: "PRT", name: "Portugal", name_fr: "Portugal", flag: 160 },
        { iso2: "PR", iso3: "PRI", name: "Puerto Rico", name_fr: "Porto Rico", flag: 161 },
        { iso2: "QA", iso3: "QAT", name: "Qatar", name_fr: "Qatar", flag: 162 },
        { iso2: "RE", iso3: "REU", name: "Réunion", name_fr: "Réunion", flag: 0 },
        { iso2: "RO", iso3: "ROU", name: "Romania", name_fr: "Roumanie", alternates: ["România"], flag: 163 },
        { iso2: "RU", iso3: "RUS", name: "Russia", name_fr: "Russie (la Fédération de)", alternates: ["Rossiya"], flag: 164 },
        { iso2: "RW", iso3: "RWA", name: "Rwanda", name_fr: "Rwanda", flag: 165 },
        { iso2: "MF", iso3: "MAF", name: "Saint Martin (French)", name_fr: "Saint-Martin (partie française)", flag: 0 },
        { iso2: "WS", iso3: "WSM", name: "Samoa", name_fr: "Samoa", flag: 171 },
        { iso2: "SM", iso3: "SMR", name: "San Marino", name_fr: "Saint-Marin", flag: 172 },
        { iso2: "ST", iso3: "STP", name: "Sao Tome and Principe", name_fr: "Sao Tomé-et-Principe", flag: 173 },
        { iso2: "SA", iso3: "SAU", name: "Saudi Arabia", name_fr: "Arabie saoudite", flag: 174 },
        { iso2: "SN", iso3: "SEN", name: "Senegal", name_fr: "Sénégal", flag: 175 },
        { iso2: "RS", iso3: "SRB", name: "Serbia", name_fr: "Serbie", alternates: ["Srbija"], flag: 0 },
        { iso2: "SC", iso3: "SYC", name: "Seychelles", name_fr: "Seychelles", flag: 176 },
        { iso2: "SL", iso3: "SLE", name: "Sierra Leone", name_fr: "Sierra Leone", flag: 177 },
        { iso2: "SG", iso3: "SGP", name: "Singapore", name_fr: "Singapour", flag: 178 },
        { iso2: "SX", iso3: "SXM", name: "Sint Maarten (Dutch)", name_fr: "Saint-Martin (partie néerlandaise)", flag: 0 },
        { iso2: "SK", iso3: "SVK", name: "Slovakia", name_fr: "Slovaquie", alternates: ["Slovenská republika"], flag: 179 },
        { iso2: "SI", iso3: "SVN", name: "Slovenia", name_fr: "Slovénie", alternates: ["Slovenija"], flag: 180 },
        { iso2: "SB", iso3: "SLB", name: "Solomon Islands", name_fr: "Salomon (Îles)", flag: 181 },
        { iso2: "SO", iso3: "SOM", name: "Somalia", name_fr: "Somalie", flag: 182 },
        { iso2: "ZA", iso3: "ZAF", name: "South Africa", name_fr: "Afrique du Sud", flag: 183 },
        { iso2: "GS", iso3: "SGS", name: "South Georgia and the South Sandwich Islands", name_fr: "Géorgie du Sud-et-les Îles Sandwich du Sud", flag: 184 },
        { iso2: "SS", iso3: "SSD", name: "South Sudan ", name_fr: "Soudan du Sud", flag: 0 },
        { iso2: "ES", iso3: "ESP", name: "Spain", name_fr: "Espagne", alternates: ["España"], flag: 186 },
        { iso2: "LK", iso3: "LKA", name: "Sri Lanka", name_fr: "Sri Lanka", flag: 187 },
        { iso2: "BL", iso3: "BLM", name: "St Barthélemy", name_fr: "Saint-Barthélemy", flag: 0 },
        { iso2: "SH", iso3: "SHN", name: "St Helena, Ascension and Tristan da Cunha", name_fr: "Sainte-Hélène, Ascension et Tristan da Cunha", flag: 166 },
        { iso2: "KN", iso3: "KNA", name: "St Kitts and Nevis", name_fr: "Saint-Kitts-et-Nevis", flag: 167 },
        { iso2: "LC", iso3: "LCA", name: "St Lucia", name_fr: "Sainte-Lucie", flag: 168 },
        { iso2: "PM", iso3: "SPM", name: "St Pierre and Miquelon", name_fr: "Saint-Pierre-et-Miquelon", flag: 169 },
        { iso2: "VC", iso3: "VCT", name: "St Vincent", name_fr: "Saint-Vincent-et-les-Grenadines", flag: 170 },
        { iso2: "SD", iso3: "SDN", name: "Sudan", name_fr: "Soudan", flag: 188 },
        { iso2: "SR", iso3: "SUR", name: "Suriname", name_fr: "Suriname", flag: 189 },
        { iso2: "SJ", iso3: "SJM", name: "Svalbard and Jan Mayen", name_fr: "Svalbard et l'Île Jan Mayen", flag: 190 },
        { iso2: "SE", iso3: "SWE", name: "Sweden", name_fr: "Suède", alternates: ["Sverige"], flag: 192 },
        { iso2: "CH", iso3: "CHE", name: "Switzerland", name_fr: "Suisse", alternates: ["Schweiz"], flag: 193 },
        { iso2: "SY", iso3: "SYR", name: "Syria", name_fr: "République arabe syrienne", flag: 0 },
        { iso2: "TW", iso3: "TWN", name: "Taiwan", name_fr: "Taïwan (Province de Chine)", flag: 194 },
        { iso2: "TJ", iso3: "TJK", name: "Tajikistan", name_fr: "Tadjikistan", flag: 195 },
        { iso2: "TZ", iso3: "TZA", name: "Tanzania", name_fr: "Tanzanie, République-Unie de", flag: 196 },
        { iso2: "TH", iso3: "THA", name: "Thailand", name_fr: "Thaïlande", flag: 197 },
        { iso2: "TG", iso3: "TGO", name: "Togo", name_fr: "Togo", flag: 198 },
        { iso2: "TK", iso3: "TKL", name: "Tokelau", name_fr: "Tokelau", flag: 0 },
        { iso2: "TO", iso3: "TON", name: "Tonga", name_fr: "Tonga", flag: 199 },
        { iso2: "TT", iso3: "TTO", name: "Trinidad and Tobago", name_fr: "Trinité-et-Tobago", flag: 200 },
        { iso2: "TN", iso3: "TUN", name: "Tunisia", name_fr: "Tunisie", flag: 201 },
        { iso2: "TR", iso3: "TUR", name: "Turkey", name_fr: "Turquie", alternates: ["Türkiye"], flag: 202 },
        { iso2: "TM", iso3: "TKM", name: "Turkmenistan", name_fr: "Turkménistan", flag: 203 },
        { iso2: "TC", iso3: "TCA", name: "Turks and Caicos Islands", name_fr: "Turks-et-Caïcos (les Îles)", flag: 204 },
        { iso2: "TV", iso3: "TUV", name: "Tuvalu", name_fr: "Tuvalu", flag: 205 },
        { iso2: "UG", iso3: "UGA", name: "Uganda", name_fr: "Ouganda", flag: 206 },
        { iso2: "UA", iso3: "UKR", name: "Ukraine", name_fr: "Ukraine", alternates: ["Ukraina"], flag: 207 },
        { iso2: "AE", iso3: "ARE", name: "United Arab Emirates", name_fr: "Émirats arabes unis", alternates: ["UAE"], flag: 208 },
        { iso2: "GB", iso3: "GBR", name: "United Kingdom", name_fr: "Royaume-Uni", alternates: ["Britain", "England", "Great Britain", "Northern Ireland", "Scotland", "UK", "Wales"], flag: 78 },
        { iso2: "US", iso3: "USA", name: "United States", name_fr: "États-Unis", alternates: ["America", "United States of America"], flag: 210 },
        { iso2: "UM", iso3: "UMI", name: "United States Minor Outlying Islands", name_fr: "Îles mineures éloignées des États-Unis", flag: 0 },
        { iso2: "VI", iso3: "VIR", name: "United States Virgin Islands", name_fr: "Vierges des États-Unis (les Îles)", flag: 215 },
        { iso2: "UY", iso3: "URY", name: "Uruguay", name_fr: "Uruguay", flag: 209 },
        { iso2: "UZ", iso3: "UZB", name: "Uzbekistan", name_fr: "Ouzbékistan", flag: 211 },
        { iso2: "VU", iso3: "VUT", name: "Vanuatu", name_fr: "Vanuatu", flag: 212 },
        { iso2: "VA", iso3: "VAT", name: "Vatican City", name_fr: "Saint-Siège [État de la Cité du Vatican]", flag: 0 },
        { iso2: "VE", iso3: "VEN", name: "Venezuela", name_fr: "Venezuela, République bolivarienne du ", flag: 213 },
        { iso2: "VN", iso3: "VNM", name: "Viet Nam", name_fr: "Viet Nam", flag: 214 },
        { iso2: "WF", iso3: "WLF", name: "Wallis and Futuna", name_fr: "Wallis-et-Futuna ", flag: 216 },
        { iso2: "EH", iso3: "ESH", name: "Western Sahara", name_fr: "Sahara occidental", flag: 0 },
        { iso2: "YE", iso3: "YEM", name: "Yemen", name_fr: "Yémen", flag: 217 },
        { iso2: "ZM", iso3: "ZMB", name: "Zambia", name_fr: "Zambie", flag: 218 },
        { iso2: "ZW", iso3: "ZWE", name: "Zimbabwe", name_fr: "Zimbabwe", flag: 219 }
    ];

    /** Input field modes.
    * @memberof pca
    * @readonly
    * @enum {number} */
    pca.countryNameType = {
        /** The full country name */
        NAME: 0,
        /** The ISO 2-char code, e.g. GB */
        ISO2: 1,
        /** The ISO 3-char code, e.g. GBR */
        ISO3: 2
    };

    /**
    * Country List options.
    * @typedef {Object} pca.CountryList.Options
    * @property {string} [defaultCode] - The default country as an ISO 3-char code.
    * @property {string} [fallbackCode] - The default country as an ISO 3-char code in the case that the defaultCode is not present in the list.
    * @property {string} [value] - The initial value.
    * @property {string} [codesList] - A comma separated list of ISO 2-char or 3-char country codes for the basis of the list.
    * @property {boolean} [fillOthers=true] - If a codesList is provided, any remaining countries will be appended to the bottom of the list.
    * @property {prepopulate} [fillOthers=true] - When the country is changed, any fields will be populated.
    * @property {string} [nameLanguage=en] - The language for country names, only en and fr are supported.
    * @property {pca.countryNameType} [nameType=NAME] - The text format of the country name for populating an input field.
    * @property {pca.countryNameType} [valueType=ISO3] - The value format of a country option for populating a select list.
    */

    /** Creates an autocomplete list with country options.
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {Array.<HTMLElement>} fields - A list of input elements to bind to.
    * @param {pca.CountryList.Options} [options] - Additional options to apply to the list.
    */
    pca.CountryList = function (fields, options) {
        /** @lends pca.CountryList.prototype */
        var countrylist = new pca.Eventable(this);

        /** The current country fields
        * @type {Array.<HTMLElement>} */
        countrylist.fields = fields || [];
        /** The current country fields
        * @type {Array.<Object>} */
        countrylist.options = options || {};

        //parse the options
        countrylist.options.defaultCode = countrylist.options.defaultCode || "";
        countrylist.options.value = countrylist.options.value || "";
        countrylist.options.codesList = countrylist.options.codesList || "";
        countrylist.options.fillOthers = countrylist.options.fillOthers || false;
        countrylist.options.list = countrylist.options.list || {};
        countrylist.options.populate = typeof countrylist.options.populate == "boolean" ? countrylist.options.populate : true;
        countrylist.options.prepopulate = typeof countrylist.options.prepopulate == "boolean" ? countrylist.options.prepopulate : true;
        countrylist.options.language = countrylist.options.language || "en";
        countrylist.options.nameType = countrylist.options.nameType || pca.countryNameType.NAME;
        countrylist.options.valueType = countrylist.options.valueType || pca.countryNameType.NAME;
        countrylist.options.fallbackCode = countrylist.options.fallbackCode || "GBR";
        countrylist.options.list.type = "countrylist";

        /** The list
        * @type {pca.AutoComplete} */
        countrylist.autocomplete = new pca.AutoComplete(countrylist.fields, countrylist.options.list);
        /** The current country
        * @type {pca.Country} */
        countrylist.country = null;
        countrylist.textChanged = false;
        countrylist.nameProperty = countrylist.options.language === "fr" ? "name_fr" : "name";
        countrylist.template = "<div class='pcaflag'></div><div class='pcaflaglabel'>{" + countrylist.nameProperty + "}</div>";

        countrylist.load = function () {
            pca.addClass(countrylist.autocomplete.element, "pcacountrylist");

            //country has been selected
            function selectCountry(country) {
                countrylist.change(country);
                countrylist.fire("select", country);
            }

            //add countries to the list
            if (countrylist.options.codesList) {
                var codesSplit = countrylist.options.codesList.replace(/\s/g, "").split(","),
                    filteredList = [];

                countrylist.autocomplete.clear();

                for (var i = 0; i < codesSplit.length; i++) {
                    var code = codesSplit[i].toString().toUpperCase();

                    for (var c = 0; c < pca.countries.length; c++) {
                        if (pca.countries[c].iso2 === code || pca.countries[c].iso3 === code) {
                            filteredList.push(pca.countries[c]);
                            break;
                        }
                    }
                }

                if (countrylist.options.fillOthers) {
                    for (var o = 0; o < pca.countries.length; o++) {
                        var contains = false;

                        for (var f = 0; f < filteredList.length; f++) {
                            if (pca.countries[o].iso3 === filteredList[f].iso3)
                                contains = true;
                        }

                        if (!contains) filteredList.push(pca.countries[o]);
                    }
                }

                countrylist.autocomplete.clear().add(filteredList, countrylist.template, selectCountry);
            }
            else countrylist.autocomplete.clear().add(pca.countries, countrylist.template, selectCountry);

            //set flags and add alternate filter tags to each country
            countrylist.autocomplete.list.collection.all(function (item) {
                countrylist.setFlagPosition(item.element.firstChild, item.data.flag);
                item.tag += " " + pca.formatTag(item.data.iso3 + (item.data.alternates ? " " + item.data.alternates.join(" ") : ""));
            });

            //always show the full list to begin with
            countrylist.autocomplete.listen("focus", function () {
                countrylist.autocomplete.showAll();
            });


            //user has changed country on the form
            function textChanged(field) {
                //for a select list we should try the value and label
                if (pca.selectList(field)) {
                    var selected = pca.getSelectedItem(field);
                    countrylist.change(countrylist.find(selected.value) || countrylist.find(selected.text));
                }
                else
                    countrylist.setCountry(pca.getValue(field));

                countrylist.textChanged = false;
            }

            //automatically set the country when the field value is changed
            countrylist.autocomplete.listen("change", function (field) {
                countrylist.autocomplete.visible ? countrylist.textChanged = true : textChanged(field);
            });

            countrylist.autocomplete.listen("hide", function () {
                if (countrylist.textChanged) textChanged(countrylist.autocomplete.field);
            });

            //set the initial value
            if (countrylist.options.value) countrylist.country = countrylist.find(countrylist.options.value);
            if (!countrylist.country && countrylist.options.defaultCode) countrylist.country = countrylist.find(countrylist.options.defaultCode);

            //use the fallback or first in the list
            countrylist.country = countrylist.country || (countrylist.options.codesList ? countrylist.first() : countrylist.find(countrylist.options.fallbackCode)) || countrylist.first() || countrylist.find(countrylist.options.fallbackCode);

            countrylist.fire("load");
        }

        /** Returns the name of the country with the current nameType option.
        * @param {pca.Country} [country] - The country object to get the desired name of. */
        countrylist.getName = function (country) {
            switch (countrylist.options.nameType) {
                case pca.countryNameType.NAME:
                    return (country || countrylist.country)[countrylist.nameProperty];
                case pca.countryNameType.ISO2:
                    return (country || countrylist.country).iso2;
                case pca.countryNameType.ISO3:
                    return (country || countrylist.country).iso3;
            }

            return (country || countrylist.country)[countrylist.nameProperty];
        }

        /** Returns the value of the country with the current valueType option.
        * @param {pca.Country} [country] - The country object to get the desired value of. */
        countrylist.getValue = function (country) {
            switch (countrylist.options.valueType) {
                case pca.countryNameType.NAME:
                    return (country || countrylist.country)[countrylist.nameProperty];
                case pca.countryNameType.ISO2:
                    return (country || countrylist.country).iso2;
                case pca.countryNameType.ISO3:
                    return (country || countrylist.country).iso3;
            }

            return (country || countrylist.country).iso3;
        }

        /** Populates all bound country fields.
        * @fires populate */
        countrylist.populate = function () {
            if (!countrylist.options.populate) return;

            var name = countrylist.getName(),
                value = countrylist.getValue();

            for (var i = 0; i < countrylist.fields.length; i++) {
                var countryField = pca.getElement(countrylist.fields[i]),
                    currentValue = pca.getValue(countryField);

                pca.setValue(countryField, (pca.selectList(countryField) ? value : name));

                if (countrylist.options.prepopulate && currentValue !== pca.getValue(countryField))
                    pca.fire(countryField, "change");
            }

            countrylist.fire("populate");
        }

        /** Finds a matching country from a name or code.
        * @param {string} country - The country name or code to find.
        * @returns {pca.Country} The country object. */
        countrylist.find = function (country) {
            country = country.toString().toUpperCase();

            function isAlternate(item) {
                if (item.data.alternates) {
                    for (var a = 0; a < item.data.alternates.length; a++) {
                        if (item.data.alternates[a].toUpperCase() === country)
                            return true;
                    }
                }

                return false;
            }

            return (countrylist.autocomplete.list.collection.first(function (item) {
                return item.data.iso2.toUpperCase() === country || item.data.iso3.toUpperCase() === country || item.data.name.toUpperCase() === country || item.data.name_fr.toUpperCase() === country || isAlternate(item);
            }) || {}).data;
        }

        /** Returns the first country in the list.
        * @returns {pca.Country} The first country object. */
        countrylist.first = function () {
            return countrylist.autocomplete.list.collection.first().data;
        }

        /** Country has been selected.
        * @param {pca.Country} country - The country to change to.
        * @fires change */
        countrylist.change = function (country, isByIp) {
            isByIp = typeof isByIp == "undefined" ? false : true;
            if (country) {
                countrylist.country = country;
                countrylist.populate();
                countrylist.textChanged = false;
                countrylist.fire("change", countrylist.country, isByIp);
            }
        }

        /** Sets the index of a flag icon element.
        * @param {HTMLElement} element - The flag icon element to change.
        * @param {number} index - The country flag icon index. */
        countrylist.setFlagPosition = function (element, index) {
            element.style.backgroundPosition = "-1px -" + (index * 16 + 2) + "px";
        }

        /** Creates a dynamic flag icon.
        * @returns {HTMLDivElement} A dynamic HTML DIV showing the flag as an icon. */
        countrylist.flag = function () {
            var flag = pca.create("div", { className: "pcaflag" });

            function updateFlag(country) {
                countrylist.setFlagPosition(flag, country.flag);
            }

            updateFlag(countrylist.country);
            countrylist.listen("change", updateFlag);

            return flag;
        }

        /** Sets the country
        * @param {string} country - The country name or code to change to. */
        countrylist.setCountry = function (country, isByIp) {
            isByIp = typeof isByIp == "undefined" ? false : isByIp;
            countrylist.change(countrylist.find(country), isByIp);
            return countrylist;
        }

        /** Sets the country based on the current client IP.
        * @param {string} key - A license key for the request. */
        countrylist.setCountryByIP = function (key) {
            function success(response) {
                if (response.length && response[0].Iso3)
                    countrylist.setCountry(response[0].Iso3, true);
            }

            if (key) pca.fetch("Extras/Web/Ip2Country/v1.10", { Key: key }, success);
        }

        countrylist.load();
    }
})();
(function (window, undefined) {
    var pca = window.pca = window.pca || {},
        document = window.document;


    pca.browser = (function () {
        var ua = navigator.userAgent, tem,
            M = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [],
            fullVersionMatch = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*([\d.]+)/i) || [];
        if (/trident/i.test(M[1])) {
            tem = /\brv[ :]+(\d+)/g.exec(ua) || [];
            return { name: 'IE', version: (tem[1] || '') };
        }
        if (M[1] === 'Chrome') {
            tem = ua.match(/\b(OPR|Edge)\/(\d+)/);
            if (tem != null) return { name: tem[1].replace('OPR', 'Opera'), version: tem[2] };
        }
        M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, '-?'];
        if ((tem = ua.match(/version\/(\d+)/i)) != null) M.splice(1, 1, tem[1]);
        if (fullVersionMatch && fullVersionMatch[2]) {
            return { name: M[0], version: M[1], fullVersion: fullVersionMatch[2] };
        }
        return { name: M[0], version: M[1] };
    })();


})(window);
/*3.97 - No change to sync the style changes update to version 3.97*/

(function () {
    var pca = window.pca = window.pca || {};

    /** Input field modes. Bit set values.
    * @memberof pca
    * @readonly
    * @enum {number} */
    pca.fieldMode = {
        /** Default of search and populate */
        DEFAULT: 3,
        /** The field will be ignored. */
        NONE: 0,
        /** Search from this field. */
        SEARCH: 1,
        /** Set the value of this field. */
        POPULATE: 2,
        /** Do not overwrite. */
        PRESERVE: 4,
        /** Show just the country list. */
        COUNTRY: 8
    };

    /** Search filtering modes.
    * @memberof pca
    * @readonly
    * @enum {string} */
    pca.filteringMode = {
        /** Addresses results will be returned */
        ADDRESS: "Address",
        /** Streets results will be returned */
        STREET: "Street",
        /** Cities, towns and districts will be returned */
        LOCALITY: "Locality",
        /** Postcodes will be returned */
        POSTCODE: "Postcode",
        /** Everything will be returned */
        EVERYTHING: ""
    };

    /** Search ordering mode.
    * @memberof pca
    * @readonly
    * @enum {string} */
    pca.orderingMode = {
        /** Default ordering will be used */
        DEFAULT: "UserLocation",
        /** Results will be ordered by current proximity */
        LOCATION: "UserLocation",
        /** No special ordering */
        NONE: ""
    };

    /** Text messages to display
    * @memberof pca */
    pca.messages = {
        "en": {
            DIDYOUMEAN: "Did you mean:",
            NORESULTS: "No results found",
            KEEPTYPING: "Keep typing your address to display more results",
            RETRIEVEERROR: "Sorry, we could not retrieve this address",
            SERVICEERROR: "Service Error:",
            COUNTRYSELECT: "Change Country",
            NOLOCATION: "Sorry, we could not get your location",
            NOCOUNTRY: "Sorry, we could not find this country",
            MANUALENTRY: "I cannot find my address. Let me type it in",
            RESULTCOUNT: "<b>{count}</b> matching results",
            GEOLOCATION: "Use my Location",
            COUNTRYHELP: "The selected country is {country}. Press control and shift and C to change the selected country.",
            INCOUNTRYHELP: "You are in the country select menu. The selected country is {country}. Press control and shift and C to return to the address search.",
            DRILLDOWN: "There are multiple address options at this location, select this location to expand the address options.",
            POPULATED: "Address has populated",
            ADDRESSAVAILABLE: "address available",
            ADDRESSESAVAILABLE: "addresses available",
            COUNTRYAVAILABLE: "country available",
            COUNTRIESAVAILABLE: "countries available",
            ADDRESSLIST: "address list"
        },
        "cy": {
            DIDYOUMEAN: "A oeddech yn meddwl:",
            NORESULTS: "Dim canlyniadau ar ganlyniadau",
            KEEPTYPING: "Cadwch teipio eich cyfeiriad i arddangos mwy o ganlyniadau",
            RETRIEVEERROR: "Mae'n ddrwg gennym, ni allem adfer y cyfeiriad hwn",
            SERVICEERROR: "Gwall gwasanaeth:",
            COUNTRYSELECT: "Dewiswch gwlad",
            NOLOCATION: "Mae'n ddrwg gennym, nid oeddem yn gallu cael eich lleoliad",
            NOCOUNTRY: "Mae'n ddrwg gennym, ni allem ddod o hyd y wlad hon",
            MANUALENTRY: "Ni allaf ddod o hyd i fy nghyfeiriad. Gadewch i mi deipio mewn",
            RESULTCOUNT: "<b>{count}</b> Canlyniadau paru",
            GEOLOCATION: "Defnyddiwch fy Lleoliad",
            COUNTRYHELP: "Y wlad a ddewiswyd yw {country}. Pwyswch reolaeth a shifft a C i newid y wlad a ddewiswyd.",
            INCOUNTRYHELP: "Rydych chi yn y ddewislen dewis gwlad. Y wlad a ddewiswyd yw {country}. Pwyswch control a shifft a C i ddychwelyd i'r chwiliad cyfeiriad.",
            DRILLDOWN: "Mae sawl opsiwn cyfeiriad yn y lleoliad hwn, dewiswch y lleoliad hwn i ehangu'r opsiynau cyfeiriad.",
            POPULATED: "Mae'r cyfeiriad wedi poblogi",
            ADDRESSAVAILABLE: "cyfeiriad ar gael",
            ADDRESSESAVAILABLE: "gyfeiriad ar gael",
            COUNTRYAVAILABLE: "gwlad ar gael",
            COUNTRIESAVAILABLE: "gwledydd ar gael",
            ADDRESSLIST: "rhestr cyfeiriadau"
        },
        "fr": {
            DIDYOUMEAN: "Vouliez-vous dire:",
            NORESULTS: "Aucun résultat n'a été trouvé",
            KEEPTYPING: "Continuer à taper votre adresse pour afficher plus de résultats",
            RETRIEVEERROR: "Désolé , nous ne pouvions pas récupérer cette adresse",
            SERVICEERROR: "Erreur de service:",
            COUNTRYSELECT: "Changer de pays",
            NOLOCATION: "Désolé, nous n'avons pas pu obtenir votre emplacement",
            NOCOUNTRY: "Désolé, nous n'avons pas trouvé ce pays",
            MANUALENTRY: "Je ne peux pas trouver mon adresse. Permettez-moi de taper dans",
            RESULTCOUNT: "<b>{count}</b> résultats correspondants",
            GEOLOCATION: "Utiliser ma position",
            COUNTRYHELP: "Le pays sélectionné est {country}. Appuyez sur Ctrl et Maj et C pour changer le pays sélectionné.",
            INCOUNTRYHELP: "Vous êtes dans le menu de sélection du pays. Le pays sélectionné est {country}. Appuyez sur Ctrl et Maj et sur C pour revenir à la recherche d'adresse.",
            DRILLDOWN: "Il existe plusieurs options d'adresse à cet emplacement, sélectionnez cet emplacement pour développer les options d'adresse.",
            POPULATED: "L'adresse a été remplie",
            ADDRESSAVAILABLE: "adresse disponible",
            ADDRESSESAVAILABLE: "adresses disponibles",
            COUNTRYAVAILABLE: "pays disponible",
            COUNTRIESAVAILABLE: "pays disponibles",
            ADDRESSLIST: "liste d'adresses"
        },
        "de": {
            DIDYOUMEAN: "Meinten Sie:",
            NORESULTS: "Keine Adressen gefunden",
            KEEPTYPING: "Geben Sie mehr von Ihrer Adresse ein, um weitere Ergebnisse anzuzeigen",
            RETRIEVEERROR: "Wir konnten diese Adresse leider nicht abrufen",
            SERVICEERROR: "Service-Fehler:",
            COUNTRYSELECT: "Land wechseln",
            NOLOCATION: "Wir konnten Ihren Standort leider nicht finden",
            NOCOUNTRY: "Wir konnten dieses Land leider nicht finden",
            MANUALENTRY: "Ich kann meine Adresse nicht finden. Lassen Sie mich es manuell eingeben",
            RESULTCOUNT: "<b>{count}</b> passenden Ergebnisse",
            GEOLOCATION: "Meinen Standort verwenden",
            COUNTRYHELP: "Das ausgewählte Land ist {country}. Drücken Sie Strg und Umschalt und C, um das ausgewählte Land zu ändern.",
            INCOUNTRYHELP: "Sie befinden sich im Länderauswahlmenü. Das ausgewählte Land ist {country}. Drücken Sie Strg und Umschalttaste und C, um zur Adresssuche zurückzukehren.",
            DRILLDOWN: "An diesem Speicherort gibt es mehrere Adressoptionen. Wählen Sie diesen Speicherort aus, um die Adressoptionen zu erweitern.",
            POPULATED: "Adresse wurde ausgefüllt",
            ADDRESSAVAILABLE: "Adresse verfügbar",
            ADDRESSESAVAILABLE: "Adressen verfügbar",
            COUNTRYAVAILABLE: "Land verfügbar",
            COUNTRIESAVAILABLE: "Länder verfügbar",
            ADDRESSLIST: "Adressliste"
        }
    };

    /** An example retrieve response.
    * @memberof pca */
    pca.exampleAddress = {
        "Id": "GBR|PR|52509479|0|0|0",
        "DomesticId": "52509479",
        "Language": "ENG",
        "LanguageAlternatives": "ENG",
        "Department": "",
        "Company": "Postcode Anywhere (Europe) Ltd",
        "SubBuilding": "",
        "BuildingNumber": "",
        "BuildingName": "Waterside",
        "SecondaryStreet": "",
        "Street": "Basin Road",
        "Block": "",
        "Neighbourhood": "",
        "District": "",
        "City": "Worcester",
        "Line1": "Waterside",
        "Line2": "Basin Road",
        "Line3": "",
        "Line4": "",
        "Line5": "",
        "AdminAreaName": "Worcester",
        "AdminAreaCode": "47UE",
        "Province": "Worcestershire",
        "ProvinceName": "Worcestershire",
        "ProvinceCode": "",
        "PostalCode": "WR5 3DA",
        "CountryName": "United Kingdom",
        "CountryIso2": "GB",
        "CountryIso3": "GBR",
        "CountryIsoNumber": 826,
        "SortingNumber1": "94142",
        "SortingNumber2": "",
        "Barcode": "(WR53DA1PX)",
        "Label": "Postcode Anywhere (Europe) Ltd\nWaterside\nBasin Road\n\nWorcester\nWR5 3DA\nUnited Kingdom",
        "Type": "Commercial",
        "DataLevel": "Premise",
        "Field1": "",
        "Field2": "",
        "Field3": "",
        "Field4": "",
        "Field5": "",
        "Field6": "",
        "Field7": "",
        "Field8": "",
        "Field9": "",
        "Field10": "",
        "Field11": "",
        "Field12": "",
        "Field13": "",
        "Field14": "",
        "Field15": "",
        "Field16": "",
        "Field17": "",
        "Field18": "",
        "Field19": "",
        "Field20": ""
    };

    /** Formatting templates.
    * @memberof pca */
    pca.templates = {
        AUTOCOMPLETE: "{HighlightedText}{<span class='pcadescription'>{HighlightedDescription}</span>}",
        AUTOCOMPLETE_UTILITY: "{<span class='pcautilitytype'>({UtilityType})</span>}{HighlightedText}{<span class='pcadescription'>{HighlightedDescription}</span>}"
    };

    /**
    * Address control field binding.
    * @typedef {Object} pca.Address.Binding
    * @property {string} element - The id or name of the element.
    * @property {string} field - The format string for the address field, e.g. "{Line1}"
    * @property {pca.fieldMode} mode - The mode of the field.
    */

    /**
    * Address control bar options.
    * @typedef {Object} pca.Address.BarOptions
    * @property {boolean} [visible=false] - Show the search bar.
    * @property {boolean} [showCountry=true] - Show the country flag.
    * @property {boolean} [showLogo=true] - Show the logo.
    * @property {boolean} [logoLink=true] - Use the logo as a web link.
    * @property {string} [logoClass] - The CSS class name for the logo.
    * @property {string} [logoTitle] - The hover text for the logo.
    * @property {string} [logoUrl] - The URL to link to from the logo.
    */

    /**
    * Web service search options
    * @typedef {Object} pca.Address.SearchOptions
    * @property {number} [maxSuggestions] - The maximum number of autocomplete suggestions to get.
    * @property {number} [maxResults] - The maximum number of address results to get.
    */

    /**
    * Address control options.
    * @typedef {Object} pca.Address.Options
    * @property {string} key - The key to use for service request authentication.
    * @property {string} [name] - A reference for the control used as an id to provide ARIA support.
    * @property {boolean} [populate=true] - Used to enable or disable population of all fields.
    * @property {boolean} [onlyInputs=false] - Only input fields will be populated.
    * @property {boolean} [autoSearch=false] - Search will be triggered on field focus.
    * @property {boolean} [preselect=true] - Automatically highlight the first item in the list.
    * @property {boolean} [prompt=false] - Shows a message to prompt the user for more detail.
    * @property {number} [promptDelay=0] - The time in milliseconds before the control will prompt the user for more detail.
    * @property {boolean} [inlineMessages=false] - Shows messages within the list rather than above the search field.
    * @property {boolean} [setCursor=false] - Updates the input field with the current search text.
    * @property {boolean} [matchCount=false] - Shows the number of possible matches while searching.
    * @property {number} [minSearch=1] - Search will be triggered on field focus.
    * @property {number} [minItems=1] - The minimum number of items to show in the list.
    * @property {number} [maxItems=7] - The maximum number of items to show in the list.
    * @property {boolean} [manualEntry=false] - If no results are found, the message can be clicked to disable the control.
    * @property {boolean} [manualEntryItem=false] - Adds an item to the bottom of the list which enables manual address entry.
    * @property {number} [disableTime=60000] - The time in milliseconds to disable the control for manual entry.
    * @property {boolean} [suppressAutocomplete=true] - Suppress the default browser field autocomplete on search fields.
    * @property {boolean} [setCountryByIP=false] - Automatically set the country based upon the user IP address.
    * @property {string} [culture] - Force set the culture for labels, e.g. "en-us", "fr-ca".
    * @property {string} [languagePreference] - The preferred language for the selected address, e.g. "eng", "fra".
    * @property {pca.filteringMode} [filteringMode] - The type of results to search for.
    * @property {pca.orderingMode} [orderingMode] - The order in which to display results.
    * @property {pca.CountryList.Options} [countries] - Options for the country list.
    * @property {pca.AutoComplete.Options} [list] - Options for the search list.
    * @property {pca.Address.BarOptions} [bar] - Options for the address control footer bar.
    * @property {pca.Address.SearchOptions} [search] - Options for control search results.
    */

    /** Address searching component.
    * @memberof pca
    * @constructor
    * @mixes Eventable
    * @param {Array.<pca.Address.Binding>} fields - A list of field bindings.
    * @param {pca.Address.Options} options - Additional options to apply to the control.
    */
    pca.Address = function (fields, options) {
        /** @lends pca.Address.prototype */

        function parseOptions(options) {
            options = options || {};
            options.name = options.name || "";
            options.source = options.source || "";
            options.populate = typeof (options.populate) == "boolean" ? options.populate : true;
            options.onlyInputs = typeof (options.onlyInputs) == "boolean" ? options.onlyInputs : false;
            options.autoSearch = typeof (options.autoSearch) == "boolean" ? options.autoSearch : false;
            options.preselect = typeof (options.preselect) == "boolean" ? options.preselect : true;
            options.minSearch = options.minSearch || 1;
            options.minItems = options.minItems || 1;
            options.maxItems = options.maxItems || 7;
            options.advancedFields = options.advancedFields || [];
            options.manualEntry = typeof (options.manualEntry) == "boolean" ? options.manualEntry : false;
            options.manualEntryItem = typeof (options.manualEntryItem) == "boolean" ? options.manualEntryItem : false;
            options.disableTime = options.disableTime || 60000;
            options.suppressAutocomplete = typeof (options.suppressAutocomplete) == "boolean" ? options.suppressAutocomplete : true;
            options.brand = options.brand || "PostcodeAnywhere" || "PostcodeAnywhere";
            options.product = options.product || "Capture+";
            options.culture = options.culture || "en-GB";
            options.prompt = typeof (options.prompt) == "boolean" ? options.prompt : false;
            options.promptDelay = options.promptDelay || 0;
            options.inlineMessages = typeof (options.inlineMessages) == "boolean" ? options.inlineMessages : false;
            options.setCursor = typeof (options.setCursor) == "boolean" ? options.setCursor : false;
            options.matchCount = typeof (options.matchCount) == "boolean" ? options.matchCount : false;
            options.languagePreference = options.languagePreference || "";
            options.filteringMode = options.filteringMode || pca.filteringMode.EVERYTHING;
            options.orderingMode = options.orderingMode || pca.orderingMode.DEFAULT;
            options.countries = options.countries || {};
            options.countries.codesList = options.countries.codesList || "";
            options.countries.defaultCode = options.countries.defaultCode || "";
            options.setCountryByIP = typeof (options.setCountryByIP) == "boolean" && !options.countries.defaultCode ? options.setCountryByIP : false;
            options.countries.value = options.countries.value || "";
            options.countries.prepopulate = typeof (options.countries.prepopulate) == "boolean" ? options.countries.prepopulate : true;
            options.list = options.list || {};
            options.list.name = options.name ? options.name + "_results" : "";
            options.list.maxItems = options.list.maxItems || options.maxItems;
            options.list.minItems = options.list.minItems || options.minItems;
            options.countries.list = options.countries.list || pca.extend({}, options.list);
            options.countries.list.name = options.name ? options.name + "_countries" : "";
            options.GeoLocationEnabled = options.GeoLocationEnabled == 'true' || options.GeoLocationEnabled == true;
            options.GeoLocationRadius = options.GeoLocationRadius || 50;
            options.GeoLocationMaxItems = options.GeoLocationMaxItems || 10;
            options.utilitiesenabled = typeof (options.utilitiesenabled) == "boolean" ? options.utilitiesenabled : false;
            options.utilitiesutilitycodetype = options.utilitiesutilitycodetype || "ALL";
            /* If geolocation is enabled, it only works for UK */
            if (options.GeoLocationEnabled) {
                options.setCountryByIP = false;
            }
            options.bar = options.bar || {};
            /* If geolocation is turned on, we need the bar to be visible. */
            options.bar.visible = options.GeoLocationEnabled ? true : typeof options.bar.visible == "boolean" ? options.bar.visible : false;
            options.bar.showCountry = typeof (options.bar.showCountry) == "boolean" ? options.bar.showCountry : false;
            options.bar.showLogo = typeof (options.bar.showLogo) == "boolean" ? options.bar.showLogo : true;
            options.bar.logoLink = typeof (options.bar.logoLink) == "boolean" ? options.bar.logoLink : false;
            options.bar.logoClass = options.bar.logoClass || "pcalogo" || "pcalogo";
            options.bar.logoTitle = options.bar.logoTitle || "Powered by www.pcapredict.com";
            options.bar.logoUrl = options.bar.logoUrl || "http://www.pcapredict.com/";
            options.search = options.search || {};
            options.search.limit = options.search.limit || options.maxItems;
            options.search.origin = options.search.origin || options.countries.defaultCode || "";
            options.search.countries = options.search.countries || options.countries.codesList || "";
            options.search.datasets = options.search.datasets || "";
            options.search.language = options.search.language || "";
        };

        parseOptions(options);

        var address = new pca.Eventable(this);

        /** The current field bindings
        * @type {Array.<pca.Address.Binding>} */
        address.fields = fields || [];

        /** The current options
        * @type {pca.Address.Options} */
        address.options = options;

        /** The current key for service request authentication
        * @type {string} */
        address.key = address.options.key || "";

        //internal properties
        address.country = address.options.countries.defaultCode; //the country to search in
        address.origin = address.options.search.origin;
        address.advancedFields = address.options.advancedFields; //advanced field formats
        address.initialSearch = false; //when this has been done the list will filter
        address.searchContext = null; //stored when filtering to aid searching
        address.lastActionTimer = null; //the time of the last user interaction with the control
        address.notifcationTimer = null; //the time to show a notification for
        address.storedSearch = null; //stored value from search when country is switched
        address.geolocation = null; //users current geolocation when searching by location
        address.geoLocationButton = null;
        address.loaded = false; //current state of the control
        address.language = "en"; //current language code for the control
        address.filteringMode = address.options.filteringMode; //search filtering mode
        address.orderingMode = address.options.orderingMode; //search ordering mode
        address.testMode = false;
        address.instance = null;
        address.frugalSearch = true; //skip searches that would not refine the current results
        address.blockSearches = true; //block subsequent search requests while waiting for a response
        address.cacheRequests = true; //cache search and retrieve request results

        /** The search list
        * @type {pca.AutoComplete} */
        address.autocomplete = null;
        /** The country list
        * @type {pca.CountryList} */
        address.countrylist = null;
        address.messageBox = null;

        /** Initialise the control.
        * @fires load */
        address.load = function () {
            var searchFields = [],
                countryFields = [];

            //create a list of search and country fields
            for (var f = 0; f < address.fields.length; f++) {
                var field = address.fields[f];

                field.mode = typeof (field.mode) == "number" ? field.mode : pca.fieldMode.DEFAULT;

                if (field.mode & pca.fieldMode.COUNTRY) {
                    countryFields.push(field.element);

                    //tell the countrylist to use the same format
                    if (/CountryIso2/.test(field.field)) {
                        address.options.countries.nameType = address.options.countries.nameType || pca.countryNameType.ISO2;
                        address.options.countries.valueType = address.options.countries.valueType || pca.countryNameType.ISO2;
                    }
                    if (/CountryIso3/.test(field.field)) {
                        address.options.countries.nameType = address.options.countries.nameType || pca.countryNameType.ISO3;
                        address.options.countries.valueType = address.options.countries.valueType || pca.countryNameType.ISO3;
                    }
                }
                else if (field.mode & pca.fieldMode.SEARCH) {
                    searchFields.push(field.element);
                    var elem = pca.getElement(field.element);
                    if (elem) {
                        elem.setAttribute("role", "combobox");
                        elem.setAttribute("aria-describedby", "pca-country-button-help-text pca-help-text");
                        elem.setAttribute("aria-autocomplete", "list");
                        elem.setAttribute("aria-expanded", "false");
                        if (address.options.suppressAutocomplete) {
                            address.preventAutocomplete(elem);
                        }
                    }
                }

                //check for advanced fields
                field.field = address.checkFormat(field.field);
            }

            //set the current language for UI
            address.detectLanguage();

            //create an autocomplete list to display search results
            address.options.list.name = "address_list";
            address.options.list.language = address.language;
            address.options.list.ariaLabel = pca.messages[address.language].ADDRESSLIST;
            address.autocomplete = new pca.AutoComplete(searchFields, address.options.list);
            address.autocomplete.address = address;

            //disable standard filter, this will be handled
            address.autocomplete.skipFilter = true;

            //marker function for when we display results with utilities lookup enabled.
            address.autocomplete.addUtilityLookupToTop = false;
            address.autocomplete.checkIfProbablyUtilitySearch = function () {
                // Nested, reduces logic evaluation.
                if (address.options.utilitiesenabled) {
                    if (pca.getValue(address.autocomplete.field).replace(/[^0-9]/g, "").length >= 5) {
                        address.autocomplete.addUtilityLookupToTop = true;

                        // backup what user might have set.
                        address.userSetFrugalSearch = address.frugalSearch;
                        address.userSetCacheRequests = address.cacheRequests;

                        // turn them off.
                        address.frugalSearch = false;
                        address.cacheRequests = false;
                    }
                    else {
                        address.autocomplete.addUtilityLookupToTop = false;

                        // restore the user's preferences.
                        address.frugalSearch = address.userSetFrugalSearch;
                        address.cacheRequests = address.userSetCacheRequests;
                    }
                }
            };

            //listen for the user typing something
            address.autocomplete.listen("keyup", function (key) {
                pca.activeAddress = address;
                address.autocomplete.checkIfProbablyUtilitySearch();
                if (address.countrylist.autocomplete.visible)
                    address.countrylist.autocomplete.handleKey(key);
                else if (address.autocomplete.controlDown && key === 40)
                    address.switchToCountrySelect();
                else if (key === 0 || key === 8 || key === 32 || (key >= 36 && key <= 40 && !address.initialSearch) || key > 40)
                    address.searchFromField();
            });

            //listen to the user pasting something
            address.autocomplete.listen("paste", function () {
                address.autocomplete.checkIfProbablyUtilitySearch();
                address.newSearch();
                address.searchFromField();
            });

            //show just the bar when a field gets focus
            address.autocomplete.listen("focus", address.focus);

            //pass through the show event
            address.autocomplete.listen("show", function () {
                address.fire("show");
            });

            //pass through the hide event
            address.autocomplete.listen("hide", function () {
                address.fire("hide");
            });

            //search on double click
            address.autocomplete.listen("dblclick", address.searchFromField);

            //if the list says its filtered out some results we need to load more
            address.autocomplete.list.listen("filter", function () {
                if (address.frugalSearch)
                    address.search(pca.getValue(address.autocomplete.field));
            });

            //if the user hits delete we can't be sure we've done the first search
            address.autocomplete.listen("delete", address.newSearch);

            //get initial country value
            if (!address.options.countries.value && countryFields.length)
                address.options.countries.value = pca.getValue(countryFields[0]);

            //set the language for country names
            address.options.countries.language = address.language;

            //create a countrylist to change the current country
            address.countrylist = new pca.CountryList(countryFields, address.options.countries);
            address.countrylist.autocomplete.options.emptyMessage = pca.messages[address.language].NOCOUNTRY;
            address.country = address.countrylist.country.iso3;

            //when the country is changed
            address.countrylist.listen("change", function (country, isByIp) {
                address.country = country && country.iso3 ? country.iso3 : address.options.countries.defaultCode;
                if (isByIp) {
                    address.updateGeoLocationActive();
                }
                address.origin = address.country;
                address.inCountryListMode = false;
                var countryDescription = address.autocomplete.footer.element.querySelector("#pca-country-button-help-text");
                if (countryDescription) {
                    countryDescription.innerText = pca.formatLine(
                        {
                            country: country ? (address.language === "fr" ? country.name_fr : country.name) : "",
                        },
                        pca.messages[address.language].COUNTRYHELP
                    );
                }
                address.fire("country", country);
            });

            //switch back to the regular list when a country is selected
            address.countrylist.listen("select", address.switchToSearchMode);

            //pass through the show event
            address.countrylist.autocomplete.listen("show", function () {
                address.fire("show");
            });

            //when the list is closed restore the search state
            address.countrylist.autocomplete.listen("hide", function () {
                address.autocomplete.enable();

                if (address.storedSearch != null)
                    pca.setValue(address.autocomplete.field, address.storedSearch);

                address.storedSearch = null;
                address.fire("hide");
            });

            //add the logo to the footer - shown with results
            var link = pca.create("a", { href: address.options.bar.logoUrl, target: "_blank", rel: "nofollow" }),
                logo = pca.create("div", { className: (address.options.bar.logoClass + " pcalogo" + address.language), title: address.options.bar.logoTitle });
            if (address.options.bar.logoLink) link.appendChild(logo);
            else link = logo;
            address.autocomplete.footer.setContent(link);

            //do not show the button if there is only one country
            if (address.countrylist.autocomplete.list.collection.count === 1)
                address.options.bar.showCountry = false;

            //add reverse geocode button if required
            if (address.options.GeoLocationEnabled) {
                var reverseButton = pca.create("div", { className: "geoLocationIcon", title: pca.messages[address.language].GEOLOCATION });
                var reverseText = pca.create("div", { className: "geoLocationMessage", innerHTML: pca.messages[address.language].GEOLOCATION });
                pca.listen(reverseButton, "click", address.startGeoLocation);
                pca.listen(reverseText, "click", address.startGeoLocation);

                address.autocomplete.footer.setContent(reverseButton);
                address.autocomplete.footer.setContent(reverseText);

                address.geocodeButton = reverseButton;
            }

            //create a flag icon and add to the footer of the search list
            var flagbutton = pca.create("div", { className: "pcaflagbutton" });
            flagbutton.setAttribute("tabindex", 0);
            flagbutton.setAttribute("role", "button");
            flagbutton.setAttribute("id", (options.list.name || "") + "_button"),
                flagbutton.setAttribute("aria-labelledby", (options.list.name || "") + "_label");

            var flag = address.countrylist.flag();

            var message = pca.create("div", {
                className: "pcamessage pcadisableselect",
                innerHTML: pca.messages[address.language].COUNTRYSELECT,
            });
            message.setAttribute("id", (options.list.name || "addresslist_change_country") + "_label");

            var countryMessage = pca.create("div", {
                className: "pcamessage pcadisableselect",
                innerHTML: pca.messages[address.language].COUNTRYSELECT
            });
            countryMessage.setAttribute("id", (options.countries.list.name || "countrylist_change_country") + "_label");

            flagbutton.appendChild(message);
            flagbutton.appendChild(flag);

            //country a11y description
            var selectedCountry = pca.countries.find(function (c) {
                return c.iso3 == address.country;
            });
            var countryDescription = pca.create("span", {
                id: "pca-country-button-help-text",
                className: "pca-visually-hidden",
                innerText: pca.formatLine(
                    {
                        country: selectedCountry
                            ? address.language === "fr"
                                ? selectedCountry.name_fr
                                : selectedCountry.name
                            : "",
                    },
                    pca.messages[address.language].COUNTRYHELP
                ),
            });

            if (address.options.bar.showCountry) {
                address.autocomplete.footer.setContent(flagbutton);
                address.autocomplete.footer.setContent(countryDescription);
                address.countrylist.autocomplete.footer.setContent(countryMessage);
            }

            //clicking the flag button will show the country list
            pca.listen(flagbutton, "click", function (evt) {
                pca.smash(evt);
                address.switchToCountrySelect();
            });

            pca.listen(flagbutton, "keyup", function (evt) {
                if (evt.keyCode == 13) {
                    pca.smash(evt);
                    address.switchToCountrySelect();
                }
            });


            //switch to the logo
            address.showFooterLogo = function () {
                address.autocomplete.footer.element.classList.add('pca-showlogo');
                link.style.display = address.options.bar.showLogo ? "" : "none";
            };

            //switch to the message
            address.showFooterMessage = function () {
                link.style.display = address.options.bar.showCountry ? "none" : (address.options.bar.showLogo ? "" : "none");
            };

            //check if search bar is visible
            if (address.options.bar.visible) {
                address.autocomplete.footer.show();
                address.countrylist.autocomplete.footer.show();
                address.showFooterMessage();
            } else {
                address.autocomplete.hide();
                address.countrylist.autocomplete.footer.hide();
            }

            //add an item for manual entry
            if (address.options.manualEntryItem) {
                address.addManualEntryItem();
            }

            //get the users country by IP
            if (address.options.setCountryByIP) {
                address.setCountryByIP();
            } else {
                address.countrylist.setCountry(address.country);
            }

            //create the hovering message box
            address.messageBox = pca.create("div", { className: "pcatext pcanotification", id: "pca-help-text" });
            pca.append(address.messageBox, pca.container);

            //control load finished
            address.loaded = true;
            address.fire("load");
        };

        /** Searches based upon the content of the current field. */
        address.searchFromField = function () {
            var term = pca.getValue(address.autocomplete.field);

            if (term && !address.autocomplete.disabled && (!address.initialSearch || !address.frugalSearch) && term.length >= address.options.minSearch) {
                address.initialSearch = true;
                address.search(term);
            }
        };

        address.updateGeoLocationActive = function () {
            if (address.country == "GBR" && pca.supports("reverseGeo") && address.options.GeoLocationEnabled) {
                if (address.geocodeButton) {
                    pca.addClass(address.geocodeButton, "active");
                }
            } else {
                if (address.geocodeButton) {
                    pca.removeClass(address.geocodeButton, "active");
                }
            }
        };

        address.geolocationLookup = function (location) {
            if (location.coords) {
                var params = {
                    Key: address.key,
                    Latitude: location.coords.latitude,
                    Longitude: location.coords.longitude,
                    Items: address.options.GeoLocationMaxItems,
                    Radius: address.options.GeoLocationRadius
                };
                address.fire("geolocation", params);
                pca.fetch("Capture/Interactive/GeoLocation/v1.00", params, function (items, response) {
                    //success
                    pca.removeClass(address.geocodeButton, "working");
                    if (items.length)
                        address.display(items, pca.templates.AUTOCOMPLETE, response);
                    else
                        address.noResultsMessage();
                }, function (err) {
                    pca.removeClass(address.geocodeButton, "working");
                    address.error(err);
                });
            } else {
                address.error("The location supplied for the reverse geocode doesn't contain coordinate information.");
            }
        };

        address.utilitiesLookup = function (utilityCode) {
            var params = {
                Key: address.key,
                Text: utilityCode,
                UtilCodeType: address.options.utilitiesutilitycodetype
            };
            address.fire("utilities", params);
            pca.fetch("Capture/Interactive/Utilities/v1.00", params, function (items, response) {
                // Success
                if (items.length)
                    address.display(items, pca.templates.AUTOCOMPLETE_UTILITY, response);
                else
                    address.noResultsMessage();
            }, function (err) {
                address.error(err);
            });
        };

        /** Takes a search string and gets matches for it.
        * @param {string} term - The text to search for.
        * @fires search */
        address.search = function (term) {
            // utility route.
            if (address.autocomplete.addUtilityLookupToTop) {

                address.fire("utilitiesactive", term.replace(/[^0-9]/g, ""));

                address.display([
                    {
                        Id: "",
                        Type: "Utility",
                        Text: "Lookup MPAN/MPRN/Serial Number",
                        Highlight: "",
                        Description: ""
                    }
                ], pca.templates.AUTOCOMPLETE_UTILITY, null);
            }
            else {
                //does the search string still contain the last selected result
                if (address.searchContext) {
                    if (~term.indexOf(address.searchContext.search))
                        term = term.replace(address.searchContext.search, address.searchContext.text);
                    else
                        address.searchContext = null;
                }

                //if the last result is still being used, then filter from the id
                var isContained = address.searchContext != null;
                var search = {
                    text: term,
                    container: address.searchContext ? (address.searchContext.id || "") : "",
                    origin: address.origin || "",
                    countries: address.options.search.countries,
                    datasets: address.options.search.datasets,
                    filter: address.filteringMode,
                    limit: address.options.search.limit,
                    language: address.options.search.language || address.language
                };

                function success(items, response) {
                    if (items.length) {
                        address.display(items, pca.templates.AUTOCOMPLETE, response);
                        if (isContained) {
                            //focus on first item
                            address.autocomplete.list.next();
                        }
                    }
                    else {
                        address.noResultsMessage();
                    }
                }
                address.fire("search", search);

                if (search.text) {
                    var searchParameters = { Key: address.key, Text: search.text, Container: search.container, Origin: search.origin, Countries: search.countries, Datasets: search.datasets, Limit: search.limit, Filter: search.filter, Language: search.language, $block: address.blockSearches, $cache: address.cacheRequests };

                    //flags for testing purposes
                    if (address.testMode)
                        searchParameters.Test = address.testMode;

                    if (address.instance)
                        searchParameters.Instance = address.instance;

                    pca.fetch("Capture/Interactive/Find/v1.00", searchParameters, success, address.error);
                }
            }

            return address;
        };

        /** Retrieves an address from an Id and populates the fields.
        * @param {string} id - The address id to retrieve. */
        address.retrieve = function (id) {
            var params = { Key: address.key, Id: id, Source: address.options.source, $cache: address.cacheRequests };

            function fail(message) {
                address.message(pca.messages[address.language].RETRIEVEERROR, { clickToDisable: address.options.manualEntry, error: true, clearList: true });
                address.error(message);
            }

            function success(response, responseObject, request) {
                if (request) {
                    address.fire("retrieveResponse", response, responseObject, request);
                }
                response.length ? address.populate(response) : fail(response);
            }

            //add the advanced fields
            for (var i = 0; i < address.advancedFields.length; i++)
                params["field" + (i + 1) + "format"] = address.advancedFields[i];

            //add the param for field count
            if (address.advancedFields.length) {
                params.Fields = address.advancedFields.length;
            }

            pca.fetch("Capture/Interactive/Retrieve/v1.00", params, success, fail);
        };

        /** Handles an error from the service.
        * @param {string} message - A description of the error.
        * @fires error
        * @throws The error. */
        address.error = function (message) {
            address.fire("error", message);

            pca.clearBlockingRequests();

            //if the error message is not handled throw it
            if (!address.listeners["error"]) {
                if (typeof (console) != "undefined" && typeof (console.error) != "undefined")
                    console.error(pca.messages[address.language].SERVICEERROR + " " + message);
                else
                    throw pca.messages[address.language].SERVICEERROR + " " + message;
            }

        };

        //clears any current prompt timer
        function clearPromptTimer() {
            if (address.lastActionTimer != null) {
                window.clearTimeout(address.lastActionTimer);
                address.lastActionTimer = null;
            }
        };

        /** Show search results in the list.
        * @param {Array.<Object>} results - The response from a service request.
        * @param {string} template - The format template for list items.
       * @fires results
       * @fires display */
        address.display = function (results, template, attributes) {
            address.autocomplete.header.hide();
            address.highlight(results);
            address.fire("results", results, attributes);
            address.autocomplete.clear().add(results, template, address.select).show();
            address.showFooterLogo();

            //add expandable class
            address.autocomplete.list.collection.all(function (item) {
                if (item.data && item.data.Type && item.data.Type !== "Address") {
                    pca.addClass(item.element, "pcaexpandable");
                    item.element.appendChild(pca.create('div', {
                        className: 'pca-visually-hidden',
                        innerText: ', ' + pca.messages[address.language].DRILLDOWN
                    }));
                }
            });

            //prompt the user for more detail
            if (address.options.prompt) {
                function showPromptMessage() {
                    address.message(pca.messages[address.language].KEEPTYPING);
                }

                clearPromptTimer();

                if (address.options.promptDelay)
                    address.lastActionTimer = window.setTimeout(showPromptMessage, address.options.promptDelay);
                else showPromptMessage();
            }

            //show the number of matching results
            if (address.options.matchCount && attributes && attributes.ContainerCount)
                address.resultCountMessage(attributes.ContainerCount);

            address.fire("display", results, attributes);
            return address;
        };

        /**
        * Message options.
        * @typedef {Object} pca.Address.MessageOptions
        * @property {number} [notificationTimeout] - The time in ms to show the notification for.
        * @property {boolean} [inline] - Show messages in the header of the list.
        * @property {boolean} [clearList] - Clears the list of results when showing this message.
        * @property {boolean} [clickToDisable] - Clicking the message will hide and disable the control.
        * @property {boolean} [error] - Apply the style class for an error message.
        */

        /** Shows a message in the autocomplete.
        * @param {string} text - The message to show.
        * @param {pca.Address.MessageOptions} messageOptions - Options for the message. */
        address.message = function (text, messageOptions) {
            messageOptions = messageOptions || {};
            messageOptions.notificationTimeout = messageOptions.notificationTimeout || 3000;
            messageOptions.inline = messageOptions.inline || address.options.inlineMessages;

            clearPromptTimer();

            if (messageOptions.inline) {
                address.autocomplete.show();

                if (messageOptions.clickToDisable)
                    address.autocomplete.header.clear().setContent(pca.create("div", { className: "pcamessage", innerHTML: text, onclick: address.manualEntry }, "cursor:pointer;")).show();
                else
                    address.autocomplete.header.clear().setText(text).show();

                address.reposition();
            }
            else {
                address.messageBox.innerHTML = text;
                pca.addClass(address.messageBox, "pcavisible");

                pca.removeClass(address.messageBox, "pcaerror");
                if (messageOptions.error) pca.addClass(address.messageBox, "pcaerror");

                if (address.notifcationTimer) window.clearTimeout(address.notifcationTimer);
                pca.removeClass(address.messageBox, "pcafade");
                address.notifcationTimer = window.setTimeout(function () {
                    pca.addClass(address.messageBox, "pcafade");
                    window.setTimeout(function () {
                        pca.removeClass(address.messageBox, "pcavisible");
                    }, 500);
                }, messageOptions.notificationTimeout);

                var fieldPosition = pca.getPosition(address.autocomplete.field),
                    fieldSize = pca.getSize(address.autocomplete.field),
                    messageSize = pca.getSize(address.messageBox);

                address.messageBox.style.top = (address.autocomplete.upwards ? fieldPosition.top + fieldSize.height + 8 : fieldPosition.top - messageSize.height - 8) + "px";
                address.messageBox.style.left = fieldPosition.left + "px";
            }

            if (messageOptions.clearList)
                address.autocomplete.clear().list.hide();

            return address;
        };

        // Show the no results message which can be clicked to disable searching.
        address.noResultsMessage = function () {
            address.reset();
            address.message(pca.messages[address.language].NORESULTS, { clickToDisable: address.options.manualEntry, error: true, clearList: true });
            address.fire("noresults");
        };

        // Show the number of results possible
        address.resultCountMessage = function (count) {
            address.message(pca.formatLine({ count: count }, pca.messages[address.language].RESULTCOUNT));
        };

        /** Sets the value of current input field to prompt the user.
        * @param {string} text - The text to show.
        * @param {number} [position] - The index at which to set the carat. */
        address.setCursorText = function (text, position) {
            address.autocomplete.prompt(text, position);
            return address;
        };

        /** User has selected something, either an address or location.
        * @param {Object} suggestion - The selected item from a find service response. */
        address.select = function (suggestion) {

            function filterSearch() {
                var searchText = pca.getValue(address.autocomplete.field);

                if (address.options.setCursor) {
                    searchText = pca.removeHtml(suggestion.Text).replace("...", "");
                    address.setCursorText(searchText, suggestion.Cursor >= 0 ? suggestion.Cursor : null);
                }
                else {
                    pca.setValue(address.autocomplete.field, searchText + " ");
                    address.autocomplete.field.focus();
                }

                address.searchContext = { id: suggestion.Id, text: suggestion.Text, search: searchText };
                address.search(searchText);
            }

            if (suggestion.Type === "Address") {
                address.retrieve(suggestion.Id);
            }
            else if (suggestion.Type === "Utility") {
                var searchText = pca.getValue(address.autocomplete.field);
                address.utilitiesLookup(searchText);
            } else {
                filterSearch();
            }

            return address;
        };

        /** Adds highlights to suggestions
        * @param {Array.<Object>} suggestions - The response from the find service.
        * @param {string} [prefix=<b>] - The string to insert at the start of a highlight.
        * @param {string} [suffix=</b>] - The string to insert at the end of a highlight. */
        address.highlight = function (suggestions, prefix, suffix) {
            prefix = prefix || "<b>";
            suffix = suffix || "</b>";

            function applyHighlights(text, highlights) {
                for (var i = highlights.length - 1; i >= 0; i--) {
                    var indexes = highlights[i].split("-");

                    text = text.substring(0, parseInt(indexes[0])) + prefix + text.substring(parseInt(indexes[0]), parseInt(indexes[1])) + suffix + text.substring(parseInt(indexes[1]), text.length);
                }

                return text;
            }

            for (var s = 0; s < suggestions.length; s++) {
                var suggestion = suggestions[s];

                //initial values are all the same
                suggestion.HighlightedText = suggestion.title = suggestion.tag = suggestion.Text;
                suggestion.HighlightedDescription = suggestion.Description;

                //no highlight indexes
                if (!suggestion.Highlight)
                    continue;

                var highlightParts = suggestion.Highlight.split(";");

                //main text highlights
                if (highlightParts.length > 0)
                    suggestion.HighlightedText = applyHighlights(suggestion.HighlightedText, highlightParts[0].split(","));

                //description text highlights
                if (highlightParts.length > 1)
                    suggestion.HighlightedDescription = applyHighlights(suggestion.HighlightedDescription, highlightParts[1].split(","));
            }
        };

        /** Populate the fields with the address result.
        * @param {Array.<Object>} response - A response from the retrieve service.
        * @fires prepopulate
        * @fires populate */
        address.populate = function (items) {
            var detail = items[0];

            //apply language preference
            if (address.options.languagePreference) {
                for (var i = 0; i < items.length; i++) {
                    if (items[i].Language === address.options.languagePreference.toUpperCase()) {
                        detail = items[i];
                        break;
                    }
                }
            }

            //set the current country
            address.setCountry(detail.CountryIso2);

            //pre populate country
            if (address.options.countries.prepopulate) { }
            address.countrylist.populate();

            //check the number of address lines defined
            var addressLineFields = { Line1: null, Line2: null, Line3: null, Line4: null, Line5: null, Street: null, Building: null, Company: null },
                addressLineCount = 0;

            for (var f = 0; f < address.fields.length; f++) {
                for (var l in addressLineFields) {
                    if (~address.fields[f].field.indexOf(l))
                        addressLineFields[l] = address.fields[f];
                }
            }

            //replace with additional address line formats
            for (var la = 1; la <= 5; la++) {
                if (addressLineFields["Line" + la])
                    addressLineCount++;
            }

            if (addressLineFields.Building && addressLineFields.Street) addressLineCount++;

            //add additional formatted address lines
            for (var lb = 1; lb <= 5; lb++)
                detail["FormattedLine" + lb] = address.getAddressLine(detail, lb, addressLineCount, !addressLineFields.Company);

            address.fire("prepopulate", detail, items);

            //check and poplate the fields
            for (var a = 0; a < address.fields.length && address.options.populate; a++) {
                var field = address.fields[a];

                //skip this field if it's not set to be populated
                if (!(field.mode & pca.fieldMode.POPULATE)) continue;

                //skip the field if it's not an input field and the onlyInputs option is set
                if (address.options.onlyInputs && !(pca.inputField(field.element) || pca.selectList(field.element) || pca.checkBox(field.element))) continue;

                //skip this field if it's in preserve mode, already had a value and is not the search field
                if ((field.mode & pca.fieldMode.PRESERVE) && pca.getValue(field.element) && address.autocomplete.field !== pca.getElement(field.element)) continue;

                //process format strings and/or field names
                var format = address.fields[a].field.replace(/(Formatted)?Line/g, "FormattedLine"),
                    value = (/[\{\}]/).test(format) || format === "" ? pca.formatLine(detail, format) : detail[format];

                pca.setValue(field.element, value);
            }

            address.hide();
            address.newSearch();
            address.fire("populate", detail, items, address.key);
            pca.read(pca.messages[address.language].POPULATED);
            if (address.autocomplete.field) {
                address.autocomplete.field.focus();
            }
            return address;
        };

        /** Returns a formatted address line from the address response.
        * @param {Object} details - The address as a response item from the retrieve service.
        * @param {number} lineNumber - The required address line number.
        * @param {number} lineTotal - The total number of lines required.
        * @param {boolean} includeCompany - Specifies whether to include the company name in the address.
        * @returns {string} The formatted address line. */
        address.getAddressLine = function (details, lineNumber, fieldCount, includeCompany) {
            var addressLines,
                result = "";

            includeCompany = includeCompany && !!details.Company;

            if (includeCompany) {
                if (lineNumber === 1 && fieldCount > 1)
                    return details.Company;

                if (lineNumber === 1 && fieldCount === 1)
                    result = details.Company;
                else {
                    lineNumber--;
                    fieldCount--;
                }
            }

            if (!details.Line1)
                addressLines = 0;
            else if (!details.Line2)
                addressLines = 1;
            else if (!details.Line3)
                addressLines = 2;
            else if (!details.Line4)
                addressLines = 3;
            else if (!details.Line5)
                addressLines = 4;
            else
                addressLines = 5;

            //work out the first address line number to return and how many address elements should appear on it
            var firstLine = fieldCount >= addressLines ? lineNumber : Math.floor(1 + ((addressLines / fieldCount) + ((fieldCount - (lineNumber - 1)) / fieldCount)) * (lineNumber - 1)),
                numberOfLines = Math.floor((addressLines / fieldCount) + ((fieldCount - lineNumber) / fieldCount));

            //concatenate the address elements to make the address line
            for (var a = 0; a < numberOfLines; a++)
                result += (result ? ", " : "") + (details["Line" + (a + firstLine)] || "");

            return result;
        };

        /** Switches to the country list. */
        address.switchToCountrySelect = function () {
            if (address.inCountryListMode) {
                return address.switchToSearchMode();
            }
            var countryDescription =
                address.autocomplete.footer.element.querySelector(
                    "#pca-country-button-help-text"
                );
            if (countryDescription) {
                var country = pca.countries.find(function (c) {
                    return c.iso3 == address.country;
                });
                countryDescription.innerHTML = pca.formatLine(
                    {
                        country: country ? (address.language === "fr" ? country.name_fr : country.name) : "",
                    },
                    pca.messages[address.language].INCOUNTRYHELP
                );
            }
            address.countrylist.autocomplete.position(address.autocomplete.field);
            address.countrylist.autocomplete.field = address.autocomplete.field;
            address.countrylist.autocomplete.focused = true;
            address.countrylist.autocomplete.enable().showAll();
            address.countrylist.autocomplete.list.first();
            address.autocomplete.disable().hide();
            address.inCountryListMode = true;

            //store the state of the search mode
            address.storedSearch = pca.getValue(address.autocomplete.field);
            pca.clear(address.autocomplete.field);
            address.autocomplete.field.focus();
        };

        /** Switches back to the default search list. */
        address.switchToSearchMode = function () {
            var searchAfter = address.storedSearch != null;

            var countryDescription =
                address.autocomplete.footer.element.querySelector(
                    "#pca-country-button-help-text"
                );

            if (countryDescription) {
                var country = pca.countries.find(function (c) {
                    return c.iso3 == address.country;
                });
                countryDescription.innerHTML = countryDescription.innerHTML =
                    pca.formatLine(
                        {
                            country: country ? (address.language === "fr" ? country.name_fr : country.name) : "",
                        },
                        pca.messages[address.language].COUNTRYHELP
                    );
            }

            address.countrylist.autocomplete.hide();
            address.autocomplete.enable();

            if (searchAfter) {
                address.newSearch();
                address.autocomplete.field.focus();
                address.searchFromField();
            }
        };

        address.startGeoLocation = function () {
            if (pca.supports("reverseGeo")) {
                var nav = window.navigator;
                pca.addClass(address.geocodeButton, "working");
                nav.geolocation.getCurrentPosition(function (position) {
                    address.geolocation = position;
                    address.geolocationLookup(address.geolocation);
                }, function (error) {
                    pca.removeClass(address.geocodeButton, "working");
                    address.error(error.message);
                }, {
                    timeout: 5000
                });
            } else {
                //browser not able to do geo location
                //TODO - handle error gracefully
                address.error("Location data is not supported in this browser.");
            }

        };

        /** Sets the country for searching.
        * @param {string} country - The country name or code to change to. */
        address.setCountry = function (country) {
            address.countrylist.setCountry(country);
            return address;
        };

        /** Sets the country based on the current client IP. */
        address.setCountryByIP = function () {
            address.countrylist.setCountryByIP(address.key);
            return address;
        };

        /** Alters attributes on an element to try and prevent autocomplete */
        address.preventAutocomplete = function (element) {
            if (element) {
                var isSet = false;
                if (pca.browser && pca.browser.name) {
                    switch (pca.browser.name) {
                        case "Chrome":
                            if (pca.browser.version && !isNaN(Number(pca.browser.version))) {
                                var version = Number(pca.browser.version);
                                if (version === 63 || (version >= 80 && version < 90)) {
                                    element.autocomplete = "pca-override";
                                    isSet = true;
                                }
                            }
                            break;
                    }
                }
                if (!isSet) {
                    element.autocomplete = "off";
                }

            }
        };

        /** Detects the browser culture. */
        address.detectLanguage = function () {
            var culture = address.options.culture;
            var searchLanguage = address.options.search.language;

            if (culture !== searchLanguage) {
                culture = (window && window.navigator ? window.navigator.language || window.navigator.browserLanguage : "") || "";
            }

            address.language = culture && culture.length > 1 ? culture.substring(0, 2).toLowerCase() : "en";

            if (!pca.messages[address.language])
                address.language = "en";
        };

        /** Sets the control culture.
        * @param {string} culture - The culture code to set. */
        address.setCulture = function (culture) {
            address.options.culture = culture;
            address.reload();
        };

        /** Sets the width of the control.
        * @param {number|string} width - The width in pixels for the control. */
        address.setWidth = function (width) {
            address.autocomplete.setWidth(width);
            address.countrylist.autocomplete.setWidth(width);
        };

        /** Sets the height of the control.
        * @param {number|string} height - The height in pixels for the control. */
        address.setHeight = function (height) {
            address.autocomplete.setHeight(height);
            address.countrylist.autocomplete.setHeight(height);
        };

        /** Clear the address fields.
        * @fires clear */
        address.clear = function () {
            for (var a = 0; a < address.fields.length; a++)
                pca.setValue(address.fields[a].element, "");

            address.fire("clear");
            return address;
        };

        /** Reset the control back to it's initial state. */
        address.reset = function () {
            if (address.options.bar.visible) {
                address.autocomplete.list.clear().hide();
                address.autocomplete.header.hide();
                address.showFooterMessage();
                address.autocomplete.reposition();
            }
            else {
                address.autocomplete.hide();
                address.autocomplete.footer.hide();
            }

            clearPromptTimer();
            address.newSearch();
            return address;
        };

        //tell the control to begin a fresh search
        address.newSearch = function () {
            address.initialSearch = false;
            address.searchContext = null;
        };

        /** Address control has focus.
        * @fires focus */
        address.focus = function () {
            address.reset();

            if (address.options.autoSearch)
                address.searchFromField();

            address.fire("focus");
        };

        /** Hides the address control.
        * @fires hide */
        address.hide = function () {
            clearPromptTimer();

            address.autocomplete.hide();
            address.countrylist.autocomplete.hide();

            address.fire("hide");
        };

        /** Return the visible state of the control.
        * @returns {boolean} True if the control is visible. */
        address.visible = function () {
            return address.autocomplete.visible || address.countrylist.autocomplete.visible;
        };

        /** Repositions the address control. */
        address.reposition = function () {
            address.autocomplete.reposition();
            address.countrylist.autocomplete.reposition();
        };

        /** Disables the address control. */
        address.disable = function () {
            address.autocomplete.disabled = true;
            address.countrylist.autocomplete.disabled = true;
            return address;
        };

        /** Enables the address control after being disabled. */
        address.enable = function () {
            address.autocomplete.disabled = false;
            address.countrylist.autocomplete.disabled = false;
            return address;
        };

        /** Permanently removes the address control elements and event listeners from the page. */
        address.destroy = function () {
            if (address.autocomplete) address.autocomplete.destroy();
            if (address.countrylist) address.countrylist.autocomplete.destroy();
            return address;
        };

        /** Reloads the address control */
        address.reload = function () {
            address.destroy();
            address.load();
        };

        /** Disables the control to allow for manual address entry. */
        address.manualEntry = function () {
            if (window && window.setTimeout && address.options.disableTime) {
                address.autocomplete.field.focus();
                address.destroy();

                window.setTimeout(address.load, address.options.disableTime);

                address.fire("manual");
            }

            return address;
        };

        /** Adds a permanent item to the bottom of the list to enable manual address entry.
        * @param {string} [message] - The text to display. */
        address.addManualEntryItem = function (message) {
            message = message || pca.messages[address.language].MANUALENTRY;
            address.autocomplete.list.setFooterItem({ text: message }, "<u>{text}</u>", address.manualEntry);
        };

        /** Checks whether the control is bound to a particular element.
        * @param {string|HTMLElement} element - The element or element id to check for.
        * @returns {boolean} True if the control is bound to that element. */
        address.bound = function (element) {
            if (element = pca.getElement(element)) {
                for (var f = 0; f < address.fields.length; f++) {
                    if (element == pca.getElement(fields[f].element))
                        return true;
                }
            }

            return false;
        };

        /** Checks a format string for non-standard fields.
        * @param {string} format - The address line format string to check.
        * @returns {string} The standardised format string. */
        address.checkFormat = function (format) {
            function standardField(field) {
                for (var i in pca.exampleAddress) {
                    if (i === field) return true;
                }

                return false;
            }

            return format.replace(/\{(\w+)([^\}\w])?\}/g, function (m, c) {
                if (!standardField(c)) {
                    address.advancedFields.push(m);
                    return "{Field" + address.advancedFields.length + "}";
                }

                return m;
            });
        };

        /* Preload images that are to be used in the css. */
        function preloadImage(url) {
            var img = new Image();
            img.src = url;
        }

        preloadImage('//' + pca.host + '/images/icons/captureplus/loqatelogoinverted.svg');
        preloadImage('//' + pca.host + '/images/icons/captureplus/geolocationicon.svg');
        preloadImage('//' + pca.host + '/images/icons/captureplus/loader.gif');
        preloadImage('//' + pca.host + '/images/icons/captureplus/chevron.png');

        //only load when the page is ready
        pca.ready(address.load);
    };

})();;
/**
 * jquery.calendario.js v1.0.0
 * http://www.codrops.com
 *
 * Licensed under the MIT license.
 * http://www.opensource.org/licenses/mit-license.php
 * 
 * Copyright 2012, Codrops
 * http://www.codrops.com
 */
;( function( $, window, undefined ) {
	
	'use strict';

	$.Calendario = function( options, element ) {
		
		this.$el = $( element );
		this._init( options );
		
	};

	// the options
	$.Calendario.defaults = {
		/*
		you can also pass:
		month : initialize calendar with this month (1-12). Default is today.
		year : initialize calendar with this year. Default is today.
		caldata : initial data/content for the calendar.
		caldata format:
		{
			'MM-DD-YYYY' : 'HTML Content',
			'MM-DD-YYYY' : 'HTML Content',
			'MM-DD-YYYY' : 'HTML Content'
			...
		}
		*/
		weeks : [ 'Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday' ],
		weekabbrs : [ 'Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat' ],
		months : [ 'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December' ],
		monthabbrs : [ 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec' ],
		// choose between values in options.weeks or options.weekabbrs
		displayWeekAbbr : false,
		// choose between values in options.months or options.monthabbrs
		displayMonthAbbr : false,
		// left most day in the calendar
		// 0 - Sunday, 1 - Monday, ... , 6 - Saturday
		startIn : 1,
		onDayClick: function ($el, $content, dateProperties) { return false; },
		onShowAllClick: function ($anch, dateProperties) { return false; }
	};

	$.Calendario.prototype = {

		_init : function( options ) {
			
			// options
			this.options = $.extend( true, {}, $.Calendario.defaults, options );

			this.today = new Date();
			this.month = ( isNaN( this.options.month ) || this.options.month == null) ? this.today.getMonth() : this.options.month - 1;
			this.year = ( isNaN( this.options.year ) || this.options.year == null) ? this.today.getFullYear() : this.options.year;
			this.caldata = this.options.caldata || {};
			this._generateTemplate();
			this._initEvents();

		},
		_initEvents : function() {

			var self = this;

			this.$el.on( 'click.calendario', 'div.fc-row > div', function() {

				var $cell = $( this ),
					idx = $cell.index(),
					$content = $cell.children( 'div' ),
					dateProp = {
						day : $cell.children( 'span.fc-date' ).text(),
						month : self.month + 1,
						monthname : self.options.displayMonthAbbr ? self.options.monthabbrs[ self.month ] : self.options.months[ self.month ],
						year : self.year,
						weekday : idx + self.options.startIn,
						weekdayname : self.options.weeks[ idx + self.options.startIn ]
					};

				if( dateProp.day ) {
					self.options.onDayClick( $cell, $content, dateProp );
				}

			});


			this.$el.on('click.calendario', 'div.fc-row > div .fc-showall', function (event) {

			    var $anch = $(this);

			    var $cell = $anch.parent();
			    var idx = $cell.index();

			    var dateProp = {
			        day: $cell.children('span.fc-date').text(),
			        month: self.month + 1,
			        monthname: self.options.displayMonthAbbr ? self.options.monthabbrs[self.month] : self.options.months[self.month],
			        year: self.year,
			        weekday: idx + self.options.startIn,
			        weekdayname: self.options.weeks[idx + self.options.startIn]
			    };

			    if (dateProp.day) {
			        self.options.onShowAllClick($anch, dateProp);
			    }
			    event.preventDefault();

			});


		},
		// Calendar logic based on http://jszen.blogspot.pt/2007/03/how-to-build-simple-calendar-with.html
		_generateTemplate : function( callback ) {

			var head = this._getHead(),
				body = this._getBody(),
				rowClass;

			switch( this.rowTotal ) {
				case 4 : rowClass = 'fc-four-rows'; break;
				case 5 : rowClass = 'fc-five-rows'; break;
				case 6 : rowClass = 'fc-six-rows'; break;
			}

			this.$cal = $( '<div class="fc-calendar ' + rowClass + '">' ).append( head, body );

			this.$el.find( 'div.fc-calendar' ).remove().end().append( this.$cal );

			if( callback ) { callback.call(); }

		},
		_getHead : function() {

			var html = '<div class="fc-head">';
		
			for ( var i = 0; i <= 6; i++ ) {

				var pos = i + this.options.startIn,
					j = pos > 6 ? pos - 6 - 1 : pos;

				html += '<div>';
				html += this.options.displayWeekAbbr ? this.options.weekabbrs[ j ] : this.options.weeks[ j ];
				html += '</div>';

			}

			html += '</div>';

			return html;

		},
		_getBody : function() {

			var d = new Date( this.year, this.month + 1, 0 ),
				// number of days in the month
				monthLength = d.getDate(),
				firstDay = new Date( this.year, this.month, 1 );

			// day of the week
			this.startingDay = firstDay.getDay();

			var html = '<div class="fc-body"><div class="fc-row">',
				// fill in the days
				day = 1;

			// this loop is for weeks (rows)
			for ( var i = 0; i < 7; i++ ) {

				// this loop is for weekdays (cells)
				for ( var j = 0; j <= 6; j++ ) {

					var pos = this.startingDay - this.options.startIn,
						p = pos < 0 ? 6 + pos + 1 : pos,
						inner = '',
						today = this.month === this.today.getMonth() && this.year === this.today.getFullYear() && day === this.today.getDate(),
						content = '';
					
					if ( day <= monthLength && ( i > 0 || j >= p ) ) {

					    inner += '<span class="fc-date">' + day + '</span><a href="#" class="fc-showall">Show All</a><span class="fc-weekday">' + this.options.weekabbrs[j + this.options.startIn > 6 ? j + this.options.startIn - 6 - 1 : j + this.options.startIn] + '</span>';

						// this day is:
						var strdate = ( this.month + 1 < 10 ? '0' + ( this.month + 1 ) : this.month + 1 ) + '-' + ( day < 10 ? '0' + day : day ) + '-' + this.year,
							dayData = this.caldata[ strdate ];

						if( dayData ) {
							content = dayData;
						}

						if( content !== '' ) {
							inner += '<div>' + content + '</div>';
						}

						++day;

					}
					else {
						today = false;
					}

					var cellClasses = today ? 'fc-today ' : '';
					if( content !== '' ) {
						cellClasses += 'fc-content';
					}

					html += cellClasses !== '' ? '<div class="' + cellClasses + '">' : '<div>';
					html += inner;
					html += '</div>';

				}

				// stop making rows if we've run out of days
				if (day > monthLength) {
					this.rowTotal = i + 1;
					break;
				} 
				else {
					html += '</div><div class="fc-row">';
				}

			}
			html += '</div></div>';

			return html;

		},
		// based on http://stackoverflow.com/a/8390325/989439
		_isValidDate : function( date ) {

			date = date.replace(/-/gi,'');
			var month = parseInt( date.substring( 0, 2 ), 10 ),
				day = parseInt( date.substring( 2, 4 ), 10 ),
				year = parseInt( date.substring( 4, 8 ), 10 );

			if( ( month < 1 ) || ( month > 12 ) ) {
				return false;
			}
			else if( ( day < 1 ) || ( day > 31 ) )  {
				return false;
			}
			else if( ( ( month == 4 ) || ( month == 6 ) || ( month == 9 ) || ( month == 11 ) ) && ( day > 30 ) )  {
				return false;
			}
			else if( ( month == 2 ) && ( ( ( year % 400 ) == 0) || ( ( year % 4 ) == 0 ) ) && ( ( year % 100 ) != 0 ) && ( day > 29 ) )  {
				return false;
			}
			else if( ( month == 2 ) && ( ( year % 100 ) == 0 ) && ( day > 29 ) )  {
				return false;
			}

			return {
				day : day,
				month : month,
				year : year
			};

		},
		_move : function( period, dir, callback ) {

			if( dir === 'previous' ) {
				
				if( period === 'month' ) {
					this.year = this.month > 0 ? this.year : --this.year;
					this.month = this.month > 0 ? --this.month : 11;
				}
				else if( period === 'year' ) {
					this.year = --this.year;
				}

			}
			else if( dir === 'next' ) {

				if( period === 'month' ) {
					this.year = this.month < 11 ? this.year : ++this.year;
					this.month = this.month < 11 ? ++this.month : 0;
				}
				else if( period === 'year' ) {
					this.year = ++this.year;
				}

			}

			this._generateTemplate( callback );

		},
		/************************* 
		******PUBLIC METHODS *****
		**************************/
		getYear : function() {
			return this.year;
		},
		getMonth : function() {
			return this.month + 1;
		},
		getMonthName : function() {
			return this.options.displayMonthAbbr ? this.options.monthabbrs[ this.month ] : this.options.months[ this.month ];
		},
		// gets the cell's content div associated to a day of the current displayed month
		// day : 1 - [28||29||30||31]
		getCell : function( day ) {

			var row = Math.floor( ( day + this.startingDay - this.options.startIn ) / 7 ),
				pos = day + this.startingDay - this.options.startIn - ( row * 7 ) - 1;

			return this.$cal.find( 'div.fc-body' ).children( 'div.fc-row' ).eq( row ).children( 'div' ).eq( pos ).children( 'div' );

		},
		setData : function( caldata ) {

			caldata = caldata || {};
			$.extend( this.caldata, caldata );
			this._generateTemplate();

		},
		// goes to today's month/year
		gotoNow : function( callback ) {

			this.month = this.today.getMonth();
			this.year = this.today.getFullYear();
			this._generateTemplate( callback );

		},
		// goes to month/year
		goto : function( month, year, callback ) {

			this.month = month;
			this.year = year;
			this._generateTemplate( callback );

		},
		gotoPreviousMonth : function( callback ) {
			this._move( 'month', 'previous', callback );
		},
		gotoPreviousYear : function( callback ) {
			this._move( 'year', 'previous', callback );
		},
		gotoNextMonth : function( callback ) {
			this._move( 'month', 'next', callback );
		},
		gotoNextYear : function( callback ) {
			this._move( 'year', 'next', callback );
		}

	};
	
	var logError = function( message ) {

		if ( window.console ) {

			window.console.error( message );
		
		}

	};
	
	$.fn.calendario = function( options ) {

		var instance = $.data( this, 'calendario' );
		
		if ( typeof options === 'string' ) {
			
			var args = Array.prototype.slice.call( arguments, 1 );
			
			this.each(function() {
			
				if ( !instance ) {

					logError( "cannot call methods on calendario prior to initialization; " +
					"attempted to call method '" + options + "'" );
					return;
				
				}
				
				if ( !$.isFunction( instance[options] ) || options.charAt(0) === "_" ) {

					logError( "no such method '" + options + "' for calendario instance" );
					return;
				
				}
				
				instance[ options ].apply( instance, args );
			
			});
		
		} 
		else {
		
			this.each(function() {
				
				if ( instance ) {

					instance._init();
				
				}
				else {

					instance = $.data( this, 'calendario', new $.Calendario( options, this ) );
				
				}

			});
		
		}
		
		return instance;
		
	};
	
} )( jQuery, window );
;
/*!
 * Nestable jQuery Plugin - Copyright (c) 2012 David Bushell - http://dbushell.com/
 * Dual-licensed under the BSD or MIT licenses
 */
;(function($, window, document, undefined)
{
    var hasTouch = 'ontouchstart' in window;

    /**
     * Detect CSS pointer-events property
     * events are normally disabled on the dragging element to avoid conflicts
     * https://github.com/ausi/Feature-detection-technique-for-pointer-events/blob/master/modernizr-pointerevents.js
     */
    var hasPointerEvents = (function()
    {
        var el    = document.createElement('div'),
            docEl = document.documentElement;
        if (!('pointerEvents' in el.style)) {
            return false;
        }
        el.style.pointerEvents = 'auto';
        el.style.pointerEvents = 'x';
        docEl.appendChild(el);
        var supports = window.getComputedStyle && window.getComputedStyle(el, '').pointerEvents === 'auto';
        docEl.removeChild(el);
        return !!supports;
    })();

    var eStart  = hasTouch ? 'touchstart'  : 'mousedown',
        eMove   = hasTouch ? 'touchmove'   : 'mousemove',
        eEnd    = hasTouch ? 'touchend'    : 'mouseup';
        eCancel = hasTouch ? 'touchcancel' : 'mouseup';

    var defaults = {
            listNodeName    : 'ol',
            itemNodeName    : 'li',
            rootClass       : 'dd',
            listClass       : 'dd-list',
            itemClass       : 'dd-item',
            dragClass       : 'dd-dragel',
            handleClass     : 'dd-handle',
            collapsedClass  : 'dd-collapsed',
            placeClass      : 'dd-placeholder',
            noDragClass     : 'dd-nodrag',
            emptyClass      : 'dd-empty',
            expandBtnHTML   : '<button data-action="expand" type="button">Expand</button>',
            collapseBtnHTML : '<button data-action="collapse" type="button">Collapse</button>',
            group           : 0,
            maxDepth        : 5,
            threshold       : 20
        };

    function Plugin(element, options)
    {
        this.w  = $(window);
        this.el = $(element);
        this.options = $.extend({}, defaults, options);
        this.init();
    }

    Plugin.prototype = {

        init: function()
        {
            var list = this;

            list.reset();

            list.el.data('nestable-group', this.options.group);

            list.placeEl = $('<div class="' + list.options.placeClass + '"/>');

            $.each(this.el.find(list.options.itemNodeName), function(k, el) {
                list.setParent($(el));
            });

            list.el.on('click', 'button', function(e) {
                if (list.dragEl || (!hasTouch && e.button !== 0)) {
                    return;
                }
                var target = $(e.currentTarget),
                    action = target.data('action'),
                    item   = target.parent(list.options.itemNodeName);
                if (action === 'collapse') {
                    list.collapseItem(item);
                }
                if (action === 'expand') {
                    list.expandItem(item);
                }
            });

            var onStartEvent = function(e)
            {
                var handle = $(e.target);
                if (!handle.hasClass(list.options.handleClass)) {
                    if (handle.closest('.' + list.options.noDragClass).length) {
                        return;
                    }
                    handle = handle.closest('.' + list.options.handleClass);
                }
                if (!handle.length || list.dragEl || (!hasTouch && e.button !== 0) || (hasTouch && e.touches.length !== 1)) {
                    return;
                }
                e.preventDefault();
                list.dragStart(hasTouch ? e.touches[0] : e);
            };

            var onMoveEvent = function(e)
            {
                if (list.dragEl) {
                    e.preventDefault();
                    list.dragMove(hasTouch ? e.touches[0] : e);
                }
            };

            var onEndEvent = function(e)
            {
                if (list.dragEl) {
                    e.preventDefault();
                    list.dragStop(hasTouch ? e.touches[0] : e);
                }
            };

            if (hasTouch) {
                list.el[0].addEventListener(eStart, onStartEvent, false);
                window.addEventListener(eMove, onMoveEvent, false);
                window.addEventListener(eEnd, onEndEvent, false);
                window.addEventListener(eCancel, onEndEvent, false);
            } else {
                list.el.on(eStart, onStartEvent);
                list.w.on(eMove, onMoveEvent);
                list.w.on(eEnd, onEndEvent);
            }

        },

        serialize: function()
        {
            var data,
                depth = 0,
                list  = this;
                step  = function(level, depth)
                {
                    var array = [ ],
                        items = level.children(list.options.itemNodeName);
                    items.each(function()
                    {
                        var li   = $(this),
                            item = $.extend({}, li.data()),
                            sub  = li.children(list.options.listNodeName);
                        if (sub.length) {
                            item.children = step(sub, depth + 1);
                        }
                        array.push(item);
                    });
                    return array;
                };
            data = step(list.el.find(list.options.listNodeName).first(), depth);
            return data;
        },

        serialise: function()
        {
            return this.serialize();
        },

        reset: function()
        {
            this.mouse = {
                offsetX   : 0,
                offsetY   : 0,
                startX    : 0,
                startY    : 0,
                lastX     : 0,
                lastY     : 0,
                nowX      : 0,
                nowY      : 0,
                distX     : 0,
                distY     : 0,
                dirAx     : 0,
                dirX      : 0,
                dirY      : 0,
                lastDirX  : 0,
                lastDirY  : 0,
                distAxX   : 0,
                distAxY   : 0
            };
            this.moving     = false;
            this.dragEl     = null;
            this.dragRootEl = null;
            this.dragDepth  = 0;
            this.hasNewRoot = false;
            this.pointEl    = null;
        },

        expandItem: function(li)
        {
            li.removeClass(this.options.collapsedClass);
            li.children('[data-action="expand"]').hide();
            li.children('[data-action="collapse"]').show();
            li.children(this.options.listNodeName).show();
        },

        collapseItem: function(li)
        {
            var lists = li.children(this.options.listNodeName);
            if (lists.length) {
                li.addClass(this.options.collapsedClass);
                li.children('[data-action="collapse"]').hide();
                li.children('[data-action="expand"]').show();
                li.children(this.options.listNodeName).hide();
            }
        },

        expandAll: function()
        {
            var list = this;
            list.el.find(list.options.itemNodeName).each(function() {
                list.expandItem($(this));
            });
        },

        collapseAll: function()
        {
            var list = this;
            list.el.find(list.options.itemNodeName).each(function() {
                list.collapseItem($(this));
            });
        },

        setParent: function(li)
        {
            if (li.children(this.options.listNodeName).length) {
                li.prepend($(this.options.expandBtnHTML));
                li.prepend($(this.options.collapseBtnHTML));
            }
            li.children('[data-action="expand"]').hide();
        },

        unsetParent: function(li)
        {
            li.removeClass(this.options.collapsedClass);
            li.children('[data-action]').remove();
            li.children(this.options.listNodeName).remove();
        },

        dragStart: function(e)
        {
            var mouse    = this.mouse,
                target   = $(e.target),
                dragItem = target.closest(this.options.itemNodeName);

            this.placeEl.css('height', dragItem.height());

            mouse.offsetX = e.offsetX !== undefined ? e.offsetX : e.pageX - target.offset().left;
            mouse.offsetY = e.offsetY !== undefined ? e.offsetY : e.pageY - target.offset().top;
            mouse.startX = mouse.lastX = e.pageX;
            mouse.startY = mouse.lastY = e.pageY;

            this.dragRootEl = this.el;

            this.dragEl = $(document.createElement(this.options.listNodeName)).addClass(this.options.listClass + ' ' + this.options.dragClass);
            this.dragEl.css('width', dragItem.width());

            // fix for zepto.js
            //dragItem.after(this.placeEl).detach().appendTo(this.dragEl);
            dragItem.after(this.placeEl);
            dragItem[0].parentNode.removeChild(dragItem[0]);
            dragItem.appendTo(this.dragEl);

            $(document.body).append(this.dragEl);
            this.dragEl.css({
                'left' : e.pageX - mouse.offsetX,
                'top'  : e.pageY - mouse.offsetY
            });
            // total depth of dragging item
            var i, depth,
                items = this.dragEl.find(this.options.itemNodeName);
            for (i = 0; i < items.length; i++) {
                depth = $(items[i]).parents(this.options.listNodeName).length;
                if (depth > this.dragDepth) {
                    this.dragDepth = depth;
                }
            }
        },

        dragStop: function(e)
        {
            // fix for zepto.js
            //this.placeEl.replaceWith(this.dragEl.children(this.options.itemNodeName + ':first').detach());
            var el = this.dragEl.children(this.options.itemNodeName).first();
            el[0].parentNode.removeChild(el[0]);
            this.placeEl.replaceWith(el);

            this.dragEl.remove();
            this.el.trigger('change');
            if (this.hasNewRoot) {
                this.dragRootEl.trigger('change');
            }
            this.reset();
        },

        dragMove: function(e)
        {
            var list, parent, prev, next, depth,
                opt   = this.options,
                mouse = this.mouse;

            this.dragEl.css({
                'left' : e.pageX - mouse.offsetX,
                'top'  : e.pageY - mouse.offsetY
            });

            // mouse position last events
            mouse.lastX = mouse.nowX;
            mouse.lastY = mouse.nowY;
            // mouse position this events
            mouse.nowX  = e.pageX;
            mouse.nowY  = e.pageY;
            // distance mouse moved between events
            mouse.distX = mouse.nowX - mouse.lastX;
            mouse.distY = mouse.nowY - mouse.lastY;
            // direction mouse was moving
            mouse.lastDirX = mouse.dirX;
            mouse.lastDirY = mouse.dirY;
            // direction mouse is now moving (on both axis)
            mouse.dirX = mouse.distX === 0 ? 0 : mouse.distX > 0 ? 1 : -1;
            mouse.dirY = mouse.distY === 0 ? 0 : mouse.distY > 0 ? 1 : -1;
            // axis mouse is now moving on
            var newAx   = Math.abs(mouse.distX) > Math.abs(mouse.distY) ? 1 : 0;

            // do nothing on first move
            if (!mouse.moving) {
                mouse.dirAx  = newAx;
                mouse.moving = true;
                return;
            }

            // calc distance moved on this axis (and direction)
            if (mouse.dirAx !== newAx) {
                mouse.distAxX = 0;
                mouse.distAxY = 0;
            } else {
                mouse.distAxX += Math.abs(mouse.distX);
                if (mouse.dirX !== 0 && mouse.dirX !== mouse.lastDirX) {
                    mouse.distAxX = 0;
                }
                mouse.distAxY += Math.abs(mouse.distY);
                if (mouse.dirY !== 0 && mouse.dirY !== mouse.lastDirY) {
                    mouse.distAxY = 0;
                }
            }
            mouse.dirAx = newAx;

            /**
             * move horizontal
             */
            if (mouse.dirAx && mouse.distAxX >= opt.threshold) {
                // reset move distance on x-axis for new phase
                mouse.distAxX = 0;
                prev = this.placeEl.prev(opt.itemNodeName);
                // increase horizontal level if previous sibling exists and is not collapsed
                if (mouse.distX > 0 && prev.length && !prev.hasClass(opt.collapsedClass)) {
                    // cannot increase level when item above is collapsed
                    list = prev.find(opt.listNodeName).last();
                    // check if depth limit has reached
                    depth = this.placeEl.parents(opt.listNodeName).length;
                    if (depth + this.dragDepth <= opt.maxDepth) {
                        // create new sub-level if one doesn't exist
                        if (!list.length) {
                            list = $('<' + opt.listNodeName + '/>').addClass(opt.listClass);
                            list.append(this.placeEl);
                            prev.append(list);
                            this.setParent(prev);
                        } else {
                            // else append to next level up
                            list = prev.children(opt.listNodeName).last();
                            list.append(this.placeEl);
                        }
                    }
                }
                // decrease horizontal level
                if (mouse.distX < 0) {
                    // we can't decrease a level if an item preceeds the current one
                    next = this.placeEl.next(opt.itemNodeName);
                    if (!next.length) {
                        parent = this.placeEl.parent();
                        this.placeEl.closest(opt.itemNodeName).after(this.placeEl);
                        if (!parent.children().length) {
                            this.unsetParent(parent.parent());
                        }
                    }
                }
            }

            var isEmpty = false;

            // find list item under cursor
            if (!hasPointerEvents) {
                this.dragEl[0].style.visibility = 'hidden';
            }
            this.pointEl = $(document.elementFromPoint(e.pageX - document.body.scrollLeft, e.pageY - (window.pageYOffset || document.documentElement.scrollTop)));
            if (!hasPointerEvents) {
                this.dragEl[0].style.visibility = 'visible';
            }
            if (this.pointEl.hasClass(opt.handleClass)) {
                this.pointEl = this.pointEl.parent(opt.itemNodeName);
            }
            if (this.pointEl.hasClass(opt.emptyClass)) {
                isEmpty = true;
            }
            else if (!this.pointEl.length || !this.pointEl.hasClass(opt.itemClass)) {
                return;
            }

            // find parent list of item under cursor
            var pointElRoot = this.pointEl.closest('.' + opt.rootClass),
                isNewRoot   = this.dragRootEl.data('nestable-id') !== pointElRoot.data('nestable-id');

            /**
             * move vertical
             */
            if (!mouse.dirAx || isNewRoot || isEmpty) {
                // check if groups match if dragging over new root
                if (isNewRoot && opt.group !== pointElRoot.data('nestable-group')) {
                    return;
                }
                // check depth limit
                depth = this.dragDepth - 1 + this.pointEl.parents(opt.listNodeName).length;
                if (depth > opt.maxDepth) {
                    return;
                }
                var before = e.pageY < (this.pointEl.offset().top + this.pointEl.height() / 2);
                    parent = this.placeEl.parent();
                // if empty create new list to replace empty placeholder
                if (isEmpty) {
                    list = $(document.createElement(opt.listNodeName)).addClass(opt.listClass);
                    list.append(this.placeEl);
                    this.pointEl.replaceWith(list);
                }
                else if (before) {
                    this.pointEl.before(this.placeEl);
                }
                else {
                    this.pointEl.after(this.placeEl);
                }
                if (!parent.children().length) {
                    this.unsetParent(parent.parent());
                }
                if (!this.dragRootEl.find(opt.itemNodeName).length) {
                    this.dragRootEl.append('<div class="' + opt.emptyClass + '"/>');
                }
                // parent root list has changed
                if (isNewRoot) {
                    this.dragRootEl = pointElRoot;
                    this.hasNewRoot = this.el[0] !== this.dragRootEl[0];
                }
            }
        }

    };

    $.fn.nestable = function(params)
    {
        var lists  = this,
            retval = this;

        lists.each(function()
        {
            var plugin = $(this).data("nestable");

            if (!plugin) {
                $(this).data("nestable", new Plugin(this, params));
                $(this).data("nestable-id", new Date().getTime());
            } else {
                if (typeof params === 'string' && typeof plugin[params] === 'function') {
                    retval = plugin[params]();
                }
            }
        });

        return retval || lists;
    };

})(window.jQuery || window.Zepto, window, document);
;
/**
 * Wheel Color Picker 3.0.8
 * (c) 2011-2019 Fajar Chandra. Released under MIT License.
 * https://raffer.one/projects/jquery-wheelcolorpicker
 */
!function(G){G.fn.wheelColorPicker=function(){var i=this;if(0<arguments.length)var s="string"==typeof(a=[].shift.apply(arguments))?a.charAt(0).toUpperCase()+a.slice(1):a;else{var a=void 0;s=void 0}var o=arguments;return this.each(function(){var e=G(this).data("jQWCP.instance");if(null==e||null==e){var t={};"object"==typeof a&&(t=a),e=new h.ColorPicker(this,t),G(this).data("jQWCP.instance",e)}if(void 0===a||"object"==typeof a);else if("function"==typeof e[a]){if((r=e[a].apply(e,o))!==e)return i=r,!1}else if("function"==typeof e["set"+s]&&0<o.length){if((r=e["set"+s].apply(e,o))!==e)return i=r,!1}else if("function"==typeof e["get"+s]){var r;if((r=e["get"+s].apply(e,o))!==e)return i=r,!1}else if(void 0!==e.options[a]&&0<o.length)e.options[a]=o[0];else{if(void 0!==e.options[a])return i=e.options[a],!1;G.error("Method/option named "+a+" does not exist on jQuery.wheelColorPicker")}}),i};var h=G.fn.wheelColorPicker;h.defaults={format:"hex",preview:!1,live:!0,userinput:!0,validate:!0,autoResize:!0,autoFormat:!0,preserveWheel:null,cssClass:"",layout:"popup",animDuration:200,quality:1,sliders:null,rounding:2,mobile:!0,mobileWidth:480,hideKeyboard:!1,htmlOptions:!0,snap:!1,snapTolerance:.05},h.BUG_RELATIVE_PAGE_ORIGIN=!1,h.ORIGIN={left:0,top:0},h.colorToStr=function(e,t){var r="";switch(t){case"css":r="#";case"hex":1==(i=Math.round(255*e.r).toString(16)).length&&(i="0"+i),1==(s=Math.round(255*e.g).toString(16)).length&&(s="0"+s),1==(a=Math.round(255*e.b).toString(16)).length&&(a="0"+a),r+=i+s+a;break;case"cssa":r="#";case"hexa":var i,s,a;1==(i=Math.round(255*e.r).toString(16)).length&&(i="0"+i),1==(s=Math.round(255*e.g).toString(16)).length&&(s="0"+s),1==(a=Math.round(255*e.b).toString(16)).length&&(a="0"+a);var o=Math.round(255*e.a).toString(16);1==o.length&&(o="0"+o),r+=i+s+a+o;break;case"rgb":r="rgb("+Math.round(255*e.r)+","+Math.round(255*e.g)+","+Math.round(255*e.b)+")";break;case"rgb%":r="rgb("+100*e.r+"%,"+100*e.g+"%,"+100*e.b+"%)";break;case"rgba":r="rgba("+Math.round(255*e.r)+","+Math.round(255*e.g)+","+Math.round(255*e.b)+","+e.a+")";break;case"rgba%":r="rgba("+100*e.r+"%,"+100*e.g+"%,"+100*e.b+"%,"+100*e.a+"%)";break;case"hsv":r="hsv("+360*e.h+","+e.s+","+e.v+")";break;case"hsv%":r="hsv("+100*e.h+"%,"+100*e.s+"%,"+100*e.v+"%)";break;case"hsva":r="hsva("+360*e.h+","+e.s+","+e.v+","+e.a+")";break;case"hsva%":r="hsva("+100*e.h+"%,"+100*e.s+"%,"+100*e.v+"%,"+100*e.a+"%)";break;case"hsb":r="hsb("+e.h+","+e.s+","+e.v+")";break;case"hsb%":r="hsb("+100*e.h+"%,"+100*e.s+"%,"+100*e.v+"%)";break;case"hsba":r="hsba("+e.h+","+e.s+","+e.v+","+e.a+")";break;case"hsba%":r="hsba("+100*e.h+"%,"+100*e.s+"%,"+100*e.v+"%,"+100*e.a+"%)"}return r},h.strToColor=function(e){var t,r,i={a:1};if(null!=e.match(/^#[0-9a-f]{3}$/i)||e.match(/^#[0-9a-f]{4}$/i)){if(isNaN(i.r=17*parseInt(e.substr(1,1),16)/255))return!1;if(isNaN(i.g=17*parseInt(e.substr(2,1),16)/255))return!1;if(isNaN(i.b=17*parseInt(e.substr(3,1),16)/255))return!1;if(5==e.length&&isNaN(i.a=17*parseInt(e.substr(4,1),16)/255))return!1}else if(null!=e.match(/^[0-9a-f]{3}$/i)||null!=e.match(/^[0-9a-f]{4}$/i)){if(isNaN(i.r=17*parseInt(e.substr(0,1),16)/255))return!1;if(isNaN(i.g=17*parseInt(e.substr(1,1),16)/255))return!1;if(isNaN(i.b=17*parseInt(e.substr(2,1),16)/255))return!1;if(4==e.length&&isNaN(i.a=17*parseInt(e.substr(3,1),16)/255))return!1}else if(null!=e.match(/^#[0-9a-f]{6}$/i)||null!=e.match(/^#[0-9a-f]{8}$/i)){if(isNaN(i.r=parseInt(e.substr(1,2),16)/255))return!1;if(isNaN(i.g=parseInt(e.substr(3,2),16)/255))return!1;if(isNaN(i.b=parseInt(e.substr(5,2),16)/255))return!1;if(9==e.length&&isNaN(i.a=parseInt(e.substr(7,2),16)/255))return!1}else if(null!=e.match(/^[0-9a-f]{6}$/i)||null!=e.match(/^[0-9a-f]{8}$/i)){if(isNaN(i.r=parseInt(e.substr(0,2),16)/255))return!1;if(isNaN(i.g=parseInt(e.substr(2,2),16)/255))return!1;if(isNaN(i.b=parseInt(e.substr(4,2),16)/255))return!1;if(8==e.length&&isNaN(i.a=parseInt(e.substr(6,2),16)/255))return!1}else if(null!=e.match(/^rgba\s*\(\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*\)$/i)||null!=e.match(/^rgb\s*\(\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*\)$/i)){if(r=null!=e.match(/a/i),"%"==(t=e.substring(e.indexOf("(")+1,e.indexOf(","))).charAt(t.length-1)){if(isNaN(i.r=parseFloat(t)/100))return!1}else if(isNaN(i.r=parseInt(t)/255))return!1;if("%"==(t=e.substring(e.indexOf(",")+1,e.indexOf(",",e.indexOf(",")+1))).charAt(t.length-1)){if(isNaN(i.g=parseFloat(t)/100))return!1}else if(isNaN(i.g=parseInt(t)/255))return!1;if("%"==(t=r?e.substring(e.indexOf(",",e.indexOf(",")+1)+1,e.lastIndexOf(",")):e.substring(e.lastIndexOf(",")+1,e.lastIndexOf(")"))).charAt(t.length-1)){if(isNaN(i.b=parseFloat(t)/100))return!1}else if(isNaN(i.b=parseInt(t)/255))return!1;if(r)if("%"==(t=e.substring(e.lastIndexOf(",")+1,e.lastIndexOf(")"))).charAt(t.length-1)){if(isNaN(i.a=parseFloat(t)/100))return!1}else if(isNaN(i.a=parseFloat(t)))return!1}else{if(null==e.match(/^hsva\s*\(\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*\)$/i)&&null==e.match(/^hsv\s*\(\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*\)$/i)&&null==e.match(/^hsba\s*\(\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*\)$/i)&&null==e.match(/^hsb\s*\(\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*,\s*([0-9\.]+%|[01]?\.?[0-9]*)\s*\)$/i))return!1;if(r=null!=e.match(/a/i),"%"==(t=e.substring(e.indexOf("(")+1,e.indexOf(","))).charAt(t.length-1)){if(isNaN(i.h=parseFloat(t)/100))return!1}else if(isNaN(i.h=parseFloat(t)/360))return!1;if("%"==(t=e.substring(e.indexOf(",")+1,e.indexOf(",",e.indexOf(",")+1))).charAt(t.length-1)){if(isNaN(i.s=parseFloat(t)/100))return!1}else if(isNaN(i.s=parseFloat(t)))return!1;if("%"==(t=r?e.substring(e.indexOf(",",e.indexOf(",")+1)+1,e.lastIndexOf(",")):e.substring(e.lastIndexOf(",")+1,e.lastIndexOf(")"))).charAt(t.length-1)){if(isNaN(i.v=parseFloat(t)/100))return!1}else if(isNaN(i.v=parseFloat(t)))return!1;if(r)if("%"==(t=e.substring(e.lastIndexOf(",")+1,e.lastIndexOf(")"))).charAt(t.length-1)){if(isNaN(i.a=parseFloat(t)/100))return!1}else if(isNaN(i.a=parseFloat(t)))return!1}return i},h.hsvToRgb=function(e,t,r){var i=e<=1/6||5/6<=e?1:e<1/3?1-6*(e-1/6):4/6<e?6*(e-4/6):0,s=1/6<=e&&e<=.5?1:e<1/6?6*e:e<4/6?1-6*(e-.5):0,a=.5<=e&&e<=5/6?1:2/6<e&&e<.5?6*(e-2/6):5/6<e?1-6*(e-5/6):0;return{r:(i+(1-i)*(1-t))*r,g:(s+(1-s)*(1-t))*r,b:(a+(1-a)*(1-t))*r}},h.rgbToHsv=function(e,t,r){var i,s=Math.max(e,t,r),a=s-Math.min(e,t,r);return i=0==a?0:e==s?(6+(t-r)/a)%6:t==s?2+(r-e)/a:r==s?4+(e-t)/a:0,{h:i/=6,s:0!=s?a/s:0,v:s}},h.ColorPicker=function(e,t){this.input=e,this.color={h:0,s:0,v:1,r:1,g:1,b:1,a:1},this.setValue(this.input.value),this.options=G.extend(!0,{},h.defaults),this.setOptions(t),null==this.options.sliders&&(this.options.sliders="wvp"+(0<=this.options.format.indexOf("a")?"a":"")),this.init()},h.ColorPicker.widget=null,h.ColorPicker.overlay=null,h.ColorPicker.init=function(){if(1!=h.ColorPicker.init.hasInit){h.ColorPicker.init.hasInit=!0;var e=G('<div class="jQWCP-overlay" style="display: none;"></div>');e.on("click",h.Handler.overlay_click),h.ColorPicker.overlay=e.get(0),G("body").append(e);var t=h.ColorPicker.getWheelDataUrl(200);G("head").append('<style type="text/css">.jQWCP-wWheel {background-image: url('+t+");}</style>"),G("html").on("mouseup.wheelColorPicker",h.Handler.html_mouseup),G("html").on("touchend.wheelColorPicker",h.Handler.html_mouseup),G("html").on("mousemove.wheelColorPicker",h.Handler.html_mousemove),G("html").on("touchmove.wheelColorPicker",h.Handler.html_mousemove),G(window).on("resize.wheelColorPicker",h.Handler.window_resize)}},h.ColorPicker.createWidget=function(){var e=G("<div class='jQWCP-wWidget'><div class='jQWCP-wWheel'><div class='jQWCP-wWheelOverlay'></div><span class='jQWCP-wWheelCursor'></span></div><div class='jQWCP-wHue jQWCP-slider-wrapper'><canvas class='jQWCP-wHueSlider jQWCP-slider' width='1' height='50' title='Hue'></canvas><span class='jQWCP-wHueCursor jQWCP-scursor'></span></div><div class='jQWCP-wSat jQWCP-slider-wrapper'><canvas class='jQWCP-wSatSlider jQWCP-slider' width='1' height='50' title='Saturation'></canvas><span class='jQWCP-wSatCursor jQWCP-scursor'></span></div><div class='jQWCP-wVal jQWCP-slider-wrapper'><canvas class='jQWCP-wValSlider jQWCP-slider' width='1' height='50' title='Value'></canvas><span class='jQWCP-wValCursor jQWCP-scursor'></span></div><div class='jQWCP-wRed jQWCP-slider-wrapper'><canvas class='jQWCP-wRedSlider jQWCP-slider' width='1' height='50' title='Red'></canvas><span class='jQWCP-wRedCursor jQWCP-scursor'></span></div><div class='jQWCP-wGreen jQWCP-slider-wrapper'><canvas class='jQWCP-wGreenSlider jQWCP-slider' width='1' height='50' title='Green'></canvas><span class='jQWCP-wGreenCursor jQWCP-scursor'></span></div><div class='jQWCP-wBlue jQWCP-slider-wrapper'><canvas class='jQWCP-wBlueSlider jQWCP-slider' width='1' height='50' title='Blue'></canvas><span class='jQWCP-wBlueCursor jQWCP-scursor'></span></div><div class='jQWCP-wAlpha jQWCP-slider-wrapper'><canvas class='jQWCP-wAlphaSlider jQWCP-slider' width='1' height='50' title='Alpha'></canvas><span class='jQWCP-wAlphaCursor jQWCP-scursor'></span></div><div class='jQWCP-wPreview'><canvas class='jQWCP-wPreviewBox' width='1' height='1' title='Selected Color'></canvas></div></div>");return e.find(".jQWCP-wWheel, .jQWCP-slider-wrapper, .jQWCP-scursor, .jQWCP-slider").attr("unselectable","on").css("-moz-user-select","none").css("-webkit-user-select","none").css("user-select","none").css("-webkit-touch-callout","none"),e.on("contextmenu.wheelColorPicker",function(){return!1}),e.on("mousedown.wheelColorPicker",".jQWCP-wWheel",h.Handler.wheel_mousedown),e.on("touchstart.wheelColorPicker",".jQWCP-wWheel",h.Handler.wheel_mousedown),e.on("mousedown.wheelColorPicker",".jQWCP-wWheelCursor",h.Handler.wheelCursor_mousedown),e.on("touchstart.wheelColorPicker",".jQWCP-wWheelCursor",h.Handler.wheelCursor_mousedown),e.on("mousedown.wheelColorPicker",".jQWCP-slider",h.Handler.slider_mousedown),e.on("touchstart.wheelColorPicker",".jQWCP-slider",h.Handler.slider_mousedown),e.on("mousedown.wheelColorPicker",".jQWCP-scursor",h.Handler.sliderCursor_mousedown),e.on("touchstart.wheelColorPicker",".jQWCP-scursor",h.Handler.sliderCursor_mousedown),e.get(0)},h.ColorPicker.getWheelDataUrl=function(e){var t=e/2,r=t,i=document.createElement("canvas");i.width=e,i.height=e;for(var s=i.getContext("2d"),a=0;a<e;a++)for(var o=0;o<e;o++){var n=Math.sqrt(Math.pow(o-r,2)+Math.pow(a-r,2));if(!(2+t<n)){var l=((o-r==0?a<r?90:270:Math.atan((r-a)/(o-r))/Math.PI*180)+(o<r?180:0)+360)%360,d=n/t,h=(Math.abs(360+l)+60)%360<120?1:240<l?(120-Math.abs(l-360))/60:l<120?(120-l)/60:0,u=Math.abs(l-120)<60?1:Math.abs(l-120)<120?(120-Math.abs(l-120))/60:0,c=Math.abs(l-240)<60?1:Math.abs(l-240)<120?(120-Math.abs(l-240))/60:0,p=Math.round(255*(h+(1-h)*(1-d))),C=Math.round(255*(u+(1-u)*(1-d))),f=Math.round(255*(c+(1-c)*(1-d)));s.fillStyle="rgb("+p+","+C+","+f+")",s.fillRect(o,a,1,1)}}return i.toDataURL()},h.ColorPicker.prototype.options=null,h.ColorPicker.prototype.input=null,h.ColorPicker.prototype.widget=null,h.ColorPicker.prototype.color=null,h.ColorPicker.prototype.lastValue=null,h.ColorPicker.prototype.setOptions=function(e){if(e=G.extend(!0,{},e),this.options.htmlOptions)for(var t in h.defaults)this.input.hasAttribute("data-wcp-"+t)&&void 0===e[t]&&(e[t]=this.input.getAttribute("data-wcp-"+t),"true"==e[t]?e[t]=!0:"false"==e[t]&&(e[t]=!1));for(var t in e)if(void 0!==this.options[t]){var r=t.charAt(0).toUpperCase()+t.slice(1);"function"==typeof this["set"+r]?this["set"+r](e[t]):this.options[t]=e[t]}return this},h.ColorPicker.prototype.init=function(){if(h.ColorPicker.init(),1!=this.hasInit){this.hasInit=!0;var e=G(this.input),t=null;"block"==this.options.layout?(this.widget=h.ColorPicker.createWidget(),(t=G(this.widget)).data("jQWCP.instance",this),t.insertAfter(this.input),"inline"==e.css("display")?t.css("display","inline-block"):t.css("display",e.css("display")),t.append(this.input),e.hide(),null!=e.attr("tabindex")?t.attr("tabindex",e.attr("tabindex")):t.attr("tabindex",0),this.refreshWidget(),this.redrawSliders(!0),this.updateSliders(),t.on("focus.wheelColorPicker",h.Handler.widget_focus_block),t.on("blur.wheelColorPicker",h.Handler.widget_blur_block)):(null==h.ColorPicker.widget&&(h.ColorPicker.widget=h.ColorPicker.createWidget(),(t=G(h.ColorPicker.widget)).hide(),G("body").append(t),t.on("mousedown.wheelColorPicker",h.Handler.widget_mousedown_popup)),this.widget=h.ColorPicker.widget,e.on("focus.wheelColorPicker",h.Handler.input_focus_popup),e.on("blur.wheelColorPicker",h.Handler.input_blur_popup)),e.on("keyup.wheelColorPicker",h.Handler.input_keyup),e.on("change.wheelColorPicker",h.Handler.input_change),"object"==typeof this.options.color?(this.setColor(this.options.color),this.options.color=void 0):"string"==typeof this.options.color&&(this.setValue(this.options.color),this.options.color=void 0),this.options.userinput?e.removeAttr("readonly"):e.attr("readonly",!0)}},h.ColorPicker.prototype.destroy=function(){var e=G(this.widget),t=G(this.input);if("block"==this.options.layout){var r=G(G("body").data("jQWCP.activeControl"));if(r.length){var i=r.closest(".jQWCP-wWidget");e.is(i)&&G("body").data("jQWCP.activeControl",null)}e.before(this.input),e.remove(),t.show()}t.off("focus.wheelColorPicker"),t.off("blur.wheelColorPicker"),t.off("keyup.wheelColorPicker"),t.off("change.wheelColorPicker"),t.data("jQWCP.instance",null)},h.ColorPicker.prototype.refreshWidget=function(){var e=G(this.widget),t=this.options,r=!1;for(var i in e.attr("class","jQWCP-wWidget"),"block"==t.layout&&e.addClass("jQWCP-block"),e.addClass(t.cssClass),window.innerWidth<=t.mobileWidth&&"block"!=t.layout&&t.mobile&&(r=!0,e.addClass("jQWCP-mobile")),e.find(".jQWCP-wWheel, .jQWCP-slider-wrapper, .jQWCP-wPreview").hide().addClass("hidden"),t.sliders){var s=null;switch(this.options.sliders[i]){case"w":s=e.find(".jQWCP-wWheel");break;case"h":s=e.find(".jQWCP-wHue");break;case"s":s=e.find(".jQWCP-wSat");break;case"v":s=e.find(".jQWCP-wVal");break;case"r":s=e.find(".jQWCP-wRed");break;case"g":s=e.find(".jQWCP-wGreen");break;case"b":s=e.find(".jQWCP-wBlue");break;case"a":s=e.find(".jQWCP-wAlpha");break;case"p":s=e.find(".jQWCP-wPreview")}null!=s&&(s.appendTo(this.widget),s.show().removeClass("hidden"))}var a=50*t.quality;e.find(".jQWCP-slider").attr("height",a);var o=e.find(".jQWCP-wWheel, .jQWCP-slider-wrapper, .jQWCP-wPreview").not(".hidden");if(t.autoResize&&!r){var n=0;o.css({width:"",height:""}),o.each(function(e,t){var r=G(t);n+=parseFloat(r.css("margin-left").replace("px",""))+parseFloat(r.css("margin-right").replace("px",""))+r.outerWidth()}),e.css({width:n+"px"})}else{e.css({width:""});var l=e.find(".jQWCP-wWheel").not(".hidden"),d=e.find(".jQWCP-slider-wrapper, .jQWCP-wPreview").not(".hidden");if(l.css({height:e.height()+"px",width:e.height()}),0<l.length)var h=e.width()-l.outerWidth()-parseFloat(l.css("margin-left").replace("px",""))-parseFloat(l.css("margin-right").replace("px",""));else h=e.width();if(0<d.length){var u=parseFloat(d.css("margin-left").replace("px",""))+parseFloat(d.css("margin-right").replace("px",""));d.css({height:e.height()+"px",width:(h-(d.length-1)*u)/d.length+"px"})}}return this},h.ColorPicker.prototype.redrawSliders=function(e){if(null==this.widget)return this;var t=G(this.widget);if("string"==typeof e&&(e=arguments[1]),this!=t.data("jQWCP.instance"))return this;var r=this.options,i=this.color,s=50*r.quality,a=1,o=0,n=0,l=0,d=0,h=0,u=1;r.live&&(a=i.a,o=Math.round(255*i.r),n=Math.round(255*i.g),l=Math.round(255*i.b),d=i.h,h=i.s,u=i.v);var c=t.find(".jQWCP-wPreviewBox");if(!c.hasClass("hidden")){var p=c.get(0).getContext("2d");p.fillStyle="rgba("+o+","+n+","+l+","+a+")",p.clearRect(0,0,1,1),p.fillRect(0,0,1,1)}if(!this.options.live&&!e)return this;var C=t.find(".jQWCP-wAlphaSlider");if(!C.hasClass("hidden")||e){var f=C.get(0).getContext("2d"),g=f.createLinearGradient(0,0,0,s);g.addColorStop(0,"rgba("+o+","+n+","+l+",1)"),g.addColorStop(1,"rgba("+o+","+n+","+l+",0)"),f.fillStyle=g,f.clearRect(0,0,1,s),f.fillRect(0,0,1,s)}var v=t.find(".jQWCP-wRedSlider");if(!v.hasClass("hidden")||e){var w=v.get(0).getContext("2d"),P=w.createLinearGradient(0,0,0,s);P.addColorStop(0,"rgb(255,"+n+","+l+")"),P.addColorStop(1,"rgb(0,"+n+","+l+")"),w.fillStyle=P,w.fillRect(0,0,1,s)}var W=t.find(".jQWCP-wGreenSlider");if(!W.hasClass("hidden")||e){var b=W.get(0).getContext("2d"),j=b.createLinearGradient(0,0,0,s);j.addColorStop(0,"rgb("+o+",255,"+l+")"),j.addColorStop(1,"rgb("+o+",0,"+l+")"),b.fillStyle=j,b.fillRect(0,0,1,s)}var Q=t.find(".jQWCP-wBlueSlider");if(!Q.hasClass("hidden")||e){var k=Q.get(0).getContext("2d"),y=k.createLinearGradient(0,0,0,s);y.addColorStop(0,"rgb("+o+","+n+",255)"),y.addColorStop(1,"rgb("+o+","+n+",0)"),k.fillStyle=y,k.fillRect(0,0,1,s)}var m=t.find(".jQWCP-wHueSlider");if(!m.hasClass("hidden")||e){var S=m.get(0).getContext("2d"),N=S.createLinearGradient(0,0,0,s);N.addColorStop(0,"#f00"),N.addColorStop(.166666667,"#ff0"),N.addColorStop(.333333333,"#0f0"),N.addColorStop(.5,"#0ff"),N.addColorStop(.666666667,"#00f"),N.addColorStop(.833333333,"#f0f"),N.addColorStop(1,"#f00"),S.fillStyle=N,S.fillRect(0,0,1,s)}var I=t.find(".jQWCP-wSatSlider");if(!I.hasClass("hidden")||e){var x=G.fn.wheelColorPicker.hsvToRgb(d,1,u);x.r=Math.round(255*x.r),x.g=Math.round(255*x.g),x.b=Math.round(255*x.b);var H=I.get(0).getContext("2d"),_=H.createLinearGradient(0,0,0,s);_.addColorStop(0,"rgb("+x.r+","+x.g+","+x.b+")"),_.addColorStop(1,"rgb("+Math.round(255*u)+","+Math.round(255*u)+","+Math.round(255*u)+")"),H.fillStyle=_,H.fillRect(0,0,1,s)}var R=t.find(".jQWCP-wValSlider");if(!R.hasClass("hidden")||e){var M=G.fn.wheelColorPicker.hsvToRgb(d,h,1);M.r=Math.round(255*M.r),M.g=Math.round(255*M.g),M.b=Math.round(255*M.b);var O=R.get(0).getContext("2d"),A=O.createLinearGradient(0,0,0,s);A.addColorStop(0,"rgb("+M.r+","+M.g+","+M.b+")"),A.addColorStop(1,"#000"),O.fillStyle=A,O.fillRect(0,0,1,s)}return this},h.ColorPicker.prototype.updateSliders=function(){if(null==this.widget)return this;var e=G(this.widget),t=this.color;if(this!=e.data("jQWCP.instance"))return this;var r=e.find(".jQWCP-wWheel");if(!r.hasClass("hidden")){var i=e.find(".jQWCP-wWheelCursor"),s=e.find(".jQWCP-wWheelOverlay"),a=Math.cos(2*Math.PI*t.h)*t.s,o=Math.sin(2*Math.PI*t.h)*t.s,n=r.width()/2,l=r.height()/2;i.css("left",n+a*r.width()/2+"px"),i.css("top",l-o*r.height()/2+"px"),1==this.options.preserveWheel||null==this.options.preserveWheel&&0==this.options.live?s.css("opacity",0):s.css("opacity",1-(t.v<.2?.2:t.v))}var d=e.find(".jQWCP-wHueSlider");d.hasClass("hidden")||e.find(".jQWCP-wHueCursor").css("top",t.h*d.height()+"px");var h=e.find(".jQWCP-wSatSlider");h.hasClass("hidden")||e.find(".jQWCP-wSatCursor").css("top",(1-t.s)*h.height()+"px");var u=e.find(".jQWCP-wValSlider");u.hasClass("hidden")||e.find(".jQWCP-wValCursor").css("top",(1-t.v)*u.height()+"px");var c=e.find(".jQWCP-wRedSlider");c.hasClass("hidden")||e.find(".jQWCP-wRedCursor").css("top",(1-t.r)*c.height()+"px");var p=e.find(".jQWCP-wGreenSlider");p.hasClass("hidden")||e.find(".jQWCP-wGreenCursor").css("top",(1-t.g)*p.height()+"px");var C=e.find(".jQWCP-wBlueSlider");C.hasClass("hidden")||e.find(".jQWCP-wBlueCursor").css("top",(1-t.b)*C.height()+"px");var f=e.find(".jQWCP-wAlphaSlider");f.hasClass("hidden")||e.find(".jQWCP-wAlphaCursor").css("top",(1-t.a)*f.height()+"px");return this},h.ColorPicker.prototype.updateSelection=function(){return this.redrawSliders(),this.updateSliders(),this},h.ColorPicker.prototype.updateInput=function(){if(null==this.widget)return this;var e=G(this.input);this.input.value!=this.getValue()&&(e.attr("value",this.getValue()),this.input.value=this.getValue()),e.trigger("colorchange"),this.options.preview&&(e.css("background",h.colorToStr(this.color,"rgba")),.5<this.color.v?e.css("color","black"):e.css("color","white"))},h.ColorPicker.prototype.updateActiveControl=function(e){var t=G(G("body").data("jQWCP.activeControl"));if(0!=t.length){G(this.input);var r=this.options,i=this.color;if(e.originalEvent.touches&&0<e.originalEvent.touches.length&&(e.pageX=e.originalEvent.touches[0].pageX,e.pageY=e.originalEvent.touches[0].pageY),t.hasClass("jQWCP-wWheel")){var s=t.find(".jQWCP-wWheelCursor"),a=(t.find(".jQWCP-wWheelOverlay"),(e.pageX-t.offset().left-t.width()/2)/(t.width()/2)),o=-(e.pageY-t.offset().top-t.height()/2)/(t.height()/2);if(h.BUG_RELATIVE_PAGE_ORIGIN)a=(e.pageX-(t.get(0).getBoundingClientRect().left-h.ORIGIN.left)-t.width()/2)/(t.width()/2),o=-(e.pageY-(t.get(0).getBoundingClientRect().top-h.ORIGIN.top)-t.height()/2)/(t.height()/2);var n=Math.sqrt(Math.pow(a,2)+Math.pow(o,2));1<n&&(n=1),r.snap&&n<r.snapTolerance&&(n=0);var l=0==a&&0==o?0:Math.atan(o/a)/(2*Math.PI);a<0&&0==o&&(l=.5),l<0&&(l+=.5),o<0&&(l+=.5),this.setHsv(l,n,i.v)}else if(t.hasClass("jQWCP-slider-wrapper")){s=t.find(".jQWCP-scursor"),o=(e.pageY-t.offset().top)/t.height();if(h.BUG_RELATIVE_PAGE_ORIGIN)o=(e.pageY-(t.get(0).getBoundingClientRect().top-h.ORIGIN.top))/t.height();var d=o<0?0:1<o?1:o;r.snap&&d<r.snapTolerance?d=0:r.snap&&d>1-r.snapTolerance&&(d=1),r.snap&&d>.5-r.snapTolerance&&d<.5+r.snapTolerance&&(d=.5),s.css("top",d*t.height()+"px"),t.hasClass("jQWCP-wRed")&&this.setRgb(1-d,i.g,i.b),t.hasClass("jQWCP-wGreen")&&this.setRgb(i.r,1-d,i.b),t.hasClass("jQWCP-wBlue")&&this.setRgb(i.r,i.g,1-d),t.hasClass("jQWCP-wHue")&&this.setHsv(d,i.s,i.v),t.hasClass("jQWCP-wSat")&&this.setHsv(i.h,1-d,i.v),t.hasClass("jQWCP-wVal")&&this.setHsv(i.h,i.s,1-d),t.hasClass("jQWCP-wAlpha")&&this.setAlpha(1-d)}}},h.ColorPicker.prototype.getColor=function(){return this.color},h.ColorPicker.prototype.getValue=function(e){var t=this.options;return null==e&&(e=t.format),0<=t.rounding&&(this.color.a=Math.round(this.color.a*Math.pow(10,t.rounding))/Math.pow(10,t.rounding)),h.colorToStr(this.color,e)},h.ColorPicker.prototype.setValue=function(e,t){var r=h.strToColor(e);return r?this.setColor(r,t):this},h.ColorPicker.prototype.setColor=function(e,t){return"string"==typeof e?this.setValue(e,t):null!=e.r?this.setRgba(e.r,e.g,e.b,e.a,t):null!=e.h?this.setHsva(e.h,e.s,e.v,e.a,t):null!=e.a?this.setAlpha(e.a,t):this},h.ColorPicker.prototype.setRgba=function(e,t,r,i,s){void 0===s&&(s=!0);var a=this.color;a.r=e,a.g=t,a.b=r,null!=i&&(a.a=i);var o=h.rgbToHsv(e,t,r);return a.h=o.h,a.s=o.s,a.v=o.v,this.updateSliders(),this.redrawSliders(),s&&this.updateInput(),this},h.ColorPicker.prototype.setRgb=function(e,t,r,i){return this.setRgba(e,t,r,null,i)},h.ColorPicker.prototype.setHsva=function(e,t,r,i,s){void 0===s&&(s=!0);var a=this.color;a.h=e,a.s=t,a.v=r,null!=i&&(a.a=i);var o=h.hsvToRgb(e,t,r);return a.r=o.r,a.g=o.g,a.b=o.b,this.updateSliders(),this.redrawSliders(),s&&this.updateInput(),this},h.ColorPicker.prototype.setHsv=function(e,t,r,i){return this.setHsva(e,t,r,null,i)},h.ColorPicker.prototype.setAlpha=function(e,t){return void 0===t&&(t=!0),this.color.a=e,this.updateSliders(),this.redrawSliders(),t&&this.updateInput(),this},h.ColorPicker.prototype.show=function(){var e=this.input,t=G(e),r=G(this.widget),i=this.options;if("popup"==i.layout&&(r.data("jQWCP.instance",this),r.stop(!0,!0),r.css({top:e.getBoundingClientRect().top-h.ORIGIN.top+t.outerHeight()+"px",left:e.getBoundingClientRect().left-h.ORIGIN.left+"px"}),this.refreshWidget(),this.redrawSliders(),this.lastValue=e.value,r.fadeIn(i.animDuration),this.updateSliders(),i.hideKeyboard&&(t.blur(),G(h.ColorPicker.overlay).show()),r.hasClass("jQWCP-mobile"))){var s=G("html").scrollTop(),a=e.getBoundingClientRect().top-h.ORIGIN.top;a<s?G("html").animate({scrollTop:a}):a+t.outerHeight()>s+window.innerHeight-r.outerHeight()&&G("html").animate({scrollTop:a+t.outerHeight()-window.innerHeight+r.outerHeight()})}},h.ColorPicker.prototype.hide=function(){var e=G(this.widget);this==e.data("jQWCP.instance")&&(e.fadeOut(this.options.animDuration),G(h.ColorPicker.overlay).hide())},h.Handler={},h.Handler.input_focus_popup=function(e){var t=G(this).data("jQWCP.instance");t.show(),null==G(this).attr("readonly")&&(G(this).attr("readonly",!0),setTimeout(function(){G(t.input).removeAttr("readonly")}),null!=navigator.userAgent.match(/Android .* Firefox/)&&setTimeout(function(){G(t.input).attr("readonly",!0),G(t.input).one("blur",function(){G(t.input).removeAttr("readonly")})}))},h.Handler.input_blur_popup=function(e){var t=G(this).data("jQWCP.instance");t.options.hideKeyboard||(t.hide(),t.lastValue!=this.value&&G(this).trigger("change"))},h.Handler.input_keyup=function(e){var t=G(this).data("jQWCP.instance"),r=h.strToColor(this.value);r&&t.setColor(r,!1)},h.Handler.input_change=function(e){var t=G(this).data("jQWCP.instance"),r=h.strToColor(this.value);t.options.autoFormat&&r?t.setColor(r,!0):t.options.validate&&!r&&""!=this.value&&(this.value=t.getValue())},h.Handler.widget_focus_block=function(e){var t=G(this).data("jQWCP.instance"),r=G(t.input);t.lastValue=t.input.value,r.triggerHandler("focus")},h.Handler.widget_mousedown_popup=function(e){e.preventDefault();var t=G(this).data("jQWCP.instance"),r=G(t.input);if(r.off("focus.wheelColorPicker"),r.off("blur.wheelColorPicker"),null!=r.data("events"))var i=r.data("events").blur;else i=void 0;var s={blur:[]};if(null!=i)for(var a=0;a<i.length;a++)s.blur.push(i[a]);r.data("jQWCP.suspendedEvents",s)},h.Handler.widget_blur_block=function(e){var t=G(this).data("jQWCP.instance"),r=G(t.input);t.lastValue!=t.input.value&&r.trigger("change"),r.triggerHandler("blur")},h.Handler.wheelCursor_mousedown=function(e){e.preventDefault();var t=G(this),r=t.closest(".jQWCP-wWidget").data("jQWCP.instance"),i=G(r.input);G("body").data("jQWCP.activeControl",t.parent().get(0)),i.trigger("sliderdown")},h.Handler.wheel_mousedown=function(e){e.preventDefault();var t=G(this),r=t.closest(".jQWCP-wWidget").data("jQWCP.instance"),i=G(r.input);G("body").data("jQWCP.activeControl",t.get(0)),i.trigger("sliderdown"),r.updateActiveControl(e)},h.Handler.slider_mousedown=function(e){e.preventDefault();var t=G(this),r=t.closest(".jQWCP-wWidget").data("jQWCP.instance"),i=G(r.input);G("body").data("jQWCP.activeControl",t.parent().get(0)),i.trigger("sliderdown"),r.updateActiveControl(e)},h.Handler.sliderCursor_mousedown=function(e){e.preventDefault();var t=G(this),r=t.closest(".jQWCP-wWidget").data("jQWCP.instance"),i=G(r.input);G("body").data("jQWCP.activeControl",t.parent().get(0)),i.trigger("sliderdown")},h.Handler.html_mouseup=function(e){var t=G(G("body").data("jQWCP.activeControl"));if(0!=t.length){var r=t.closest(".jQWCP-wWidget").data("jQWCP.instance"),i=G(r.input);if("popup"==r.options.layout){r.options.hideKeyboard||i.trigger("focus.jQWCP_DONT_TRIGGER_EVENTS"),i.on("focus.wheelColorPicker",h.Handler.input_focus_popup),i.on("blur.wheelColorPicker",h.Handler.input_blur_popup);var s=i.data("jQWCP.suspendedEvents");if(null!=s)for(var a=s.blur,o=0;o<a.length;o++)i.on("blur"+(""==a[o].namespace?"":"."+a[o].namespace),a[o].handler)}0!=t.length&&("touchend"!=e.type&&r.updateActiveControl(e),G("body").data("jQWCP.activeControl",null),i.trigger("sliderup"))}},h.Handler.html_mousemove=function(e){var t=G(G("body").data("jQWCP.activeControl"));if(0!=t.length){e.preventDefault();var r=t.closest(".jQWCP-wWidget").data("jQWCP.instance"),i=G(r.input);return r.updateActiveControl(e),i.trigger("slidermove"),!1}},h.Handler.window_resize=function(e){G("body .jQWCP-wWidget.jQWCP-block").each(function(){var e=G(this).data("jQWCP.instance");e.refreshWidget(),e.redrawSliders()})},h.Handler.overlay_click=function(e){if(null!=h.ColorPicker.widget){var t=G(h.ColorPicker.widget).data("jQWCP.instance");if(null!=t){var r=G(t.input);t.lastValue!=t.input.value&&r.trigger("change"),t.hide()}}},G(document).ready(function(){G("[data-wheelcolorpicker]").wheelColorPicker({htmlOptions:!0})}),null!=G.browser&&G.browser.mozilla&&(G.fn.wheelColorPicker.defaults.quality=.2),G(document).ready(function(){G("body").append('<div id="jQWCP-PageOrigin" style="position: absolute; top: 0; left: 0; height: 0; width: 0;"></div>');var e=document.getElementById("jQWCP-PageOrigin").getBoundingClientRect();h.ORIGIN=e,G(window).on("scroll.jQWCP_RelativePageOriginBugFix",function(){var e=document.getElementById("jQWCP-PageOrigin").getBoundingClientRect();0==(h.ORIGIN=e).left&&0==e.top||(h.BUG_RELATIVE_PAGE_ORIGIN=!0)})})}(jQuery);;
"use strict";function _typeof(e){return(_typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}!function(s){var d={filename:"table.csv",appendTo:"body",separator:",",newline:"\n",quoteFields:!0,trimContent:!0,excludeColumns:"",excludeRows:""},f={};s.fn.table2csv=function(e,t){if("object"===_typeof(e)?(t=e,e="download"):void 0===e&&(e="download"),"string"!=typeof e)throw new Error('"action" argument must be a string');if(void 0!==t&&"object"!==_typeof(t))throw new Error('"options" argument must be an object');f=s.extend({},d,t);var o=this.filter("table");if(o.length<=0)throw new Error("table2csv must be called on a <table> element");if(1<o.length)throw new Error("converting multiple table elements at once is not supported yet");var r,n,i,l,a,u,c=(r="",n=o.find("tr").not(f.excludeRows),i=n.first().find("td,th").filter(":visible").not(f.excludeColumns).length,n.each(function(e,t){s(t).find("td,th").filter(":visible").not(f.excludeColumns).each(function(e,t){var o=s(t),n=f.trimContent?s.trim(o.text()):o.text();r+=f.quoteFields?'"'+n.replace(/"/g,'""')+'"':n,r+=e!==i-1?f.separator:f.newline})}),r);switch(e){case"download":l=f.filename,a=c,(u=document.createElement("a")).setAttribute("href","data:text/csv;charset=utf-8,\ufeff"+encodeURIComponent(a)),u.setAttribute("download",l),u.style.display="none",document.body.appendChild(u),u.click(),document.body.removeChild(u);break;case"output":s(f.appendTo).append(s("<pre>").text(c));break;case"return":return c;default:throw new Error('"action" argument must be one of the supported action strings')}return this}}(jQuery);;
//! moment.js
//! version : 2.10.6
//! authors : Tim Wood, Iskren Chernev, Moment.js contributors
//! license : MIT
//! momentjs.com

(function (global, factory) {
    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
    typeof define === 'function' && define.amd ? define(factory) :
    global.moment = factory()
}(this, function () { 'use strict';

    var hookCallback;

    function utils_hooks__hooks () {
        return hookCallback.apply(null, arguments);
    }

    // This is done to register the method called with moment()
    // without creating circular dependencies.
    function setHookCallback (callback) {
        hookCallback = callback;
    }

    function isArray(input) {
        return Object.prototype.toString.call(input) === '[object Array]';
    }

    function isDate(input) {
        return input instanceof Date || Object.prototype.toString.call(input) === '[object Date]';
    }

    function map(arr, fn) {
        var res = [], i;
        for (i = 0; i < arr.length; ++i) {
            res.push(fn(arr[i], i));
        }
        return res;
    }

    function hasOwnProp(a, b) {
        return Object.prototype.hasOwnProperty.call(a, b);
    }

    function extend(a, b) {
        for (var i in b) {
            if (hasOwnProp(b, i)) {
                a[i] = b[i];
            }
        }

        if (hasOwnProp(b, 'toString')) {
            a.toString = b.toString;
        }

        if (hasOwnProp(b, 'valueOf')) {
            a.valueOf = b.valueOf;
        }

        return a;
    }

    function create_utc__createUTC (input, format, locale, strict) {
        return createLocalOrUTC(input, format, locale, strict, true).utc();
    }

    function defaultParsingFlags() {
        // We need to deep clone this object.
        return {
            empty           : false,
            unusedTokens    : [],
            unusedInput     : [],
            overflow        : -2,
            charsLeftOver   : 0,
            nullInput       : false,
            invalidMonth    : null,
            invalidFormat   : false,
            userInvalidated : false,
            iso             : false
        };
    }

    function getParsingFlags(m) {
        if (m._pf == null) {
            m._pf = defaultParsingFlags();
        }
        return m._pf;
    }

    function valid__isValid(m) {
        if (m._isValid == null) {
            var flags = getParsingFlags(m);
            m._isValid = !isNaN(m._d.getTime()) &&
                flags.overflow < 0 &&
                !flags.empty &&
                !flags.invalidMonth &&
                !flags.invalidWeekday &&
                !flags.nullInput &&
                !flags.invalidFormat &&
                !flags.userInvalidated;

            if (m._strict) {
                m._isValid = m._isValid &&
                    flags.charsLeftOver === 0 &&
                    flags.unusedTokens.length === 0 &&
                    flags.bigHour === undefined;
            }
        }
        return m._isValid;
    }

    function valid__createInvalid (flags) {
        var m = create_utc__createUTC(NaN);
        if (flags != null) {
            extend(getParsingFlags(m), flags);
        }
        else {
            getParsingFlags(m).userInvalidated = true;
        }

        return m;
    }

    var momentProperties = utils_hooks__hooks.momentProperties = [];

    function copyConfig(to, from) {
        var i, prop, val;

        if (typeof from._isAMomentObject !== 'undefined') {
            to._isAMomentObject = from._isAMomentObject;
        }
        if (typeof from._i !== 'undefined') {
            to._i = from._i;
        }
        if (typeof from._f !== 'undefined') {
            to._f = from._f;
        }
        if (typeof from._l !== 'undefined') {
            to._l = from._l;
        }
        if (typeof from._strict !== 'undefined') {
            to._strict = from._strict;
        }
        if (typeof from._tzm !== 'undefined') {
            to._tzm = from._tzm;
        }
        if (typeof from._isUTC !== 'undefined') {
            to._isUTC = from._isUTC;
        }
        if (typeof from._offset !== 'undefined') {
            to._offset = from._offset;
        }
        if (typeof from._pf !== 'undefined') {
            to._pf = getParsingFlags(from);
        }
        if (typeof from._locale !== 'undefined') {
            to._locale = from._locale;
        }

        if (momentProperties.length > 0) {
            for (i in momentProperties) {
                prop = momentProperties[i];
                val = from[prop];
                if (typeof val !== 'undefined') {
                    to[prop] = val;
                }
            }
        }

        return to;
    }

    var updateInProgress = false;

    // Moment prototype object
    function Moment(config) {
        copyConfig(this, config);
        this._d = new Date(config._d != null ? config._d.getTime() : NaN);
        // Prevent infinite loop in case updateOffset creates new moment
        // objects.
        if (updateInProgress === false) {
            updateInProgress = true;
            utils_hooks__hooks.updateOffset(this);
            updateInProgress = false;
        }
    }

    function isMoment (obj) {
        return obj instanceof Moment || (obj != null && obj._isAMomentObject != null);
    }

    function absFloor (number) {
        if (number < 0) {
            return Math.ceil(number);
        } else {
            return Math.floor(number);
        }
    }

    function toInt(argumentForCoercion) {
        var coercedNumber = +argumentForCoercion,
            value = 0;

        if (coercedNumber !== 0 && isFinite(coercedNumber)) {
            value = absFloor(coercedNumber);
        }

        return value;
    }

    function compareArrays(array1, array2, dontConvert) {
        var len = Math.min(array1.length, array2.length),
            lengthDiff = Math.abs(array1.length - array2.length),
            diffs = 0,
            i;
        for (i = 0; i < len; i++) {
            if ((dontConvert && array1[i] !== array2[i]) ||
                (!dontConvert && toInt(array1[i]) !== toInt(array2[i]))) {
                diffs++;
            }
        }
        return diffs + lengthDiff;
    }

    function Locale() {
    }

    var locales = {};
    var globalLocale;

    function normalizeLocale(key) {
        return key ? key.toLowerCase().replace('_', '-') : key;
    }

    // pick the locale from the array
    // try ['en-au', 'en-gb'] as 'en-au', 'en-gb', 'en', as in move through the list trying each
    // substring from most specific to least, but move to the next array item if it's a more specific variant than the current root
    function chooseLocale(names) {
        var i = 0, j, next, locale, split;

        while (i < names.length) {
            split = normalizeLocale(names[i]).split('-');
            j = split.length;
            next = normalizeLocale(names[i + 1]);
            next = next ? next.split('-') : null;
            while (j > 0) {
                locale = loadLocale(split.slice(0, j).join('-'));
                if (locale) {
                    return locale;
                }
                if (next && next.length >= j && compareArrays(split, next, true) >= j - 1) {
                    //the next array item is better than a shallower substring of this one
                    break;
                }
                j--;
            }
            i++;
        }
        return null;
    }

    function loadLocale(name) {
        var oldLocale = null;
        // TODO: Find a better way to register and load all the locales in Node
        if (!locales[name] && typeof module !== 'undefined' &&
                module && module.exports) {
            try {
                oldLocale = globalLocale._abbr;
                require('./locale/' + name);
                // because defineLocale currently also sets the global locale, we
                // want to undo that for lazy loaded locales
                locale_locales__getSetGlobalLocale(oldLocale);
            } catch (e) { }
        }
        return locales[name];
    }

    // This function will load locale and then set the global locale.  If
    // no arguments are passed in, it will simply return the current global
    // locale key.
    function locale_locales__getSetGlobalLocale (key, values) {
        var data;
        if (key) {
            if (typeof values === 'undefined') {
                data = locale_locales__getLocale(key);
            }
            else {
                data = defineLocale(key, values);
            }

            if (data) {
                // moment.duration._locale = moment._locale = data;
                globalLocale = data;
            }
        }

        return globalLocale._abbr;
    }

    function defineLocale (name, values) {
        if (values !== null) {
            values.abbr = name;
            locales[name] = locales[name] || new Locale();
            locales[name].set(values);

            // backwards compat for now: also set the locale
            locale_locales__getSetGlobalLocale(name);

            return locales[name];
        } else {
            // useful for testing
            delete locales[name];
            return null;
        }
    }

    // returns locale data
    function locale_locales__getLocale (key) {
        var locale;

        if (key && key._locale && key._locale._abbr) {
            key = key._locale._abbr;
        }

        if (!key) {
            return globalLocale;
        }

        if (!isArray(key)) {
            //short-circuit everything else
            locale = loadLocale(key);
            if (locale) {
                return locale;
            }
            key = [key];
        }

        return chooseLocale(key);
    }

    var aliases = {};

    function addUnitAlias (unit, shorthand) {
        var lowerCase = unit.toLowerCase();
        aliases[lowerCase] = aliases[lowerCase + 's'] = aliases[shorthand] = unit;
    }

    function normalizeUnits(units) {
        return typeof units === 'string' ? aliases[units] || aliases[units.toLowerCase()] : undefined;
    }

    function normalizeObjectUnits(inputObject) {
        var normalizedInput = {},
            normalizedProp,
            prop;

        for (prop in inputObject) {
            if (hasOwnProp(inputObject, prop)) {
                normalizedProp = normalizeUnits(prop);
                if (normalizedProp) {
                    normalizedInput[normalizedProp] = inputObject[prop];
                }
            }
        }

        return normalizedInput;
    }

    function makeGetSet (unit, keepTime) {
        return function (value) {
            if (value != null) {
                get_set__set(this, unit, value);
                utils_hooks__hooks.updateOffset(this, keepTime);
                return this;
            } else {
                return get_set__get(this, unit);
            }
        };
    }

    function get_set__get (mom, unit) {
        return mom._d['get' + (mom._isUTC ? 'UTC' : '') + unit]();
    }

    function get_set__set (mom, unit, value) {
        return mom._d['set' + (mom._isUTC ? 'UTC' : '') + unit](value);
    }

    // MOMENTS

    function getSet (units, value) {
        var unit;
        if (typeof units === 'object') {
            for (unit in units) {
                this.set(unit, units[unit]);
            }
        } else {
            units = normalizeUnits(units);
            if (typeof this[units] === 'function') {
                return this[units](value);
            }
        }
        return this;
    }

    function zeroFill(number, targetLength, forceSign) {
        var absNumber = '' + Math.abs(number),
            zerosToFill = targetLength - absNumber.length,
            sign = number >= 0;
        return (sign ? (forceSign ? '+' : '') : '-') +
            Math.pow(10, Math.max(0, zerosToFill)).toString().substr(1) + absNumber;
    }

    var formattingTokens = /(\[[^\[]*\])|(\\)?(Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Q|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g;

    var localFormattingTokens = /(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g;

    var formatFunctions = {};

    var formatTokenFunctions = {};

    // token:    'M'
    // padded:   ['MM', 2]
    // ordinal:  'Mo'
    // callback: function () { this.month() + 1 }
    function addFormatToken (token, padded, ordinal, callback) {
        var func = callback;
        if (typeof callback === 'string') {
            func = function () {
                return this[callback]();
            };
        }
        if (token) {
            formatTokenFunctions[token] = func;
        }
        if (padded) {
            formatTokenFunctions[padded[0]] = function () {
                return zeroFill(func.apply(this, arguments), padded[1], padded[2]);
            };
        }
        if (ordinal) {
            formatTokenFunctions[ordinal] = function () {
                return this.localeData().ordinal(func.apply(this, arguments), token);
            };
        }
    }

    function removeFormattingTokens(input) {
        if (input.match(/\[[\s\S]/)) {
            return input.replace(/^\[|\]$/g, '');
        }
        return input.replace(/\\/g, '');
    }

    function makeFormatFunction(format) {
        var array = format.match(formattingTokens), i, length;

        for (i = 0, length = array.length; i < length; i++) {
            if (formatTokenFunctions[array[i]]) {
                array[i] = formatTokenFunctions[array[i]];
            } else {
                array[i] = removeFormattingTokens(array[i]);
            }
        }

        return function (mom) {
            var output = '';
            for (i = 0; i < length; i++) {
                output += array[i] instanceof Function ? array[i].call(mom, format) : array[i];
            }
            return output;
        };
    }

    // format date using native date object
    function formatMoment(m, format) {
        if (!m.isValid()) {
            return m.localeData().invalidDate();
        }

        format = expandFormat(format, m.localeData());
        formatFunctions[format] = formatFunctions[format] || makeFormatFunction(format);

        return formatFunctions[format](m);
    }

    function expandFormat(format, locale) {
        var i = 5;

        function replaceLongDateFormatTokens(input) {
            return locale.longDateFormat(input) || input;
        }

        localFormattingTokens.lastIndex = 0;
        while (i >= 0 && localFormattingTokens.test(format)) {
            format = format.replace(localFormattingTokens, replaceLongDateFormatTokens);
            localFormattingTokens.lastIndex = 0;
            i -= 1;
        }

        return format;
    }

    var match1         = /\d/;            //       0 - 9
    var match2         = /\d\d/;          //      00 - 99
    var match3         = /\d{3}/;         //     000 - 999
    var match4         = /\d{4}/;         //    0000 - 9999
    var match6         = /[+-]?\d{6}/;    // -999999 - 999999
    var match1to2      = /\d\d?/;         //       0 - 99
    var match1to3      = /\d{1,3}/;       //       0 - 999
    var match1to4      = /\d{1,4}/;       //       0 - 9999
    var match1to6      = /[+-]?\d{1,6}/;  // -999999 - 999999

    var matchUnsigned  = /\d+/;           //       0 - inf
    var matchSigned    = /[+-]?\d+/;      //    -inf - inf

    var matchOffset    = /Z|[+-]\d\d:?\d\d/gi; // +00:00 -00:00 +0000 -0000 or Z

    var matchTimestamp = /[+-]?\d+(\.\d{1,3})?/; // 123456789 123456789.123

    // any word (or two) characters or numbers including two/three word month in arabic.
    var matchWord = /[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i;

    var regexes = {};

    function isFunction (sth) {
        // https://github.com/moment/moment/issues/2325
        return typeof sth === 'function' &&
            Object.prototype.toString.call(sth) === '[object Function]';
    }


    function addRegexToken (token, regex, strictRegex) {
        regexes[token] = isFunction(regex) ? regex : function (isStrict) {
            return (isStrict && strictRegex) ? strictRegex : regex;
        };
    }

    function getParseRegexForToken (token, config) {
        if (!hasOwnProp(regexes, token)) {
            return new RegExp(unescapeFormat(token));
        }

        return regexes[token](config._strict, config._locale);
    }

    // Code from http://stackoverflow.com/questions/3561493/is-there-a-regexp-escape-function-in-javascript
    function unescapeFormat(s) {
        return s.replace('\\', '').replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g, function (matched, p1, p2, p3, p4) {
            return p1 || p2 || p3 || p4;
        }).replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&');
    }

    var tokens = {};

    function addParseToken (token, callback) {
        var i, func = callback;
        if (typeof token === 'string') {
            token = [token];
        }
        if (typeof callback === 'number') {
            func = function (input, array) {
                array[callback] = toInt(input);
            };
        }
        for (i = 0; i < token.length; i++) {
            tokens[token[i]] = func;
        }
    }

    function addWeekParseToken (token, callback) {
        addParseToken(token, function (input, array, config, token) {
            config._w = config._w || {};
            callback(input, config._w, config, token);
        });
    }

    function addTimeToArrayFromToken(token, input, config) {
        if (input != null && hasOwnProp(tokens, token)) {
            tokens[token](input, config._a, config, token);
        }
    }

    var YEAR = 0;
    var MONTH = 1;
    var DATE = 2;
    var HOUR = 3;
    var MINUTE = 4;
    var SECOND = 5;
    var MILLISECOND = 6;

    function daysInMonth(year, month) {
        return new Date(Date.UTC(year, month + 1, 0)).getUTCDate();
    }

    // FORMATTING

    addFormatToken('M', ['MM', 2], 'Mo', function () {
        return this.month() + 1;
    });

    addFormatToken('MMM', 0, 0, function (format) {
        return this.localeData().monthsShort(this, format);
    });

    addFormatToken('MMMM', 0, 0, function (format) {
        return this.localeData().months(this, format);
    });

    // ALIASES

    addUnitAlias('month', 'M');

    // PARSING

    addRegexToken('M',    match1to2);
    addRegexToken('MM',   match1to2, match2);
    addRegexToken('MMM',  matchWord);
    addRegexToken('MMMM', matchWord);

    addParseToken(['M', 'MM'], function (input, array) {
        array[MONTH] = toInt(input) - 1;
    });

    addParseToken(['MMM', 'MMMM'], function (input, array, config, token) {
        var month = config._locale.monthsParse(input, token, config._strict);
        // if we didn't find a month name, mark the date as invalid.
        if (month != null) {
            array[MONTH] = month;
        } else {
            getParsingFlags(config).invalidMonth = input;
        }
    });

    // LOCALES

    var defaultLocaleMonths = 'January_February_March_April_May_June_July_August_September_October_November_December'.split('_');
    function localeMonths (m) {
        return this._months[m.month()];
    }

    var defaultLocaleMonthsShort = 'Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec'.split('_');
    function localeMonthsShort (m) {
        return this._monthsShort[m.month()];
    }

    function localeMonthsParse (monthName, format, strict) {
        var i, mom, regex;

        if (!this._monthsParse) {
            this._monthsParse = [];
            this._longMonthsParse = [];
            this._shortMonthsParse = [];
        }

        for (i = 0; i < 12; i++) {
            // make the regex if we don't have it already
            mom = create_utc__createUTC([2000, i]);
            if (strict && !this._longMonthsParse[i]) {
                this._longMonthsParse[i] = new RegExp('^' + this.months(mom, '').replace('.', '') + '$', 'i');
                this._shortMonthsParse[i] = new RegExp('^' + this.monthsShort(mom, '').replace('.', '') + '$', 'i');
            }
            if (!strict && !this._monthsParse[i]) {
                regex = '^' + this.months(mom, '') + '|^' + this.monthsShort(mom, '');
                this._monthsParse[i] = new RegExp(regex.replace('.', ''), 'i');
            }
            // test the regex
            if (strict && format === 'MMMM' && this._longMonthsParse[i].test(monthName)) {
                return i;
            } else if (strict && format === 'MMM' && this._shortMonthsParse[i].test(monthName)) {
                return i;
            } else if (!strict && this._monthsParse[i].test(monthName)) {
                return i;
            }
        }
    }

    // MOMENTS

    function setMonth (mom, value) {
        var dayOfMonth;

        // TODO: Move this out of here!
        if (typeof value === 'string') {
            value = mom.localeData().monthsParse(value);
            // TODO: Another silent failure?
            if (typeof value !== 'number') {
                return mom;
            }
        }

        dayOfMonth = Math.min(mom.date(), daysInMonth(mom.year(), value));
        mom._d['set' + (mom._isUTC ? 'UTC' : '') + 'Month'](value, dayOfMonth);
        return mom;
    }

    function getSetMonth (value) {
        if (value != null) {
            setMonth(this, value);
            utils_hooks__hooks.updateOffset(this, true);
            return this;
        } else {
            return get_set__get(this, 'Month');
        }
    }

    function getDaysInMonth () {
        return daysInMonth(this.year(), this.month());
    }

    function checkOverflow (m) {
        var overflow;
        var a = m._a;

        if (a && getParsingFlags(m).overflow === -2) {
            overflow =
                a[MONTH]       < 0 || a[MONTH]       > 11  ? MONTH :
                a[DATE]        < 1 || a[DATE]        > daysInMonth(a[YEAR], a[MONTH]) ? DATE :
                a[HOUR]        < 0 || a[HOUR]        > 24 || (a[HOUR] === 24 && (a[MINUTE] !== 0 || a[SECOND] !== 0 || a[MILLISECOND] !== 0)) ? HOUR :
                a[MINUTE]      < 0 || a[MINUTE]      > 59  ? MINUTE :
                a[SECOND]      < 0 || a[SECOND]      > 59  ? SECOND :
                a[MILLISECOND] < 0 || a[MILLISECOND] > 999 ? MILLISECOND :
                -1;

            if (getParsingFlags(m)._overflowDayOfYear && (overflow < YEAR || overflow > DATE)) {
                overflow = DATE;
            }

            getParsingFlags(m).overflow = overflow;
        }

        return m;
    }

    function warn(msg) {
        if (utils_hooks__hooks.suppressDeprecationWarnings === false && typeof console !== 'undefined' && console.warn) {
            console.warn('Deprecation warning: ' + msg);
        }
    }

    function deprecate(msg, fn) {
        var firstTime = true;

        return extend(function () {
            if (firstTime) {
                warn(msg + '\n' + (new Error()).stack);
                firstTime = false;
            }
            return fn.apply(this, arguments);
        }, fn);
    }

    var deprecations = {};

    function deprecateSimple(name, msg) {
        if (!deprecations[name]) {
            warn(msg);
            deprecations[name] = true;
        }
    }

    utils_hooks__hooks.suppressDeprecationWarnings = false;

    var from_string__isoRegex = /^\s*(?:[+-]\d{6}|\d{4})-(?:(\d\d-\d\d)|(W\d\d$)|(W\d\d-\d)|(\d\d\d))((T| )(\d\d(:\d\d(:\d\d(\.\d+)?)?)?)?([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?$/;

    var isoDates = [
        ['YYYYYY-MM-DD', /[+-]\d{6}-\d{2}-\d{2}/],
        ['YYYY-MM-DD', /\d{4}-\d{2}-\d{2}/],
        ['GGGG-[W]WW-E', /\d{4}-W\d{2}-\d/],
        ['GGGG-[W]WW', /\d{4}-W\d{2}/],
        ['YYYY-DDD', /\d{4}-\d{3}/]
    ];

    // iso time formats and regexes
    var isoTimes = [
        ['HH:mm:ss.SSSS', /(T| )\d\d:\d\d:\d\d\.\d+/],
        ['HH:mm:ss', /(T| )\d\d:\d\d:\d\d/],
        ['HH:mm', /(T| )\d\d:\d\d/],
        ['HH', /(T| )\d\d/]
    ];

    var aspNetJsonRegex = /^\/?Date\((\-?\d+)/i;

    // date from iso format
    function configFromISO(config) {
        var i, l,
            string = config._i,
            match = from_string__isoRegex.exec(string);

        if (match) {
            getParsingFlags(config).iso = true;
            for (i = 0, l = isoDates.length; i < l; i++) {
                if (isoDates[i][1].exec(string)) {
                    config._f = isoDates[i][0];
                    break;
                }
            }
            for (i = 0, l = isoTimes.length; i < l; i++) {
                if (isoTimes[i][1].exec(string)) {
                    // match[6] should be 'T' or space
                    config._f += (match[6] || ' ') + isoTimes[i][0];
                    break;
                }
            }
            if (string.match(matchOffset)) {
                config._f += 'Z';
            }
            configFromStringAndFormat(config);
        } else {
            config._isValid = false;
        }
    }

    // date from iso format or fallback
    function configFromString(config) {
        var matched = aspNetJsonRegex.exec(config._i);

        if (matched !== null) {
            config._d = new Date(+matched[1]);
            return;
        }

        configFromISO(config);
        if (config._isValid === false) {
            delete config._isValid;
            utils_hooks__hooks.createFromInputFallback(config);
        }
    }

    utils_hooks__hooks.createFromInputFallback = deprecate(
        'moment construction falls back to js Date. This is ' +
        'discouraged and will be removed in upcoming major ' +
        'release. Please refer to ' +
        'https://github.com/moment/moment/issues/1407 for more info.',
        function (config) {
            config._d = new Date(config._i + (config._useUTC ? ' UTC' : ''));
        }
    );

    function createDate (y, m, d, h, M, s, ms) {
        //can't just apply() to create a date:
        //http://stackoverflow.com/questions/181348/instantiating-a-javascript-object-by-calling-prototype-constructor-apply
        var date = new Date(y, m, d, h, M, s, ms);

        //the date constructor doesn't accept years < 1970
        if (y < 1970) {
            date.setFullYear(y);
        }
        return date;
    }

    function createUTCDate (y) {
        var date = new Date(Date.UTC.apply(null, arguments));
        if (y < 1970) {
            date.setUTCFullYear(y);
        }
        return date;
    }

    addFormatToken(0, ['YY', 2], 0, function () {
        return this.year() % 100;
    });

    addFormatToken(0, ['YYYY',   4],       0, 'year');
    addFormatToken(0, ['YYYYY',  5],       0, 'year');
    addFormatToken(0, ['YYYYYY', 6, true], 0, 'year');

    // ALIASES

    addUnitAlias('year', 'y');

    // PARSING

    addRegexToken('Y',      matchSigned);
    addRegexToken('YY',     match1to2, match2);
    addRegexToken('YYYY',   match1to4, match4);
    addRegexToken('YYYYY',  match1to6, match6);
    addRegexToken('YYYYYY', match1to6, match6);

    addParseToken(['YYYYY', 'YYYYYY'], YEAR);
    addParseToken('YYYY', function (input, array) {
        array[YEAR] = input.length === 2 ? utils_hooks__hooks.parseTwoDigitYear(input) : toInt(input);
    });
    addParseToken('YY', function (input, array) {
        array[YEAR] = utils_hooks__hooks.parseTwoDigitYear(input);
    });

    // HELPERS

    function daysInYear(year) {
        return isLeapYear(year) ? 366 : 365;
    }

    function isLeapYear(year) {
        return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0;
    }

    // HOOKS

    utils_hooks__hooks.parseTwoDigitYear = function (input) {
        return toInt(input) + (toInt(input) > 68 ? 1900 : 2000);
    };

    // MOMENTS

    var getSetYear = makeGetSet('FullYear', false);

    function getIsLeapYear () {
        return isLeapYear(this.year());
    }

    addFormatToken('w', ['ww', 2], 'wo', 'week');
    addFormatToken('W', ['WW', 2], 'Wo', 'isoWeek');

    // ALIASES

    addUnitAlias('week', 'w');
    addUnitAlias('isoWeek', 'W');

    // PARSING

    addRegexToken('w',  match1to2);
    addRegexToken('ww', match1to2, match2);
    addRegexToken('W',  match1to2);
    addRegexToken('WW', match1to2, match2);

    addWeekParseToken(['w', 'ww', 'W', 'WW'], function (input, week, config, token) {
        week[token.substr(0, 1)] = toInt(input);
    });

    // HELPERS

    // firstDayOfWeek       0 = sun, 6 = sat
    //                      the day of the week that starts the week
    //                      (usually sunday or monday)
    // firstDayOfWeekOfYear 0 = sun, 6 = sat
    //                      the first week is the week that contains the first
    //                      of this day of the week
    //                      (eg. ISO weeks use thursday (4))
    function weekOfYear(mom, firstDayOfWeek, firstDayOfWeekOfYear) {
        var end = firstDayOfWeekOfYear - firstDayOfWeek,
            daysToDayOfWeek = firstDayOfWeekOfYear - mom.day(),
            adjustedMoment;


        if (daysToDayOfWeek > end) {
            daysToDayOfWeek -= 7;
        }

        if (daysToDayOfWeek < end - 7) {
            daysToDayOfWeek += 7;
        }

        adjustedMoment = local__createLocal(mom).add(daysToDayOfWeek, 'd');
        return {
            week: Math.ceil(adjustedMoment.dayOfYear() / 7),
            year: adjustedMoment.year()
        };
    }

    // LOCALES

    function localeWeek (mom) {
        return weekOfYear(mom, this._week.dow, this._week.doy).week;
    }

    var defaultLocaleWeek = {
        dow : 0, // Sunday is the first day of the week.
        doy : 6  // The week that contains Jan 1st is the first week of the year.
    };

    function localeFirstDayOfWeek () {
        return this._week.dow;
    }

    function localeFirstDayOfYear () {
        return this._week.doy;
    }

    // MOMENTS

    function getSetWeek (input) {
        var week = this.localeData().week(this);
        return input == null ? week : this.add((input - week) * 7, 'd');
    }

    function getSetISOWeek (input) {
        var week = weekOfYear(this, 1, 4).week;
        return input == null ? week : this.add((input - week) * 7, 'd');
    }

    addFormatToken('DDD', ['DDDD', 3], 'DDDo', 'dayOfYear');

    // ALIASES

    addUnitAlias('dayOfYear', 'DDD');

    // PARSING

    addRegexToken('DDD',  match1to3);
    addRegexToken('DDDD', match3);
    addParseToken(['DDD', 'DDDD'], function (input, array, config) {
        config._dayOfYear = toInt(input);
    });

    // HELPERS

    //http://en.wikipedia.org/wiki/ISO_week_date#Calculating_a_date_given_the_year.2C_week_number_and_weekday
    function dayOfYearFromWeeks(year, week, weekday, firstDayOfWeekOfYear, firstDayOfWeek) {
        var week1Jan = 6 + firstDayOfWeek - firstDayOfWeekOfYear, janX = createUTCDate(year, 0, 1 + week1Jan), d = janX.getUTCDay(), dayOfYear;
        if (d < firstDayOfWeek) {
            d += 7;
        }

        weekday = weekday != null ? 1 * weekday : firstDayOfWeek;

        dayOfYear = 1 + week1Jan + 7 * (week - 1) - d + weekday;

        return {
            year: dayOfYear > 0 ? year : year - 1,
            dayOfYear: dayOfYear > 0 ?  dayOfYear : daysInYear(year - 1) + dayOfYear
        };
    }

    // MOMENTS

    function getSetDayOfYear (input) {
        var dayOfYear = Math.round((this.clone().startOf('day') - this.clone().startOf('year')) / 864e5) + 1;
        return input == null ? dayOfYear : this.add((input - dayOfYear), 'd');
    }

    // Pick the first defined of two or three arguments.
    function defaults(a, b, c) {
        if (a != null) {
            return a;
        }
        if (b != null) {
            return b;
        }
        return c;
    }

    function currentDateArray(config) {
        var now = new Date();
        if (config._useUTC) {
            return [now.getUTCFullYear(), now.getUTCMonth(), now.getUTCDate()];
        }
        return [now.getFullYear(), now.getMonth(), now.getDate()];
    }

    // convert an array to a date.
    // the array should mirror the parameters below
    // note: all values past the year are optional and will default to the lowest possible value.
    // [year, month, day , hour, minute, second, millisecond]
    function configFromArray (config) {
        var i, date, input = [], currentDate, yearToUse;

        if (config._d) {
            return;
        }

        currentDate = currentDateArray(config);

        //compute day of the year from weeks and weekdays
        if (config._w && config._a[DATE] == null && config._a[MONTH] == null) {
            dayOfYearFromWeekInfo(config);
        }

        //if the day of the year is set, figure out what it is
        if (config._dayOfYear) {
            yearToUse = defaults(config._a[YEAR], currentDate[YEAR]);

            if (config._dayOfYear > daysInYear(yearToUse)) {
                getParsingFlags(config)._overflowDayOfYear = true;
            }

            date = createUTCDate(yearToUse, 0, config._dayOfYear);
            config._a[MONTH] = date.getUTCMonth();
            config._a[DATE] = date.getUTCDate();
        }

        // Default to current date.
        // * if no year, month, day of month are given, default to today
        // * if day of month is given, default month and year
        // * if month is given, default only year
        // * if year is given, don't default anything
        for (i = 0; i < 3 && config._a[i] == null; ++i) {
            config._a[i] = input[i] = currentDate[i];
        }

        // Zero out whatever was not defaulted, including time
        for (; i < 7; i++) {
            config._a[i] = input[i] = (config._a[i] == null) ? (i === 2 ? 1 : 0) : config._a[i];
        }

        // Check for 24:00:00.000
        if (config._a[HOUR] === 24 &&
                config._a[MINUTE] === 0 &&
                config._a[SECOND] === 0 &&
                config._a[MILLISECOND] === 0) {
            config._nextDay = true;
            config._a[HOUR] = 0;
        }

        config._d = (config._useUTC ? createUTCDate : createDate).apply(null, input);
        // Apply timezone offset from input. The actual utcOffset can be changed
        // with parseZone.
        if (config._tzm != null) {
            config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);
        }

        if (config._nextDay) {
            config._a[HOUR] = 24;
        }
    }

    function dayOfYearFromWeekInfo(config) {
        var w, weekYear, week, weekday, dow, doy, temp;

        w = config._w;
        if (w.GG != null || w.W != null || w.E != null) {
            dow = 1;
            doy = 4;

            // TODO: We need to take the current isoWeekYear, but that depends on
            // how we interpret now (local, utc, fixed offset). So create
            // a now version of current config (take local/utc/offset flags, and
            // create now).
            weekYear = defaults(w.GG, config._a[YEAR], weekOfYear(local__createLocal(), 1, 4).year);
            week = defaults(w.W, 1);
            weekday = defaults(w.E, 1);
        } else {
            dow = config._locale._week.dow;
            doy = config._locale._week.doy;

            weekYear = defaults(w.gg, config._a[YEAR], weekOfYear(local__createLocal(), dow, doy).year);
            week = defaults(w.w, 1);

            if (w.d != null) {
                // weekday -- low day numbers are considered next week
                weekday = w.d;
                if (weekday < dow) {
                    ++week;
                }
            } else if (w.e != null) {
                // local weekday -- counting starts from begining of week
                weekday = w.e + dow;
            } else {
                // default to begining of week
                weekday = dow;
            }
        }
        temp = dayOfYearFromWeeks(weekYear, week, weekday, doy, dow);

        config._a[YEAR] = temp.year;
        config._dayOfYear = temp.dayOfYear;
    }

    utils_hooks__hooks.ISO_8601 = function () {};

    // date from string and format string
    function configFromStringAndFormat(config) {
        // TODO: Move this to another part of the creation flow to prevent circular deps
        if (config._f === utils_hooks__hooks.ISO_8601) {
            configFromISO(config);
            return;
        }

        config._a = [];
        getParsingFlags(config).empty = true;

        // This array is used to make a Date, either with `new Date` or `Date.UTC`
        var string = '' + config._i,
            i, parsedInput, tokens, token, skipped,
            stringLength = string.length,
            totalParsedInputLength = 0;

        tokens = expandFormat(config._f, config._locale).match(formattingTokens) || [];

        for (i = 0; i < tokens.length; i++) {
            token = tokens[i];
            parsedInput = (string.match(getParseRegexForToken(token, config)) || [])[0];
            if (parsedInput) {
                skipped = string.substr(0, string.indexOf(parsedInput));
                if (skipped.length > 0) {
                    getParsingFlags(config).unusedInput.push(skipped);
                }
                string = string.slice(string.indexOf(parsedInput) + parsedInput.length);
                totalParsedInputLength += parsedInput.length;
            }
            // don't parse if it's not a known token
            if (formatTokenFunctions[token]) {
                if (parsedInput) {
                    getParsingFlags(config).empty = false;
                }
                else {
                    getParsingFlags(config).unusedTokens.push(token);
                }
                addTimeToArrayFromToken(token, parsedInput, config);
            }
            else if (config._strict && !parsedInput) {
                getParsingFlags(config).unusedTokens.push(token);
            }
        }

        // add remaining unparsed input length to the string
        getParsingFlags(config).charsLeftOver = stringLength - totalParsedInputLength;
        if (string.length > 0) {
            getParsingFlags(config).unusedInput.push(string);
        }

        // clear _12h flag if hour is <= 12
        if (getParsingFlags(config).bigHour === true &&
                config._a[HOUR] <= 12 &&
                config._a[HOUR] > 0) {
            getParsingFlags(config).bigHour = undefined;
        }
        // handle meridiem
        config._a[HOUR] = meridiemFixWrap(config._locale, config._a[HOUR], config._meridiem);

        configFromArray(config);
        checkOverflow(config);
    }


    function meridiemFixWrap (locale, hour, meridiem) {
        var isPm;

        if (meridiem == null) {
            // nothing to do
            return hour;
        }
        if (locale.meridiemHour != null) {
            return locale.meridiemHour(hour, meridiem);
        } else if (locale.isPM != null) {
            // Fallback
            isPm = locale.isPM(meridiem);
            if (isPm && hour < 12) {
                hour += 12;
            }
            if (!isPm && hour === 12) {
                hour = 0;
            }
            return hour;
        } else {
            // this is not supposed to happen
            return hour;
        }
    }

    function configFromStringAndArray(config) {
        var tempConfig,
            bestMoment,

            scoreToBeat,
            i,
            currentScore;

        if (config._f.length === 0) {
            getParsingFlags(config).invalidFormat = true;
            config._d = new Date(NaN);
            return;
        }

        for (i = 0; i < config._f.length; i++) {
            currentScore = 0;
            tempConfig = copyConfig({}, config);
            if (config._useUTC != null) {
                tempConfig._useUTC = config._useUTC;
            }
            tempConfig._f = config._f[i];
            configFromStringAndFormat(tempConfig);

            if (!valid__isValid(tempConfig)) {
                continue;
            }

            // if there is any input that was not parsed add a penalty for that format
            currentScore += getParsingFlags(tempConfig).charsLeftOver;

            //or tokens
            currentScore += getParsingFlags(tempConfig).unusedTokens.length * 10;

            getParsingFlags(tempConfig).score = currentScore;

            if (scoreToBeat == null || currentScore < scoreToBeat) {
                scoreToBeat = currentScore;
                bestMoment = tempConfig;
            }
        }

        extend(config, bestMoment || tempConfig);
    }

    function configFromObject(config) {
        if (config._d) {
            return;
        }

        var i = normalizeObjectUnits(config._i);
        config._a = [i.year, i.month, i.day || i.date, i.hour, i.minute, i.second, i.millisecond];

        configFromArray(config);
    }

    function createFromConfig (config) {
        var res = new Moment(checkOverflow(prepareConfig(config)));
        if (res._nextDay) {
            // Adding is smart enough around DST
            res.add(1, 'd');
            res._nextDay = undefined;
        }

        return res;
    }

    function prepareConfig (config) {
        var input = config._i,
            format = config._f;

        config._locale = config._locale || locale_locales__getLocale(config._l);

        if (input === null || (format === undefined && input === '')) {
            return valid__createInvalid({nullInput: true});
        }

        if (typeof input === 'string') {
            config._i = input = config._locale.preparse(input);
        }

        if (isMoment(input)) {
            return new Moment(checkOverflow(input));
        } else if (isArray(format)) {
            configFromStringAndArray(config);
        } else if (format) {
            configFromStringAndFormat(config);
        } else if (isDate(input)) {
            config._d = input;
        } else {
            configFromInput(config);
        }

        return config;
    }

    function configFromInput(config) {
        var input = config._i;
        if (input === undefined) {
            config._d = new Date();
        } else if (isDate(input)) {
            config._d = new Date(+input);
        } else if (typeof input === 'string') {
            configFromString(config);
        } else if (isArray(input)) {
            config._a = map(input.slice(0), function (obj) {
                return parseInt(obj, 10);
            });
            configFromArray(config);
        } else if (typeof(input) === 'object') {
            configFromObject(config);
        } else if (typeof(input) === 'number') {
            // from milliseconds
            config._d = new Date(input);
        } else {
            utils_hooks__hooks.createFromInputFallback(config);
        }
    }

    function createLocalOrUTC (input, format, locale, strict, isUTC) {
        var c = {};

        if (typeof(locale) === 'boolean') {
            strict = locale;
            locale = undefined;
        }
        // object construction must be done this way.
        // https://github.com/moment/moment/issues/1423
        c._isAMomentObject = true;
        c._useUTC = c._isUTC = isUTC;
        c._l = locale;
        c._i = input;
        c._f = format;
        c._strict = strict;

        return createFromConfig(c);
    }

    function local__createLocal (input, format, locale, strict) {
        return createLocalOrUTC(input, format, locale, strict, false);
    }

    var prototypeMin = deprecate(
         'moment().min is deprecated, use moment.min instead. https://github.com/moment/moment/issues/1548',
         function () {
             var other = local__createLocal.apply(null, arguments);
             return other < this ? this : other;
         }
     );

    var prototypeMax = deprecate(
        'moment().max is deprecated, use moment.max instead. https://github.com/moment/moment/issues/1548',
        function () {
            var other = local__createLocal.apply(null, arguments);
            return other > this ? this : other;
        }
    );

    // Pick a moment m from moments so that m[fn](other) is true for all
    // other. This relies on the function fn to be transitive.
    //
    // moments should either be an array of moment objects or an array, whose
    // first element is an array of moment objects.
    function pickBy(fn, moments) {
        var res, i;
        if (moments.length === 1 && isArray(moments[0])) {
            moments = moments[0];
        }
        if (!moments.length) {
            return local__createLocal();
        }
        res = moments[0];
        for (i = 1; i < moments.length; ++i) {
            if (!moments[i].isValid() || moments[i][fn](res)) {
                res = moments[i];
            }
        }
        return res;
    }

    // TODO: Use [].sort instead?
    function min () {
        var args = [].slice.call(arguments, 0);

        return pickBy('isBefore', args);
    }

    function max () {
        var args = [].slice.call(arguments, 0);

        return pickBy('isAfter', args);
    }

    function Duration (duration) {
        var normalizedInput = normalizeObjectUnits(duration),
            years = normalizedInput.year || 0,
            quarters = normalizedInput.quarter || 0,
            months = normalizedInput.month || 0,
            weeks = normalizedInput.week || 0,
            days = normalizedInput.day || 0,
            hours = normalizedInput.hour || 0,
            minutes = normalizedInput.minute || 0,
            seconds = normalizedInput.second || 0,
            milliseconds = normalizedInput.millisecond || 0;

        // representation for dateAddRemove
        this._milliseconds = +milliseconds +
            seconds * 1e3 + // 1000
            minutes * 6e4 + // 1000 * 60
            hours * 36e5; // 1000 * 60 * 60
        // Because of dateAddRemove treats 24 hours as different from a
        // day when working around DST, we need to store them separately
        this._days = +days +
            weeks * 7;
        // It is impossible translate months into days without knowing
        // which months you are are talking about, so we have to store
        // it separately.
        this._months = +months +
            quarters * 3 +
            years * 12;

        this._data = {};

        this._locale = locale_locales__getLocale();

        this._bubble();
    }

    function isDuration (obj) {
        return obj instanceof Duration;
    }

    function offset (token, separator) {
        addFormatToken(token, 0, 0, function () {
            var offset = this.utcOffset();
            var sign = '+';
            if (offset < 0) {
                offset = -offset;
                sign = '-';
            }
            return sign + zeroFill(~~(offset / 60), 2) + separator + zeroFill(~~(offset) % 60, 2);
        });
    }

    offset('Z', ':');
    offset('ZZ', '');

    // PARSING

    addRegexToken('Z',  matchOffset);
    addRegexToken('ZZ', matchOffset);
    addParseToken(['Z', 'ZZ'], function (input, array, config) {
        config._useUTC = true;
        config._tzm = offsetFromString(input);
    });

    // HELPERS

    // timezone chunker
    // '+10:00' > ['10',  '00']
    // '-1530'  > ['-15', '30']
    var chunkOffset = /([\+\-]|\d\d)/gi;

    function offsetFromString(string) {
        var matches = ((string || '').match(matchOffset) || []);
        var chunk   = matches[matches.length - 1] || [];
        var parts   = (chunk + '').match(chunkOffset) || ['-', 0, 0];
        var minutes = +(parts[1] * 60) + toInt(parts[2]);

        return parts[0] === '+' ? minutes : -minutes;
    }

    // Return a moment from input, that is local/utc/zone equivalent to model.
    function cloneWithOffset(input, model) {
        var res, diff;
        if (model._isUTC) {
            res = model.clone();
            diff = (isMoment(input) || isDate(input) ? +input : +local__createLocal(input)) - (+res);
            // Use low-level api, because this fn is low-level api.
            res._d.setTime(+res._d + diff);
            utils_hooks__hooks.updateOffset(res, false);
            return res;
        } else {
            return local__createLocal(input).local();
        }
    }

    function getDateOffset (m) {
        // On Firefox.24 Date#getTimezoneOffset returns a floating point.
        // https://github.com/moment/moment/pull/1871
        return -Math.round(m._d.getTimezoneOffset() / 15) * 15;
    }

    // HOOKS

    // This function will be called whenever a moment is mutated.
    // It is intended to keep the offset in sync with the timezone.
    utils_hooks__hooks.updateOffset = function () {};

    // MOMENTS

    // keepLocalTime = true means only change the timezone, without
    // affecting the local hour. So 5:31:26 +0300 --[utcOffset(2, true)]-->
    // 5:31:26 +0200 It is possible that 5:31:26 doesn't exist with offset
    // +0200, so we adjust the time as needed, to be valid.
    //
    // Keeping the time actually adds/subtracts (one hour)
    // from the actual represented time. That is why we call updateOffset
    // a second time. In case it wants us to change the offset again
    // _changeInProgress == true case, then we have to adjust, because
    // there is no such time in the given timezone.
    function getSetOffset (input, keepLocalTime) {
        var offset = this._offset || 0,
            localAdjust;
        if (input != null) {
            if (typeof input === 'string') {
                input = offsetFromString(input);
            }
            if (Math.abs(input) < 16) {
                input = input * 60;
            }
            if (!this._isUTC && keepLocalTime) {
                localAdjust = getDateOffset(this);
            }
            this._offset = input;
            this._isUTC = true;
            if (localAdjust != null) {
                this.add(localAdjust, 'm');
            }
            if (offset !== input) {
                if (!keepLocalTime || this._changeInProgress) {
                    add_subtract__addSubtract(this, create__createDuration(input - offset, 'm'), 1, false);
                } else if (!this._changeInProgress) {
                    this._changeInProgress = true;
                    utils_hooks__hooks.updateOffset(this, true);
                    this._changeInProgress = null;
                }
            }
            return this;
        } else {
            return this._isUTC ? offset : getDateOffset(this);
        }
    }

    function getSetZone (input, keepLocalTime) {
        if (input != null) {
            if (typeof input !== 'string') {
                input = -input;
            }

            this.utcOffset(input, keepLocalTime);

            return this;
        } else {
            return -this.utcOffset();
        }
    }

    function setOffsetToUTC (keepLocalTime) {
        return this.utcOffset(0, keepLocalTime);
    }

    function setOffsetToLocal (keepLocalTime) {
        if (this._isUTC) {
            this.utcOffset(0, keepLocalTime);
            this._isUTC = false;

            if (keepLocalTime) {
                this.subtract(getDateOffset(this), 'm');
            }
        }
        return this;
    }

    function setOffsetToParsedOffset () {
        if (this._tzm) {
            this.utcOffset(this._tzm);
        } else if (typeof this._i === 'string') {
            this.utcOffset(offsetFromString(this._i));
        }
        return this;
    }

    function hasAlignedHourOffset (input) {
        input = input ? local__createLocal(input).utcOffset() : 0;

        return (this.utcOffset() - input) % 60 === 0;
    }

    function isDaylightSavingTime () {
        return (
            this.utcOffset() > this.clone().month(0).utcOffset() ||
            this.utcOffset() > this.clone().month(5).utcOffset()
        );
    }

    function isDaylightSavingTimeShifted () {
        if (typeof this._isDSTShifted !== 'undefined') {
            return this._isDSTShifted;
        }

        var c = {};

        copyConfig(c, this);
        c = prepareConfig(c);

        if (c._a) {
            var other = c._isUTC ? create_utc__createUTC(c._a) : local__createLocal(c._a);
            this._isDSTShifted = this.isValid() &&
                compareArrays(c._a, other.toArray()) > 0;
        } else {
            this._isDSTShifted = false;
        }

        return this._isDSTShifted;
    }

    function isLocal () {
        return !this._isUTC;
    }

    function isUtcOffset () {
        return this._isUTC;
    }

    function isUtc () {
        return this._isUTC && this._offset === 0;
    }

    var aspNetRegex = /(\-)?(?:(\d*)\.)?(\d+)\:(\d+)(?:\:(\d+)\.?(\d{3})?)?/;

    // from http://docs.closure-library.googlecode.com/git/closure_goog_date_date.js.source.html
    // somewhat more in line with 4.4.3.2 2004 spec, but allows decimal anywhere
    var create__isoRegex = /^(-)?P(?:(?:([0-9,.]*)Y)?(?:([0-9,.]*)M)?(?:([0-9,.]*)D)?(?:T(?:([0-9,.]*)H)?(?:([0-9,.]*)M)?(?:([0-9,.]*)S)?)?|([0-9,.]*)W)$/;

    function create__createDuration (input, key) {
        var duration = input,
            // matching against regexp is expensive, do it on demand
            match = null,
            sign,
            ret,
            diffRes;

        if (isDuration(input)) {
            duration = {
                ms : input._milliseconds,
                d  : input._days,
                M  : input._months
            };
        } else if (typeof input === 'number') {
            duration = {};
            if (key) {
                duration[key] = input;
            } else {
                duration.milliseconds = input;
            }
        } else if (!!(match = aspNetRegex.exec(input))) {
            sign = (match[1] === '-') ? -1 : 1;
            duration = {
                y  : 0,
                d  : toInt(match[DATE])        * sign,
                h  : toInt(match[HOUR])        * sign,
                m  : toInt(match[MINUTE])      * sign,
                s  : toInt(match[SECOND])      * sign,
                ms : toInt(match[MILLISECOND]) * sign
            };
        } else if (!!(match = create__isoRegex.exec(input))) {
            sign = (match[1] === '-') ? -1 : 1;
            duration = {
                y : parseIso(match[2], sign),
                M : parseIso(match[3], sign),
                d : parseIso(match[4], sign),
                h : parseIso(match[5], sign),
                m : parseIso(match[6], sign),
                s : parseIso(match[7], sign),
                w : parseIso(match[8], sign)
            };
        } else if (duration == null) {// checks for null or undefined
            duration = {};
        } else if (typeof duration === 'object' && ('from' in duration || 'to' in duration)) {
            diffRes = momentsDifference(local__createLocal(duration.from), local__createLocal(duration.to));

            duration = {};
            duration.ms = diffRes.milliseconds;
            duration.M = diffRes.months;
        }

        ret = new Duration(duration);

        if (isDuration(input) && hasOwnProp(input, '_locale')) {
            ret._locale = input._locale;
        }

        return ret;
    }

    create__createDuration.fn = Duration.prototype;

    function parseIso (inp, sign) {
        // We'd normally use ~~inp for this, but unfortunately it also
        // converts floats to ints.
        // inp may be undefined, so careful calling replace on it.
        var res = inp && parseFloat(inp.replace(',', '.'));
        // apply sign while we're at it
        return (isNaN(res) ? 0 : res) * sign;
    }

    function positiveMomentsDifference(base, other) {
        var res = {milliseconds: 0, months: 0};

        res.months = other.month() - base.month() +
            (other.year() - base.year()) * 12;
        if (base.clone().add(res.months, 'M').isAfter(other)) {
            --res.months;
        }

        res.milliseconds = +other - +(base.clone().add(res.months, 'M'));

        return res;
    }

    function momentsDifference(base, other) {
        var res;
        other = cloneWithOffset(other, base);
        if (base.isBefore(other)) {
            res = positiveMomentsDifference(base, other);
        } else {
            res = positiveMomentsDifference(other, base);
            res.milliseconds = -res.milliseconds;
            res.months = -res.months;
        }

        return res;
    }

    function createAdder(direction, name) {
        return function (val, period) {
            var dur, tmp;
            //invert the arguments, but complain about it
            if (period !== null && !isNaN(+period)) {
                deprecateSimple(name, 'moment().' + name  + '(period, number) is deprecated. Please use moment().' + name + '(number, period).');
                tmp = val; val = period; period = tmp;
            }

            val = typeof val === 'string' ? +val : val;
            dur = create__createDuration(val, period);
            add_subtract__addSubtract(this, dur, direction);
            return this;
        };
    }

    function add_subtract__addSubtract (mom, duration, isAdding, updateOffset) {
        var milliseconds = duration._milliseconds,
            days = duration._days,
            months = duration._months;
        updateOffset = updateOffset == null ? true : updateOffset;

        if (milliseconds) {
            mom._d.setTime(+mom._d + milliseconds * isAdding);
        }
        if (days) {
            get_set__set(mom, 'Date', get_set__get(mom, 'Date') + days * isAdding);
        }
        if (months) {
            setMonth(mom, get_set__get(mom, 'Month') + months * isAdding);
        }
        if (updateOffset) {
            utils_hooks__hooks.updateOffset(mom, days || months);
        }
    }

    var add_subtract__add      = createAdder(1, 'add');
    var add_subtract__subtract = createAdder(-1, 'subtract');

    function moment_calendar__calendar (time, formats) {
        // We want to compare the start of today, vs this.
        // Getting start-of-today depends on whether we're local/utc/offset or not.
        var now = time || local__createLocal(),
            sod = cloneWithOffset(now, this).startOf('day'),
            diff = this.diff(sod, 'days', true),
            format = diff < -6 ? 'sameElse' :
                diff < -1 ? 'lastWeek' :
                diff < 0 ? 'lastDay' :
                diff < 1 ? 'sameDay' :
                diff < 2 ? 'nextDay' :
                diff < 7 ? 'nextWeek' : 'sameElse';
        return this.format(formats && formats[format] || this.localeData().calendar(format, this, local__createLocal(now)));
    }

    function clone () {
        return new Moment(this);
    }

    function isAfter (input, units) {
        var inputMs;
        units = normalizeUnits(typeof units !== 'undefined' ? units : 'millisecond');
        if (units === 'millisecond') {
            input = isMoment(input) ? input : local__createLocal(input);
            return +this > +input;
        } else {
            inputMs = isMoment(input) ? +input : +local__createLocal(input);
            return inputMs < +this.clone().startOf(units);
        }
    }

    function isBefore (input, units) {
        var inputMs;
        units = normalizeUnits(typeof units !== 'undefined' ? units : 'millisecond');
        if (units === 'millisecond') {
            input = isMoment(input) ? input : local__createLocal(input);
            return +this < +input;
        } else {
            inputMs = isMoment(input) ? +input : +local__createLocal(input);
            return +this.clone().endOf(units) < inputMs;
        }
    }

    function isBetween (from, to, units) {
        return this.isAfter(from, units) && this.isBefore(to, units);
    }

    function isSame (input, units) {
        var inputMs;
        units = normalizeUnits(units || 'millisecond');
        if (units === 'millisecond') {
            input = isMoment(input) ? input : local__createLocal(input);
            return +this === +input;
        } else {
            inputMs = +local__createLocal(input);
            return +(this.clone().startOf(units)) <= inputMs && inputMs <= +(this.clone().endOf(units));
        }
    }

    function diff (input, units, asFloat) {
        var that = cloneWithOffset(input, this),
            zoneDelta = (that.utcOffset() - this.utcOffset()) * 6e4,
            delta, output;

        units = normalizeUnits(units);

        if (units === 'year' || units === 'month' || units === 'quarter') {
            output = monthDiff(this, that);
            if (units === 'quarter') {
                output = output / 3;
            } else if (units === 'year') {
                output = output / 12;
            }
        } else {
            delta = this - that;
            output = units === 'second' ? delta / 1e3 : // 1000
                units === 'minute' ? delta / 6e4 : // 1000 * 60
                units === 'hour' ? delta / 36e5 : // 1000 * 60 * 60
                units === 'day' ? (delta - zoneDelta) / 864e5 : // 1000 * 60 * 60 * 24, negate dst
                units === 'week' ? (delta - zoneDelta) / 6048e5 : // 1000 * 60 * 60 * 24 * 7, negate dst
                delta;
        }
        return asFloat ? output : absFloor(output);
    }

    function monthDiff (a, b) {
        // difference in months
        var wholeMonthDiff = ((b.year() - a.year()) * 12) + (b.month() - a.month()),
            // b is in (anchor - 1 month, anchor + 1 month)
            anchor = a.clone().add(wholeMonthDiff, 'months'),
            anchor2, adjust;

        if (b - anchor < 0) {
            anchor2 = a.clone().add(wholeMonthDiff - 1, 'months');
            // linear across the month
            adjust = (b - anchor) / (anchor - anchor2);
        } else {
            anchor2 = a.clone().add(wholeMonthDiff + 1, 'months');
            // linear across the month
            adjust = (b - anchor) / (anchor2 - anchor);
        }

        return -(wholeMonthDiff + adjust);
    }

    utils_hooks__hooks.defaultFormat = 'YYYY-MM-DDTHH:mm:ssZ';

    function toString () {
        return this.clone().locale('en').format('ddd MMM DD YYYY HH:mm:ss [GMT]ZZ');
    }

    function moment_format__toISOString () {
        var m = this.clone().utc();
        if (0 < m.year() && m.year() <= 9999) {
            if ('function' === typeof Date.prototype.toISOString) {
                // native implementation is ~50x faster, use it when we can
                return this.toDate().toISOString();
            } else {
                return formatMoment(m, 'YYYY-MM-DD[T]HH:mm:ss.SSS[Z]');
            }
        } else {
            return formatMoment(m, 'YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]');
        }
    }

    function format (inputString) {
        var output = formatMoment(this, inputString || utils_hooks__hooks.defaultFormat);
        return this.localeData().postformat(output);
    }

    function from (time, withoutSuffix) {
        if (!this.isValid()) {
            return this.localeData().invalidDate();
        }
        return create__createDuration({to: this, from: time}).locale(this.locale()).humanize(!withoutSuffix);
    }

    function fromNow (withoutSuffix) {
        return this.from(local__createLocal(), withoutSuffix);
    }

    function to (time, withoutSuffix) {
        if (!this.isValid()) {
            return this.localeData().invalidDate();
        }
        return create__createDuration({from: this, to: time}).locale(this.locale()).humanize(!withoutSuffix);
    }

    function toNow (withoutSuffix) {
        return this.to(local__createLocal(), withoutSuffix);
    }

    function locale (key) {
        var newLocaleData;

        if (key === undefined) {
            return this._locale._abbr;
        } else {
            newLocaleData = locale_locales__getLocale(key);
            if (newLocaleData != null) {
                this._locale = newLocaleData;
            }
            return this;
        }
    }

    var lang = deprecate(
        'moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.',
        function (key) {
            if (key === undefined) {
                return this.localeData();
            } else {
                return this.locale(key);
            }
        }
    );

    function localeData () {
        return this._locale;
    }

    function startOf (units) {
        units = normalizeUnits(units);
        // the following switch intentionally omits break keywords
        // to utilize falling through the cases.
        switch (units) {
        case 'year':
            this.month(0);
            /* falls through */
        case 'quarter':
        case 'month':
            this.date(1);
            /* falls through */
        case 'week':
        case 'isoWeek':
        case 'day':
            this.hours(0);
            /* falls through */
        case 'hour':
            this.minutes(0);
            /* falls through */
        case 'minute':
            this.seconds(0);
            /* falls through */
        case 'second':
            this.milliseconds(0);
        }

        // weeks are a special case
        if (units === 'week') {
            this.weekday(0);
        }
        if (units === 'isoWeek') {
            this.isoWeekday(1);
        }

        // quarters are also special
        if (units === 'quarter') {
            this.month(Math.floor(this.month() / 3) * 3);
        }

        return this;
    }

    function endOf (units) {
        units = normalizeUnits(units);
        if (units === undefined || units === 'millisecond') {
            return this;
        }
        return this.startOf(units).add(1, (units === 'isoWeek' ? 'week' : units)).subtract(1, 'ms');
    }

    function to_type__valueOf () {
        return +this._d - ((this._offset || 0) * 60000);
    }

    function unix () {
        return Math.floor(+this / 1000);
    }

    function toDate () {
        return this._offset ? new Date(+this) : this._d;
    }

    function toArray () {
        var m = this;
        return [m.year(), m.month(), m.date(), m.hour(), m.minute(), m.second(), m.millisecond()];
    }

    function toObject () {
        var m = this;
        return {
            years: m.year(),
            months: m.month(),
            date: m.date(),
            hours: m.hours(),
            minutes: m.minutes(),
            seconds: m.seconds(),
            milliseconds: m.milliseconds()
        };
    }

    function moment_valid__isValid () {
        return valid__isValid(this);
    }

    function parsingFlags () {
        return extend({}, getParsingFlags(this));
    }

    function invalidAt () {
        return getParsingFlags(this).overflow;
    }

    addFormatToken(0, ['gg', 2], 0, function () {
        return this.weekYear() % 100;
    });

    addFormatToken(0, ['GG', 2], 0, function () {
        return this.isoWeekYear() % 100;
    });

    function addWeekYearFormatToken (token, getter) {
        addFormatToken(0, [token, token.length], 0, getter);
    }

    addWeekYearFormatToken('gggg',     'weekYear');
    addWeekYearFormatToken('ggggg',    'weekYear');
    addWeekYearFormatToken('GGGG',  'isoWeekYear');
    addWeekYearFormatToken('GGGGG', 'isoWeekYear');

    // ALIASES

    addUnitAlias('weekYear', 'gg');
    addUnitAlias('isoWeekYear', 'GG');

    // PARSING

    addRegexToken('G',      matchSigned);
    addRegexToken('g',      matchSigned);
    addRegexToken('GG',     match1to2, match2);
    addRegexToken('gg',     match1to2, match2);
    addRegexToken('GGGG',   match1to4, match4);
    addRegexToken('gggg',   match1to4, match4);
    addRegexToken('GGGGG',  match1to6, match6);
    addRegexToken('ggggg',  match1to6, match6);

    addWeekParseToken(['gggg', 'ggggg', 'GGGG', 'GGGGG'], function (input, week, config, token) {
        week[token.substr(0, 2)] = toInt(input);
    });

    addWeekParseToken(['gg', 'GG'], function (input, week, config, token) {
        week[token] = utils_hooks__hooks.parseTwoDigitYear(input);
    });

    // HELPERS

    function weeksInYear(year, dow, doy) {
        return weekOfYear(local__createLocal([year, 11, 31 + dow - doy]), dow, doy).week;
    }

    // MOMENTS

    function getSetWeekYear (input) {
        var year = weekOfYear(this, this.localeData()._week.dow, this.localeData()._week.doy).year;
        return input == null ? year : this.add((input - year), 'y');
    }

    function getSetISOWeekYear (input) {
        var year = weekOfYear(this, 1, 4).year;
        return input == null ? year : this.add((input - year), 'y');
    }

    function getISOWeeksInYear () {
        return weeksInYear(this.year(), 1, 4);
    }

    function getWeeksInYear () {
        var weekInfo = this.localeData()._week;
        return weeksInYear(this.year(), weekInfo.dow, weekInfo.doy);
    }

    addFormatToken('Q', 0, 0, 'quarter');

    // ALIASES

    addUnitAlias('quarter', 'Q');

    // PARSING

    addRegexToken('Q', match1);
    addParseToken('Q', function (input, array) {
        array[MONTH] = (toInt(input) - 1) * 3;
    });

    // MOMENTS

    function getSetQuarter (input) {
        return input == null ? Math.ceil((this.month() + 1) / 3) : this.month((input - 1) * 3 + this.month() % 3);
    }

    addFormatToken('D', ['DD', 2], 'Do', 'date');

    // ALIASES

    addUnitAlias('date', 'D');

    // PARSING

    addRegexToken('D',  match1to2);
    addRegexToken('DD', match1to2, match2);
    addRegexToken('Do', function (isStrict, locale) {
        return isStrict ? locale._ordinalParse : locale._ordinalParseLenient;
    });

    addParseToken(['D', 'DD'], DATE);
    addParseToken('Do', function (input, array) {
        array[DATE] = toInt(input.match(match1to2)[0], 10);
    });

    // MOMENTS

    var getSetDayOfMonth = makeGetSet('Date', true);

    addFormatToken('d', 0, 'do', 'day');

    addFormatToken('dd', 0, 0, function (format) {
        return this.localeData().weekdaysMin(this, format);
    });

    addFormatToken('ddd', 0, 0, function (format) {
        return this.localeData().weekdaysShort(this, format);
    });

    addFormatToken('dddd', 0, 0, function (format) {
        return this.localeData().weekdays(this, format);
    });

    addFormatToken('e', 0, 0, 'weekday');
    addFormatToken('E', 0, 0, 'isoWeekday');

    // ALIASES

    addUnitAlias('day', 'd');
    addUnitAlias('weekday', 'e');
    addUnitAlias('isoWeekday', 'E');

    // PARSING

    addRegexToken('d',    match1to2);
    addRegexToken('e',    match1to2);
    addRegexToken('E',    match1to2);
    addRegexToken('dd',   matchWord);
    addRegexToken('ddd',  matchWord);
    addRegexToken('dddd', matchWord);

    addWeekParseToken(['dd', 'ddd', 'dddd'], function (input, week, config) {
        var weekday = config._locale.weekdaysParse(input);
        // if we didn't get a weekday name, mark the date as invalid
        if (weekday != null) {
            week.d = weekday;
        } else {
            getParsingFlags(config).invalidWeekday = input;
        }
    });

    addWeekParseToken(['d', 'e', 'E'], function (input, week, config, token) {
        week[token] = toInt(input);
    });

    // HELPERS

    function parseWeekday(input, locale) {
        if (typeof input !== 'string') {
            return input;
        }

        if (!isNaN(input)) {
            return parseInt(input, 10);
        }

        input = locale.weekdaysParse(input);
        if (typeof input === 'number') {
            return input;
        }

        return null;
    }

    // LOCALES

    var defaultLocaleWeekdays = 'Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday'.split('_');
    function localeWeekdays (m) {
        return this._weekdays[m.day()];
    }

    var defaultLocaleWeekdaysShort = 'Sun_Mon_Tue_Wed_Thu_Fri_Sat'.split('_');
    function localeWeekdaysShort (m) {
        return this._weekdaysShort[m.day()];
    }

    var defaultLocaleWeekdaysMin = 'Su_Mo_Tu_We_Th_Fr_Sa'.split('_');
    function localeWeekdaysMin (m) {
        return this._weekdaysMin[m.day()];
    }

    function localeWeekdaysParse (weekdayName) {
        var i, mom, regex;

        this._weekdaysParse = this._weekdaysParse || [];

        for (i = 0; i < 7; i++) {
            // make the regex if we don't have it already
            if (!this._weekdaysParse[i]) {
                mom = local__createLocal([2000, 1]).day(i);
                regex = '^' + this.weekdays(mom, '') + '|^' + this.weekdaysShort(mom, '') + '|^' + this.weekdaysMin(mom, '');
                this._weekdaysParse[i] = new RegExp(regex.replace('.', ''), 'i');
            }
            // test the regex
            if (this._weekdaysParse[i].test(weekdayName)) {
                return i;
            }
        }
    }

    // MOMENTS

    function getSetDayOfWeek (input) {
        var day = this._isUTC ? this._d.getUTCDay() : this._d.getDay();
        if (input != null) {
            input = parseWeekday(input, this.localeData());
            return this.add(input - day, 'd');
        } else {
            return day;
        }
    }

    function getSetLocaleDayOfWeek (input) {
        var weekday = (this.day() + 7 - this.localeData()._week.dow) % 7;
        return input == null ? weekday : this.add(input - weekday, 'd');
    }

    function getSetISODayOfWeek (input) {
        // behaves the same as moment#day except
        // as a getter, returns 7 instead of 0 (1-7 range instead of 0-6)
        // as a setter, sunday should belong to the previous week.
        return input == null ? this.day() || 7 : this.day(this.day() % 7 ? input : input - 7);
    }

    addFormatToken('H', ['HH', 2], 0, 'hour');
    addFormatToken('h', ['hh', 2], 0, function () {
        return this.hours() % 12 || 12;
    });

    function meridiem (token, lowercase) {
        addFormatToken(token, 0, 0, function () {
            return this.localeData().meridiem(this.hours(), this.minutes(), lowercase);
        });
    }

    meridiem('a', true);
    meridiem('A', false);

    // ALIASES

    addUnitAlias('hour', 'h');

    // PARSING

    function matchMeridiem (isStrict, locale) {
        return locale._meridiemParse;
    }

    addRegexToken('a',  matchMeridiem);
    addRegexToken('A',  matchMeridiem);
    addRegexToken('H',  match1to2);
    addRegexToken('h',  match1to2);
    addRegexToken('HH', match1to2, match2);
    addRegexToken('hh', match1to2, match2);

    addParseToken(['H', 'HH'], HOUR);
    addParseToken(['a', 'A'], function (input, array, config) {
        config._isPm = config._locale.isPM(input);
        config._meridiem = input;
    });
    addParseToken(['h', 'hh'], function (input, array, config) {
        array[HOUR] = toInt(input);
        getParsingFlags(config).bigHour = true;
    });

    // LOCALES

    function localeIsPM (input) {
        // IE8 Quirks Mode & IE7 Standards Mode do not allow accessing strings like arrays
        // Using charAt should be more compatible.
        return ((input + '').toLowerCase().charAt(0) === 'p');
    }

    var defaultLocaleMeridiemParse = /[ap]\.?m?\.?/i;
    function localeMeridiem (hours, minutes, isLower) {
        if (hours > 11) {
            return isLower ? 'pm' : 'PM';
        } else {
            return isLower ? 'am' : 'AM';
        }
    }


    // MOMENTS

    // Setting the hour should keep the time, because the user explicitly
    // specified which hour he wants. So trying to maintain the same hour (in
    // a new timezone) makes sense. Adding/subtracting hours does not follow
    // this rule.
    var getSetHour = makeGetSet('Hours', true);

    addFormatToken('m', ['mm', 2], 0, 'minute');

    // ALIASES

    addUnitAlias('minute', 'm');

    // PARSING

    addRegexToken('m',  match1to2);
    addRegexToken('mm', match1to2, match2);
    addParseToken(['m', 'mm'], MINUTE);

    // MOMENTS

    var getSetMinute = makeGetSet('Minutes', false);

    addFormatToken('s', ['ss', 2], 0, 'second');

    // ALIASES

    addUnitAlias('second', 's');

    // PARSING

    addRegexToken('s',  match1to2);
    addRegexToken('ss', match1to2, match2);
    addParseToken(['s', 'ss'], SECOND);

    // MOMENTS

    var getSetSecond = makeGetSet('Seconds', false);

    addFormatToken('S', 0, 0, function () {
        return ~~(this.millisecond() / 100);
    });

    addFormatToken(0, ['SS', 2], 0, function () {
        return ~~(this.millisecond() / 10);
    });

    addFormatToken(0, ['SSS', 3], 0, 'millisecond');
    addFormatToken(0, ['SSSS', 4], 0, function () {
        return this.millisecond() * 10;
    });
    addFormatToken(0, ['SSSSS', 5], 0, function () {
        return this.millisecond() * 100;
    });
    addFormatToken(0, ['SSSSSS', 6], 0, function () {
        return this.millisecond() * 1000;
    });
    addFormatToken(0, ['SSSSSSS', 7], 0, function () {
        return this.millisecond() * 10000;
    });
    addFormatToken(0, ['SSSSSSSS', 8], 0, function () {
        return this.millisecond() * 100000;
    });
    addFormatToken(0, ['SSSSSSSSS', 9], 0, function () {
        return this.millisecond() * 1000000;
    });


    // ALIASES

    addUnitAlias('millisecond', 'ms');

    // PARSING

    addRegexToken('S',    match1to3, match1);
    addRegexToken('SS',   match1to3, match2);
    addRegexToken('SSS',  match1to3, match3);

    var token;
    for (token = 'SSSS'; token.length <= 9; token += 'S') {
        addRegexToken(token, matchUnsigned);
    }

    function parseMs(input, array) {
        array[MILLISECOND] = toInt(('0.' + input) * 1000);
    }

    for (token = 'S'; token.length <= 9; token += 'S') {
        addParseToken(token, parseMs);
    }
    // MOMENTS

    var getSetMillisecond = makeGetSet('Milliseconds', false);

    addFormatToken('z',  0, 0, 'zoneAbbr');
    addFormatToken('zz', 0, 0, 'zoneName');

    // MOMENTS

    function getZoneAbbr () {
        return this._isUTC ? 'UTC' : '';
    }

    function getZoneName () {
        return this._isUTC ? 'Coordinated Universal Time' : '';
    }

    var momentPrototype__proto = Moment.prototype;

    momentPrototype__proto.add          = add_subtract__add;
    momentPrototype__proto.calendar     = moment_calendar__calendar;
    momentPrototype__proto.clone        = clone;
    momentPrototype__proto.diff         = diff;
    momentPrototype__proto.endOf        = endOf;
    momentPrototype__proto.format       = format;
    momentPrototype__proto.from         = from;
    momentPrototype__proto.fromNow      = fromNow;
    momentPrototype__proto.to           = to;
    momentPrototype__proto.toNow        = toNow;
    momentPrototype__proto.get          = getSet;
    momentPrototype__proto.invalidAt    = invalidAt;
    momentPrototype__proto.isAfter      = isAfter;
    momentPrototype__proto.isBefore     = isBefore;
    momentPrototype__proto.isBetween    = isBetween;
    momentPrototype__proto.isSame       = isSame;
    momentPrototype__proto.isValid      = moment_valid__isValid;
    momentPrototype__proto.lang         = lang;
    momentPrototype__proto.locale       = locale;
    momentPrototype__proto.localeData   = localeData;
    momentPrototype__proto.max          = prototypeMax;
    momentPrototype__proto.min          = prototypeMin;
    momentPrototype__proto.parsingFlags = parsingFlags;
    momentPrototype__proto.set          = getSet;
    momentPrototype__proto.startOf      = startOf;
    momentPrototype__proto.subtract     = add_subtract__subtract;
    momentPrototype__proto.toArray      = toArray;
    momentPrototype__proto.toObject     = toObject;
    momentPrototype__proto.toDate       = toDate;
    momentPrototype__proto.toISOString  = moment_format__toISOString;
    momentPrototype__proto.toJSON       = moment_format__toISOString;
    momentPrototype__proto.toString     = toString;
    momentPrototype__proto.unix         = unix;
    momentPrototype__proto.valueOf      = to_type__valueOf;

    // Year
    momentPrototype__proto.year       = getSetYear;
    momentPrototype__proto.isLeapYear = getIsLeapYear;

    // Week Year
    momentPrototype__proto.weekYear    = getSetWeekYear;
    momentPrototype__proto.isoWeekYear = getSetISOWeekYear;

    // Quarter
    momentPrototype__proto.quarter = momentPrototype__proto.quarters = getSetQuarter;

    // Month
    momentPrototype__proto.month       = getSetMonth;
    momentPrototype__proto.daysInMonth = getDaysInMonth;

    // Week
    momentPrototype__proto.week           = momentPrototype__proto.weeks        = getSetWeek;
    momentPrototype__proto.isoWeek        = momentPrototype__proto.isoWeeks     = getSetISOWeek;
    momentPrototype__proto.weeksInYear    = getWeeksInYear;
    momentPrototype__proto.isoWeeksInYear = getISOWeeksInYear;

    // Day
    momentPrototype__proto.date       = getSetDayOfMonth;
    momentPrototype__proto.day        = momentPrototype__proto.days             = getSetDayOfWeek;
    momentPrototype__proto.weekday    = getSetLocaleDayOfWeek;
    momentPrototype__proto.isoWeekday = getSetISODayOfWeek;
    momentPrototype__proto.dayOfYear  = getSetDayOfYear;

    // Hour
    momentPrototype__proto.hour = momentPrototype__proto.hours = getSetHour;

    // Minute
    momentPrototype__proto.minute = momentPrototype__proto.minutes = getSetMinute;

    // Second
    momentPrototype__proto.second = momentPrototype__proto.seconds = getSetSecond;

    // Millisecond
    momentPrototype__proto.millisecond = momentPrototype__proto.milliseconds = getSetMillisecond;

    // Offset
    momentPrototype__proto.utcOffset            = getSetOffset;
    momentPrototype__proto.utc                  = setOffsetToUTC;
    momentPrototype__proto.local                = setOffsetToLocal;
    momentPrototype__proto.parseZone            = setOffsetToParsedOffset;
    momentPrototype__proto.hasAlignedHourOffset = hasAlignedHourOffset;
    momentPrototype__proto.isDST                = isDaylightSavingTime;
    momentPrototype__proto.isDSTShifted         = isDaylightSavingTimeShifted;
    momentPrototype__proto.isLocal              = isLocal;
    momentPrototype__proto.isUtcOffset          = isUtcOffset;
    momentPrototype__proto.isUtc                = isUtc;
    momentPrototype__proto.isUTC                = isUtc;

    // Timezone
    momentPrototype__proto.zoneAbbr = getZoneAbbr;
    momentPrototype__proto.zoneName = getZoneName;

    // Deprecations
    momentPrototype__proto.dates  = deprecate('dates accessor is deprecated. Use date instead.', getSetDayOfMonth);
    momentPrototype__proto.months = deprecate('months accessor is deprecated. Use month instead', getSetMonth);
    momentPrototype__proto.years  = deprecate('years accessor is deprecated. Use year instead', getSetYear);
    momentPrototype__proto.zone   = deprecate('moment().zone is deprecated, use moment().utcOffset instead. https://github.com/moment/moment/issues/1779', getSetZone);

    var momentPrototype = momentPrototype__proto;

    function moment__createUnix (input) {
        return local__createLocal(input * 1000);
    }

    function moment__createInZone () {
        return local__createLocal.apply(null, arguments).parseZone();
    }

    var defaultCalendar = {
        sameDay : '[Today at] LT',
        nextDay : '[Tomorrow at] LT',
        nextWeek : 'dddd [at] LT',
        lastDay : '[Yesterday at] LT',
        lastWeek : '[Last] dddd [at] LT',
        sameElse : 'L'
    };

    function locale_calendar__calendar (key, mom, now) {
        var output = this._calendar[key];
        return typeof output === 'function' ? output.call(mom, now) : output;
    }

    var defaultLongDateFormat = {
        LTS  : 'h:mm:ss A',
        LT   : 'h:mm A',
        L    : 'MM/DD/YYYY',
        LL   : 'MMMM D, YYYY',
        LLL  : 'MMMM D, YYYY h:mm A',
        LLLL : 'dddd, MMMM D, YYYY h:mm A'
    };

    function longDateFormat (key) {
        var format = this._longDateFormat[key],
            formatUpper = this._longDateFormat[key.toUpperCase()];

        if (format || !formatUpper) {
            return format;
        }

        this._longDateFormat[key] = formatUpper.replace(/MMMM|MM|DD|dddd/g, function (val) {
            return val.slice(1);
        });

        return this._longDateFormat[key];
    }

    var defaultInvalidDate = 'Invalid date';

    function invalidDate () {
        return this._invalidDate;
    }

    var defaultOrdinal = '%d';
    var defaultOrdinalParse = /\d{1,2}/;

    function ordinal (number) {
        return this._ordinal.replace('%d', number);
    }

    function preParsePostFormat (string) {
        return string;
    }

    var defaultRelativeTime = {
        future : 'in %s',
        past   : '%s ago',
        s  : 'a few seconds',
        m  : 'a minute',
        mm : '%d minutes',
        h  : 'an hour',
        hh : '%d hours',
        d  : 'a day',
        dd : '%d days',
        M  : 'a month',
        MM : '%d months',
        y  : 'a year',
        yy : '%d years'
    };

    function relative__relativeTime (number, withoutSuffix, string, isFuture) {
        var output = this._relativeTime[string];
        return (typeof output === 'function') ?
            output(number, withoutSuffix, string, isFuture) :
            output.replace(/%d/i, number);
    }

    function pastFuture (diff, output) {
        var format = this._relativeTime[diff > 0 ? 'future' : 'past'];
        return typeof format === 'function' ? format(output) : format.replace(/%s/i, output);
    }

    function locale_set__set (config) {
        var prop, i;
        for (i in config) {
            prop = config[i];
            if (typeof prop === 'function') {
                this[i] = prop;
            } else {
                this['_' + i] = prop;
            }
        }
        // Lenient ordinal parsing accepts just a number in addition to
        // number + (possibly) stuff coming from _ordinalParseLenient.
        this._ordinalParseLenient = new RegExp(this._ordinalParse.source + '|' + (/\d{1,2}/).source);
    }

    var prototype__proto = Locale.prototype;

    prototype__proto._calendar       = defaultCalendar;
    prototype__proto.calendar        = locale_calendar__calendar;
    prototype__proto._longDateFormat = defaultLongDateFormat;
    prototype__proto.longDateFormat  = longDateFormat;
    prototype__proto._invalidDate    = defaultInvalidDate;
    prototype__proto.invalidDate     = invalidDate;
    prototype__proto._ordinal        = defaultOrdinal;
    prototype__proto.ordinal         = ordinal;
    prototype__proto._ordinalParse   = defaultOrdinalParse;
    prototype__proto.preparse        = preParsePostFormat;
    prototype__proto.postformat      = preParsePostFormat;
    prototype__proto._relativeTime   = defaultRelativeTime;
    prototype__proto.relativeTime    = relative__relativeTime;
    prototype__proto.pastFuture      = pastFuture;
    prototype__proto.set             = locale_set__set;

    // Month
    prototype__proto.months       =        localeMonths;
    prototype__proto._months      = defaultLocaleMonths;
    prototype__proto.monthsShort  =        localeMonthsShort;
    prototype__proto._monthsShort = defaultLocaleMonthsShort;
    prototype__proto.monthsParse  =        localeMonthsParse;

    // Week
    prototype__proto.week = localeWeek;
    prototype__proto._week = defaultLocaleWeek;
    prototype__proto.firstDayOfYear = localeFirstDayOfYear;
    prototype__proto.firstDayOfWeek = localeFirstDayOfWeek;

    // Day of Week
    prototype__proto.weekdays       =        localeWeekdays;
    prototype__proto._weekdays      = defaultLocaleWeekdays;
    prototype__proto.weekdaysMin    =        localeWeekdaysMin;
    prototype__proto._weekdaysMin   = defaultLocaleWeekdaysMin;
    prototype__proto.weekdaysShort  =        localeWeekdaysShort;
    prototype__proto._weekdaysShort = defaultLocaleWeekdaysShort;
    prototype__proto.weekdaysParse  =        localeWeekdaysParse;

    // Hours
    prototype__proto.isPM = localeIsPM;
    prototype__proto._meridiemParse = defaultLocaleMeridiemParse;
    prototype__proto.meridiem = localeMeridiem;

    function lists__get (format, index, field, setter) {
        var locale = locale_locales__getLocale();
        var utc = create_utc__createUTC().set(setter, index);
        return locale[field](utc, format);
    }

    function list (format, index, field, count, setter) {
        if (typeof format === 'number') {
            index = format;
            format = undefined;
        }

        format = format || '';

        if (index != null) {
            return lists__get(format, index, field, setter);
        }

        var i;
        var out = [];
        for (i = 0; i < count; i++) {
            out[i] = lists__get(format, i, field, setter);
        }
        return out;
    }

    function lists__listMonths (format, index) {
        return list(format, index, 'months', 12, 'month');
    }

    function lists__listMonthsShort (format, index) {
        return list(format, index, 'monthsShort', 12, 'month');
    }

    function lists__listWeekdays (format, index) {
        return list(format, index, 'weekdays', 7, 'day');
    }

    function lists__listWeekdaysShort (format, index) {
        return list(format, index, 'weekdaysShort', 7, 'day');
    }

    function lists__listWeekdaysMin (format, index) {
        return list(format, index, 'weekdaysMin', 7, 'day');
    }

    locale_locales__getSetGlobalLocale('en', {
        ordinalParse: /\d{1,2}(th|st|nd|rd)/,
        ordinal : function (number) {
            var b = number % 10,
                output = (toInt(number % 100 / 10) === 1) ? 'th' :
                (b === 1) ? 'st' :
                (b === 2) ? 'nd' :
                (b === 3) ? 'rd' : 'th';
            return number + output;
        }
    });

    // Side effect imports
    utils_hooks__hooks.lang = deprecate('moment.lang is deprecated. Use moment.locale instead.', locale_locales__getSetGlobalLocale);
    utils_hooks__hooks.langData = deprecate('moment.langData is deprecated. Use moment.localeData instead.', locale_locales__getLocale);

    var mathAbs = Math.abs;

    function duration_abs__abs () {
        var data           = this._data;

        this._milliseconds = mathAbs(this._milliseconds);
        this._days         = mathAbs(this._days);
        this._months       = mathAbs(this._months);

        data.milliseconds  = mathAbs(data.milliseconds);
        data.seconds       = mathAbs(data.seconds);
        data.minutes       = mathAbs(data.minutes);
        data.hours         = mathAbs(data.hours);
        data.months        = mathAbs(data.months);
        data.years         = mathAbs(data.years);

        return this;
    }

    function duration_add_subtract__addSubtract (duration, input, value, direction) {
        var other = create__createDuration(input, value);

        duration._milliseconds += direction * other._milliseconds;
        duration._days         += direction * other._days;
        duration._months       += direction * other._months;

        return duration._bubble();
    }

    // supports only 2.0-style add(1, 's') or add(duration)
    function duration_add_subtract__add (input, value) {
        return duration_add_subtract__addSubtract(this, input, value, 1);
    }

    // supports only 2.0-style subtract(1, 's') or subtract(duration)
    function duration_add_subtract__subtract (input, value) {
        return duration_add_subtract__addSubtract(this, input, value, -1);
    }

    function absCeil (number) {
        if (number < 0) {
            return Math.floor(number);
        } else {
            return Math.ceil(number);
        }
    }

    function bubble () {
        var milliseconds = this._milliseconds;
        var days         = this._days;
        var months       = this._months;
        var data         = this._data;
        var seconds, minutes, hours, years, monthsFromDays;

        // if we have a mix of positive and negative values, bubble down first
        // check: https://github.com/moment/moment/issues/2166
        if (!((milliseconds >= 0 && days >= 0 && months >= 0) ||
                (milliseconds <= 0 && days <= 0 && months <= 0))) {
            milliseconds += absCeil(monthsToDays(months) + days) * 864e5;
            days = 0;
            months = 0;
        }

        // The following code bubbles up values, see the tests for
        // examples of what that means.
        data.milliseconds = milliseconds % 1000;

        seconds           = absFloor(milliseconds / 1000);
        data.seconds      = seconds % 60;

        minutes           = absFloor(seconds / 60);
        data.minutes      = minutes % 60;

        hours             = absFloor(minutes / 60);
        data.hours        = hours % 24;

        days += absFloor(hours / 24);

        // convert days to months
        monthsFromDays = absFloor(daysToMonths(days));
        months += monthsFromDays;
        days -= absCeil(monthsToDays(monthsFromDays));

        // 12 months -> 1 year
        years = absFloor(months / 12);
        months %= 12;

        data.days   = days;
        data.months = months;
        data.years  = years;

        return this;
    }

    function daysToMonths (days) {
        // 400 years have 146097 days (taking into account leap year rules)
        // 400 years have 12 months === 4800
        return days * 4800 / 146097;
    }

    function monthsToDays (months) {
        // the reverse of daysToMonths
        return months * 146097 / 4800;
    }

    function as (units) {
        var days;
        var months;
        var milliseconds = this._milliseconds;

        units = normalizeUnits(units);

        if (units === 'month' || units === 'year') {
            days   = this._days   + milliseconds / 864e5;
            months = this._months + daysToMonths(days);
            return units === 'month' ? months : months / 12;
        } else {
            // handle milliseconds separately because of floating point math errors (issue #1867)
            days = this._days + Math.round(monthsToDays(this._months));
            switch (units) {
                case 'week'   : return days / 7     + milliseconds / 6048e5;
                case 'day'    : return days         + milliseconds / 864e5;
                case 'hour'   : return days * 24    + milliseconds / 36e5;
                case 'minute' : return days * 1440  + milliseconds / 6e4;
                case 'second' : return days * 86400 + milliseconds / 1000;
                // Math.floor prevents floating point math errors here
                case 'millisecond': return Math.floor(days * 864e5) + milliseconds;
                default: throw new Error('Unknown unit ' + units);
            }
        }
    }

    // TODO: Use this.as('ms')?
    function duration_as__valueOf () {
        return (
            this._milliseconds +
            this._days * 864e5 +
            (this._months % 12) * 2592e6 +
            toInt(this._months / 12) * 31536e6
        );
    }

    function makeAs (alias) {
        return function () {
            return this.as(alias);
        };
    }

    var asMilliseconds = makeAs('ms');
    var asSeconds      = makeAs('s');
    var asMinutes      = makeAs('m');
    var asHours        = makeAs('h');
    var asDays         = makeAs('d');
    var asWeeks        = makeAs('w');
    var asMonths       = makeAs('M');
    var asYears        = makeAs('y');

    function duration_get__get (units) {
        units = normalizeUnits(units);
        return this[units + 's']();
    }

    function makeGetter(name) {
        return function () {
            return this._data[name];
        };
    }

    var milliseconds = makeGetter('milliseconds');
    var seconds      = makeGetter('seconds');
    var minutes      = makeGetter('minutes');
    var hours        = makeGetter('hours');
    var days         = makeGetter('days');
    var months       = makeGetter('months');
    var years        = makeGetter('years');

    function weeks () {
        return absFloor(this.days() / 7);
    }

    var round = Math.round;
    var thresholds = {
        s: 45,  // seconds to minute
        m: 45,  // minutes to hour
        h: 22,  // hours to day
        d: 26,  // days to month
        M: 11   // months to year
    };

    // helper function for moment.fn.from, moment.fn.fromNow, and moment.duration.fn.humanize
    function substituteTimeAgo(string, number, withoutSuffix, isFuture, locale) {
        return locale.relativeTime(number || 1, !!withoutSuffix, string, isFuture);
    }

    function duration_humanize__relativeTime (posNegDuration, withoutSuffix, locale) {
        var duration = create__createDuration(posNegDuration).abs();
        var seconds  = round(duration.as('s'));
        var minutes  = round(duration.as('m'));
        var hours    = round(duration.as('h'));
        var days     = round(duration.as('d'));
        var months   = round(duration.as('M'));
        var years    = round(duration.as('y'));

        var a = seconds < thresholds.s && ['s', seconds]  ||
                minutes === 1          && ['m']           ||
                minutes < thresholds.m && ['mm', minutes] ||
                hours   === 1          && ['h']           ||
                hours   < thresholds.h && ['hh', hours]   ||
                days    === 1          && ['d']           ||
                days    < thresholds.d && ['dd', days]    ||
                months  === 1          && ['M']           ||
                months  < thresholds.M && ['MM', months]  ||
                years   === 1          && ['y']           || ['yy', years];

        a[2] = withoutSuffix;
        a[3] = +posNegDuration > 0;
        a[4] = locale;
        return substituteTimeAgo.apply(null, a);
    }

    // This function allows you to set a threshold for relative time strings
    function duration_humanize__getSetRelativeTimeThreshold (threshold, limit) {
        if (thresholds[threshold] === undefined) {
            return false;
        }
        if (limit === undefined) {
            return thresholds[threshold];
        }
        thresholds[threshold] = limit;
        return true;
    }

    function humanize (withSuffix) {
        var locale = this.localeData();
        var output = duration_humanize__relativeTime(this, !withSuffix, locale);

        if (withSuffix) {
            output = locale.pastFuture(+this, output);
        }

        return locale.postformat(output);
    }

    var iso_string__abs = Math.abs;

    function iso_string__toISOString() {
        // for ISO strings we do not use the normal bubbling rules:
        //  * milliseconds bubble up until they become hours
        //  * days do not bubble at all
        //  * months bubble up until they become years
        // This is because there is no context-free conversion between hours and days
        // (think of clock changes)
        // and also not between days and months (28-31 days per month)
        var seconds = iso_string__abs(this._milliseconds) / 1000;
        var days         = iso_string__abs(this._days);
        var months       = iso_string__abs(this._months);
        var minutes, hours, years;

        // 3600 seconds -> 60 minutes -> 1 hour
        minutes           = absFloor(seconds / 60);
        hours             = absFloor(minutes / 60);
        seconds %= 60;
        minutes %= 60;

        // 12 months -> 1 year
        years  = absFloor(months / 12);
        months %= 12;


        // inspired by https://github.com/dordille/moment-isoduration/blob/master/moment.isoduration.js
        var Y = years;
        var M = months;
        var D = days;
        var h = hours;
        var m = minutes;
        var s = seconds;
        var total = this.asSeconds();

        if (!total) {
            // this is the same as C#'s (Noda) and python (isodate)...
            // but not other JS (goog.date)
            return 'P0D';
        }

        return (total < 0 ? '-' : '') +
            'P' +
            (Y ? Y + 'Y' : '') +
            (M ? M + 'M' : '') +
            (D ? D + 'D' : '') +
            ((h || m || s) ? 'T' : '') +
            (h ? h + 'H' : '') +
            (m ? m + 'M' : '') +
            (s ? s + 'S' : '');
    }

    var duration_prototype__proto = Duration.prototype;

    duration_prototype__proto.abs            = duration_abs__abs;
    duration_prototype__proto.add            = duration_add_subtract__add;
    duration_prototype__proto.subtract       = duration_add_subtract__subtract;
    duration_prototype__proto.as             = as;
    duration_prototype__proto.asMilliseconds = asMilliseconds;
    duration_prototype__proto.asSeconds      = asSeconds;
    duration_prototype__proto.asMinutes      = asMinutes;
    duration_prototype__proto.asHours        = asHours;
    duration_prototype__proto.asDays         = asDays;
    duration_prototype__proto.asWeeks        = asWeeks;
    duration_prototype__proto.asMonths       = asMonths;
    duration_prototype__proto.asYears        = asYears;
    duration_prototype__proto.valueOf        = duration_as__valueOf;
    duration_prototype__proto._bubble        = bubble;
    duration_prototype__proto.get            = duration_get__get;
    duration_prototype__proto.milliseconds   = milliseconds;
    duration_prototype__proto.seconds        = seconds;
    duration_prototype__proto.minutes        = minutes;
    duration_prototype__proto.hours          = hours;
    duration_prototype__proto.days           = days;
    duration_prototype__proto.weeks          = weeks;
    duration_prototype__proto.months         = months;
    duration_prototype__proto.years          = years;
    duration_prototype__proto.humanize       = humanize;
    duration_prototype__proto.toISOString    = iso_string__toISOString;
    duration_prototype__proto.toString       = iso_string__toISOString;
    duration_prototype__proto.toJSON         = iso_string__toISOString;
    duration_prototype__proto.locale         = locale;
    duration_prototype__proto.localeData     = localeData;

    // Deprecations
    duration_prototype__proto.toIsoString = deprecate('toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)', iso_string__toISOString);
    duration_prototype__proto.lang = lang;

    // Side effect imports

    addFormatToken('X', 0, 0, 'unix');
    addFormatToken('x', 0, 0, 'valueOf');

    // PARSING

    addRegexToken('x', matchSigned);
    addRegexToken('X', matchTimestamp);
    addParseToken('X', function (input, array, config) {
        config._d = new Date(parseFloat(input, 10) * 1000);
    });
    addParseToken('x', function (input, array, config) {
        config._d = new Date(toInt(input));
    });

    // Side effect imports


    utils_hooks__hooks.version = '2.10.6';

    setHookCallback(local__createLocal);

    utils_hooks__hooks.fn                    = momentPrototype;
    utils_hooks__hooks.min                   = min;
    utils_hooks__hooks.max                   = max;
    utils_hooks__hooks.utc                   = create_utc__createUTC;
    utils_hooks__hooks.unix                  = moment__createUnix;
    utils_hooks__hooks.months                = lists__listMonths;
    utils_hooks__hooks.isDate                = isDate;
    utils_hooks__hooks.locale                = locale_locales__getSetGlobalLocale;
    utils_hooks__hooks.invalid               = valid__createInvalid;
    utils_hooks__hooks.duration              = create__createDuration;
    utils_hooks__hooks.isMoment              = isMoment;
    utils_hooks__hooks.weekdays              = lists__listWeekdays;
    utils_hooks__hooks.parseZone             = moment__createInZone;
    utils_hooks__hooks.localeData            = locale_locales__getLocale;
    utils_hooks__hooks.isDuration            = isDuration;
    utils_hooks__hooks.monthsShort           = lists__listMonthsShort;
    utils_hooks__hooks.weekdaysMin           = lists__listWeekdaysMin;
    utils_hooks__hooks.defineLocale          = defineLocale;
    utils_hooks__hooks.weekdaysShort         = lists__listWeekdaysShort;
    utils_hooks__hooks.normalizeUnits        = normalizeUnits;
    utils_hooks__hooks.relativeTimeThreshold = duration_humanize__getSetRelativeTimeThreshold;

    var _moment = utils_hooks__hooks;

    return _moment;

}));;

/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements.  See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership.  The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License.  You may obtain a copy of the License at
*
*   http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied.  See the License for the
* specific language governing permissions and limitations
* under the License.
*/

!function (t, e) { "object" == typeof exports && "undefined" != typeof module ? e(exports) : "function" == typeof define && define.amd ? define(["exports"], e) : e((t = "undefined" != typeof globalThis ? globalThis : t || self).echarts = {}) }(this, (function (t) {
    "use strict";
/*! *****************************************************************************
    Copyright (c) Microsoft Corporation.

    Permission to use, copy, modify, and/or distribute this software for any
    purpose with or without fee is hereby granted.

    THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
    REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
    AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
    INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
    LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
    OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
    PERFORMANCE OF THIS SOFTWARE.
    ***************************************************************************** */var e = function (t, n) { return e = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function (t, e) { t.__proto__ = e } || function (t, e) { for (var n in e) Object.prototype.hasOwnProperty.call(e, n) && (t[n] = e[n]) }, e(t, n) }; function n(t, n) { if ("function" != typeof n && null !== n) throw new TypeError("Class extends value " + String(n) + " is not a constructor or null"); function i() { this.constructor = t } e(t, n), t.prototype = null === n ? Object.create(n) : (i.prototype = n.prototype, new i) } var i = function () { this.firefox = !1, this.ie = !1, this.edge = !1, this.newEdge = !1, this.weChat = !1 }, r = new function () { this.browser = new i, this.node = !1, this.wxa = !1, this.worker = !1, this.svgSupported = !1, this.touchEventsSupported = !1, this.pointerEventsSupported = !1, this.domSupported = !1, this.transformSupported = !1, this.transform3dSupported = !1, this.hasGlobalWindow = "undefined" != typeof window }; "object" == typeof wx && "function" == typeof wx.getSystemInfoSync ? (r.wxa = !0, r.touchEventsSupported = !0) : "undefined" == typeof document && "undefined" != typeof self ? r.worker = !0 : "undefined" == typeof navigator ? (r.node = !0, r.svgSupported = !0) : function (t, e) { var n = e.browser, i = t.match(/Firefox\/([\d.]+)/), r = t.match(/MSIE\s([\d.]+)/) || t.match(/Trident\/.+?rv:(([\d.]+))/), o = t.match(/Edge?\/([\d.]+)/), a = /micromessenger/i.test(t); i && (n.firefox = !0, n.version = i[1]); r && (n.ie = !0, n.version = r[1]); o && (n.edge = !0, n.version = o[1], n.newEdge = +o[1].split(".")[0] > 18); a && (n.weChat = !0); e.svgSupported = "undefined" != typeof SVGRect, e.touchEventsSupported = "ontouchstart" in window && !n.ie && !n.edge, e.pointerEventsSupported = "onpointerdown" in window && (n.edge || n.ie && +n.version >= 11), e.domSupported = "undefined" != typeof document; var s = document.documentElement.style; e.transform3dSupported = (n.ie && "transition" in s || n.edge || "WebKitCSSMatrix" in window && "m11" in new WebKitCSSMatrix || "MozPerspective" in s) && !("OTransition" in s), e.transformSupported = e.transform3dSupported || n.ie && +n.version >= 9 }(navigator.userAgent, r); var o = "sans-serif", a = "12px " + o; var s, l, u = function (t) { var e = {}; if ("undefined" == typeof JSON) return e; for (var n = 0; n < t.length; n++) { var i = String.fromCharCode(n + 32), r = (t.charCodeAt(n) - 20) / 100; e[i] = r } return e }("007LLmW'55;N0500LLLLLLLLLL00NNNLzWW\\\\WQb\\0FWLg\\bWb\\WQ\\WrWWQ000CL5LLFLL0LL**F*gLLLL5F0LF\\FFF5.5N"), h = { createCanvas: function () { return "undefined" != typeof document && document.createElement("canvas") }, measureText: function (t, e) { if (!s) { var n = h.createCanvas(); s = n && n.getContext("2d") } if (s) return l !== e && (l = s.font = e || a), s.measureText(t); t = t || ""; var i = /(\d+)px/.exec(e = e || a), r = i && +i[1] || 12, o = 0; if (e.indexOf("mono") >= 0) o = r * t.length; else for (var c = 0; c < t.length; c++) { var p = u[t[c]]; o += null == p ? r : p * r } return { width: o } }, loadImage: function (t, e, n) { var i = new Image; return i.onload = e, i.onerror = n, i.src = t, i } }; function c(t) { for (var e in h) t[e] && (h[e] = t[e]) } var p = V(["Function", "RegExp", "Date", "Error", "CanvasGradient", "CanvasPattern", "Image", "Canvas"], (function (t, e) { return t["[object " + e + "]"] = !0, t }), {}), d = V(["Int8", "Uint8", "Uint8Clamped", "Int16", "Uint16", "Int32", "Uint32", "Float32", "Float64"], (function (t, e) { return t["[object " + e + "Array]"] = !0, t }), {}), f = Object.prototype.toString, g = Array.prototype, y = g.forEach, v = g.filter, m = g.slice, x = g.map, _ = function () { }.constructor, b = _ ? _.prototype : null, w = "__proto__", S = 2311; function M() { return S++ } function I() { for (var t = [], e = 0; e < arguments.length; e++)t[e] = arguments[e]; "undefined" != typeof console && console.error.apply(console, t) } function T(t) { if (null == t || "object" != typeof t) return t; var e = t, n = f.call(t); if ("[object Array]" === n) { if (!pt(t)) { e = []; for (var i = 0, r = t.length; i < r; i++)e[i] = T(t[i]) } } else if (d[n]) { if (!pt(t)) { var o = t.constructor; if (o.from) e = o.from(t); else { e = new o(t.length); for (i = 0, r = t.length; i < r; i++)e[i] = t[i] } } } else if (!p[n] && !pt(t) && !J(t)) for (var a in e = {}, t) t.hasOwnProperty(a) && a !== w && (e[a] = T(t[a])); return e } function C(t, e, n) { if (!q(e) || !q(t)) return n ? T(e) : t; for (var i in e) if (e.hasOwnProperty(i) && i !== w) { var r = t[i], o = e[i]; !q(o) || !q(r) || Y(o) || Y(r) || J(o) || J(r) || K(o) || K(r) || pt(o) || pt(r) ? !n && i in t || (t[i] = T(e[i])) : C(r, o, n) } return t } function D(t, e) { for (var n = t[0], i = 1, r = t.length; i < r; i++)n = C(n, t[i], e); return n } function A(t, e) { if (Object.assign) Object.assign(t, e); else for (var n in e) e.hasOwnProperty(n) && n !== w && (t[n] = e[n]); return t } function k(t, e, n) { for (var i = G(e), r = 0; r < i.length; r++) { var o = i[r]; (n ? null != e[o] : null == t[o]) && (t[o] = e[o]) } return t } var L = h.createCanvas; function P(t, e) { if (t) { if (t.indexOf) return t.indexOf(e); for (var n = 0, i = t.length; n < i; n++)if (t[n] === e) return n } return -1 } function O(t, e) { var n = t.prototype; function i() { } for (var r in i.prototype = e.prototype, t.prototype = new i, n) n.hasOwnProperty(r) && (t.prototype[r] = n[r]); t.prototype.constructor = t, t.superClass = e } function R(t, e, n) { if (t = "prototype" in t ? t.prototype : t, e = "prototype" in e ? e.prototype : e, Object.getOwnPropertyNames) for (var i = Object.getOwnPropertyNames(e), r = 0; r < i.length; r++) { var o = i[r]; "constructor" !== o && (n ? null != e[o] : null == t[o]) && (t[o] = e[o]) } else k(t, e, n) } function N(t) { return !!t && ("string" != typeof t && "number" == typeof t.length) } function E(t, e, n) { if (t && e) if (t.forEach && t.forEach === y) t.forEach(e, n); else if (t.length === +t.length) for (var i = 0, r = t.length; i < r; i++)e.call(n, t[i], i, t); else for (var o in t) t.hasOwnProperty(o) && e.call(n, t[o], o, t) } function z(t, e, n) { if (!t) return []; if (!e) return at(t); if (t.map && t.map === x) return t.map(e, n); for (var i = [], r = 0, o = t.length; r < o; r++)i.push(e.call(n, t[r], r, t)); return i } function V(t, e, n, i) { if (t && e) { for (var r = 0, o = t.length; r < o; r++)n = e.call(i, n, t[r], r, t); return n } } function B(t, e, n) { if (!t) return []; if (!e) return at(t); if (t.filter && t.filter === v) return t.filter(e, n); for (var i = [], r = 0, o = t.length; r < o; r++)e.call(n, t[r], r, t) && i.push(t[r]); return i } function F(t, e, n) { if (t && e) for (var i = 0, r = t.length; i < r; i++)if (e.call(n, t[i], i, t)) return t[i] } function G(t) { if (!t) return []; if (Object.keys) return Object.keys(t); var e = []; for (var n in t) t.hasOwnProperty(n) && e.push(n); return e } var W = b && X(b.bind) ? b.call.bind(b.bind) : function (t, e) { for (var n = [], i = 2; i < arguments.length; i++)n[i - 2] = arguments[i]; return function () { return t.apply(e, n.concat(m.call(arguments))) } }; function H(t) { for (var e = [], n = 1; n < arguments.length; n++)e[n - 1] = arguments[n]; return function () { return t.apply(this, e.concat(m.call(arguments))) } } function Y(t) { return Array.isArray ? Array.isArray(t) : "[object Array]" === f.call(t) } function X(t) { return "function" == typeof t } function U(t) { return "string" == typeof t } function Z(t) { return "[object String]" === f.call(t) } function j(t) { return "number" == typeof t } function q(t) { var e = typeof t; return "function" === e || !!t && "object" === e } function K(t) { return !!p[f.call(t)] } function $(t) { return !!d[f.call(t)] } function J(t) { return "object" == typeof t && "number" == typeof t.nodeType && "object" == typeof t.ownerDocument } function Q(t) { return null != t.colorStops } function tt(t) { return null != t.image } function et(t) { return "[object RegExp]" === f.call(t) } function nt(t) { return t != t } function it() { for (var t = [], e = 0; e < arguments.length; e++)t[e] = arguments[e]; for (var n = 0, i = t.length; n < i; n++)if (null != t[n]) return t[n] } function rt(t, e) { return null != t ? t : e } function ot(t, e, n) { return null != t ? t : null != e ? e : n } function at(t) { for (var e = [], n = 1; n < arguments.length; n++)e[n - 1] = arguments[n]; return m.apply(t, e) } function st(t) { if ("number" == typeof t) return [t, t, t, t]; var e = t.length; return 2 === e ? [t[0], t[1], t[0], t[1]] : 3 === e ? [t[0], t[1], t[2], t[1]] : t } function lt(t, e) { if (!t) throw new Error(e) } function ut(t) { return null == t ? null : "function" == typeof t.trim ? t.trim() : t.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, "") } var ht = "__ec_primitive__"; function ct(t) { t[ht] = !0 } function pt(t) { return t[ht] } var dt = function () { function t() { this.data = {} } return t.prototype.delete = function (t) { var e = this.has(t); return e && delete this.data[t], e }, t.prototype.has = function (t) { return this.data.hasOwnProperty(t) }, t.prototype.get = function (t) { return this.data[t] }, t.prototype.set = function (t, e) { return this.data[t] = e, this }, t.prototype.keys = function () { return G(this.data) }, t.prototype.forEach = function (t) { var e = this.data; for (var n in e) e.hasOwnProperty(n) && t(e[n], n) }, t }(), ft = "function" == typeof Map; var gt = function () { function t(e) { var n = Y(e); this.data = ft ? new Map : new dt; var i = this; function r(t, e) { n ? i.set(t, e) : i.set(e, t) } e instanceof t ? e.each(r) : e && E(e, r) } return t.prototype.hasKey = function (t) { return this.data.has(t) }, t.prototype.get = function (t) { return this.data.get(t) }, t.prototype.set = function (t, e) { return this.data.set(t, e), e }, t.prototype.each = function (t, e) { this.data.forEach((function (n, i) { t.call(e, n, i) })) }, t.prototype.keys = function () { var t = this.data.keys(); return ft ? Array.from(t) : t }, t.prototype.removeKey = function (t) { this.data.delete(t) }, t }(); function yt(t) { return new gt(t) } function vt(t, e) { for (var n = new t.constructor(t.length + e.length), i = 0; i < t.length; i++)n[i] = t[i]; var r = t.length; for (i = 0; i < e.length; i++)n[i + r] = e[i]; return n } function mt(t, e) { var n; if (Object.create) n = Object.create(t); else { var i = function () { }; i.prototype = t, n = new i } return e && A(n, e), n } function xt(t) { var e = t.style; e.webkitUserSelect = "none", e.userSelect = "none", e.webkitTapHighlightColor = "rgba(0,0,0,0)", e["-webkit-touch-callout"] = "none" } function _t(t, e) { return t.hasOwnProperty(e) } function bt() { } var wt = 180 / Math.PI, St = Object.freeze({ __proto__: null, guid: M, logError: I, clone: T, merge: C, mergeAll: D, extend: A, defaults: k, createCanvas: L, indexOf: P, inherits: O, mixin: R, isArrayLike: N, each: E, map: z, reduce: V, filter: B, find: F, keys: G, bind: W, curry: H, isArray: Y, isFunction: X, isString: U, isStringSafe: Z, isNumber: j, isObject: q, isBuiltInObject: K, isTypedArray: $, isDom: J, isGradientObject: Q, isImagePatternObject: tt, isRegExp: et, eqNaN: nt, retrieve: it, retrieve2: rt, retrieve3: ot, slice: at, normalizeCssArray: st, assert: lt, trim: ut, setAsPrimitive: ct, isPrimitive: pt, HashMap: gt, createHashMap: yt, concatArray: vt, createObject: mt, disableUserSelect: xt, hasOwn: _t, noop: bt, RADIAN_TO_DEGREE: wt }); function Mt(t, e) { return null == t && (t = 0), null == e && (e = 0), [t, e] } function It(t, e) { return t[0] = e[0], t[1] = e[1], t } function Tt(t) { return [t[0], t[1]] } function Ct(t, e, n) { return t[0] = e, t[1] = n, t } function Dt(t, e, n) { return t[0] = e[0] + n[0], t[1] = e[1] + n[1], t } function At(t, e, n, i) { return t[0] = e[0] + n[0] * i, t[1] = e[1] + n[1] * i, t } function kt(t, e, n) { return t[0] = e[0] - n[0], t[1] = e[1] - n[1], t } function Lt(t) { return Math.sqrt(Ot(t)) } var Pt = Lt; function Ot(t) { return t[0] * t[0] + t[1] * t[1] } var Rt = Ot; function Nt(t, e, n) { return t[0] = e[0] * n, t[1] = e[1] * n, t } function Et(t, e) { var n = Lt(e); return 0 === n ? (t[0] = 0, t[1] = 0) : (t[0] = e[0] / n, t[1] = e[1] / n), t } function zt(t, e) { return Math.sqrt((t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1])) } var Vt = zt; function Bt(t, e) { return (t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1]) } var Ft = Bt; function Gt(t, e, n, i) { return t[0] = e[0] + i * (n[0] - e[0]), t[1] = e[1] + i * (n[1] - e[1]), t } function Wt(t, e, n) { var i = e[0], r = e[1]; return t[0] = n[0] * i + n[2] * r + n[4], t[1] = n[1] * i + n[3] * r + n[5], t } function Ht(t, e, n) { return t[0] = Math.min(e[0], n[0]), t[1] = Math.min(e[1], n[1]), t } function Yt(t, e, n) { return t[0] = Math.max(e[0], n[0]), t[1] = Math.max(e[1], n[1]), t } var Xt = Object.freeze({ __proto__: null, create: Mt, copy: It, clone: Tt, set: Ct, add: Dt, scaleAndAdd: At, sub: kt, len: Lt, length: Pt, lenSquare: Ot, lengthSquare: Rt, mul: function (t, e, n) { return t[0] = e[0] * n[0], t[1] = e[1] * n[1], t }, div: function (t, e, n) { return t[0] = e[0] / n[0], t[1] = e[1] / n[1], t }, dot: function (t, e) { return t[0] * e[0] + t[1] * e[1] }, scale: Nt, normalize: Et, distance: zt, dist: Vt, distanceSquare: Bt, distSquare: Ft, negate: function (t, e) { return t[0] = -e[0], t[1] = -e[1], t }, lerp: Gt, applyTransform: Wt, min: Ht, max: Yt }), Ut = function (t, e) { this.target = t, this.topTarget = e && e.topTarget }, Zt = function () { function t(t) { this.handler = t, t.on("mousedown", this._dragStart, this), t.on("mousemove", this._drag, this), t.on("mouseup", this._dragEnd, this) } return t.prototype._dragStart = function (t) { for (var e = t.target; e && !e.draggable;)e = e.parent || e.__hostTarget; e && (this._draggingTarget = e, e.dragging = !0, this._x = t.offsetX, this._y = t.offsetY, this.handler.dispatchToElement(new Ut(e, t), "dragstart", t.event)) }, t.prototype._drag = function (t) { var e = this._draggingTarget; if (e) { var n = t.offsetX, i = t.offsetY, r = n - this._x, o = i - this._y; this._x = n, this._y = i, e.drift(r, o, t), this.handler.dispatchToElement(new Ut(e, t), "drag", t.event); var a = this.handler.findHover(n, i, e).target, s = this._dropTarget; this._dropTarget = a, e !== a && (s && a !== s && this.handler.dispatchToElement(new Ut(s, t), "dragleave", t.event), a && a !== s && this.handler.dispatchToElement(new Ut(a, t), "dragenter", t.event)) } }, t.prototype._dragEnd = function (t) { var e = this._draggingTarget; e && (e.dragging = !1), this.handler.dispatchToElement(new Ut(e, t), "dragend", t.event), this._dropTarget && this.handler.dispatchToElement(new Ut(this._dropTarget, t), "drop", t.event), this._draggingTarget = null, this._dropTarget = null }, t }(), jt = function () { function t(t) { t && (this._$eventProcessor = t) } return t.prototype.on = function (t, e, n, i) { this._$handlers || (this._$handlers = {}); var r = this._$handlers; if ("function" == typeof e && (i = n, n = e, e = null), !n || !t) return this; var o = this._$eventProcessor; null != e && o && o.normalizeQuery && (e = o.normalizeQuery(e)), r[t] || (r[t] = []); for (var a = 0; a < r[t].length; a++)if (r[t][a].h === n) return this; var s = { h: n, query: e, ctx: i || this, callAtLast: n.zrEventfulCallAtLast }, l = r[t].length - 1, u = r[t][l]; return u && u.callAtLast ? r[t].splice(l, 0, s) : r[t].push(s), this }, t.prototype.isSilent = function (t) { var e = this._$handlers; return !e || !e[t] || !e[t].length }, t.prototype.off = function (t, e) { var n = this._$handlers; if (!n) return this; if (!t) return this._$handlers = {}, this; if (e) { if (n[t]) { for (var i = [], r = 0, o = n[t].length; r < o; r++)n[t][r].h !== e && i.push(n[t][r]); n[t] = i } n[t] && 0 === n[t].length && delete n[t] } else delete n[t]; return this }, t.prototype.trigger = function (t) { for (var e = [], n = 1; n < arguments.length; n++)e[n - 1] = arguments[n]; if (!this._$handlers) return this; var i = this._$handlers[t], r = this._$eventProcessor; if (i) for (var o = e.length, a = i.length, s = 0; s < a; s++) { var l = i[s]; if (!r || !r.filter || null == l.query || r.filter(t, l.query)) switch (o) { case 0: l.h.call(l.ctx); break; case 1: l.h.call(l.ctx, e[0]); break; case 2: l.h.call(l.ctx, e[0], e[1]); break; default: l.h.apply(l.ctx, e) } } return r && r.afterTrigger && r.afterTrigger(t), this }, t.prototype.triggerWithContext = function (t) { for (var e = [], n = 1; n < arguments.length; n++)e[n - 1] = arguments[n]; if (!this._$handlers) return this; var i = this._$handlers[t], r = this._$eventProcessor; if (i) for (var o = e.length, a = e[o - 1], s = i.length, l = 0; l < s; l++) { var u = i[l]; if (!r || !r.filter || null == u.query || r.filter(t, u.query)) switch (o) { case 0: u.h.call(a); break; case 1: u.h.call(a, e[0]); break; case 2: u.h.call(a, e[0], e[1]); break; default: u.h.apply(a, e.slice(1, o - 1)) } } return r && r.afterTrigger && r.afterTrigger(t), this }, t }(), qt = Math.log(2); function Kt(t, e, n, i, r, o) { var a = i + "-" + r, s = t.length; if (o.hasOwnProperty(a)) return o[a]; if (1 === e) { var l = Math.round(Math.log((1 << s) - 1 & ~r) / qt); return t[n][l] } for (var u = i | 1 << n, h = n + 1; i & 1 << h;)h++; for (var c = 0, p = 0, d = 0; p < s; p++) { var f = 1 << p; f & r || (c += (d % 2 ? -1 : 1) * t[n][p] * Kt(t, e - 1, h, u, r | f, o), d++) } return o[a] = c, c } function $t(t, e) { var n = [[t[0], t[1], 1, 0, 0, 0, -e[0] * t[0], -e[0] * t[1]], [0, 0, 0, t[0], t[1], 1, -e[1] * t[0], -e[1] * t[1]], [t[2], t[3], 1, 0, 0, 0, -e[2] * t[2], -e[2] * t[3]], [0, 0, 0, t[2], t[3], 1, -e[3] * t[2], -e[3] * t[3]], [t[4], t[5], 1, 0, 0, 0, -e[4] * t[4], -e[4] * t[5]], [0, 0, 0, t[4], t[5], 1, -e[5] * t[4], -e[5] * t[5]], [t[6], t[7], 1, 0, 0, 0, -e[6] * t[6], -e[6] * t[7]], [0, 0, 0, t[6], t[7], 1, -e[7] * t[6], -e[7] * t[7]]], i = {}, r = Kt(n, 8, 0, 0, 0, i); if (0 !== r) { for (var o = [], a = 0; a < 8; a++)for (var s = 0; s < 8; s++)null == o[s] && (o[s] = 0), o[s] += ((a + s) % 2 ? -1 : 1) * Kt(n, 7, 0 === a ? 1 : 0, 1 << a, 1 << s, i) / r * e[a]; return function (t, e, n) { var i = e * o[6] + n * o[7] + 1; t[0] = (e * o[0] + n * o[1] + o[2]) / i, t[1] = (e * o[3] + n * o[4] + o[5]) / i } } } var Jt = "___zrEVENTSAVED", Qt = []; function te(t, e, n, i, o) { if (e.getBoundingClientRect && r.domSupported && !ee(e)) { var a = e[Jt] || (e[Jt] = {}), s = function (t, e) { var n = e.markers; if (n) return n; n = e.markers = []; for (var i = ["left", "right"], r = ["top", "bottom"], o = 0; o < 4; o++) { var a = document.createElement("div"), s = o % 2, l = (o >> 1) % 2; a.style.cssText = ["position: absolute", "visibility: hidden", "padding: 0", "margin: 0", "border-width: 0", "user-select: none", "width:0", "height:0", i[s] + ":0", r[l] + ":0", i[1 - s] + ":auto", r[1 - l] + ":auto", ""].join("!important;"), t.appendChild(a), n.push(a) } return n }(e, a), l = function (t, e, n) { for (var i = n ? "invTrans" : "trans", r = e[i], o = e.srcCoords, a = [], s = [], l = !0, u = 0; u < 4; u++) { var h = t[u].getBoundingClientRect(), c = 2 * u, p = h.left, d = h.top; a.push(p, d), l = l && o && p === o[c] && d === o[c + 1], s.push(t[u].offsetLeft, t[u].offsetTop) } return l && r ? r : (e.srcCoords = a, e[i] = n ? $t(s, a) : $t(a, s)) }(s, a, o); if (l) return l(t, n, i), !0 } return !1 } function ee(t) { return "CANVAS" === t.nodeName.toUpperCase() } var ne = /([&<>"'])/g, ie = { "&": "&amp;", "<": "&lt;", ">": "&gt;", '"': "&quot;", "'": "&#39;" }; function re(t) { return null == t ? "" : (t + "").replace(ne, (function (t, e) { return ie[e] })) } var oe = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, ae = [], se = r.browser.firefox && +r.browser.version.split(".")[0] < 39; function le(t, e, n, i) { return n = n || {}, i ? ue(t, e, n) : se && null != e.layerX && e.layerX !== e.offsetX ? (n.zrX = e.layerX, n.zrY = e.layerY) : null != e.offsetX ? (n.zrX = e.offsetX, n.zrY = e.offsetY) : ue(t, e, n), n } function ue(t, e, n) { if (r.domSupported && t.getBoundingClientRect) { var i = e.clientX, o = e.clientY; if (ee(t)) { var a = t.getBoundingClientRect(); return n.zrX = i - a.left, void (n.zrY = o - a.top) } if (te(ae, t, i, o)) return n.zrX = ae[0], void (n.zrY = ae[1]) } n.zrX = n.zrY = 0 } function he(t) { return t || window.event } function ce(t, e, n) { if (null != (e = he(e)).zrX) return e; var i = e.type; if (i && i.indexOf("touch") >= 0) { var r = "touchend" !== i ? e.targetTouches[0] : e.changedTouches[0]; r && le(t, r, e, n) } else { le(t, e, e, n); var o = function (t) { var e = t.wheelDelta; if (e) return e; var n = t.deltaX, i = t.deltaY; if (null == n || null == i) return e; return 3 * (0 !== i ? Math.abs(i) : Math.abs(n)) * (i > 0 ? -1 : i < 0 ? 1 : n > 0 ? -1 : 1) }(e); e.zrDelta = o ? o / 120 : -(e.detail || 0) / 3 } var a = e.button; return null == e.which && void 0 !== a && oe.test(e.type) && (e.which = 1 & a ? 1 : 2 & a ? 3 : 4 & a ? 2 : 0), e } function pe(t, e, n, i) { t.addEventListener(e, n, i) } var de = function (t) { t.preventDefault(), t.stopPropagation(), t.cancelBubble = !0 }; function fe(t) { return 2 === t.which || 3 === t.which } var ge = function () { function t() { this._track = [] } return t.prototype.recognize = function (t, e, n) { return this._doTrack(t, e, n), this._recognize(t) }, t.prototype.clear = function () { return this._track.length = 0, this }, t.prototype._doTrack = function (t, e, n) { var i = t.touches; if (i) { for (var r = { points: [], touches: [], target: e, event: t }, o = 0, a = i.length; o < a; o++) { var s = i[o], l = le(n, s, {}); r.points.push([l.zrX, l.zrY]), r.touches.push(s) } this._track.push(r) } }, t.prototype._recognize = function (t) { for (var e in ve) if (ve.hasOwnProperty(e)) { var n = ve[e](this._track, t); if (n) return n } }, t }(); function ye(t) { var e = t[1][0] - t[0][0], n = t[1][1] - t[0][1]; return Math.sqrt(e * e + n * n) } var ve = { pinch: function (t, e) { var n = t.length; if (n) { var i, r = (t[n - 1] || {}).points, o = (t[n - 2] || {}).points || r; if (o && o.length > 1 && r && r.length > 1) { var a = ye(r) / ye(o); !isFinite(a) && (a = 1), e.pinchScale = a; var s = [((i = r)[0][0] + i[1][0]) / 2, (i[0][1] + i[1][1]) / 2]; return e.pinchX = s[0], e.pinchY = s[1], { type: "pinch", target: t[0].target, event: e } } } } }; function me() { return [1, 0, 0, 1, 0, 0] } function xe(t) { return t[0] = 1, t[1] = 0, t[2] = 0, t[3] = 1, t[4] = 0, t[5] = 0, t } function _e(t, e) { return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t[4] = e[4], t[5] = e[5], t } function be(t, e, n) { var i = e[0] * n[0] + e[2] * n[1], r = e[1] * n[0] + e[3] * n[1], o = e[0] * n[2] + e[2] * n[3], a = e[1] * n[2] + e[3] * n[3], s = e[0] * n[4] + e[2] * n[5] + e[4], l = e[1] * n[4] + e[3] * n[5] + e[5]; return t[0] = i, t[1] = r, t[2] = o, t[3] = a, t[4] = s, t[5] = l, t } function we(t, e, n) { return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t[4] = e[4] + n[0], t[5] = e[5] + n[1], t } function Se(t, e, n) { var i = e[0], r = e[2], o = e[4], a = e[1], s = e[3], l = e[5], u = Math.sin(n), h = Math.cos(n); return t[0] = i * h + a * u, t[1] = -i * u + a * h, t[2] = r * h + s * u, t[3] = -r * u + h * s, t[4] = h * o + u * l, t[5] = h * l - u * o, t } function Me(t, e, n) { var i = n[0], r = n[1]; return t[0] = e[0] * i, t[1] = e[1] * r, t[2] = e[2] * i, t[3] = e[3] * r, t[4] = e[4] * i, t[5] = e[5] * r, t } function Ie(t, e) { var n = e[0], i = e[2], r = e[4], o = e[1], a = e[3], s = e[5], l = n * a - o * i; return l ? (l = 1 / l, t[0] = a * l, t[1] = -o * l, t[2] = -i * l, t[3] = n * l, t[4] = (i * s - a * r) * l, t[5] = (o * r - n * s) * l, t) : null } function Te(t) { var e = [1, 0, 0, 1, 0, 0]; return _e(e, t), e } var Ce = Object.freeze({ __proto__: null, create: me, identity: xe, copy: _e, mul: be, translate: we, rotate: Se, scale: Me, invert: Ie, clone: Te }), De = function () { function t(t, e) { this.x = t || 0, this.y = e || 0 } return t.prototype.copy = function (t) { return this.x = t.x, this.y = t.y, this }, t.prototype.clone = function () { return new t(this.x, this.y) }, t.prototype.set = function (t, e) { return this.x = t, this.y = e, this }, t.prototype.equal = function (t) { return t.x === this.x && t.y === this.y }, t.prototype.add = function (t) { return this.x += t.x, this.y += t.y, this }, t.prototype.scale = function (t) { this.x *= t, this.y *= t }, t.prototype.scaleAndAdd = function (t, e) { this.x += t.x * e, this.y += t.y * e }, t.prototype.sub = function (t) { return this.x -= t.x, this.y -= t.y, this }, t.prototype.dot = function (t) { return this.x * t.x + this.y * t.y }, t.prototype.len = function () { return Math.sqrt(this.x * this.x + this.y * this.y) }, t.prototype.lenSquare = function () { return this.x * this.x + this.y * this.y }, t.prototype.normalize = function () { var t = this.len(); return this.x /= t, this.y /= t, this }, t.prototype.distance = function (t) { var e = this.x - t.x, n = this.y - t.y; return Math.sqrt(e * e + n * n) }, t.prototype.distanceSquare = function (t) { var e = this.x - t.x, n = this.y - t.y; return e * e + n * n }, t.prototype.negate = function () { return this.x = -this.x, this.y = -this.y, this }, t.prototype.transform = function (t) { if (t) { var e = this.x, n = this.y; return this.x = t[0] * e + t[2] * n + t[4], this.y = t[1] * e + t[3] * n + t[5], this } }, t.prototype.toArray = function (t) { return t[0] = this.x, t[1] = this.y, t }, t.prototype.fromArray = function (t) { this.x = t[0], this.y = t[1] }, t.set = function (t, e, n) { t.x = e, t.y = n }, t.copy = function (t, e) { t.x = e.x, t.y = e.y }, t.len = function (t) { return Math.sqrt(t.x * t.x + t.y * t.y) }, t.lenSquare = function (t) { return t.x * t.x + t.y * t.y }, t.dot = function (t, e) { return t.x * e.x + t.y * e.y }, t.add = function (t, e, n) { t.x = e.x + n.x, t.y = e.y + n.y }, t.sub = function (t, e, n) { t.x = e.x - n.x, t.y = e.y - n.y }, t.scale = function (t, e, n) { t.x = e.x * n, t.y = e.y * n }, t.scaleAndAdd = function (t, e, n, i) { t.x = e.x + n.x * i, t.y = e.y + n.y * i }, t.lerp = function (t, e, n, i) { var r = 1 - i; t.x = r * e.x + i * n.x, t.y = r * e.y + i * n.y }, t }(), Ae = Math.min, ke = Math.max, Le = new De, Pe = new De, Oe = new De, Re = new De, Ne = new De, Ee = new De, ze = function () { function t(t, e, n, i) { n < 0 && (t += n, n = -n), i < 0 && (e += i, i = -i), this.x = t, this.y = e, this.width = n, this.height = i } return t.prototype.union = function (t) { var e = Ae(t.x, this.x), n = Ae(t.y, this.y); isFinite(this.x) && isFinite(this.width) ? this.width = ke(t.x + t.width, this.x + this.width) - e : this.width = t.width, isFinite(this.y) && isFinite(this.height) ? this.height = ke(t.y + t.height, this.y + this.height) - n : this.height = t.height, this.x = e, this.y = n }, t.prototype.applyTransform = function (e) { t.applyTransform(this, this, e) }, t.prototype.calculateTransform = function (t) { var e = this, n = t.width / e.width, i = t.height / e.height, r = [1, 0, 0, 1, 0, 0]; return we(r, r, [-e.x, -e.y]), Me(r, r, [n, i]), we(r, r, [t.x, t.y]), r }, t.prototype.intersect = function (e, n) { if (!e) return !1; e instanceof t || (e = t.create(e)); var i = this, r = i.x, o = i.x + i.width, a = i.y, s = i.y + i.height, l = e.x, u = e.x + e.width, h = e.y, c = e.y + e.height, p = !(o < l || u < r || s < h || c < a); if (n) { var d = 1 / 0, f = 0, g = Math.abs(o - l), y = Math.abs(u - r), v = Math.abs(s - h), m = Math.abs(c - a), x = Math.min(g, y), _ = Math.min(v, m); o < l || u < r ? x > f && (f = x, g < y ? De.set(Ee, -g, 0) : De.set(Ee, y, 0)) : x < d && (d = x, g < y ? De.set(Ne, g, 0) : De.set(Ne, -y, 0)), s < h || c < a ? _ > f && (f = _, v < m ? De.set(Ee, 0, -v) : De.set(Ee, 0, m)) : x < d && (d = x, v < m ? De.set(Ne, 0, v) : De.set(Ne, 0, -m)) } return n && De.copy(n, p ? Ne : Ee), p }, t.prototype.contain = function (t, e) { var n = this; return t >= n.x && t <= n.x + n.width && e >= n.y && e <= n.y + n.height }, t.prototype.clone = function () { return new t(this.x, this.y, this.width, this.height) }, t.prototype.copy = function (e) { t.copy(this, e) }, t.prototype.plain = function () { return { x: this.x, y: this.y, width: this.width, height: this.height } }, t.prototype.isFinite = function () { return isFinite(this.x) && isFinite(this.y) && isFinite(this.width) && isFinite(this.height) }, t.prototype.isZero = function () { return 0 === this.width || 0 === this.height }, t.create = function (e) { return new t(e.x, e.y, e.width, e.height) }, t.copy = function (t, e) { t.x = e.x, t.y = e.y, t.width = e.width, t.height = e.height }, t.applyTransform = function (e, n, i) { if (i) { if (i[1] < 1e-5 && i[1] > -1e-5 && i[2] < 1e-5 && i[2] > -1e-5) { var r = i[0], o = i[3], a = i[4], s = i[5]; return e.x = n.x * r + a, e.y = n.y * o + s, e.width = n.width * r, e.height = n.height * o, e.width < 0 && (e.x += e.width, e.width = -e.width), void (e.height < 0 && (e.y += e.height, e.height = -e.height)) } Le.x = Oe.x = n.x, Le.y = Re.y = n.y, Pe.x = Re.x = n.x + n.width, Pe.y = Oe.y = n.y + n.height, Le.transform(i), Re.transform(i), Pe.transform(i), Oe.transform(i), e.x = Ae(Le.x, Pe.x, Oe.x, Re.x), e.y = Ae(Le.y, Pe.y, Oe.y, Re.y); var l = ke(Le.x, Pe.x, Oe.x, Re.x), u = ke(Le.y, Pe.y, Oe.y, Re.y); e.width = l - e.x, e.height = u - e.y } else e !== n && t.copy(e, n) }, t }(), Ve = "silent"; function Be() { de(this.event) } var Fe = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.handler = null, e } return n(e, t), e.prototype.dispose = function () { }, e.prototype.setCursor = function () { }, e }(jt), Ge = function (t, e) { this.x = t, this.y = e }, We = ["click", "dblclick", "mousewheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu"], He = new ze(0, 0, 0, 0), Ye = function (t) { function e(e, n, i, r, o) { var a = t.call(this) || this; return a._hovered = new Ge(0, 0), a.storage = e, a.painter = n, a.painterRoot = r, a._pointerSize = o, i = i || new Fe, a.proxy = null, a.setHandlerProxy(i), a._draggingMgr = new Zt(a), a } return n(e, t), e.prototype.setHandlerProxy = function (t) { this.proxy && this.proxy.dispose(), t && (E(We, (function (e) { t.on && t.on(e, this[e], this) }), this), t.handler = this), this.proxy = t }, e.prototype.mousemove = function (t) { var e = t.zrX, n = t.zrY, i = Ze(this, e, n), r = this._hovered, o = r.target; o && !o.__zr && (o = (r = this.findHover(r.x, r.y)).target); var a = this._hovered = i ? new Ge(e, n) : this.findHover(e, n), s = a.target, l = this.proxy; l.setCursor && l.setCursor(s ? s.cursor : "default"), o && s !== o && this.dispatchToElement(r, "mouseout", t), this.dispatchToElement(a, "mousemove", t), s && s !== o && this.dispatchToElement(a, "mouseover", t) }, e.prototype.mouseout = function (t) { var e = t.zrEventControl; "only_globalout" !== e && this.dispatchToElement(this._hovered, "mouseout", t), "no_globalout" !== e && this.trigger("globalout", { type: "globalout", event: t }) }, e.prototype.resize = function () { this._hovered = new Ge(0, 0) }, e.prototype.dispatch = function (t, e) { var n = this[t]; n && n.call(this, e) }, e.prototype.dispose = function () { this.proxy.dispose(), this.storage = null, this.proxy = null, this.painter = null }, e.prototype.setCursorStyle = function (t) { var e = this.proxy; e.setCursor && e.setCursor(t) }, e.prototype.dispatchToElement = function (t, e, n) { var i = (t = t || {}).target; if (!i || !i.silent) { for (var r = "on" + e, o = function (t, e, n) { return { type: t, event: n, target: e.target, topTarget: e.topTarget, cancelBubble: !1, offsetX: n.zrX, offsetY: n.zrY, gestureEvent: n.gestureEvent, pinchX: n.pinchX, pinchY: n.pinchY, pinchScale: n.pinchScale, wheelDelta: n.zrDelta, zrByTouch: n.zrByTouch, which: n.which, stop: Be } }(e, t, n); i && (i[r] && (o.cancelBubble = !!i[r].call(i, o)), i.trigger(e, o), i = i.__hostTarget ? i.__hostTarget : i.parent, !o.cancelBubble);); o.cancelBubble || (this.trigger(e, o), this.painter && this.painter.eachOtherLayer && this.painter.eachOtherLayer((function (t) { "function" == typeof t[r] && t[r].call(t, o), t.trigger && t.trigger(e, o) }))) } }, e.prototype.findHover = function (t, e, n) { var i = this.storage.getDisplayList(), r = new Ge(t, e); if (Ue(i, r, t, e, n), this._pointerSize && !r.target) { for (var o = [], a = this._pointerSize, s = a / 2, l = new ze(t - s, e - s, a, a), u = i.length - 1; u >= 0; u--) { var h = i[u]; h === n || h.ignore || h.ignoreCoarsePointer || h.parent && h.parent.ignoreCoarsePointer || (He.copy(h.getBoundingRect()), h.transform && He.applyTransform(h.transform), He.intersect(l) && o.push(h)) } if (o.length) for (var c = Math.PI / 12, p = 2 * Math.PI, d = 0; d < s; d += 4)for (var f = 0; f < p; f += c) { if (Ue(o, r, t + d * Math.cos(f), e + d * Math.sin(f), n), r.target) return r } } return r }, e.prototype.processGesture = function (t, e) { this._gestureMgr || (this._gestureMgr = new ge); var n = this._gestureMgr; "start" === e && n.clear(); var i = n.recognize(t, this.findHover(t.zrX, t.zrY, null).target, this.proxy.dom); if ("end" === e && n.clear(), i) { var r = i.type; t.gestureEvent = r; var o = new Ge; o.target = i.target, this.dispatchToElement(o, r, i.event) } }, e }(jt); function Xe(t, e, n) { if (t[t.rectHover ? "rectContain" : "contain"](e, n)) { for (var i = t, r = void 0, o = !1; i;) { if (i.ignoreClip && (o = !0), !o) { var a = i.getClipPath(); if (a && !a.contain(e, n)) return !1; i.silent && (r = !0) } var s = i.__hostTarget; i = s || i.parent } return !r || Ve } return !1 } function Ue(t, e, n, i, r) { for (var o = t.length - 1; o >= 0; o--) { var a = t[o], s = void 0; if (a !== r && !a.ignore && (s = Xe(a, n, i)) && (!e.topTarget && (e.topTarget = a), s !== Ve)) { e.target = a; break } } } function Ze(t, e, n) { var i = t.painter; return e < 0 || e > i.getWidth() || n < 0 || n > i.getHeight() } E(["click", "mousedown", "mouseup", "mousewheel", "dblclick", "contextmenu"], (function (t) { Ye.prototype[t] = function (e) { var n, i, r = e.zrX, o = e.zrY, a = Ze(this, r, o); if ("mouseup" === t && a || (i = (n = this.findHover(r, o)).target), "mousedown" === t) this._downEl = i, this._downPoint = [e.zrX, e.zrY], this._upEl = i; else if ("mouseup" === t) this._upEl = i; else if ("click" === t) { if (this._downEl !== this._upEl || !this._downPoint || Vt(this._downPoint, [e.zrX, e.zrY]) > 4) return; this._downPoint = null } this.dispatchToElement(n, t, e) } })); function je(t, e, n, i) { var r = e + 1; if (r === n) return 1; if (i(t[r++], t[e]) < 0) { for (; r < n && i(t[r], t[r - 1]) < 0;)r++; !function (t, e, n) { n--; for (; e < n;) { var i = t[e]; t[e++] = t[n], t[n--] = i } }(t, e, r) } else for (; r < n && i(t[r], t[r - 1]) >= 0;)r++; return r - e } function qe(t, e, n, i, r) { for (i === e && i++; i < n; i++) { for (var o, a = t[i], s = e, l = i; s < l;)r(a, t[o = s + l >>> 1]) < 0 ? l = o : s = o + 1; var u = i - s; switch (u) { case 3: t[s + 3] = t[s + 2]; case 2: t[s + 2] = t[s + 1]; case 1: t[s + 1] = t[s]; break; default: for (; u > 0;)t[s + u] = t[s + u - 1], u-- }t[s] = a } } function Ke(t, e, n, i, r, o) { var a = 0, s = 0, l = 1; if (o(t, e[n + r]) > 0) { for (s = i - r; l < s && o(t, e[n + r + l]) > 0;)a = l, (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s), a += r, l += r } else { for (s = r + 1; l < s && o(t, e[n + r - l]) <= 0;)a = l, (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s); var u = a; a = r - l, l = r - u } for (a++; a < l;) { var h = a + (l - a >>> 1); o(t, e[n + h]) > 0 ? a = h + 1 : l = h } return l } function $e(t, e, n, i, r, o) { var a = 0, s = 0, l = 1; if (o(t, e[n + r]) < 0) { for (s = r + 1; l < s && o(t, e[n + r - l]) < 0;)a = l, (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s); var u = a; a = r - l, l = r - u } else { for (s = i - r; l < s && o(t, e[n + r + l]) >= 0;)a = l, (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s), a += r, l += r } for (a++; a < l;) { var h = a + (l - a >>> 1); o(t, e[n + h]) < 0 ? l = h : a = h + 1 } return l } function Je(t, e) { var n, i, r = 7, o = 0; t.length; var a = []; function s(s) { var l = n[s], u = i[s], h = n[s + 1], c = i[s + 1]; i[s] = u + c, s === o - 3 && (n[s + 1] = n[s + 2], i[s + 1] = i[s + 2]), o--; var p = $e(t[h], t, l, u, 0, e); l += p, 0 !== (u -= p) && 0 !== (c = Ke(t[l + u - 1], t, h, c, c - 1, e)) && (u <= c ? function (n, i, o, s) { var l = 0; for (l = 0; l < i; l++)a[l] = t[n + l]; var u = 0, h = o, c = n; if (t[c++] = t[h++], 0 == --s) { for (l = 0; l < i; l++)t[c + l] = a[u + l]; return } if (1 === i) { for (l = 0; l < s; l++)t[c + l] = t[h + l]; return void (t[c + s] = a[u]) } var p, d, f, g = r; for (; ;) { p = 0, d = 0, f = !1; do { if (e(t[h], a[u]) < 0) { if (t[c++] = t[h++], d++, p = 0, 0 == --s) { f = !0; break } } else if (t[c++] = a[u++], p++, d = 0, 1 == --i) { f = !0; break } } while ((p | d) < g); if (f) break; do { if (0 !== (p = $e(t[h], a, u, i, 0, e))) { for (l = 0; l < p; l++)t[c + l] = a[u + l]; if (c += p, u += p, (i -= p) <= 1) { f = !0; break } } if (t[c++] = t[h++], 0 == --s) { f = !0; break } if (0 !== (d = Ke(a[u], t, h, s, 0, e))) { for (l = 0; l < d; l++)t[c + l] = t[h + l]; if (c += d, h += d, 0 === (s -= d)) { f = !0; break } } if (t[c++] = a[u++], 1 == --i) { f = !0; break } g-- } while (p >= 7 || d >= 7); if (f) break; g < 0 && (g = 0), g += 2 } if ((r = g) < 1 && (r = 1), 1 === i) { for (l = 0; l < s; l++)t[c + l] = t[h + l]; t[c + s] = a[u] } else { if (0 === i) throw new Error; for (l = 0; l < i; l++)t[c + l] = a[u + l] } }(l, u, h, c) : function (n, i, o, s) { var l = 0; for (l = 0; l < s; l++)a[l] = t[o + l]; var u = n + i - 1, h = s - 1, c = o + s - 1, p = 0, d = 0; if (t[c--] = t[u--], 0 == --i) { for (p = c - (s - 1), l = 0; l < s; l++)t[p + l] = a[l]; return } if (1 === s) { for (d = (c -= i) + 1, p = (u -= i) + 1, l = i - 1; l >= 0; l--)t[d + l] = t[p + l]; return void (t[c] = a[h]) } var f = r; for (; ;) { var g = 0, y = 0, v = !1; do { if (e(a[h], t[u]) < 0) { if (t[c--] = t[u--], g++, y = 0, 0 == --i) { v = !0; break } } else if (t[c--] = a[h--], y++, g = 0, 1 == --s) { v = !0; break } } while ((g | y) < f); if (v) break; do { if (0 !== (g = i - $e(a[h], t, n, i, i - 1, e))) { for (i -= g, d = (c -= g) + 1, p = (u -= g) + 1, l = g - 1; l >= 0; l--)t[d + l] = t[p + l]; if (0 === i) { v = !0; break } } if (t[c--] = a[h--], 1 == --s) { v = !0; break } if (0 !== (y = s - Ke(t[u], a, 0, s, s - 1, e))) { for (s -= y, d = (c -= y) + 1, p = (h -= y) + 1, l = 0; l < y; l++)t[d + l] = a[p + l]; if (s <= 1) { v = !0; break } } if (t[c--] = t[u--], 0 == --i) { v = !0; break } f-- } while (g >= 7 || y >= 7); if (v) break; f < 0 && (f = 0), f += 2 } (r = f) < 1 && (r = 1); if (1 === s) { for (d = (c -= i) + 1, p = (u -= i) + 1, l = i - 1; l >= 0; l--)t[d + l] = t[p + l]; t[c] = a[h] } else { if (0 === s) throw new Error; for (p = c - (s - 1), l = 0; l < s; l++)t[p + l] = a[l] } }(l, u, h, c)) } return n = [], i = [], { mergeRuns: function () { for (; o > 1;) { var t = o - 2; if (t >= 1 && i[t - 1] <= i[t] + i[t + 1] || t >= 2 && i[t - 2] <= i[t] + i[t - 1]) i[t - 1] < i[t + 1] && t--; else if (i[t] > i[t + 1]) break; s(t) } }, forceMergeRuns: function () { for (; o > 1;) { var t = o - 2; t > 0 && i[t - 1] < i[t + 1] && t--, s(t) } }, pushRun: function (t, e) { n[o] = t, i[o] = e, o += 1 } } } function Qe(t, e, n, i) { n || (n = 0), i || (i = t.length); var r = i - n; if (!(r < 2)) { var o = 0; if (r < 32) qe(t, n, i, n + (o = je(t, n, i, e)), e); else { var a = Je(t, e), s = function (t) { for (var e = 0; t >= 32;)e |= 1 & t, t >>= 1; return t + e }(r); do { if ((o = je(t, n, i, e)) < s) { var l = r; l > s && (l = s), qe(t, n, n + l, n + o, e), o = l } a.pushRun(n, o), a.mergeRuns(), r -= o, n += o } while (0 !== r); a.forceMergeRuns() } } } var tn = !1; function en() { tn || (tn = !0, console.warn("z / z2 / zlevel of displayable is invalid, which may cause unexpected errors")) } function nn(t, e) { return t.zlevel === e.zlevel ? t.z === e.z ? t.z2 - e.z2 : t.z - e.z : t.zlevel - e.zlevel } var rn = function () { function t() { this._roots = [], this._displayList = [], this._displayListLen = 0, this.displayableSortFunc = nn } return t.prototype.traverse = function (t, e) { for (var n = 0; n < this._roots.length; n++)this._roots[n].traverse(t, e) }, t.prototype.getDisplayList = function (t, e) { e = e || !1; var n = this._displayList; return !t && n.length || this.updateDisplayList(e), n }, t.prototype.updateDisplayList = function (t) { this._displayListLen = 0; for (var e = this._roots, n = this._displayList, i = 0, r = e.length; i < r; i++)this._updateAndAddDisplayable(e[i], null, t); n.length = this._displayListLen, Qe(n, nn) }, t.prototype._updateAndAddDisplayable = function (t, e, n) { if (!t.ignore || n) { t.beforeUpdate(), t.update(), t.afterUpdate(); var i = t.getClipPath(); if (t.ignoreClip) e = null; else if (i) { e = e ? e.slice() : []; for (var r = i, o = t; r;)r.parent = o, r.updateTransform(), e.push(r), o = r, r = r.getClipPath() } if (t.childrenRef) { for (var a = t.childrenRef(), s = 0; s < a.length; s++) { var l = a[s]; t.__dirty && (l.__dirty |= 1), this._updateAndAddDisplayable(l, e, n) } t.__dirty = 0 } else { var u = t; e && e.length ? u.__clipPaths = e : u.__clipPaths && u.__clipPaths.length > 0 && (u.__clipPaths = []), isNaN(u.z) && (en(), u.z = 0), isNaN(u.z2) && (en(), u.z2 = 0), isNaN(u.zlevel) && (en(), u.zlevel = 0), this._displayList[this._displayListLen++] = u } var h = t.getDecalElement && t.getDecalElement(); h && this._updateAndAddDisplayable(h, e, n); var c = t.getTextGuideLine(); c && this._updateAndAddDisplayable(c, e, n); var p = t.getTextContent(); p && this._updateAndAddDisplayable(p, e, n) } }, t.prototype.addRoot = function (t) { t.__zr && t.__zr.storage === this || this._roots.push(t) }, t.prototype.delRoot = function (t) { if (t instanceof Array) for (var e = 0, n = t.length; e < n; e++)this.delRoot(t[e]); else { var i = P(this._roots, t); i >= 0 && this._roots.splice(i, 1) } }, t.prototype.delAllRoots = function () { this._roots = [], this._displayList = [], this._displayListLen = 0 }, t.prototype.getRoots = function () { return this._roots }, t.prototype.dispose = function () { this._displayList = null, this._roots = null }, t }(), on = r.hasGlobalWindow && (window.requestAnimationFrame && window.requestAnimationFrame.bind(window) || window.msRequestAnimationFrame && window.msRequestAnimationFrame.bind(window) || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame) || function (t) { return setTimeout(t, 16) }, an = { linear: function (t) { return t }, quadraticIn: function (t) { return t * t }, quadraticOut: function (t) { return t * (2 - t) }, quadraticInOut: function (t) { return (t *= 2) < 1 ? .5 * t * t : -.5 * (--t * (t - 2) - 1) }, cubicIn: function (t) { return t * t * t }, cubicOut: function (t) { return --t * t * t + 1 }, cubicInOut: function (t) { return (t *= 2) < 1 ? .5 * t * t * t : .5 * ((t -= 2) * t * t + 2) }, quarticIn: function (t) { return t * t * t * t }, quarticOut: function (t) { return 1 - --t * t * t * t }, quarticInOut: function (t) { return (t *= 2) < 1 ? .5 * t * t * t * t : -.5 * ((t -= 2) * t * t * t - 2) }, quinticIn: function (t) { return t * t * t * t * t }, quinticOut: function (t) { return --t * t * t * t * t + 1 }, quinticInOut: function (t) { return (t *= 2) < 1 ? .5 * t * t * t * t * t : .5 * ((t -= 2) * t * t * t * t + 2) }, sinusoidalIn: function (t) { return 1 - Math.cos(t * Math.PI / 2) }, sinusoidalOut: function (t) { return Math.sin(t * Math.PI / 2) }, sinusoidalInOut: function (t) { return .5 * (1 - Math.cos(Math.PI * t)) }, exponentialIn: function (t) { return 0 === t ? 0 : Math.pow(1024, t - 1) }, exponentialOut: function (t) { return 1 === t ? 1 : 1 - Math.pow(2, -10 * t) }, exponentialInOut: function (t) { return 0 === t ? 0 : 1 === t ? 1 : (t *= 2) < 1 ? .5 * Math.pow(1024, t - 1) : .5 * (2 - Math.pow(2, -10 * (t - 1))) }, circularIn: function (t) { return 1 - Math.sqrt(1 - t * t) }, circularOut: function (t) { return Math.sqrt(1 - --t * t) }, circularInOut: function (t) { return (t *= 2) < 1 ? -.5 * (Math.sqrt(1 - t * t) - 1) : .5 * (Math.sqrt(1 - (t -= 2) * t) + 1) }, elasticIn: function (t) { var e, n = .1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? (n = 1, e = .1) : e = .4 * Math.asin(1 / n) / (2 * Math.PI), -n * Math.pow(2, 10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / .4)) }, elasticOut: function (t) { var e, n = .1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? (n = 1, e = .1) : e = .4 * Math.asin(1 / n) / (2 * Math.PI), n * Math.pow(2, -10 * t) * Math.sin((t - e) * (2 * Math.PI) / .4) + 1) }, elasticInOut: function (t) { var e, n = .1, i = .4; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? (n = 1, e = .1) : e = i * Math.asin(1 / n) / (2 * Math.PI), (t *= 2) < 1 ? n * Math.pow(2, 10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / i) * -.5 : n * Math.pow(2, -10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / i) * .5 + 1) }, backIn: function (t) { var e = 1.70158; return t * t * ((e + 1) * t - e) }, backOut: function (t) { var e = 1.70158; return --t * t * ((e + 1) * t + e) + 1 }, backInOut: function (t) { var e = 2.5949095; return (t *= 2) < 1 ? t * t * ((e + 1) * t - e) * .5 : .5 * ((t -= 2) * t * ((e + 1) * t + e) + 2) }, bounceIn: function (t) { return 1 - an.bounceOut(1 - t) }, bounceOut: function (t) { return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + .75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + .9375 : 7.5625 * (t -= 2.625 / 2.75) * t + .984375 }, bounceInOut: function (t) { return t < .5 ? .5 * an.bounceIn(2 * t) : .5 * an.bounceOut(2 * t - 1) + .5 } }, sn = Math.pow, ln = Math.sqrt, un = 1e-8, hn = 1e-4, cn = ln(3), pn = 1 / 3, dn = Mt(), fn = Mt(), gn = Mt(); function yn(t) { return t > -1e-8 && t < un } function vn(t) { return t > un || t < -1e-8 } function mn(t, e, n, i, r) { var o = 1 - r; return o * o * (o * t + 3 * r * e) + r * r * (r * i + 3 * o * n) } function xn(t, e, n, i, r) { var o = 1 - r; return 3 * (((e - t) * o + 2 * (n - e) * r) * o + (i - n) * r * r) } function _n(t, e, n, i, r, o) { var a = i + 3 * (e - n) - t, s = 3 * (n - 2 * e + t), l = 3 * (e - t), u = t - r, h = s * s - 3 * a * l, c = s * l - 9 * a * u, p = l * l - 3 * s * u, d = 0; if (yn(h) && yn(c)) { if (yn(s)) o[0] = 0; else (M = -l / s) >= 0 && M <= 1 && (o[d++] = M) } else { var f = c * c - 4 * h * p; if (yn(f)) { var g = c / h, y = -g / 2; (M = -s / a + g) >= 0 && M <= 1 && (o[d++] = M), y >= 0 && y <= 1 && (o[d++] = y) } else if (f > 0) { var v = ln(f), m = h * s + 1.5 * a * (-c + v), x = h * s + 1.5 * a * (-c - v); (M = (-s - ((m = m < 0 ? -sn(-m, pn) : sn(m, pn)) + (x = x < 0 ? -sn(-x, pn) : sn(x, pn)))) / (3 * a)) >= 0 && M <= 1 && (o[d++] = M) } else { var _ = (2 * h * s - 3 * a * c) / (2 * ln(h * h * h)), b = Math.acos(_) / 3, w = ln(h), S = Math.cos(b), M = (-s - 2 * w * S) / (3 * a), I = (y = (-s + w * (S + cn * Math.sin(b))) / (3 * a), (-s + w * (S - cn * Math.sin(b))) / (3 * a)); M >= 0 && M <= 1 && (o[d++] = M), y >= 0 && y <= 1 && (o[d++] = y), I >= 0 && I <= 1 && (o[d++] = I) } } return d } function bn(t, e, n, i, r) { var o = 6 * n - 12 * e + 6 * t, a = 9 * e + 3 * i - 3 * t - 9 * n, s = 3 * e - 3 * t, l = 0; if (yn(a)) { if (vn(o)) (h = -s / o) >= 0 && h <= 1 && (r[l++] = h) } else { var u = o * o - 4 * a * s; if (yn(u)) r[0] = -o / (2 * a); else if (u > 0) { var h, c = ln(u), p = (-o - c) / (2 * a); (h = (-o + c) / (2 * a)) >= 0 && h <= 1 && (r[l++] = h), p >= 0 && p <= 1 && (r[l++] = p) } } return l } function wn(t, e, n, i, r, o) { var a = (e - t) * r + t, s = (n - e) * r + e, l = (i - n) * r + n, u = (s - a) * r + a, h = (l - s) * r + s, c = (h - u) * r + u; o[0] = t, o[1] = a, o[2] = u, o[3] = c, o[4] = c, o[5] = h, o[6] = l, o[7] = i } function Sn(t, e, n, i, r, o, a, s, l, u, h) { var c, p, d, f, g, y = .005, v = 1 / 0; dn[0] = l, dn[1] = u; for (var m = 0; m < 1; m += .05)fn[0] = mn(t, n, r, a, m), fn[1] = mn(e, i, o, s, m), (f = Ft(dn, fn)) < v && (c = m, v = f); v = 1 / 0; for (var x = 0; x < 32 && !(y < hn); x++)p = c - y, d = c + y, fn[0] = mn(t, n, r, a, p), fn[1] = mn(e, i, o, s, p), f = Ft(fn, dn), p >= 0 && f < v ? (c = p, v = f) : (gn[0] = mn(t, n, r, a, d), gn[1] = mn(e, i, o, s, d), g = Ft(gn, dn), d <= 1 && g < v ? (c = d, v = g) : y *= .5); return h && (h[0] = mn(t, n, r, a, c), h[1] = mn(e, i, o, s, c)), ln(v) } function Mn(t, e, n, i, r, o, a, s, l) { for (var u = t, h = e, c = 0, p = 1 / l, d = 1; d <= l; d++) { var f = d * p, g = mn(t, n, r, a, f), y = mn(e, i, o, s, f), v = g - u, m = y - h; c += Math.sqrt(v * v + m * m), u = g, h = y } return c } function In(t, e, n, i) { var r = 1 - i; return r * (r * t + 2 * i * e) + i * i * n } function Tn(t, e, n, i) { return 2 * ((1 - i) * (e - t) + i * (n - e)) } function Cn(t, e, n) { var i = t + n - 2 * e; return 0 === i ? .5 : (t - e) / i } function Dn(t, e, n, i, r) { var o = (e - t) * i + t, a = (n - e) * i + e, s = (a - o) * i + o; r[0] = t, r[1] = o, r[2] = s, r[3] = s, r[4] = a, r[5] = n } function An(t, e, n, i, r, o, a, s, l) { var u, h = .005, c = 1 / 0; dn[0] = a, dn[1] = s; for (var p = 0; p < 1; p += .05) { fn[0] = In(t, n, r, p), fn[1] = In(e, i, o, p), (y = Ft(dn, fn)) < c && (u = p, c = y) } c = 1 / 0; for (var d = 0; d < 32 && !(h < hn); d++) { var f = u - h, g = u + h; fn[0] = In(t, n, r, f), fn[1] = In(e, i, o, f); var y = Ft(fn, dn); if (f >= 0 && y < c) u = f, c = y; else { gn[0] = In(t, n, r, g), gn[1] = In(e, i, o, g); var v = Ft(gn, dn); g <= 1 && v < c ? (u = g, c = v) : h *= .5 } } return l && (l[0] = In(t, n, r, u), l[1] = In(e, i, o, u)), ln(c) } function kn(t, e, n, i, r, o, a) { for (var s = t, l = e, u = 0, h = 1 / a, c = 1; c <= a; c++) { var p = c * h, d = In(t, n, r, p), f = In(e, i, o, p), g = d - s, y = f - l; u += Math.sqrt(g * g + y * y), s = d, l = f } return u } var Ln = /cubic-bezier\(([0-9,\.e ]+)\)/; function Pn(t) { var e = t && Ln.exec(t); if (e) { var n = e[1].split(","), i = +ut(n[0]), r = +ut(n[1]), o = +ut(n[2]), a = +ut(n[3]); if (isNaN(i + r + o + a)) return; var s = []; return function (t) { return t <= 0 ? 0 : t >= 1 ? 1 : _n(0, i, o, 1, t, s) && mn(0, r, a, 1, s[0]) } } } var On = function () { function t(t) { this._inited = !1, this._startTime = 0, this._pausedTime = 0, this._paused = !1, this._life = t.life || 1e3, this._delay = t.delay || 0, this.loop = t.loop || !1, this.onframe = t.onframe || bt, this.ondestroy = t.ondestroy || bt, this.onrestart = t.onrestart || bt, t.easing && this.setEasing(t.easing) } return t.prototype.step = function (t, e) { if (this._inited || (this._startTime = t + this._delay, this._inited = !0), !this._paused) { var n = this._life, i = t - this._startTime - this._pausedTime, r = i / n; r < 0 && (r = 0), r = Math.min(r, 1); var o = this.easingFunc, a = o ? o(r) : r; if (this.onframe(a), 1 === r) { if (!this.loop) return !0; var s = i % n; this._startTime = t - s, this._pausedTime = 0, this.onrestart() } return !1 } this._pausedTime += e }, t.prototype.pause = function () { this._paused = !0 }, t.prototype.resume = function () { this._paused = !1 }, t.prototype.setEasing = function (t) { this.easing = t, this.easingFunc = X(t) ? t : an[t] || Pn(t) }, t }(), Rn = function (t) { this.value = t }, Nn = function () { function t() { this._len = 0 } return t.prototype.insert = function (t) { var e = new Rn(t); return this.insertEntry(e), e }, t.prototype.insertEntry = function (t) { this.head ? (this.tail.next = t, t.prev = this.tail, t.next = null, this.tail = t) : this.head = this.tail = t, this._len++ }, t.prototype.remove = function (t) { var e = t.prev, n = t.next; e ? e.next = n : this.head = n, n ? n.prev = e : this.tail = e, t.next = t.prev = null, this._len-- }, t.prototype.len = function () { return this._len }, t.prototype.clear = function () { this.head = this.tail = null, this._len = 0 }, t }(), En = function () { function t(t) { this._list = new Nn, this._maxSize = 10, this._map = {}, this._maxSize = t } return t.prototype.put = function (t, e) { var n = this._list, i = this._map, r = null; if (null == i[t]) { var o = n.len(), a = this._lastRemovedEntry; if (o >= this._maxSize && o > 0) { var s = n.head; n.remove(s), delete i[s.key], r = s.value, this._lastRemovedEntry = s } a ? a.value = e : a = new Rn(e), a.key = t, n.insertEntry(a), i[t] = a } return r }, t.prototype.get = function (t) { var e = this._map[t], n = this._list; if (null != e) return e !== n.tail && (n.remove(e), n.insertEntry(e)), e.value }, t.prototype.clear = function () { this._list.clear(), this._map = {} }, t.prototype.len = function () { return this._list.len() }, t }(), zn = { transparent: [0, 0, 0, 0], aliceblue: [240, 248, 255, 1], antiquewhite: [250, 235, 215, 1], aqua: [0, 255, 255, 1], aquamarine: [127, 255, 212, 1], azure: [240, 255, 255, 1], beige: [245, 245, 220, 1], bisque: [255, 228, 196, 1], black: [0, 0, 0, 1], blanchedalmond: [255, 235, 205, 1], blue: [0, 0, 255, 1], blueviolet: [138, 43, 226, 1], brown: [165, 42, 42, 1], burlywood: [222, 184, 135, 1], cadetblue: [95, 158, 160, 1], chartreuse: [127, 255, 0, 1], chocolate: [210, 105, 30, 1], coral: [255, 127, 80, 1], cornflowerblue: [100, 149, 237, 1], cornsilk: [255, 248, 220, 1], crimson: [220, 20, 60, 1], cyan: [0, 255, 255, 1], darkblue: [0, 0, 139, 1], darkcyan: [0, 139, 139, 1], darkgoldenrod: [184, 134, 11, 1], darkgray: [169, 169, 169, 1], darkgreen: [0, 100, 0, 1], darkgrey: [169, 169, 169, 1], darkkhaki: [189, 183, 107, 1], darkmagenta: [139, 0, 139, 1], darkolivegreen: [85, 107, 47, 1], darkorange: [255, 140, 0, 1], darkorchid: [153, 50, 204, 1], darkred: [139, 0, 0, 1], darksalmon: [233, 150, 122, 1], darkseagreen: [143, 188, 143, 1], darkslateblue: [72, 61, 139, 1], darkslategray: [47, 79, 79, 1], darkslategrey: [47, 79, 79, 1], darkturquoise: [0, 206, 209, 1], darkviolet: [148, 0, 211, 1], deeppink: [255, 20, 147, 1], deepskyblue: [0, 191, 255, 1], dimgray: [105, 105, 105, 1], dimgrey: [105, 105, 105, 1], dodgerblue: [30, 144, 255, 1], firebrick: [178, 34, 34, 1], floralwhite: [255, 250, 240, 1], forestgreen: [34, 139, 34, 1], fuchsia: [255, 0, 255, 1], gainsboro: [220, 220, 220, 1], ghostwhite: [248, 248, 255, 1], gold: [255, 215, 0, 1], goldenrod: [218, 165, 32, 1], gray: [128, 128, 128, 1], green: [0, 128, 0, 1], greenyellow: [173, 255, 47, 1], grey: [128, 128, 128, 1], honeydew: [240, 255, 240, 1], hotpink: [255, 105, 180, 1], indianred: [205, 92, 92, 1], indigo: [75, 0, 130, 1], ivory: [255, 255, 240, 1], khaki: [240, 230, 140, 1], lavender: [230, 230, 250, 1], lavenderblush: [255, 240, 245, 1], lawngreen: [124, 252, 0, 1], lemonchiffon: [255, 250, 205, 1], lightblue: [173, 216, 230, 1], lightcoral: [240, 128, 128, 1], lightcyan: [224, 255, 255, 1], lightgoldenrodyellow: [250, 250, 210, 1], lightgray: [211, 211, 211, 1], lightgreen: [144, 238, 144, 1], lightgrey: [211, 211, 211, 1], lightpink: [255, 182, 193, 1], lightsalmon: [255, 160, 122, 1], lightseagreen: [32, 178, 170, 1], lightskyblue: [135, 206, 250, 1], lightslategray: [119, 136, 153, 1], lightslategrey: [119, 136, 153, 1], lightsteelblue: [176, 196, 222, 1], lightyellow: [255, 255, 224, 1], lime: [0, 255, 0, 1], limegreen: [50, 205, 50, 1], linen: [250, 240, 230, 1], magenta: [255, 0, 255, 1], maroon: [128, 0, 0, 1], mediumaquamarine: [102, 205, 170, 1], mediumblue: [0, 0, 205, 1], mediumorchid: [186, 85, 211, 1], mediumpurple: [147, 112, 219, 1], mediumseagreen: [60, 179, 113, 1], mediumslateblue: [123, 104, 238, 1], mediumspringgreen: [0, 250, 154, 1], mediumturquoise: [72, 209, 204, 1], mediumvioletred: [199, 21, 133, 1], midnightblue: [25, 25, 112, 1], mintcream: [245, 255, 250, 1], mistyrose: [255, 228, 225, 1], moccasin: [255, 228, 181, 1], navajowhite: [255, 222, 173, 1], navy: [0, 0, 128, 1], oldlace: [253, 245, 230, 1], olive: [128, 128, 0, 1], olivedrab: [107, 142, 35, 1], orange: [255, 165, 0, 1], orangered: [255, 69, 0, 1], orchid: [218, 112, 214, 1], palegoldenrod: [238, 232, 170, 1], palegreen: [152, 251, 152, 1], paleturquoise: [175, 238, 238, 1], palevioletred: [219, 112, 147, 1], papayawhip: [255, 239, 213, 1], peachpuff: [255, 218, 185, 1], peru: [205, 133, 63, 1], pink: [255, 192, 203, 1], plum: [221, 160, 221, 1], powderblue: [176, 224, 230, 1], purple: [128, 0, 128, 1], red: [255, 0, 0, 1], rosybrown: [188, 143, 143, 1], royalblue: [65, 105, 225, 1], saddlebrown: [139, 69, 19, 1], salmon: [250, 128, 114, 1], sandybrown: [244, 164, 96, 1], seagreen: [46, 139, 87, 1], seashell: [255, 245, 238, 1], sienna: [160, 82, 45, 1], silver: [192, 192, 192, 1], skyblue: [135, 206, 235, 1], slateblue: [106, 90, 205, 1], slategray: [112, 128, 144, 1], slategrey: [112, 128, 144, 1], snow: [255, 250, 250, 1], springgreen: [0, 255, 127, 1], steelblue: [70, 130, 180, 1], tan: [210, 180, 140, 1], teal: [0, 128, 128, 1], thistle: [216, 191, 216, 1], tomato: [255, 99, 71, 1], turquoise: [64, 224, 208, 1], violet: [238, 130, 238, 1], wheat: [245, 222, 179, 1], white: [255, 255, 255, 1], whitesmoke: [245, 245, 245, 1], yellow: [255, 255, 0, 1], yellowgreen: [154, 205, 50, 1] }; function Vn(t) { return (t = Math.round(t)) < 0 ? 0 : t > 255 ? 255 : t } function Bn(t) { return t < 0 ? 0 : t > 1 ? 1 : t } function Fn(t) { var e = t; return e.length && "%" === e.charAt(e.length - 1) ? Vn(parseFloat(e) / 100 * 255) : Vn(parseInt(e, 10)) } function Gn(t) { var e = t; return e.length && "%" === e.charAt(e.length - 1) ? Bn(parseFloat(e) / 100) : Bn(parseFloat(e)) } function Wn(t, e, n) { return n < 0 ? n += 1 : n > 1 && (n -= 1), 6 * n < 1 ? t + (e - t) * n * 6 : 2 * n < 1 ? e : 3 * n < 2 ? t + (e - t) * (2 / 3 - n) * 6 : t } function Hn(t, e, n) { return t + (e - t) * n } function Yn(t, e, n, i, r) { return t[0] = e, t[1] = n, t[2] = i, t[3] = r, t } function Xn(t, e) { return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t } var Un = new En(20), Zn = null; function jn(t, e) { Zn && Xn(Zn, e), Zn = Un.put(t, Zn || e.slice()) } function qn(t, e) { if (t) { e = e || []; var n = Un.get(t); if (n) return Xn(e, n); var i = (t += "").replace(/ /g, "").toLowerCase(); if (i in zn) return Xn(e, zn[i]), jn(t, e), e; var r, o = i.length; if ("#" === i.charAt(0)) return 4 === o || 5 === o ? (r = parseInt(i.slice(1, 4), 16)) >= 0 && r <= 4095 ? (Yn(e, (3840 & r) >> 4 | (3840 & r) >> 8, 240 & r | (240 & r) >> 4, 15 & r | (15 & r) << 4, 5 === o ? parseInt(i.slice(4), 16) / 15 : 1), jn(t, e), e) : void Yn(e, 0, 0, 0, 1) : 7 === o || 9 === o ? (r = parseInt(i.slice(1, 7), 16)) >= 0 && r <= 16777215 ? (Yn(e, (16711680 & r) >> 16, (65280 & r) >> 8, 255 & r, 9 === o ? parseInt(i.slice(7), 16) / 255 : 1), jn(t, e), e) : void Yn(e, 0, 0, 0, 1) : void 0; var a = i.indexOf("("), s = i.indexOf(")"); if (-1 !== a && s + 1 === o) { var l = i.substr(0, a), u = i.substr(a + 1, s - (a + 1)).split(","), h = 1; switch (l) { case "rgba": if (4 !== u.length) return 3 === u.length ? Yn(e, +u[0], +u[1], +u[2], 1) : Yn(e, 0, 0, 0, 1); h = Gn(u.pop()); case "rgb": return u.length >= 3 ? (Yn(e, Fn(u[0]), Fn(u[1]), Fn(u[2]), 3 === u.length ? h : Gn(u[3])), jn(t, e), e) : void Yn(e, 0, 0, 0, 1); case "hsla": return 4 !== u.length ? void Yn(e, 0, 0, 0, 1) : (u[3] = Gn(u[3]), Kn(u, e), jn(t, e), e); case "hsl": return 3 !== u.length ? void Yn(e, 0, 0, 0, 1) : (Kn(u, e), jn(t, e), e); default: return } } Yn(e, 0, 0, 0, 1) } } function Kn(t, e) { var n = (parseFloat(t[0]) % 360 + 360) % 360 / 360, i = Gn(t[1]), r = Gn(t[2]), o = r <= .5 ? r * (i + 1) : r + i - r * i, a = 2 * r - o; return Yn(e = e || [], Vn(255 * Wn(a, o, n + 1 / 3)), Vn(255 * Wn(a, o, n)), Vn(255 * Wn(a, o, n - 1 / 3)), 1), 4 === t.length && (e[3] = t[3]), e } function $n(t, e) { var n = qn(t); if (n) { for (var i = 0; i < 3; i++)n[i] = e < 0 ? n[i] * (1 - e) | 0 : (255 - n[i]) * e + n[i] | 0, n[i] > 255 ? n[i] = 255 : n[i] < 0 && (n[i] = 0); return ri(n, 4 === n.length ? "rgba" : "rgb") } } function Jn(t, e, n) { if (e && e.length && t >= 0 && t <= 1) { n = n || []; var i = t * (e.length - 1), r = Math.floor(i), o = Math.ceil(i), a = e[r], s = e[o], l = i - r; return n[0] = Vn(Hn(a[0], s[0], l)), n[1] = Vn(Hn(a[1], s[1], l)), n[2] = Vn(Hn(a[2], s[2], l)), n[3] = Bn(Hn(a[3], s[3], l)), n } } var Qn = Jn; function ti(t, e, n) { if (e && e.length && t >= 0 && t <= 1) { var i = t * (e.length - 1), r = Math.floor(i), o = Math.ceil(i), a = qn(e[r]), s = qn(e[o]), l = i - r, u = ri([Vn(Hn(a[0], s[0], l)), Vn(Hn(a[1], s[1], l)), Vn(Hn(a[2], s[2], l)), Bn(Hn(a[3], s[3], l))], "rgba"); return n ? { color: u, leftIndex: r, rightIndex: o, value: i } : u } } var ei = ti; function ni(t, e, n, i) { var r = qn(t); if (t) return r = function (t) { if (t) { var e, n, i = t[0] / 255, r = t[1] / 255, o = t[2] / 255, a = Math.min(i, r, o), s = Math.max(i, r, o), l = s - a, u = (s + a) / 2; if (0 === l) e = 0, n = 0; else { n = u < .5 ? l / (s + a) : l / (2 - s - a); var h = ((s - i) / 6 + l / 2) / l, c = ((s - r) / 6 + l / 2) / l, p = ((s - o) / 6 + l / 2) / l; i === s ? e = p - c : r === s ? e = 1 / 3 + h - p : o === s && (e = 2 / 3 + c - h), e < 0 && (e += 1), e > 1 && (e -= 1) } var d = [360 * e, n, u]; return null != t[3] && d.push(t[3]), d } }(r), null != e && (r[0] = function (t) { return (t = Math.round(t)) < 0 ? 0 : t > 360 ? 360 : t }(e)), null != n && (r[1] = Gn(n)), null != i && (r[2] = Gn(i)), ri(Kn(r), "rgba") } function ii(t, e) { var n = qn(t); if (n && null != e) return n[3] = Bn(e), ri(n, "rgba") } function ri(t, e) { if (t && t.length) { var n = t[0] + "," + t[1] + "," + t[2]; return "rgba" !== e && "hsva" !== e && "hsla" !== e || (n += "," + t[3]), e + "(" + n + ")" } } function oi(t, e) { var n = qn(t); return n ? (.299 * n[0] + .587 * n[1] + .114 * n[2]) * n[3] / 255 + (1 - n[3]) * e : 0 } var ai = Object.freeze({ __proto__: null, parse: qn, lift: $n, toHex: function (t) { var e = qn(t); if (e) return ((1 << 24) + (e[0] << 16) + (e[1] << 8) + +e[2]).toString(16).slice(1) }, fastLerp: Jn, fastMapToColor: Qn, lerp: ti, mapToColor: ei, modifyHSL: ni, modifyAlpha: ii, stringify: ri, lum: oi, random: function () { return ri([Math.round(255 * Math.random()), Math.round(255 * Math.random()), Math.round(255 * Math.random())], "rgb") } }), si = Math.round; function li(t) { var e; if (t && "transparent" !== t) { if ("string" == typeof t && t.indexOf("rgba") > -1) { var n = qn(t); n && (t = "rgb(" + n[0] + "," + n[1] + "," + n[2] + ")", e = n[3]) } } else t = "none"; return { color: t, opacity: null == e ? 1 : e } } var ui = 1e-4; function hi(t) { return t < ui && t > -1e-4 } function ci(t) { return si(1e3 * t) / 1e3 } function pi(t) { return si(1e4 * t) / 1e4 } var di = { left: "start", right: "end", center: "middle", middle: "middle" }; function fi(t) { return t && !!t.image } function gi(t) { return fi(t) || function (t) { return t && !!t.svgElement }(t) } function yi(t) { return "linear" === t.type } function vi(t) { return "radial" === t.type } function mi(t) { return t && ("linear" === t.type || "radial" === t.type) } function xi(t) { return "url(#" + t + ")" } function _i(t) { var e = t.getGlobalScale(), n = Math.max(e[0], e[1]); return Math.max(Math.ceil(Math.log(n) / Math.log(10)), 1) } function bi(t) { var e = t.x || 0, n = t.y || 0, i = (t.rotation || 0) * wt, r = rt(t.scaleX, 1), o = rt(t.scaleY, 1), a = t.skewX || 0, s = t.skewY || 0, l = []; return (e || n) && l.push("translate(" + e + "px," + n + "px)"), i && l.push("rotate(" + i + ")"), 1 === r && 1 === o || l.push("scale(" + r + "," + o + ")"), (a || s) && l.push("skew(" + si(a * wt) + "deg, " + si(s * wt) + "deg)"), l.join(" ") } var wi = r.hasGlobalWindow && X(window.btoa) ? function (t) { return window.btoa(unescape(encodeURIComponent(t))) } : "undefined" != typeof Buffer ? function (t) { return Buffer.from(t).toString("base64") } : function (t) { return null }, Si = Array.prototype.slice; function Mi(t, e, n) { return (e - t) * n + t } function Ii(t, e, n, i) { for (var r = e.length, o = 0; o < r; o++)t[o] = Mi(e[o], n[o], i); return t } function Ti(t, e, n, i) { for (var r = e.length, o = 0; o < r; o++)t[o] = e[o] + n[o] * i; return t } function Ci(t, e, n, i) { for (var r = e.length, o = r && e[0].length, a = 0; a < r; a++) { t[a] || (t[a] = []); for (var s = 0; s < o; s++)t[a][s] = e[a][s] + n[a][s] * i } return t } function Di(t, e) { for (var n = t.length, i = e.length, r = n > i ? e : t, o = Math.min(n, i), a = r[o - 1] || { color: [0, 0, 0, 0], offset: 0 }, s = o; s < Math.max(n, i); s++)r.push({ offset: a.offset, color: a.color.slice() }) } function Ai(t, e, n) { var i = t, r = e; if (i.push && r.push) { var o = i.length, a = r.length; if (o !== a) if (o > a) i.length = a; else for (var s = o; s < a; s++)i.push(1 === n ? r[s] : Si.call(r[s])); var l = i[0] && i[0].length; for (s = 0; s < i.length; s++)if (1 === n) isNaN(i[s]) && (i[s] = r[s]); else for (var u = 0; u < l; u++)isNaN(i[s][u]) && (i[s][u] = r[s][u]) } } function ki(t) { if (N(t)) { var e = t.length; if (N(t[0])) { for (var n = [], i = 0; i < e; i++)n.push(Si.call(t[i])); return n } return Si.call(t) } return t } function Li(t) { return t[0] = Math.floor(t[0]) || 0, t[1] = Math.floor(t[1]) || 0, t[2] = Math.floor(t[2]) || 0, t[3] = null == t[3] ? 1 : t[3], "rgba(" + t.join(",") + ")" } function Pi(t) { return 4 === t || 5 === t } function Oi(t) { return 1 === t || 2 === t } var Ri = [0, 0, 0, 0], Ni = function () { function t(t) { this.keyframes = [], this.discrete = !1, this._invalid = !1, this._needsSort = !1, this._lastFr = 0, this._lastFrP = 0, this.propName = t } return t.prototype.isFinished = function () { return this._finished }, t.prototype.setFinished = function () { this._finished = !0, this._additiveTrack && this._additiveTrack.setFinished() }, t.prototype.needsAnimate = function () { return this.keyframes.length >= 1 }, t.prototype.getAdditiveTrack = function () { return this._additiveTrack }, t.prototype.addKeyframe = function (t, e, n) { this._needsSort = !0; var i = this.keyframes, r = i.length, o = !1, a = 6, s = e; if (N(e)) { var l = function (t) { return N(t && t[0]) ? 2 : 1 }(e); a = l, (1 === l && !j(e[0]) || 2 === l && !j(e[0][0])) && (o = !0) } else if (j(e) && !nt(e)) a = 0; else if (U(e)) if (isNaN(+e)) { var u = qn(e); u && (s = u, a = 3) } else a = 0; else if (Q(e)) { var h = A({}, s); h.colorStops = z(e.colorStops, (function (t) { return { offset: t.offset, color: qn(t.color) } })), yi(e) ? a = 4 : vi(e) && (a = 5), s = h } 0 === r ? this.valType = a : a === this.valType && 6 !== a || (o = !0), this.discrete = this.discrete || o; var c = { time: t, value: s, rawValue: e, percent: 0 }; return n && (c.easing = n, c.easingFunc = X(n) ? n : an[n] || Pn(n)), i.push(c), c }, t.prototype.prepare = function (t, e) { var n = this.keyframes; this._needsSort && n.sort((function (t, e) { return t.time - e.time })); for (var i = this.valType, r = n.length, o = n[r - 1], a = this.discrete, s = Oi(i), l = Pi(i), u = 0; u < r; u++) { var h = n[u], c = h.value, p = o.value; h.percent = h.time / t, a || (s && u !== r - 1 ? Ai(c, p, i) : l && Di(c.colorStops, p.colorStops)) } if (!a && 5 !== i && e && this.needsAnimate() && e.needsAnimate() && i === e.valType && !e._finished) { this._additiveTrack = e; var d = n[0].value; for (u = 0; u < r; u++)0 === i ? n[u].additiveValue = n[u].value - d : 3 === i ? n[u].additiveValue = Ti([], n[u].value, d, -1) : Oi(i) && (n[u].additiveValue = 1 === i ? Ti([], n[u].value, d, -1) : Ci([], n[u].value, d, -1)) } }, t.prototype.step = function (t, e) { if (!this._finished) { this._additiveTrack && this._additiveTrack._finished && (this._additiveTrack = null); var n, i, r, o = null != this._additiveTrack, a = o ? "additiveValue" : "value", s = this.valType, l = this.keyframes, u = l.length, h = this.propName, c = 3 === s, p = this._lastFr, d = Math.min; if (1 === u) i = r = l[0]; else { if (e < 0) n = 0; else if (e < this._lastFrP) { for (n = d(p + 1, u - 1); n >= 0 && !(l[n].percent <= e); n--); n = d(n, u - 2) } else { for (n = p; n < u && !(l[n].percent > e); n++); n = d(n - 1, u - 2) } r = l[n + 1], i = l[n] } if (i && r) { this._lastFr = n, this._lastFrP = e; var f = r.percent - i.percent, g = 0 === f ? 1 : d((e - i.percent) / f, 1); r.easingFunc && (g = r.easingFunc(g)); var y = o ? this._additiveValue : c ? Ri : t[h]; if (!Oi(s) && !c || y || (y = this._additiveValue = []), this.discrete) t[h] = g < 1 ? i.rawValue : r.rawValue; else if (Oi(s)) 1 === s ? Ii(y, i[a], r[a], g) : function (t, e, n, i) { for (var r = e.length, o = r && e[0].length, a = 0; a < r; a++) { t[a] || (t[a] = []); for (var s = 0; s < o; s++)t[a][s] = Mi(e[a][s], n[a][s], i) } }(y, i[a], r[a], g); else if (Pi(s)) { var v = i[a], m = r[a], x = 4 === s; t[h] = { type: x ? "linear" : "radial", x: Mi(v.x, m.x, g), y: Mi(v.y, m.y, g), colorStops: z(v.colorStops, (function (t, e) { var n = m.colorStops[e]; return { offset: Mi(t.offset, n.offset, g), color: Li(Ii([], t.color, n.color, g)) } })), global: m.global }, x ? (t[h].x2 = Mi(v.x2, m.x2, g), t[h].y2 = Mi(v.y2, m.y2, g)) : t[h].r = Mi(v.r, m.r, g) } else if (c) Ii(y, i[a], r[a], g), o || (t[h] = Li(y)); else { var _ = Mi(i[a], r[a], g); o ? this._additiveValue = _ : t[h] = _ } o && this._addToTarget(t) } } }, t.prototype._addToTarget = function (t) { var e = this.valType, n = this.propName, i = this._additiveValue; 0 === e ? t[n] = t[n] + i : 3 === e ? (qn(t[n], Ri), Ti(Ri, Ri, i, 1), t[n] = Li(Ri)) : 1 === e ? Ti(t[n], t[n], i, 1) : 2 === e && Ci(t[n], t[n], i, 1) }, t }(), Ei = function () { function t(t, e, n, i) { this._tracks = {}, this._trackKeys = [], this._maxTime = 0, this._started = 0, this._clip = null, this._target = t, this._loop = e, e && i ? I("Can' use additive animation on looped animation.") : (this._additiveAnimators = i, this._allowDiscrete = n) } return t.prototype.getMaxTime = function () { return this._maxTime }, t.prototype.getDelay = function () { return this._delay }, t.prototype.getLoop = function () { return this._loop }, t.prototype.getTarget = function () { return this._target }, t.prototype.changeTarget = function (t) { this._target = t }, t.prototype.when = function (t, e, n) { return this.whenWithKeys(t, e, G(e), n) }, t.prototype.whenWithKeys = function (t, e, n, i) { for (var r = this._tracks, o = 0; o < n.length; o++) { var a = n[o], s = r[a]; if (!s) { s = r[a] = new Ni(a); var l = void 0, u = this._getAdditiveTrack(a); if (u) { var h = u.keyframes, c = h[h.length - 1]; l = c && c.value, 3 === u.valType && l && (l = Li(l)) } else l = this._target[a]; if (null == l) continue; t > 0 && s.addKeyframe(0, ki(l), i), this._trackKeys.push(a) } s.addKeyframe(t, ki(e[a]), i) } return this._maxTime = Math.max(this._maxTime, t), this }, t.prototype.pause = function () { this._clip.pause(), this._paused = !0 }, t.prototype.resume = function () { this._clip.resume(), this._paused = !1 }, t.prototype.isPaused = function () { return !!this._paused }, t.prototype.duration = function (t) { return this._maxTime = t, this._force = !0, this }, t.prototype._doneCallback = function () { this._setTracksFinished(), this._clip = null; var t = this._doneCbs; if (t) for (var e = t.length, n = 0; n < e; n++)t[n].call(this) }, t.prototype._abortedCallback = function () { this._setTracksFinished(); var t = this.animation, e = this._abortedCbs; if (t && t.removeClip(this._clip), this._clip = null, e) for (var n = 0; n < e.length; n++)e[n].call(this) }, t.prototype._setTracksFinished = function () { for (var t = this._tracks, e = this._trackKeys, n = 0; n < e.length; n++)t[e[n]].setFinished() }, t.prototype._getAdditiveTrack = function (t) { var e, n = this._additiveAnimators; if (n) for (var i = 0; i < n.length; i++) { var r = n[i].getTrack(t); r && (e = r) } return e }, t.prototype.start = function (t) { if (!(this._started > 0)) { this._started = 1; for (var e = this, n = [], i = this._maxTime || 0, r = 0; r < this._trackKeys.length; r++) { var o = this._trackKeys[r], a = this._tracks[o], s = this._getAdditiveTrack(o), l = a.keyframes, u = l.length; if (a.prepare(i, s), a.needsAnimate()) if (!this._allowDiscrete && a.discrete) { var h = l[u - 1]; h && (e._target[a.propName] = h.rawValue), a.setFinished() } else n.push(a) } if (n.length || this._force) { var c = new On({ life: i, loop: this._loop, delay: this._delay || 0, onframe: function (t) { e._started = 2; var i = e._additiveAnimators; if (i) { for (var r = !1, o = 0; o < i.length; o++)if (i[o]._clip) { r = !0; break } r || (e._additiveAnimators = null) } for (o = 0; o < n.length; o++)n[o].step(e._target, t); var a = e._onframeCbs; if (a) for (o = 0; o < a.length; o++)a[o](e._target, t) }, ondestroy: function () { e._doneCallback() } }); this._clip = c, this.animation && this.animation.addClip(c), t && c.setEasing(t) } else this._doneCallback(); return this } }, t.prototype.stop = function (t) { if (this._clip) { var e = this._clip; t && e.onframe(1), this._abortedCallback() } }, t.prototype.delay = function (t) { return this._delay = t, this }, t.prototype.during = function (t) { return t && (this._onframeCbs || (this._onframeCbs = []), this._onframeCbs.push(t)), this }, t.prototype.done = function (t) { return t && (this._doneCbs || (this._doneCbs = []), this._doneCbs.push(t)), this }, t.prototype.aborted = function (t) { return t && (this._abortedCbs || (this._abortedCbs = []), this._abortedCbs.push(t)), this }, t.prototype.getClip = function () { return this._clip }, t.prototype.getTrack = function (t) { return this._tracks[t] }, t.prototype.getTracks = function () { var t = this; return z(this._trackKeys, (function (e) { return t._tracks[e] })) }, t.prototype.stopTracks = function (t, e) { if (!t.length || !this._clip) return !0; for (var n = this._tracks, i = this._trackKeys, r = 0; r < t.length; r++) { var o = n[t[r]]; o && !o.isFinished() && (e ? o.step(this._target, 1) : 1 === this._started && o.step(this._target, 0), o.setFinished()) } var a = !0; for (r = 0; r < i.length; r++)if (!n[i[r]].isFinished()) { a = !1; break } return a && this._abortedCallback(), a }, t.prototype.saveTo = function (t, e, n) { if (t) { e = e || this._trackKeys; for (var i = 0; i < e.length; i++) { var r = e[i], o = this._tracks[r]; if (o && !o.isFinished()) { var a = o.keyframes, s = a[n ? 0 : a.length - 1]; s && (t[r] = ki(s.rawValue)) } } } }, t.prototype.__changeFinalValue = function (t, e) { e = e || G(t); for (var n = 0; n < e.length; n++) { var i = e[n], r = this._tracks[i]; if (r) { var o = r.keyframes; if (o.length > 1) { var a = o.pop(); r.addKeyframe(a.time, t[i]), r.prepare(this._maxTime, r.getAdditiveTrack()) } } } }, t }(); function zi() { return (new Date).getTime() } var Vi, Bi, Fi = function (t) { function e(e) { var n = t.call(this) || this; return n._running = !1, n._time = 0, n._pausedTime = 0, n._pauseStart = 0, n._paused = !1, e = e || {}, n.stage = e.stage || {}, n } return n(e, t), e.prototype.addClip = function (t) { t.animation && this.removeClip(t), this._head ? (this._tail.next = t, t.prev = this._tail, t.next = null, this._tail = t) : this._head = this._tail = t, t.animation = this }, e.prototype.addAnimator = function (t) { t.animation = this; var e = t.getClip(); e && this.addClip(e) }, e.prototype.removeClip = function (t) { if (t.animation) { var e = t.prev, n = t.next; e ? e.next = n : this._head = n, n ? n.prev = e : this._tail = e, t.next = t.prev = t.animation = null } }, e.prototype.removeAnimator = function (t) { var e = t.getClip(); e && this.removeClip(e), t.animation = null }, e.prototype.update = function (t) { for (var e = zi() - this._pausedTime, n = e - this._time, i = this._head; i;) { var r = i.next; i.step(e, n) ? (i.ondestroy(), this.removeClip(i), i = r) : i = r } this._time = e, t || (this.trigger("frame", n), this.stage.update && this.stage.update()) }, e.prototype._startLoop = function () { var t = this; this._running = !0, on((function e() { t._running && (on(e), !t._paused && t.update()) })) }, e.prototype.start = function () { this._running || (this._time = zi(), this._pausedTime = 0, this._startLoop()) }, e.prototype.stop = function () { this._running = !1 }, e.prototype.pause = function () { this._paused || (this._pauseStart = zi(), this._paused = !0) }, e.prototype.resume = function () { this._paused && (this._pausedTime += zi() - this._pauseStart, this._paused = !1) }, e.prototype.clear = function () { for (var t = this._head; t;) { var e = t.next; t.prev = t.next = t.animation = null, t = e } this._head = this._tail = null }, e.prototype.isFinished = function () { return null == this._head }, e.prototype.animate = function (t, e) { e = e || {}, this.start(); var n = new Ei(t, e.loop); return this.addAnimator(n), n }, e }(jt), Gi = r.domSupported, Wi = (Bi = { pointerdown: 1, pointerup: 1, pointermove: 1, pointerout: 1 }, { mouse: Vi = ["click", "dblclick", "mousewheel", "wheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu"], touch: ["touchstart", "touchend", "touchmove"], pointer: z(Vi, (function (t) { var e = t.replace("mouse", "pointer"); return Bi.hasOwnProperty(e) ? e : t })) }), Hi = ["mousemove", "mouseup"], Yi = ["pointermove", "pointerup"], Xi = !1; function Ui(t) { var e = t.pointerType; return "pen" === e || "touch" === e } function Zi(t) { t && (t.zrByTouch = !0) } function ji(t, e) { for (var n = e, i = !1; n && 9 !== n.nodeType && !(i = n.domBelongToZr || n !== e && n === t.painterRoot);)n = n.parentNode; return i } var qi = function (t, e) { this.stopPropagation = bt, this.stopImmediatePropagation = bt, this.preventDefault = bt, this.type = e.type, this.target = this.currentTarget = t.dom, this.pointerType = e.pointerType, this.clientX = e.clientX, this.clientY = e.clientY }, Ki = { mousedown: function (t) { t = ce(this.dom, t), this.__mayPointerCapture = [t.zrX, t.zrY], this.trigger("mousedown", t) }, mousemove: function (t) { t = ce(this.dom, t); var e = this.__mayPointerCapture; !e || t.zrX === e[0] && t.zrY === e[1] || this.__togglePointerCapture(!0), this.trigger("mousemove", t) }, mouseup: function (t) { t = ce(this.dom, t), this.__togglePointerCapture(!1), this.trigger("mouseup", t) }, mouseout: function (t) { ji(this, (t = ce(this.dom, t)).toElement || t.relatedTarget) || (this.__pointerCapturing && (t.zrEventControl = "no_globalout"), this.trigger("mouseout", t)) }, wheel: function (t) { Xi = !0, t = ce(this.dom, t), this.trigger("mousewheel", t) }, mousewheel: function (t) { Xi || (t = ce(this.dom, t), this.trigger("mousewheel", t)) }, touchstart: function (t) { Zi(t = ce(this.dom, t)), this.__lastTouchMoment = new Date, this.handler.processGesture(t, "start"), Ki.mousemove.call(this, t), Ki.mousedown.call(this, t) }, touchmove: function (t) { Zi(t = ce(this.dom, t)), this.handler.processGesture(t, "change"), Ki.mousemove.call(this, t) }, touchend: function (t) { Zi(t = ce(this.dom, t)), this.handler.processGesture(t, "end"), Ki.mouseup.call(this, t), +new Date - +this.__lastTouchMoment < 300 && Ki.click.call(this, t) }, pointerdown: function (t) { Ki.mousedown.call(this, t) }, pointermove: function (t) { Ui(t) || Ki.mousemove.call(this, t) }, pointerup: function (t) { Ki.mouseup.call(this, t) }, pointerout: function (t) { Ui(t) || Ki.mouseout.call(this, t) } }; E(["click", "dblclick", "contextmenu"], (function (t) { Ki[t] = function (e) { e = ce(this.dom, e), this.trigger(t, e) } })); var $i = { pointermove: function (t) { Ui(t) || $i.mousemove.call(this, t) }, pointerup: function (t) { $i.mouseup.call(this, t) }, mousemove: function (t) { this.trigger("mousemove", t) }, mouseup: function (t) { var e = this.__pointerCapturing; this.__togglePointerCapture(!1), this.trigger("mouseup", t), e && (t.zrEventControl = "only_globalout", this.trigger("mouseout", t)) } }; function Ji(t, e) { var n = e.domHandlers; r.pointerEventsSupported ? E(Wi.pointer, (function (i) { tr(e, i, (function (e) { n[i].call(t, e) })) })) : (r.touchEventsSupported && E(Wi.touch, (function (i) { tr(e, i, (function (r) { n[i].call(t, r), function (t) { t.touching = !0, null != t.touchTimer && (clearTimeout(t.touchTimer), t.touchTimer = null), t.touchTimer = setTimeout((function () { t.touching = !1, t.touchTimer = null }), 700) }(e) })) })), E(Wi.mouse, (function (i) { tr(e, i, (function (r) { r = he(r), e.touching || n[i].call(t, r) })) }))) } function Qi(t, e) { function n(n) { tr(e, n, (function (i) { i = he(i), ji(t, i.target) || (i = function (t, e) { return ce(t.dom, new qi(t, e), !0) }(t, i), e.domHandlers[n].call(t, i)) }), { capture: !0 }) } r.pointerEventsSupported ? E(Yi, n) : r.touchEventsSupported || E(Hi, n) } function tr(t, e, n, i) { t.mounted[e] = n, t.listenerOpts[e] = i, pe(t.domTarget, e, n, i) } function er(t) { var e, n, i, r, o = t.mounted; for (var a in o) o.hasOwnProperty(a) && (e = t.domTarget, n = a, i = o[a], r = t.listenerOpts[a], e.removeEventListener(n, i, r)); t.mounted = {} } var nr = function (t, e) { this.mounted = {}, this.listenerOpts = {}, this.touching = !1, this.domTarget = t, this.domHandlers = e }, ir = function (t) { function e(e, n) { var i = t.call(this) || this; return i.__pointerCapturing = !1, i.dom = e, i.painterRoot = n, i._localHandlerScope = new nr(e, Ki), Gi && (i._globalHandlerScope = new nr(document, $i)), Ji(i, i._localHandlerScope), i } return n(e, t), e.prototype.dispose = function () { er(this._localHandlerScope), Gi && er(this._globalHandlerScope) }, e.prototype.setCursor = function (t) { this.dom.style && (this.dom.style.cursor = t || "default") }, e.prototype.__togglePointerCapture = function (t) { if (this.__mayPointerCapture = null, Gi && +this.__pointerCapturing ^ +t) { this.__pointerCapturing = t; var e = this._globalHandlerScope; t ? Qi(this, e) : er(e) } }, e }(jt), rr = 1; r.hasGlobalWindow && (rr = Math.max(window.devicePixelRatio || window.screen && window.screen.deviceXDPI / window.screen.logicalXDPI || 1, 1)); var or = rr, ar = "#333", sr = "#ccc", lr = xe, ur = 5e-5; function hr(t) { return t > ur || t < -5e-5 } var cr = [], pr = [], dr = [1, 0, 0, 1, 0, 0], fr = Math.abs, gr = function () { function t() { } return t.prototype.getLocalTransform = function (e) { return t.getLocalTransform(this, e) }, t.prototype.setPosition = function (t) { this.x = t[0], this.y = t[1] }, t.prototype.setScale = function (t) { this.scaleX = t[0], this.scaleY = t[1] }, t.prototype.setSkew = function (t) { this.skewX = t[0], this.skewY = t[1] }, t.prototype.setOrigin = function (t) { this.originX = t[0], this.originY = t[1] }, t.prototype.needLocalTransform = function () { return hr(this.rotation) || hr(this.x) || hr(this.y) || hr(this.scaleX - 1) || hr(this.scaleY - 1) || hr(this.skewX) || hr(this.skewY) }, t.prototype.updateTransform = function () { var t = this.parent && this.parent.transform, e = this.needLocalTransform(), n = this.transform; e || t ? (n = n || [1, 0, 0, 1, 0, 0], e ? this.getLocalTransform(n) : lr(n), t && (e ? be(n, t, n) : _e(n, t)), this.transform = n, this._resolveGlobalScaleRatio(n)) : n && (lr(n), this.invTransform = null) }, t.prototype._resolveGlobalScaleRatio = function (t) { var e = this.globalScaleRatio; if (null != e && 1 !== e) { this.getGlobalScale(cr); var n = cr[0] < 0 ? -1 : 1, i = cr[1] < 0 ? -1 : 1, r = ((cr[0] - n) * e + n) / cr[0] || 0, o = ((cr[1] - i) * e + i) / cr[1] || 0; t[0] *= r, t[1] *= r, t[2] *= o, t[3] *= o } this.invTransform = this.invTransform || [1, 0, 0, 1, 0, 0], Ie(this.invTransform, t) }, t.prototype.getComputedTransform = function () { for (var t = this, e = []; t;)e.push(t), t = t.parent; for (; t = e.pop();)t.updateTransform(); return this.transform }, t.prototype.setLocalTransform = function (t) { if (t) { var e = t[0] * t[0] + t[1] * t[1], n = t[2] * t[2] + t[3] * t[3], i = Math.atan2(t[1], t[0]), r = Math.PI / 2 + i - Math.atan2(t[3], t[2]); n = Math.sqrt(n) * Math.cos(r), e = Math.sqrt(e), this.skewX = r, this.skewY = 0, this.rotation = -i, this.x = +t[4], this.y = +t[5], this.scaleX = e, this.scaleY = n, this.originX = 0, this.originY = 0 } }, t.prototype.decomposeTransform = function () { if (this.transform) { var t = this.parent, e = this.transform; t && t.transform && (be(pr, t.invTransform, e), e = pr); var n = this.originX, i = this.originY; (n || i) && (dr[4] = n, dr[5] = i, be(pr, e, dr), pr[4] -= n, pr[5] -= i, e = pr), this.setLocalTransform(e) } }, t.prototype.getGlobalScale = function (t) { var e = this.transform; return t = t || [], e ? (t[0] = Math.sqrt(e[0] * e[0] + e[1] * e[1]), t[1] = Math.sqrt(e[2] * e[2] + e[3] * e[3]), e[0] < 0 && (t[0] = -t[0]), e[3] < 0 && (t[1] = -t[1]), t) : (t[0] = 1, t[1] = 1, t) }, t.prototype.transformCoordToLocal = function (t, e) { var n = [t, e], i = this.invTransform; return i && Wt(n, n, i), n }, t.prototype.transformCoordToGlobal = function (t, e) { var n = [t, e], i = this.transform; return i && Wt(n, n, i), n }, t.prototype.getLineScale = function () { var t = this.transform; return t && fr(t[0] - 1) > 1e-10 && fr(t[3] - 1) > 1e-10 ? Math.sqrt(fr(t[0] * t[3] - t[2] * t[1])) : 1 }, t.prototype.copyTransform = function (t) { vr(this, t) }, t.getLocalTransform = function (t, e) { e = e || []; var n = t.originX || 0, i = t.originY || 0, r = t.scaleX, o = t.scaleY, a = t.anchorX, s = t.anchorY, l = t.rotation || 0, u = t.x, h = t.y, c = t.skewX ? Math.tan(t.skewX) : 0, p = t.skewY ? Math.tan(-t.skewY) : 0; if (n || i || a || s) { var d = n + a, f = i + s; e[4] = -d * r - c * f * o, e[5] = -f * o - p * d * r } else e[4] = e[5] = 0; return e[0] = r, e[3] = o, e[1] = p * r, e[2] = c * o, l && Se(e, e, l), e[4] += n + u, e[5] += i + h, e }, t.initDefaultProps = function () { var e = t.prototype; e.scaleX = e.scaleY = e.globalScaleRatio = 1, e.x = e.y = e.originX = e.originY = e.skewX = e.skewY = e.rotation = e.anchorX = e.anchorY = 0 }(), t }(), yr = ["x", "y", "originX", "originY", "anchorX", "anchorY", "rotation", "scaleX", "scaleY", "skewX", "skewY"]; function vr(t, e) { for (var n = 0; n < yr.length; n++) { var i = yr[n]; t[i] = e[i] } } var mr = {}; function xr(t, e) { var n = mr[e = e || a]; n || (n = mr[e] = new En(500)); var i = n.get(t); return null == i && (i = h.measureText(t, e).width, n.put(t, i)), i } function _r(t, e, n, i) { var r = xr(t, e), o = Mr(e), a = wr(0, r, n), s = Sr(0, o, i); return new ze(a, s, r, o) } function br(t, e, n, i) { var r = ((t || "") + "").split("\n"); if (1 === r.length) return _r(r[0], e, n, i); for (var o = new ze(0, 0, 0, 0), a = 0; a < r.length; a++) { var s = _r(r[a], e, n, i); 0 === a ? o.copy(s) : o.union(s) } return o } function wr(t, e, n) { return "right" === n ? t -= e : "center" === n && (t -= e / 2), t } function Sr(t, e, n) { return "middle" === n ? t -= e / 2 : "bottom" === n && (t -= e), t } function Mr(t) { return xr("国", t) } function Ir(t, e) { return "string" == typeof t ? t.lastIndexOf("%") >= 0 ? parseFloat(t) / 100 * e : parseFloat(t) : t } function Tr(t, e, n) { var i = e.position || "inside", r = null != e.distance ? e.distance : 5, o = n.height, a = n.width, s = o / 2, l = n.x, u = n.y, h = "left", c = "top"; if (i instanceof Array) l += Ir(i[0], n.width), u += Ir(i[1], n.height), h = null, c = null; else switch (i) { case "left": l -= r, u += s, h = "right", c = "middle"; break; case "right": l += r + a, u += s, c = "middle"; break; case "top": l += a / 2, u -= r, h = "center", c = "bottom"; break; case "bottom": l += a / 2, u += o + r, h = "center"; break; case "inside": l += a / 2, u += s, h = "center", c = "middle"; break; case "insideLeft": l += r, u += s, c = "middle"; break; case "insideRight": l += a - r, u += s, h = "right", c = "middle"; break; case "insideTop": l += a / 2, u += r, h = "center"; break; case "insideBottom": l += a / 2, u += o - r, h = "center", c = "bottom"; break; case "insideTopLeft": l += r, u += r; break; case "insideTopRight": l += a - r, u += r, h = "right"; break; case "insideBottomLeft": l += r, u += o - r, c = "bottom"; break; case "insideBottomRight": l += a - r, u += o - r, h = "right", c = "bottom" }return (t = t || {}).x = l, t.y = u, t.align = h, t.verticalAlign = c, t } var Cr = "__zr_normal__", Dr = yr.concat(["ignore"]), Ar = V(yr, (function (t, e) { return t[e] = !0, t }), { ignore: !1 }), kr = {}, Lr = new ze(0, 0, 0, 0), Pr = function () { function t(t) { this.id = M(), this.animators = [], this.currentStates = [], this.states = {}, this._init(t) } return t.prototype._init = function (t) { this.attr(t) }, t.prototype.drift = function (t, e, n) { switch (this.draggable) { case "horizontal": e = 0; break; case "vertical": t = 0 }var i = this.transform; i || (i = this.transform = [1, 0, 0, 1, 0, 0]), i[4] += t, i[5] += e, this.decomposeTransform(), this.markRedraw() }, t.prototype.beforeUpdate = function () { }, t.prototype.afterUpdate = function () { }, t.prototype.update = function () { this.updateTransform(), this.__dirty && this.updateInnerText() }, t.prototype.updateInnerText = function (t) { var e = this._textContent; if (e && (!e.ignore || t)) { this.textConfig || (this.textConfig = {}); var n = this.textConfig, i = n.local, r = e.innerTransformable, o = void 0, a = void 0, s = !1; r.parent = i ? this : null; var l = !1; if (r.copyTransform(e), null != n.position) { var u = Lr; n.layoutRect ? u.copy(n.layoutRect) : u.copy(this.getBoundingRect()), i || u.applyTransform(this.transform), this.calculateTextPosition ? this.calculateTextPosition(kr, n, u) : Tr(kr, n, u), r.x = kr.x, r.y = kr.y, o = kr.align, a = kr.verticalAlign; var h = n.origin; if (h && null != n.rotation) { var c = void 0, p = void 0; "center" === h ? (c = .5 * u.width, p = .5 * u.height) : (c = Ir(h[0], u.width), p = Ir(h[1], u.height)), l = !0, r.originX = -r.x + c + (i ? 0 : u.x), r.originY = -r.y + p + (i ? 0 : u.y) } } null != n.rotation && (r.rotation = n.rotation); var d = n.offset; d && (r.x += d[0], r.y += d[1], l || (r.originX = -d[0], r.originY = -d[1])); var f = null == n.inside ? "string" == typeof n.position && n.position.indexOf("inside") >= 0 : n.inside, g = this._innerTextDefaultStyle || (this._innerTextDefaultStyle = {}), y = void 0, v = void 0, m = void 0; f && this.canBeInsideText() ? (y = n.insideFill, v = n.insideStroke, null != y && "auto" !== y || (y = this.getInsideTextFill()), null != v && "auto" !== v || (v = this.getInsideTextStroke(y), m = !0)) : (y = n.outsideFill, v = n.outsideStroke, null != y && "auto" !== y || (y = this.getOutsideFill()), null != v && "auto" !== v || (v = this.getOutsideStroke(y), m = !0)), (y = y || "#000") === g.fill && v === g.stroke && m === g.autoStroke && o === g.align && a === g.verticalAlign || (s = !0, g.fill = y, g.stroke = v, g.autoStroke = m, g.align = o, g.verticalAlign = a, e.setDefaultTextStyle(g)), e.__dirty |= 1, s && e.dirtyStyle(!0) } }, t.prototype.canBeInsideText = function () { return !0 }, t.prototype.getInsideTextFill = function () { return "#fff" }, t.prototype.getInsideTextStroke = function (t) { return "#000" }, t.prototype.getOutsideFill = function () { return this.__zr && this.__zr.isDarkMode() ? sr : ar }, t.prototype.getOutsideStroke = function (t) { var e = this.__zr && this.__zr.getBackgroundColor(), n = "string" == typeof e && qn(e); n || (n = [255, 255, 255, 1]); for (var i = n[3], r = this.__zr.isDarkMode(), o = 0; o < 3; o++)n[o] = n[o] * i + (r ? 0 : 255) * (1 - i); return n[3] = 1, ri(n, "rgba") }, t.prototype.traverse = function (t, e) { }, t.prototype.attrKV = function (t, e) { "textConfig" === t ? this.setTextConfig(e) : "textContent" === t ? this.setTextContent(e) : "clipPath" === t ? this.setClipPath(e) : "extra" === t ? (this.extra = this.extra || {}, A(this.extra, e)) : this[t] = e }, t.prototype.hide = function () { this.ignore = !0, this.markRedraw() }, t.prototype.show = function () { this.ignore = !1, this.markRedraw() }, t.prototype.attr = function (t, e) { if ("string" == typeof t) this.attrKV(t, e); else if (q(t)) for (var n = G(t), i = 0; i < n.length; i++) { var r = n[i]; this.attrKV(r, t[r]) } return this.markRedraw(), this }, t.prototype.saveCurrentToNormalState = function (t) { this._innerSaveToNormal(t); for (var e = this._normalState, n = 0; n < this.animators.length; n++) { var i = this.animators[n], r = i.__fromStateTransition; if (!(i.getLoop() || r && r !== Cr)) { var o = i.targetName, a = o ? e[o] : e; i.saveTo(a) } } }, t.prototype._innerSaveToNormal = function (t) { var e = this._normalState; e || (e = this._normalState = {}), t.textConfig && !e.textConfig && (e.textConfig = this.textConfig), this._savePrimaryToNormal(t, e, Dr) }, t.prototype._savePrimaryToNormal = function (t, e, n) { for (var i = 0; i < n.length; i++) { var r = n[i]; null == t[r] || r in e || (e[r] = this[r]) } }, t.prototype.hasState = function () { return this.currentStates.length > 0 }, t.prototype.getState = function (t) { return this.states[t] }, t.prototype.ensureState = function (t) { var e = this.states; return e[t] || (e[t] = {}), e[t] }, t.prototype.clearStates = function (t) { this.useState(Cr, !1, t) }, t.prototype.useState = function (t, e, n, i) { var r = t === Cr; if (this.hasState() || !r) { var o = this.currentStates, a = this.stateTransition; if (!(P(o, t) >= 0) || !e && 1 !== o.length) { var s; if (this.stateProxy && !r && (s = this.stateProxy(t)), s || (s = this.states && this.states[t]), s || r) { r || this.saveCurrentToNormalState(s); var l = !!(s && s.hoverLayer || i); l && this._toggleHoverLayerFlag(!0), this._applyStateObj(t, s, this._normalState, e, !n && !this.__inHover && a && a.duration > 0, a); var u = this._textContent, h = this._textGuide; return u && u.useState(t, e, n, l), h && h.useState(t, e, n, l), r ? (this.currentStates = [], this._normalState = {}) : e ? this.currentStates.push(t) : this.currentStates = [t], this._updateAnimationTargets(), this.markRedraw(), !l && this.__inHover && (this._toggleHoverLayerFlag(!1), this.__dirty &= -2), s } I("State " + t + " not exists.") } } }, t.prototype.useStates = function (t, e, n) { if (t.length) { var i = [], r = this.currentStates, o = t.length, a = o === r.length; if (a) for (var s = 0; s < o; s++)if (t[s] !== r[s]) { a = !1; break } if (a) return; for (s = 0; s < o; s++) { var l = t[s], u = void 0; this.stateProxy && (u = this.stateProxy(l, t)), u || (u = this.states[l]), u && i.push(u) } var h = i[o - 1], c = !!(h && h.hoverLayer || n); c && this._toggleHoverLayerFlag(!0); var p = this._mergeStates(i), d = this.stateTransition; this.saveCurrentToNormalState(p), this._applyStateObj(t.join(","), p, this._normalState, !1, !e && !this.__inHover && d && d.duration > 0, d); var f = this._textContent, g = this._textGuide; f && f.useStates(t, e, c), g && g.useStates(t, e, c), this._updateAnimationTargets(), this.currentStates = t.slice(), this.markRedraw(), !c && this.__inHover && (this._toggleHoverLayerFlag(!1), this.__dirty &= -2) } else this.clearStates() }, t.prototype._updateAnimationTargets = function () { for (var t = 0; t < this.animators.length; t++) { var e = this.animators[t]; e.targetName && e.changeTarget(this[e.targetName]) } }, t.prototype.removeState = function (t) { var e = P(this.currentStates, t); if (e >= 0) { var n = this.currentStates.slice(); n.splice(e, 1), this.useStates(n) } }, t.prototype.replaceState = function (t, e, n) { var i = this.currentStates.slice(), r = P(i, t), o = P(i, e) >= 0; r >= 0 ? o ? i.splice(r, 1) : i[r] = e : n && !o && i.push(e), this.useStates(i) }, t.prototype.toggleState = function (t, e) { e ? this.useState(t, !0) : this.removeState(t) }, t.prototype._mergeStates = function (t) { for (var e, n = {}, i = 0; i < t.length; i++) { var r = t[i]; A(n, r), r.textConfig && A(e = e || {}, r.textConfig) } return e && (n.textConfig = e), n }, t.prototype._applyStateObj = function (t, e, n, i, r, o) { var a = !(e && i); e && e.textConfig ? (this.textConfig = A({}, i ? this.textConfig : n.textConfig), A(this.textConfig, e.textConfig)) : a && n.textConfig && (this.textConfig = n.textConfig); for (var s = {}, l = !1, u = 0; u < Dr.length; u++) { var h = Dr[u], c = r && Ar[h]; e && null != e[h] ? c ? (l = !0, s[h] = e[h]) : this[h] = e[h] : a && null != n[h] && (c ? (l = !0, s[h] = n[h]) : this[h] = n[h]) } if (!r) for (u = 0; u < this.animators.length; u++) { var p = this.animators[u], d = p.targetName; p.getLoop() || p.__changeFinalValue(d ? (e || n)[d] : e || n) } l && this._transitionState(t, s, o) }, t.prototype._attachComponent = function (t) { if ((!t.__zr || t.__hostTarget) && t !== this) { var e = this.__zr; e && t.addSelfToZr(e), t.__zr = e, t.__hostTarget = this } }, t.prototype._detachComponent = function (t) { t.__zr && t.removeSelfFromZr(t.__zr), t.__zr = null, t.__hostTarget = null }, t.prototype.getClipPath = function () { return this._clipPath }, t.prototype.setClipPath = function (t) { this._clipPath && this._clipPath !== t && this.removeClipPath(), this._attachComponent(t), this._clipPath = t, this.markRedraw() }, t.prototype.removeClipPath = function () { var t = this._clipPath; t && (this._detachComponent(t), this._clipPath = null, this.markRedraw()) }, t.prototype.getTextContent = function () { return this._textContent }, t.prototype.setTextContent = function (t) { var e = this._textContent; e !== t && (e && e !== t && this.removeTextContent(), t.innerTransformable = new gr, this._attachComponent(t), this._textContent = t, this.markRedraw()) }, t.prototype.setTextConfig = function (t) { this.textConfig || (this.textConfig = {}), A(this.textConfig, t), this.markRedraw() }, t.prototype.removeTextConfig = function () { this.textConfig = null, this.markRedraw() }, t.prototype.removeTextContent = function () { var t = this._textContent; t && (t.innerTransformable = null, this._detachComponent(t), this._textContent = null, this._innerTextDefaultStyle = null, this.markRedraw()) }, t.prototype.getTextGuideLine = function () { return this._textGuide }, t.prototype.setTextGuideLine = function (t) { this._textGuide && this._textGuide !== t && this.removeTextGuideLine(), this._attachComponent(t), this._textGuide = t, this.markRedraw() }, t.prototype.removeTextGuideLine = function () { var t = this._textGuide; t && (this._detachComponent(t), this._textGuide = null, this.markRedraw()) }, t.prototype.markRedraw = function () { this.__dirty |= 1; var t = this.__zr; t && (this.__inHover ? t.refreshHover() : t.refresh()), this.__hostTarget && this.__hostTarget.markRedraw() }, t.prototype.dirty = function () { this.markRedraw() }, t.prototype._toggleHoverLayerFlag = function (t) { this.__inHover = t; var e = this._textContent, n = this._textGuide; e && (e.__inHover = t), n && (n.__inHover = t) }, t.prototype.addSelfToZr = function (t) { if (this.__zr !== t) { this.__zr = t; var e = this.animators; if (e) for (var n = 0; n < e.length; n++)t.animation.addAnimator(e[n]); this._clipPath && this._clipPath.addSelfToZr(t), this._textContent && this._textContent.addSelfToZr(t), this._textGuide && this._textGuide.addSelfToZr(t) } }, t.prototype.removeSelfFromZr = function (t) { if (this.__zr) { this.__zr = null; var e = this.animators; if (e) for (var n = 0; n < e.length; n++)t.animation.removeAnimator(e[n]); this._clipPath && this._clipPath.removeSelfFromZr(t), this._textContent && this._textContent.removeSelfFromZr(t), this._textGuide && this._textGuide.removeSelfFromZr(t) } }, t.prototype.animate = function (t, e, n) { var i = t ? this[t] : this; var r = new Ei(i, e, n); return t && (r.targetName = t), this.addAnimator(r, t), r }, t.prototype.addAnimator = function (t, e) { var n = this.__zr, i = this; t.during((function () { i.updateDuringAnimation(e) })).done((function () { var e = i.animators, n = P(e, t); n >= 0 && e.splice(n, 1) })), this.animators.push(t), n && n.animation.addAnimator(t), n && n.wakeUp() }, t.prototype.updateDuringAnimation = function (t) { this.markRedraw() }, t.prototype.stopAnimation = function (t, e) { for (var n = this.animators, i = n.length, r = [], o = 0; o < i; o++) { var a = n[o]; t && t !== a.scope ? r.push(a) : a.stop(e) } return this.animators = r, this }, t.prototype.animateTo = function (t, e, n) { Or(this, t, e, n) }, t.prototype.animateFrom = function (t, e, n) { Or(this, t, e, n, !0) }, t.prototype._transitionState = function (t, e, n, i) { for (var r = Or(this, e, n, i), o = 0; o < r.length; o++)r[o].__fromStateTransition = t }, t.prototype.getBoundingRect = function () { return null }, t.prototype.getPaintRect = function () { return null }, t.initDefaultProps = function () { var e = t.prototype; e.type = "element", e.name = "", e.ignore = e.silent = e.isGroup = e.draggable = e.dragging = e.ignoreClip = e.__inHover = !1, e.__dirty = 1; function n(t, n, i, r) { function o(t, e) { Object.defineProperty(e, 0, { get: function () { return t[i] }, set: function (e) { t[i] = e } }), Object.defineProperty(e, 1, { get: function () { return t[r] }, set: function (e) { t[r] = e } }) } Object.defineProperty(e, t, { get: function () { this[n] || o(this, this[n] = []); return this[n] }, set: function (t) { this[i] = t[0], this[r] = t[1], this[n] = t, o(this, t) } }) } Object.defineProperty && (n("position", "_legacyPos", "x", "y"), n("scale", "_legacyScale", "scaleX", "scaleY"), n("origin", "_legacyOrigin", "originX", "originY")) }(), t }(); function Or(t, e, n, i, r) { var o = []; Er(t, "", t, e, n = n || {}, i, o, r); var a = o.length, s = !1, l = n.done, u = n.aborted, h = function () { s = !0, --a <= 0 && (s ? l && l() : u && u()) }, c = function () { --a <= 0 && (s ? l && l() : u && u()) }; a || l && l(), o.length > 0 && n.during && o[0].during((function (t, e) { n.during(e) })); for (var p = 0; p < o.length; p++) { var d = o[p]; h && d.done(h), c && d.aborted(c), n.force && d.duration(n.duration), d.start(n.easing) } return o } function Rr(t, e, n) { for (var i = 0; i < n; i++)t[i] = e[i] } function Nr(t, e, n) { if (N(e[n])) if (N(t[n]) || (t[n] = []), $(e[n])) { var i = e[n].length; t[n].length !== i && (t[n] = new e[n].constructor(i), Rr(t[n], e[n], i)) } else { var r = e[n], o = t[n], a = r.length; if (N(r[0])) for (var s = r[0].length, l = 0; l < a; l++)o[l] ? Rr(o[l], r[l], s) : o[l] = Array.prototype.slice.call(r[l]); else Rr(o, r, a); o.length = r.length } else t[n] = e[n] } function Er(t, e, n, i, r, o, a, s) { for (var l = G(i), u = r.duration, h = r.delay, c = r.additive, p = r.setToFinal, d = !q(o), f = t.animators, g = [], y = 0; y < l.length; y++) { var v = l[y], m = i[v]; if (null != m && null != n[v] && (d || o[v])) if (!q(m) || N(m) || Q(m)) g.push(v); else { if (e) { s || (n[v] = m, t.updateDuringAnimation(e)); continue } Er(t, v, n[v], m, r, o && o[v], a, s) } else s || (n[v] = m, t.updateDuringAnimation(e), g.push(v)) } var x = g.length; if (!c && x) for (var _ = 0; _ < f.length; _++) { if ((w = f[_]).targetName === e) if (w.stopTracks(g)) { var b = P(f, w); f.splice(b, 1) } } if (r.force || (g = B(g, (function (t) { return e = i[t], r = n[t], !(e === r || N(e) && N(r) && function (t, e) { var n = t.length; if (n !== e.length) return !1; for (var i = 0; i < n; i++)if (t[i] !== e[i]) return !1; return !0 }(e, r)); var e, r })), x = g.length), x > 0 || r.force && !a.length) { var w, S = void 0, M = void 0, I = void 0; if (s) { M = {}, p && (S = {}); for (_ = 0; _ < x; _++) { M[v = g[_]] = n[v], p ? S[v] = i[v] : n[v] = i[v] } } else if (p) { I = {}; for (_ = 0; _ < x; _++) { I[v = g[_]] = ki(n[v]), Nr(n, i, v) } } (w = new Ei(n, !1, !1, c ? B(f, (function (t) { return t.targetName === e })) : null)).targetName = e, r.scope && (w.scope = r.scope), p && S && w.whenWithKeys(0, S, g), I && w.whenWithKeys(0, I, g), w.whenWithKeys(null == u ? 500 : u, s ? M : i, g).delay(h || 0), t.addAnimator(w, e), a.push(w) } } R(Pr, jt), R(Pr, gr); var zr = function (t) { function e(e) { var n = t.call(this) || this; return n.isGroup = !0, n._children = [], n.attr(e), n } return n(e, t), e.prototype.childrenRef = function () { return this._children }, e.prototype.children = function () { return this._children.slice() }, e.prototype.childAt = function (t) { return this._children[t] }, e.prototype.childOfName = function (t) { for (var e = this._children, n = 0; n < e.length; n++)if (e[n].name === t) return e[n] }, e.prototype.childCount = function () { return this._children.length }, e.prototype.add = function (t) { return t && t !== this && t.parent !== this && (this._children.push(t), this._doAdd(t)), this }, e.prototype.addBefore = function (t, e) { if (t && t !== this && t.parent !== this && e && e.parent === this) { var n = this._children, i = n.indexOf(e); i >= 0 && (n.splice(i, 0, t), this._doAdd(t)) } return this }, e.prototype.replace = function (t, e) { var n = P(this._children, t); return n >= 0 && this.replaceAt(e, n), this }, e.prototype.replaceAt = function (t, e) { var n = this._children, i = n[e]; if (t && t !== this && t.parent !== this && t !== i) { n[e] = t, i.parent = null; var r = this.__zr; r && i.removeSelfFromZr(r), this._doAdd(t) } return this }, e.prototype._doAdd = function (t) { t.parent && t.parent.remove(t), t.parent = this; var e = this.__zr; e && e !== t.__zr && t.addSelfToZr(e), e && e.refresh() }, e.prototype.remove = function (t) { var e = this.__zr, n = this._children, i = P(n, t); return i < 0 || (n.splice(i, 1), t.parent = null, e && t.removeSelfFromZr(e), e && e.refresh()), this }, e.prototype.removeAll = function () { for (var t = this._children, e = this.__zr, n = 0; n < t.length; n++) { var i = t[n]; e && i.removeSelfFromZr(e), i.parent = null } return t.length = 0, this }, e.prototype.eachChild = function (t, e) { for (var n = this._children, i = 0; i < n.length; i++) { var r = n[i]; t.call(e, r, i) } return this }, e.prototype.traverse = function (t, e) { for (var n = 0; n < this._children.length; n++) { var i = this._children[n], r = t.call(e, i); i.isGroup && !r && i.traverse(t, e) } return this }, e.prototype.addSelfToZr = function (e) { t.prototype.addSelfToZr.call(this, e); for (var n = 0; n < this._children.length; n++) { this._children[n].addSelfToZr(e) } }, e.prototype.removeSelfFromZr = function (e) { t.prototype.removeSelfFromZr.call(this, e); for (var n = 0; n < this._children.length; n++) { this._children[n].removeSelfFromZr(e) } }, e.prototype.getBoundingRect = function (t) { for (var e = new ze(0, 0, 0, 0), n = t || this._children, i = [], r = null, o = 0; o < n.length; o++) { var a = n[o]; if (!a.ignore && !a.invisible) { var s = a.getBoundingRect(), l = a.getLocalTransform(i); l ? (ze.applyTransform(e, s, l), (r = r || e.clone()).union(e)) : (r = r || s.clone()).union(s) } } return r || e }, e }(Pr); zr.prototype.type = "group";
    /*!
        * ZRender, a high performance 2d drawing library.
        *
        * Copyright (c) 2013, Baidu Inc.
        * All rights reserved.
        *
        * LICENSE
        * https://github.com/ecomfe/zrender/blob/master/LICENSE.txt
        */
    var Vr = {}, Br = {}; var Fr = function () { function t(t, e, n) { var i = this; this._sleepAfterStill = 10, this._stillFrameAccum = 0, this._needsRefresh = !0, this._needsRefreshHover = !0, this._darkMode = !1, n = n || {}, this.dom = e, this.id = t; var o = new rn, a = n.renderer || "canvas"; Vr[a] || (a = G(Vr)[0]), n.useDirtyRect = null != n.useDirtyRect && n.useDirtyRect; var s = new Vr[a](e, o, n, t), l = n.ssr || s.ssrOnly; this.storage = o, this.painter = s; var u, h = r.node || r.worker || l ? null : new ir(s.getViewportRoot(), s.root), c = n.useCoarsePointer; (null == c || "auto" === c ? r.touchEventsSupported : !!c) && (u = rt(n.pointerSize, 44)), this.handler = new Ye(o, s, h, s.root, u), this.animation = new Fi({ stage: { update: l ? null : function () { return i._flush(!0) } } }), l || this.animation.start() } return t.prototype.add = function (t) { t && (this.storage.addRoot(t), t.addSelfToZr(this), this.refresh()) }, t.prototype.remove = function (t) { t && (this.storage.delRoot(t), t.removeSelfFromZr(this), this.refresh()) }, t.prototype.configLayer = function (t, e) { this.painter.configLayer && this.painter.configLayer(t, e), this.refresh() }, t.prototype.setBackgroundColor = function (t) { this.painter.setBackgroundColor && this.painter.setBackgroundColor(t), this.refresh(), this._backgroundColor = t, this._darkMode = function (t) { if (!t) return !1; if ("string" == typeof t) return oi(t, 1) < .4; if (t.colorStops) { for (var e = t.colorStops, n = 0, i = e.length, r = 0; r < i; r++)n += oi(e[r].color, 1); return (n /= i) < .4 } return !1 }(t) }, t.prototype.getBackgroundColor = function () { return this._backgroundColor }, t.prototype.setDarkMode = function (t) { this._darkMode = t }, t.prototype.isDarkMode = function () { return this._darkMode }, t.prototype.refreshImmediately = function (t) { t || this.animation.update(!0), this._needsRefresh = !1, this.painter.refresh(), this._needsRefresh = !1 }, t.prototype.refresh = function () { this._needsRefresh = !0, this.animation.start() }, t.prototype.flush = function () { this._flush(!1) }, t.prototype._flush = function (t) { var e, n = zi(); this._needsRefresh && (e = !0, this.refreshImmediately(t)), this._needsRefreshHover && (e = !0, this.refreshHoverImmediately()); var i = zi(); e ? (this._stillFrameAccum = 0, this.trigger("rendered", { elapsedTime: i - n })) : this._sleepAfterStill > 0 && (this._stillFrameAccum++, this._stillFrameAccum > this._sleepAfterStill && this.animation.stop()) }, t.prototype.setSleepAfterStill = function (t) { this._sleepAfterStill = t }, t.prototype.wakeUp = function () { this.animation.start(), this._stillFrameAccum = 0 }, t.prototype.refreshHover = function () { this._needsRefreshHover = !0 }, t.prototype.refreshHoverImmediately = function () { this._needsRefreshHover = !1, this.painter.refreshHover && "canvas" === this.painter.getType() && this.painter.refreshHover() }, t.prototype.resize = function (t) { t = t || {}, this.painter.resize(t.width, t.height), this.handler.resize() }, t.prototype.clearAnimation = function () { this.animation.clear() }, t.prototype.getWidth = function () { return this.painter.getWidth() }, t.prototype.getHeight = function () { return this.painter.getHeight() }, t.prototype.setCursorStyle = function (t) { this.handler.setCursorStyle(t) }, t.prototype.findHover = function (t, e) { return this.handler.findHover(t, e) }, t.prototype.on = function (t, e, n) { return this.handler.on(t, e, n), this }, t.prototype.off = function (t, e) { this.handler.off(t, e) }, t.prototype.trigger = function (t, e) { this.handler.trigger(t, e) }, t.prototype.clear = function () { for (var t = this.storage.getRoots(), e = 0; e < t.length; e++)t[e] instanceof zr && t[e].removeSelfFromZr(this); this.storage.delAllRoots(), this.painter.clear() }, t.prototype.dispose = function () { var t; this.animation.stop(), this.clear(), this.storage.dispose(), this.painter.dispose(), this.handler.dispose(), this.animation = this.storage = this.painter = this.handler = null, t = this.id, delete Br[t] }, t }(); function Gr(t, e) { var n = new Fr(M(), t, e); return Br[n.id] = n, n } function Wr(t, e) { Vr[t] = e } var Hr = Object.freeze({ __proto__: null, init: Gr, dispose: function (t) { t.dispose() }, disposeAll: function () { for (var t in Br) Br.hasOwnProperty(t) && Br[t].dispose(); Br = {} }, getInstance: function (t) { return Br[t] }, registerPainter: Wr, version: "5.4.4" }), Yr = 1e-4; function Xr(t, e, n, i) { var r = e[0], o = e[1], a = n[0], s = n[1], l = o - r, u = s - a; if (0 === l) return 0 === u ? a : (a + s) / 2; if (i) if (l > 0) { if (t <= r) return a; if (t >= o) return s } else { if (t >= r) return a; if (t <= o) return s } else { if (t === r) return a; if (t === o) return s } return (t - r) / l * u + a } function Ur(t, e) { switch (t) { case "center": case "middle": t = "50%"; break; case "left": case "top": t = "0%"; break; case "right": case "bottom": t = "100%" }return U(t) ? (n = t, n.replace(/^\s+|\s+$/g, "")).match(/%$/) ? parseFloat(t) / 100 * e : parseFloat(t) : null == t ? NaN : +t; var n } function Zr(t, e, n) { return null == e && (e = 10), e = Math.min(Math.max(0, e), 20), t = (+t).toFixed(e), n ? t : +t } function jr(t) { return t.sort((function (t, e) { return t - e })), t } function qr(t) { if (t = +t, isNaN(t)) return 0; if (t > 1e-14) for (var e = 1, n = 0; n < 15; n++, e *= 10)if (Math.round(t * e) / e === t) return n; return Kr(t) } function Kr(t) { var e = t.toString().toLowerCase(), n = e.indexOf("e"), i = n > 0 ? +e.slice(n + 1) : 0, r = n > 0 ? n : e.length, o = e.indexOf("."), a = o < 0 ? 0 : r - 1 - o; return Math.max(0, a - i) } function $r(t, e) { var n = Math.log, i = Math.LN10, r = Math.floor(n(t[1] - t[0]) / i), o = Math.round(n(Math.abs(e[1] - e[0])) / i), a = Math.min(Math.max(-r + o, 0), 20); return isFinite(a) ? a : 20 } function Jr(t, e) { var n = V(t, (function (t, e) { return t + (isNaN(e) ? 0 : e) }), 0); if (0 === n) return []; for (var i = Math.pow(10, e), r = z(t, (function (t) { return (isNaN(t) ? 0 : t) / n * i * 100 })), o = 100 * i, a = z(r, (function (t) { return Math.floor(t) })), s = V(a, (function (t, e) { return t + e }), 0), l = z(r, (function (t, e) { return t - a[e] })); s < o;) { for (var u = Number.NEGATIVE_INFINITY, h = null, c = 0, p = l.length; c < p; ++c)l[c] > u && (u = l[c], h = c); ++a[h], l[h] = 0, ++s } return z(a, (function (t) { return t / i })) } function Qr(t, e) { var n = Math.max(qr(t), qr(e)), i = t + e; return n > 20 ? i : Zr(i, n) } var to = 9007199254740991; function eo(t) { var e = 2 * Math.PI; return (t % e + e) % e } function no(t) { return t > -1e-4 && t < Yr } var io = /^(?:(\d{4})(?:[-\/](\d{1,2})(?:[-\/](\d{1,2})(?:[T ](\d{1,2})(?::(\d{1,2})(?::(\d{1,2})(?:[.,](\d+))?)?)?(Z|[\+\-]\d\d:?\d\d)?)?)?)?)?$/; function ro(t) { if (t instanceof Date) return t; if (U(t)) { var e = io.exec(t); if (!e) return new Date(NaN); if (e[8]) { var n = +e[4] || 0; return "Z" !== e[8].toUpperCase() && (n -= +e[8].slice(0, 3)), new Date(Date.UTC(+e[1], +(e[2] || 1) - 1, +e[3] || 1, n, +(e[5] || 0), +e[6] || 0, e[7] ? +e[7].substring(0, 3) : 0)) } return new Date(+e[1], +(e[2] || 1) - 1, +e[3] || 1, +e[4] || 0, +(e[5] || 0), +e[6] || 0, e[7] ? +e[7].substring(0, 3) : 0) } return null == t ? new Date(NaN) : new Date(Math.round(t)) } function oo(t) { return Math.pow(10, ao(t)) } function ao(t) { if (0 === t) return 0; var e = Math.floor(Math.log(t) / Math.LN10); return t / Math.pow(10, e) >= 10 && e++, e } function so(t, e) { var n = ao(t), i = Math.pow(10, n), r = t / i; return t = (e ? r < 1.5 ? 1 : r < 2.5 ? 2 : r < 4 ? 3 : r < 7 ? 5 : 10 : r < 1 ? 1 : r < 2 ? 2 : r < 3 ? 3 : r < 5 ? 5 : 10) * i, n >= -20 ? +t.toFixed(n < 0 ? -n : 0) : t } function lo(t, e) { var n = (t.length - 1) * e + 1, i = Math.floor(n), r = +t[i - 1], o = n - i; return o ? r + o * (t[i] - r) : r } function uo(t) { t.sort((function (t, e) { return s(t, e, 0) ? -1 : 1 })); for (var e = -1 / 0, n = 1, i = 0; i < t.length;) { for (var r = t[i].interval, o = t[i].close, a = 0; a < 2; a++)r[a] <= e && (r[a] = e, o[a] = a ? 1 : 1 - n), e = r[a], n = o[a]; r[0] === r[1] && o[0] * o[1] != 1 ? t.splice(i, 1) : i++ } return t; function s(t, e, n) { return t.interval[n] < e.interval[n] || t.interval[n] === e.interval[n] && (t.close[n] - e.close[n] == (n ? -1 : 1) || !n && s(t, e, 1)) } } function ho(t) { var e = parseFloat(t); return e == t && (0 !== e || !U(t) || t.indexOf("x") <= 0) ? e : NaN } function co(t) { return !isNaN(ho(t)) } function po() { return Math.round(9 * Math.random()) } function fo(t, e) { return 0 === e ? t : fo(e, t % e) } function go(t, e) { return null == t ? e : null == e ? t : t * e / fo(t, e) } "undefined" != typeof console && console.warn && console.log; function yo(t) { 0 } function vo(t) { throw new Error(t) } function mo(t, e, n) { return (e - t) * n + t } var xo = "series\0", _o = "\0_ec_\0"; function bo(t) { return t instanceof Array ? t : null == t ? [] : [t] } function wo(t, e, n) { if (t) { t[e] = t[e] || {}, t.emphasis = t.emphasis || {}, t.emphasis[e] = t.emphasis[e] || {}; for (var i = 0, r = n.length; i < r; i++) { var o = n[i]; !t.emphasis[e].hasOwnProperty(o) && t[e].hasOwnProperty(o) && (t.emphasis[e][o] = t[e][o]) } } } var So = ["fontStyle", "fontWeight", "fontSize", "fontFamily", "rich", "tag", "color", "textBorderColor", "textBorderWidth", "width", "height", "lineHeight", "align", "verticalAlign", "baseline", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY", "textShadowColor", "textShadowBlur", "textShadowOffsetX", "textShadowOffsetY", "backgroundColor", "borderColor", "borderWidth", "borderRadius", "padding"]; function Mo(t) { return !q(t) || Y(t) || t instanceof Date ? t : t.value } function Io(t) { return q(t) && !(t instanceof Array) } function To(t, e, n) { var i = "normalMerge" === n, r = "replaceMerge" === n, o = "replaceAll" === n; t = t || [], e = (e || []).slice(); var a = yt(); E(e, (function (t, n) { q(t) || (e[n] = null) })); var s, l, u = function (t, e, n) { var i = []; if ("replaceAll" === n) return i; for (var r = 0; r < t.length; r++) { var o = t[r]; o && null != o.id && e.set(o.id, r), i.push({ existing: "replaceMerge" === n || Lo(o) ? null : o, newOption: null, keyInfo: null, brandNew: null }) } return i }(t, a, n); return (i || r) && function (t, e, n, i) { E(i, (function (r, o) { if (r && null != r.id) { var a = Do(r.id), s = n.get(a); if (null != s) { var l = t[s]; lt(!l.newOption, 'Duplicated option on id "' + a + '".'), l.newOption = r, l.existing = e[s], i[o] = null } } })) }(u, t, a, e), i && function (t, e) { E(e, (function (n, i) { if (n && null != n.name) for (var r = 0; r < t.length; r++) { var o = t[r].existing; if (!t[r].newOption && o && (null == o.id || null == n.id) && !Lo(n) && !Lo(o) && Co("name", o, n)) return t[r].newOption = n, void (e[i] = null) } })) }(u, e), i || r ? function (t, e, n) { E(e, (function (e) { if (e) { for (var i, r = 0; (i = t[r]) && (i.newOption || Lo(i.existing) || i.existing && null != e.id && !Co("id", e, i.existing));)r++; i ? (i.newOption = e, i.brandNew = n) : t.push({ newOption: e, brandNew: n, existing: null, keyInfo: null }), r++ } })) }(u, e, r) : o && function (t, e) { E(e, (function (e) { t.push({ newOption: e, brandNew: !0, existing: null, keyInfo: null }) })) }(u, e), s = u, l = yt(), E(s, (function (t) { var e = t.existing; e && l.set(e.id, t) })), E(s, (function (t) { var e = t.newOption; lt(!e || null == e.id || !l.get(e.id) || l.get(e.id) === t, "id duplicates: " + (e && e.id)), e && null != e.id && l.set(e.id, t), !t.keyInfo && (t.keyInfo = {}) })), E(s, (function (t, e) { var n = t.existing, i = t.newOption, r = t.keyInfo; if (q(i)) { if (r.name = null != i.name ? Do(i.name) : n ? n.name : xo + e, n) r.id = Do(n.id); else if (null != i.id) r.id = Do(i.id); else { var o = 0; do { r.id = "\0" + r.name + "\0" + o++ } while (l.get(r.id)) } l.set(r.id, t) } })), u } function Co(t, e, n) { var i = Ao(e[t], null), r = Ao(n[t], null); return null != i && null != r && i === r } function Do(t) { return Ao(t, "") } function Ao(t, e) { return null == t ? e : U(t) ? t : j(t) || Z(t) ? t + "" : e } function ko(t) { var e = t.name; return !(!e || !e.indexOf(xo)) } function Lo(t) { return t && null != t.id && 0 === Do(t.id).indexOf(_o) } function Po(t, e) { return null != e.dataIndexInside ? e.dataIndexInside : null != e.dataIndex ? Y(e.dataIndex) ? z(e.dataIndex, (function (e) { return t.indexOfRawIndex(e) })) : t.indexOfRawIndex(e.dataIndex) : null != e.name ? Y(e.name) ? z(e.name, (function (e) { return t.indexOfName(e) })) : t.indexOfName(e.name) : void 0 } function Oo() { var t = "__ec_inner_" + Ro++; return function (e) { return e[t] || (e[t] = {}) } } var Ro = po(); function No(t, e, n) { var i = Eo(e, n), r = i.mainTypeSpecified, o = i.queryOptionMap, a = i.others, s = n ? n.defaultMainType : null; return !r && s && o.set(s, {}), o.each((function (e, i) { var r = Bo(t, i, e, { useDefault: s === i, enableAll: !n || null == n.enableAll || n.enableAll, enableNone: !n || null == n.enableNone || n.enableNone }); a[i + "Models"] = r.models, a[i + "Model"] = r.models[0] })), a } function Eo(t, e) { var n; if (U(t)) { var i = {}; i[t + "Index"] = 0, n = i } else n = t; var r = yt(), o = {}, a = !1; return E(n, (function (t, n) { if ("dataIndex" !== n && "dataIndexInside" !== n) { var i = n.match(/^(\w+)(Index|Id|Name)$/) || [], s = i[1], l = (i[2] || "").toLowerCase(); if (s && l && !(e && e.includeMainTypes && P(e.includeMainTypes, s) < 0)) a = a || !!s, (r.get(s) || r.set(s, {}))[l] = t } else o[n] = t })), { mainTypeSpecified: a, queryOptionMap: r, others: o } } var zo = { useDefault: !0, enableAll: !1, enableNone: !1 }, Vo = { useDefault: !1, enableAll: !0, enableNone: !0 }; function Bo(t, e, n, i) { i = i || zo; var r = n.index, o = n.id, a = n.name, s = { models: null, specified: null != r || null != o || null != a }; if (!s.specified) { var l = void 0; return s.models = i.useDefault && (l = t.getComponent(e)) ? [l] : [], s } return "none" === r || !1 === r ? (lt(i.enableNone, '`"none"` or `false` is not a valid value on index option.'), s.models = [], s) : ("all" === r && (lt(i.enableAll, '`"all"` is not a valid value on index option.'), r = o = a = null), s.models = t.queryComponents({ mainType: e, index: r, id: o, name: a }), s) } function Fo(t, e, n) { t.setAttribute ? t.setAttribute(e, n) : t[e] = n } function Go(t, e) { var n = yt(), i = []; return E(t, (function (t) { var r = e(t); (n.get(r) || (i.push(r), n.set(r, []))).push(t) })), { keys: i, buckets: n } } function Wo(t, e, n, i, r) { var o = null == e || "auto" === e; if (null == i) return i; if (j(i)) return Zr(f = mo(n || 0, i, r), o ? Math.max(qr(n || 0), qr(i)) : e); if (U(i)) return r < 1 ? n : i; for (var a = [], s = n, l = i, u = Math.max(s ? s.length : 0, l.length), h = 0; h < u; ++h) { var c = t.getDimensionInfo(h); if (c && "ordinal" === c.type) a[h] = (r < 1 && s ? s : l)[h]; else { var p = s && s[h] ? s[h] : 0, d = l[h], f = mo(p, d, r); a[h] = Zr(f, o ? Math.max(qr(p), qr(d)) : e) } } return a } var Ho = "___EC__COMPONENT__CONTAINER___", Yo = "___EC__EXTENDED_CLASS___"; function Xo(t) { var e = { main: "", sub: "" }; if (t) { var n = t.split("."); e.main = n[0] || "", e.sub = n[1] || "" } return e } function Uo(t, e) { t.$constructor = t, t.extend = function (t) { var e, i, r = this; return X(i = r) && /^class\s/.test(Function.prototype.toString.call(i)) ? e = function (t) { function e() { return t.apply(this, arguments) || this } return n(e, t), e }(r) : (e = function () { (t.$constructor || r).apply(this, arguments) }, O(e, this)), A(e.prototype, t), e[Yo] = !0, e.extend = this.extend, e.superCall = qo, e.superApply = Ko, e.superClass = r, e } } function Zo(t, e) { t.extend = e.extend } var jo = Math.round(10 * Math.random()); function qo(t, e) { for (var n = [], i = 2; i < arguments.length; i++)n[i - 2] = arguments[i]; return this.superClass.prototype[e].apply(t, n) } function Ko(t, e, n) { return this.superClass.prototype[e].apply(t, n) } function $o(t) { var e = {}; t.registerClass = function (t) { var n, i = t.type || t.prototype.type; if (i) { lt(/^[a-zA-Z0-9_]+([.][a-zA-Z0-9_]+)?$/.test(n = i), 'componentType "' + n + '" illegal'), t.prototype.type = i; var r = Xo(i); if (r.sub) { if (r.sub !== Ho) { var o = function (t) { var n = e[t.main]; n && n[Ho] || ((n = e[t.main] = {})[Ho] = !0); return n }(r); o[r.sub] = t } } else e[r.main] = t } return t }, t.getClass = function (t, n, i) { var r = e[t]; if (r && r[Ho] && (r = n ? r[n] : null), i && !r) throw new Error(n ? "Component " + t + "." + (n || "") + " is used but not imported." : t + ".type should be specified."); return r }, t.getClassesByMainType = function (t) { var n = Xo(t), i = [], r = e[n.main]; return r && r[Ho] ? E(r, (function (t, e) { e !== Ho && i.push(t) })) : i.push(r), i }, t.hasClass = function (t) { var n = Xo(t); return !!e[n.main] }, t.getAllClassMainTypes = function () { var t = []; return E(e, (function (e, n) { t.push(n) })), t }, t.hasSubTypes = function (t) { var n = Xo(t), i = e[n.main]; return i && i[Ho] } } function Jo(t, e) { for (var n = 0; n < t.length; n++)t[n][1] || (t[n][1] = t[n][0]); return e = e || !1, function (n, i, r) { for (var o = {}, a = 0; a < t.length; a++) { var s = t[a][1]; if (!(i && P(i, s) >= 0 || r && P(r, s) < 0)) { var l = n.getShallow(s, e); null != l && (o[t[a][0]] = l) } } return o } } var Qo = Jo([["fill", "color"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["opacity"], ["shadowColor"]]), ta = function () { function t() { } return t.prototype.getAreaStyle = function (t, e) { return Qo(this, t, e) }, t }(), ea = new En(50); function na(t) { if ("string" == typeof t) { var e = ea.get(t); return e && e.image } return t } function ia(t, e, n, i, r) { if (t) { if ("string" == typeof t) { if (e && e.__zrImageSrc === t || !n) return e; var o = ea.get(t), a = { hostEl: n, cb: i, cbPayload: r }; return o ? !oa(e = o.image) && o.pending.push(a) : ((e = h.loadImage(t, ra, ra)).__zrImageSrc = t, ea.put(t, e.__cachedImgObj = { image: e, pending: [a] })), e } return t } return e } function ra() { var t = this.__cachedImgObj; this.onload = this.onerror = this.__cachedImgObj = null; for (var e = 0; e < t.pending.length; e++) { var n = t.pending[e], i = n.cb; i && i(this, n.cbPayload), n.hostEl.dirty() } t.pending.length = 0 } function oa(t) { return t && t.width && t.height } var aa = /\{([a-zA-Z0-9_]+)\|([^}]*)\}/g; function sa(t, e, n, i, r) { if (!e) return ""; var o = (t + "").split("\n"); r = la(e, n, i, r); for (var a = 0, s = o.length; a < s; a++)o[a] = ua(o[a], r); return o.join("\n") } function la(t, e, n, i) { var r = A({}, i = i || {}); r.font = e, n = rt(n, "..."), r.maxIterations = rt(i.maxIterations, 2); var o = r.minChar = rt(i.minChar, 0); r.cnCharWidth = xr("国", e); var a = r.ascCharWidth = xr("a", e); r.placeholder = rt(i.placeholder, ""); for (var s = t = Math.max(0, t - 1), l = 0; l < o && s >= a; l++)s -= a; var u = xr(n, e); return u > s && (n = "", u = 0), s = t - u, r.ellipsis = n, r.ellipsisWidth = u, r.contentWidth = s, r.containerWidth = t, r } function ua(t, e) { var n = e.containerWidth, i = e.font, r = e.contentWidth; if (!n) return ""; var o = xr(t, i); if (o <= n) return t; for (var a = 0; ; a++) { if (o <= r || a >= e.maxIterations) { t += e.ellipsis; break } var s = 0 === a ? ha(t, r, e.ascCharWidth, e.cnCharWidth) : o > 0 ? Math.floor(t.length * r / o) : 0; o = xr(t = t.substr(0, s), i) } return "" === t && (t = e.placeholder), t } function ha(t, e, n, i) { for (var r = 0, o = 0, a = t.length; o < a && r < e; o++) { var s = t.charCodeAt(o); r += 0 <= s && s <= 127 ? n : i } return o } var ca = function () { }, pa = function (t) { this.tokens = [], t && (this.tokens = t) }, da = function () { this.width = 0, this.height = 0, this.contentWidth = 0, this.contentHeight = 0, this.outerWidth = 0, this.outerHeight = 0, this.lines = [] }; function fa(t, e, n, i, r) { var o, a, s = "" === e, l = r && n.rich[r] || {}, u = t.lines, h = l.font || n.font, c = !1; if (i) { var p = l.padding, d = p ? p[1] + p[3] : 0; if (null != l.width && "auto" !== l.width) { var f = Ir(l.width, i.width) + d; u.length > 0 && f + i.accumWidth > i.width && (o = e.split("\n"), c = !0), i.accumWidth = f } else { var g = va(e, h, i.width, i.breakAll, i.accumWidth); i.accumWidth = g.accumWidth + d, a = g.linesWidths, o = g.lines } } else o = e.split("\n"); for (var y = 0; y < o.length; y++) { var v = o[y], m = new ca; if (m.styleName = r, m.text = v, m.isLineHolder = !v && !s, "number" == typeof l.width ? m.width = l.width : m.width = a ? a[y] : xr(v, h), y || c) u.push(new pa([m])); else { var x = (u[u.length - 1] || (u[0] = new pa)).tokens, _ = x.length; 1 === _ && x[0].isLineHolder ? x[0] = m : (v || !_ || s) && x.push(m) } } } var ga = V(",&?/;] ".split(""), (function (t, e) { return t[e] = !0, t }), {}); function ya(t) { return !function (t) { var e = t.charCodeAt(0); return e >= 32 && e <= 591 || e >= 880 && e <= 4351 || e >= 4608 && e <= 5119 || e >= 7680 && e <= 8303 }(t) || !!ga[t] } function va(t, e, n, i, r) { for (var o = [], a = [], s = "", l = "", u = 0, h = 0, c = 0; c < t.length; c++) { var p = t.charAt(c); if ("\n" !== p) { var d = xr(p, e), f = !i && !ya(p); (o.length ? h + d > n : r + h + d > n) ? h ? (s || l) && (f ? (s || (s = l, l = "", h = u = 0), o.push(s), a.push(h - u), l += p, s = "", h = u += d) : (l && (s += l, l = "", u = 0), o.push(s), a.push(h), s = p, h = d)) : f ? (o.push(l), a.push(u), l = p, u = d) : (o.push(p), a.push(d)) : (h += d, f ? (l += p, u += d) : (l && (s += l, l = "", u = 0), s += p)) } else l && (s += l, h += u), o.push(s), a.push(h), s = "", l = "", u = 0, h = 0 } return o.length || s || (s = t, l = "", u = 0), l && (s += l), s && (o.push(s), a.push(h)), 1 === o.length && (h += r), { accumWidth: h, lines: o, linesWidths: a } } var ma = "__zr_style_" + Math.round(10 * Math.random()), xa = { shadowBlur: 0, shadowOffsetX: 0, shadowOffsetY: 0, shadowColor: "#000", opacity: 1, blend: "source-over" }, _a = { style: { shadowBlur: !0, shadowOffsetX: !0, shadowOffsetY: !0, shadowColor: !0, opacity: !0 } }; xa[ma] = !0; var ba = ["z", "z2", "invisible"], wa = ["invisible"], Sa = function (t) { function e(e) { return t.call(this, e) || this } var i; return n(e, t), e.prototype._init = function (e) { for (var n = G(e), i = 0; i < n.length; i++) { var r = n[i]; "style" === r ? this.useStyle(e[r]) : t.prototype.attrKV.call(this, r, e[r]) } this.style || this.useStyle({}) }, e.prototype.beforeBrush = function () { }, e.prototype.afterBrush = function () { }, e.prototype.innerBeforeBrush = function () { }, e.prototype.innerAfterBrush = function () { }, e.prototype.shouldBePainted = function (t, e, n, i) { var r = this.transform; if (this.ignore || this.invisible || 0 === this.style.opacity || this.culling && function (t, e, n) { Ma.copy(t.getBoundingRect()), t.transform && Ma.applyTransform(t.transform); return Ia.width = e, Ia.height = n, !Ma.intersect(Ia) }(this, t, e) || r && !r[0] && !r[3]) return !1; if (n && this.__clipPaths) for (var o = 0; o < this.__clipPaths.length; ++o)if (this.__clipPaths[o].isZeroArea()) return !1; if (i && this.parent) for (var a = this.parent; a;) { if (a.ignore) return !1; a = a.parent } return !0 }, e.prototype.contain = function (t, e) { return this.rectContain(t, e) }, e.prototype.traverse = function (t, e) { t.call(e, this) }, e.prototype.rectContain = function (t, e) { var n = this.transformCoordToLocal(t, e); return this.getBoundingRect().contain(n[0], n[1]) }, e.prototype.getPaintRect = function () { var t = this._paintRect; if (!this._paintRect || this.__dirty) { var e = this.transform, n = this.getBoundingRect(), i = this.style, r = i.shadowBlur || 0, o = i.shadowOffsetX || 0, a = i.shadowOffsetY || 0; t = this._paintRect || (this._paintRect = new ze(0, 0, 0, 0)), e ? ze.applyTransform(t, n, e) : t.copy(n), (r || o || a) && (t.width += 2 * r + Math.abs(o), t.height += 2 * r + Math.abs(a), t.x = Math.min(t.x, t.x + o - r), t.y = Math.min(t.y, t.y + a - r)); var s = this.dirtyRectTolerance; t.isZero() || (t.x = Math.floor(t.x - s), t.y = Math.floor(t.y - s), t.width = Math.ceil(t.width + 1 + 2 * s), t.height = Math.ceil(t.height + 1 + 2 * s)) } return t }, e.prototype.setPrevPaintRect = function (t) { t ? (this._prevPaintRect = this._prevPaintRect || new ze(0, 0, 0, 0), this._prevPaintRect.copy(t)) : this._prevPaintRect = null }, e.prototype.getPrevPaintRect = function () { return this._prevPaintRect }, e.prototype.animateStyle = function (t) { return this.animate("style", t) }, e.prototype.updateDuringAnimation = function (t) { "style" === t ? this.dirtyStyle() : this.markRedraw() }, e.prototype.attrKV = function (e, n) { "style" !== e ? t.prototype.attrKV.call(this, e, n) : this.style ? this.setStyle(n) : this.useStyle(n) }, e.prototype.setStyle = function (t, e) { return "string" == typeof t ? this.style[t] = e : A(this.style, t), this.dirtyStyle(), this }, e.prototype.dirtyStyle = function (t) { t || this.markRedraw(), this.__dirty |= 2, this._rect && (this._rect = null) }, e.prototype.dirty = function () { this.dirtyStyle() }, e.prototype.styleChanged = function () { return !!(2 & this.__dirty) }, e.prototype.styleUpdated = function () { this.__dirty &= -3 }, e.prototype.createStyle = function (t) { return mt(xa, t) }, e.prototype.useStyle = function (t) { t[ma] || (t = this.createStyle(t)), this.__inHover ? this.__hoverStyle = t : this.style = t, this.dirtyStyle() }, e.prototype.isStyleObject = function (t) { return t[ma] }, e.prototype._innerSaveToNormal = function (e) { t.prototype._innerSaveToNormal.call(this, e); var n = this._normalState; e.style && !n.style && (n.style = this._mergeStyle(this.createStyle(), this.style)), this._savePrimaryToNormal(e, n, ba) }, e.prototype._applyStateObj = function (e, n, i, r, o, a) { t.prototype._applyStateObj.call(this, e, n, i, r, o, a); var s, l = !(n && r); if (n && n.style ? o ? r ? s = n.style : (s = this._mergeStyle(this.createStyle(), i.style), this._mergeStyle(s, n.style)) : (s = this._mergeStyle(this.createStyle(), r ? this.style : i.style), this._mergeStyle(s, n.style)) : l && (s = i.style), s) if (o) { var u = this.style; if (this.style = this.createStyle(l ? {} : u), l) for (var h = G(u), c = 0; c < h.length; c++) { (d = h[c]) in s && (s[d] = s[d], this.style[d] = u[d]) } var p = G(s); for (c = 0; c < p.length; c++) { var d = p[c]; this.style[d] = this.style[d] } this._transitionState(e, { style: s }, a, this.getAnimationStyleProps()) } else this.useStyle(s); var f = this.__inHover ? wa : ba; for (c = 0; c < f.length; c++) { d = f[c]; n && null != n[d] ? this[d] = n[d] : l && null != i[d] && (this[d] = i[d]) } }, e.prototype._mergeStates = function (e) { for (var n, i = t.prototype._mergeStates.call(this, e), r = 0; r < e.length; r++) { var o = e[r]; o.style && (n = n || {}, this._mergeStyle(n, o.style)) } return n && (i.style = n), i }, e.prototype._mergeStyle = function (t, e) { return A(t, e), t }, e.prototype.getAnimationStyleProps = function () { return _a }, e.initDefaultProps = ((i = e.prototype).type = "displayable", i.invisible = !1, i.z = 0, i.z2 = 0, i.zlevel = 0, i.culling = !1, i.cursor = "pointer", i.rectHover = !1, i.incremental = !1, i._rect = null, i.dirtyRectTolerance = 0, void (i.__dirty = 3)), e }(Pr), Ma = new ze(0, 0, 0, 0), Ia = new ze(0, 0, 0, 0); var Ta = Math.min, Ca = Math.max, Da = Math.sin, Aa = Math.cos, ka = 2 * Math.PI, La = Mt(), Pa = Mt(), Oa = Mt(); function Ra(t, e, n) { if (0 !== t.length) { for (var i = t[0], r = i[0], o = i[0], a = i[1], s = i[1], l = 1; l < t.length; l++)i = t[l], r = Ta(r, i[0]), o = Ca(o, i[0]), a = Ta(a, i[1]), s = Ca(s, i[1]); e[0] = r, e[1] = a, n[0] = o, n[1] = s } } function Na(t, e, n, i, r, o) { r[0] = Ta(t, n), r[1] = Ta(e, i), o[0] = Ca(t, n), o[1] = Ca(e, i) } var Ea = [], za = []; function Va(t, e, n, i, r, o, a, s, l, u) { var h = bn, c = mn, p = h(t, n, r, a, Ea); l[0] = 1 / 0, l[1] = 1 / 0, u[0] = -1 / 0, u[1] = -1 / 0; for (var d = 0; d < p; d++) { var f = c(t, n, r, a, Ea[d]); l[0] = Ta(f, l[0]), u[0] = Ca(f, u[0]) } p = h(e, i, o, s, za); for (d = 0; d < p; d++) { var g = c(e, i, o, s, za[d]); l[1] = Ta(g, l[1]), u[1] = Ca(g, u[1]) } l[0] = Ta(t, l[0]), u[0] = Ca(t, u[0]), l[0] = Ta(a, l[0]), u[0] = Ca(a, u[0]), l[1] = Ta(e, l[1]), u[1] = Ca(e, u[1]), l[1] = Ta(s, l[1]), u[1] = Ca(s, u[1]) } function Ba(t, e, n, i, r, o, a, s) { var l = Cn, u = In, h = Ca(Ta(l(t, n, r), 1), 0), c = Ca(Ta(l(e, i, o), 1), 0), p = u(t, n, r, h), d = u(e, i, o, c); a[0] = Ta(t, r, p), a[1] = Ta(e, o, d), s[0] = Ca(t, r, p), s[1] = Ca(e, o, d) } function Fa(t, e, n, i, r, o, a, s, l) { var u = Ht, h = Yt, c = Math.abs(r - o); if (c % ka < 1e-4 && c > 1e-4) return s[0] = t - n, s[1] = e - i, l[0] = t + n, void (l[1] = e + i); if (La[0] = Aa(r) * n + t, La[1] = Da(r) * i + e, Pa[0] = Aa(o) * n + t, Pa[1] = Da(o) * i + e, u(s, La, Pa), h(l, La, Pa), (r %= ka) < 0 && (r += ka), (o %= ka) < 0 && (o += ka), r > o && !a ? o += ka : r < o && a && (r += ka), a) { var p = o; o = r, r = p } for (var d = 0; d < o; d += Math.PI / 2)d > r && (Oa[0] = Aa(d) * n + t, Oa[1] = Da(d) * i + e, u(s, Oa, s), h(l, Oa, l)) } var Ga = { M: 1, L: 2, C: 3, Q: 4, A: 5, Z: 6, R: 7 }, Wa = [], Ha = [], Ya = [], Xa = [], Ua = [], Za = [], ja = Math.min, qa = Math.max, Ka = Math.cos, $a = Math.sin, Ja = Math.abs, Qa = Math.PI, ts = 2 * Qa, es = "undefined" != typeof Float32Array, ns = []; function is(t) { return Math.round(t / Qa * 1e8) / 1e8 % 2 * Qa } function rs(t, e) { var n = is(t[0]); n < 0 && (n += ts); var i = n - t[0], r = t[1]; r += i, !e && r - n >= ts ? r = n + ts : e && n - r >= ts ? r = n - ts : !e && n > r ? r = n + (ts - is(n - r)) : e && n < r && (r = n - (ts - is(r - n))), t[0] = n, t[1] = r } var os = function () { function t(t) { this.dpr = 1, this._xi = 0, this._yi = 0, this._x0 = 0, this._y0 = 0, this._len = 0, t && (this._saveData = !1), this._saveData && (this.data = []) } return t.prototype.increaseVersion = function () { this._version++ }, t.prototype.getVersion = function () { return this._version }, t.prototype.setScale = function (t, e, n) { (n = n || 0) > 0 && (this._ux = Ja(n / or / t) || 0, this._uy = Ja(n / or / e) || 0) }, t.prototype.setDPR = function (t) { this.dpr = t }, t.prototype.setContext = function (t) { this._ctx = t }, t.prototype.getContext = function () { return this._ctx }, t.prototype.beginPath = function () { return this._ctx && this._ctx.beginPath(), this.reset(), this }, t.prototype.reset = function () { this._saveData && (this._len = 0), this._pathSegLen && (this._pathSegLen = null, this._pathLen = 0), this._version++ }, t.prototype.moveTo = function (t, e) { return this._drawPendingPt(), this.addData(Ga.M, t, e), this._ctx && this._ctx.moveTo(t, e), this._x0 = t, this._y0 = e, this._xi = t, this._yi = e, this }, t.prototype.lineTo = function (t, e) { var n = Ja(t - this._xi), i = Ja(e - this._yi), r = n > this._ux || i > this._uy; if (this.addData(Ga.L, t, e), this._ctx && r && this._ctx.lineTo(t, e), r) this._xi = t, this._yi = e, this._pendingPtDist = 0; else { var o = n * n + i * i; o > this._pendingPtDist && (this._pendingPtX = t, this._pendingPtY = e, this._pendingPtDist = o) } return this }, t.prototype.bezierCurveTo = function (t, e, n, i, r, o) { return this._drawPendingPt(), this.addData(Ga.C, t, e, n, i, r, o), this._ctx && this._ctx.bezierCurveTo(t, e, n, i, r, o), this._xi = r, this._yi = o, this }, t.prototype.quadraticCurveTo = function (t, e, n, i) { return this._drawPendingPt(), this.addData(Ga.Q, t, e, n, i), this._ctx && this._ctx.quadraticCurveTo(t, e, n, i), this._xi = n, this._yi = i, this }, t.prototype.arc = function (t, e, n, i, r, o) { this._drawPendingPt(), ns[0] = i, ns[1] = r, rs(ns, o), i = ns[0]; var a = (r = ns[1]) - i; return this.addData(Ga.A, t, e, n, n, i, a, 0, o ? 0 : 1), this._ctx && this._ctx.arc(t, e, n, i, r, o), this._xi = Ka(r) * n + t, this._yi = $a(r) * n + e, this }, t.prototype.arcTo = function (t, e, n, i, r) { return this._drawPendingPt(), this._ctx && this._ctx.arcTo(t, e, n, i, r), this }, t.prototype.rect = function (t, e, n, i) { return this._drawPendingPt(), this._ctx && this._ctx.rect(t, e, n, i), this.addData(Ga.R, t, e, n, i), this }, t.prototype.closePath = function () { this._drawPendingPt(), this.addData(Ga.Z); var t = this._ctx, e = this._x0, n = this._y0; return t && t.closePath(), this._xi = e, this._yi = n, this }, t.prototype.fill = function (t) { t && t.fill(), this.toStatic() }, t.prototype.stroke = function (t) { t && t.stroke(), this.toStatic() }, t.prototype.len = function () { return this._len }, t.prototype.setData = function (t) { var e = t.length; this.data && this.data.length === e || !es || (this.data = new Float32Array(e)); for (var n = 0; n < e; n++)this.data[n] = t[n]; this._len = e }, t.prototype.appendPath = function (t) { t instanceof Array || (t = [t]); for (var e = t.length, n = 0, i = this._len, r = 0; r < e; r++)n += t[r].len(); es && this.data instanceof Float32Array && (this.data = new Float32Array(i + n)); for (r = 0; r < e; r++)for (var o = t[r].data, a = 0; a < o.length; a++)this.data[i++] = o[a]; this._len = i }, t.prototype.addData = function (t, e, n, i, r, o, a, s, l) { if (this._saveData) { var u = this.data; this._len + arguments.length > u.length && (this._expandData(), u = this.data); for (var h = 0; h < arguments.length; h++)u[this._len++] = arguments[h] } }, t.prototype._drawPendingPt = function () { this._pendingPtDist > 0 && (this._ctx && this._ctx.lineTo(this._pendingPtX, this._pendingPtY), this._pendingPtDist = 0) }, t.prototype._expandData = function () { if (!(this.data instanceof Array)) { for (var t = [], e = 0; e < this._len; e++)t[e] = this.data[e]; this.data = t } }, t.prototype.toStatic = function () { if (this._saveData) { this._drawPendingPt(); var t = this.data; t instanceof Array && (t.length = this._len, es && this._len > 11 && (this.data = new Float32Array(t))) } }, t.prototype.getBoundingRect = function () { Ya[0] = Ya[1] = Ua[0] = Ua[1] = Number.MAX_VALUE, Xa[0] = Xa[1] = Za[0] = Za[1] = -Number.MAX_VALUE; var t, e = this.data, n = 0, i = 0, r = 0, o = 0; for (t = 0; t < this._len;) { var a = e[t++], s = 1 === t; switch (s && (r = n = e[t], o = i = e[t + 1]), a) { case Ga.M: n = r = e[t++], i = o = e[t++], Ua[0] = r, Ua[1] = o, Za[0] = r, Za[1] = o; break; case Ga.L: Na(n, i, e[t], e[t + 1], Ua, Za), n = e[t++], i = e[t++]; break; case Ga.C: Va(n, i, e[t++], e[t++], e[t++], e[t++], e[t], e[t + 1], Ua, Za), n = e[t++], i = e[t++]; break; case Ga.Q: Ba(n, i, e[t++], e[t++], e[t], e[t + 1], Ua, Za), n = e[t++], i = e[t++]; break; case Ga.A: var l = e[t++], u = e[t++], h = e[t++], c = e[t++], p = e[t++], d = e[t++] + p; t += 1; var f = !e[t++]; s && (r = Ka(p) * h + l, o = $a(p) * c + u), Fa(l, u, h, c, p, d, f, Ua, Za), n = Ka(d) * h + l, i = $a(d) * c + u; break; case Ga.R: Na(r = n = e[t++], o = i = e[t++], r + e[t++], o + e[t++], Ua, Za); break; case Ga.Z: n = r, i = o }Ht(Ya, Ya, Ua), Yt(Xa, Xa, Za) } return 0 === t && (Ya[0] = Ya[1] = Xa[0] = Xa[1] = 0), new ze(Ya[0], Ya[1], Xa[0] - Ya[0], Xa[1] - Ya[1]) }, t.prototype._calculateLength = function () { var t = this.data, e = this._len, n = this._ux, i = this._uy, r = 0, o = 0, a = 0, s = 0; this._pathSegLen || (this._pathSegLen = []); for (var l = this._pathSegLen, u = 0, h = 0, c = 0; c < e;) { var p = t[c++], d = 1 === c; d && (a = r = t[c], s = o = t[c + 1]); var f = -1; switch (p) { case Ga.M: r = a = t[c++], o = s = t[c++]; break; case Ga.L: var g = t[c++], y = (x = t[c++]) - o; (Ja(A = g - r) > n || Ja(y) > i || c === e - 1) && (f = Math.sqrt(A * A + y * y), r = g, o = x); break; case Ga.C: var v = t[c++], m = t[c++], x = (g = t[c++], t[c++]), _ = t[c++], b = t[c++]; f = Mn(r, o, v, m, g, x, _, b, 10), r = _, o = b; break; case Ga.Q: f = kn(r, o, v = t[c++], m = t[c++], g = t[c++], x = t[c++], 10), r = g, o = x; break; case Ga.A: var w = t[c++], S = t[c++], M = t[c++], I = t[c++], T = t[c++], C = t[c++], D = C + T; c += 1; t[c++]; d && (a = Ka(T) * M + w, s = $a(T) * I + S), f = qa(M, I) * ja(ts, Math.abs(C)), r = Ka(D) * M + w, o = $a(D) * I + S; break; case Ga.R: a = r = t[c++], s = o = t[c++], f = 2 * t[c++] + 2 * t[c++]; break; case Ga.Z: var A = a - r; y = s - o; f = Math.sqrt(A * A + y * y), r = a, o = s }f >= 0 && (l[h++] = f, u += f) } return this._pathLen = u, u }, t.prototype.rebuildPath = function (t, e) { var n, i, r, o, a, s, l, u, h, c, p = this.data, d = this._ux, f = this._uy, g = this._len, y = e < 1, v = 0, m = 0, x = 0; if (!y || (this._pathSegLen || this._calculateLength(), l = this._pathSegLen, u = e * this._pathLen)) t: for (var _ = 0; _ < g;) { var b = p[_++], w = 1 === _; switch (w && (n = r = p[_], i = o = p[_ + 1]), b !== Ga.L && x > 0 && (t.lineTo(h, c), x = 0), b) { case Ga.M: n = r = p[_++], i = o = p[_++], t.moveTo(r, o); break; case Ga.L: a = p[_++], s = p[_++]; var S = Ja(a - r), M = Ja(s - o); if (S > d || M > f) { if (y) { if (v + (j = l[m++]) > u) { var I = (u - v) / j; t.lineTo(r * (1 - I) + a * I, o * (1 - I) + s * I); break t } v += j } t.lineTo(a, s), r = a, o = s, x = 0 } else { var T = S * S + M * M; T > x && (h = a, c = s, x = T) } break; case Ga.C: var C = p[_++], D = p[_++], A = p[_++], k = p[_++], L = p[_++], P = p[_++]; if (y) { if (v + (j = l[m++]) > u) { wn(r, C, A, L, I = (u - v) / j, Wa), wn(o, D, k, P, I, Ha), t.bezierCurveTo(Wa[1], Ha[1], Wa[2], Ha[2], Wa[3], Ha[3]); break t } v += j } t.bezierCurveTo(C, D, A, k, L, P), r = L, o = P; break; case Ga.Q: C = p[_++], D = p[_++], A = p[_++], k = p[_++]; if (y) { if (v + (j = l[m++]) > u) { Dn(r, C, A, I = (u - v) / j, Wa), Dn(o, D, k, I, Ha), t.quadraticCurveTo(Wa[1], Ha[1], Wa[2], Ha[2]); break t } v += j } t.quadraticCurveTo(C, D, A, k), r = A, o = k; break; case Ga.A: var O = p[_++], R = p[_++], N = p[_++], E = p[_++], z = p[_++], V = p[_++], B = p[_++], F = !p[_++], G = N > E ? N : E, W = Ja(N - E) > .001, H = z + V, Y = !1; if (y) v + (j = l[m++]) > u && (H = z + V * (u - v) / j, Y = !0), v += j; if (W && t.ellipse ? t.ellipse(O, R, N, E, B, z, H, F) : t.arc(O, R, G, z, H, F), Y) break t; w && (n = Ka(z) * N + O, i = $a(z) * E + R), r = Ka(H) * N + O, o = $a(H) * E + R; break; case Ga.R: n = r = p[_], i = o = p[_ + 1], a = p[_++], s = p[_++]; var X = p[_++], U = p[_++]; if (y) { if (v + (j = l[m++]) > u) { var Z = u - v; t.moveTo(a, s), t.lineTo(a + ja(Z, X), s), (Z -= X) > 0 && t.lineTo(a + X, s + ja(Z, U)), (Z -= U) > 0 && t.lineTo(a + qa(X - Z, 0), s + U), (Z -= X) > 0 && t.lineTo(a, s + qa(U - Z, 0)); break t } v += j } t.rect(a, s, X, U); break; case Ga.Z: if (y) { var j; if (v + (j = l[m++]) > u) { I = (u - v) / j; t.lineTo(r * (1 - I) + n * I, o * (1 - I) + i * I); break t } v += j } t.closePath(), r = n, o = i } } }, t.prototype.clone = function () { var e = new t, n = this.data; return e.data = n.slice ? n.slice() : Array.prototype.slice.call(n), e._len = this._len, e }, t.CMD = Ga, t.initDefaultProps = function () { var e = t.prototype; e._saveData = !0, e._ux = 0, e._uy = 0, e._pendingPtDist = 0, e._version = 0 }(), t }(); function as(t, e, n, i, r, o, a) { if (0 === r) return !1; var s = r, l = 0; if (a > e + s && a > i + s || a < e - s && a < i - s || o > t + s && o > n + s || o < t - s && o < n - s) return !1; if (t === n) return Math.abs(o - t) <= s / 2; var u = (l = (e - i) / (t - n)) * o - a + (t * i - n * e) / (t - n); return u * u / (l * l + 1) <= s / 2 * s / 2 } function ss(t, e, n, i, r, o, a, s, l, u, h) { if (0 === l) return !1; var c = l; return !(h > e + c && h > i + c && h > o + c && h > s + c || h < e - c && h < i - c && h < o - c && h < s - c || u > t + c && u > n + c && u > r + c && u > a + c || u < t - c && u < n - c && u < r - c && u < a - c) && Sn(t, e, n, i, r, o, a, s, u, h, null) <= c / 2 } function ls(t, e, n, i, r, o, a, s, l) { if (0 === a) return !1; var u = a; return !(l > e + u && l > i + u && l > o + u || l < e - u && l < i - u && l < o - u || s > t + u && s > n + u && s > r + u || s < t - u && s < n - u && s < r - u) && An(t, e, n, i, r, o, s, l, null) <= u / 2 } var us = 2 * Math.PI; function hs(t) { return (t %= us) < 0 && (t += us), t } var cs = 2 * Math.PI; function ps(t, e, n, i, r, o, a, s, l) { if (0 === a) return !1; var u = a; s -= t, l -= e; var h = Math.sqrt(s * s + l * l); if (h - u > n || h + u < n) return !1; if (Math.abs(i - r) % cs < 1e-4) return !0; if (o) { var c = i; i = hs(r), r = hs(c) } else i = hs(i), r = hs(r); i > r && (r += cs); var p = Math.atan2(l, s); return p < 0 && (p += cs), p >= i && p <= r || p + cs >= i && p + cs <= r } function ds(t, e, n, i, r, o) { if (o > e && o > i || o < e && o < i) return 0; if (i === e) return 0; var a = (o - e) / (i - e), s = i < e ? 1 : -1; 1 !== a && 0 !== a || (s = i < e ? .5 : -.5); var l = a * (n - t) + t; return l === r ? 1 / 0 : l > r ? s : 0 } var fs = os.CMD, gs = 2 * Math.PI; var ys = [-1, -1, -1], vs = [-1, -1]; function ms(t, e, n, i, r, o, a, s, l, u) { if (u > e && u > i && u > o && u > s || u < e && u < i && u < o && u < s) return 0; var h, c = _n(e, i, o, s, u, ys); if (0 === c) return 0; for (var p = 0, d = -1, f = void 0, g = void 0, y = 0; y < c; y++) { var v = ys[y], m = 0 === v || 1 === v ? .5 : 1; mn(t, n, r, a, v) < l || (d < 0 && (d = bn(e, i, o, s, vs), vs[1] < vs[0] && d > 1 && (h = void 0, h = vs[0], vs[0] = vs[1], vs[1] = h), f = mn(e, i, o, s, vs[0]), d > 1 && (g = mn(e, i, o, s, vs[1]))), 2 === d ? v < vs[0] ? p += f < e ? m : -m : v < vs[1] ? p += g < f ? m : -m : p += s < g ? m : -m : v < vs[0] ? p += f < e ? m : -m : p += s < f ? m : -m) } return p } function xs(t, e, n, i, r, o, a, s) { if (s > e && s > i && s > o || s < e && s < i && s < o) return 0; var l = function (t, e, n, i, r) { var o = t - 2 * e + n, a = 2 * (e - t), s = t - i, l = 0; if (yn(o)) vn(a) && (h = -s / a) >= 0 && h <= 1 && (r[l++] = h); else { var u = a * a - 4 * o * s; if (yn(u)) (h = -a / (2 * o)) >= 0 && h <= 1 && (r[l++] = h); else if (u > 0) { var h, c = ln(u), p = (-a - c) / (2 * o); (h = (-a + c) / (2 * o)) >= 0 && h <= 1 && (r[l++] = h), p >= 0 && p <= 1 && (r[l++] = p) } } return l }(e, i, o, s, ys); if (0 === l) return 0; var u = Cn(e, i, o); if (u >= 0 && u <= 1) { for (var h = 0, c = In(e, i, o, u), p = 0; p < l; p++) { var d = 0 === ys[p] || 1 === ys[p] ? .5 : 1; In(t, n, r, ys[p]) < a || (ys[p] < u ? h += c < e ? d : -d : h += o < c ? d : -d) } return h } d = 0 === ys[0] || 1 === ys[0] ? .5 : 1; return In(t, n, r, ys[0]) < a ? 0 : o < e ? d : -d } function _s(t, e, n, i, r, o, a, s) { if ((s -= e) > n || s < -n) return 0; var l = Math.sqrt(n * n - s * s); ys[0] = -l, ys[1] = l; var u = Math.abs(i - r); if (u < 1e-4) return 0; if (u >= gs - 1e-4) { i = 0, r = gs; var h = o ? 1 : -1; return a >= ys[0] + t && a <= ys[1] + t ? h : 0 } if (i > r) { var c = i; i = r, r = c } i < 0 && (i += gs, r += gs); for (var p = 0, d = 0; d < 2; d++) { var f = ys[d]; if (f + t > a) { var g = Math.atan2(s, f); h = o ? 1 : -1; g < 0 && (g = gs + g), (g >= i && g <= r || g + gs >= i && g + gs <= r) && (g > Math.PI / 2 && g < 1.5 * Math.PI && (h = -h), p += h) } } return p } function bs(t, e, n, i, r) { for (var o, a, s, l, u = t.data, h = t.len(), c = 0, p = 0, d = 0, f = 0, g = 0, y = 0; y < h;) { var v = u[y++], m = 1 === y; switch (v === fs.M && y > 1 && (n || (c += ds(p, d, f, g, i, r))), m && (f = p = u[y], g = d = u[y + 1]), v) { case fs.M: p = f = u[y++], d = g = u[y++]; break; case fs.L: if (n) { if (as(p, d, u[y], u[y + 1], e, i, r)) return !0 } else c += ds(p, d, u[y], u[y + 1], i, r) || 0; p = u[y++], d = u[y++]; break; case fs.C: if (n) { if (ss(p, d, u[y++], u[y++], u[y++], u[y++], u[y], u[y + 1], e, i, r)) return !0 } else c += ms(p, d, u[y++], u[y++], u[y++], u[y++], u[y], u[y + 1], i, r) || 0; p = u[y++], d = u[y++]; break; case fs.Q: if (n) { if (ls(p, d, u[y++], u[y++], u[y], u[y + 1], e, i, r)) return !0 } else c += xs(p, d, u[y++], u[y++], u[y], u[y + 1], i, r) || 0; p = u[y++], d = u[y++]; break; case fs.A: var x = u[y++], _ = u[y++], b = u[y++], w = u[y++], S = u[y++], M = u[y++]; y += 1; var I = !!(1 - u[y++]); o = Math.cos(S) * b + x, a = Math.sin(S) * w + _, m ? (f = o, g = a) : c += ds(p, d, o, a, i, r); var T = (i - x) * w / b + x; if (n) { if (ps(x, _, w, S, S + M, I, e, T, r)) return !0 } else c += _s(x, _, w, S, S + M, I, T, r); p = Math.cos(S + M) * b + x, d = Math.sin(S + M) * w + _; break; case fs.R: if (f = p = u[y++], g = d = u[y++], o = f + u[y++], a = g + u[y++], n) { if (as(f, g, o, g, e, i, r) || as(o, g, o, a, e, i, r) || as(o, a, f, a, e, i, r) || as(f, a, f, g, e, i, r)) return !0 } else c += ds(o, g, o, a, i, r), c += ds(f, a, f, g, i, r); break; case fs.Z: if (n) { if (as(p, d, f, g, e, i, r)) return !0 } else c += ds(p, d, f, g, i, r); p = f, d = g } } return n || (s = d, l = g, Math.abs(s - l) < 1e-4) || (c += ds(p, d, f, g, i, r) || 0), 0 !== c } var ws = k({ fill: "#000", stroke: null, strokePercent: 1, fillOpacity: 1, strokeOpacity: 1, lineDashOffset: 0, lineWidth: 1, lineCap: "butt", miterLimit: 10, strokeNoScale: !1, strokeFirst: !1 }, xa), Ss = { style: k({ fill: !0, stroke: !0, strokePercent: !0, fillOpacity: !0, strokeOpacity: !0, lineDashOffset: !0, lineWidth: !0, miterLimit: !0 }, _a.style) }, Ms = yr.concat(["invisible", "culling", "z", "z2", "zlevel", "parent"]), Is = function (t) { function e(e) { return t.call(this, e) || this } var i; return n(e, t), e.prototype.update = function () { var n = this; t.prototype.update.call(this); var i = this.style; if (i.decal) { var r = this._decalEl = this._decalEl || new e; r.buildPath === e.prototype.buildPath && (r.buildPath = function (t) { n.buildPath(t, n.shape) }), r.silent = !0; var o = r.style; for (var a in i) o[a] !== i[a] && (o[a] = i[a]); o.fill = i.fill ? i.decal : null, o.decal = null, o.shadowColor = null, i.strokeFirst && (o.stroke = null); for (var s = 0; s < Ms.length; ++s)r[Ms[s]] = this[Ms[s]]; r.__dirty |= 1 } else this._decalEl && (this._decalEl = null) }, e.prototype.getDecalElement = function () { return this._decalEl }, e.prototype._init = function (e) { var n = G(e); this.shape = this.getDefaultShape(); var i = this.getDefaultStyle(); i && this.useStyle(i); for (var r = 0; r < n.length; r++) { var o = n[r], a = e[o]; "style" === o ? this.style ? A(this.style, a) : this.useStyle(a) : "shape" === o ? A(this.shape, a) : t.prototype.attrKV.call(this, o, a) } this.style || this.useStyle({}) }, e.prototype.getDefaultStyle = function () { return null }, e.prototype.getDefaultShape = function () { return {} }, e.prototype.canBeInsideText = function () { return this.hasFill() }, e.prototype.getInsideTextFill = function () { var t = this.style.fill; if ("none" !== t) { if (U(t)) { var e = oi(t, 0); return e > .5 ? ar : e > .2 ? "#eee" : sr } if (t) return sr } return ar }, e.prototype.getInsideTextStroke = function (t) { var e = this.style.fill; if (U(e)) { var n = this.__zr; if (!(!n || !n.isDarkMode()) === oi(t, 0) < .4) return e } }, e.prototype.buildPath = function (t, e, n) { }, e.prototype.pathUpdated = function () { this.__dirty &= -5 }, e.prototype.getUpdatedPathProxy = function (t) { return !this.path && this.createPathProxy(), this.path.beginPath(), this.buildPath(this.path, this.shape, t), this.path }, e.prototype.createPathProxy = function () { this.path = new os(!1) }, e.prototype.hasStroke = function () { var t = this.style, e = t.stroke; return !(null == e || "none" === e || !(t.lineWidth > 0)) }, e.prototype.hasFill = function () { var t = this.style.fill; return null != t && "none" !== t }, e.prototype.getBoundingRect = function () { var t = this._rect, e = this.style, n = !t; if (n) { var i = !1; this.path || (i = !0, this.createPathProxy()); var r = this.path; (i || 4 & this.__dirty) && (r.beginPath(), this.buildPath(r, this.shape, !1), this.pathUpdated()), t = r.getBoundingRect() } if (this._rect = t, this.hasStroke() && this.path && this.path.len() > 0) { var o = this._rectStroke || (this._rectStroke = t.clone()); if (this.__dirty || n) { o.copy(t); var a = e.strokeNoScale ? this.getLineScale() : 1, s = e.lineWidth; if (!this.hasFill()) { var l = this.strokeContainThreshold; s = Math.max(s, null == l ? 4 : l) } a > 1e-10 && (o.width += s / a, o.height += s / a, o.x -= s / a / 2, o.y -= s / a / 2) } return o } return t }, e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e), i = this.getBoundingRect(), r = this.style; if (t = n[0], e = n[1], i.contain(t, e)) { var o = this.path; if (this.hasStroke()) { var a = r.lineWidth, s = r.strokeNoScale ? this.getLineScale() : 1; if (s > 1e-10 && (this.hasFill() || (a = Math.max(a, this.strokeContainThreshold)), function (t, e, n, i) { return bs(t, e, !0, n, i) }(o, a / s, t, e))) return !0 } if (this.hasFill()) return function (t, e, n) { return bs(t, 0, !1, e, n) }(o, t, e) } return !1 }, e.prototype.dirtyShape = function () { this.__dirty |= 4, this._rect && (this._rect = null), this._decalEl && this._decalEl.dirtyShape(), this.markRedraw() }, e.prototype.dirty = function () { this.dirtyStyle(), this.dirtyShape() }, e.prototype.animateShape = function (t) { return this.animate("shape", t) }, e.prototype.updateDuringAnimation = function (t) { "style" === t ? this.dirtyStyle() : "shape" === t ? this.dirtyShape() : this.markRedraw() }, e.prototype.attrKV = function (e, n) { "shape" === e ? this.setShape(n) : t.prototype.attrKV.call(this, e, n) }, e.prototype.setShape = function (t, e) { var n = this.shape; return n || (n = this.shape = {}), "string" == typeof t ? n[t] = e : A(n, t), this.dirtyShape(), this }, e.prototype.shapeChanged = function () { return !!(4 & this.__dirty) }, e.prototype.createStyle = function (t) { return mt(ws, t) }, e.prototype._innerSaveToNormal = function (e) { t.prototype._innerSaveToNormal.call(this, e); var n = this._normalState; e.shape && !n.shape && (n.shape = A({}, this.shape)) }, e.prototype._applyStateObj = function (e, n, i, r, o, a) { t.prototype._applyStateObj.call(this, e, n, i, r, o, a); var s, l = !(n && r); if (n && n.shape ? o ? r ? s = n.shape : (s = A({}, i.shape), A(s, n.shape)) : (s = A({}, r ? this.shape : i.shape), A(s, n.shape)) : l && (s = i.shape), s) if (o) { this.shape = A({}, this.shape); for (var u = {}, h = G(s), c = 0; c < h.length; c++) { var p = h[c]; "object" == typeof s[p] ? this.shape[p] = s[p] : u[p] = s[p] } this._transitionState(e, { shape: u }, a) } else this.shape = s, this.dirtyShape() }, e.prototype._mergeStates = function (e) { for (var n, i = t.prototype._mergeStates.call(this, e), r = 0; r < e.length; r++) { var o = e[r]; o.shape && (n = n || {}, this._mergeStyle(n, o.shape)) } return n && (i.shape = n), i }, e.prototype.getAnimationStyleProps = function () { return Ss }, e.prototype.isZeroArea = function () { return !1 }, e.extend = function (t) { var i = function (e) { function i(n) { var i = e.call(this, n) || this; return t.init && t.init.call(i, n), i } return n(i, e), i.prototype.getDefaultStyle = function () { return T(t.style) }, i.prototype.getDefaultShape = function () { return T(t.shape) }, i }(e); for (var r in t) "function" == typeof t[r] && (i.prototype[r] = t[r]); return i }, e.initDefaultProps = ((i = e.prototype).type = "path", i.strokeContainThreshold = 5, i.segmentIgnoreThreshold = 0, i.subPixelOptimize = !1, i.autoBatch = !1, void (i.__dirty = 7)), e }(Sa), Ts = k({ strokeFirst: !0, font: a, x: 0, y: 0, textAlign: "left", textBaseline: "top", miterLimit: 2 }, ws), Cs = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.hasStroke = function () { var t = this.style, e = t.stroke; return null != e && "none" !== e && t.lineWidth > 0 }, e.prototype.hasFill = function () { var t = this.style.fill; return null != t && "none" !== t }, e.prototype.createStyle = function (t) { return mt(Ts, t) }, e.prototype.setBoundingRect = function (t) { this._rect = t }, e.prototype.getBoundingRect = function () { var t = this.style; if (!this._rect) { var e = t.text; null != e ? e += "" : e = ""; var n = br(e, t.font, t.textAlign, t.textBaseline); if (n.x += t.x || 0, n.y += t.y || 0, this.hasStroke()) { var i = t.lineWidth; n.x -= i / 2, n.y -= i / 2, n.width += i, n.height += i } this._rect = n } return this._rect }, e.initDefaultProps = void (e.prototype.dirtyRectTolerance = 10), e }(Sa); Cs.prototype.type = "tspan"; var Ds = k({ x: 0, y: 0 }, xa), As = { style: k({ x: !0, y: !0, width: !0, height: !0, sx: !0, sy: !0, sWidth: !0, sHeight: !0 }, _a.style) }; var ks = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.createStyle = function (t) { return mt(Ds, t) }, e.prototype._getSize = function (t) { var e = this.style, n = e[t]; if (null != n) return n; var i, r = (i = e.image) && "string" != typeof i && i.width && i.height ? e.image : this.__image; if (!r) return 0; var o = "width" === t ? "height" : "width", a = e[o]; return null == a ? r[t] : r[t] / r[o] * a }, e.prototype.getWidth = function () { return this._getSize("width") }, e.prototype.getHeight = function () { return this._getSize("height") }, e.prototype.getAnimationStyleProps = function () { return As }, e.prototype.getBoundingRect = function () { var t = this.style; return this._rect || (this._rect = new ze(t.x || 0, t.y || 0, this.getWidth(), this.getHeight())), this._rect }, e }(Sa); ks.prototype.type = "image"; var Ls = Math.round; function Ps(t, e, n) { if (e) { var i = e.x1, r = e.x2, o = e.y1, a = e.y2; t.x1 = i, t.x2 = r, t.y1 = o, t.y2 = a; var s = n && n.lineWidth; return s ? (Ls(2 * i) === Ls(2 * r) && (t.x1 = t.x2 = Rs(i, s, !0)), Ls(2 * o) === Ls(2 * a) && (t.y1 = t.y2 = Rs(o, s, !0)), t) : t } } function Os(t, e, n) { if (e) { var i = e.x, r = e.y, o = e.width, a = e.height; t.x = i, t.y = r, t.width = o, t.height = a; var s = n && n.lineWidth; return s ? (t.x = Rs(i, s, !0), t.y = Rs(r, s, !0), t.width = Math.max(Rs(i + o, s, !1) - t.x, 0 === o ? 0 : 1), t.height = Math.max(Rs(r + a, s, !1) - t.y, 0 === a ? 0 : 1), t) : t } } function Rs(t, e, n) { if (!e) return t; var i = Ls(2 * t); return (i + Ls(e)) % 2 == 0 ? i / 2 : (i + (n ? 1 : -1)) / 2 } var Ns = function () { this.x = 0, this.y = 0, this.width = 0, this.height = 0 }, Es = {}, zs = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new Ns }, e.prototype.buildPath = function (t, e) { var n, i, r, o; if (this.subPixelOptimize) { var a = Os(Es, e, this.style); n = a.x, i = a.y, r = a.width, o = a.height, a.r = e.r, e = a } else n = e.x, i = e.y, r = e.width, o = e.height; e.r ? function (t, e) { var n, i, r, o, a, s = e.x, l = e.y, u = e.width, h = e.height, c = e.r; u < 0 && (s += u, u = -u), h < 0 && (l += h, h = -h), "number" == typeof c ? n = i = r = o = c : c instanceof Array ? 1 === c.length ? n = i = r = o = c[0] : 2 === c.length ? (n = r = c[0], i = o = c[1]) : 3 === c.length ? (n = c[0], i = o = c[1], r = c[2]) : (n = c[0], i = c[1], r = c[2], o = c[3]) : n = i = r = o = 0, n + i > u && (n *= u / (a = n + i), i *= u / a), r + o > u && (r *= u / (a = r + o), o *= u / a), i + r > h && (i *= h / (a = i + r), r *= h / a), n + o > h && (n *= h / (a = n + o), o *= h / a), t.moveTo(s + n, l), t.lineTo(s + u - i, l), 0 !== i && t.arc(s + u - i, l + i, i, -Math.PI / 2, 0), t.lineTo(s + u, l + h - r), 0 !== r && t.arc(s + u - r, l + h - r, r, 0, Math.PI / 2), t.lineTo(s + o, l + h), 0 !== o && t.arc(s + o, l + h - o, o, Math.PI / 2, Math.PI), t.lineTo(s, l + n), 0 !== n && t.arc(s + n, l + n, n, Math.PI, 1.5 * Math.PI) }(t, e) : t.rect(n, i, r, o) }, e.prototype.isZeroArea = function () { return !this.shape.width || !this.shape.height }, e }(Is); zs.prototype.type = "rect"; var Vs = { fill: "#000" }, Bs = { style: k({ fill: !0, stroke: !0, fillOpacity: !0, strokeOpacity: !0, lineWidth: !0, fontSize: !0, lineHeight: !0, width: !0, height: !0, textShadowColor: !0, textShadowBlur: !0, textShadowOffsetX: !0, textShadowOffsetY: !0, backgroundColor: !0, padding: !0, borderColor: !0, borderWidth: !0, borderRadius: !0 }, _a.style) }, Fs = function (t) { function e(e) { var n = t.call(this) || this; return n.type = "text", n._children = [], n._defaultStyle = Vs, n.attr(e), n } return n(e, t), e.prototype.childrenRef = function () { return this._children }, e.prototype.update = function () { t.prototype.update.call(this), this.styleChanged() && this._updateSubTexts(); for (var e = 0; e < this._children.length; e++) { var n = this._children[e]; n.zlevel = this.zlevel, n.z = this.z, n.z2 = this.z2, n.culling = this.culling, n.cursor = this.cursor, n.invisible = this.invisible } }, e.prototype.updateTransform = function () { var e = this.innerTransformable; e ? (e.updateTransform(), e.transform && (this.transform = e.transform)) : t.prototype.updateTransform.call(this) }, e.prototype.getLocalTransform = function (e) { var n = this.innerTransformable; return n ? n.getLocalTransform(e) : t.prototype.getLocalTransform.call(this, e) }, e.prototype.getComputedTransform = function () { return this.__hostTarget && (this.__hostTarget.getComputedTransform(), this.__hostTarget.updateInnerText(!0)), t.prototype.getComputedTransform.call(this) }, e.prototype._updateSubTexts = function () { var t; this._childCursor = 0, Zs(t = this.style), E(t.rich, Zs), this.style.rich ? this._updateRichTexts() : this._updatePlainTexts(), this._children.length = this._childCursor, this.styleUpdated() }, e.prototype.addSelfToZr = function (e) { t.prototype.addSelfToZr.call(this, e); for (var n = 0; n < this._children.length; n++)this._children[n].__zr = e }, e.prototype.removeSelfFromZr = function (e) { t.prototype.removeSelfFromZr.call(this, e); for (var n = 0; n < this._children.length; n++)this._children[n].__zr = null }, e.prototype.getBoundingRect = function () { if (this.styleChanged() && this._updateSubTexts(), !this._rect) { for (var t = new ze(0, 0, 0, 0), e = this._children, n = [], i = null, r = 0; r < e.length; r++) { var o = e[r], a = o.getBoundingRect(), s = o.getLocalTransform(n); s ? (t.copy(a), t.applyTransform(s), (i = i || t.clone()).union(t)) : (i = i || a.clone()).union(a) } this._rect = i || t } return this._rect }, e.prototype.setDefaultTextStyle = function (t) { this._defaultStyle = t || Vs }, e.prototype.setTextContent = function (t) { 0 }, e.prototype._mergeStyle = function (t, e) { if (!e) return t; var n = e.rich, i = t.rich || n && {}; return A(t, e), n && i ? (this._mergeRich(i, n), t.rich = i) : i && (t.rich = i), t }, e.prototype._mergeRich = function (t, e) { for (var n = G(e), i = 0; i < n.length; i++) { var r = n[i]; t[r] = t[r] || {}, A(t[r], e[r]) } }, e.prototype.getAnimationStyleProps = function () { return Bs }, e.prototype._getOrCreateChild = function (t) { var e = this._children[this._childCursor]; return e && e instanceof t || (e = new t), this._children[this._childCursor++] = e, e.__zr = this.__zr, e.parent = this, e }, e.prototype._updatePlainTexts = function () { var t = this.style, e = t.font || a, n = t.padding, i = function (t, e) { null != t && (t += ""); var n, i = e.overflow, r = e.padding, o = e.font, a = "truncate" === i, s = Mr(o), l = rt(e.lineHeight, s), u = !!e.backgroundColor, h = "truncate" === e.lineOverflow, c = e.width, p = (n = null == c || "break" !== i && "breakAll" !== i ? t ? t.split("\n") : [] : t ? va(t, e.font, c, "breakAll" === i, 0).lines : []).length * l, d = rt(e.height, p); if (p > d && h) { var f = Math.floor(d / l); n = n.slice(0, f) } if (t && a && null != c) for (var g = la(c, o, e.ellipsis, { minChar: e.truncateMinChar, placeholder: e.placeholder }), y = 0; y < n.length; y++)n[y] = ua(n[y], g); var v = d, m = 0; for (y = 0; y < n.length; y++)m = Math.max(xr(n[y], o), m); null == c && (c = m); var x = m; return r && (v += r[0] + r[2], x += r[1] + r[3], c += r[1] + r[3]), u && (x = c), { lines: n, height: d, outerWidth: x, outerHeight: v, lineHeight: l, calculatedLineHeight: s, contentWidth: m, contentHeight: p, width: c } }($s(t), t), r = Js(t), o = !!t.backgroundColor, s = i.outerHeight, l = i.outerWidth, u = i.contentWidth, h = i.lines, c = i.lineHeight, p = this._defaultStyle, d = t.x || 0, f = t.y || 0, g = t.align || p.align || "left", y = t.verticalAlign || p.verticalAlign || "top", v = d, m = Sr(f, i.contentHeight, y); if (r || n) { var x = wr(d, l, g), _ = Sr(f, s, y); r && this._renderBackground(t, t, x, _, l, s) } m += c / 2, n && (v = Ks(d, g, n), "top" === y ? m += n[0] : "bottom" === y && (m -= n[2])); for (var b = 0, w = !1, S = (qs("fill" in t ? t.fill : (w = !0, p.fill))), M = (js("stroke" in t ? t.stroke : o || p.autoStroke && !w ? null : (b = 2, p.stroke))), I = t.textShadowBlur > 0, T = null != t.width && ("truncate" === t.overflow || "break" === t.overflow || "breakAll" === t.overflow), C = i.calculatedLineHeight, D = 0; D < h.length; D++) { var A = this._getOrCreateChild(Cs), k = A.createStyle(); A.useStyle(k), k.text = h[D], k.x = v, k.y = m, g && (k.textAlign = g), k.textBaseline = "middle", k.opacity = t.opacity, k.strokeFirst = !0, I && (k.shadowBlur = t.textShadowBlur || 0, k.shadowColor = t.textShadowColor || "transparent", k.shadowOffsetX = t.textShadowOffsetX || 0, k.shadowOffsetY = t.textShadowOffsetY || 0), k.stroke = M, k.fill = S, M && (k.lineWidth = t.lineWidth || b, k.lineDash = t.lineDash, k.lineDashOffset = t.lineDashOffset || 0), k.font = e, Xs(k, t), m += c, T && A.setBoundingRect(new ze(wr(k.x, t.width, k.textAlign), Sr(k.y, C, k.textBaseline), u, C)) } }, e.prototype._updateRichTexts = function () { var t = this.style, e = function (t, e) { var n = new da; if (null != t && (t += ""), !t) return n; for (var i, r = e.width, o = e.height, a = e.overflow, s = "break" !== a && "breakAll" !== a || null == r ? null : { width: r, accumWidth: 0, breakAll: "breakAll" === a }, l = aa.lastIndex = 0; null != (i = aa.exec(t));) { var u = i.index; u > l && fa(n, t.substring(l, u), e, s), fa(n, i[2], e, s, i[1]), l = aa.lastIndex } l < t.length && fa(n, t.substring(l, t.length), e, s); var h = [], c = 0, p = 0, d = e.padding, f = "truncate" === a, g = "truncate" === e.lineOverflow; function y(t, e, n) { t.width = e, t.lineHeight = n, c += n, p = Math.max(p, e) } t: for (var v = 0; v < n.lines.length; v++) { for (var m = n.lines[v], x = 0, _ = 0, b = 0; b < m.tokens.length; b++) { var w = (P = m.tokens[b]).styleName && e.rich[P.styleName] || {}, S = P.textPadding = w.padding, M = S ? S[1] + S[3] : 0, I = P.font = w.font || e.font; P.contentHeight = Mr(I); var T = rt(w.height, P.contentHeight); if (P.innerHeight = T, S && (T += S[0] + S[2]), P.height = T, P.lineHeight = ot(w.lineHeight, e.lineHeight, T), P.align = w && w.align || e.align, P.verticalAlign = w && w.verticalAlign || "middle", g && null != o && c + P.lineHeight > o) { b > 0 ? (m.tokens = m.tokens.slice(0, b), y(m, _, x), n.lines = n.lines.slice(0, v + 1)) : n.lines = n.lines.slice(0, v); break t } var C = w.width, D = null == C || "auto" === C; if ("string" == typeof C && "%" === C.charAt(C.length - 1)) P.percentWidth = C, h.push(P), P.contentWidth = xr(P.text, I); else { if (D) { var A = w.backgroundColor, k = A && A.image; k && oa(k = na(k)) && (P.width = Math.max(P.width, k.width * T / k.height)) } var L = f && null != r ? r - _ : null; null != L && L < P.width ? !D || L < M ? (P.text = "", P.width = P.contentWidth = 0) : (P.text = sa(P.text, L - M, I, e.ellipsis, { minChar: e.truncateMinChar }), P.width = P.contentWidth = xr(P.text, I)) : P.contentWidth = xr(P.text, I) } P.width += M, _ += P.width, w && (x = Math.max(x, P.lineHeight)) } y(m, _, x) } for (n.outerWidth = n.width = rt(r, p), n.outerHeight = n.height = rt(o, c), n.contentHeight = c, n.contentWidth = p, d && (n.outerWidth += d[1] + d[3], n.outerHeight += d[0] + d[2]), v = 0; v < h.length; v++) { var P, O = (P = h[v]).percentWidth; P.width = parseInt(O, 10) / 100 * n.width } return n }($s(t), t), n = e.width, i = e.outerWidth, r = e.outerHeight, o = t.padding, a = t.x || 0, s = t.y || 0, l = this._defaultStyle, u = t.align || l.align, h = t.verticalAlign || l.verticalAlign, c = wr(a, i, u), p = Sr(s, r, h), d = c, f = p; o && (d += o[3], f += o[0]); var g = d + n; Js(t) && this._renderBackground(t, t, c, p, i, r); for (var y = !!t.backgroundColor, v = 0; v < e.lines.length; v++) { for (var m = e.lines[v], x = m.tokens, _ = x.length, b = m.lineHeight, w = m.width, S = 0, M = d, I = g, T = _ - 1, C = void 0; S < _ && (!(C = x[S]).align || "left" === C.align);)this._placeToken(C, t, b, f, M, "left", y), w -= C.width, M += C.width, S++; for (; T >= 0 && "right" === (C = x[T]).align;)this._placeToken(C, t, b, f, I, "right", y), w -= C.width, I -= C.width, T--; for (M += (n - (M - d) - (g - I) - w) / 2; S <= T;)C = x[S], this._placeToken(C, t, b, f, M + C.width / 2, "center", y), M += C.width, S++; f += b } }, e.prototype._placeToken = function (t, e, n, i, r, o, s) { var l = e.rich[t.styleName] || {}; l.text = t.text; var u = t.verticalAlign, h = i + n / 2; "top" === u ? h = i + t.height / 2 : "bottom" === u && (h = i + n - t.height / 2), !t.isLineHolder && Js(l) && this._renderBackground(l, e, "right" === o ? r - t.width : "center" === o ? r - t.width / 2 : r, h - t.height / 2, t.width, t.height); var c = !!l.backgroundColor, p = t.textPadding; p && (r = Ks(r, o, p), h -= t.height / 2 - p[0] - t.innerHeight / 2); var d = this._getOrCreateChild(Cs), f = d.createStyle(); d.useStyle(f); var g = this._defaultStyle, y = !1, v = 0, m = qs("fill" in l ? l.fill : "fill" in e ? e.fill : (y = !0, g.fill)), x = js("stroke" in l ? l.stroke : "stroke" in e ? e.stroke : c || s || g.autoStroke && !y ? null : (v = 2, g.stroke)), _ = l.textShadowBlur > 0 || e.textShadowBlur > 0; f.text = t.text, f.x = r, f.y = h, _ && (f.shadowBlur = l.textShadowBlur || e.textShadowBlur || 0, f.shadowColor = l.textShadowColor || e.textShadowColor || "transparent", f.shadowOffsetX = l.textShadowOffsetX || e.textShadowOffsetX || 0, f.shadowOffsetY = l.textShadowOffsetY || e.textShadowOffsetY || 0), f.textAlign = o, f.textBaseline = "middle", f.font = t.font || a, f.opacity = ot(l.opacity, e.opacity, 1), Xs(f, l), x && (f.lineWidth = ot(l.lineWidth, e.lineWidth, v), f.lineDash = rt(l.lineDash, e.lineDash), f.lineDashOffset = e.lineDashOffset || 0, f.stroke = x), m && (f.fill = m); var b = t.contentWidth, w = t.contentHeight; d.setBoundingRect(new ze(wr(f.x, b, f.textAlign), Sr(f.y, w, f.textBaseline), b, w)) }, e.prototype._renderBackground = function (t, e, n, i, r, o) { var a, s, l, u = t.backgroundColor, h = t.borderWidth, c = t.borderColor, p = u && u.image, d = u && !p, f = t.borderRadius, g = this; if (d || t.lineHeight || h && c) { (a = this._getOrCreateChild(zs)).useStyle(a.createStyle()), a.style.fill = null; var y = a.shape; y.x = n, y.y = i, y.width = r, y.height = o, y.r = f, a.dirtyShape() } if (d) (l = a.style).fill = u || null, l.fillOpacity = rt(t.fillOpacity, 1); else if (p) { (s = this._getOrCreateChild(ks)).onload = function () { g.dirtyStyle() }; var v = s.style; v.image = u.image, v.x = n, v.y = i, v.width = r, v.height = o } h && c && ((l = a.style).lineWidth = h, l.stroke = c, l.strokeOpacity = rt(t.strokeOpacity, 1), l.lineDash = t.borderDash, l.lineDashOffset = t.borderDashOffset || 0, a.strokeContainThreshold = 0, a.hasFill() && a.hasStroke() && (l.strokeFirst = !0, l.lineWidth *= 2)); var m = (a || s).style; m.shadowBlur = t.shadowBlur || 0, m.shadowColor = t.shadowColor || "transparent", m.shadowOffsetX = t.shadowOffsetX || 0, m.shadowOffsetY = t.shadowOffsetY || 0, m.opacity = ot(t.opacity, e.opacity, 1) }, e.makeFont = function (t) { var e = ""; return Us(t) && (e = [t.fontStyle, t.fontWeight, Ys(t.fontSize), t.fontFamily || "sans-serif"].join(" ")), e && ut(e) || t.textFont || t.font }, e }(Sa), Gs = { left: !0, right: 1, center: 1 }, Ws = { top: 1, bottom: 1, middle: 1 }, Hs = ["fontStyle", "fontWeight", "fontSize", "fontFamily"]; function Ys(t) { return "string" != typeof t || -1 === t.indexOf("px") && -1 === t.indexOf("rem") && -1 === t.indexOf("em") ? isNaN(+t) ? "12px" : t + "px" : t } function Xs(t, e) { for (var n = 0; n < Hs.length; n++) { var i = Hs[n], r = e[i]; null != r && (t[i] = r) } } function Us(t) { return null != t.fontSize || t.fontFamily || t.fontWeight } function Zs(t) { if (t) { t.font = Fs.makeFont(t); var e = t.align; "middle" === e && (e = "center"), t.align = null == e || Gs[e] ? e : "left"; var n = t.verticalAlign; "center" === n && (n = "middle"), t.verticalAlign = null == n || Ws[n] ? n : "top", t.padding && (t.padding = st(t.padding)) } } function js(t, e) { return null == t || e <= 0 || "transparent" === t || "none" === t ? null : t.image || t.colorStops ? "#000" : t } function qs(t) { return null == t || "none" === t ? null : t.image || t.colorStops ? "#000" : t } function Ks(t, e, n) { return "right" === e ? t - n[1] : "center" === e ? t + n[3] / 2 - n[1] / 2 : t + n[3] } function $s(t) { var e = t.text; return null != e && (e += ""), e } function Js(t) { return !!(t.backgroundColor || t.lineHeight || t.borderWidth && t.borderColor) } var Qs = Oo(), tl = function (t, e, n, i) { if (i) { var r = Qs(i); r.dataIndex = n, r.dataType = e, r.seriesIndex = t, "group" === i.type && i.traverse((function (i) { var r = Qs(i); r.seriesIndex = t, r.dataIndex = n, r.dataType = e })) } }, el = 1, nl = {}, il = Oo(), rl = Oo(), ol = ["emphasis", "blur", "select"], al = ["normal", "emphasis", "blur", "select"], sl = 10, ll = "highlight", ul = "downplay", hl = "select", cl = "unselect", pl = "toggleSelect"; function dl(t) { return null != t && "none" !== t } var fl = new En(100); function gl(t) { if (U(t)) { var e = fl.get(t); return e || (e = $n(t, -.1), fl.put(t, e)), e } if (Q(t)) { var n = A({}, t); return n.colorStops = z(t.colorStops, (function (t) { return { offset: t.offset, color: $n(t.color, -.1) } })), n } return t } function yl(t, e, n) { t.onHoverStateChange && (t.hoverState || 0) !== n && t.onHoverStateChange(e), t.hoverState = n } function vl(t) { yl(t, "emphasis", 2) } function ml(t) { 2 === t.hoverState && yl(t, "normal", 0) } function xl(t) { yl(t, "blur", 1) } function _l(t) { 1 === t.hoverState && yl(t, "normal", 0) } function bl(t) { t.selected = !0 } function wl(t) { t.selected = !1 } function Sl(t, e, n) { e(t, n) } function Ml(t, e, n) { Sl(t, e, n), t.isGroup && t.traverse((function (t) { Sl(t, e, n) })) } function Il(t, e) { switch (e) { case "emphasis": t.hoverState = 2; break; case "normal": t.hoverState = 0; break; case "blur": t.hoverState = 1; break; case "select": t.selected = !0 } } function Tl(t, e) { var n = this.states[t]; if (this.style) { if ("emphasis" === t) return function (t, e, n, i) { var r = n && P(n, "select") >= 0, o = !1; if (t instanceof Is) { var a = il(t), s = r && a.selectFill || a.normalFill, l = r && a.selectStroke || a.normalStroke; if (dl(s) || dl(l)) { var u = (i = i || {}).style || {}; "inherit" === u.fill ? (o = !0, i = A({}, i), (u = A({}, u)).fill = s) : !dl(u.fill) && dl(s) ? (o = !0, i = A({}, i), (u = A({}, u)).fill = gl(s)) : !dl(u.stroke) && dl(l) && (o || (i = A({}, i), u = A({}, u)), u.stroke = gl(l)), i.style = u } } if (i && null == i.z2) { o || (i = A({}, i)); var h = t.z2EmphasisLift; i.z2 = t.z2 + (null != h ? h : sl) } return i }(this, 0, e, n); if ("blur" === t) return function (t, e, n) { var i = P(t.currentStates, e) >= 0, r = t.style.opacity, o = i ? null : function (t, e, n, i) { for (var r = t.style, o = {}, a = 0; a < e.length; a++) { var s = e[a], l = r[s]; o[s] = null == l ? i && i[s] : l } for (a = 0; a < t.animators.length; a++) { var u = t.animators[a]; u.__fromStateTransition && u.__fromStateTransition.indexOf(n) < 0 && "style" === u.targetName && u.saveTo(o, e) } return o }(t, ["opacity"], e, { opacity: 1 }), a = (n = n || {}).style || {}; return null == a.opacity && (n = A({}, n), a = A({ opacity: i ? r : .1 * o.opacity }, a), n.style = a), n }(this, t, n); if ("select" === t) return function (t, e, n) { if (n && null == n.z2) { n = A({}, n); var i = t.z2SelectLift; n.z2 = t.z2 + (null != i ? i : 9) } return n }(this, 0, n) } return n } function Cl(t) { t.stateProxy = Tl; var e = t.getTextContent(), n = t.getTextGuideLine(); e && (e.stateProxy = Tl), n && (n.stateProxy = Tl) } function Dl(t, e) { !El(t, e) && !t.__highByOuter && Ml(t, vl) } function Al(t, e) { !El(t, e) && !t.__highByOuter && Ml(t, ml) } function kl(t, e) { t.__highByOuter |= 1 << (e || 0), Ml(t, vl) } function Ll(t, e) { !(t.__highByOuter &= ~(1 << (e || 0))) && Ml(t, ml) } function Pl(t) { Ml(t, xl) } function Ol(t) { Ml(t, _l) } function Rl(t) { Ml(t, bl) } function Nl(t) { Ml(t, wl) } function El(t, e) { return t.__highDownSilentOnTouch && e.zrByTouch } function zl(t) { var e = t.getModel(), n = [], i = []; e.eachComponent((function (e, r) { var o = rl(r), a = "series" === e, s = a ? t.getViewOfSeriesModel(r) : t.getViewOfComponentModel(r); !a && i.push(s), o.isBlured && (s.group.traverse((function (t) { _l(t) })), a && n.push(r)), o.isBlured = !1 })), E(i, (function (t) { t && t.toggleBlurSeries && t.toggleBlurSeries(n, !1, e) })) } function Vl(t, e, n, i) { var r = i.getModel(); function o(t, e) { for (var n = 0; n < e.length; n++) { var i = t.getItemGraphicEl(e[n]); i && Ol(i) } } if (n = n || "coordinateSystem", null != t && e && "none" !== e) { var a = r.getSeriesByIndex(t), s = a.coordinateSystem; s && s.master && (s = s.master); var l = []; r.eachSeries((function (t) { var r = a === t, u = t.coordinateSystem; if (u && u.master && (u = u.master), !("series" === n && !r || "coordinateSystem" === n && !(u && s ? u === s : r) || "series" === e && r)) { if (i.getViewOfSeriesModel(t).group.traverse((function (t) { t.__highByOuter && r && "self" === e || xl(t) })), N(e)) o(t.getData(), e); else if (q(e)) for (var h = G(e), c = 0; c < h.length; c++)o(t.getData(h[c]), e[h[c]]); l.push(t), rl(t).isBlured = !0 } })), r.eachComponent((function (t, e) { if ("series" !== t) { var n = i.getViewOfComponentModel(e); n && n.toggleBlurSeries && n.toggleBlurSeries(l, !0, r) } })) } } function Bl(t, e, n) { if (null != t && null != e) { var i = n.getModel().getComponent(t, e); if (i) { rl(i).isBlured = !0; var r = n.getViewOfComponentModel(i); r && r.focusBlurEnabled && r.group.traverse((function (t) { xl(t) })) } } } function Fl(t, e, n, i) { var r = { focusSelf: !1, dispatchers: null }; if (null == t || "series" === t || null == e || null == n) return r; var o = i.getModel().getComponent(t, e); if (!o) return r; var a = i.getViewOfComponentModel(o); if (!a || !a.findHighDownDispatchers) return r; for (var s, l = a.findHighDownDispatchers(n), u = 0; u < l.length; u++)if ("self" === Qs(l[u]).focus) { s = !0; break } return { focusSelf: s, dispatchers: l } } function Gl(t) { E(t.getAllData(), (function (e) { var n = e.data, i = e.type; n.eachItemGraphicEl((function (e, n) { t.isSelected(n, i) ? Rl(e) : Nl(e) })) })) } function Wl(t) { var e = []; return t.eachSeries((function (t) { E(t.getAllData(), (function (n) { n.data; var i = n.type, r = t.getSelectedDataIndices(); if (r.length > 0) { var o = { dataIndex: r, seriesIndex: t.seriesIndex }; null != i && (o.dataType = i), e.push(o) } })) })), e } function Hl(t, e, n) { ql(t, !0), Ml(t, Cl), Xl(t, e, n) } function Yl(t, e, n, i) { i ? function (t) { ql(t, !1) }(t) : Hl(t, e, n) } function Xl(t, e, n) { var i = Qs(t); null != e ? (i.focus = e, i.blurScope = n) : i.focus && (i.focus = null) } var Ul = ["emphasis", "blur", "select"], Zl = { itemStyle: "getItemStyle", lineStyle: "getLineStyle", areaStyle: "getAreaStyle" }; function jl(t, e, n, i) { n = n || "itemStyle"; for (var r = 0; r < Ul.length; r++) { var o = Ul[r], a = e.getModel([o, n]); t.ensureState(o).style = i ? i(a) : a[Zl[n]]() } } function ql(t, e) { var n = !1 === e, i = t; t.highDownSilentOnTouch && (i.__highDownSilentOnTouch = t.highDownSilentOnTouch), n && !i.__highDownDispatcher || (i.__highByOuter = i.__highByOuter || 0, i.__highDownDispatcher = !n) } function Kl(t) { return !(!t || !t.__highDownDispatcher) } function $l(t) { var e = t.type; return e === hl || e === cl || e === pl } function Jl(t) { var e = t.type; return e === ll || e === ul } var Ql = os.CMD, tu = [[], [], []], eu = Math.sqrt, nu = Math.atan2; function iu(t, e) { if (e) { var n, i, r, o, a, s, l = t.data, u = t.len(), h = Ql.M, c = Ql.C, p = Ql.L, d = Ql.R, f = Ql.A, g = Ql.Q; for (r = 0, o = 0; r < u;) { switch (n = l[r++], o = r, i = 0, n) { case h: case p: i = 1; break; case c: i = 3; break; case g: i = 2; break; case f: var y = e[4], v = e[5], m = eu(e[0] * e[0] + e[1] * e[1]), x = eu(e[2] * e[2] + e[3] * e[3]), _ = nu(-e[1] / x, e[0] / m); l[r] *= m, l[r++] += y, l[r] *= x, l[r++] += v, l[r++] *= m, l[r++] *= x, l[r++] += _, l[r++] += _, o = r += 2; break; case d: s[0] = l[r++], s[1] = l[r++], Wt(s, s, e), l[o++] = s[0], l[o++] = s[1], s[0] += l[r++], s[1] += l[r++], Wt(s, s, e), l[o++] = s[0], l[o++] = s[1] }for (a = 0; a < i; a++) { var b = tu[a]; b[0] = l[r++], b[1] = l[r++], Wt(b, b, e), l[o++] = b[0], l[o++] = b[1] } } t.increaseVersion() } } var ru = Math.sqrt, ou = Math.sin, au = Math.cos, su = Math.PI; function lu(t) { return Math.sqrt(t[0] * t[0] + t[1] * t[1]) } function uu(t, e) { return (t[0] * e[0] + t[1] * e[1]) / (lu(t) * lu(e)) } function hu(t, e) { return (t[0] * e[1] < t[1] * e[0] ? -1 : 1) * Math.acos(uu(t, e)) } function cu(t, e, n, i, r, o, a, s, l, u, h) { var c = l * (su / 180), p = au(c) * (t - n) / 2 + ou(c) * (e - i) / 2, d = -1 * ou(c) * (t - n) / 2 + au(c) * (e - i) / 2, f = p * p / (a * a) + d * d / (s * s); f > 1 && (a *= ru(f), s *= ru(f)); var g = (r === o ? -1 : 1) * ru((a * a * (s * s) - a * a * (d * d) - s * s * (p * p)) / (a * a * (d * d) + s * s * (p * p))) || 0, y = g * a * d / s, v = g * -s * p / a, m = (t + n) / 2 + au(c) * y - ou(c) * v, x = (e + i) / 2 + ou(c) * y + au(c) * v, _ = hu([1, 0], [(p - y) / a, (d - v) / s]), b = [(p - y) / a, (d - v) / s], w = [(-1 * p - y) / a, (-1 * d - v) / s], S = hu(b, w); if (uu(b, w) <= -1 && (S = su), uu(b, w) >= 1 && (S = 0), S < 0) { var M = Math.round(S / su * 1e6) / 1e6; S = 2 * su + M % 2 * su } h.addData(u, m, x, a, s, _, S, c, o) } var pu = /([mlvhzcqtsa])([^mlvhzcqtsa]*)/gi, du = /-?([0-9]*\.)?[0-9]+([eE]-?[0-9]+)?/g; var fu = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.applyTransform = function (t) { }, e }(Is); function gu(t) { return null != t.setData } function yu(t, e) { var n = function (t) { var e = new os; if (!t) return e; var n, i = 0, r = 0, o = i, a = r, s = os.CMD, l = t.match(pu); if (!l) return e; for (var u = 0; u < l.length; u++) { for (var h = l[u], c = h.charAt(0), p = void 0, d = h.match(du) || [], f = d.length, g = 0; g < f; g++)d[g] = parseFloat(d[g]); for (var y = 0; y < f;) { var v = void 0, m = void 0, x = void 0, _ = void 0, b = void 0, w = void 0, S = void 0, M = i, I = r, T = void 0, C = void 0; switch (c) { case "l": i += d[y++], r += d[y++], p = s.L, e.addData(p, i, r); break; case "L": i = d[y++], r = d[y++], p = s.L, e.addData(p, i, r); break; case "m": i += d[y++], r += d[y++], p = s.M, e.addData(p, i, r), o = i, a = r, c = "l"; break; case "M": i = d[y++], r = d[y++], p = s.M, e.addData(p, i, r), o = i, a = r, c = "L"; break; case "h": i += d[y++], p = s.L, e.addData(p, i, r); break; case "H": i = d[y++], p = s.L, e.addData(p, i, r); break; case "v": r += d[y++], p = s.L, e.addData(p, i, r); break; case "V": r = d[y++], p = s.L, e.addData(p, i, r); break; case "C": p = s.C, e.addData(p, d[y++], d[y++], d[y++], d[y++], d[y++], d[y++]), i = d[y - 2], r = d[y - 1]; break; case "c": p = s.C, e.addData(p, d[y++] + i, d[y++] + r, d[y++] + i, d[y++] + r, d[y++] + i, d[y++] + r), i += d[y - 2], r += d[y - 1]; break; case "S": v = i, m = r, T = e.len(), C = e.data, n === s.C && (v += i - C[T - 4], m += r - C[T - 3]), p = s.C, M = d[y++], I = d[y++], i = d[y++], r = d[y++], e.addData(p, v, m, M, I, i, r); break; case "s": v = i, m = r, T = e.len(), C = e.data, n === s.C && (v += i - C[T - 4], m += r - C[T - 3]), p = s.C, M = i + d[y++], I = r + d[y++], i += d[y++], r += d[y++], e.addData(p, v, m, M, I, i, r); break; case "Q": M = d[y++], I = d[y++], i = d[y++], r = d[y++], p = s.Q, e.addData(p, M, I, i, r); break; case "q": M = d[y++] + i, I = d[y++] + r, i += d[y++], r += d[y++], p = s.Q, e.addData(p, M, I, i, r); break; case "T": v = i, m = r, T = e.len(), C = e.data, n === s.Q && (v += i - C[T - 4], m += r - C[T - 3]), i = d[y++], r = d[y++], p = s.Q, e.addData(p, v, m, i, r); break; case "t": v = i, m = r, T = e.len(), C = e.data, n === s.Q && (v += i - C[T - 4], m += r - C[T - 3]), i += d[y++], r += d[y++], p = s.Q, e.addData(p, v, m, i, r); break; case "A": x = d[y++], _ = d[y++], b = d[y++], w = d[y++], S = d[y++], cu(M = i, I = r, i = d[y++], r = d[y++], w, S, x, _, b, p = s.A, e); break; case "a": x = d[y++], _ = d[y++], b = d[y++], w = d[y++], S = d[y++], cu(M = i, I = r, i += d[y++], r += d[y++], w, S, x, _, b, p = s.A, e) } } "z" !== c && "Z" !== c || (p = s.Z, e.addData(p), i = o, r = a), n = p } return e.toStatic(), e }(t), i = A({}, e); return i.buildPath = function (t) { if (gu(t)) { t.setData(n.data), (e = t.getContext()) && t.rebuildPath(e, 1) } else { var e = t; n.rebuildPath(e, 1) } }, i.applyTransform = function (t) { iu(n, t), this.dirtyShape() }, i } function vu(t, e) { return new fu(yu(t, e)) } function mu(t, e) { e = e || {}; var n = new Is; return t.shape && n.setShape(t.shape), n.setStyle(t.style), e.bakeTransform ? iu(n.path, t.getComputedTransform()) : e.toLocal ? n.setLocalTransform(t.getComputedTransform()) : n.copyTransform(t), n.buildPath = t.buildPath, n.applyTransform = n.applyTransform, n.z = t.z, n.z2 = t.z2, n.zlevel = t.zlevel, n } var xu = function () { this.cx = 0, this.cy = 0, this.r = 0 }, _u = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new xu }, e.prototype.buildPath = function (t, e) { t.moveTo(e.cx + e.r, e.cy), t.arc(e.cx, e.cy, e.r, 0, 2 * Math.PI) }, e }(Is); _u.prototype.type = "circle"; var bu = function () { this.cx = 0, this.cy = 0, this.rx = 0, this.ry = 0 }, wu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new bu }, e.prototype.buildPath = function (t, e) { var n = .5522848, i = e.cx, r = e.cy, o = e.rx, a = e.ry, s = o * n, l = a * n; t.moveTo(i - o, r), t.bezierCurveTo(i - o, r - l, i - s, r - a, i, r - a), t.bezierCurveTo(i + s, r - a, i + o, r - l, i + o, r), t.bezierCurveTo(i + o, r + l, i + s, r + a, i, r + a), t.bezierCurveTo(i - s, r + a, i - o, r + l, i - o, r), t.closePath() }, e }(Is); wu.prototype.type = "ellipse"; var Su = Math.PI, Mu = 2 * Su, Iu = Math.sin, Tu = Math.cos, Cu = Math.acos, Du = Math.atan2, Au = Math.abs, ku = Math.sqrt, Lu = Math.max, Pu = Math.min, Ou = 1e-4; function Ru(t, e, n, i, r, o, a) { var s = t - n, l = e - i, u = (a ? o : -o) / ku(s * s + l * l), h = u * l, c = -u * s, p = t + h, d = e + c, f = n + h, g = i + c, y = (p + f) / 2, v = (d + g) / 2, m = f - p, x = g - d, _ = m * m + x * x, b = r - o, w = p * g - f * d, S = (x < 0 ? -1 : 1) * ku(Lu(0, b * b * _ - w * w)), M = (w * x - m * S) / _, I = (-w * m - x * S) / _, T = (w * x + m * S) / _, C = (-w * m + x * S) / _, D = M - y, A = I - v, k = T - y, L = C - v; return D * D + A * A > k * k + L * L && (M = T, I = C), { cx: M, cy: I, x0: -h, y0: -c, x1: M * (r / b - 1), y1: I * (r / b - 1) } } function Nu(t, e) { var n, i = Lu(e.r, 0), r = Lu(e.r0 || 0, 0), o = i > 0; if (o || r > 0) { if (o || (i = r, r = 0), r > i) { var a = i; i = r, r = a } var s = e.startAngle, l = e.endAngle; if (!isNaN(s) && !isNaN(l)) { var u = e.cx, h = e.cy, c = !!e.clockwise, p = Au(l - s), d = p > Mu && p % Mu; if (d > Ou && (p = d), i > Ou) if (p > Mu - Ou) t.moveTo(u + i * Tu(s), h + i * Iu(s)), t.arc(u, h, i, s, l, !c), r > Ou && (t.moveTo(u + r * Tu(l), h + r * Iu(l)), t.arc(u, h, r, l, s, c)); else { var f = void 0, g = void 0, y = void 0, v = void 0, m = void 0, x = void 0, _ = void 0, b = void 0, w = void 0, S = void 0, M = void 0, I = void 0, T = void 0, C = void 0, D = void 0, A = void 0, k = i * Tu(s), L = i * Iu(s), P = r * Tu(l), O = r * Iu(l), R = p > Ou; if (R) { var N = e.cornerRadius; N && (n = function (t) { var e; if (Y(t)) { var n = t.length; if (!n) return t; e = 1 === n ? [t[0], t[0], 0, 0] : 2 === n ? [t[0], t[0], t[1], t[1]] : 3 === n ? t.concat(t[2]) : t } else e = [t, t, t, t]; return e }(N), f = n[0], g = n[1], y = n[2], v = n[3]); var E = Au(i - r) / 2; if (m = Pu(E, y), x = Pu(E, v), _ = Pu(E, f), b = Pu(E, g), M = w = Lu(m, x), I = S = Lu(_, b), (w > Ou || S > Ou) && (T = i * Tu(l), C = i * Iu(l), D = r * Tu(s), A = r * Iu(s), p < Su)) { var z = function (t, e, n, i, r, o, a, s) { var l = n - t, u = i - e, h = a - r, c = s - o, p = c * l - h * u; if (!(p * p < Ou)) return [t + (p = (h * (e - o) - c * (t - r)) / p) * l, e + p * u] }(k, L, D, A, T, C, P, O); if (z) { var V = k - z[0], B = L - z[1], F = T - z[0], G = C - z[1], W = 1 / Iu(Cu((V * F + B * G) / (ku(V * V + B * B) * ku(F * F + G * G))) / 2), H = ku(z[0] * z[0] + z[1] * z[1]); M = Pu(w, (i - H) / (W + 1)), I = Pu(S, (r - H) / (W - 1)) } } } if (R) if (M > Ou) { var X = Pu(y, M), U = Pu(v, M), Z = Ru(D, A, k, L, i, X, c), j = Ru(T, C, P, O, i, U, c); t.moveTo(u + Z.cx + Z.x0, h + Z.cy + Z.y0), M < w && X === U ? t.arc(u + Z.cx, h + Z.cy, M, Du(Z.y0, Z.x0), Du(j.y0, j.x0), !c) : (X > 0 && t.arc(u + Z.cx, h + Z.cy, X, Du(Z.y0, Z.x0), Du(Z.y1, Z.x1), !c), t.arc(u, h, i, Du(Z.cy + Z.y1, Z.cx + Z.x1), Du(j.cy + j.y1, j.cx + j.x1), !c), U > 0 && t.arc(u + j.cx, h + j.cy, U, Du(j.y1, j.x1), Du(j.y0, j.x0), !c)) } else t.moveTo(u + k, h + L), t.arc(u, h, i, s, l, !c); else t.moveTo(u + k, h + L); if (r > Ou && R) if (I > Ou) { X = Pu(f, I), Z = Ru(P, O, T, C, r, -(U = Pu(g, I)), c), j = Ru(k, L, D, A, r, -X, c); t.lineTo(u + Z.cx + Z.x0, h + Z.cy + Z.y0), I < S && X === U ? t.arc(u + Z.cx, h + Z.cy, I, Du(Z.y0, Z.x0), Du(j.y0, j.x0), !c) : (U > 0 && t.arc(u + Z.cx, h + Z.cy, U, Du(Z.y0, Z.x0), Du(Z.y1, Z.x1), !c), t.arc(u, h, r, Du(Z.cy + Z.y1, Z.cx + Z.x1), Du(j.cy + j.y1, j.cx + j.x1), c), X > 0 && t.arc(u + j.cx, h + j.cy, X, Du(j.y1, j.x1), Du(j.y0, j.x0), !c)) } else t.lineTo(u + P, h + O), t.arc(u, h, r, l, s, c); else t.lineTo(u + P, h + O) } else t.moveTo(u, h); t.closePath() } } } var Eu = function () { this.cx = 0, this.cy = 0, this.r0 = 0, this.r = 0, this.startAngle = 0, this.endAngle = 2 * Math.PI, this.clockwise = !0, this.cornerRadius = 0 }, zu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new Eu }, e.prototype.buildPath = function (t, e) { Nu(t, e) }, e.prototype.isZeroArea = function () { return this.shape.startAngle === this.shape.endAngle || this.shape.r === this.shape.r0 }, e }(Is); zu.prototype.type = "sector"; var Vu = function () { this.cx = 0, this.cy = 0, this.r = 0, this.r0 = 0 }, Bu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new Vu }, e.prototype.buildPath = function (t, e) { var n = e.cx, i = e.cy, r = 2 * Math.PI; t.moveTo(n + e.r, i), t.arc(n, i, e.r, 0, r, !1), t.moveTo(n + e.r0, i), t.arc(n, i, e.r0, 0, r, !0) }, e }(Is); function Fu(t, e, n) { var i = e.smooth, r = e.points; if (r && r.length >= 2) { if (i) { var o = function (t, e, n, i) { var r, o, a, s, l = [], u = [], h = [], c = []; if (i) { a = [1 / 0, 1 / 0], s = [-1 / 0, -1 / 0]; for (var p = 0, d = t.length; p < d; p++)Ht(a, a, t[p]), Yt(s, s, t[p]); Ht(a, a, i[0]), Yt(s, s, i[1]) } for (p = 0, d = t.length; p < d; p++) { var f = t[p]; if (n) r = t[p ? p - 1 : d - 1], o = t[(p + 1) % d]; else { if (0 === p || p === d - 1) { l.push(Tt(t[p])); continue } r = t[p - 1], o = t[p + 1] } kt(u, o, r), Nt(u, u, e); var g = zt(f, r), y = zt(f, o), v = g + y; 0 !== v && (g /= v, y /= v), Nt(h, u, -g), Nt(c, u, y); var m = Dt([], f, h), x = Dt([], f, c); i && (Yt(m, m, a), Ht(m, m, s), Yt(x, x, a), Ht(x, x, s)), l.push(m), l.push(x) } return n && l.push(l.shift()), l }(r, i, n, e.smoothConstraint); t.moveTo(r[0][0], r[0][1]); for (var a = r.length, s = 0; s < (n ? a : a - 1); s++) { var l = o[2 * s], u = o[2 * s + 1], h = r[(s + 1) % a]; t.bezierCurveTo(l[0], l[1], u[0], u[1], h[0], h[1]) } } else { t.moveTo(r[0][0], r[0][1]); s = 1; for (var c = r.length; s < c; s++)t.lineTo(r[s][0], r[s][1]) } n && t.closePath() } } Bu.prototype.type = "ring"; var Gu = function () { this.points = null, this.smooth = 0, this.smoothConstraint = null }, Wu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new Gu }, e.prototype.buildPath = function (t, e) { Fu(t, e, !0) }, e }(Is); Wu.prototype.type = "polygon"; var Hu = function () { this.points = null, this.percent = 1, this.smooth = 0, this.smoothConstraint = null }, Yu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new Hu }, e.prototype.buildPath = function (t, e) { Fu(t, e, !1) }, e }(Is); Yu.prototype.type = "polyline"; var Xu = {}, Uu = function () { this.x1 = 0, this.y1 = 0, this.x2 = 0, this.y2 = 0, this.percent = 1 }, Zu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new Uu }, e.prototype.buildPath = function (t, e) { var n, i, r, o; if (this.subPixelOptimize) { var a = Ps(Xu, e, this.style); n = a.x1, i = a.y1, r = a.x2, o = a.y2 } else n = e.x1, i = e.y1, r = e.x2, o = e.y2; var s = e.percent; 0 !== s && (t.moveTo(n, i), s < 1 && (r = n * (1 - s) + r * s, o = i * (1 - s) + o * s), t.lineTo(r, o)) }, e.prototype.pointAt = function (t) { var e = this.shape; return [e.x1 * (1 - t) + e.x2 * t, e.y1 * (1 - t) + e.y2 * t] }, e }(Is); Zu.prototype.type = "line"; var ju = [], qu = function () { this.x1 = 0, this.y1 = 0, this.x2 = 0, this.y2 = 0, this.cpx1 = 0, this.cpy1 = 0, this.percent = 1 }; function Ku(t, e, n) { var i = t.cpx2, r = t.cpy2; return null != i || null != r ? [(n ? xn : mn)(t.x1, t.cpx1, t.cpx2, t.x2, e), (n ? xn : mn)(t.y1, t.cpy1, t.cpy2, t.y2, e)] : [(n ? Tn : In)(t.x1, t.cpx1, t.x2, e), (n ? Tn : In)(t.y1, t.cpy1, t.y2, e)] } var $u = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new qu }, e.prototype.buildPath = function (t, e) { var n = e.x1, i = e.y1, r = e.x2, o = e.y2, a = e.cpx1, s = e.cpy1, l = e.cpx2, u = e.cpy2, h = e.percent; 0 !== h && (t.moveTo(n, i), null == l || null == u ? (h < 1 && (Dn(n, a, r, h, ju), a = ju[1], r = ju[2], Dn(i, s, o, h, ju), s = ju[1], o = ju[2]), t.quadraticCurveTo(a, s, r, o)) : (h < 1 && (wn(n, a, l, r, h, ju), a = ju[1], l = ju[2], r = ju[3], wn(i, s, u, o, h, ju), s = ju[1], u = ju[2], o = ju[3]), t.bezierCurveTo(a, s, l, u, r, o))) }, e.prototype.pointAt = function (t) { return Ku(this.shape, t, !1) }, e.prototype.tangentAt = function (t) { var e = Ku(this.shape, t, !0); return Et(e, e) }, e }(Is); $u.prototype.type = "bezier-curve"; var Ju = function () { this.cx = 0, this.cy = 0, this.r = 0, this.startAngle = 0, this.endAngle = 2 * Math.PI, this.clockwise = !0 }, Qu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new Ju }, e.prototype.buildPath = function (t, e) { var n = e.cx, i = e.cy, r = Math.max(e.r, 0), o = e.startAngle, a = e.endAngle, s = e.clockwise, l = Math.cos(o), u = Math.sin(o); t.moveTo(l * r + n, u * r + i), t.arc(n, i, r, o, a, !s) }, e }(Is); Qu.prototype.type = "arc"; var th = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "compound", e } return n(e, t), e.prototype._updatePathDirty = function () { for (var t = this.shape.paths, e = this.shapeChanged(), n = 0; n < t.length; n++)e = e || t[n].shapeChanged(); e && this.dirtyShape() }, e.prototype.beforeBrush = function () { this._updatePathDirty(); for (var t = this.shape.paths || [], e = this.getGlobalScale(), n = 0; n < t.length; n++)t[n].path || t[n].createPathProxy(), t[n].path.setScale(e[0], e[1], t[n].segmentIgnoreThreshold) }, e.prototype.buildPath = function (t, e) { for (var n = e.paths || [], i = 0; i < n.length; i++)n[i].buildPath(t, n[i].shape, !0) }, e.prototype.afterBrush = function () { for (var t = this.shape.paths || [], e = 0; e < t.length; e++)t[e].pathUpdated() }, e.prototype.getBoundingRect = function () { return this._updatePathDirty.call(this), Is.prototype.getBoundingRect.call(this) }, e }(Is), eh = function () { function t(t) { this.colorStops = t || [] } return t.prototype.addColorStop = function (t, e) { this.colorStops.push({ offset: t, color: e }) }, t }(), nh = function (t) { function e(e, n, i, r, o, a) { var s = t.call(this, o) || this; return s.x = null == e ? 0 : e, s.y = null == n ? 0 : n, s.x2 = null == i ? 1 : i, s.y2 = null == r ? 0 : r, s.type = "linear", s.global = a || !1, s } return n(e, t), e }(eh), ih = function (t) { function e(e, n, i, r, o) { var a = t.call(this, r) || this; return a.x = null == e ? .5 : e, a.y = null == n ? .5 : n, a.r = null == i ? .5 : i, a.type = "radial", a.global = o || !1, a } return n(e, t), e }(eh), rh = [0, 0], oh = [0, 0], ah = new De, sh = new De, lh = function () { function t(t, e) { this._corners = [], this._axes = [], this._origin = [0, 0]; for (var n = 0; n < 4; n++)this._corners[n] = new De; for (n = 0; n < 2; n++)this._axes[n] = new De; t && this.fromBoundingRect(t, e) } return t.prototype.fromBoundingRect = function (t, e) { var n = this._corners, i = this._axes, r = t.x, o = t.y, a = r + t.width, s = o + t.height; if (n[0].set(r, o), n[1].set(a, o), n[2].set(a, s), n[3].set(r, s), e) for (var l = 0; l < 4; l++)n[l].transform(e); De.sub(i[0], n[1], n[0]), De.sub(i[1], n[3], n[0]), i[0].normalize(), i[1].normalize(); for (l = 0; l < 2; l++)this._origin[l] = i[l].dot(n[0]) }, t.prototype.intersect = function (t, e) { var n = !0, i = !e; return ah.set(1 / 0, 1 / 0), sh.set(0, 0), !this._intersectCheckOneSide(this, t, ah, sh, i, 1) && (n = !1, i) || !this._intersectCheckOneSide(t, this, ah, sh, i, -1) && (n = !1, i) || i || De.copy(e, n ? ah : sh), n }, t.prototype._intersectCheckOneSide = function (t, e, n, i, r, o) { for (var a = !0, s = 0; s < 2; s++) { var l = this._axes[s]; if (this._getProjMinMaxOnAxis(s, t._corners, rh), this._getProjMinMaxOnAxis(s, e._corners, oh), rh[1] < oh[0] || rh[0] > oh[1]) { if (a = !1, r) return a; var u = Math.abs(oh[0] - rh[1]), h = Math.abs(rh[0] - oh[1]); Math.min(u, h) > i.len() && (u < h ? De.scale(i, l, -u * o) : De.scale(i, l, h * o)) } else if (n) { u = Math.abs(oh[0] - rh[1]), h = Math.abs(rh[0] - oh[1]); Math.min(u, h) < n.len() && (u < h ? De.scale(n, l, u * o) : De.scale(n, l, -h * o)) } } return a }, t.prototype._getProjMinMaxOnAxis = function (t, e, n) { for (var i = this._axes[t], r = this._origin, o = e[0].dot(i) + r[t], a = o, s = o, l = 1; l < e.length; l++) { var u = e[l].dot(i) + r[t]; a = Math.min(u, a), s = Math.max(u, s) } n[0] = a, n[1] = s }, t }(), uh = [], hh = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.notClear = !0, e.incremental = !0, e._displayables = [], e._temporaryDisplayables = [], e._cursor = 0, e } return n(e, t), e.prototype.traverse = function (t, e) { t.call(e, this) }, e.prototype.useStyle = function () { this.style = {} }, e.prototype.getCursor = function () { return this._cursor }, e.prototype.innerAfterBrush = function () { this._cursor = this._displayables.length }, e.prototype.clearDisplaybles = function () { this._displayables = [], this._temporaryDisplayables = [], this._cursor = 0, this.markRedraw(), this.notClear = !1 }, e.prototype.clearTemporalDisplayables = function () { this._temporaryDisplayables = [] }, e.prototype.addDisplayable = function (t, e) { e ? this._temporaryDisplayables.push(t) : this._displayables.push(t), this.markRedraw() }, e.prototype.addDisplayables = function (t, e) { e = e || !1; for (var n = 0; n < t.length; n++)this.addDisplayable(t[n], e) }, e.prototype.getDisplayables = function () { return this._displayables }, e.prototype.getTemporalDisplayables = function () { return this._temporaryDisplayables }, e.prototype.eachPendingDisplayable = function (t) { for (var e = this._cursor; e < this._displayables.length; e++)t && t(this._displayables[e]); for (e = 0; e < this._temporaryDisplayables.length; e++)t && t(this._temporaryDisplayables[e]) }, e.prototype.update = function () { this.updateTransform(); for (var t = this._cursor; t < this._displayables.length; t++) { (e = this._displayables[t]).parent = this, e.update(), e.parent = null } for (t = 0; t < this._temporaryDisplayables.length; t++) { var e; (e = this._temporaryDisplayables[t]).parent = this, e.update(), e.parent = null } }, e.prototype.getBoundingRect = function () { if (!this._rect) { for (var t = new ze(1 / 0, 1 / 0, -1 / 0, -1 / 0), e = 0; e < this._displayables.length; e++) { var n = this._displayables[e], i = n.getBoundingRect().clone(); n.needLocalTransform() && i.applyTransform(n.getLocalTransform(uh)), t.union(i) } this._rect = t } return this._rect }, e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e); if (this.getBoundingRect().contain(n[0], n[1])) for (var i = 0; i < this._displayables.length; i++) { if (this._displayables[i].contain(t, e)) return !0 } return !1 }, e }(Sa), ch = Oo(); function ph(t, e, n, i, r) { var o; if (e && e.ecModel) { var a = e.ecModel.getUpdatePayload(); o = a && a.animation } var s = "update" === t; if (e && e.isAnimationEnabled()) { var l = void 0, u = void 0, h = void 0; return i ? (l = rt(i.duration, 200), u = rt(i.easing, "cubicOut"), h = 0) : (l = e.getShallow(s ? "animationDurationUpdate" : "animationDuration"), u = e.getShallow(s ? "animationEasingUpdate" : "animationEasing"), h = e.getShallow(s ? "animationDelayUpdate" : "animationDelay")), o && (null != o.duration && (l = o.duration), null != o.easing && (u = o.easing), null != o.delay && (h = o.delay)), X(h) && (h = h(n, r)), X(l) && (l = l(n)), { duration: l || 0, delay: h, easing: u } } return null } function dh(t, e, n, i, r, o, a) { var s, l = !1; X(r) ? (a = o, o = r, r = null) : q(r) && (o = r.cb, a = r.during, l = r.isFrom, s = r.removeOpt, r = r.dataIndex); var u = "leave" === t; u || e.stopAnimation("leave"); var h = ph(t, i, r, u ? s || {} : null, i && i.getAnimationDelayParams ? i.getAnimationDelayParams(e, r) : null); if (h && h.duration > 0) { var c = { duration: h.duration, delay: h.delay || 0, easing: h.easing, done: o, force: !!o || !!a, setToFinal: !u, scope: t, during: a }; l ? e.animateFrom(n, c) : e.animateTo(n, c) } else e.stopAnimation(), !l && e.attr(n), a && a(1), o && o() } function fh(t, e, n, i, r, o) { dh("update", t, e, n, i, r, o) } function gh(t, e, n, i, r, o) { dh("enter", t, e, n, i, r, o) } function yh(t) { if (!t.__zr) return !0; for (var e = 0; e < t.animators.length; e++) { if ("leave" === t.animators[e].scope) return !0 } return !1 } function vh(t, e, n, i, r, o) { yh(t) || dh("leave", t, e, n, i, r, o) } function mh(t, e, n, i) { t.removeTextContent(), t.removeTextGuideLine(), vh(t, { style: { opacity: 0 } }, e, n, i) } function xh(t, e, n) { function i() { t.parent && t.parent.remove(t) } t.isGroup ? t.traverse((function (t) { t.isGroup || mh(t, e, n, i) })) : mh(t, e, n, i) } function _h(t) { ch(t).oldStyle = t.style } var bh = Math.max, wh = Math.min, Sh = {}; function Mh(t) { return Is.extend(t) } var Ih = function (t, e) { var i = yu(t, e); return function (t) { function e(e) { var n = t.call(this, e) || this; return n.applyTransform = i.applyTransform, n.buildPath = i.buildPath, n } return n(e, t), e }(fu) }; function Th(t, e) { return Ih(t, e) } function Ch(t, e) { Sh[t] = e } function Dh(t) { if (Sh.hasOwnProperty(t)) return Sh[t] } function Ah(t, e, n, i) { var r = vu(t, e); return n && ("center" === i && (n = Lh(n, r.getBoundingRect())), Oh(r, n)), r } function kh(t, e, n) { var i = new ks({ style: { image: t, x: e.x, y: e.y, width: e.width, height: e.height }, onload: function (t) { if ("center" === n) { var r = { width: t.width, height: t.height }; i.setStyle(Lh(e, r)) } } }); return i } function Lh(t, e) { var n, i = e.width / e.height, r = t.height * i; return n = r <= t.width ? t.height : (r = t.width) / i, { x: t.x + t.width / 2 - r / 2, y: t.y + t.height / 2 - n / 2, width: r, height: n } } var Ph = function (t, e) { for (var n = [], i = t.length, r = 0; r < i; r++) { var o = t[r]; n.push(o.getUpdatedPathProxy(!0)) } var a = new Is(e); return a.createPathProxy(), a.buildPath = function (t) { if (gu(t)) { t.appendPath(n); var e = t.getContext(); e && t.rebuildPath(e, 1) } }, a }; function Oh(t, e) { if (t.applyTransform) { var n = t.getBoundingRect().calculateTransform(e); t.applyTransform(n) } } function Rh(t, e) { return Ps(t, t, { lineWidth: e }), t } var Nh = Rs; function Eh(t, e) { for (var n = xe([]); t && t !== e;)be(n, t.getLocalTransform(), n), t = t.parent; return n } function zh(t, e, n) { return e && !N(e) && (e = gr.getLocalTransform(e)), n && (e = Ie([], e)), Wt([], t, e) } function Vh(t, e, n) { var i = 0 === e[4] || 0 === e[5] || 0 === e[0] ? 1 : Math.abs(2 * e[4] / e[0]), r = 0 === e[4] || 0 === e[5] || 0 === e[2] ? 1 : Math.abs(2 * e[4] / e[2]), o = ["left" === t ? -i : "right" === t ? i : 0, "top" === t ? -r : "bottom" === t ? r : 0]; return o = zh(o, e, n), Math.abs(o[0]) > Math.abs(o[1]) ? o[0] > 0 ? "right" : "left" : o[1] > 0 ? "bottom" : "top" } function Bh(t) { return !t.isGroup } function Fh(t, e, n) { if (t && e) { var i, r = (i = {}, t.traverse((function (t) { Bh(t) && t.anid && (i[t.anid] = t) })), i); e.traverse((function (t) { if (Bh(t) && t.anid) { var e = r[t.anid]; if (e) { var i = o(t); t.attr(o(e)), fh(t, i, n, Qs(t).dataIndex) } } })) } function o(t) { var e = { x: t.x, y: t.y, rotation: t.rotation }; return function (t) { return null != t.shape }(t) && (e.shape = A({}, t.shape)), e } } function Gh(t, e) { return z(t, (function (t) { var n = t[0]; n = bh(n, e.x), n = wh(n, e.x + e.width); var i = t[1]; return i = bh(i, e.y), [n, i = wh(i, e.y + e.height)] })) } function Wh(t, e) { var n = bh(t.x, e.x), i = wh(t.x + t.width, e.x + e.width), r = bh(t.y, e.y), o = wh(t.y + t.height, e.y + e.height); if (i >= n && o >= r) return { x: n, y: r, width: i - n, height: o - r } } function Hh(t, e, n) { var i = A({ rectHover: !0 }, e), r = i.style = { strokeNoScale: !0 }; if (n = n || { x: -1, y: -1, width: 2, height: 2 }, t) return 0 === t.indexOf("image://") ? (r.image = t.slice(8), k(r, n), new ks(i)) : Ah(t.replace("path://", ""), i, n, "center") } function Yh(t, e, n, i, r) { for (var o = 0, a = r[r.length - 1]; o < r.length; o++) { var s = r[o]; if (Xh(t, e, n, i, s[0], s[1], a[0], a[1])) return !0; a = s } } function Xh(t, e, n, i, r, o, a, s) { var l, u = n - t, h = i - e, c = a - r, p = s - o, d = Uh(c, p, u, h); if ((l = d) <= 1e-6 && l >= -1e-6) return !1; var f = t - r, g = e - o, y = Uh(f, g, u, h) / d; if (y < 0 || y > 1) return !1; var v = Uh(f, g, c, p) / d; return !(v < 0 || v > 1) } function Uh(t, e, n, i) { return t * i - n * e } function Zh(t) { var e = t.itemTooltipOption, n = t.componentModel, i = t.itemName, r = U(e) ? { formatter: e } : e, o = n.mainType, a = n.componentIndex, s = { componentType: o, name: i, $vars: ["name"] }; s[o + "Index"] = a; var l = t.formatterParamsExtra; l && E(G(l), (function (t) { _t(s, t) || (s[t] = l[t], s.$vars.push(t)) })); var u = Qs(t.el); u.componentMainType = o, u.componentIndex = a, u.tooltipConfig = { name: i, option: k({ content: i, formatterParams: s }, r) } } function jh(t, e) { var n; t.isGroup && (n = e(t)), n || t.traverse(e) } function qh(t, e) { if (t) if (Y(t)) for (var n = 0; n < t.length; n++)jh(t[n], e); else jh(t, e) } Ch("circle", _u), Ch("ellipse", wu), Ch("sector", zu), Ch("ring", Bu), Ch("polygon", Wu), Ch("polyline", Yu), Ch("rect", zs), Ch("line", Zu), Ch("bezierCurve", $u), Ch("arc", Qu); var Kh = Object.freeze({ __proto__: null, updateProps: fh, initProps: gh, removeElement: vh, removeElementWithFadeOut: xh, isElementRemoved: yh, extendShape: Mh, extendPath: Th, registerShape: Ch, getShapeClass: Dh, makePath: Ah, makeImage: kh, mergePath: Ph, resizePath: Oh, subPixelOptimizeLine: Rh, subPixelOptimizeRect: function (t) { return Os(t.shape, t.shape, t.style), t }, subPixelOptimize: Nh, getTransform: Eh, applyTransform: zh, transformDirection: Vh, groupTransition: Fh, clipPointsByRect: Gh, clipRectByRect: Wh, createIcon: Hh, linePolygonIntersect: Yh, lineLineIntersect: Xh, setTooltipConfig: Zh, traverseElements: qh, Group: zr, Image: ks, Text: Fs, Circle: _u, Ellipse: wu, Sector: zu, Ring: Bu, Polygon: Wu, Polyline: Yu, Rect: zs, Line: Zu, BezierCurve: $u, Arc: Qu, IncrementalDisplayable: hh, CompoundPath: th, LinearGradient: nh, RadialGradient: ih, BoundingRect: ze, OrientedBoundingRect: lh, Point: De, Path: Is }), $h = {}; function Jh(t, e) { for (var n = 0; n < ol.length; n++) { var i = ol[n], r = e[i], o = t.ensureState(i); o.style = o.style || {}, o.style.text = r } var a = t.currentStates.slice(); t.clearStates(!0), t.setStyle({ text: e.normal }), t.useStates(a, !0) } function Qh(t, e, n) { var i, r = t.labelFetcher, o = t.labelDataIndex, a = t.labelDimIndex, s = e.normal; r && (i = r.getFormattedLabel(o, "normal", null, a, s && s.get("formatter"), null != n ? { interpolatedValue: n } : null)), null == i && (i = X(t.defaultText) ? t.defaultText(o, t, n) : t.defaultText); for (var l = { normal: i }, u = 0; u < ol.length; u++) { var h = ol[u], c = e[h]; l[h] = rt(r ? r.getFormattedLabel(o, h, null, a, c && c.get("formatter")) : null, i) } return l } function tc(t, e, n, i) { n = n || $h; for (var r = t instanceof Fs, o = !1, a = 0; a < al.length; a++) { if ((p = e[al[a]]) && p.getShallow("show")) { o = !0; break } } var s = r ? t : t.getTextContent(); if (o) { r || (s || (s = new Fs, t.setTextContent(s)), t.stateProxy && (s.stateProxy = t.stateProxy)); var l = Qh(n, e), u = e.normal, h = !!u.getShallow("show"), c = nc(u, i && i.normal, n, !1, !r); c.text = l.normal, r || t.setTextConfig(ic(u, n, !1)); for (a = 0; a < ol.length; a++) { var p, d = ol[a]; if (p = e[d]) { var f = s.ensureState(d), g = !!rt(p.getShallow("show"), h); if (g !== h && (f.ignore = !g), f.style = nc(p, i && i[d], n, !0, !r), f.style.text = l[d], !r) t.ensureState(d).textConfig = ic(p, n, !0) } } s.silent = !!u.getShallow("silent"), null != s.style.x && (c.x = s.style.x), null != s.style.y && (c.y = s.style.y), s.ignore = !h, s.useStyle(c), s.dirty(), n.enableTextSetter && (uc(s).setLabelText = function (t) { var i = Qh(n, e, t); Jh(s, i) }) } else s && (s.ignore = !0); t.dirty() } function ec(t, e) { e = e || "label"; for (var n = { normal: t.getModel(e) }, i = 0; i < ol.length; i++) { var r = ol[i]; n[r] = t.getModel([r, e]) } return n } function nc(t, e, n, i, r) { var o = {}; return function (t, e, n, i, r) { n = n || $h; var o, a = e.ecModel, s = a && a.option.textStyle, l = function (t) { var e; for (; t && t !== t.ecModel;) { var n = (t.option || $h).rich; if (n) { e = e || {}; for (var i = G(n), r = 0; r < i.length; r++) { e[i[r]] = 1 } } t = t.parentModel } return e }(e); if (l) for (var u in o = {}, l) if (l.hasOwnProperty(u)) { var h = e.getModel(["rich", u]); sc(o[u] = {}, h, s, n, i, r, !1, !0) } o && (t.rich = o); var c = e.get("overflow"); c && (t.overflow = c); var p = e.get("minMargin"); null != p && (t.margin = p); sc(t, e, s, n, i, r, !0, !1) }(o, t, n, i, r), e && A(o, e), o } function ic(t, e, n) { e = e || {}; var i, r = {}, o = t.getShallow("rotate"), a = rt(t.getShallow("distance"), n ? null : 5), s = t.getShallow("offset"); return "outside" === (i = t.getShallow("position") || (n ? null : "inside")) && (i = e.defaultOutsidePosition || "top"), null != i && (r.position = i), null != s && (r.offset = s), null != o && (o *= Math.PI / 180, r.rotation = o), null != a && (r.distance = a), r.outsideFill = "inherit" === t.get("color") ? e.inheritColor || null : "auto", r } var rc = ["fontStyle", "fontWeight", "fontSize", "fontFamily", "textShadowColor", "textShadowBlur", "textShadowOffsetX", "textShadowOffsetY"], oc = ["align", "lineHeight", "width", "height", "tag", "verticalAlign", "ellipsis"], ac = ["padding", "borderWidth", "borderRadius", "borderDashOffset", "backgroundColor", "borderColor", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY"]; function sc(t, e, n, i, r, o, a, s) { n = !r && n || $h; var l = i && i.inheritColor, u = e.getShallow("color"), h = e.getShallow("textBorderColor"), c = rt(e.getShallow("opacity"), n.opacity); "inherit" !== u && "auto" !== u || (u = l || null), "inherit" !== h && "auto" !== h || (h = l || null), o || (u = u || n.color, h = h || n.textBorderColor), null != u && (t.fill = u), null != h && (t.stroke = h); var p = rt(e.getShallow("textBorderWidth"), n.textBorderWidth); null != p && (t.lineWidth = p); var d = rt(e.getShallow("textBorderType"), n.textBorderType); null != d && (t.lineDash = d); var f = rt(e.getShallow("textBorderDashOffset"), n.textBorderDashOffset); null != f && (t.lineDashOffset = f), r || null != c || s || (c = i && i.defaultOpacity), null != c && (t.opacity = c), r || o || null == t.fill && i.inheritColor && (t.fill = i.inheritColor); for (var g = 0; g < rc.length; g++) { var y = rc[g]; null != (m = rt(e.getShallow(y), n[y])) && (t[y] = m) } for (g = 0; g < oc.length; g++) { y = oc[g]; null != (m = e.getShallow(y)) && (t[y] = m) } if (null == t.verticalAlign) { var v = e.getShallow("baseline"); null != v && (t.verticalAlign = v) } if (!a || !i.disableBox) { for (g = 0; g < ac.length; g++) { var m; y = ac[g]; null != (m = e.getShallow(y)) && (t[y] = m) } var x = e.getShallow("borderType"); null != x && (t.borderDash = x), "auto" !== t.backgroundColor && "inherit" !== t.backgroundColor || !l || (t.backgroundColor = l), "auto" !== t.borderColor && "inherit" !== t.borderColor || !l || (t.borderColor = l) } } function lc(t, e) { var n = e && e.getModel("textStyle"); return ut([t.fontStyle || n && n.getShallow("fontStyle") || "", t.fontWeight || n && n.getShallow("fontWeight") || "", (t.fontSize || n && n.getShallow("fontSize") || 12) + "px", t.fontFamily || n && n.getShallow("fontFamily") || "sans-serif"].join(" ")) } var uc = Oo(); function hc(t, e, n, i) { if (t) { var r = uc(t); r.prevValue = r.value, r.value = n; var o = e.normal; r.valueAnimation = o.get("valueAnimation"), r.valueAnimation && (r.precision = o.get("precision"), r.defaultInterpolatedText = i, r.statesModels = e) } } function cc(t, e, n, i, r) { var o = uc(t); if (o.valueAnimation && o.prevValue !== o.value) { var a = o.defaultInterpolatedText, s = rt(o.interpolatedValue, o.prevValue), l = o.value; t.percent = 0, (null == o.prevValue ? gh : fh)(t, { percent: 1 }, i, e, null, (function (i) { var u = Wo(n, o.precision, s, l, i); o.interpolatedValue = 1 === i ? null : u; var h = Qh({ labelDataIndex: e, labelFetcher: r, defaultText: a ? a(u) : u + "" }, o.statesModels, u); Jh(t, h) })) } } var pc, dc, fc = ["textStyle", "color"], gc = ["fontStyle", "fontWeight", "fontSize", "fontFamily", "padding", "lineHeight", "rich", "width", "height", "overflow"], yc = new Fs, vc = function () { function t() { } return t.prototype.getTextColor = function (t) { var e = this.ecModel; return this.getShallow("color") || (!t && e ? e.get(fc) : null) }, t.prototype.getFont = function () { return lc({ fontStyle: this.getShallow("fontStyle"), fontWeight: this.getShallow("fontWeight"), fontSize: this.getShallow("fontSize"), fontFamily: this.getShallow("fontFamily") }, this.ecModel) }, t.prototype.getTextRect = function (t) { for (var e = { text: t, verticalAlign: this.getShallow("verticalAlign") || this.getShallow("baseline") }, n = 0; n < gc.length; n++)e[gc[n]] = this.getShallow(gc[n]); return yc.useStyle(e), yc.update(), yc.getBoundingRect() }, t }(), mc = [["lineWidth", "width"], ["stroke", "color"], ["opacity"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"], ["lineDash", "type"], ["lineDashOffset", "dashOffset"], ["lineCap", "cap"], ["lineJoin", "join"], ["miterLimit"]], xc = Jo(mc), _c = function () { function t() { } return t.prototype.getLineStyle = function (t) { return xc(this, t) }, t }(), bc = [["fill", "color"], ["stroke", "borderColor"], ["lineWidth", "borderWidth"], ["opacity"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"], ["lineDash", "borderType"], ["lineDashOffset", "borderDashOffset"], ["lineCap", "borderCap"], ["lineJoin", "borderJoin"], ["miterLimit", "borderMiterLimit"]], wc = Jo(bc), Sc = function () { function t() { } return t.prototype.getItemStyle = function (t, e) { return wc(this, t, e) }, t }(), Mc = function () { function t(t, e, n) { this.parentModel = e, this.ecModel = n, this.option = t } return t.prototype.init = function (t, e, n) { for (var i = [], r = 3; r < arguments.length; r++)i[r - 3] = arguments[r] }, t.prototype.mergeOption = function (t, e) { C(this.option, t, !0) }, t.prototype.get = function (t, e) { return null == t ? this.option : this._doGet(this.parsePath(t), !e && this.parentModel) }, t.prototype.getShallow = function (t, e) { var n = this.option, i = null == n ? n : n[t]; if (null == i && !e) { var r = this.parentModel; r && (i = r.getShallow(t)) } return i }, t.prototype.getModel = function (e, n) { var i = null != e, r = i ? this.parsePath(e) : null; return new t(i ? this._doGet(r) : this.option, n = n || this.parentModel && this.parentModel.getModel(this.resolveParentPath(r)), this.ecModel) }, t.prototype.isEmpty = function () { return null == this.option }, t.prototype.restoreData = function () { }, t.prototype.clone = function () { return new (0, this.constructor)(T(this.option)) }, t.prototype.parsePath = function (t) { return "string" == typeof t ? t.split(".") : t }, t.prototype.resolveParentPath = function (t) { return t }, t.prototype.isAnimationEnabled = function () { if (!r.node && this.option) { if (null != this.option.animation) return !!this.option.animation; if (this.parentModel) return this.parentModel.isAnimationEnabled() } }, t.prototype._doGet = function (t, e) { var n = this.option; if (!t) return n; for (var i = 0; i < t.length && (!t[i] || null != (n = n && "object" == typeof n ? n[t[i]] : null)); i++); return null == n && e && (n = e._doGet(this.resolveParentPath(t), e.parentModel)), n }, t }(); Uo(Mc), pc = Mc, dc = ["__\0is_clz", jo++].join("_"), pc.prototype[dc] = !0, pc.isInstance = function (t) { return !(!t || !t[dc]) }, R(Mc, _c), R(Mc, Sc), R(Mc, ta), R(Mc, vc); var Ic = Math.round(10 * Math.random()); function Tc(t) { return [t || "", Ic++].join("_") } function Cc(t, e) { return C(C({}, t, !0), e, !0) } var Dc = "ZH", Ac = "EN", kc = Ac, Lc = {}, Pc = {}, Oc = r.domSupported && (document.documentElement.lang || navigator.language || navigator.browserLanguage).toUpperCase().indexOf(Dc) > -1 ? Dc : kc; function Rc(t, e) { t = t.toUpperCase(), Pc[t] = new Mc(e), Lc[t] = e } function Nc(t) { return Pc[t] } Rc(Ac, { time: { month: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], monthAbbr: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], dayOfWeek: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], dayOfWeekAbbr: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"] }, legend: { selector: { all: "All", inverse: "Inv" } }, toolbox: { brush: { title: { rect: "Box Select", polygon: "Lasso Select", lineX: "Horizontally Select", lineY: "Vertically Select", keep: "Keep Selections", clear: "Clear Selections" } }, dataView: { title: "Data View", lang: ["Data View", "Close", "Refresh"] }, dataZoom: { title: { zoom: "Zoom", back: "Zoom Reset" } }, magicType: { title: { line: "Switch to Line Chart", bar: "Switch to Bar Chart", stack: "Stack", tiled: "Tile" } }, restore: { title: "Restore" }, saveAsImage: { title: "Save as Image", lang: ["Right Click to Save Image"] } }, series: { typeNames: { pie: "Pie chart", bar: "Bar chart", line: "Line chart", scatter: "Scatter plot", effectScatter: "Ripple scatter plot", radar: "Radar chart", tree: "Tree", treemap: "Treemap", boxplot: "Boxplot", candlestick: "Candlestick", k: "K line chart", heatmap: "Heat map", map: "Map", parallel: "Parallel coordinate map", lines: "Line graph", graph: "Relationship graph", sankey: "Sankey diagram", funnel: "Funnel chart", gauge: "Gauge", pictorialBar: "Pictorial bar", themeRiver: "Theme River Map", sunburst: "Sunburst" } }, aria: { general: { withTitle: 'This is a chart about "{title}"', withoutTitle: "This is a chart" }, series: { single: { prefix: "", withName: " with type {seriesType} named {seriesName}.", withoutName: " with type {seriesType}." }, multiple: { prefix: ". It consists of {seriesCount} series count.", withName: " The {seriesId} series is a {seriesType} representing {seriesName}.", withoutName: " The {seriesId} series is a {seriesType}.", separator: { middle: "", end: "" } } }, data: { allData: "The data is as follows: ", partialData: "The first {displayCnt} items are: ", withName: "the data for {name} is {value}", withoutName: "{value}", separator: { middle: ", ", end: ". " } } } }), Rc(Dc, { time: { month: ["一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月"], monthAbbr: ["1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月", "11月", "12月"], dayOfWeek: ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"], dayOfWeekAbbr: ["日", "一", "二", "三", "四", "五", "六"] }, legend: { selector: { all: "全选", inverse: "反选" } }, toolbox: { brush: { title: { rect: "矩形选择", polygon: "圈选", lineX: "横向选择", lineY: "纵向选择", keep: "保持选择", clear: "清除选择" } }, dataView: { title: "数据视图", lang: ["数据视图", "关闭", "刷新"] }, dataZoom: { title: { zoom: "区域缩放", back: "区域缩放还原" } }, magicType: { title: { line: "切换为折线图", bar: "切换为柱状图", stack: "切换为堆叠", tiled: "切换为平铺" } }, restore: { title: "还原" }, saveAsImage: { title: "保存为图片", lang: ["右键另存为图片"] } }, series: { typeNames: { pie: "饼图", bar: "柱状图", line: "折线图", scatter: "散点图", effectScatter: "涟漪散点图", radar: "雷达图", tree: "树图", treemap: "矩形树图", boxplot: "箱型图", candlestick: "K线图", k: "K线图", heatmap: "热力图", map: "地图", parallel: "平行坐标图", lines: "线图", graph: "关系图", sankey: "桑基图", funnel: "漏斗图", gauge: "仪表盘图", pictorialBar: "象形柱图", themeRiver: "主题河流图", sunburst: "旭日图" } }, aria: { general: { withTitle: "这是一个关于“{title}”的图表。", withoutTitle: "这是一个图表，" }, series: { single: { prefix: "", withName: "图表类型是{seriesType}，表示{seriesName}。", withoutName: "图表类型是{seriesType}。" }, multiple: { prefix: "它由{seriesCount}个图表系列组成。", withName: "第{seriesId}个系列是一个表示{seriesName}的{seriesType}，", withoutName: "第{seriesId}个系列是一个{seriesType}，", separator: { middle: "；", end: "。" } } }, data: { allData: "其数据是——", partialData: "其中，前{displayCnt}项是——", withName: "{name}的数据是{value}", withoutName: "{value}", separator: { middle: "，", end: "" } } } }); var Ec = 1e3, zc = 6e4, Vc = 36e5, Bc = 864e5, Fc = 31536e6, Gc = { year: "{yyyy}", month: "{MMM}", day: "{d}", hour: "{HH}:{mm}", minute: "{HH}:{mm}", second: "{HH}:{mm}:{ss}", millisecond: "{HH}:{mm}:{ss} {SSS}", none: "{yyyy}-{MM}-{dd} {HH}:{mm}:{ss} {SSS}" }, Wc = "{yyyy}-{MM}-{dd}", Hc = { year: "{yyyy}", month: "{yyyy}-{MM}", day: Wc, hour: Wc + " " + Gc.hour, minute: Wc + " " + Gc.minute, second: Wc + " " + Gc.second, millisecond: Gc.none }, Yc = ["year", "month", "day", "hour", "minute", "second", "millisecond"], Xc = ["year", "half-year", "quarter", "month", "week", "half-week", "day", "half-day", "quarter-day", "hour", "minute", "second", "millisecond"]; function Uc(t, e) { return "0000".substr(0, e - (t += "").length) + t } function Zc(t) { switch (t) { case "half-year": case "quarter": return "month"; case "week": case "half-week": return "day"; case "half-day": case "quarter-day": return "hour"; default: return t } } function jc(t) { return t === Zc(t) } function qc(t, e, n, i) { var r = ro(t), o = r[Jc(n)](), a = r[Qc(n)]() + 1, s = Math.floor((a - 1) / 3) + 1, l = r[tp(n)](), u = r["get" + (n ? "UTC" : "") + "Day"](), h = r[ep(n)](), c = (h - 1) % 12 + 1, p = r[np(n)](), d = r[ip(n)](), f = r[rp(n)](), g = (i instanceof Mc ? i : Nc(i || Oc) || Pc[kc]).getModel("time"), y = g.get("month"), v = g.get("monthAbbr"), m = g.get("dayOfWeek"), x = g.get("dayOfWeekAbbr"); return (e || "").replace(/{yyyy}/g, o + "").replace(/{yy}/g, Uc(o % 100 + "", 2)).replace(/{Q}/g, s + "").replace(/{MMMM}/g, y[a - 1]).replace(/{MMM}/g, v[a - 1]).replace(/{MM}/g, Uc(a, 2)).replace(/{M}/g, a + "").replace(/{dd}/g, Uc(l, 2)).replace(/{d}/g, l + "").replace(/{eeee}/g, m[u]).replace(/{ee}/g, x[u]).replace(/{e}/g, u + "").replace(/{HH}/g, Uc(h, 2)).replace(/{H}/g, h + "").replace(/{hh}/g, Uc(c + "", 2)).replace(/{h}/g, c + "").replace(/{mm}/g, Uc(p, 2)).replace(/{m}/g, p + "").replace(/{ss}/g, Uc(d, 2)).replace(/{s}/g, d + "").replace(/{SSS}/g, Uc(f, 3)).replace(/{S}/g, f + "") } function Kc(t, e) { var n = ro(t), i = n[Qc(e)]() + 1, r = n[tp(e)](), o = n[ep(e)](), a = n[np(e)](), s = n[ip(e)](), l = 0 === n[rp(e)](), u = l && 0 === s, h = u && 0 === a, c = h && 0 === o, p = c && 1 === r; return p && 1 === i ? "year" : p ? "month" : c ? "day" : h ? "hour" : u ? "minute" : l ? "second" : "millisecond" } function $c(t, e, n) { var i = j(t) ? ro(t) : t; switch (e = e || Kc(t, n)) { case "year": return i[Jc(n)](); case "half-year": return i[Qc(n)]() >= 6 ? 1 : 0; case "quarter": return Math.floor((i[Qc(n)]() + 1) / 4); case "month": return i[Qc(n)](); case "day": return i[tp(n)](); case "half-day": return i[ep(n)]() / 24; case "hour": return i[ep(n)](); case "minute": return i[np(n)](); case "second": return i[ip(n)](); case "millisecond": return i[rp(n)]() } } function Jc(t) { return t ? "getUTCFullYear" : "getFullYear" } function Qc(t) { return t ? "getUTCMonth" : "getMonth" } function tp(t) { return t ? "getUTCDate" : "getDate" } function ep(t) { return t ? "getUTCHours" : "getHours" } function np(t) { return t ? "getUTCMinutes" : "getMinutes" } function ip(t) { return t ? "getUTCSeconds" : "getSeconds" } function rp(t) { return t ? "getUTCMilliseconds" : "getMilliseconds" } function op(t) { return t ? "setUTCFullYear" : "setFullYear" } function ap(t) { return t ? "setUTCMonth" : "setMonth" } function sp(t) { return t ? "setUTCDate" : "setDate" } function lp(t) { return t ? "setUTCHours" : "setHours" } function up(t) { return t ? "setUTCMinutes" : "setMinutes" } function hp(t) { return t ? "setUTCSeconds" : "setSeconds" } function cp(t) { return t ? "setUTCMilliseconds" : "setMilliseconds" } function pp(t) { if (!co(t)) return U(t) ? t : "-"; var e = (t + "").split("."); return e[0].replace(/(\d{1,3})(?=(?:\d{3})+(?!\d))/g, "$1,") + (e.length > 1 ? "." + e[1] : "") } function dp(t, e) { return t = (t || "").toLowerCase().replace(/-(.)/g, (function (t, e) { return e.toUpperCase() })), e && t && (t = t.charAt(0).toUpperCase() + t.slice(1)), t } var fp = st; function gp(t, e, n) { function i(t) { return t && ut(t) ? t : "-" } function r(t) { return !(null == t || isNaN(t) || !isFinite(t)) } var o = "time" === e, a = t instanceof Date; if (o || a) { var s = o ? ro(t) : t; if (!isNaN(+s)) return qc(s, "{yyyy}-{MM}-{dd} {HH}:{mm}:{ss}", n); if (a) return "-" } if ("ordinal" === e) return Z(t) ? i(t) : j(t) && r(t) ? t + "" : "-"; var l = ho(t); return r(l) ? pp(l) : Z(t) ? i(t) : "boolean" == typeof t ? t + "" : "-" } var yp = ["a", "b", "c", "d", "e", "f", "g"], vp = function (t, e) { return "{" + t + (null == e ? "" : e) + "}" }; function mp(t, e, n) { Y(e) || (e = [e]); var i = e.length; if (!i) return ""; for (var r = e[0].$vars || [], o = 0; o < r.length; o++) { var a = yp[o]; t = t.replace(vp(a), vp(a, 0)) } for (var s = 0; s < i; s++)for (var l = 0; l < r.length; l++) { var u = e[s][r[l]]; t = t.replace(vp(yp[l], s), n ? re(u) : u) } return t } function xp(t, e) { var n = U(t) ? { color: t, extraCssText: e } : t || {}, i = n.color, r = n.type; e = n.extraCssText; var o = n.renderMode || "html"; return i ? "html" === o ? "subItem" === r ? '<span style="display:inline-block;vertical-align:middle;margin-right:8px;margin-left:3px;border-radius:4px;width:4px;height:4px;background-color:' + re(i) + ";" + (e || "") + '"></span>' : '<span style="display:inline-block;margin-right:4px;border-radius:10px;width:10px;height:10px;background-color:' + re(i) + ";" + (e || "") + '"></span>' : { renderMode: o, content: "{" + (n.markerId || "markerX") + "|}  ", style: "subItem" === r ? { width: 4, height: 4, borderRadius: 2, backgroundColor: i } : { width: 10, height: 10, borderRadius: 5, backgroundColor: i } } : "" } function _p(t, e) { return e = e || "transparent", U(t) ? t : q(t) && t.colorStops && (t.colorStops[0] || {}).color || e } function bp(t, e) { if ("_blank" === e || "blank" === e) { var n = window.open(); n.opener = null, n.location.href = t } else window.open(t, e) } var wp = E, Sp = ["left", "right", "top", "bottom", "width", "height"], Mp = [["width", "left", "right"], ["height", "top", "bottom"]]; function Ip(t, e, n, i, r) { var o = 0, a = 0; null == i && (i = 1 / 0), null == r && (r = 1 / 0); var s = 0; e.eachChild((function (l, u) { var h, c, p = l.getBoundingRect(), d = e.childAt(u + 1), f = d && d.getBoundingRect(); if ("horizontal" === t) { var g = p.width + (f ? -f.x + p.x : 0); (h = o + g) > i || l.newline ? (o = 0, h = g, a += s + n, s = p.height) : s = Math.max(s, p.height) } else { var y = p.height + (f ? -f.y + p.y : 0); (c = a + y) > r || l.newline ? (o += s + n, a = 0, c = y, s = p.width) : s = Math.max(s, p.width) } l.newline || (l.x = o, l.y = a, l.markRedraw(), "horizontal" === t ? o = h + n : a = c + n) })) } var Tp = Ip; H(Ip, "vertical"), H(Ip, "horizontal"); function Cp(t, e, n) { n = fp(n || 0); var i = e.width, r = e.height, o = Ur(t.left, i), a = Ur(t.top, r), s = Ur(t.right, i), l = Ur(t.bottom, r), u = Ur(t.width, i), h = Ur(t.height, r), c = n[2] + n[0], p = n[1] + n[3], d = t.aspect; switch (isNaN(u) && (u = i - s - p - o), isNaN(h) && (h = r - l - c - a), null != d && (isNaN(u) && isNaN(h) && (d > i / r ? u = .8 * i : h = .8 * r), isNaN(u) && (u = d * h), isNaN(h) && (h = u / d)), isNaN(o) && (o = i - s - u - p), isNaN(a) && (a = r - l - h - c), t.left || t.right) { case "center": o = i / 2 - u / 2 - n[3]; break; case "right": o = i - u - p }switch (t.top || t.bottom) { case "middle": case "center": a = r / 2 - h / 2 - n[0]; break; case "bottom": a = r - h - c }o = o || 0, a = a || 0, isNaN(u) && (u = i - p - o - (s || 0)), isNaN(h) && (h = r - c - a - (l || 0)); var f = new ze(o + n[3], a + n[0], u, h); return f.margin = n, f } function Dp(t, e, n, i, r, o) { var a, s = !r || !r.hv || r.hv[0], l = !r || !r.hv || r.hv[1], u = r && r.boundingMode || "all"; if ((o = o || t).x = t.x, o.y = t.y, !s && !l) return !1; if ("raw" === u) a = "group" === t.type ? new ze(0, 0, +e.width || 0, +e.height || 0) : t.getBoundingRect(); else if (a = t.getBoundingRect(), t.needLocalTransform()) { var h = t.getLocalTransform(); (a = a.clone()).applyTransform(h) } var c = Cp(k({ width: a.width, height: a.height }, e), n, i), p = s ? c.x - a.x : 0, d = l ? c.y - a.y : 0; return "raw" === u ? (o.x = p, o.y = d) : (o.x += p, o.y += d), o === t && t.markRedraw(), !0 } function Ap(t) { var e = t.layoutMode || t.constructor.layoutMode; return q(e) ? e : e ? { type: e } : null } function kp(t, e, n) { var i = n && n.ignoreSize; !Y(i) && (i = [i, i]); var r = a(Mp[0], 0), o = a(Mp[1], 1); function a(n, r) { var o = {}, a = 0, u = {}, h = 0; if (wp(n, (function (e) { u[e] = t[e] })), wp(n, (function (t) { s(e, t) && (o[t] = u[t] = e[t]), l(o, t) && a++, l(u, t) && h++ })), i[r]) return l(e, n[1]) ? u[n[2]] = null : l(e, n[2]) && (u[n[1]] = null), u; if (2 !== h && a) { if (a >= 2) return o; for (var c = 0; c < n.length; c++) { var p = n[c]; if (!s(o, p) && s(t, p)) { o[p] = t[p]; break } } return o } return u } function s(t, e) { return t.hasOwnProperty(e) } function l(t, e) { return null != t[e] && "auto" !== t[e] } function u(t, e, n) { wp(t, (function (t) { e[t] = n[t] })) } u(Mp[0], t, r), u(Mp[1], t, o) } function Lp(t) { return Pp({}, t) } function Pp(t, e) { return e && t && wp(Sp, (function (n) { e.hasOwnProperty(n) && (t[n] = e[n]) })), t } var Op = Oo(), Rp = function (t) { function e(e, n, i) { var r = t.call(this, e, n, i) || this; return r.uid = Tc("ec_cpt_model"), r } return n(e, t), e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n) }, e.prototype.mergeDefaultAndTheme = function (t, e) { var n = Ap(this), i = n ? Lp(t) : {}; C(t, e.getTheme().get(this.mainType)), C(t, this.getDefaultOption()), n && kp(t, i, n) }, e.prototype.mergeOption = function (t, e) { C(this.option, t, !0); var n = Ap(this); n && kp(this.option, t, n) }, e.prototype.optionUpdated = function (t, e) { }, e.prototype.getDefaultOption = function () { var t = this.constructor; if (!function (t) { return !(!t || !t[Yo]) }(t)) return t.defaultOption; var e = Op(this); if (!e.defaultOption) { for (var n = [], i = t; i;) { var r = i.prototype.defaultOption; r && n.push(r), i = i.superClass } for (var o = {}, a = n.length - 1; a >= 0; a--)o = C(o, n[a], !0); e.defaultOption = o } return e.defaultOption }, e.prototype.getReferringComponents = function (t, e) { var n = t + "Index", i = t + "Id"; return Bo(this.ecModel, t, { index: this.get(n, !0), id: this.get(i, !0) }, e) }, e.prototype.getBoxLayoutParams = function () { var t = this; return { left: t.get("left"), top: t.get("top"), right: t.get("right"), bottom: t.get("bottom"), width: t.get("width"), height: t.get("height") } }, e.prototype.getZLevelKey = function () { return "" }, e.prototype.setZLevel = function (t) { this.option.zlevel = t }, e.protoInitialize = function () { var t = e.prototype; t.type = "component", t.id = "", t.name = "", t.mainType = "", t.subType = "", t.componentIndex = 0 }(), e }(Mc); Zo(Rp, Mc), $o(Rp), function (t) { var e = {}; t.registerSubTypeDefaulter = function (t, n) { var i = Xo(t); e[i.main] = n }, t.determineSubType = function (n, i) { var r = i.type; if (!r) { var o = Xo(n).main; t.hasSubTypes(n) && e[o] && (r = e[o](i)) } return r } }(Rp), function (t, e) { function n(t, e) { return t[e] || (t[e] = { predecessor: [], successor: [] }), t[e] } t.topologicalTravel = function (t, i, r, o) { if (t.length) { var a = function (t) { var i = {}, r = []; return E(t, (function (o) { var a = n(i, o), s = function (t, e) { var n = []; return E(t, (function (t) { P(e, t) >= 0 && n.push(t) })), n }(a.originalDeps = e(o), t); a.entryCount = s.length, 0 === a.entryCount && r.push(o), E(s, (function (t) { P(a.predecessor, t) < 0 && a.predecessor.push(t); var e = n(i, t); P(e.successor, t) < 0 && e.successor.push(o) })) })), { graph: i, noEntryList: r } }(i), s = a.graph, l = a.noEntryList, u = {}; for (E(t, (function (t) { u[t] = !0 })); l.length;) { var h = l.pop(), c = s[h], p = !!u[h]; p && (r.call(o, h, c.originalDeps.slice()), delete u[h]), E(c.successor, p ? f : d) } E(u, (function () { var t = ""; throw new Error(t) })) } function d(t) { s[t].entryCount--, 0 === s[t].entryCount && l.push(t) } function f(t) { u[t] = !0, d(t) } } }(Rp, (function (t) { var e = []; E(Rp.getClassesByMainType(t), (function (t) { e = e.concat(t.dependencies || t.prototype.dependencies || []) })), e = z(e, (function (t) { return Xo(t).main })), "dataset" !== t && P(e, "dataset") <= 0 && e.unshift("dataset"); return e })); var Np = ""; "undefined" != typeof navigator && (Np = navigator.platform || ""); var Ep = "rgba(0, 0, 0, 0.2)", zp = { darkMode: "auto", colorBy: "series", color: ["#5470c6", "#91cc75", "#fac858", "#ee6666", "#73c0de", "#3ba272", "#fc8452", "#9a60b4", "#ea7ccc"], gradientColor: ["#f6efa6", "#d88273", "#bf444c"], aria: { decal: { decals: [{ color: Ep, dashArrayX: [1, 0], dashArrayY: [2, 5], symbolSize: 1, rotation: Math.PI / 6 }, { color: Ep, symbol: "circle", dashArrayX: [[8, 8], [0, 8, 8, 0]], dashArrayY: [6, 0], symbolSize: .8 }, { color: Ep, dashArrayX: [1, 0], dashArrayY: [4, 3], rotation: -Math.PI / 4 }, { color: Ep, dashArrayX: [[6, 6], [0, 6, 6, 0]], dashArrayY: [6, 0] }, { color: Ep, dashArrayX: [[1, 0], [1, 6]], dashArrayY: [1, 0, 6, 0], rotation: Math.PI / 4 }, { color: Ep, symbol: "triangle", dashArrayX: [[9, 9], [0, 9, 9, 0]], dashArrayY: [7, 2], symbolSize: .75 }] } }, textStyle: { fontFamily: Np.match(/^Win/) ? "Microsoft YaHei" : "sans-serif", fontSize: 12, fontStyle: "normal", fontWeight: "normal" }, blendMode: null, stateAnimation: { duration: 300, easing: "cubicOut" }, animation: "auto", animationDuration: 1e3, animationDurationUpdate: 500, animationEasing: "cubicInOut", animationEasingUpdate: "cubicInOut", animationThreshold: 2e3, progressiveThreshold: 3e3, progressive: 400, hoverLayerThreshold: 3e3, useUTC: !1 }, Vp = yt(["tooltip", "label", "itemName", "itemId", "itemGroupId", "seriesName"]), Bp = "original", Fp = "arrayRows", Gp = "objectRows", Wp = "keyedColumns", Hp = "typedArray", Yp = "unknown", Xp = "column", Up = "row", Zp = 1, jp = 2, qp = 3, Kp = Oo(); function $p(t, e, n) { var i = {}, r = Qp(e); if (!r || !t) return i; var o, a, s = [], l = [], u = e.ecModel, h = Kp(u).datasetMap, c = r.uid + "_" + n.seriesLayoutBy; E(t = t.slice(), (function (e, n) { var r = q(e) ? e : t[n] = { name: e }; "ordinal" === r.type && null == o && (o = n, a = f(r)), i[r.name] = [] })); var p = h.get(c) || h.set(c, { categoryWayDim: a, valueWayDim: 0 }); function d(t, e, n) { for (var i = 0; i < n; i++)t.push(e + i) } function f(t) { var e = t.dimsDef; return e ? e.length : 1 } return E(t, (function (t, e) { var n = t.name, r = f(t); if (null == o) { var a = p.valueWayDim; d(i[n], a, r), d(l, a, r), p.valueWayDim += r } else if (o === e) d(i[n], 0, r), d(s, 0, r); else { a = p.categoryWayDim; d(i[n], a, r), d(l, a, r), p.categoryWayDim += r } })), s.length && (i.itemName = s), l.length && (i.seriesName = l), i } function Jp(t, e, n) { var i = {}; if (!Qp(t)) return i; var r, o = e.sourceFormat, a = e.dimensionsDefine; o !== Gp && o !== Wp || E(a, (function (t, e) { "name" === (q(t) ? t.name : t) && (r = e) })); var s = function () { for (var t = {}, i = {}, s = [], l = 0, u = Math.min(5, n); l < u; l++) { var h = ed(e.data, o, e.seriesLayoutBy, a, e.startIndex, l); s.push(h); var c = h === qp; if (c && null == t.v && l !== r && (t.v = l), (null == t.n || t.n === t.v || !c && s[t.n] === qp) && (t.n = l), p(t) && s[t.n] !== qp) return t; c || (h === jp && null == i.v && l !== r && (i.v = l), null != i.n && i.n !== i.v || (i.n = l)) } function p(t) { return null != t.v && null != t.n } return p(t) ? t : p(i) ? i : null }(); if (s) { i.value = [s.v]; var l = null != r ? r : s.n; i.itemName = [l], i.seriesName = [l] } return i } function Qp(t) { if (!t.get("data", !0)) return Bo(t.ecModel, "dataset", { index: t.get("datasetIndex", !0), id: t.get("datasetId", !0) }, zo).models[0] } function td(t, e) { return ed(t.data, t.sourceFormat, t.seriesLayoutBy, t.dimensionsDefine, t.startIndex, e) } function ed(t, e, n, i, r, o) { var a, s, l; if ($(t)) return qp; if (i) { var u = i[o]; q(u) ? (s = u.name, l = u.type) : U(u) && (s = u) } if (null != l) return "ordinal" === l ? Zp : qp; if (e === Fp) { var h = t; if (n === Up) { for (var c = h[o], p = 0; p < (c || []).length && p < 5; p++)if (null != (a = m(c[r + p]))) return a } else for (p = 0; p < h.length && p < 5; p++) { var d = h[r + p]; if (d && null != (a = m(d[o]))) return a } } else if (e === Gp) { var f = t; if (!s) return qp; for (p = 0; p < f.length && p < 5; p++) { if ((y = f[p]) && null != (a = m(y[s]))) return a } } else if (e === Wp) { if (!s) return qp; if (!(c = t[s]) || $(c)) return qp; for (p = 0; p < c.length && p < 5; p++)if (null != (a = m(c[p]))) return a } else if (e === Bp) { var g = t; for (p = 0; p < g.length && p < 5; p++) { var y, v = Mo(y = g[p]); if (!Y(v)) return qp; if (null != (a = m(v[o]))) return a } } function m(t) { var e = U(t); return null != t && isFinite(t) && "" !== t ? e ? jp : qp : e && "-" !== t ? Zp : void 0 } return qp } var nd = yt(); var id, rd, od, ad = Oo(), sd = Oo(), ld = function () { function t() { } return t.prototype.getColorFromPalette = function (t, e, n) { var i = bo(this.get("color", !0)), r = this.get("colorLayer", !0); return hd(this, ad, i, r, t, e, n) }, t.prototype.clearColorPalette = function () { !function (t, e) { e(t).paletteIdx = 0, e(t).paletteNameMap = {} }(this, ad) }, t }(); function ud(t, e, n, i) { var r = bo(t.get(["aria", "decal", "decals"])); return hd(t, sd, r, null, e, n, i) } function hd(t, e, n, i, r, o, a) { var s = e(o = o || t), l = s.paletteIdx || 0, u = s.paletteNameMap = s.paletteNameMap || {}; if (u.hasOwnProperty(r)) return u[r]; var h = null != a && i ? function (t, e) { for (var n = t.length, i = 0; i < n; i++)if (t[i].length > e) return t[i]; return t[n - 1] }(i, a) : n; if ((h = h || n) && h.length) { var c = h[l]; return r && (u[r] = c), s.paletteIdx = (l + 1) % h.length, c } } var cd = "\0_ec_inner"; var pd = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.init = function (t, e, n, i, r, o) { i = i || {}, this.option = null, this._theme = new Mc(i), this._locale = new Mc(r), this._optionManager = o }, e.prototype.setOption = function (t, e, n) { var i = gd(e); this._optionManager.setOption(t, n, i), this._resetOption(null, i) }, e.prototype.resetOption = function (t, e) { return this._resetOption(t, gd(e)) }, e.prototype._resetOption = function (t, e) { var n = !1, i = this._optionManager; if (!t || "recreate" === t) { var r = i.mountOption("recreate" === t); 0, this.option && "recreate" !== t ? (this.restoreData(), this._mergeOption(r, e)) : od(this, r), n = !0 } if ("timeline" !== t && "media" !== t || this.restoreData(), !t || "recreate" === t || "timeline" === t) { var o = i.getTimelineOption(this); o && (n = !0, this._mergeOption(o, e)) } if (!t || "recreate" === t || "media" === t) { var a = i.getMediaOption(this); a.length && E(a, (function (t) { n = !0, this._mergeOption(t, e) }), this) } return n }, e.prototype.mergeOption = function (t) { this._mergeOption(t, null) }, e.prototype._mergeOption = function (t, e) { var n = this.option, i = this._componentsMap, r = this._componentsCount, o = [], a = yt(), s = e && e.replaceMergeMainTypeMap; Kp(this).datasetMap = yt(), E(t, (function (t, e) { null != t && (Rp.hasClass(e) ? e && (o.push(e), a.set(e, !0)) : n[e] = null == n[e] ? T(t) : C(n[e], t, !0)) })), s && s.each((function (t, e) { Rp.hasClass(e) && !a.get(e) && (o.push(e), a.set(e, !0)) })), Rp.topologicalTravel(o, Rp.getAllClassMainTypes(), (function (e) { var o = function (t, e, n) { var i = nd.get(e); if (!i) return n; var r = i(t); return r ? n.concat(r) : n }(this, e, bo(t[e])), a = i.get(e), l = a ? s && s.get(e) ? "replaceMerge" : "normalMerge" : "replaceAll", u = To(a, o, l); (function (t, e, n) { E(t, (function (t) { var i = t.newOption; q(i) && (t.keyInfo.mainType = e, t.keyInfo.subType = function (t, e, n, i) { return e.type ? e.type : n ? n.subType : i.determineSubType(t, e) }(e, i, t.existing, n)) })) })(u, e, Rp), n[e] = null, i.set(e, null), r.set(e, 0); var h, c = [], p = [], d = 0; E(u, (function (t, n) { var i = t.existing, r = t.newOption; if (r) { var o = "series" === e, a = Rp.getClass(e, t.keyInfo.subType, !o); if (!a) return; if ("tooltip" === e) { if (h) return void 0; h = !0 } if (i && i.constructor === a) i.name = t.keyInfo.name, i.mergeOption(r, this), i.optionUpdated(r, !1); else { var s = A({ componentIndex: n }, t.keyInfo); A(i = new a(r, this, this, s), s), t.brandNew && (i.__requireNewView = !0), i.init(r, this, this), i.optionUpdated(null, !0) } } else i && (i.mergeOption({}, this), i.optionUpdated({}, !1)); i ? (c.push(i.option), p.push(i), d++) : (c.push(void 0), p.push(void 0)) }), this), n[e] = c, i.set(e, p), r.set(e, d), "series" === e && id(this) }), this), this._seriesIndices || id(this) }, e.prototype.getOption = function () { var t = T(this.option); return E(t, (function (e, n) { if (Rp.hasClass(n)) { for (var i = bo(e), r = i.length, o = !1, a = r - 1; a >= 0; a--)i[a] && !Lo(i[a]) ? o = !0 : (i[a] = null, !o && r--); i.length = r, t[n] = i } })), delete t[cd], t }, e.prototype.getTheme = function () { return this._theme }, e.prototype.getLocaleModel = function () { return this._locale }, e.prototype.setUpdatePayload = function (t) { this._payload = t }, e.prototype.getUpdatePayload = function () { return this._payload }, e.prototype.getComponent = function (t, e) { var n = this._componentsMap.get(t); if (n) { var i = n[e || 0]; if (i) return i; if (null == e) for (var r = 0; r < n.length; r++)if (n[r]) return n[r] } }, e.prototype.queryComponents = function (t) { var e = t.mainType; if (!e) return []; var n, i = t.index, r = t.id, o = t.name, a = this._componentsMap.get(e); return a && a.length ? (null != i ? (n = [], E(bo(i), (function (t) { a[t] && n.push(a[t]) }))) : n = null != r ? dd("id", r, a) : null != o ? dd("name", o, a) : B(a, (function (t) { return !!t })), fd(n, t)) : [] }, e.prototype.findComponents = function (t) { var e, n, i, r, o, a = t.query, s = t.mainType, l = (n = s + "Index", i = s + "Id", r = s + "Name", !(e = a) || null == e[n] && null == e[i] && null == e[r] ? null : { mainType: s, index: e[n], id: e[i], name: e[r] }), u = l ? this.queryComponents(l) : B(this._componentsMap.get(s), (function (t) { return !!t })); return o = fd(u, t), t.filter ? B(o, t.filter) : o }, e.prototype.eachComponent = function (t, e, n) { var i = this._componentsMap; if (X(t)) { var r = e, o = t; i.each((function (t, e) { for (var n = 0; t && n < t.length; n++) { var i = t[n]; i && o.call(r, e, i, i.componentIndex) } })) } else for (var a = U(t) ? i.get(t) : q(t) ? this.findComponents(t) : null, s = 0; a && s < a.length; s++) { var l = a[s]; l && e.call(n, l, l.componentIndex) } }, e.prototype.getSeriesByName = function (t) { var e = Ao(t, null); return B(this._componentsMap.get("series"), (function (t) { return !!t && null != e && t.name === e })) }, e.prototype.getSeriesByIndex = function (t) { return this._componentsMap.get("series")[t] }, e.prototype.getSeriesByType = function (t) { return B(this._componentsMap.get("series"), (function (e) { return !!e && e.subType === t })) }, e.prototype.getSeries = function () { return B(this._componentsMap.get("series"), (function (t) { return !!t })) }, e.prototype.getSeriesCount = function () { return this._componentsCount.get("series") }, e.prototype.eachSeries = function (t, e) { rd(this), E(this._seriesIndices, (function (n) { var i = this._componentsMap.get("series")[n]; t.call(e, i, n) }), this) }, e.prototype.eachRawSeries = function (t, e) { E(this._componentsMap.get("series"), (function (n) { n && t.call(e, n, n.componentIndex) })) }, e.prototype.eachSeriesByType = function (t, e, n) { rd(this), E(this._seriesIndices, (function (i) { var r = this._componentsMap.get("series")[i]; r.subType === t && e.call(n, r, i) }), this) }, e.prototype.eachRawSeriesByType = function (t, e, n) { return E(this.getSeriesByType(t), e, n) }, e.prototype.isSeriesFiltered = function (t) { return rd(this), null == this._seriesIndicesMap.get(t.componentIndex) }, e.prototype.getCurrentSeriesIndices = function () { return (this._seriesIndices || []).slice() }, e.prototype.filterSeries = function (t, e) { rd(this); var n = []; E(this._seriesIndices, (function (i) { var r = this._componentsMap.get("series")[i]; t.call(e, r, i) && n.push(i) }), this), this._seriesIndices = n, this._seriesIndicesMap = yt(n) }, e.prototype.restoreData = function (t) { id(this); var e = this._componentsMap, n = []; e.each((function (t, e) { Rp.hasClass(e) && n.push(e) })), Rp.topologicalTravel(n, Rp.getAllClassMainTypes(), (function (n) { E(e.get(n), (function (e) { !e || "series" === n && function (t, e) { if (e) { var n = e.seriesIndex, i = e.seriesId, r = e.seriesName; return null != n && t.componentIndex !== n || null != i && t.id !== i || null != r && t.name !== r } }(e, t) || e.restoreData() })) })) }, e.internalField = (id = function (t) { var e = t._seriesIndices = []; E(t._componentsMap.get("series"), (function (t) { t && e.push(t.componentIndex) })), t._seriesIndicesMap = yt(e) }, rd = function (t) { }, void (od = function (t, e) { t.option = {}, t.option[cd] = 1, t._componentsMap = yt({ series: [] }), t._componentsCount = yt(); var n = e.aria; q(n) && null == n.enabled && (n.enabled = !0), function (t, e) { var n = t.color && !t.colorLayer; E(e, (function (e, i) { "colorLayer" === i && n || Rp.hasClass(i) || ("object" == typeof e ? t[i] = t[i] ? C(t[i], e, !1) : T(e) : null == t[i] && (t[i] = e)) })) }(e, t._theme.option), C(e, zp, !1), t._mergeOption(e, null) })), e }(Mc); function dd(t, e, n) { if (Y(e)) { var i = yt(); return E(e, (function (t) { null != t && (null != Ao(t, null) && i.set(t, !0)) })), B(n, (function (e) { return e && i.get(e[t]) })) } var r = Ao(e, null); return B(n, (function (e) { return e && null != r && e[t] === r })) } function fd(t, e) { return e.hasOwnProperty("subType") ? B(t, (function (t) { return t && t.subType === e.subType })) : t } function gd(t) { var e = yt(); return t && E(bo(t.replaceMerge), (function (t) { e.set(t, !0) })), { replaceMergeMainTypeMap: e } } R(pd, ld); var yd = ["getDom", "getZr", "getWidth", "getHeight", "getDevicePixelRatio", "dispatchAction", "isSSR", "isDisposed", "on", "off", "getDataURL", "getConnectedDataURL", "getOption", "getId", "updateLabelLayout"], vd = function (t) { E(yd, (function (e) { this[e] = W(t[e], t) }), this) }, md = {}, xd = function () { function t() { this._coordinateSystems = [] } return t.prototype.create = function (t, e) { var n = []; E(md, (function (i, r) { var o = i.create(t, e); n = n.concat(o || []) })), this._coordinateSystems = n }, t.prototype.update = function (t, e) { E(this._coordinateSystems, (function (n) { n.update && n.update(t, e) })) }, t.prototype.getCoordinateSystems = function () { return this._coordinateSystems.slice() }, t.register = function (t, e) { md[t] = e }, t.get = function (t) { return md[t] }, t }(), _d = /^(min|max)?(.+)$/, bd = function () { function t(t) { this._timelineOptions = [], this._mediaList = [], this._currentMediaIndices = [], this._api = t } return t.prototype.setOption = function (t, e, n) { t && (E(bo(t.series), (function (t) { t && t.data && $(t.data) && ct(t.data) })), E(bo(t.dataset), (function (t) { t && t.source && $(t.source) && ct(t.source) }))), t = T(t); var i = this._optionBackup, r = function (t, e, n) { var i, r, o = [], a = t.baseOption, s = t.timeline, l = t.options, u = t.media, h = !!t.media, c = !!(l || s || a && a.timeline); a ? (r = a).timeline || (r.timeline = s) : ((c || h) && (t.options = t.media = null), r = t); h && Y(u) && E(u, (function (t) { t && t.option && (t.query ? o.push(t) : i || (i = t)) })); function p(t) { E(e, (function (e) { e(t, n) })) } return p(r), E(l, (function (t) { return p(t) })), E(o, (function (t) { return p(t.option) })), { baseOption: r, timelineOptions: l || [], mediaDefault: i, mediaList: o } }(t, e, !i); this._newBaseOption = r.baseOption, i ? (r.timelineOptions.length && (i.timelineOptions = r.timelineOptions), r.mediaList.length && (i.mediaList = r.mediaList), r.mediaDefault && (i.mediaDefault = r.mediaDefault)) : this._optionBackup = r }, t.prototype.mountOption = function (t) { var e = this._optionBackup; return this._timelineOptions = e.timelineOptions, this._mediaList = e.mediaList, this._mediaDefault = e.mediaDefault, this._currentMediaIndices = [], T(t ? e.baseOption : this._newBaseOption) }, t.prototype.getTimelineOption = function (t) { var e, n = this._timelineOptions; if (n.length) { var i = t.getComponent("timeline"); i && (e = T(n[i.getCurrentIndex()])) } return e }, t.prototype.getMediaOption = function (t) { var e, n, i = this._api.getWidth(), r = this._api.getHeight(), o = this._mediaList, a = this._mediaDefault, s = [], l = []; if (!o.length && !a) return l; for (var u = 0, h = o.length; u < h; u++)wd(o[u].query, i, r) && s.push(u); return !s.length && a && (s = [-1]), s.length && (e = s, n = this._currentMediaIndices, e.join(",") !== n.join(",")) && (l = z(s, (function (t) { return T(-1 === t ? a.option : o[t].option) }))), this._currentMediaIndices = s, l }, t }(); function wd(t, e, n) { var i = { width: e, height: n, aspectratio: e / n }, r = !0; return E(t, (function (t, e) { var n = e.match(_d); if (n && n[1] && n[2]) { var o = n[1], a = n[2].toLowerCase(); (function (t, e, n) { return "min" === n ? t >= e : "max" === n ? t <= e : t === e })(i[a], t, o) || (r = !1) } })), r } var Sd = E, Md = q, Id = ["areaStyle", "lineStyle", "nodeStyle", "linkStyle", "chordStyle", "label", "labelLine"]; function Td(t) { var e = t && t.itemStyle; if (e) for (var n = 0, i = Id.length; n < i; n++) { var r = Id[n], o = e.normal, a = e.emphasis; o && o[r] && (t[r] = t[r] || {}, t[r].normal ? C(t[r].normal, o[r]) : t[r].normal = o[r], o[r] = null), a && a[r] && (t[r] = t[r] || {}, t[r].emphasis ? C(t[r].emphasis, a[r]) : t[r].emphasis = a[r], a[r] = null) } } function Cd(t, e, n) { if (t && t[e] && (t[e].normal || t[e].emphasis)) { var i = t[e].normal, r = t[e].emphasis; i && (n ? (t[e].normal = t[e].emphasis = null, k(t[e], i)) : t[e] = i), r && (t.emphasis = t.emphasis || {}, t.emphasis[e] = r, r.focus && (t.emphasis.focus = r.focus), r.blurScope && (t.emphasis.blurScope = r.blurScope)) } } function Dd(t) { Cd(t, "itemStyle"), Cd(t, "lineStyle"), Cd(t, "areaStyle"), Cd(t, "label"), Cd(t, "labelLine"), Cd(t, "upperLabel"), Cd(t, "edgeLabel") } function Ad(t, e) { var n = Md(t) && t[e], i = Md(n) && n.textStyle; if (i) { 0; for (var r = 0, o = So.length; r < o; r++) { var a = So[r]; i.hasOwnProperty(a) && (n[a] = i[a]) } } } function kd(t) { t && (Dd(t), Ad(t, "label"), t.emphasis && Ad(t.emphasis, "label")) } function Ld(t) { return Y(t) ? t : t ? [t] : [] } function Pd(t) { return (Y(t) ? t[0] : t) || {} } function Od(t, e) { Sd(Ld(t.series), (function (t) { Md(t) && function (t) { if (Md(t)) { Td(t), Dd(t), Ad(t, "label"), Ad(t, "upperLabel"), Ad(t, "edgeLabel"), t.emphasis && (Ad(t.emphasis, "label"), Ad(t.emphasis, "upperLabel"), Ad(t.emphasis, "edgeLabel")); var e = t.markPoint; e && (Td(e), kd(e)); var n = t.markLine; n && (Td(n), kd(n)); var i = t.markArea; i && kd(i); var r = t.data; if ("graph" === t.type) { r = r || t.nodes; var o = t.links || t.edges; if (o && !$(o)) for (var a = 0; a < o.length; a++)kd(o[a]); E(t.categories, (function (t) { Dd(t) })) } if (r && !$(r)) for (a = 0; a < r.length; a++)kd(r[a]); if ((e = t.markPoint) && e.data) { var s = e.data; for (a = 0; a < s.length; a++)kd(s[a]) } if ((n = t.markLine) && n.data) { var l = n.data; for (a = 0; a < l.length; a++)Y(l[a]) ? (kd(l[a][0]), kd(l[a][1])) : kd(l[a]) } "gauge" === t.type ? (Ad(t, "axisLabel"), Ad(t, "title"), Ad(t, "detail")) : "treemap" === t.type ? (Cd(t.breadcrumb, "itemStyle"), E(t.levels, (function (t) { Dd(t) }))) : "tree" === t.type && Dd(t.leaves) } }(t) })); var n = ["xAxis", "yAxis", "radiusAxis", "angleAxis", "singleAxis", "parallelAxis", "radar"]; e && n.push("valueAxis", "categoryAxis", "logAxis", "timeAxis"), Sd(n, (function (e) { Sd(Ld(t[e]), (function (t) { t && (Ad(t, "axisLabel"), Ad(t.axisPointer, "label")) })) })), Sd(Ld(t.parallel), (function (t) { var e = t && t.parallelAxisDefault; Ad(e, "axisLabel"), Ad(e && e.axisPointer, "label") })), Sd(Ld(t.calendar), (function (t) { Cd(t, "itemStyle"), Ad(t, "dayLabel"), Ad(t, "monthLabel"), Ad(t, "yearLabel") })), Sd(Ld(t.radar), (function (t) { Ad(t, "name"), t.name && null == t.axisName && (t.axisName = t.name, delete t.name), null != t.nameGap && null == t.axisNameGap && (t.axisNameGap = t.nameGap, delete t.nameGap) })), Sd(Ld(t.geo), (function (t) { Md(t) && (kd(t), Sd(Ld(t.regions), (function (t) { kd(t) }))) })), Sd(Ld(t.timeline), (function (t) { kd(t), Cd(t, "label"), Cd(t, "itemStyle"), Cd(t, "controlStyle", !0); var e = t.data; Y(e) && E(e, (function (t) { q(t) && (Cd(t, "label"), Cd(t, "itemStyle")) })) })), Sd(Ld(t.toolbox), (function (t) { Cd(t, "iconStyle"), Sd(t.feature, (function (t) { Cd(t, "iconStyle") })) })), Ad(Pd(t.axisPointer), "label"), Ad(Pd(t.tooltip).axisPointer, "label") } function Rd(t) { t && E(Nd, (function (e) { e[0] in t && !(e[1] in t) && (t[e[1]] = t[e[0]]) })) } var Nd = [["x", "left"], ["y", "top"], ["x2", "right"], ["y2", "bottom"]], Ed = ["grid", "geo", "parallel", "legend", "toolbox", "title", "visualMap", "dataZoom", "timeline"], zd = [["borderRadius", "barBorderRadius"], ["borderColor", "barBorderColor"], ["borderWidth", "barBorderWidth"]]; function Vd(t) { var e = t && t.itemStyle; if (e) for (var n = 0; n < zd.length; n++) { var i = zd[n][1], r = zd[n][0]; null != e[i] && (e[r] = e[i]) } } function Bd(t) { t && "edge" === t.alignTo && null != t.margin && null == t.edgeDistance && (t.edgeDistance = t.margin) } function Fd(t) { t && t.downplay && !t.blur && (t.blur = t.downplay) } function Gd(t, e) { if (t) for (var n = 0; n < t.length; n++)e(t[n]), t[n] && Gd(t[n].children, e) } function Wd(t, e) { Od(t, e), t.series = bo(t.series), E(t.series, (function (t) { if (q(t)) { var e = t.type; if ("line" === e) null != t.clipOverflow && (t.clip = t.clipOverflow); else if ("pie" === e || "gauge" === e) { if (null != t.clockWise && (t.clockwise = t.clockWise), Bd(t.label), (r = t.data) && !$(r)) for (var n = 0; n < r.length; n++)Bd(r[n]); null != t.hoverOffset && (t.emphasis = t.emphasis || {}, (t.emphasis.scaleSize = null) && (t.emphasis.scaleSize = t.hoverOffset)) } else if ("gauge" === e) { var i = function (t, e) { for (var n = e.split(","), i = t, r = 0; r < n.length && null != (i = i && i[n[r]]); r++); return i }(t, "pointer.color"); null != i && function (t, e, n, i) { for (var r, o = e.split(","), a = t, s = 0; s < o.length - 1; s++)null == a[r = o[s]] && (a[r] = {}), a = a[r]; (i || null == a[o[s]]) && (a[o[s]] = n) }(t, "itemStyle.color", i) } else if ("bar" === e) { var r; if (Vd(t), Vd(t.backgroundStyle), Vd(t.emphasis), (r = t.data) && !$(r)) for (n = 0; n < r.length; n++)"object" == typeof r[n] && (Vd(r[n]), Vd(r[n] && r[n].emphasis)) } else if ("sunburst" === e) { var o = t.highlightPolicy; o && (t.emphasis = t.emphasis || {}, t.emphasis.focus || (t.emphasis.focus = o)), Fd(t), Gd(t.data, Fd) } else "graph" === e || "sankey" === e ? function (t) { t && null != t.focusNodeAdjacency && (t.emphasis = t.emphasis || {}, null == t.emphasis.focus && (t.emphasis.focus = "adjacency")) }(t) : "map" === e && (t.mapType && !t.map && (t.map = t.mapType), t.mapLocation && k(t, t.mapLocation)); null != t.hoverAnimation && (t.emphasis = t.emphasis || {}, t.emphasis && null == t.emphasis.scale && (t.emphasis.scale = t.hoverAnimation)), Rd(t) } })), t.dataRange && (t.visualMap = t.dataRange), E(Ed, (function (e) { var n = t[e]; n && (Y(n) || (n = [n]), E(n, (function (t) { Rd(t) }))) })) } function Hd(t) { E(t, (function (e, n) { var i = [], r = [NaN, NaN], o = [e.stackResultDimension, e.stackedOverDimension], a = e.data, s = e.isStackedByIndex, l = e.seriesModel.get("stackStrategy") || "samesign"; a.modify(o, (function (o, u, h) { var c, p, d = a.get(e.stackedDimension, h); if (isNaN(d)) return r; s ? p = a.getRawIndex(h) : c = a.get(e.stackedByDimension, h); for (var f = NaN, g = n - 1; g >= 0; g--) { var y = t[g]; if (s || (p = y.data.rawIndexOf(y.stackedByDimension, c)), p >= 0) { var v = y.data.getByRawIndex(y.stackResultDimension, p); if ("all" === l || "positive" === l && v > 0 || "negative" === l && v < 0 || "samesign" === l && d >= 0 && v > 0 || "samesign" === l && d <= 0 && v < 0) { d = Qr(d, v), f = v; break } } } return i[0] = d, i[1] = f, i })) })) } var Yd, Xd, Ud, Zd, jd, qd = function (t) { this.data = t.data || (t.sourceFormat === Wp ? {} : []), this.sourceFormat = t.sourceFormat || Yp, this.seriesLayoutBy = t.seriesLayoutBy || Xp, this.startIndex = t.startIndex || 0, this.dimensionsDetectedCount = t.dimensionsDetectedCount, this.metaRawOption = t.metaRawOption; var e = this.dimensionsDefine = t.dimensionsDefine; if (e) for (var n = 0; n < e.length; n++) { var i = e[n]; null == i.type && td(this, n) === Zp && (i.type = "ordinal") } }; function Kd(t) { return t instanceof qd } function $d(t, e, n) { n = n || Qd(t); var i = e.seriesLayoutBy, r = function (t, e, n, i, r) { var o, a; if (!t) return { dimensionsDefine: tf(r), startIndex: a, dimensionsDetectedCount: o }; if (e === Fp) { var s = t; "auto" === i || null == i ? ef((function (t) { null != t && "-" !== t && (U(t) ? null == a && (a = 1) : a = 0) }), n, s, 10) : a = j(i) ? i : i ? 1 : 0, r || 1 !== a || (r = [], ef((function (t, e) { r[e] = null != t ? t + "" : "" }), n, s, 1 / 0)), o = r ? r.length : n === Up ? s.length : s[0] ? s[0].length : null } else if (e === Gp) r || (r = function (t) { var e, n = 0; for (; n < t.length && !(e = t[n++]);); if (e) return G(e) }(t)); else if (e === Wp) r || (r = [], E(t, (function (t, e) { r.push(e) }))); else if (e === Bp) { var l = Mo(t[0]); o = Y(l) && l.length || 1 } return { startIndex: a, dimensionsDefine: tf(r), dimensionsDetectedCount: o } }(t, n, i, e.sourceHeader, e.dimensions); return new qd({ data: t, sourceFormat: n, seriesLayoutBy: i, dimensionsDefine: r.dimensionsDefine, startIndex: r.startIndex, dimensionsDetectedCount: r.dimensionsDetectedCount, metaRawOption: T(e) }) } function Jd(t) { return new qd({ data: t, sourceFormat: $(t) ? Hp : Bp }) } function Qd(t) { var e = Yp; if ($(t)) e = Hp; else if (Y(t)) { 0 === t.length && (e = Fp); for (var n = 0, i = t.length; n < i; n++) { var r = t[n]; if (null != r) { if (Y(r)) { e = Fp; break } if (q(r)) { e = Gp; break } } } } else if (q(t)) for (var o in t) if (_t(t, o) && N(t[o])) { e = Wp; break } return e } function tf(t) { if (t) { var e = yt(); return z(t, (function (t, n) { var i = { name: (t = q(t) ? t : { name: t }).name, displayName: t.displayName, type: t.type }; if (null == i.name) return i; i.name += "", null == i.displayName && (i.displayName = i.name); var r = e.get(i.name); return r ? i.name += "-" + r.count++ : e.set(i.name, { count: 1 }), i })) } } function ef(t, e, n, i) { if (e === Up) for (var r = 0; r < n.length && r < i; r++)t(n[r] ? n[r][0] : null, r); else { var o = n[0] || []; for (r = 0; r < o.length && r < i; r++)t(o[r], r) } } function nf(t) { var e = t.sourceFormat; return e === Gp || e === Wp } var rf = function () { function t(t, e) { var n = Kd(t) ? t : Jd(t); this._source = n; var i = this._data = n.data; n.sourceFormat === Hp && (this._offset = 0, this._dimSize = e, this._data = i), jd(this, i, n) } return t.prototype.getSource = function () { return this._source }, t.prototype.count = function () { return 0 }, t.prototype.getItem = function (t, e) { }, t.prototype.appendData = function (t) { }, t.prototype.clean = function () { }, t.protoInitialize = function () { var e = t.prototype; e.pure = !1, e.persistent = !0 }(), t.internalField = function () { var t; jd = function (t, r, o) { var a = o.sourceFormat, s = o.seriesLayoutBy, l = o.startIndex, u = o.dimensionsDefine, h = Zd[ff(a, s)]; if (A(t, h), a === Hp) t.getItem = e, t.count = i, t.fillStorage = n; else { var c = sf(a, s); t.getItem = W(c, null, r, l, u); var p = hf(a, s); t.count = W(p, null, r, l, u) } }; var e = function (t, e) { t -= this._offset, e = e || []; for (var n = this._data, i = this._dimSize, r = i * t, o = 0; o < i; o++)e[o] = n[r + o]; return e }, n = function (t, e, n, i) { for (var r = this._data, o = this._dimSize, a = 0; a < o; a++) { for (var s = i[a], l = null == s[0] ? 1 / 0 : s[0], u = null == s[1] ? -1 / 0 : s[1], h = e - t, c = n[a], p = 0; p < h; p++) { var d = r[p * o + a]; c[t + p] = d, d < l && (l = d), d > u && (u = d) } s[0] = l, s[1] = u } }, i = function () { return this._data ? this._data.length / this._dimSize : 0 }; function r(t) { for (var e = 0; e < t.length; e++)this._data.push(t[e]) } (t = {})[Fp + "_" + Xp] = { pure: !0, appendData: r }, t[Fp + "_" + Up] = { pure: !0, appendData: function () { throw new Error('Do not support appendData when set seriesLayoutBy: "row".') } }, t[Gp] = { pure: !0, appendData: r }, t[Wp] = { pure: !0, appendData: function (t) { var e = this._data; E(t, (function (t, n) { for (var i = e[n] || (e[n] = []), r = 0; r < (t || []).length; r++)i.push(t[r]) })) } }, t[Bp] = { appendData: r }, t[Hp] = { persistent: !1, pure: !0, appendData: function (t) { this._data = t }, clean: function () { this._offset += this.count(), this._data = null } }, Zd = t }(), t }(), of = function (t, e, n, i) { return t[i] }, af = ((Yd = {})[Fp + "_" + Xp] = function (t, e, n, i) { return t[i + e] }, Yd[Fp + "_" + Up] = function (t, e, n, i, r) { i += e; for (var o = r || [], a = t, s = 0; s < a.length; s++) { var l = a[s]; o[s] = l ? l[i] : null } return o }, Yd[Gp] = of, Yd[Wp] = function (t, e, n, i, r) { for (var o = r || [], a = 0; a < n.length; a++) { var s = n[a].name; 0; var l = t[s]; o[a] = l ? l[i] : null } return o }, Yd[Bp] = of, Yd); function sf(t, e) { var n = af[ff(t, e)]; return n } var lf = function (t, e, n) { return t.length }, uf = ((Xd = {})[Fp + "_" + Xp] = function (t, e, n) { return Math.max(0, t.length - e) }, Xd[Fp + "_" + Up] = function (t, e, n) { var i = t[0]; return i ? Math.max(0, i.length - e) : 0 }, Xd[Gp] = lf, Xd[Wp] = function (t, e, n) { var i = n[0].name; var r = t[i]; return r ? r.length : 0 }, Xd[Bp] = lf, Xd); function hf(t, e) { var n = uf[ff(t, e)]; return n } var cf = function (t, e, n) { return t[e] }, pf = ((Ud = {})[Fp] = cf, Ud[Gp] = function (t, e, n) { return t[n] }, Ud[Wp] = cf, Ud[Bp] = function (t, e, n) { var i = Mo(t); return i instanceof Array ? i[e] : i }, Ud[Hp] = cf, Ud); function df(t) { var e = pf[t]; return e } function ff(t, e) { return t === Fp ? t + "_" + e : t } function gf(t, e, n) { if (t) { var i = t.getRawDataItem(e); if (null != i) { var r = t.getStore(), o = r.getSource().sourceFormat; if (null != n) { var a = t.getDimensionIndex(n), s = r.getDimensionProperty(a); return df(o)(i, a, s) } var l = i; return o === Bp && (l = Mo(i)), l } } } var yf = /\{@(.+?)\}/g, vf = function () { function t() { } return t.prototype.getDataParams = function (t, e) { var n = this.getData(e), i = this.getRawValue(t, e), r = n.getRawIndex(t), o = n.getName(t), a = n.getRawDataItem(t), s = n.getItemVisual(t, "style"), l = s && s[n.getItemVisual(t, "drawType") || "fill"], u = s && s.stroke, h = this.mainType, c = "series" === h, p = n.userOutput && n.userOutput.get(); return { componentType: h, componentSubType: this.subType, componentIndex: this.componentIndex, seriesType: c ? this.subType : null, seriesIndex: this.seriesIndex, seriesId: c ? this.id : null, seriesName: c ? this.name : null, name: o, dataIndex: r, data: a, dataType: e, value: i, color: l, borderColor: u, dimensionNames: p ? p.fullDimensions : null, encode: p ? p.encode : null, $vars: ["seriesName", "name", "value"] } }, t.prototype.getFormattedLabel = function (t, e, n, i, r, o) { e = e || "normal"; var a = this.getData(n), s = this.getDataParams(t, n); (o && (s.value = o.interpolatedValue), null != i && Y(s.value) && (s.value = s.value[i]), r) || (r = a.getItemModel(t).get("normal" === e ? ["label", "formatter"] : [e, "label", "formatter"])); return X(r) ? (s.status = e, s.dimensionIndex = i, r(s)) : U(r) ? mp(r, s).replace(yf, (function (e, n) { var i = n.length, r = n; "[" === r.charAt(0) && "]" === r.charAt(i - 1) && (r = +r.slice(1, i - 1)); var s = gf(a, t, r); if (o && Y(o.interpolatedValue)) { var l = a.getDimensionIndex(r); l >= 0 && (s = o.interpolatedValue[l]) } return null != s ? s + "" : "" })) : void 0 }, t.prototype.getRawValue = function (t, e) { return gf(this.getData(e), t) }, t.prototype.formatTooltip = function (t, e, n) { }, t }(); function mf(t) { var e, n; return q(t) ? t.type && (n = t) : e = t, { text: e, frag: n } } function xf(t) { return new _f(t) } var _f = function () { function t(t) { t = t || {}, this._reset = t.reset, this._plan = t.plan, this._count = t.count, this._onDirty = t.onDirty, this._dirty = !0 } return t.prototype.perform = function (t) { var e, n = this._upstream, i = t && t.skip; if (this._dirty && n) { var r = this.context; r.data = r.outputData = n.context.outputData } this.__pipeline && (this.__pipeline.currentTask = this), this._plan && !i && (e = this._plan(this.context)); var o, a = h(this._modBy), s = this._modDataCount || 0, l = h(t && t.modBy), u = t && t.modDataCount || 0; function h(t) { return !(t >= 1) && (t = 1), t } a === l && s === u || (e = "reset"), (this._dirty || "reset" === e) && (this._dirty = !1, o = this._doReset(i)), this._modBy = l, this._modDataCount = u; var c = t && t.step; if (this._dueEnd = n ? n._outputDueEnd : this._count ? this._count(this.context) : 1 / 0, this._progress) { var p = this._dueIndex, d = Math.min(null != c ? this._dueIndex + c : 1 / 0, this._dueEnd); if (!i && (o || p < d)) { var f = this._progress; if (Y(f)) for (var g = 0; g < f.length; g++)this._doProgress(f[g], p, d, l, u); else this._doProgress(f, p, d, l, u) } this._dueIndex = d; var y = null != this._settedOutputEnd ? this._settedOutputEnd : d; 0, this._outputDueEnd = y } else this._dueIndex = this._outputDueEnd = null != this._settedOutputEnd ? this._settedOutputEnd : this._dueEnd; return this.unfinished() }, t.prototype.dirty = function () { this._dirty = !0, this._onDirty && this._onDirty(this.context) }, t.prototype._doProgress = function (t, e, n, i, r) { bf.reset(e, n, i, r), this._callingProgress = t, this._callingProgress({ start: e, end: n, count: n - e, next: bf.next }, this.context) }, t.prototype._doReset = function (t) { var e, n; this._dueIndex = this._outputDueEnd = this._dueEnd = 0, this._settedOutputEnd = null, !t && this._reset && ((e = this._reset(this.context)) && e.progress && (n = e.forceFirstProgress, e = e.progress), Y(e) && !e.length && (e = null)), this._progress = e, this._modBy = this._modDataCount = null; var i = this._downstream; return i && i.dirty(), n }, t.prototype.unfinished = function () { return this._progress && this._dueIndex < this._dueEnd }, t.prototype.pipe = function (t) { (this._downstream !== t || this._dirty) && (this._downstream = t, t._upstream = this, t.dirty()) }, t.prototype.dispose = function () { this._disposed || (this._upstream && (this._upstream._downstream = null), this._downstream && (this._downstream._upstream = null), this._dirty = !1, this._disposed = !0) }, t.prototype.getUpstream = function () { return this._upstream }, t.prototype.getDownstream = function () { return this._downstream }, t.prototype.setOutputEnd = function (t) { this._outputDueEnd = this._settedOutputEnd = t }, t }(), bf = function () { var t, e, n, i, r, o = { reset: function (l, u, h, c) { e = l, t = u, n = h, i = c, r = Math.ceil(i / n), o.next = n > 1 && i > 0 ? s : a } }; return o; function a() { return e < t ? e++ : null } function s() { var o = e % r * n + Math.ceil(e / r), a = e >= t ? null : o < i ? o : e; return e++, a } }(); function wf(t, e) { var n = e && e.type; return "ordinal" === n ? t : ("time" !== n || j(t) || null == t || "-" === t || (t = +ro(t)), null == t || "" === t ? NaN : +t) } var Sf = yt({ number: function (t) { return parseFloat(t) }, time: function (t) { return +ro(t) }, trim: function (t) { return U(t) ? ut(t) : t } }); function Mf(t) { return Sf.get(t) } var If = { lt: function (t, e) { return t < e }, lte: function (t, e) { return t <= e }, gt: function (t, e) { return t > e }, gte: function (t, e) { return t >= e } }, Tf = function () { function t(t, e) { if (!j(e)) { var n = ""; 0, vo(n) } this._opFn = If[t], this._rvalFloat = ho(e) } return t.prototype.evaluate = function (t) { return j(t) ? this._opFn(t, this._rvalFloat) : this._opFn(ho(t), this._rvalFloat) }, t }(), Cf = function () { function t(t, e) { var n = "desc" === t; this._resultLT = n ? 1 : -1, null == e && (e = n ? "min" : "max"), this._incomparable = "min" === e ? -1 / 0 : 1 / 0 } return t.prototype.evaluate = function (t, e) { var n = j(t) ? t : ho(t), i = j(e) ? e : ho(e), r = isNaN(n), o = isNaN(i); if (r && (n = this._incomparable), o && (i = this._incomparable), r && o) { var a = U(t), s = U(e); a && (n = s ? t : 0), s && (i = a ? e : 0) } return n < i ? this._resultLT : n > i ? -this._resultLT : 0 }, t }(), Df = function () { function t(t, e) { this._rval = e, this._isEQ = t, this._rvalTypeof = typeof e, this._rvalFloat = ho(e) } return t.prototype.evaluate = function (t) { var e = t === this._rval; if (!e) { var n = typeof t; n === this._rvalTypeof || "number" !== n && "number" !== this._rvalTypeof || (e = ho(t) === this._rvalFloat) } return this._isEQ ? e : !e }, t }(); function Af(t, e) { return "eq" === t || "ne" === t ? new Df("eq" === t, e) : _t(If, t) ? new Tf(t, e) : null } var kf = function () { function t() { } return t.prototype.getRawData = function () { throw new Error("not supported") }, t.prototype.getRawDataItem = function (t) { throw new Error("not supported") }, t.prototype.cloneRawData = function () { }, t.prototype.getDimensionInfo = function (t) { }, t.prototype.cloneAllDimensionInfo = function () { }, t.prototype.count = function () { }, t.prototype.retrieveValue = function (t, e) { }, t.prototype.retrieveValueFromItem = function (t, e) { }, t.prototype.convertValue = function (t, e) { return wf(t, e) }, t }(); function Lf(t) { var e = t.sourceFormat; if (!zf(e)) { var n = ""; 0, vo(n) } return t.data } function Pf(t) { var e = t.sourceFormat, n = t.data; if (!zf(e)) { var i = ""; 0, vo(i) } if (e === Fp) { for (var r = [], o = 0, a = n.length; o < a; o++)r.push(n[o].slice()); return r } if (e === Gp) { for (r = [], o = 0, a = n.length; o < a; o++)r.push(A({}, n[o])); return r } } function Of(t, e, n) { if (null != n) return j(n) || !isNaN(n) && !_t(e, n) ? t[n] : _t(e, n) ? e[n] : void 0 } function Rf(t) { return T(t) } var Nf = yt(); function Ef(t, e, n, i) { var r = ""; e.length || vo(r), q(t) || vo(r); var o = t.type, a = Nf.get(o); a || vo(r); var s = z(e, (function (t) { return function (t, e) { var n = new kf, i = t.data, r = n.sourceFormat = t.sourceFormat, o = t.startIndex, a = ""; t.seriesLayoutBy !== Xp && vo(a); var s = [], l = {}, u = t.dimensionsDefine; if (u) E(u, (function (t, e) { var n = t.name, i = { index: e, name: n, displayName: t.displayName }; if (s.push(i), null != n) { var r = ""; _t(l, n) && vo(r), l[n] = i } })); else for (var h = 0; h < t.dimensionsDetectedCount; h++)s.push({ index: h }); var c = sf(r, Xp); e.__isBuiltIn && (n.getRawDataItem = function (t) { return c(i, o, s, t) }, n.getRawData = W(Lf, null, t)), n.cloneRawData = W(Pf, null, t); var p = hf(r, Xp); n.count = W(p, null, i, o, s); var d = df(r); n.retrieveValue = function (t, e) { var n = c(i, o, s, t); return f(n, e) }; var f = n.retrieveValueFromItem = function (t, e) { if (null != t) { var n = s[e]; return n ? d(t, e, n.name) : void 0 } }; return n.getDimensionInfo = W(Of, null, s, l), n.cloneAllDimensionInfo = W(Rf, null, s), n }(t, a) })), l = bo(a.transform({ upstream: s[0], upstreamList: s, config: T(t.config) })); return z(l, (function (t, n) { var i, r = ""; q(t) || vo(r), t.data || vo(r), zf(Qd(t.data)) || vo(r); var o = e[0]; if (o && 0 === n && !t.dimensions) { var a = o.startIndex; a && (t.data = o.data.slice(0, a).concat(t.data)), i = { seriesLayoutBy: Xp, sourceHeader: a, dimensions: o.metaRawOption.dimensions } } else i = { seriesLayoutBy: Xp, sourceHeader: 0, dimensions: t.dimensions }; return $d(t.data, i, null) })) } function zf(t) { return t === Fp || t === Gp } var Vf, Bf = "undefined", Ff = typeof Uint32Array === Bf ? Array : Uint32Array, Gf = typeof Uint16Array === Bf ? Array : Uint16Array, Wf = typeof Int32Array === Bf ? Array : Int32Array, Hf = typeof Float64Array === Bf ? Array : Float64Array, Yf = { float: Hf, int: Wf, ordinal: Array, number: Array, time: Hf }; function Xf(t) { return t > 65535 ? Ff : Gf } function Uf(t, e, n, i, r) { var o = Yf[n || "float"]; if (r) { var a = t[e], s = a && a.length; if (s !== i) { for (var l = new o(i), u = 0; u < s; u++)l[u] = a[u]; t[e] = l } } else t[e] = new o(i) } var Zf = function () { function t() { this._chunks = [], this._rawExtent = [], this._extent = [], this._count = 0, this._rawCount = 0, this._calcDimNameToIdx = yt() } return t.prototype.initData = function (t, e, n) { this._provider = t, this._chunks = [], this._indices = null, this.getRawIndex = this._getRawIdxIdentity; var i = t.getSource(), r = this.defaultDimValueGetter = Vf[i.sourceFormat]; this._dimValueGetter = n || r, this._rawExtent = []; nf(i); this._dimensions = z(e, (function (t) { return { type: t.type, property: t.property } })), this._initDataFromProvider(0, t.count()) }, t.prototype.getProvider = function () { return this._provider }, t.prototype.getSource = function () { return this._provider.getSource() }, t.prototype.ensureCalculationDimension = function (t, e) { var n = this._calcDimNameToIdx, i = this._dimensions, r = n.get(t); if (null != r) { if (i[r].type === e) return r } else r = i.length; return i[r] = { type: e }, n.set(t, r), this._chunks[r] = new Yf[e || "float"](this._rawCount), this._rawExtent[r] = [1 / 0, -1 / 0], r }, t.prototype.collectOrdinalMeta = function (t, e) { var n = this._chunks[t], i = this._dimensions[t], r = this._rawExtent, o = i.ordinalOffset || 0, a = n.length; 0 === o && (r[t] = [1 / 0, -1 / 0]); for (var s = r[t], l = o; l < a; l++) { var u = n[l] = e.parseAndCollect(n[l]); isNaN(u) || (s[0] = Math.min(u, s[0]), s[1] = Math.max(u, s[1])) } i.ordinalMeta = e, i.ordinalOffset = a, i.type = "ordinal" }, t.prototype.getOrdinalMeta = function (t) { return this._dimensions[t].ordinalMeta }, t.prototype.getDimensionProperty = function (t) { var e = this._dimensions[t]; return e && e.property }, t.prototype.appendData = function (t) { var e = this._provider, n = this.count(); e.appendData(t); var i = e.count(); return e.persistent || (i += n), n < i && this._initDataFromProvider(n, i, !0), [n, i] }, t.prototype.appendValues = function (t, e) { for (var n = this._chunks, i = this._dimensions, r = i.length, o = this._rawExtent, a = this.count(), s = a + Math.max(t.length, e || 0), l = 0; l < r; l++) { Uf(n, l, (d = i[l]).type, s, !0) } for (var u = [], h = a; h < s; h++)for (var c = h - a, p = 0; p < r; p++) { var d = i[p], f = Vf.arrayRows.call(this, t[c] || u, d.property, c, p); n[p][h] = f; var g = o[p]; f < g[0] && (g[0] = f), f > g[1] && (g[1] = f) } return this._rawCount = this._count = s, { start: a, end: s } }, t.prototype._initDataFromProvider = function (t, e, n) { for (var i = this._provider, r = this._chunks, o = this._dimensions, a = o.length, s = this._rawExtent, l = z(o, (function (t) { return t.property })), u = 0; u < a; u++) { var h = o[u]; s[u] || (s[u] = [1 / 0, -1 / 0]), Uf(r, u, h.type, e, n) } if (i.fillStorage) i.fillStorage(t, e, r, s); else for (var c = [], p = t; p < e; p++) { c = i.getItem(p, c); for (var d = 0; d < a; d++) { var f = r[d], g = this._dimValueGetter(c, l[d], p, d); f[p] = g; var y = s[d]; g < y[0] && (y[0] = g), g > y[1] && (y[1] = g) } } !i.persistent && i.clean && i.clean(), this._rawCount = this._count = e, this._extent = [] }, t.prototype.count = function () { return this._count }, t.prototype.get = function (t, e) { if (!(e >= 0 && e < this._count)) return NaN; var n = this._chunks[t]; return n ? n[this.getRawIndex(e)] : NaN }, t.prototype.getValues = function (t, e) { var n = [], i = []; if (null == e) { e = t, t = []; for (var r = 0; r < this._dimensions.length; r++)i.push(r) } else i = t; r = 0; for (var o = i.length; r < o; r++)n.push(this.get(i[r], e)); return n }, t.prototype.getByRawIndex = function (t, e) { if (!(e >= 0 && e < this._rawCount)) return NaN; var n = this._chunks[t]; return n ? n[e] : NaN }, t.prototype.getSum = function (t) { var e = 0; if (this._chunks[t]) for (var n = 0, i = this.count(); n < i; n++) { var r = this.get(t, n); isNaN(r) || (e += r) } return e }, t.prototype.getMedian = function (t) { var e = []; this.each([t], (function (t) { isNaN(t) || e.push(t) })); var n = e.sort((function (t, e) { return t - e })), i = this.count(); return 0 === i ? 0 : i % 2 == 1 ? n[(i - 1) / 2] : (n[i / 2] + n[i / 2 - 1]) / 2 }, t.prototype.indexOfRawIndex = function (t) { if (t >= this._rawCount || t < 0) return -1; if (!this._indices) return t; var e = this._indices, n = e[t]; if (null != n && n < this._count && n === t) return t; for (var i = 0, r = this._count - 1; i <= r;) { var o = (i + r) / 2 | 0; if (e[o] < t) i = o + 1; else { if (!(e[o] > t)) return o; r = o - 1 } } return -1 }, t.prototype.indicesOfNearest = function (t, e, n) { var i = this._chunks[t], r = []; if (!i) return r; null == n && (n = 1 / 0); for (var o = 1 / 0, a = -1, s = 0, l = 0, u = this.count(); l < u; l++) { var h = e - i[this.getRawIndex(l)], c = Math.abs(h); c <= n && ((c < o || c === o && h >= 0 && a < 0) && (o = c, a = h, s = 0), h === a && (r[s++] = l)) } return r.length = s, r }, t.prototype.getIndices = function () { var t, e = this._indices; if (e) { var n = e.constructor, i = this._count; if (n === Array) { t = new n(i); for (var r = 0; r < i; r++)t[r] = e[r] } else t = new n(e.buffer, 0, i) } else { t = new (n = Xf(this._rawCount))(this.count()); for (r = 0; r < t.length; r++)t[r] = r } return t }, t.prototype.filter = function (t, e) { if (!this._count) return this; for (var n = this.clone(), i = n.count(), r = new (Xf(n._rawCount))(i), o = [], a = t.length, s = 0, l = t[0], u = n._chunks, h = 0; h < i; h++) { var c = void 0, p = n.getRawIndex(h); if (0 === a) c = e(h); else if (1 === a) { c = e(u[l][p], h) } else { for (var d = 0; d < a; d++)o[d] = u[t[d]][p]; o[d] = h, c = e.apply(null, o) } c && (r[s++] = p) } return s < i && (n._indices = r), n._count = s, n._extent = [], n._updateGetRawIdx(), n }, t.prototype.selectRange = function (t) { var e = this.clone(), n = e._count; if (!n) return this; var i = G(t), r = i.length; if (!r) return this; var o = e.count(), a = new (Xf(e._rawCount))(o), s = 0, l = i[0], u = t[l][0], h = t[l][1], c = e._chunks, p = !1; if (!e._indices) { var d = 0; if (1 === r) { for (var f = c[i[0]], g = 0; g < n; g++) { ((x = f[g]) >= u && x <= h || isNaN(x)) && (a[s++] = d), d++ } p = !0 } else if (2 === r) { f = c[i[0]]; var y = c[i[1]], v = t[i[1]][0], m = t[i[1]][1]; for (g = 0; g < n; g++) { var x = f[g], _ = y[g]; (x >= u && x <= h || isNaN(x)) && (_ >= v && _ <= m || isNaN(_)) && (a[s++] = d), d++ } p = !0 } } if (!p) if (1 === r) for (g = 0; g < o; g++) { var b = e.getRawIndex(g); ((x = c[i[0]][b]) >= u && x <= h || isNaN(x)) && (a[s++] = b) } else for (g = 0; g < o; g++) { for (var w = !0, S = (b = e.getRawIndex(g), 0); S < r; S++) { var M = i[S]; ((x = c[M][b]) < t[M][0] || x > t[M][1]) && (w = !1) } w && (a[s++] = e.getRawIndex(g)) } return s < o && (e._indices = a), e._count = s, e._extent = [], e._updateGetRawIdx(), e }, t.prototype.map = function (t, e) { var n = this.clone(t); return this._updateDims(n, t, e), n }, t.prototype.modify = function (t, e) { this._updateDims(this, t, e) }, t.prototype._updateDims = function (t, e, n) { for (var i = t._chunks, r = [], o = e.length, a = t.count(), s = [], l = t._rawExtent, u = 0; u < e.length; u++)l[e[u]] = [1 / 0, -1 / 0]; for (var h = 0; h < a; h++) { for (var c = t.getRawIndex(h), p = 0; p < o; p++)s[p] = i[e[p]][c]; s[o] = h; var d = n && n.apply(null, s); if (null != d) { "object" != typeof d && (r[0] = d, d = r); for (u = 0; u < d.length; u++) { var f = e[u], g = d[u], y = l[f], v = i[f]; v && (v[c] = g), g < y[0] && (y[0] = g), g > y[1] && (y[1] = g) } } } }, t.prototype.lttbDownSample = function (t, e) { var n, i, r, o = this.clone([t], !0), a = o._chunks[t], s = this.count(), l = 0, u = Math.floor(1 / e), h = this.getRawIndex(0), c = new (Xf(this._rawCount))(Math.min(2 * (Math.ceil(s / u) + 2), s)); c[l++] = h; for (var p = 1; p < s - 1; p += u) { for (var d = Math.min(p + u, s - 1), f = Math.min(p + 2 * u, s), g = (f + d) / 2, y = 0, v = d; v < f; v++) { var m = a[I = this.getRawIndex(v)]; isNaN(m) || (y += m) } y /= f - d; var x = p, _ = Math.min(p + u, s), b = p - 1, w = a[h]; n = -1, r = x; var S = -1, M = 0; for (v = x; v < _; v++) { var I; m = a[I = this.getRawIndex(v)]; isNaN(m) ? (M++, S < 0 && (S = I)) : (i = Math.abs((b - g) * (m - w) - (b - v) * (y - w))) > n && (n = i, r = I) } M > 0 && M < _ - x && (c[l++] = Math.min(S, r), r = Math.max(S, r)), c[l++] = r, h = r } return c[l++] = this.getRawIndex(s - 1), o._count = l, o._indices = c, o.getRawIndex = this._getRawIdx, o }, t.prototype.downSample = function (t, e, n, i) { for (var r = this.clone([t], !0), o = r._chunks, a = [], s = Math.floor(1 / e), l = o[t], u = this.count(), h = r._rawExtent[t] = [1 / 0, -1 / 0], c = new (Xf(this._rawCount))(Math.ceil(u / s)), p = 0, d = 0; d < u; d += s) { s > u - d && (s = u - d, a.length = s); for (var f = 0; f < s; f++) { var g = this.getRawIndex(d + f); a[f] = l[g] } var y = n(a), v = this.getRawIndex(Math.min(d + i(a, y) || 0, u - 1)); l[v] = y, y < h[0] && (h[0] = y), y > h[1] && (h[1] = y), c[p++] = v } return r._count = p, r._indices = c, r._updateGetRawIdx(), r }, t.prototype.each = function (t, e) { if (this._count) for (var n = t.length, i = this._chunks, r = 0, o = this.count(); r < o; r++) { var a = this.getRawIndex(r); switch (n) { case 0: e(r); break; case 1: e(i[t[0]][a], r); break; case 2: e(i[t[0]][a], i[t[1]][a], r); break; default: for (var s = 0, l = []; s < n; s++)l[s] = i[t[s]][a]; l[s] = r, e.apply(null, l) } } }, t.prototype.getDataExtent = function (t) { var e = this._chunks[t], n = [1 / 0, -1 / 0]; if (!e) return n; var i, r = this.count(); if (!this._indices) return this._rawExtent[t].slice(); if (i = this._extent[t]) return i.slice(); for (var o = (i = n)[0], a = i[1], s = 0; s < r; s++) { var l = e[this.getRawIndex(s)]; l < o && (o = l), l > a && (a = l) } return i = [o, a], this._extent[t] = i, i }, t.prototype.getRawDataItem = function (t) { var e = this.getRawIndex(t); if (this._provider.persistent) return this._provider.getItem(e); for (var n = [], i = this._chunks, r = 0; r < i.length; r++)n.push(i[r][e]); return n }, t.prototype.clone = function (e, n) { var i, r, o = new t, a = this._chunks, s = e && V(e, (function (t, e) { return t[e] = !0, t }), {}); if (s) for (var l = 0; l < a.length; l++)o._chunks[l] = s[l] ? (i = a[l], r = void 0, (r = i.constructor) === Array ? i.slice() : new r(i)) : a[l]; else o._chunks = a; return this._copyCommonProps(o), n || (o._indices = this._cloneIndices()), o._updateGetRawIdx(), o }, t.prototype._copyCommonProps = function (t) { t._count = this._count, t._rawCount = this._rawCount, t._provider = this._provider, t._dimensions = this._dimensions, t._extent = T(this._extent), t._rawExtent = T(this._rawExtent) }, t.prototype._cloneIndices = function () { if (this._indices) { var t = this._indices.constructor, e = void 0; if (t === Array) { var n = this._indices.length; e = new t(n); for (var i = 0; i < n; i++)e[i] = this._indices[i] } else e = new t(this._indices); return e } return null }, t.prototype._getRawIdxIdentity = function (t) { return t }, t.prototype._getRawIdx = function (t) { return t < this._count && t >= 0 ? this._indices[t] : -1 }, t.prototype._updateGetRawIdx = function () { this.getRawIndex = this._indices ? this._getRawIdx : this._getRawIdxIdentity }, t.internalField = function () { function t(t, e, n, i) { return wf(t[i], this._dimensions[i]) } Vf = { arrayRows: t, objectRows: function (t, e, n, i) { return wf(t[e], this._dimensions[i]) }, keyedColumns: t, original: function (t, e, n, i) { var r = t && (null == t.value ? t : t.value); return wf(r instanceof Array ? r[i] : r, this._dimensions[i]) }, typedArray: function (t, e, n, i) { return t[i] } } }(), t }(), jf = function () { function t(t) { this._sourceList = [], this._storeList = [], this._upstreamSignList = [], this._versionSignBase = 0, this._dirty = !0, this._sourceHost = t } return t.prototype.dirty = function () { this._setLocalSource([], []), this._storeList = [], this._dirty = !0 }, t.prototype._setLocalSource = function (t, e) { this._sourceList = t, this._upstreamSignList = e, this._versionSignBase++, this._versionSignBase > 9e10 && (this._versionSignBase = 0) }, t.prototype._getVersionSign = function () { return this._sourceHost.uid + "_" + this._versionSignBase }, t.prototype.prepareSource = function () { this._isDirty() && (this._createSource(), this._dirty = !1) }, t.prototype._createSource = function () { this._setLocalSource([], []); var t, e, n = this._sourceHost, i = this._getUpstreamSourceManagers(), r = !!i.length; if (Kf(n)) { var o = n, a = void 0, s = void 0, l = void 0; if (r) { var u = i[0]; u.prepareSource(), a = (l = u.getSource()).data, s = l.sourceFormat, e = [u._getVersionSign()] } else s = $(a = o.get("data", !0)) ? Hp : Bp, e = []; var h = this._getSourceMetaRawOption() || {}, c = l && l.metaRawOption || {}, p = rt(h.seriesLayoutBy, c.seriesLayoutBy) || null, d = rt(h.sourceHeader, c.sourceHeader), f = rt(h.dimensions, c.dimensions); t = p !== c.seriesLayoutBy || !!d != !!c.sourceHeader || f ? [$d(a, { seriesLayoutBy: p, sourceHeader: d, dimensions: f }, s)] : [] } else { var g = n; if (r) { var y = this._applyTransform(i); t = y.sourceList, e = y.upstreamSignList } else { t = [$d(g.get("source", !0), this._getSourceMetaRawOption(), null)], e = [] } } this._setLocalSource(t, e) }, t.prototype._applyTransform = function (t) { var e, n = this._sourceHost, i = n.get("transform", !0), r = n.get("fromTransformResult", !0); if (null != r) { var o = ""; 1 !== t.length && $f(o) } var a, s = [], l = []; return E(t, (function (t) { t.prepareSource(); var e = t.getSource(r || 0), n = ""; null == r || e || $f(n), s.push(e), l.push(t._getVersionSign()) })), i ? e = function (t, e, n) { var i = bo(t), r = i.length, o = ""; r || vo(o); for (var a = 0, s = r; a < s; a++)e = Ef(i[a], e), a !== s - 1 && (e.length = Math.max(e.length, 1)); return e }(i, s, n.componentIndex) : null != r && (e = [(a = s[0], new qd({ data: a.data, sourceFormat: a.sourceFormat, seriesLayoutBy: a.seriesLayoutBy, dimensionsDefine: T(a.dimensionsDefine), startIndex: a.startIndex, dimensionsDetectedCount: a.dimensionsDetectedCount }))]), { sourceList: e, upstreamSignList: l } }, t.prototype._isDirty = function () { if (this._dirty) return !0; for (var t = this._getUpstreamSourceManagers(), e = 0; e < t.length; e++) { var n = t[e]; if (n._isDirty() || this._upstreamSignList[e] !== n._getVersionSign()) return !0 } }, t.prototype.getSource = function (t) { t = t || 0; var e = this._sourceList[t]; if (!e) { var n = this._getUpstreamSourceManagers(); return n[0] && n[0].getSource(t) } return e }, t.prototype.getSharedDataStore = function (t) { var e = t.makeStoreSchema(); return this._innerGetDataStore(e.dimensions, t.source, e.hash) }, t.prototype._innerGetDataStore = function (t, e, n) { var i = this._storeList, r = i[0]; r || (r = i[0] = {}); var o = r[n]; if (!o) { var a = this._getUpstreamSourceManagers()[0]; Kf(this._sourceHost) && a ? o = a._innerGetDataStore(t, e, n) : (o = new Zf).initData(new rf(e, t.length), t), r[n] = o } return o }, t.prototype._getUpstreamSourceManagers = function () { var t = this._sourceHost; if (Kf(t)) { var e = Qp(t); return e ? [e.getSourceManager()] : [] } return z(function (t) { return t.get("transform", !0) || t.get("fromTransformResult", !0) ? Bo(t.ecModel, "dataset", { index: t.get("fromDatasetIndex", !0), id: t.get("fromDatasetId", !0) }, zo).models : [] }(t), (function (t) { return t.getSourceManager() })) }, t.prototype._getSourceMetaRawOption = function () { var t, e, n, i = this._sourceHost; if (Kf(i)) t = i.get("seriesLayoutBy", !0), e = i.get("sourceHeader", !0), n = i.get("dimensions", !0); else if (!this._getUpstreamSourceManagers().length) { var r = i; t = r.get("seriesLayoutBy", !0), e = r.get("sourceHeader", !0), n = r.get("dimensions", !0) } return { seriesLayoutBy: t, sourceHeader: e, dimensions: n } }, t }(); function qf(t) { t.option.transform && ct(t.option.transform) } function Kf(t) { return "series" === t.mainType } function $f(t) { throw new Error(t) } var Jf = "line-height:1"; function Qf(t, e) { var n = t.color || "#6e7079", i = t.fontSize || 12, r = t.fontWeight || "400", o = t.color || "#464646", a = t.fontSize || 14, s = t.fontWeight || "900"; return "html" === e ? { nameStyle: "font-size:" + re(i + "") + "px;color:" + re(n) + ";font-weight:" + re(r + ""), valueStyle: "font-size:" + re(a + "") + "px;color:" + re(o) + ";font-weight:" + re(s + "") } : { nameStyle: { fontSize: i, fill: n, fontWeight: r }, valueStyle: { fontSize: a, fill: o, fontWeight: s } } } var tg = [0, 10, 20, 30], eg = ["", "\n", "\n\n", "\n\n\n"]; function ng(t, e) { return e.type = t, e } function ig(t) { return "section" === t.type } function rg(t) { return ig(t) ? ag : sg } function og(t) { if (ig(t)) { var e = 0, n = t.blocks.length, i = n > 1 || n > 0 && !t.noHeader; return E(t.blocks, (function (t) { var n = og(t); n >= e && (e = n + +(i && (!n || ig(t) && !t.noHeader))) })), e } return 0 } function ag(t, e, n, i) { var r, o = e.noHeader, a = (r = og(e), { html: tg[r], richText: eg[r] }), s = [], l = e.blocks || []; lt(!l || Y(l)), l = l || []; var u = t.orderMode; if (e.sortBlocks && u) { l = l.slice(); var h = { valueAsc: "asc", valueDesc: "desc" }; if (_t(h, u)) { var c = new Cf(h[u], null); l.sort((function (t, e) { return c.evaluate(t.sortParam, e.sortParam) })) } else "seriesDesc" === u && l.reverse() } E(l, (function (n, r) { var o = e.valueFormatter, l = rg(n)(o ? A(A({}, t), { valueFormatter: o }) : t, n, r > 0 ? a.html : 0, i); null != l && s.push(l) })); var p = "richText" === t.renderMode ? s.join(a.richText) : ug(s.join(""), o ? n : a.html); if (o) return p; var d = gp(e.header, "ordinal", t.useUTC), f = Qf(i, t.renderMode).nameStyle; return "richText" === t.renderMode ? hg(t, d, f) + a.richText + p : ug('<div style="' + f + ";" + Jf + ';">' + re(d) + "</div>" + p, n) } function sg(t, e, n, i) { var r = t.renderMode, o = e.noName, a = e.noValue, s = !e.markerType, l = e.name, u = t.useUTC, h = e.valueFormatter || t.valueFormatter || function (t) { return z(t = Y(t) ? t : [t], (function (t, e) { return gp(t, Y(d) ? d[e] : d, u) })) }; if (!o || !a) { var c = s ? "" : t.markupStyleCreator.makeTooltipMarker(e.markerType, e.markerColor || "#333", r), p = o ? "" : gp(l, "ordinal", u), d = e.valueType, f = a ? [] : h(e.value), g = !s || !o, y = !s && o, v = Qf(i, r), m = v.nameStyle, x = v.valueStyle; return "richText" === r ? (s ? "" : c) + (o ? "" : hg(t, p, m)) + (a ? "" : function (t, e, n, i, r) { var o = [r], a = i ? 10 : 20; return n && o.push({ padding: [0, 0, 0, a], align: "right" }), t.markupStyleCreator.wrapRichTextStyle(Y(e) ? e.join("  ") : e, o) }(t, f, g, y, x)) : ug((s ? "" : c) + (o ? "" : function (t, e, n) { return '<span style="' + n + ";" + (e ? "margin-left:2px" : "") + '">' + re(t) + "</span>" }(p, !s, m)) + (a ? "" : function (t, e, n, i) { var r = n ? "10px" : "20px", o = e ? "float:right;margin-left:" + r : ""; return t = Y(t) ? t : [t], '<span style="' + o + ";" + i + '">' + z(t, (function (t) { return re(t) })).join("&nbsp;&nbsp;") + "</span>" }(f, g, y, x)), n) } } function lg(t, e, n, i, r, o) { if (t) return rg(t)({ useUTC: r, renderMode: n, orderMode: i, markupStyleCreator: e, valueFormatter: t.valueFormatter }, t, 0, o) } function ug(t, e) { return '<div style="' + ("margin: " + e + "px 0 0") + ";" + Jf + ';">' + t + '<div style="clear:both"></div></div>' } function hg(t, e, n) { return t.markupStyleCreator.wrapRichTextStyle(e, n) } function cg(t, e) { return _p(t.getData().getItemVisual(e, "style")[t.visualDrawType]) } function pg(t, e) { var n = t.get("padding"); return null != n ? n : "richText" === e ? [8, 10] : 10 } var dg = function () { function t() { this.richTextStyles = {}, this._nextStyleNameId = po() } return t.prototype._generateStyleName = function () { return "__EC_aUTo_" + this._nextStyleNameId++ }, t.prototype.makeTooltipMarker = function (t, e, n) { var i = "richText" === n ? this._generateStyleName() : null, r = xp({ color: e, type: t, renderMode: n, markerId: i }); return U(r) ? r : (this.richTextStyles[i] = r.style, r.content) }, t.prototype.wrapRichTextStyle = function (t, e) { var n = {}; Y(e) ? E(e, (function (t) { return A(n, t) })) : A(n, e); var i = this._generateStyleName(); return this.richTextStyles[i] = n, "{" + i + "|" + t + "}" }, t }(); function fg(t) { var e, n, i, r, o = t.series, a = t.dataIndex, s = t.multipleSeries, l = o.getData(), u = l.mapDimensionsAll("defaultedTooltip"), h = u.length, c = o.getRawValue(a), p = Y(c), d = cg(o, a); if (h > 1 || p && !h) { var f = function (t, e, n, i, r) { var o = e.getData(), a = V(t, (function (t, e, n) { var i = o.getDimensionInfo(n); return t || i && !1 !== i.tooltip && null != i.displayName }), !1), s = [], l = [], u = []; function h(t, e) { var n = o.getDimensionInfo(e); n && !1 !== n.otherDims.tooltip && (a ? u.push(ng("nameValue", { markerType: "subItem", markerColor: r, name: n.displayName, value: t, valueType: n.type })) : (s.push(t), l.push(n.type))) } return i.length ? E(i, (function (t) { h(gf(o, n, t), t) })) : E(t, h), { inlineValues: s, inlineValueTypes: l, blocks: u } }(c, o, a, u, d); e = f.inlineValues, n = f.inlineValueTypes, i = f.blocks, r = f.inlineValues[0] } else if (h) { var g = l.getDimensionInfo(u[0]); r = e = gf(l, a, u[0]), n = g.type } else r = e = p ? c[0] : c; var y = ko(o), v = y && o.name || "", m = l.getName(a), x = s ? v : m; return ng("section", { header: v, noHeader: s || !y, sortParam: r, blocks: [ng("nameValue", { markerType: "item", markerColor: d, name: x, noName: !ut(x), value: e, valueType: n })].concat(i || []) }) } var gg = Oo(); function yg(t, e) { return t.getName(e) || t.getId(e) } var vg = "__universalTransitionEnabled", mg = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e._selectedDataIndicesMap = {}, e } return n(e, t), e.prototype.init = function (t, e, n) { this.seriesIndex = this.componentIndex, this.dataTask = xf({ count: _g, reset: bg }), this.dataTask.context = { model: this }, this.mergeDefaultAndTheme(t, n), (gg(this).sourceManager = new jf(this)).prepareSource(); var i = this.getInitialData(t, n); Sg(i, this), this.dataTask.context.data = i, gg(this).dataBeforeProcessed = i, xg(this), this._initSelectedMapFromData(i) }, e.prototype.mergeDefaultAndTheme = function (t, e) { var n = Ap(this), i = n ? Lp(t) : {}, r = this.subType; Rp.hasClass(r) && (r += "Series"), C(t, e.getTheme().get(this.subType)), C(t, this.getDefaultOption()), wo(t, "label", ["show"]), this.fillDataTextStyle(t.data), n && kp(t, i, n) }, e.prototype.mergeOption = function (t, e) { t = C(this.option, t, !0), this.fillDataTextStyle(t.data); var n = Ap(this); n && kp(this.option, t, n); var i = gg(this).sourceManager; i.dirty(), i.prepareSource(); var r = this.getInitialData(t, e); Sg(r, this), this.dataTask.dirty(), this.dataTask.context.data = r, gg(this).dataBeforeProcessed = r, xg(this), this._initSelectedMapFromData(r) }, e.prototype.fillDataTextStyle = function (t) { if (t && !$(t)) for (var e = ["show"], n = 0; n < t.length; n++)t[n] && t[n].label && wo(t[n], "label", e) }, e.prototype.getInitialData = function (t, e) { }, e.prototype.appendData = function (t) { this.getRawData().appendData(t.data) }, e.prototype.getData = function (t) { var e = Ig(this); if (e) { var n = e.context.data; return null == t ? n : n.getLinkedData(t) } return gg(this).data }, e.prototype.getAllData = function () { var t = this.getData(); return t && t.getLinkedDataAll ? t.getLinkedDataAll() : [{ data: t }] }, e.prototype.setData = function (t) { var e = Ig(this); if (e) { var n = e.context; n.outputData = t, e !== this.dataTask && (n.data = t) } gg(this).data = t }, e.prototype.getEncode = function () { var t = this.get("encode", !0); if (t) return yt(t) }, e.prototype.getSourceManager = function () { return gg(this).sourceManager }, e.prototype.getSource = function () { return this.getSourceManager().getSource() }, e.prototype.getRawData = function () { return gg(this).dataBeforeProcessed }, e.prototype.getColorBy = function () { return this.get("colorBy") || "series" }, e.prototype.isColorBySeries = function () { return "series" === this.getColorBy() }, e.prototype.getBaseAxis = function () { var t = this.coordinateSystem; return t && t.getBaseAxis && t.getBaseAxis() }, e.prototype.formatTooltip = function (t, e, n) { return fg({ series: this, dataIndex: t, multipleSeries: e }) }, e.prototype.isAnimationEnabled = function () { var t = this.ecModel; if (r.node && (!t || !t.ssr)) return !1; var e = this.getShallow("animation"); return e && this.getData().count() > this.getShallow("animationThreshold") && (e = !1), !!e }, e.prototype.restoreData = function () { this.dataTask.dirty() }, e.prototype.getColorFromPalette = function (t, e, n) { var i = this.ecModel, r = ld.prototype.getColorFromPalette.call(this, t, e, n); return r || (r = i.getColorFromPalette(t, e, n)), r }, e.prototype.coordDimToDataDim = function (t) { return this.getRawData().mapDimensionsAll(t) }, e.prototype.getProgressive = function () { return this.get("progressive") }, e.prototype.getProgressiveThreshold = function () { return this.get("progressiveThreshold") }, e.prototype.select = function (t, e) { this._innerSelect(this.getData(e), t) }, e.prototype.unselect = function (t, e) { var n = this.option.selectedMap; if (n) { var i = this.option.selectedMode, r = this.getData(e); if ("series" === i || "all" === n) return this.option.selectedMap = {}, void (this._selectedDataIndicesMap = {}); for (var o = 0; o < t.length; o++) { var a = yg(r, t[o]); n[a] = !1, this._selectedDataIndicesMap[a] = -1 } } }, e.prototype.toggleSelect = function (t, e) { for (var n = [], i = 0; i < t.length; i++)n[0] = t[i], this.isSelected(t[i], e) ? this.unselect(n, e) : this.select(n, e) }, e.prototype.getSelectedDataIndices = function () { if ("all" === this.option.selectedMap) return [].slice.call(this.getData().getIndices()); for (var t = this._selectedDataIndicesMap, e = G(t), n = [], i = 0; i < e.length; i++) { var r = t[e[i]]; r >= 0 && n.push(r) } return n }, e.prototype.isSelected = function (t, e) { var n = this.option.selectedMap; if (!n) return !1; var i = this.getData(e); return ("all" === n || n[yg(i, t)]) && !i.getItemModel(t).get(["select", "disabled"]) }, e.prototype.isUniversalTransitionEnabled = function () { if (this[vg]) return !0; var t = this.option.universalTransition; return !!t && (!0 === t || t && t.enabled) }, e.prototype._innerSelect = function (t, e) { var n, i, r = this.option, o = r.selectedMode, a = e.length; if (o && a) if ("series" === o) r.selectedMap = "all"; else if ("multiple" === o) { q(r.selectedMap) || (r.selectedMap = {}); for (var s = r.selectedMap, l = 0; l < a; l++) { var u = e[l]; s[c = yg(t, u)] = !0, this._selectedDataIndicesMap[c] = t.getRawIndex(u) } } else if ("single" === o || !0 === o) { var h = e[a - 1], c = yg(t, h); r.selectedMap = ((n = {})[c] = !0, n), this._selectedDataIndicesMap = ((i = {})[c] = t.getRawIndex(h), i) } }, e.prototype._initSelectedMapFromData = function (t) { if (!this.option.selectedMap) { var e = []; t.hasItemOption && t.each((function (n) { var i = t.getRawDataItem(n); i && i.selected && e.push(n) })), e.length > 0 && this._innerSelect(t, e) } }, e.registerClass = function (t) { return Rp.registerClass(t) }, e.protoInitialize = function () { var t = e.prototype; t.type = "series.__base__", t.seriesIndex = 0, t.ignoreStyleOnData = !1, t.hasSymbolVisual = !1, t.defaultSymbol = "circle", t.visualStyleAccessPath = "itemStyle", t.visualDrawType = "fill" }(), e }(Rp); function xg(t) { var e = t.name; ko(t) || (t.name = function (t) { var e = t.getRawData(), n = e.mapDimensionsAll("seriesName"), i = []; return E(n, (function (t) { var n = e.getDimensionInfo(t); n.displayName && i.push(n.displayName) })), i.join(" ") }(t) || e) } function _g(t) { return t.model.getRawData().count() } function bg(t) { var e = t.model; return e.setData(e.getRawData().cloneShallow()), wg } function wg(t, e) { e.outputData && t.end > e.outputData.count() && e.model.getRawData().cloneShallow(e.outputData) } function Sg(t, e) { E(vt(t.CHANGABLE_METHODS, t.DOWNSAMPLE_METHODS), (function (n) { t.wrapMethod(n, H(Mg, e)) })) } function Mg(t, e) { var n = Ig(t); return n && n.setOutputEnd((e || this).count()), e } function Ig(t) { var e = (t.ecModel || {}).scheduler, n = e && e.getPipeline(t.uid); if (n) { var i = n.currentTask; if (i) { var r = i.agentStubMap; r && (i = r.get(t.uid)) } return i } } R(mg, vf), R(mg, ld), Zo(mg, Rp); var Tg = function () { function t() { this.group = new zr, this.uid = Tc("viewComponent") } return t.prototype.init = function (t, e) { }, t.prototype.render = function (t, e, n, i) { }, t.prototype.dispose = function (t, e) { }, t.prototype.updateView = function (t, e, n, i) { }, t.prototype.updateLayout = function (t, e, n, i) { }, t.prototype.updateVisual = function (t, e, n, i) { }, t.prototype.toggleBlurSeries = function (t, e, n) { }, t.prototype.eachRendered = function (t) { var e = this.group; e && e.traverse(t) }, t }(); function Cg() { var t = Oo(); return function (e) { var n = t(e), i = e.pipelineContext, r = !!n.large, o = !!n.progressiveRender, a = n.large = !(!i || !i.large), s = n.progressiveRender = !(!i || !i.progressiveRender); return !(r === a && o === s) && "reset" } } Uo(Tg), $o(Tg); var Dg = Oo(), Ag = Cg(), kg = function () { function t() { this.group = new zr, this.uid = Tc("viewChart"), this.renderTask = xf({ plan: Og, reset: Rg }), this.renderTask.context = { view: this } } return t.prototype.init = function (t, e) { }, t.prototype.render = function (t, e, n, i) { 0 }, t.prototype.highlight = function (t, e, n, i) { var r = t.getData(i && i.dataType); r && Pg(r, i, "emphasis") }, t.prototype.downplay = function (t, e, n, i) { var r = t.getData(i && i.dataType); r && Pg(r, i, "normal") }, t.prototype.remove = function (t, e) { this.group.removeAll() }, t.prototype.dispose = function (t, e) { }, t.prototype.updateView = function (t, e, n, i) { this.render(t, e, n, i) }, t.prototype.updateLayout = function (t, e, n, i) { this.render(t, e, n, i) }, t.prototype.updateVisual = function (t, e, n, i) { this.render(t, e, n, i) }, t.prototype.eachRendered = function (t) { qh(this.group, t) }, t.markUpdateMethod = function (t, e) { Dg(t).updateMethod = e }, t.protoInitialize = void (t.prototype.type = "chart"), t }(); function Lg(t, e, n) { t && Kl(t) && ("emphasis" === e ? kl : Ll)(t, n) } function Pg(t, e, n) { var i = Po(t, e), r = e && null != e.highlightKey ? function (t) { var e = nl[t]; return null == e && el <= 32 && (e = nl[t] = el++), e }(e.highlightKey) : null; null != i ? E(bo(i), (function (e) { Lg(t.getItemGraphicEl(e), n, r) })) : t.eachItemGraphicEl((function (t) { Lg(t, n, r) })) } function Og(t) { return Ag(t.model) } function Rg(t) { var e = t.model, n = t.ecModel, i = t.api, r = t.payload, o = e.pipelineContext.progressiveRender, a = t.view, s = r && Dg(r).updateMethod, l = o ? "incrementalPrepareRender" : s && a[s] ? s : "render"; return "render" !== l && a[l](e, n, i, r), Ng[l] } Uo(kg), $o(kg); var Ng = { incrementalPrepareRender: { progress: function (t, e) { e.view.incrementalRender(t, e.model, e.ecModel, e.api, e.payload) } }, render: { forceFirstProgress: !0, progress: function (t, e) { e.view.render(e.model, e.ecModel, e.api, e.payload) } } }, Eg = "\0__throttleOriginMethod", zg = "\0__throttleRate", Vg = "\0__throttleType"; function Bg(t, e, n) { var i, r, o, a, s, l = 0, u = 0, h = null; function c() { u = (new Date).getTime(), h = null, t.apply(o, a || []) } e = e || 0; var p = function () { for (var t = [], p = 0; p < arguments.length; p++)t[p] = arguments[p]; i = (new Date).getTime(), o = this, a = t; var d = s || e, f = s || n; s = null, r = i - (f ? l : u) - d, clearTimeout(h), f ? h = setTimeout(c, d) : r >= 0 ? c() : h = setTimeout(c, -r), l = i }; return p.clear = function () { h && (clearTimeout(h), h = null) }, p.debounceNextCall = function (t) { s = t }, p } function Fg(t, e, n, i) { var r = t[e]; if (r) { var o = r[Eg] || r, a = r[Vg]; if (r[zg] !== n || a !== i) { if (null == n || !i) return t[e] = o; (r = t[e] = Bg(o, n, "debounce" === i))[Eg] = o, r[Vg] = i, r[zg] = n } return r } } function Gg(t, e) { var n = t[e]; n && n[Eg] && (n.clear && n.clear(), t[e] = n[Eg]) } var Wg = Oo(), Hg = { itemStyle: Jo(bc, !0), lineStyle: Jo(mc, !0) }, Yg = { lineStyle: "stroke", itemStyle: "fill" }; function Xg(t, e) { var n = t.visualStyleMapper || Hg[e]; return n || (console.warn("Unknown style type '" + e + "'."), Hg.itemStyle) } function Ug(t, e) { var n = t.visualDrawType || Yg[e]; return n || (console.warn("Unknown style type '" + e + "'."), "fill") } var Zg = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { var n = t.getData(), i = t.visualStyleAccessPath || "itemStyle", r = t.getModel(i), o = Xg(t, i)(r), a = r.getShallow("decal"); a && (n.setVisual("decal", a), a.dirty = !0); var s = Ug(t, i), l = o[s], u = X(l) ? l : null, h = "auto" === o.fill || "auto" === o.stroke; if (!o[s] || u || h) { var c = t.getColorFromPalette(t.name, null, e.getSeriesCount()); o[s] || (o[s] = c, n.setVisual("colorFromPalette", !0)), o.fill = "auto" === o.fill || X(o.fill) ? c : o.fill, o.stroke = "auto" === o.stroke || X(o.stroke) ? c : o.stroke } if (n.setVisual("style", o), n.setVisual("drawType", s), !e.isSeriesFiltered(t) && u) return n.setVisual("colorFromPalette", !1), { dataEach: function (e, n) { var i = t.getDataParams(n), r = A({}, o); r[s] = u(i), e.setItemVisual(n, "style", r) } } } }, jg = new Mc, qg = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { if (!t.ignoreStyleOnData && !e.isSeriesFiltered(t)) { var n = t.getData(), i = t.visualStyleAccessPath || "itemStyle", r = Xg(t, i), o = n.getVisual("drawType"); return { dataEach: n.hasItemOption ? function (t, e) { var n = t.getRawDataItem(e); if (n && n[i]) { jg.option = n[i]; var a = r(jg); A(t.ensureUniqueItemVisual(e, "style"), a), jg.option.decal && (t.setItemVisual(e, "decal", jg.option.decal), jg.option.decal.dirty = !0), o in a && t.setItemVisual(e, "colorFromPalette", !1) } } : null } } } }, Kg = { performRawSeries: !0, overallReset: function (t) { var e = yt(); t.eachSeries((function (t) { var n = t.getColorBy(); if (!t.isColorBySeries()) { var i = t.type + "-" + n, r = e.get(i); r || (r = {}, e.set(i, r)), Wg(t).scope = r } })), t.eachSeries((function (e) { if (!e.isColorBySeries() && !t.isSeriesFiltered(e)) { var n = e.getRawData(), i = {}, r = e.getData(), o = Wg(e).scope, a = e.visualStyleAccessPath || "itemStyle", s = Ug(e, a); r.each((function (t) { var e = r.getRawIndex(t); i[e] = t })), n.each((function (t) { var a = i[t]; if (r.getItemVisual(a, "colorFromPalette")) { var l = r.ensureUniqueItemVisual(a, "style"), u = n.getName(t) || t + "", h = n.count(); l[s] = e.getColorFromPalette(u, o, h) } })) } })) } }, $g = Math.PI; var Jg = function () { function t(t, e, n, i) { this._stageTaskMap = yt(), this.ecInstance = t, this.api = e, n = this._dataProcessorHandlers = n.slice(), i = this._visualHandlers = i.slice(), this._allHandlers = n.concat(i) } return t.prototype.restoreData = function (t, e) { t.restoreData(e), this._stageTaskMap.each((function (t) { var e = t.overallTask; e && e.dirty() })) }, t.prototype.getPerformArgs = function (t, e) { if (t.__pipeline) { var n = this._pipelineMap.get(t.__pipeline.id), i = n.context, r = !e && n.progressiveEnabled && (!i || i.progressiveRender) && t.__idxInPipeline > n.blockIndex ? n.step : null, o = i && i.modDataCount; return { step: r, modBy: null != o ? Math.ceil(o / r) : null, modDataCount: o } } }, t.prototype.getPipeline = function (t) { return this._pipelineMap.get(t) }, t.prototype.updateStreamModes = function (t, e) { var n = this._pipelineMap.get(t.uid), i = t.getData().count(), r = n.progressiveEnabled && e.incrementalPrepareRender && i >= n.threshold, o = t.get("large") && i >= t.get("largeThreshold"), a = "mod" === t.get("progressiveChunkMode") ? i : null; t.pipelineContext = n.context = { progressiveRender: r, modDataCount: a, large: o } }, t.prototype.restorePipelines = function (t) { var e = this, n = e._pipelineMap = yt(); t.eachSeries((function (t) { var i = t.getProgressive(), r = t.uid; n.set(r, { id: r, head: null, tail: null, threshold: t.getProgressiveThreshold(), progressiveEnabled: i && !(t.preventIncremental && t.preventIncremental()), blockIndex: -1, step: Math.round(i || 700), count: 0 }), e._pipe(t, t.dataTask) })) }, t.prototype.prepareStageTasks = function () { var t = this._stageTaskMap, e = this.api.getModel(), n = this.api; E(this._allHandlers, (function (i) { var r = t.get(i.uid) || t.set(i.uid, {}), o = ""; lt(!(i.reset && i.overallReset), o), i.reset && this._createSeriesStageTask(i, r, e, n), i.overallReset && this._createOverallStageTask(i, r, e, n) }), this) }, t.prototype.prepareView = function (t, e, n, i) { var r = t.renderTask, o = r.context; o.model = e, o.ecModel = n, o.api = i, r.__block = !t.incrementalPrepareRender, this._pipe(e, r) }, t.prototype.performDataProcessorTasks = function (t, e) { this._performStageTasks(this._dataProcessorHandlers, t, e, { block: !0 }) }, t.prototype.performVisualTasks = function (t, e, n) { this._performStageTasks(this._visualHandlers, t, e, n) }, t.prototype._performStageTasks = function (t, e, n, i) { i = i || {}; var r = !1, o = this; function a(t, e) { return t.setDirty && (!t.dirtyMap || t.dirtyMap.get(e.__pipeline.id)) } E(t, (function (t, s) { if (!i.visualType || i.visualType === t.visualType) { var l = o._stageTaskMap.get(t.uid), u = l.seriesTaskMap, h = l.overallTask; if (h) { var c, p = h.agentStubMap; p.each((function (t) { a(i, t) && (t.dirty(), c = !0) })), c && h.dirty(), o.updatePayload(h, n); var d = o.getPerformArgs(h, i.block); p.each((function (t) { t.perform(d) })), h.perform(d) && (r = !0) } else u && u.each((function (s, l) { a(i, s) && s.dirty(); var u = o.getPerformArgs(s, i.block); u.skip = !t.performRawSeries && e.isSeriesFiltered(s.context.model), o.updatePayload(s, n), s.perform(u) && (r = !0) })) } })), this.unfinished = r || this.unfinished }, t.prototype.performSeriesTasks = function (t) { var e; t.eachSeries((function (t) { e = t.dataTask.perform() || e })), this.unfinished = e || this.unfinished }, t.prototype.plan = function () { this._pipelineMap.each((function (t) { var e = t.tail; do { if (e.__block) { t.blockIndex = e.__idxInPipeline; break } e = e.getUpstream() } while (e) })) }, t.prototype.updatePayload = function (t, e) { "remain" !== e && (t.context.payload = e) }, t.prototype._createSeriesStageTask = function (t, e, n, i) { var r = this, o = e.seriesTaskMap, a = e.seriesTaskMap = yt(), s = t.seriesType, l = t.getTargetSeries; function u(e) { var s = e.uid, l = a.set(s, o && o.get(s) || xf({ plan: iy, reset: ry, count: sy })); l.context = { model: e, ecModel: n, api: i, useClearVisual: t.isVisual && !t.isLayout, plan: t.plan, reset: t.reset, scheduler: r }, r._pipe(e, l) } t.createOnAllSeries ? n.eachRawSeries(u) : s ? n.eachRawSeriesByType(s, u) : l && l(n, i).each(u) }, t.prototype._createOverallStageTask = function (t, e, n, i) { var r = this, o = e.overallTask = e.overallTask || xf({ reset: Qg }); o.context = { ecModel: n, api: i, overallReset: t.overallReset, scheduler: r }; var a = o.agentStubMap, s = o.agentStubMap = yt(), l = t.seriesType, u = t.getTargetSeries, h = !0, c = !1, p = ""; function d(t) { var e = t.uid, n = s.set(e, a && a.get(e) || (c = !0, xf({ reset: ty, onDirty: ny }))); n.context = { model: t, overallProgress: h }, n.agent = o, n.__block = h, r._pipe(t, n) } lt(!t.createOnAllSeries, p), l ? n.eachRawSeriesByType(l, d) : u ? u(n, i).each(d) : (h = !1, E(n.getSeries(), d)), c && o.dirty() }, t.prototype._pipe = function (t, e) { var n = t.uid, i = this._pipelineMap.get(n); !i.head && (i.head = e), i.tail && i.tail.pipe(e), i.tail = e, e.__idxInPipeline = i.count++, e.__pipeline = i }, t.wrapStageHandler = function (t, e) { return X(t) && (t = { overallReset: t, seriesType: ly(t) }), t.uid = Tc("stageHandler"), e && (t.visualType = e), t }, t }(); function Qg(t) { t.overallReset(t.ecModel, t.api, t.payload) } function ty(t) { return t.overallProgress && ey } function ey() { this.agent.dirty(), this.getDownstream().dirty() } function ny() { this.agent && this.agent.dirty() } function iy(t) { return t.plan ? t.plan(t.model, t.ecModel, t.api, t.payload) : null } function ry(t) { t.useClearVisual && t.data.clearAllVisual(); var e = t.resetDefines = bo(t.reset(t.model, t.ecModel, t.api, t.payload)); return e.length > 1 ? z(e, (function (t, e) { return ay(e) })) : oy } var oy = ay(0); function ay(t) { return function (e, n) { var i = n.data, r = n.resetDefines[t]; if (r && r.dataEach) for (var o = e.start; o < e.end; o++)r.dataEach(i, o); else r && r.progress && r.progress(e, i) } } function sy(t) { return t.data.count() } function ly(t) { uy = null; try { t(hy, cy) } catch (t) { } return uy } var uy, hy = {}, cy = {}; function py(t, e) { for (var n in e.prototype) t[n] = bt } py(hy, pd), py(cy, vd), hy.eachSeriesByType = hy.eachRawSeriesByType = function (t) { uy = t }, hy.eachComponent = function (t) { "series" === t.mainType && t.subType && (uy = t.subType) }; var dy = ["#37A2DA", "#32C5E9", "#67E0E3", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#E062AE", "#E690D1", "#e7bcf3", "#9d96f5", "#8378EA", "#96BFFF"], fy = { color: dy, colorLayer: [["#37A2DA", "#ffd85c", "#fd7b5f"], ["#37A2DA", "#67E0E3", "#FFDB5C", "#ff9f7f", "#E062AE", "#9d96f5"], ["#37A2DA", "#32C5E9", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#e7bcf3", "#8378EA", "#96BFFF"], dy] }, gy = "#B9B8CE", yy = "#100C2A", vy = function () { return { axisLine: { lineStyle: { color: gy } }, splitLine: { lineStyle: { color: "#484753" } }, splitArea: { areaStyle: { color: ["rgba(255,255,255,0.02)", "rgba(255,255,255,0.05)"] } }, minorSplitLine: { lineStyle: { color: "#20203B" } } } }, my = ["#4992ff", "#7cffb2", "#fddd60", "#ff6e76", "#58d9f9", "#05c091", "#ff8a45", "#8d48e3", "#dd79ff"], xy = { darkMode: !0, color: my, backgroundColor: yy, axisPointer: { lineStyle: { color: "#817f91" }, crossStyle: { color: "#817f91" }, label: { color: "#fff" } }, legend: { textStyle: { color: gy } }, textStyle: { color: gy }, title: { textStyle: { color: "#EEF1FA" }, subtextStyle: { color: "#B9B8CE" } }, toolbox: { iconStyle: { borderColor: gy } }, dataZoom: { borderColor: "#71708A", textStyle: { color: gy }, brushStyle: { color: "rgba(135,163,206,0.3)" }, handleStyle: { color: "#353450", borderColor: "#C5CBE3" }, moveHandleStyle: { color: "#B0B6C3", opacity: .3 }, fillerColor: "rgba(135,163,206,0.2)", emphasis: { handleStyle: { borderColor: "#91B7F2", color: "#4D587D" }, moveHandleStyle: { color: "#636D9A", opacity: .7 } }, dataBackground: { lineStyle: { color: "#71708A", width: 1 }, areaStyle: { color: "#71708A" } }, selectedDataBackground: { lineStyle: { color: "#87A3CE" }, areaStyle: { color: "#87A3CE" } } }, visualMap: { textStyle: { color: gy } }, timeline: { lineStyle: { color: gy }, label: { color: gy }, controlStyle: { color: gy, borderColor: gy } }, calendar: { itemStyle: { color: yy }, dayLabel: { color: gy }, monthLabel: { color: gy }, yearLabel: { color: gy } }, timeAxis: vy(), logAxis: vy(), valueAxis: vy(), categoryAxis: vy(), line: { symbol: "circle" }, graph: { color: my }, gauge: { title: { color: gy }, axisLine: { lineStyle: { color: [[1, "rgba(207,212,219,0.2)"]] } }, axisLabel: { color: gy }, detail: { color: "#EEF1FA" } }, candlestick: { itemStyle: { color: "#f64e56", color0: "#54ea92", borderColor: "#f64e56", borderColor0: "#54ea92" } } }; xy.categoryAxis.splitLine.show = !1; var _y = function () { function t() { } return t.prototype.normalizeQuery = function (t) { var e = {}, n = {}, i = {}; if (U(t)) { var r = Xo(t); e.mainType = r.main || null, e.subType = r.sub || null } else { var o = ["Index", "Name", "Id"], a = { name: 1, dataIndex: 1, dataType: 1 }; E(t, (function (t, r) { for (var s = !1, l = 0; l < o.length; l++) { var u = o[l], h = r.lastIndexOf(u); if (h > 0 && h === r.length - u.length) { var c = r.slice(0, h); "data" !== c && (e.mainType = c, e[u.toLowerCase()] = t, s = !0) } } a.hasOwnProperty(r) && (n[r] = t, s = !0), s || (i[r] = t) })) } return { cptQuery: e, dataQuery: n, otherQuery: i } }, t.prototype.filter = function (t, e) { var n = this.eventInfo; if (!n) return !0; var i = n.targetEl, r = n.packedEvent, o = n.model, a = n.view; if (!o || !a) return !0; var s = e.cptQuery, l = e.dataQuery; return u(s, o, "mainType") && u(s, o, "subType") && u(s, o, "index", "componentIndex") && u(s, o, "name") && u(s, o, "id") && u(l, r, "name") && u(l, r, "dataIndex") && u(l, r, "dataType") && (!a.filterForExposedEvent || a.filterForExposedEvent(t, e.otherQuery, i, r)); function u(t, e, n, i) { return null == t[n] || e[i || n] === t[n] } }, t.prototype.afterTrigger = function () { this.eventInfo = null }, t }(), by = ["symbol", "symbolSize", "symbolRotate", "symbolOffset"], wy = by.concat(["symbolKeepAspect"]), Sy = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { var n = t.getData(); if (t.legendIcon && n.setVisual("legendIcon", t.legendIcon), t.hasSymbolVisual) { for (var i = {}, r = {}, o = !1, a = 0; a < by.length; a++) { var s = by[a], l = t.get(s); X(l) ? (o = !0, r[s] = l) : i[s] = l } if (i.symbol = i.symbol || t.defaultSymbol, n.setVisual(A({ legendIcon: t.legendIcon || i.symbol, symbolKeepAspect: t.get("symbolKeepAspect") }, i)), !e.isSeriesFiltered(t)) { var u = G(r); return { dataEach: o ? function (e, n) { for (var i = t.getRawValue(n), o = t.getDataParams(n), a = 0; a < u.length; a++) { var s = u[a]; e.setItemVisual(n, s, r[s](i, o)) } } : null } } } } }, My = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { if (t.hasSymbolVisual && !e.isSeriesFiltered(t)) return { dataEach: t.getData().hasItemOption ? function (t, e) { for (var n = t.getItemModel(e), i = 0; i < wy.length; i++) { var r = wy[i], o = n.getShallow(r, !0); null != o && t.setItemVisual(e, r, o) } } : null } } }; function Iy(t, e, n) { switch (n) { case "color": return t.getItemVisual(e, "style")[t.getVisual("drawType")]; case "opacity": return t.getItemVisual(e, "style").opacity; case "symbol": case "symbolSize": case "liftZ": return t.getItemVisual(e, n) } } function Ty(t, e) { switch (e) { case "color": return t.getVisual("style")[t.getVisual("drawType")]; case "opacity": return t.getVisual("style").opacity; case "symbol": case "symbolSize": case "liftZ": return t.getVisual(e) } } function Cy(t, e, n, i) { switch (n) { case "color": t.ensureUniqueItemVisual(e, "style")[t.getVisual("drawType")] = i, t.setItemVisual(e, "colorFromPalette", !1); break; case "opacity": t.ensureUniqueItemVisual(e, "style").opacity = i; break; case "symbol": case "symbolSize": case "liftZ": t.setItemVisual(e, n, i) } } function Dy(t, e) { function n(e, n) { var i = []; return e.eachComponent({ mainType: "series", subType: t, query: n }, (function (t) { i.push(t.seriesIndex) })), i } E([[t + "ToggleSelect", "toggleSelect"], [t + "Select", "select"], [t + "UnSelect", "unselect"]], (function (t) { e(t[0], (function (e, i, r) { e = A({}, e), r.dispatchAction(A(e, { type: t[1], seriesIndex: n(i, e) })) })) })) } function Ay(t, e, n, i, r) { var o = t + e; n.isSilent(o) || i.eachComponent({ mainType: "series", subType: "pie" }, (function (t) { for (var e = t.seriesIndex, i = t.option.selectedMap, a = r.selected, s = 0; s < a.length; s++)if (a[s].seriesIndex === e) { var l = t.getData(), u = Po(l, r.fromActionPayload); n.trigger(o, { type: o, seriesId: t.id, name: Y(u) ? l.getName(u[0]) : l.getName(u), selected: U(i) ? i : A({}, i) }) } })) } function ky(t, e, n) { for (var i; t && (!e(t) || (i = t, !n));)t = t.__hostTarget || t.parent; return i } var Ly = Math.round(9 * Math.random()), Py = "function" == typeof Object.defineProperty, Oy = function () { function t() { this._id = "__ec_inner_" + Ly++ } return t.prototype.get = function (t) { return this._guard(t)[this._id] }, t.prototype.set = function (t, e) { var n = this._guard(t); return Py ? Object.defineProperty(n, this._id, { value: e, enumerable: !1, configurable: !0 }) : n[this._id] = e, this }, t.prototype.delete = function (t) { return !!this.has(t) && (delete this._guard(t)[this._id], !0) }, t.prototype.has = function (t) { return !!this._guard(t)[this._id] }, t.prototype._guard = function (t) { if (t !== Object(t)) throw TypeError("Value of WeakMap is not a non-null object."); return t }, t }(), Ry = Is.extend({ type: "triangle", shape: { cx: 0, cy: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.cx, i = e.cy, r = e.width / 2, o = e.height / 2; t.moveTo(n, i - o), t.lineTo(n + r, i + o), t.lineTo(n - r, i + o), t.closePath() } }), Ny = Is.extend({ type: "diamond", shape: { cx: 0, cy: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.cx, i = e.cy, r = e.width / 2, o = e.height / 2; t.moveTo(n, i - o), t.lineTo(n + r, i), t.lineTo(n, i + o), t.lineTo(n - r, i), t.closePath() } }), Ey = Is.extend({ type: "pin", shape: { x: 0, y: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.x, i = e.y, r = e.width / 5 * 3, o = Math.max(r, e.height), a = r / 2, s = a * a / (o - a), l = i - o + a + s, u = Math.asin(s / a), h = Math.cos(u) * a, c = Math.sin(u), p = Math.cos(u), d = .6 * a, f = .7 * a; t.moveTo(n - h, l + s), t.arc(n, l, a, Math.PI - u, 2 * Math.PI + u), t.bezierCurveTo(n + h - c * d, l + s + p * d, n, i - f, n, i), t.bezierCurveTo(n, i - f, n - h + c * d, l + s + p * d, n - h, l + s), t.closePath() } }), zy = Is.extend({ type: "arrow", shape: { x: 0, y: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.height, i = e.width, r = e.x, o = e.y, a = i / 3 * 2; t.moveTo(r, o), t.lineTo(r + a, o + n), t.lineTo(r, o + n / 4 * 3), t.lineTo(r - a, o + n), t.lineTo(r, o), t.closePath() } }), Vy = { line: function (t, e, n, i, r) { r.x1 = t, r.y1 = e + i / 2, r.x2 = t + n, r.y2 = e + i / 2 }, rect: function (t, e, n, i, r) { r.x = t, r.y = e, r.width = n, r.height = i }, roundRect: function (t, e, n, i, r) { r.x = t, r.y = e, r.width = n, r.height = i, r.r = Math.min(n, i) / 4 }, square: function (t, e, n, i, r) { var o = Math.min(n, i); r.x = t, r.y = e, r.width = o, r.height = o }, circle: function (t, e, n, i, r) { r.cx = t + n / 2, r.cy = e + i / 2, r.r = Math.min(n, i) / 2 }, diamond: function (t, e, n, i, r) { r.cx = t + n / 2, r.cy = e + i / 2, r.width = n, r.height = i }, pin: function (t, e, n, i, r) { r.x = t + n / 2, r.y = e + i / 2, r.width = n, r.height = i }, arrow: function (t, e, n, i, r) { r.x = t + n / 2, r.y = e + i / 2, r.width = n, r.height = i }, triangle: function (t, e, n, i, r) { r.cx = t + n / 2, r.cy = e + i / 2, r.width = n, r.height = i } }, By = {}; E({ line: Zu, rect: zs, roundRect: zs, square: zs, circle: _u, diamond: Ny, pin: Ey, arrow: zy, triangle: Ry }, (function (t, e) { By[e] = new t })); var Fy = Is.extend({ type: "symbol", shape: { symbolType: "", x: 0, y: 0, width: 0, height: 0 }, calculateTextPosition: function (t, e, n) { var i = Tr(t, e, n), r = this.shape; return r && "pin" === r.symbolType && "inside" === e.position && (i.y = n.y + .4 * n.height), i }, buildPath: function (t, e, n) { var i = e.symbolType; if ("none" !== i) { var r = By[i]; r || (r = By[i = "rect"]), Vy[i](e.x, e.y, e.width, e.height, r.shape), r.buildPath(t, r.shape, n) } } }); function Gy(t, e) { if ("image" !== this.type) { var n = this.style; this.__isEmptyBrush ? (n.stroke = t, n.fill = e || "#fff", n.lineWidth = 2) : "line" === this.shape.symbolType ? n.stroke = t : n.fill = t, this.markRedraw() } } function Wy(t, e, n, i, r, o, a) { var s, l = 0 === t.indexOf("empty"); return l && (t = t.substr(5, 1).toLowerCase() + t.substr(6)), (s = 0 === t.indexOf("image://") ? kh(t.slice(8), new ze(e, n, i, r), a ? "center" : "cover") : 0 === t.indexOf("path://") ? Ah(t.slice(7), {}, new ze(e, n, i, r), a ? "center" : "cover") : new Fy({ shape: { symbolType: t, x: e, y: n, width: i, height: r } })).__isEmptyBrush = l, s.setColor = Gy, o && s.setColor(o), s } function Hy(t) { return Y(t) || (t = [+t, +t]), [t[0] || 0, t[1] || 0] } function Yy(t, e) { if (null != t) return Y(t) || (t = [t, t]), [Ur(t[0], e[0]) || 0, Ur(rt(t[1], t[0]), e[1]) || 0] } function Xy(t) { return isFinite(t) } function Uy(t, e, n) { for (var i = "radial" === e.type ? function (t, e, n) { var i = n.width, r = n.height, o = Math.min(i, r), a = null == e.x ? .5 : e.x, s = null == e.y ? .5 : e.y, l = null == e.r ? .5 : e.r; return e.global || (a = a * i + n.x, s = s * r + n.y, l *= o), a = Xy(a) ? a : .5, s = Xy(s) ? s : .5, l = l >= 0 && Xy(l) ? l : .5, t.createRadialGradient(a, s, 0, a, s, l) }(t, e, n) : function (t, e, n) { var i = null == e.x ? 0 : e.x, r = null == e.x2 ? 1 : e.x2, o = null == e.y ? 0 : e.y, a = null == e.y2 ? 0 : e.y2; return e.global || (i = i * n.width + n.x, r = r * n.width + n.x, o = o * n.height + n.y, a = a * n.height + n.y), i = Xy(i) ? i : 0, r = Xy(r) ? r : 1, o = Xy(o) ? o : 0, a = Xy(a) ? a : 0, t.createLinearGradient(i, o, r, a) }(t, e, n), r = e.colorStops, o = 0; o < r.length; o++)i.addColorStop(r[o].offset, r[o].color); return i } function Zy(t) { return parseInt(t, 10) } function jy(t, e, n) { var i = ["width", "height"][e], r = ["clientWidth", "clientHeight"][e], o = ["paddingLeft", "paddingTop"][e], a = ["paddingRight", "paddingBottom"][e]; if (null != n[i] && "auto" !== n[i]) return parseFloat(n[i]); var s = document.defaultView.getComputedStyle(t); return (t[r] || Zy(s[i]) || Zy(t.style[i])) - (Zy(s[o]) || 0) - (Zy(s[a]) || 0) | 0 } function qy(t) { var e, n, i = t.style, r = i.lineDash && i.lineWidth > 0 && (e = i.lineDash, n = i.lineWidth, e && "solid" !== e && n > 0 ? "dashed" === e ? [4 * n, 2 * n] : "dotted" === e ? [n] : j(e) ? [e] : Y(e) ? e : null : null), o = i.lineDashOffset; if (r) { var a = i.strokeNoScale && t.getLineScale ? t.getLineScale() : 1; a && 1 !== a && (r = z(r, (function (t) { return t / a })), o /= a) } return [r, o] } var Ky = new os(!0); function $y(t) { var e = t.stroke; return !(null == e || "none" === e || !(t.lineWidth > 0)) } function Jy(t) { return "string" == typeof t && "none" !== t } function Qy(t) { var e = t.fill; return null != e && "none" !== e } function tv(t, e) { if (null != e.fillOpacity && 1 !== e.fillOpacity) { var n = t.globalAlpha; t.globalAlpha = e.fillOpacity * e.opacity, t.fill(), t.globalAlpha = n } else t.fill() } function ev(t, e) { if (null != e.strokeOpacity && 1 !== e.strokeOpacity) { var n = t.globalAlpha; t.globalAlpha = e.strokeOpacity * e.opacity, t.stroke(), t.globalAlpha = n } else t.stroke() } function nv(t, e, n) { var i = ia(e.image, e.__image, n); if (oa(i)) { var r = t.createPattern(i, e.repeat || "repeat"); if ("function" == typeof DOMMatrix && r && r.setTransform) { var o = new DOMMatrix; o.translateSelf(e.x || 0, e.y || 0), o.rotateSelf(0, 0, (e.rotation || 0) * wt), o.scaleSelf(e.scaleX || 1, e.scaleY || 1), r.setTransform(o) } return r } } var iv = ["shadowBlur", "shadowOffsetX", "shadowOffsetY"], rv = [["lineCap", "butt"], ["lineJoin", "miter"], ["miterLimit", 10]]; function ov(t, e, n, i, r) { var o = !1; if (!i && e === (n = n || {})) return !1; if (i || e.opacity !== n.opacity) { lv(t, r), o = !0; var a = Math.max(Math.min(e.opacity, 1), 0); t.globalAlpha = isNaN(a) ? xa.opacity : a } (i || e.blend !== n.blend) && (o || (lv(t, r), o = !0), t.globalCompositeOperation = e.blend || xa.blend); for (var s = 0; s < iv.length; s++) { var l = iv[s]; (i || e[l] !== n[l]) && (o || (lv(t, r), o = !0), t[l] = t.dpr * (e[l] || 0)) } return (i || e.shadowColor !== n.shadowColor) && (o || (lv(t, r), o = !0), t.shadowColor = e.shadowColor || xa.shadowColor), o } function av(t, e, n, i, r) { var o = uv(e, r.inHover), a = i ? null : n && uv(n, r.inHover) || {}; if (o === a) return !1; var s = ov(t, o, a, i, r); if ((i || o.fill !== a.fill) && (s || (lv(t, r), s = !0), Jy(o.fill) && (t.fillStyle = o.fill)), (i || o.stroke !== a.stroke) && (s || (lv(t, r), s = !0), Jy(o.stroke) && (t.strokeStyle = o.stroke)), (i || o.opacity !== a.opacity) && (s || (lv(t, r), s = !0), t.globalAlpha = null == o.opacity ? 1 : o.opacity), e.hasStroke()) { var l = o.lineWidth / (o.strokeNoScale && e.getLineScale ? e.getLineScale() : 1); t.lineWidth !== l && (s || (lv(t, r), s = !0), t.lineWidth = l) } for (var u = 0; u < rv.length; u++) { var h = rv[u], c = h[0]; (i || o[c] !== a[c]) && (s || (lv(t, r), s = !0), t[c] = o[c] || h[1]) } return s } function sv(t, e) { var n = e.transform, i = t.dpr || 1; n ? t.setTransform(i * n[0], i * n[1], i * n[2], i * n[3], i * n[4], i * n[5]) : t.setTransform(i, 0, 0, i, 0, 0) } function lv(t, e) { e.batchFill && t.fill(), e.batchStroke && t.stroke(), e.batchFill = "", e.batchStroke = "" } function uv(t, e) { return e && t.__hoverStyle || t.style } function hv(t, e) { cv(t, e, { inHover: !1, viewWidth: 0, viewHeight: 0 }, !0) } function cv(t, e, n, i) { var r = e.transform; if (!e.shouldBePainted(n.viewWidth, n.viewHeight, !1, !1)) return e.__dirty &= -2, void (e.__isRendered = !1); var o = e.__clipPaths, s = n.prevElClipPaths, l = !1, u = !1; if (s && !function (t, e) { if (t === e || !t && !e) return !1; if (!t || !e || t.length !== e.length) return !0; for (var n = 0; n < t.length; n++)if (t[n] !== e[n]) return !0; return !1 }(o, s) || (s && s.length && (lv(t, n), t.restore(), u = l = !0, n.prevElClipPaths = null, n.allClipped = !1, n.prevEl = null), o && o.length && (lv(t, n), t.save(), function (t, e, n) { for (var i = !1, r = 0; r < t.length; r++) { var o = t[r]; i = i || o.isZeroArea(), sv(e, o), e.beginPath(), o.buildPath(e, o.shape), e.clip() } n.allClipped = i }(o, t, n), l = !0), n.prevElClipPaths = o), n.allClipped) e.__isRendered = !1; else { e.beforeBrush && e.beforeBrush(), e.innerBeforeBrush(); var h = n.prevEl; h || (u = l = !0); var c, p, d = e instanceof Is && e.autoBatch && function (t) { var e = Qy(t), n = $y(t); return !(t.lineDash || !(+e ^ +n) || e && "string" != typeof t.fill || n && "string" != typeof t.stroke || t.strokePercent < 1 || t.strokeOpacity < 1 || t.fillOpacity < 1) }(e.style); l || (c = r, p = h.transform, c && p ? c[0] !== p[0] || c[1] !== p[1] || c[2] !== p[2] || c[3] !== p[3] || c[4] !== p[4] || c[5] !== p[5] : c || p) ? (lv(t, n), sv(t, e)) : d || lv(t, n); var f = uv(e, n.inHover); e instanceof Is ? (1 !== n.lastDrawType && (u = !0, n.lastDrawType = 1), av(t, e, h, u, n), d && (n.batchFill || n.batchStroke) || t.beginPath(), function (t, e, n, i) { var r, o = $y(n), a = Qy(n), s = n.strokePercent, l = s < 1, u = !e.path; e.silent && !l || !u || e.createPathProxy(); var h = e.path || Ky, c = e.__dirty; if (!i) { var p = n.fill, d = n.stroke, f = a && !!p.colorStops, g = o && !!d.colorStops, y = a && !!p.image, v = o && !!d.image, m = void 0, x = void 0, _ = void 0, b = void 0, w = void 0; (f || g) && (w = e.getBoundingRect()), f && (m = c ? Uy(t, p, w) : e.__canvasFillGradient, e.__canvasFillGradient = m), g && (x = c ? Uy(t, d, w) : e.__canvasStrokeGradient, e.__canvasStrokeGradient = x), y && (_ = c || !e.__canvasFillPattern ? nv(t, p, e) : e.__canvasFillPattern, e.__canvasFillPattern = _), v && (b = c || !e.__canvasStrokePattern ? nv(t, d, e) : e.__canvasStrokePattern, e.__canvasStrokePattern = _), f ? t.fillStyle = m : y && (_ ? t.fillStyle = _ : a = !1), g ? t.strokeStyle = x : v && (b ? t.strokeStyle = b : o = !1) } var S, M, I = e.getGlobalScale(); h.setScale(I[0], I[1], e.segmentIgnoreThreshold), t.setLineDash && n.lineDash && (S = (r = qy(e))[0], M = r[1]); var T = !0; (u || 4 & c) && (h.setDPR(t.dpr), l ? h.setContext(null) : (h.setContext(t), T = !1), h.reset(), e.buildPath(h, e.shape, i), h.toStatic(), e.pathUpdated()), T && h.rebuildPath(t, l ? s : 1), S && (t.setLineDash(S), t.lineDashOffset = M), i || (n.strokeFirst ? (o && ev(t, n), a && tv(t, n)) : (a && tv(t, n), o && ev(t, n))), S && t.setLineDash([]) }(t, e, f, d), d && (n.batchFill = f.fill || "", n.batchStroke = f.stroke || "")) : e instanceof Cs ? (3 !== n.lastDrawType && (u = !0, n.lastDrawType = 3), av(t, e, h, u, n), function (t, e, n) { var i, r = n.text; if (null != r && (r += ""), r) { t.font = n.font || a, t.textAlign = n.textAlign, t.textBaseline = n.textBaseline; var o = void 0, s = void 0; t.setLineDash && n.lineDash && (o = (i = qy(e))[0], s = i[1]), o && (t.setLineDash(o), t.lineDashOffset = s), n.strokeFirst ? ($y(n) && t.strokeText(r, n.x, n.y), Qy(n) && t.fillText(r, n.x, n.y)) : (Qy(n) && t.fillText(r, n.x, n.y), $y(n) && t.strokeText(r, n.x, n.y)), o && t.setLineDash([]) } }(t, e, f)) : e instanceof ks ? (2 !== n.lastDrawType && (u = !0, n.lastDrawType = 2), function (t, e, n, i, r) { ov(t, uv(e, r.inHover), n && uv(n, r.inHover), i, r) }(t, e, h, u, n), function (t, e, n) { var i = e.__image = ia(n.image, e.__image, e, e.onload); if (i && oa(i)) { var r = n.x || 0, o = n.y || 0, a = e.getWidth(), s = e.getHeight(), l = i.width / i.height; if (null == a && null != s ? a = s * l : null == s && null != a ? s = a / l : null == a && null == s && (a = i.width, s = i.height), n.sWidth && n.sHeight) { var u = n.sx || 0, h = n.sy || 0; t.drawImage(i, u, h, n.sWidth, n.sHeight, r, o, a, s) } else if (n.sx && n.sy) { var c = a - (u = n.sx), p = s - (h = n.sy); t.drawImage(i, u, h, c, p, r, o, a, s) } else t.drawImage(i, r, o, a, s) } }(t, e, f)) : e.getTemporalDisplayables && (4 !== n.lastDrawType && (u = !0, n.lastDrawType = 4), function (t, e, n) { var i = e.getDisplayables(), r = e.getTemporalDisplayables(); t.save(); var o, a, s = { prevElClipPaths: null, prevEl: null, allClipped: !1, viewWidth: n.viewWidth, viewHeight: n.viewHeight, inHover: n.inHover }; for (o = e.getCursor(), a = i.length; o < a; o++) { (h = i[o]).beforeBrush && h.beforeBrush(), h.innerBeforeBrush(), cv(t, h, s, o === a - 1), h.innerAfterBrush(), h.afterBrush && h.afterBrush(), s.prevEl = h } for (var l = 0, u = r.length; l < u; l++) { var h; (h = r[l]).beforeBrush && h.beforeBrush(), h.innerBeforeBrush(), cv(t, h, s, l === u - 1), h.innerAfterBrush(), h.afterBrush && h.afterBrush(), s.prevEl = h } e.clearTemporalDisplayables(), e.notClear = !0, t.restore() }(t, e, n)), d && i && lv(t, n), e.innerAfterBrush(), e.afterBrush && e.afterBrush(), n.prevEl = e, e.__dirty = 0, e.__isRendered = !0 } } var pv = new Oy, dv = new En(100), fv = ["symbol", "symbolSize", "symbolKeepAspect", "color", "backgroundColor", "dashArrayX", "dashArrayY", "maxTileWidth", "maxTileHeight"]; function gv(t, e) { if ("none" === t) return null; var n = e.getDevicePixelRatio(), i = e.getZr(), r = "svg" === i.painter.type; t.dirty && pv.delete(t); var o = pv.get(t); if (o) return o; var a = k(t, { symbol: "rect", symbolSize: 1, symbolKeepAspect: !0, color: "rgba(0, 0, 0, 0.2)", backgroundColor: null, dashArrayX: 5, dashArrayY: 5, rotation: 0, maxTileWidth: 512, maxTileHeight: 512 }); "none" === a.backgroundColor && (a.backgroundColor = null); var s = { repeat: "repeat" }; return function (t) { for (var e, o = [n], s = !0, l = 0; l < fv.length; ++l) { var u = a[fv[l]]; if (null != u && !Y(u) && !U(u) && !j(u) && "boolean" != typeof u) { s = !1; break } o.push(u) } if (s) { e = o.join(",") + (r ? "-svg" : ""); var c = dv.get(e); c && (r ? t.svgElement = c : t.image = c) } var p, d = vv(a.dashArrayX), f = function (t) { if (!t || "object" == typeof t && 0 === t.length) return [0, 0]; if (j(t)) { var e = Math.ceil(t); return [e, e] } var n = z(t, (function (t) { return Math.ceil(t) })); return t.length % 2 ? n.concat(n) : n }(a.dashArrayY), g = yv(a.symbol), y = (b = d, z(b, (function (t) { return mv(t) }))), v = mv(f), m = !r && h.createCanvas(), x = r && { tag: "g", attrs: {}, key: "dcl", children: [] }, _ = function () { for (var t = 1, e = 0, n = y.length; e < n; ++e)t = go(t, y[e]); var i = 1; for (e = 0, n = g.length; e < n; ++e)i = go(i, g[e].length); t *= i; var r = v * y.length * g.length; return { width: Math.max(1, Math.min(t, a.maxTileWidth)), height: Math.max(1, Math.min(r, a.maxTileHeight)) } }(); var b; m && (m.width = _.width * n, m.height = _.height * n, p = m.getContext("2d")); (function () { p && (p.clearRect(0, 0, m.width, m.height), a.backgroundColor && (p.fillStyle = a.backgroundColor, p.fillRect(0, 0, m.width, m.height))); for (var t = 0, e = 0; e < f.length; ++e)t += f[e]; if (t <= 0) return; var o = -v, s = 0, l = 0, u = 0; for (; o < _.height;) { if (s % 2 == 0) { for (var h = l / 2 % g.length, c = 0, y = 0, b = 0; c < 2 * _.width;) { var w = 0; for (e = 0; e < d[u].length; ++e)w += d[u][e]; if (w <= 0) break; if (y % 2 == 0) { var S = .5 * (1 - a.symbolSize), M = c + d[u][y] * S, I = o + f[s] * S, T = d[u][y] * a.symbolSize, C = f[s] * a.symbolSize, D = b / 2 % g[h].length; A(M, I, T, C, g[h][D]) } c += d[u][y], ++b, ++y === d[u].length && (y = 0) } ++u === d.length && (u = 0) } o += f[s], ++l, ++s === f.length && (s = 0) } function A(t, e, o, s, l) { var u = r ? 1 : n, h = Wy(l, t * u, e * u, o * u, s * u, a.color, a.symbolKeepAspect); if (r) { var c = i.painter.renderOneToVNode(h); c && x.children.push(c) } else hv(p, h) } })(), s && dv.put(e, m || x); t.image = m, t.svgElement = x, t.svgWidth = _.width, t.svgHeight = _.height }(s), s.rotation = a.rotation, s.scaleX = s.scaleY = r ? 1 : 1 / n, pv.set(t, s), t.dirty = !1, s } function yv(t) { if (!t || 0 === t.length) return [["rect"]]; if (U(t)) return [[t]]; for (var e = !0, n = 0; n < t.length; ++n)if (!U(t[n])) { e = !1; break } if (e) return yv([t]); var i = []; for (n = 0; n < t.length; ++n)U(t[n]) ? i.push([t[n]]) : i.push(t[n]); return i } function vv(t) { if (!t || 0 === t.length) return [[0, 0]]; if (j(t)) return [[r = Math.ceil(t), r]]; for (var e = !0, n = 0; n < t.length; ++n)if (!j(t[n])) { e = !1; break } if (e) return vv([t]); var i = []; for (n = 0; n < t.length; ++n)if (j(t[n])) { var r = Math.ceil(t[n]); i.push([r, r]) } else { (r = z(t[n], (function (t) { return Math.ceil(t) }))).length % 2 == 1 ? i.push(r.concat(r)) : i.push(r) } return i } function mv(t) { for (var e = 0, n = 0; n < t.length; ++n)e += t[n]; return t.length % 2 == 1 ? 2 * e : e } var xv = new jt, _v = {}; function bv(t) { return _v[t] } var wv = 2e3, Sv = 4500, Mv = { PROCESSOR: { FILTER: 1e3, SERIES_FILTER: 800, STATISTIC: 5e3 }, VISUAL: { LAYOUT: 1e3, PROGRESSIVE_LAYOUT: 1100, GLOBAL: wv, CHART: 3e3, POST_CHART_LAYOUT: 4600, COMPONENT: 4e3, BRUSH: 5e3, CHART_ITEM: Sv, ARIA: 6e3, DECAL: 7e3 } }, Iv = "__flagInMainProcess", Tv = "__pendingUpdate", Cv = "__needsUpdateStatus", Dv = /^[a-zA-Z0-9_]+$/, Av = "__connectUpdateStatus"; function kv(t) { return function () { for (var e = [], n = 0; n < arguments.length; n++)e[n] = arguments[n]; if (!this.isDisposed()) return Pv(this, t, e); nm(this.id) } } function Lv(t) { return function () { for (var e = [], n = 0; n < arguments.length; n++)e[n] = arguments[n]; return Pv(this, t, e) } } function Pv(t, e, n) { return n[0] = n[0] && n[0].toLowerCase(), jt.prototype[e].apply(t, n) } var Ov, Rv, Nv, Ev, zv, Vv, Bv, Fv, Gv, Wv, Hv, Yv, Xv, Uv, Zv, jv, qv, Kv, $v = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e }(jt), Jv = $v.prototype; Jv.on = Lv("on"), Jv.off = Lv("off"); var Qv = function (t) { function e(e, n, i) { var r = t.call(this, new _y) || this; r._chartsViews = [], r._chartsMap = {}, r._componentsViews = [], r._componentsMap = {}, r._pendingActions = [], i = i || {}, U(n) && (n = lm[n]), r._dom = e; var o = "canvas", a = "auto", s = !1, l = r._zr = Gr(e, { renderer: i.renderer || o, devicePixelRatio: i.devicePixelRatio, width: i.width, height: i.height, ssr: i.ssr, useDirtyRect: rt(i.useDirtyRect, s), useCoarsePointer: rt(i.useCoarsePointer, a), pointerSize: i.pointerSize }); r._ssr = i.ssr, r._throttledZrFlush = Bg(W(l.flush, l), 17), (n = T(n)) && Wd(n, !0), r._theme = n, r._locale = function (t) { if (U(t)) { var e = Lc[t.toUpperCase()] || {}; return t === Dc || t === Ac ? T(e) : C(T(e), T(Lc[kc]), !1) } return C(T(t), T(Lc[kc]), !1) }(i.locale || Oc), r._coordSysMgr = new xd; var u = r._api = Zv(r); function h(t, e) { return t.__prio - e.__prio } return Qe(sm, h), Qe(om, h), r._scheduler = new Jg(r, u, om, sm), r._messageCenter = new $v, r._initEvents(), r.resize = W(r.resize, r), l.animation.on("frame", r._onframe, r), Wv(l, r), Hv(l, r), ct(r), r } return n(e, t), e.prototype._onframe = function () { if (!this._disposed) { Kv(this); var t = this._scheduler; if (this[Tv]) { var e = this[Tv].silent; this[Iv] = !0; try { Ov(this), Ev.update.call(this, null, this[Tv].updateParams) } catch (t) { throw this[Iv] = !1, this[Tv] = null, t } this._zr.flush(), this[Iv] = !1, this[Tv] = null, Fv.call(this, e), Gv.call(this, e) } else if (t.unfinished) { var n = 1, i = this._model, r = this._api; t.unfinished = !1; do { var o = +new Date; t.performSeriesTasks(i), t.performDataProcessorTasks(i), Vv(this, i), t.performVisualTasks(i), Uv(this, this._model, r, "remain", {}), n -= +new Date - o } while (n > 0 && t.unfinished); t.unfinished || this._zr.flush() } } }, e.prototype.getDom = function () { return this._dom }, e.prototype.getId = function () { return this.id }, e.prototype.getZr = function () { return this._zr }, e.prototype.isSSR = function () { return this._ssr }, e.prototype.setOption = function (t, e, n) { if (!this[Iv]) if (this._disposed) nm(this.id); else { var i, r, o; if (q(e) && (n = e.lazyUpdate, i = e.silent, r = e.replaceMerge, o = e.transition, e = e.notMerge), this[Iv] = !0, !this._model || e) { var a = new bd(this._api), s = this._theme, l = this._model = new pd; l.scheduler = this._scheduler, l.ssr = this._ssr, l.init(null, null, null, s, this._locale, a) } this._model.setOption(t, { replaceMerge: r }, am); var u = { seriesTransition: o, optionChanged: !0 }; if (n) this[Tv] = { silent: i, updateParams: u }, this[Iv] = !1, this.getZr().wakeUp(); else { try { Ov(this), Ev.update.call(this, null, u) } catch (t) { throw this[Tv] = null, this[Iv] = !1, t } this._ssr || this._zr.flush(), this[Tv] = null, this[Iv] = !1, Fv.call(this, i), Gv.call(this, i) } } }, e.prototype.setTheme = function () { yo() }, e.prototype.getModel = function () { return this._model }, e.prototype.getOption = function () { return this._model && this._model.getOption() }, e.prototype.getWidth = function () { return this._zr.getWidth() }, e.prototype.getHeight = function () { return this._zr.getHeight() }, e.prototype.getDevicePixelRatio = function () { return this._zr.painter.dpr || r.hasGlobalWindow && window.devicePixelRatio || 1 }, e.prototype.getRenderedCanvas = function (t) { return this.renderToCanvas(t) }, e.prototype.renderToCanvas = function (t) { t = t || {}; var e = this._zr.painter; return e.getRenderedCanvas({ backgroundColor: t.backgroundColor || this._model.get("backgroundColor"), pixelRatio: t.pixelRatio || this.getDevicePixelRatio() }) }, e.prototype.renderToSVGString = function (t) { t = t || {}; var e = this._zr.painter; return e.renderToString({ useViewBox: t.useViewBox }) }, e.prototype.getSvgDataURL = function () { if (r.svgSupported) { var t = this._zr; return E(t.storage.getDisplayList(), (function (t) { t.stopAnimation(null, !0) })), t.painter.toDataURL() } }, e.prototype.getDataURL = function (t) { if (!this._disposed) { var e = (t = t || {}).excludeComponents, n = this._model, i = [], r = this; E(e, (function (t) { n.eachComponent({ mainType: t }, (function (t) { var e = r._componentsMap[t.__viewId]; e.group.ignore || (i.push(e), e.group.ignore = !0) })) })); var o = "svg" === this._zr.painter.getType() ? this.getSvgDataURL() : this.renderToCanvas(t).toDataURL("image/" + (t && t.type || "png")); return E(i, (function (t) { t.group.ignore = !1 })), o } nm(this.id) }, e.prototype.getConnectedDataURL = function (t) { if (!this._disposed) { var e = "svg" === t.type, n = this.group, i = Math.min, r = Math.max, o = 1 / 0; if (cm[n]) { var a = o, s = o, l = -1 / 0, u = -1 / 0, c = [], p = t && t.pixelRatio || this.getDevicePixelRatio(); E(hm, (function (o, h) { if (o.group === n) { var p = e ? o.getZr().painter.getSvgDom().innerHTML : o.renderToCanvas(T(t)), d = o.getDom().getBoundingClientRect(); a = i(d.left, a), s = i(d.top, s), l = r(d.right, l), u = r(d.bottom, u), c.push({ dom: p, left: d.left, top: d.top }) } })); var d = (l *= p) - (a *= p), f = (u *= p) - (s *= p), g = h.createCanvas(), y = Gr(g, { renderer: e ? "svg" : "canvas" }); if (y.resize({ width: d, height: f }), e) { var v = ""; return E(c, (function (t) { var e = t.left - a, n = t.top - s; v += '<g transform="translate(' + e + "," + n + ')">' + t.dom + "</g>" })), y.painter.getSvgRoot().innerHTML = v, t.connectedBackgroundColor && y.painter.setBackgroundColor(t.connectedBackgroundColor), y.refreshImmediately(), y.painter.toDataURL() } return t.connectedBackgroundColor && y.add(new zs({ shape: { x: 0, y: 0, width: d, height: f }, style: { fill: t.connectedBackgroundColor } })), E(c, (function (t) { var e = new ks({ style: { x: t.left * p - a, y: t.top * p - s, image: t.dom } }); y.add(e) })), y.refreshImmediately(), g.toDataURL("image/" + (t && t.type || "png")) } return this.getDataURL(t) } nm(this.id) }, e.prototype.convertToPixel = function (t, e) { return zv(this, "convertToPixel", t, e) }, e.prototype.convertFromPixel = function (t, e) { return zv(this, "convertFromPixel", t, e) }, e.prototype.containPixel = function (t, e) { var n; if (!this._disposed) return E(No(this._model, t), (function (t, i) { i.indexOf("Models") >= 0 && E(t, (function (t) { var r = t.coordinateSystem; if (r && r.containPoint) n = n || !!r.containPoint(e); else if ("seriesModels" === i) { var o = this._chartsMap[t.__viewId]; o && o.containPoint && (n = n || o.containPoint(e, t)) } else 0 }), this) }), this), !!n; nm(this.id) }, e.prototype.getVisual = function (t, e) { var n = No(this._model, t, { defaultMainType: "series" }), i = n.seriesModel; var r = i.getData(), o = n.hasOwnProperty("dataIndexInside") ? n.dataIndexInside : n.hasOwnProperty("dataIndex") ? r.indexOfRawIndex(n.dataIndex) : null; return null != o ? Iy(r, o, e) : Ty(r, e) }, e.prototype.getViewOfComponentModel = function (t) { return this._componentsMap[t.__viewId] }, e.prototype.getViewOfSeriesModel = function (t) { return this._chartsMap[t.__viewId] }, e.prototype._initEvents = function () { var t, e, n, i = this; E(em, (function (t) { var e = function (e) { var n, r = i.getModel(), o = e.target, a = "globalout" === t; if (a ? n = {} : o && ky(o, (function (t) { var e = Qs(t); if (e && null != e.dataIndex) { var i = e.dataModel || r.getSeriesByIndex(e.seriesIndex); return n = i && i.getDataParams(e.dataIndex, e.dataType, o) || {}, !0 } if (e.eventData) return n = A({}, e.eventData), !0 }), !0), n) { var s = n.componentType, l = n.componentIndex; "markLine" !== s && "markPoint" !== s && "markArea" !== s || (s = "series", l = n.seriesIndex); var u = s && null != l && r.getComponent(s, l), h = u && i["series" === u.mainType ? "_chartsMap" : "_componentsMap"][u.__viewId]; 0, n.event = e, n.type = t, i._$eventProcessor.eventInfo = { targetEl: o, packedEvent: n, model: u, view: h }, i.trigger(t, n) } }; e.zrEventfulCallAtLast = !0, i._zr.on(t, e, i) })), E(rm, (function (t, e) { i._messageCenter.on(e, (function (t) { this.trigger(e, t) }), i) })), E(["selectchanged"], (function (t) { i._messageCenter.on(t, (function (e) { this.trigger(t, e) }), i) })), t = this._messageCenter, e = this, n = this._api, t.on("selectchanged", (function (t) { var i = n.getModel(); t.isFromClick ? (Ay("map", "selectchanged", e, i, t), Ay("pie", "selectchanged", e, i, t)) : "select" === t.fromAction ? (Ay("map", "selected", e, i, t), Ay("pie", "selected", e, i, t)) : "unselect" === t.fromAction && (Ay("map", "unselected", e, i, t), Ay("pie", "unselected", e, i, t)) })) }, e.prototype.isDisposed = function () { return this._disposed }, e.prototype.clear = function () { this._disposed ? nm(this.id) : this.setOption({ series: [] }, !0) }, e.prototype.dispose = function () { if (this._disposed) nm(this.id); else { this._disposed = !0, this.getDom() && Fo(this.getDom(), fm, ""); var t = this, e = t._api, n = t._model; E(t._componentsViews, (function (t) { t.dispose(n, e) })), E(t._chartsViews, (function (t) { t.dispose(n, e) })), t._zr.dispose(), t._dom = t._model = t._chartsMap = t._componentsMap = t._chartsViews = t._componentsViews = t._scheduler = t._api = t._zr = t._throttledZrFlush = t._theme = t._coordSysMgr = t._messageCenter = null, delete hm[t.id] } }, e.prototype.resize = function (t) { if (!this[Iv]) if (this._disposed) nm(this.id); else { this._zr.resize(t); var e = this._model; if (this._loadingFX && this._loadingFX.resize(), e) { var n = e.resetOption("media"), i = t && t.silent; this[Tv] && (null == i && (i = this[Tv].silent), n = !0, this[Tv] = null), this[Iv] = !0; try { n && Ov(this), Ev.update.call(this, { type: "resize", animation: A({ duration: 0 }, t && t.animation) }) } catch (t) { throw this[Iv] = !1, t } this[Iv] = !1, Fv.call(this, i), Gv.call(this, i) } } }, e.prototype.showLoading = function (t, e) { if (this._disposed) nm(this.id); else if (q(t) && (e = t, t = ""), t = t || "default", this.hideLoading(), um[t]) { var n = um[t](this._api, e), i = this._zr; this._loadingFX = n, i.add(n) } }, e.prototype.hideLoading = function () { this._disposed ? nm(this.id) : (this._loadingFX && this._zr.remove(this._loadingFX), this._loadingFX = null) }, e.prototype.makeActionFromEvent = function (t) { var e = A({}, t); return e.type = rm[t.type], e }, e.prototype.dispatchAction = function (t, e) { if (this._disposed) nm(this.id); else if (q(e) || (e = { silent: !!e }), im[t.type] && this._model) if (this[Iv]) this._pendingActions.push(t); else { var n = e.silent; Bv.call(this, t, n); var i = e.flush; i ? this._zr.flush() : !1 !== i && r.browser.weChat && this._throttledZrFlush(), Fv.call(this, n), Gv.call(this, n) } }, e.prototype.updateLabelLayout = function () { xv.trigger("series:layoutlabels", this._model, this._api, { updatedSeries: [] }) }, e.prototype.appendData = function (t) { if (this._disposed) nm(this.id); else { var e = t.seriesIndex, n = this.getModel().getSeriesByIndex(e); 0, n.appendData(t), this._scheduler.unfinished = !0, this.getZr().wakeUp() } }, e.internalField = function () { function t(t) { t.clearColorPalette(), t.eachSeries((function (t) { t.clearColorPalette() })) } function e(t) { for (var e = [], n = t.currentStates, i = 0; i < n.length; i++) { var r = n[i]; "emphasis" !== r && "blur" !== r && "select" !== r && e.push(r) } t.selected && t.states.select && e.push("select"), 2 === t.hoverState && t.states.emphasis ? e.push("emphasis") : 1 === t.hoverState && t.states.blur && e.push("blur"), t.useStates(e) } function i(t, e) { if (!t.preventAutoZ) { var n = t.get("z") || 0, i = t.get("zlevel") || 0; e.eachRendered((function (t) { return o(t, n, i, -1 / 0), !0 })) } } function o(t, e, n, i) { var r = t.getTextContent(), a = t.getTextGuideLine(); if (t.isGroup) for (var s = t.childrenRef(), l = 0; l < s.length; l++)i = Math.max(o(s[l], e, n, i), i); else t.z = e, t.zlevel = n, i = Math.max(t.z2, i); if (r && (r.z = e, r.zlevel = n, isFinite(i) && (r.z2 = i + 2)), a) { var u = t.textGuideLineConfig; a.z = e, a.zlevel = n, isFinite(i) && (a.z2 = i + (u && u.showAbove ? 1 : -1)) } return i } function a(t, e) { e.eachRendered((function (t) { if (!yh(t)) { var e = t.getTextContent(), n = t.getTextGuideLine(); t.stateTransition && (t.stateTransition = null), e && e.stateTransition && (e.stateTransition = null), n && n.stateTransition && (n.stateTransition = null), t.hasState() ? (t.prevStates = t.currentStates, t.clearStates()) : t.prevStates && (t.prevStates = null) } })) } function s(t, n) { var i = t.getModel("stateAnimation"), r = t.isAnimationEnabled(), o = i.get("duration"), a = o > 0 ? { duration: o, delay: i.get("delay"), easing: i.get("easing") } : null; n.eachRendered((function (t) { if (t.states && t.states.emphasis) { if (yh(t)) return; if (t instanceof Is && function (t) { var e = il(t); e.normalFill = t.style.fill, e.normalStroke = t.style.stroke; var n = t.states.select || {}; e.selectFill = n.style && n.style.fill || null, e.selectStroke = n.style && n.style.stroke || null }(t), t.__dirty) { var n = t.prevStates; n && t.useStates(n) } if (r) { t.stateTransition = a; var i = t.getTextContent(), o = t.getTextGuideLine(); i && (i.stateTransition = a), o && (o.stateTransition = a) } t.__dirty && e(t) } })) } Ov = function (t) { var e = t._scheduler; e.restorePipelines(t._model), e.prepareStageTasks(), Rv(t, !0), Rv(t, !1), e.plan() }, Rv = function (t, e) { for (var n = t._model, i = t._scheduler, r = e ? t._componentsViews : t._chartsViews, o = e ? t._componentsMap : t._chartsMap, a = t._zr, s = t._api, l = 0; l < r.length; l++)r[l].__alive = !1; function u(t) { var l = t.__requireNewView; t.__requireNewView = !1; var u = "_ec_" + t.id + "_" + t.type, h = !l && o[u]; if (!h) { var c = Xo(t.type), p = e ? Tg.getClass(c.main, c.sub) : kg.getClass(c.sub); 0, (h = new p).init(n, s), o[u] = h, r.push(h), a.add(h.group) } t.__viewId = h.__id = u, h.__alive = !0, h.__model = t, h.group.__ecComponentInfo = { mainType: t.mainType, index: t.componentIndex }, !e && i.prepareView(h, t, n, s) } e ? n.eachComponent((function (t, e) { "series" !== t && u(e) })) : n.eachSeries(u); for (l = 0; l < r.length;) { var h = r[l]; h.__alive ? l++ : (!e && h.renderTask.dispose(), a.remove(h.group), h.dispose(n, s), r.splice(l, 1), o[h.__id] === h && delete o[h.__id], h.__id = h.group.__ecComponentInfo = null) } }, Nv = function (t, e, n, i, r) { var o = t._model; if (o.setUpdatePayload(n), i) { var a = {}; a[i + "Id"] = n[i + "Id"], a[i + "Index"] = n[i + "Index"], a[i + "Name"] = n[i + "Name"]; var s = { mainType: i, query: a }; r && (s.subType = r); var l, u = n.excludeSeriesId; null != u && (l = yt(), E(bo(u), (function (t) { var e = Ao(t, null); null != e && l.set(e, !0) }))), o && o.eachComponent(s, (function (e) { if (!(l && null != l.get(e.id))) if (Jl(n)) if (e instanceof mg) n.type !== ll || n.notBlur || e.get(["emphasis", "disabled"]) || function (t, e, n) { var i = t.seriesIndex, r = t.getData(e.dataType); if (r) { var o = Po(r, e); o = (Y(o) ? o[0] : o) || 0; var a = r.getItemGraphicEl(o); if (!a) for (var s = r.count(), l = 0; !a && l < s;)a = r.getItemGraphicEl(l++); if (a) { var u = Qs(a); Vl(i, u.focus, u.blurScope, n) } else { var h = t.get(["emphasis", "focus"]), c = t.get(["emphasis", "blurScope"]); null != h && Vl(i, h, c, n) } } }(e, n, t._api); else { var i = Fl(e.mainType, e.componentIndex, n.name, t._api), r = i.focusSelf, o = i.dispatchers; n.type === ll && r && !n.notBlur && Bl(e.mainType, e.componentIndex, t._api), o && E(o, (function (t) { n.type === ll ? kl(t) : Ll(t) })) } else $l(n) && e instanceof mg && (!function (t, e, n) { if ($l(e)) { var i = e.dataType, r = Po(t.getData(i), e); Y(r) || (r = [r]), t[e.type === pl ? "toggleSelect" : e.type === hl ? "select" : "unselect"](r, i) } }(e, n, t._api), Gl(e), qv(t)) }), t), o && o.eachComponent(s, (function (e) { l && null != l.get(e.id) || h(t["series" === i ? "_chartsMap" : "_componentsMap"][e.__viewId]) }), t) } else E([].concat(t._componentsViews).concat(t._chartsViews), h); function h(i) { i && i.__alive && i[e] && i[e](i.__model, o, t._api, n) } }, Ev = { prepareAndUpdate: function (t) { Ov(this), Ev.update.call(this, t, { optionChanged: null != t.newOption }) }, update: function (e, n) { var i = this._model, r = this._api, o = this._zr, a = this._coordSysMgr, s = this._scheduler; if (i) { i.setUpdatePayload(e), s.restoreData(i, e), s.performSeriesTasks(i), a.create(i, r), s.performDataProcessorTasks(i, e), Vv(this, i), a.update(i, r), t(i), s.performVisualTasks(i, e), Yv(this, i, r, e, n); var l = i.get("backgroundColor") || "transparent", u = i.get("darkMode"); o.setBackgroundColor(l), null != u && "auto" !== u && o.setDarkMode(u), xv.trigger("afterupdate", i, r) } }, updateTransform: function (e) { var n = this, i = this._model, r = this._api; if (i) { i.setUpdatePayload(e); var o = []; i.eachComponent((function (t, a) { if ("series" !== t) { var s = n.getViewOfComponentModel(a); if (s && s.__alive) if (s.updateTransform) { var l = s.updateTransform(a, i, r, e); l && l.update && o.push(s) } else o.push(s) } })); var a = yt(); i.eachSeries((function (t) { var o = n._chartsMap[t.__viewId]; if (o.updateTransform) { var s = o.updateTransform(t, i, r, e); s && s.update && a.set(t.uid, 1) } else a.set(t.uid, 1) })), t(i), this._scheduler.performVisualTasks(i, e, { setDirty: !0, dirtyMap: a }), Uv(this, i, r, e, {}, a), xv.trigger("afterupdate", i, r) } }, updateView: function (e) { var n = this._model; n && (n.setUpdatePayload(e), kg.markUpdateMethod(e, "updateView"), t(n), this._scheduler.performVisualTasks(n, e, { setDirty: !0 }), Yv(this, n, this._api, e, {}), xv.trigger("afterupdate", n, this._api)) }, updateVisual: function (e) { var n = this, i = this._model; i && (i.setUpdatePayload(e), i.eachSeries((function (t) { t.getData().clearAllVisual() })), kg.markUpdateMethod(e, "updateVisual"), t(i), this._scheduler.performVisualTasks(i, e, { visualType: "visual", setDirty: !0 }), i.eachComponent((function (t, r) { if ("series" !== t) { var o = n.getViewOfComponentModel(r); o && o.__alive && o.updateVisual(r, i, n._api, e) } })), i.eachSeries((function (t) { n._chartsMap[t.__viewId].updateVisual(t, i, n._api, e) })), xv.trigger("afterupdate", i, this._api)) }, updateLayout: function (t) { Ev.update.call(this, t) } }, zv = function (t, e, n, i) { if (t._disposed) nm(t.id); else { for (var r, o = t._model, a = t._coordSysMgr.getCoordinateSystems(), s = No(o, n), l = 0; l < a.length; l++) { var u = a[l]; if (u[e] && null != (r = u[e](o, s, i))) return r } 0 } }, Vv = function (t, e) { var n = t._chartsMap, i = t._scheduler; e.eachSeries((function (t) { i.updateStreamModes(t, n[t.__viewId]) })) }, Bv = function (t, e) { var n = this, i = this.getModel(), r = t.type, o = t.escapeConnect, a = im[r], s = a.actionInfo, l = (s.update || "update").split(":"), u = l.pop(), h = null != l[0] && Xo(l[0]); this[Iv] = !0; var c = [t], p = !1; t.batch && (p = !0, c = z(t.batch, (function (e) { return (e = k(A({}, e), t)).batch = null, e }))); var d, f = [], g = $l(t), y = Jl(t); if (y && zl(this._api), E(c, (function (e) { if ((d = (d = a.action(e, n._model, n._api)) || A({}, e)).type = s.event || d.type, f.push(d), y) { var i = Eo(t), r = i.queryOptionMap, o = i.mainTypeSpecified ? r.keys()[0] : "series"; Nv(n, u, e, o), qv(n) } else g ? (Nv(n, u, e, "series"), qv(n)) : h && Nv(n, u, e, h.main, h.sub) })), "none" !== u && !y && !g && !h) try { this[Tv] ? (Ov(this), Ev.update.call(this, t), this[Tv] = null) : Ev[u].call(this, t) } catch (t) { throw this[Iv] = !1, t } if (d = p ? { type: s.event || r, escapeConnect: o, batch: f } : f[0], this[Iv] = !1, !e) { var v = this._messageCenter; if (v.trigger(d.type, d), g) { var m = { type: "selectchanged", escapeConnect: o, selected: Wl(i), isFromClick: t.isFromClick || !1, fromAction: t.type, fromActionPayload: t }; v.trigger(m.type, m) } } }, Fv = function (t) { for (var e = this._pendingActions; e.length;) { var n = e.shift(); Bv.call(this, n, t) } }, Gv = function (t) { !t && this.trigger("updated") }, Wv = function (t, e) { t.on("rendered", (function (n) { e.trigger("rendered", n), !t.animation.isFinished() || e[Tv] || e._scheduler.unfinished || e._pendingActions.length || e.trigger("finished") })) }, Hv = function (t, e) { t.on("mouseover", (function (t) { var n = ky(t.target, Kl); n && (!function (t, e, n) { var i = Qs(t), r = Fl(i.componentMainType, i.componentIndex, i.componentHighDownName, n), o = r.dispatchers, a = r.focusSelf; o ? (a && Bl(i.componentMainType, i.componentIndex, n), E(o, (function (t) { return Dl(t, e) }))) : (Vl(i.seriesIndex, i.focus, i.blurScope, n), "self" === i.focus && Bl(i.componentMainType, i.componentIndex, n), Dl(t, e)) }(n, t, e._api), qv(e)) })).on("mouseout", (function (t) { var n = ky(t.target, Kl); n && (!function (t, e, n) { zl(n); var i = Qs(t), r = Fl(i.componentMainType, i.componentIndex, i.componentHighDownName, n).dispatchers; r ? E(r, (function (t) { return Al(t, e) })) : Al(t, e) }(n, t, e._api), qv(e)) })).on("click", (function (t) { var n = ky(t.target, (function (t) { return null != Qs(t).dataIndex }), !0); if (n) { var i = n.selected ? "unselect" : "select", r = Qs(n); e._api.dispatchAction({ type: i, dataType: r.dataType, dataIndexInside: r.dataIndex, seriesIndex: r.seriesIndex, isFromClick: !0 }) } })) }, Yv = function (t, e, n, i, r) { !function (t) { var e = [], n = [], i = !1; if (t.eachComponent((function (t, r) { var o = r.get("zlevel") || 0, a = r.get("z") || 0, s = r.getZLevelKey(); i = i || !!s, ("series" === t ? n : e).push({ zlevel: o, z: a, idx: r.componentIndex, type: t, key: s }) })), i) { var r, o, a = e.concat(n); Qe(a, (function (t, e) { return t.zlevel === e.zlevel ? t.z - e.z : t.zlevel - e.zlevel })), E(a, (function (e) { var n = t.getComponent(e.type, e.idx), i = e.zlevel, a = e.key; null != r && (i = Math.max(r, i)), a ? (i === r && a !== o && i++, o = a) : o && (i === r && i++, o = ""), r = i, n.setZLevel(i) })) } }(e), Xv(t, e, n, i, r), E(t._chartsViews, (function (t) { t.__alive = !1 })), Uv(t, e, n, i, r), E(t._chartsViews, (function (t) { t.__alive || t.remove(e, n) })) }, Xv = function (t, e, n, r, o, l) { E(l || t._componentsViews, (function (t) { var o = t.__model; a(o, t), t.render(o, e, n, r), i(o, t), s(o, t) })) }, Uv = function (t, e, n, o, l, u) { var h = t._scheduler; l = A(l || {}, { updatedSeries: e.getSeries() }), xv.trigger("series:beforeupdate", e, n, l); var c = !1; e.eachSeries((function (e) { var n = t._chartsMap[e.__viewId]; n.__alive = !0; var i = n.renderTask; h.updatePayload(i, o), a(e, n), u && u.get(e.uid) && i.dirty(), i.perform(h.getPerformArgs(i)) && (c = !0), n.group.silent = !!e.get("silent"), function (t, e) { var n = t.get("blendMode") || null; e.eachRendered((function (t) { t.isGroup || (t.style.blend = n) })) }(e, n), Gl(e) })), h.unfinished = c || h.unfinished, xv.trigger("series:layoutlabels", e, n, l), xv.trigger("series:transition", e, n, l), e.eachSeries((function (e) { var n = t._chartsMap[e.__viewId]; i(e, n), s(e, n) })), function (t, e) { var n = t._zr, i = n.storage, o = 0; i.traverse((function (t) { t.isGroup || o++ })), o > e.get("hoverLayerThreshold") && !r.node && !r.worker && e.eachSeries((function (e) { if (!e.preventUsingHoverLayer) { var n = t._chartsMap[e.__viewId]; n.__alive && n.eachRendered((function (t) { t.states.emphasis && (t.states.emphasis.hoverLayer = !0) })) } })) }(t, e), xv.trigger("series:afterupdate", e, n, l) }, qv = function (t) { t[Cv] = !0, t.getZr().wakeUp() }, Kv = function (t) { t[Cv] && (t.getZr().storage.traverse((function (t) { yh(t) || e(t) })), t[Cv] = !1) }, Zv = function (t) { return new (function (e) { function i() { return null !== e && e.apply(this, arguments) || this } return n(i, e), i.prototype.getCoordinateSystems = function () { return t._coordSysMgr.getCoordinateSystems() }, i.prototype.getComponentByElement = function (e) { for (; e;) { var n = e.__ecComponentInfo; if (null != n) return t._model.getComponent(n.mainType, n.index); e = e.parent } }, i.prototype.enterEmphasis = function (e, n) { kl(e, n), qv(t) }, i.prototype.leaveEmphasis = function (e, n) { Ll(e, n), qv(t) }, i.prototype.enterBlur = function (e) { Pl(e), qv(t) }, i.prototype.leaveBlur = function (e) { Ol(e), qv(t) }, i.prototype.enterSelect = function (e) { Rl(e), qv(t) }, i.prototype.leaveSelect = function (e) { Nl(e), qv(t) }, i.prototype.getModel = function () { return t.getModel() }, i.prototype.getViewOfComponentModel = function (e) { return t.getViewOfComponentModel(e) }, i.prototype.getViewOfSeriesModel = function (e) { return t.getViewOfSeriesModel(e) }, i }(vd))(t) }, jv = function (t) { function e(t, e) { for (var n = 0; n < t.length; n++) { t[n][Av] = e } } E(rm, (function (n, i) { t._messageCenter.on(i, (function (n) { if (cm[t.group] && 0 !== t[Av]) { if (n && n.escapeConnect) return; var i = t.makeActionFromEvent(n), r = []; E(hm, (function (e) { e !== t && e.group === t.group && r.push(e) })), e(r, 0), E(r, (function (t) { 1 !== t[Av] && t.dispatchAction(i) })), e(r, 2) } })) })) } }(), e }(jt), tm = Qv.prototype; tm.on = kv("on"), tm.off = kv("off"), tm.one = function (t, e, n) { var i = this; yo(), this.on.call(this, t, (function n() { for (var r = [], o = 0; o < arguments.length; o++)r[o] = arguments[o]; e && e.apply && e.apply(this, r), i.off(t, n) }), n) }; var em = ["click", "dblclick", "mouseover", "mouseout", "mousemove", "mousedown", "mouseup", "globalout", "contextmenu"]; function nm(t) { 0 } var im = {}, rm = {}, om = [], am = [], sm = [], lm = {}, um = {}, hm = {}, cm = {}, pm = +new Date - 0, dm = +new Date - 0, fm = "_echarts_instance_"; function gm(t) { cm[t] = !1 } var ym = gm; function vm(t) { return hm[function (t, e) { return t.getAttribute ? t.getAttribute(e) : t[e] }(t, fm)] } function mm(t, e) { lm[t] = e } function xm(t) { P(am, t) < 0 && am.push(t) } function _m(t, e) { Am(om, t, e, 2e3) } function bm(t) { Sm("afterinit", t) } function wm(t) { Sm("afterupdate", t) } function Sm(t, e) { xv.on(t, e) } function Mm(t, e, n) { X(e) && (n = e, e = ""); var i = q(t) ? t.type : [t, t = { event: e }][0]; t.event = (t.event || i).toLowerCase(), e = t.event, rm[e] || (lt(Dv.test(i) && Dv.test(e)), im[i] || (im[i] = { action: n, actionInfo: t }), rm[e] = i) } function Im(t, e) { xd.register(t, e) } function Tm(t, e) { Am(sm, t, e, 1e3, "layout") } function Cm(t, e) { Am(sm, t, e, 3e3, "visual") } var Dm = []; function Am(t, e, n, i, r) { if ((X(e) || q(e)) && (n = e, e = i), !(P(Dm, n) >= 0)) { Dm.push(n); var o = Jg.wrapStageHandler(n, r); o.__prio = e, o.__raw = n, t.push(o) } } function km(t, e) { um[t] = e } function Lm(t, e, n) { var i = bv("registerMap"); i && i(t, e, n) } var Pm = function (t) { var e = (t = T(t)).type, n = ""; e || vo(n); var i = e.split(":"); 2 !== i.length && vo(n); var r = !1; "echarts" === i[0] && (e = i[1], r = !0), t.__isBuiltIn = r, Nf.set(e, t) }; Cm(wv, Zg), Cm(Sv, qg), Cm(Sv, Kg), Cm(wv, Sy), Cm(Sv, My), Cm(7e3, (function (t, e) { t.eachRawSeries((function (n) { if (!t.isSeriesFiltered(n)) { var i = n.getData(); i.hasItemVisual() && i.each((function (t) { var n = i.getItemVisual(t, "decal"); n && (i.ensureUniqueItemVisual(t, "style").decal = gv(n, e)) })); var r = i.getVisual("decal"); if (r) i.getVisual("style").decal = gv(r, e) } })) })), xm(Wd), _m(900, (function (t) { var e = yt(); t.eachSeries((function (t) { var n = t.get("stack"); if (n) { var i = e.get(n) || e.set(n, []), r = t.getData(), o = { stackResultDimension: r.getCalculationInfo("stackResultDimension"), stackedOverDimension: r.getCalculationInfo("stackedOverDimension"), stackedDimension: r.getCalculationInfo("stackedDimension"), stackedByDimension: r.getCalculationInfo("stackedByDimension"), isStackedByIndex: r.getCalculationInfo("isStackedByIndex"), data: r, seriesModel: t }; if (!o.stackedDimension || !o.isStackedByIndex && !o.stackedByDimension) return; i.length && r.setCalculationInfo("stackedOnSeries", i[i.length - 1].seriesModel), i.push(o) } })), e.each(Hd) })), km("default", (function (t, e) { k(e = e || {}, { text: "loading", textColor: "#000", fontSize: 12, fontWeight: "normal", fontStyle: "normal", fontFamily: "sans-serif", maskColor: "rgba(255, 255, 255, 0.8)", showSpinner: !0, color: "#5470c6", spinnerRadius: 10, lineWidth: 5, zlevel: 0 }); var n = new zr, i = new zs({ style: { fill: e.maskColor }, zlevel: e.zlevel, z: 1e4 }); n.add(i); var r, o = new Fs({ style: { text: e.text, fill: e.textColor, fontSize: e.fontSize, fontWeight: e.fontWeight, fontStyle: e.fontStyle, fontFamily: e.fontFamily }, zlevel: e.zlevel, z: 10001 }), a = new zs({ style: { fill: "none" }, textContent: o, textConfig: { position: "right", distance: 10 }, zlevel: e.zlevel, z: 10001 }); return n.add(a), e.showSpinner && ((r = new Qu({ shape: { startAngle: -$g / 2, endAngle: -$g / 2 + .1, r: e.spinnerRadius }, style: { stroke: e.color, lineCap: "round", lineWidth: e.lineWidth }, zlevel: e.zlevel, z: 10001 })).animateShape(!0).when(1e3, { endAngle: 3 * $g / 2 }).start("circularInOut"), r.animateShape(!0).when(1e3, { startAngle: 3 * $g / 2 }).delay(300).start("circularInOut"), n.add(r)), n.resize = function () { var n = o.getBoundingRect().width, s = e.showSpinner ? e.spinnerRadius : 0, l = (t.getWidth() - 2 * s - (e.showSpinner && n ? 10 : 0) - n) / 2 - (e.showSpinner && n ? 0 : 5 + n / 2) + (e.showSpinner ? 0 : n / 2) + (n ? 0 : s), u = t.getHeight() / 2; e.showSpinner && r.setShape({ cx: l, cy: u }), a.setShape({ x: l - s, y: u - s, width: 2 * s, height: 2 * s }), i.setShape({ x: 0, y: 0, width: t.getWidth(), height: t.getHeight() }) }, n.resize(), n })), Mm({ type: ll, event: ll, update: ll }, bt), Mm({ type: ul, event: ul, update: ul }, bt), Mm({ type: hl, event: hl, update: hl }, bt), Mm({ type: cl, event: cl, update: cl }, bt), Mm({ type: pl, event: pl, update: pl }, bt), mm("light", fy), mm("dark", xy); var Om = [], Rm = { registerPreprocessor: xm, registerProcessor: _m, registerPostInit: bm, registerPostUpdate: wm, registerUpdateLifecycle: Sm, registerAction: Mm, registerCoordinateSystem: Im, registerLayout: Tm, registerVisual: Cm, registerTransform: Pm, registerLoading: km, registerMap: Lm, registerImpl: function (t, e) { _v[t] = e }, PRIORITY: Mv, ComponentModel: Rp, ComponentView: Tg, SeriesModel: mg, ChartView: kg, registerComponentModel: function (t) { Rp.registerClass(t) }, registerComponentView: function (t) { Tg.registerClass(t) }, registerSeriesModel: function (t) { mg.registerClass(t) }, registerChartView: function (t) { kg.registerClass(t) }, registerSubTypeDefaulter: function (t, e) { Rp.registerSubTypeDefaulter(t, e) }, registerPainter: function (t, e) { Wr(t, e) } }; function Nm(t) { Y(t) ? E(t, (function (t) { Nm(t) })) : P(Om, t) >= 0 || (Om.push(t), X(t) && (t = { install: t }), t.install(Rm)) } function Em(t) { return null == t ? 0 : t.length || 1 } function zm(t) { return t } var Vm = function () { function t(t, e, n, i, r, o) { this._old = t, this._new = e, this._oldKeyGetter = n || zm, this._newKeyGetter = i || zm, this.context = r, this._diffModeMultiple = "multiple" === o } return t.prototype.add = function (t) { return this._add = t, this }, t.prototype.update = function (t) { return this._update = t, this }, t.prototype.updateManyToOne = function (t) { return this._updateManyToOne = t, this }, t.prototype.updateOneToMany = function (t) { return this._updateOneToMany = t, this }, t.prototype.updateManyToMany = function (t) { return this._updateManyToMany = t, this }, t.prototype.remove = function (t) { return this._remove = t, this }, t.prototype.execute = function () { this[this._diffModeMultiple ? "_executeMultiple" : "_executeOneToOne"]() }, t.prototype._executeOneToOne = function () { var t = this._old, e = this._new, n = {}, i = new Array(t.length), r = new Array(e.length); this._initIndexMap(t, null, i, "_oldKeyGetter"), this._initIndexMap(e, n, r, "_newKeyGetter"); for (var o = 0; o < t.length; o++) { var a = i[o], s = n[a], l = Em(s); if (l > 1) { var u = s.shift(); 1 === s.length && (n[a] = s[0]), this._update && this._update(u, o) } else 1 === l ? (n[a] = null, this._update && this._update(s, o)) : this._remove && this._remove(o) } this._performRestAdd(r, n) }, t.prototype._executeMultiple = function () { var t = this._old, e = this._new, n = {}, i = {}, r = [], o = []; this._initIndexMap(t, n, r, "_oldKeyGetter"), this._initIndexMap(e, i, o, "_newKeyGetter"); for (var a = 0; a < r.length; a++) { var s = r[a], l = n[s], u = i[s], h = Em(l), c = Em(u); if (h > 1 && 1 === c) this._updateManyToOne && this._updateManyToOne(u, l), i[s] = null; else if (1 === h && c > 1) this._updateOneToMany && this._updateOneToMany(u, l), i[s] = null; else if (1 === h && 1 === c) this._update && this._update(u, l), i[s] = null; else if (h > 1 && c > 1) this._updateManyToMany && this._updateManyToMany(u, l), i[s] = null; else if (h > 1) for (var p = 0; p < h; p++)this._remove && this._remove(l[p]); else this._remove && this._remove(l) } this._performRestAdd(o, i) }, t.prototype._performRestAdd = function (t, e) { for (var n = 0; n < t.length; n++) { var i = t[n], r = e[i], o = Em(r); if (o > 1) for (var a = 0; a < o; a++)this._add && this._add(r[a]); else 1 === o && this._add && this._add(r); e[i] = null } }, t.prototype._initIndexMap = function (t, e, n, i) { for (var r = this._diffModeMultiple, o = 0; o < t.length; o++) { var a = "_ec_" + this[i](t[o], o); if (r || (n[o] = a), e) { var s = e[a], l = Em(s); 0 === l ? (e[a] = o, r && n.push(a)) : 1 === l ? e[a] = [s, o] : s.push(o) } } }, t }(), Bm = function () { function t(t, e) { this._encode = t, this._schema = e } return t.prototype.get = function () { return { fullDimensions: this._getFullDimensionNames(), encode: this._encode } }, t.prototype._getFullDimensionNames = function () { return this._cachedDimNames || (this._cachedDimNames = this._schema ? this._schema.makeOutputDimensionNames() : []), this._cachedDimNames }, t }(); function Fm(t, e) { return t.hasOwnProperty(e) || (t[e] = []), t[e] } function Gm(t) { return "category" === t ? "ordinal" : "time" === t ? "time" : "float" } var Wm = function (t) { this.otherDims = {}, null != t && A(this, t) }, Hm = Oo(), Ym = { float: "f", int: "i", ordinal: "o", number: "n", time: "t" }, Xm = function () { function t(t) { this.dimensions = t.dimensions, this._dimOmitted = t.dimensionOmitted, this.source = t.source, this._fullDimCount = t.fullDimensionCount, this._updateDimOmitted(t.dimensionOmitted) } return t.prototype.isDimensionOmitted = function () { return this._dimOmitted }, t.prototype._updateDimOmitted = function (t) { this._dimOmitted = t, t && (this._dimNameMap || (this._dimNameMap = jm(this.source))) }, t.prototype.getSourceDimensionIndex = function (t) { return rt(this._dimNameMap.get(t), -1) }, t.prototype.getSourceDimension = function (t) { var e = this.source.dimensionsDefine; if (e) return e[t] }, t.prototype.makeStoreSchema = function () { for (var t = this._fullDimCount, e = nf(this.source), n = !qm(t), i = "", r = [], o = 0, a = 0; o < t; o++) { var s = void 0, l = void 0, u = void 0, h = this.dimensions[a]; if (h && h.storeDimIndex === o) s = e ? h.name : null, l = h.type, u = h.ordinalMeta, a++; else { var c = this.getSourceDimension(o); c && (s = e ? c.name : null, l = c.type) } r.push({ property: s, type: l, ordinalMeta: u }), !e || null == s || h && h.isCalculationCoord || (i += n ? s.replace(/\`/g, "`1").replace(/\$/g, "`2") : s), i += "$", i += Ym[l] || "f", u && (i += u.uid), i += "$" } var p = this.source; return { dimensions: r, hash: [p.seriesLayoutBy, p.startIndex, i].join("$$") } }, t.prototype.makeOutputDimensionNames = function () { for (var t = [], e = 0, n = 0; e < this._fullDimCount; e++) { var i = void 0, r = this.dimensions[n]; if (r && r.storeDimIndex === e) r.isCalculationCoord || (i = r.name), n++; else { var o = this.getSourceDimension(e); o && (i = o.name) } t.push(i) } return t }, t.prototype.appendCalculationDimension = function (t) { this.dimensions.push(t), t.isCalculationCoord = !0, this._fullDimCount++, this._updateDimOmitted(!0) }, t }(); function Um(t) { return t instanceof Xm } function Zm(t) { for (var e = yt(), n = 0; n < (t || []).length; n++) { var i = t[n], r = q(i) ? i.name : i; null != r && null == e.get(r) && e.set(r, n) } return e } function jm(t) { var e = Hm(t); return e.dimNameMap || (e.dimNameMap = Zm(t.dimensionsDefine)) } function qm(t) { return t > 30 } var Km, $m, Jm, Qm, tx, ex, nx, ix = q, rx = z, ox = "undefined" == typeof Int32Array ? Array : Int32Array, ax = ["hasItemOption", "_nameList", "_idList", "_invertedIndicesMap", "_dimSummary", "userOutput", "_rawData", "_dimValueGetter", "_nameDimIdx", "_idDimIdx", "_nameRepeatCount"], sx = ["_approximateExtent"], lx = function () { function t(t, e) { var n; this.type = "list", this._dimOmitted = !1, this._nameList = [], this._idList = [], this._visual = {}, this._layout = {}, this._itemVisuals = [], this._itemLayouts = [], this._graphicEls = [], this._approximateExtent = {}, this._calculationInfo = {}, this.hasItemOption = !1, this.TRANSFERABLE_METHODS = ["cloneShallow", "downSample", "lttbDownSample", "map"], this.CHANGABLE_METHODS = ["filterSelf", "selectRange"], this.DOWNSAMPLE_METHODS = ["downSample", "lttbDownSample"]; var i = !1; Um(t) ? (n = t.dimensions, this._dimOmitted = t.isDimensionOmitted(), this._schema = t) : (i = !0, n = t), n = n || ["x", "y"]; for (var r = {}, o = [], a = {}, s = !1, l = {}, u = 0; u < n.length; u++) { var h = n[u], c = U(h) ? new Wm({ name: h }) : h instanceof Wm ? h : new Wm(h), p = c.name; c.type = c.type || "float", c.coordDim || (c.coordDim = p, c.coordDimIndex = 0); var d = c.otherDims = c.otherDims || {}; o.push(p), r[p] = c, null != l[p] && (s = !0), c.createInvertedIndices && (a[p] = []), 0 === d.itemName && (this._nameDimIdx = u), 0 === d.itemId && (this._idDimIdx = u), i && (c.storeDimIndex = u) } if (this.dimensions = o, this._dimInfos = r, this._initGetDimensionInfo(s), this.hostModel = e, this._invertedIndicesMap = a, this._dimOmitted) { var f = this._dimIdxToName = yt(); E(o, (function (t) { f.set(r[t].storeDimIndex, t) })) } } return t.prototype.getDimension = function (t) { var e = this._recognizeDimIndex(t); if (null == e) return t; if (e = t, !this._dimOmitted) return this.dimensions[e]; var n = this._dimIdxToName.get(e); if (null != n) return n; var i = this._schema.getSourceDimension(e); return i ? i.name : void 0 }, t.prototype.getDimensionIndex = function (t) { var e = this._recognizeDimIndex(t); if (null != e) return e; if (null == t) return -1; var n = this._getDimInfo(t); return n ? n.storeDimIndex : this._dimOmitted ? this._schema.getSourceDimensionIndex(t) : -1 }, t.prototype._recognizeDimIndex = function (t) { if (j(t) || null != t && !isNaN(t) && !this._getDimInfo(t) && (!this._dimOmitted || this._schema.getSourceDimensionIndex(t) < 0)) return +t }, t.prototype._getStoreDimIndex = function (t) { var e = this.getDimensionIndex(t); return e }, t.prototype.getDimensionInfo = function (t) { return this._getDimInfo(this.getDimension(t)) }, t.prototype._initGetDimensionInfo = function (t) { var e = this._dimInfos; this._getDimInfo = t ? function (t) { return e.hasOwnProperty(t) ? e[t] : void 0 } : function (t) { return e[t] } }, t.prototype.getDimensionsOnCoord = function () { return this._dimSummary.dataDimsOnCoord.slice() }, t.prototype.mapDimension = function (t, e) { var n = this._dimSummary; if (null == e) return n.encodeFirstDimNotExtra[t]; var i = n.encode[t]; return i ? i[e] : null }, t.prototype.mapDimensionsAll = function (t) { return (this._dimSummary.encode[t] || []).slice() }, t.prototype.getStore = function () { return this._store }, t.prototype.initData = function (t, e, n) { var i, r = this; if (t instanceof Zf && (i = t), !i) { var o = this.dimensions, a = Kd(t) || N(t) ? new rf(t, o.length) : t; i = new Zf; var s = rx(o, (function (t) { return { type: r._dimInfos[t].type, property: t } })); i.initData(a, s, n) } this._store = i, this._nameList = (e || []).slice(), this._idList = [], this._nameRepeatCount = {}, this._doInit(0, i.count()), this._dimSummary = function (t, e) { var n = {}, i = n.encode = {}, r = yt(), o = [], a = [], s = {}; E(t.dimensions, (function (e) { var n, l = t.getDimensionInfo(e), u = l.coordDim; if (u) { var h = l.coordDimIndex; Fm(i, u)[h] = e, l.isExtraCoord || (r.set(u, 1), "ordinal" !== (n = l.type) && "time" !== n && (o[0] = e), Fm(s, u)[h] = t.getDimensionIndex(l.name)), l.defaultTooltip && a.push(e) } Vp.each((function (t, e) { var n = Fm(i, e), r = l.otherDims[e]; null != r && !1 !== r && (n[r] = l.name) })) })); var l = [], u = {}; r.each((function (t, e) { var n = i[e]; u[e] = n[0], l = l.concat(n) })), n.dataDimsOnCoord = l, n.dataDimIndicesOnCoord = z(l, (function (e) { return t.getDimensionInfo(e).storeDimIndex })), n.encodeFirstDimNotExtra = u; var h = i.label; h && h.length && (o = h.slice()); var c = i.tooltip; return c && c.length ? a = c.slice() : a.length || (a = o.slice()), i.defaultedLabel = o, i.defaultedTooltip = a, n.userOutput = new Bm(s, e), n }(this, this._schema), this.userOutput = this._dimSummary.userOutput }, t.prototype.appendData = function (t) { var e = this._store.appendData(t); this._doInit(e[0], e[1]) }, t.prototype.appendValues = function (t, e) { var n = this._store.appendValues(t, e.length), i = n.start, r = n.end, o = this._shouldMakeIdFromName(); if (this._updateOrdinalMeta(), e) for (var a = i; a < r; a++) { var s = a - i; this._nameList[a] = e[s], o && nx(this, a) } }, t.prototype._updateOrdinalMeta = function () { for (var t = this._store, e = this.dimensions, n = 0; n < e.length; n++) { var i = this._dimInfos[e[n]]; i.ordinalMeta && t.collectOrdinalMeta(i.storeDimIndex, i.ordinalMeta) } }, t.prototype._shouldMakeIdFromName = function () { var t = this._store.getProvider(); return null == this._idDimIdx && t.getSource().sourceFormat !== Hp && !t.fillStorage }, t.prototype._doInit = function (t, e) { if (!(t >= e)) { var n = this._store.getProvider(); this._updateOrdinalMeta(); var i = this._nameList, r = this._idList; if (n.getSource().sourceFormat === Bp && !n.pure) for (var o = [], a = t; a < e; a++) { var s = n.getItem(a, o); if (!this.hasItemOption && Io(s) && (this.hasItemOption = !0), s) { var l = s.name; null == i[a] && null != l && (i[a] = Ao(l, null)); var u = s.id; null == r[a] && null != u && (r[a] = Ao(u, null)) } } if (this._shouldMakeIdFromName()) for (a = t; a < e; a++)nx(this, a); Km(this) } }, t.prototype.getApproximateExtent = function (t) { return this._approximateExtent[t] || this._store.getDataExtent(this._getStoreDimIndex(t)) }, t.prototype.setApproximateExtent = function (t, e) { e = this.getDimension(e), this._approximateExtent[e] = t.slice() }, t.prototype.getCalculationInfo = function (t) { return this._calculationInfo[t] }, t.prototype.setCalculationInfo = function (t, e) { ix(t) ? A(this._calculationInfo, t) : this._calculationInfo[t] = e }, t.prototype.getName = function (t) { var e = this.getRawIndex(t), n = this._nameList[e]; return null == n && null != this._nameDimIdx && (n = Jm(this, this._nameDimIdx, e)), null == n && (n = ""), n }, t.prototype._getCategory = function (t, e) { var n = this._store.get(t, e), i = this._store.getOrdinalMeta(t); return i ? i.categories[n] : n }, t.prototype.getId = function (t) { return $m(this, this.getRawIndex(t)) }, t.prototype.count = function () { return this._store.count() }, t.prototype.get = function (t, e) { var n = this._store, i = this._dimInfos[t]; if (i) return n.get(i.storeDimIndex, e) }, t.prototype.getByRawIndex = function (t, e) { var n = this._store, i = this._dimInfos[t]; if (i) return n.getByRawIndex(i.storeDimIndex, e) }, t.prototype.getIndices = function () { return this._store.getIndices() }, t.prototype.getDataExtent = function (t) { return this._store.getDataExtent(this._getStoreDimIndex(t)) }, t.prototype.getSum = function (t) { return this._store.getSum(this._getStoreDimIndex(t)) }, t.prototype.getMedian = function (t) { return this._store.getMedian(this._getStoreDimIndex(t)) }, t.prototype.getValues = function (t, e) { var n = this, i = this._store; return Y(t) ? i.getValues(rx(t, (function (t) { return n._getStoreDimIndex(t) })), e) : i.getValues(t) }, t.prototype.hasValue = function (t) { for (var e = this._dimSummary.dataDimIndicesOnCoord, n = 0, i = e.length; n < i; n++)if (isNaN(this._store.get(e[n], t))) return !1; return !0 }, t.prototype.indexOfName = function (t) { for (var e = 0, n = this._store.count(); e < n; e++)if (this.getName(e) === t) return e; return -1 }, t.prototype.getRawIndex = function (t) { return this._store.getRawIndex(t) }, t.prototype.indexOfRawIndex = function (t) { return this._store.indexOfRawIndex(t) }, t.prototype.rawIndexOf = function (t, e) { var n = t && this._invertedIndicesMap[t]; var i = n[e]; return null == i || isNaN(i) ? -1 : i }, t.prototype.indicesOfNearest = function (t, e, n) { return this._store.indicesOfNearest(this._getStoreDimIndex(t), e, n) }, t.prototype.each = function (t, e, n) { X(t) && (n = e, e = t, t = []); var i = n || this, r = rx(Qm(t), this._getStoreDimIndex, this); this._store.each(r, i ? W(e, i) : e) }, t.prototype.filterSelf = function (t, e, n) { X(t) && (n = e, e = t, t = []); var i = n || this, r = rx(Qm(t), this._getStoreDimIndex, this); return this._store = this._store.filter(r, i ? W(e, i) : e), this }, t.prototype.selectRange = function (t) { var e = this, n = {}; return E(G(t), (function (i) { var r = e._getStoreDimIndex(i); n[r] = t[i] })), this._store = this._store.selectRange(n), this }, t.prototype.mapArray = function (t, e, n) { X(t) && (n = e, e = t, t = []), n = n || this; var i = []; return this.each(t, (function () { i.push(e && e.apply(this, arguments)) }), n), i }, t.prototype.map = function (t, e, n, i) { var r = n || i || this, o = rx(Qm(t), this._getStoreDimIndex, this), a = ex(this); return a._store = this._store.map(o, r ? W(e, r) : e), a }, t.prototype.modify = function (t, e, n, i) { var r = n || i || this; var o = rx(Qm(t), this._getStoreDimIndex, this); this._store.modify(o, r ? W(e, r) : e) }, t.prototype.downSample = function (t, e, n, i) { var r = ex(this); return r._store = this._store.downSample(this._getStoreDimIndex(t), e, n, i), r }, t.prototype.lttbDownSample = function (t, e) { var n = ex(this); return n._store = this._store.lttbDownSample(this._getStoreDimIndex(t), e), n }, t.prototype.getRawDataItem = function (t) { return this._store.getRawDataItem(t) }, t.prototype.getItemModel = function (t) { var e = this.hostModel, n = this.getRawDataItem(t); return new Mc(n, e, e && e.ecModel) }, t.prototype.diff = function (t) { var e = this; return new Vm(t ? t.getStore().getIndices() : [], this.getStore().getIndices(), (function (e) { return $m(t, e) }), (function (t) { return $m(e, t) })) }, t.prototype.getVisual = function (t) { var e = this._visual; return e && e[t] }, t.prototype.setVisual = function (t, e) { this._visual = this._visual || {}, ix(t) ? A(this._visual, t) : this._visual[t] = e }, t.prototype.getItemVisual = function (t, e) { var n = this._itemVisuals[t], i = n && n[e]; return null == i ? this.getVisual(e) : i }, t.prototype.hasItemVisual = function () { return this._itemVisuals.length > 0 }, t.prototype.ensureUniqueItemVisual = function (t, e) { var n = this._itemVisuals, i = n[t]; i || (i = n[t] = {}); var r = i[e]; return null == r && (Y(r = this.getVisual(e)) ? r = r.slice() : ix(r) && (r = A({}, r)), i[e] = r), r }, t.prototype.setItemVisual = function (t, e, n) { var i = this._itemVisuals[t] || {}; this._itemVisuals[t] = i, ix(e) ? A(i, e) : i[e] = n }, t.prototype.clearAllVisual = function () { this._visual = {}, this._itemVisuals = [] }, t.prototype.setLayout = function (t, e) { ix(t) ? A(this._layout, t) : this._layout[t] = e }, t.prototype.getLayout = function (t) { return this._layout[t] }, t.prototype.getItemLayout = function (t) { return this._itemLayouts[t] }, t.prototype.setItemLayout = function (t, e, n) { this._itemLayouts[t] = n ? A(this._itemLayouts[t] || {}, e) : e }, t.prototype.clearItemLayouts = function () { this._itemLayouts.length = 0 }, t.prototype.setItemGraphicEl = function (t, e) { var n = this.hostModel && this.hostModel.seriesIndex; tl(n, this.dataType, t, e), this._graphicEls[t] = e }, t.prototype.getItemGraphicEl = function (t) { return this._graphicEls[t] }, t.prototype.eachItemGraphicEl = function (t, e) { E(this._graphicEls, (function (n, i) { n && t && t.call(e, n, i) })) }, t.prototype.cloneShallow = function (e) { return e || (e = new t(this._schema ? this._schema : rx(this.dimensions, this._getDimInfo, this), this.hostModel)), tx(e, this), e._store = this._store, e }, t.prototype.wrapMethod = function (t, e) { var n = this[t]; X(n) && (this.__wrappedMethods = this.__wrappedMethods || [], this.__wrappedMethods.push(t), this[t] = function () { var t = n.apply(this, arguments); return e.apply(this, [t].concat(at(arguments))) }) }, t.internalField = (Km = function (t) { var e = t._invertedIndicesMap; E(e, (function (n, i) { var r = t._dimInfos[i], o = r.ordinalMeta, a = t._store; if (o) { n = e[i] = new ox(o.categories.length); for (var s = 0; s < n.length; s++)n[s] = -1; for (s = 0; s < a.count(); s++)n[a.get(r.storeDimIndex, s)] = s } })) }, Jm = function (t, e, n) { return Ao(t._getCategory(e, n), null) }, $m = function (t, e) { var n = t._idList[e]; return null == n && null != t._idDimIdx && (n = Jm(t, t._idDimIdx, e)), null == n && (n = "e\0\0" + e), n }, Qm = function (t) { return Y(t) || (t = null != t ? [t] : []), t }, ex = function (e) { var n = new t(e._schema ? e._schema : rx(e.dimensions, e._getDimInfo, e), e.hostModel); return tx(n, e), n }, tx = function (t, e) { E(ax.concat(e.__wrappedMethods || []), (function (n) { e.hasOwnProperty(n) && (t[n] = e[n]) })), t.__wrappedMethods = e.__wrappedMethods, E(sx, (function (n) { t[n] = T(e[n]) })), t._calculationInfo = A({}, e._calculationInfo) }, void (nx = function (t, e) { var n = t._nameList, i = t._idList, r = t._nameDimIdx, o = t._idDimIdx, a = n[e], s = i[e]; if (null == a && null != r && (n[e] = a = Jm(t, r, e)), null == s && null != o && (i[e] = s = Jm(t, o, e)), null == s && null != a) { var l = t._nameRepeatCount, u = l[a] = (l[a] || 0) + 1; s = a, u > 1 && (s += "__ec__" + u), i[e] = s } })), t }(); function ux(t, e) { Kd(t) || (t = Jd(t)); var n = (e = e || {}).coordDimensions || [], i = e.dimensionsDefine || t.dimensionsDefine || [], r = yt(), o = [], a = function (t, e, n, i) { var r = Math.max(t.dimensionsDetectedCount || 1, e.length, n.length, i || 0); return E(e, (function (t) { var e; q(t) && (e = t.dimsDef) && (r = Math.max(r, e.length)) })), r }(t, n, i, e.dimensionsCount), s = e.canOmitUnusedDimensions && qm(a), l = i === t.dimensionsDefine, u = l ? jm(t) : Zm(i), h = e.encodeDefine; !h && e.encodeDefaulter && (h = e.encodeDefaulter(t, a)); for (var c = yt(h), p = new Wf(a), d = 0; d < p.length; d++)p[d] = -1; function f(t) { var e = p[t]; if (e < 0) { var n = i[t], r = q(n) ? n : { name: n }, a = new Wm, s = r.name; null != s && null != u.get(s) && (a.name = a.displayName = s), null != r.type && (a.type = r.type), null != r.displayName && (a.displayName = r.displayName); var l = o.length; return p[t] = l, a.storeDimIndex = t, o.push(a), a } return o[e] } if (!s) for (d = 0; d < a; d++)f(d); c.each((function (t, e) { var n = bo(t).slice(); if (1 === n.length && !U(n[0]) && n[0] < 0) c.set(e, !1); else { var i = c.set(e, []); E(n, (function (t, n) { var r = U(t) ? u.get(t) : t; null != r && r < a && (i[n] = r, y(f(r), e, n)) })) } })); var g = 0; function y(t, e, n) { null != Vp.get(e) ? t.otherDims[e] = n : (t.coordDim = e, t.coordDimIndex = n, r.set(e, !0)) } E(n, (function (t) { var e, n, i, r; if (U(t)) e = t, r = {}; else { e = (r = t).name; var o = r.ordinalMeta; r.ordinalMeta = null, (r = A({}, r)).ordinalMeta = o, n = r.dimsDef, i = r.otherDims, r.name = r.coordDim = r.coordDimIndex = r.dimsDef = r.otherDims = null } var s = c.get(e); if (!1 !== s) { if (!(s = bo(s)).length) for (var u = 0; u < (n && n.length || 1); u++) { for (; g < a && null != f(g).coordDim;)g++; g < a && s.push(g++) } E(s, (function (t, o) { var a = f(t); if (l && null != r.type && (a.type = r.type), y(k(a, r), e, o), null == a.name && n) { var s = n[o]; !q(s) && (s = { name: s }), a.name = a.displayName = s.name, a.defaultTooltip = s.defaultTooltip } i && k(a.otherDims, i) })) } })); var v = e.generateCoord, m = e.generateCoordCount, x = null != m; m = v ? m || 1 : 0; var _ = v || "value"; function b(t) { null == t.name && (t.name = t.coordDim) } if (s) E(o, (function (t) { b(t) })), o.sort((function (t, e) { return t.storeDimIndex - e.storeDimIndex })); else for (var w = 0; w < a; w++) { var S = f(w); null == S.coordDim && (S.coordDim = hx(_, r, x), S.coordDimIndex = 0, (!v || m <= 0) && (S.isExtraCoord = !0), m--), b(S), null != S.type || td(t, w) !== Zp && (!S.isExtraCoord || null == S.otherDims.itemName && null == S.otherDims.seriesName) || (S.type = "ordinal") } return function (t) { for (var e = yt(), n = 0; n < t.length; n++) { var i = t[n], r = i.name, o = e.get(r) || 0; o > 0 && (i.name = r + (o - 1)), o++, e.set(r, o) } }(o), new Xm({ source: t, dimensions: o, fullDimensionCount: a, dimensionOmitted: s }) } function hx(t, e, n) { if (n || e.hasKey(t)) { for (var i = 0; e.hasKey(t + i);)i++; t += i } return e.set(t, !0), t } var cx = function (t) { this.coordSysDims = [], this.axisMap = yt(), this.categoryAxisMap = yt(), this.coordSysName = t }; var px = { cartesian2d: function (t, e, n, i) { var r = t.getReferringComponents("xAxis", zo).models[0], o = t.getReferringComponents("yAxis", zo).models[0]; e.coordSysDims = ["x", "y"], n.set("x", r), n.set("y", o), dx(r) && (i.set("x", r), e.firstCategoryDimIndex = 0), dx(o) && (i.set("y", o), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = 1)) }, singleAxis: function (t, e, n, i) { var r = t.getReferringComponents("singleAxis", zo).models[0]; e.coordSysDims = ["single"], n.set("single", r), dx(r) && (i.set("single", r), e.firstCategoryDimIndex = 0) }, polar: function (t, e, n, i) { var r = t.getReferringComponents("polar", zo).models[0], o = r.findAxisModel("radiusAxis"), a = r.findAxisModel("angleAxis"); e.coordSysDims = ["radius", "angle"], n.set("radius", o), n.set("angle", a), dx(o) && (i.set("radius", o), e.firstCategoryDimIndex = 0), dx(a) && (i.set("angle", a), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = 1)) }, geo: function (t, e, n, i) { e.coordSysDims = ["lng", "lat"] }, parallel: function (t, e, n, i) { var r = t.ecModel, o = r.getComponent("parallel", t.get("parallelIndex")), a = e.coordSysDims = o.dimensions.slice(); E(o.parallelAxisIndex, (function (t, o) { var s = r.getComponent("parallelAxis", t), l = a[o]; n.set(l, s), dx(s) && (i.set(l, s), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = o)) })) } }; function dx(t) { return "category" === t.get("type") } function fx(t, e, n) { var i, r, o, a = (n = n || {}).byIndex, s = n.stackedCoordDimension; !function (t) { return !Um(t.schema) }(e) ? (r = e.schema, i = r.dimensions, o = e.store) : i = e; var l, u, h, c, p = !(!t || !t.get("stack")); if (E(i, (function (t, e) { U(t) && (i[e] = t = { name: t }), p && !t.isExtraCoord && (a || l || !t.ordinalMeta || (l = t), u || "ordinal" === t.type || "time" === t.type || s && s !== t.coordDim || (u = t)) })), !u || a || l || (a = !0), u) { h = "__\0ecstackresult_" + t.id, c = "__\0ecstackedover_" + t.id, l && (l.createInvertedIndices = !0); var d = u.coordDim, f = u.type, g = 0; E(i, (function (t) { t.coordDim === d && g++ })); var y = { name: h, coordDim: d, coordDimIndex: g, type: f, isExtraCoord: !0, isCalculationCoord: !0, storeDimIndex: i.length }, v = { name: c, coordDim: c, coordDimIndex: g + 1, type: f, isExtraCoord: !0, isCalculationCoord: !0, storeDimIndex: i.length + 1 }; r ? (o && (y.storeDimIndex = o.ensureCalculationDimension(c, f), v.storeDimIndex = o.ensureCalculationDimension(h, f)), r.appendCalculationDimension(y), r.appendCalculationDimension(v)) : (i.push(y), i.push(v)) } return { stackedDimension: u && u.name, stackedByDimension: l && l.name, isStackedByIndex: a, stackedOverDimension: c, stackResultDimension: h } } function gx(t, e) { return !!e && e === t.getCalculationInfo("stackedDimension") } function yx(t, e) { return gx(t, e) ? t.getCalculationInfo("stackResultDimension") : e } function vx(t, e, n) { n = n || {}; var i, r = e.getSourceManager(), o = !1; t ? (o = !0, i = Jd(t)) : o = (i = r.getSource()).sourceFormat === Bp; var a = function (t) { var e = t.get("coordinateSystem"), n = new cx(e), i = px[e]; if (i) return i(t, n, n.axisMap, n.categoryAxisMap), n }(e), s = function (t, e) { var n, i = t.get("coordinateSystem"), r = xd.get(i); return e && e.coordSysDims && (n = z(e.coordSysDims, (function (t) { var n = { name: t }, i = e.axisMap.get(t); if (i) { var r = i.get("type"); n.type = Gm(r) } return n }))), n || (n = r && (r.getDimensionsInfo ? r.getDimensionsInfo() : r.dimensions.slice()) || ["x", "y"]), n }(e, a), l = n.useEncodeDefaulter, u = X(l) ? l : l ? H($p, s, e) : null, h = ux(i, { coordDimensions: s, generateCoord: n.generateCoord, encodeDefine: e.getEncode(), encodeDefaulter: u, canOmitUnusedDimensions: !o }), c = function (t, e, n) { var i, r; return n && E(t, (function (t, o) { var a = t.coordDim, s = n.categoryAxisMap.get(a); s && (null == i && (i = o), t.ordinalMeta = s.getOrdinalMeta(), e && (t.createInvertedIndices = !0)), null != t.otherDims.itemName && (r = !0) })), r || null == i || (t[i].otherDims.itemName = 0), i }(h.dimensions, n.createInvertedIndices, a), p = o ? null : r.getSharedDataStore(h), d = fx(e, { schema: h, store: p }), f = new lx(h, e); f.setCalculationInfo(d); var g = null != c && function (t) { if (t.sourceFormat === Bp) { var e = function (t) { var e = 0; for (; e < t.length && null == t[e];)e++; return t[e] }(t.data || []); return !Y(Mo(e)) } }(i) ? function (t, e, n, i) { return i === c ? n : this.defaultDimValueGetter(t, e, n, i) } : null; return f.hasItemOption = !1, f.initData(o ? i : p, null, g), f } var mx = function () { function t(t) { this._setting = t || {}, this._extent = [1 / 0, -1 / 0] } return t.prototype.getSetting = function (t) { return this._setting[t] }, t.prototype.unionExtent = function (t) { var e = this._extent; t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1]) }, t.prototype.unionExtentFromData = function (t, e) { this.unionExtent(t.getApproximateExtent(e)) }, t.prototype.getExtent = function () { return this._extent.slice() }, t.prototype.setExtent = function (t, e) { var n = this._extent; isNaN(t) || (n[0] = t), isNaN(e) || (n[1] = e) }, t.prototype.isInExtentRange = function (t) { return this._extent[0] <= t && this._extent[1] >= t }, t.prototype.isBlank = function () { return this._isBlank }, t.prototype.setBlank = function (t) { this._isBlank = t }, t }(); $o(mx); var xx = 0, _x = function () { function t(t) { this.categories = t.categories || [], this._needCollect = t.needCollect, this._deduplication = t.deduplication, this.uid = ++xx } return t.createByAxisModel = function (e) { var n = e.option, i = n.data, r = i && z(i, bx); return new t({ categories: r, needCollect: !r, deduplication: !1 !== n.dedplication }) }, t.prototype.getOrdinal = function (t) { return this._getOrCreateMap().get(t) }, t.prototype.parseAndCollect = function (t) { var e, n = this._needCollect; if (!U(t) && !n) return t; if (n && !this._deduplication) return e = this.categories.length, this.categories[e] = t, e; var i = this._getOrCreateMap(); return null == (e = i.get(t)) && (n ? (e = this.categories.length, this.categories[e] = t, i.set(t, e)) : e = NaN), e }, t.prototype._getOrCreateMap = function () { return this._map || (this._map = yt(this.categories)) }, t }(); function bx(t) { return q(t) && null != t.value ? t.value : t + "" } function Sx(t) { return "interval" === t.type || "log" === t.type } function Mx(t, e, n, i) { var r = {}, o = t[1] - t[0], a = r.interval = so(o / e, !0); null != n && a < n && (a = r.interval = n), null != i && a > i && (a = r.interval = i); var s = r.intervalPrecision = Tx(a); return function (t, e) { !isFinite(t[0]) && (t[0] = e[0]), !isFinite(t[1]) && (t[1] = e[1]), Cx(t, 0, e), Cx(t, 1, e), t[0] > t[1] && (t[0] = t[1]) }(r.niceTickExtent = [Zr(Math.ceil(t[0] / a) * a, s), Zr(Math.floor(t[1] / a) * a, s)], t), r } function Ix(t) { var e = Math.pow(10, ao(t)), n = t / e; return n ? 2 === n ? n = 3 : 3 === n ? n = 5 : n *= 2 : n = 1, Zr(n * e) } function Tx(t) { return qr(t) + 2 } function Cx(t, e, n) { t[e] = Math.max(Math.min(t[e], n[1]), n[0]) } function Dx(t, e) { return t >= e[0] && t <= e[1] } function Ax(t, e) { return e[1] === e[0] ? .5 : (t - e[0]) / (e[1] - e[0]) } function kx(t, e) { return t * (e[1] - e[0]) + e[0] } var Lx = function (t) { function e(e) { var n = t.call(this, e) || this; n.type = "ordinal"; var i = n.getSetting("ordinalMeta"); return i || (i = new _x({})), Y(i) && (i = new _x({ categories: z(i, (function (t) { return q(t) ? t.value : t })) })), n._ordinalMeta = i, n._extent = n.getSetting("extent") || [0, i.categories.length - 1], n } return n(e, t), e.prototype.parse = function (t) { return null == t ? NaN : U(t) ? this._ordinalMeta.getOrdinal(t) : Math.round(t) }, e.prototype.contain = function (t) { return Dx(t = this.parse(t), this._extent) && null != this._ordinalMeta.categories[t] }, e.prototype.normalize = function (t) { return Ax(t = this._getTickNumber(this.parse(t)), this._extent) }, e.prototype.scale = function (t) { return t = Math.round(kx(t, this._extent)), this.getRawOrdinalNumber(t) }, e.prototype.getTicks = function () { for (var t = [], e = this._extent, n = e[0]; n <= e[1];)t.push({ value: n }), n++; return t }, e.prototype.getMinorTicks = function (t) { }, e.prototype.setSortInfo = function (t) { if (null != t) { for (var e = t.ordinalNumbers, n = this._ordinalNumbersByTick = [], i = this._ticksByOrdinalNumber = [], r = 0, o = this._ordinalMeta.categories.length, a = Math.min(o, e.length); r < a; ++r) { var s = e[r]; n[r] = s, i[s] = r } for (var l = 0; r < o; ++r) { for (; null != i[l];)l++; n.push(l), i[l] = r } } else this._ordinalNumbersByTick = this._ticksByOrdinalNumber = null }, e.prototype._getTickNumber = function (t) { var e = this._ticksByOrdinalNumber; return e && t >= 0 && t < e.length ? e[t] : t }, e.prototype.getRawOrdinalNumber = function (t) { var e = this._ordinalNumbersByTick; return e && t >= 0 && t < e.length ? e[t] : t }, e.prototype.getLabel = function (t) { if (!this.isBlank()) { var e = this.getRawOrdinalNumber(t.value), n = this._ordinalMeta.categories[e]; return null == n ? "" : n + "" } }, e.prototype.count = function () { return this._extent[1] - this._extent[0] + 1 }, e.prototype.unionExtentFromData = function (t, e) { this.unionExtent(t.getApproximateExtent(e)) }, e.prototype.isInExtentRange = function (t) { return t = this._getTickNumber(t), this._extent[0] <= t && this._extent[1] >= t }, e.prototype.getOrdinalMeta = function () { return this._ordinalMeta }, e.prototype.calcNiceTicks = function () { }, e.prototype.calcNiceExtent = function () { }, e.type = "ordinal", e }(mx); mx.registerClass(Lx); var Px = Zr, Ox = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "interval", e._interval = 0, e._intervalPrecision = 2, e } return n(e, t), e.prototype.parse = function (t) { return t }, e.prototype.contain = function (t) { return Dx(t, this._extent) }, e.prototype.normalize = function (t) { return Ax(t, this._extent) }, e.prototype.scale = function (t) { return kx(t, this._extent) }, e.prototype.setExtent = function (t, e) { var n = this._extent; isNaN(t) || (n[0] = parseFloat(t)), isNaN(e) || (n[1] = parseFloat(e)) }, e.prototype.unionExtent = function (t) { var e = this._extent; t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1]), this.setExtent(e[0], e[1]) }, e.prototype.getInterval = function () { return this._interval }, e.prototype.setInterval = function (t) { this._interval = t, this._niceExtent = this._extent.slice(), this._intervalPrecision = Tx(t) }, e.prototype.getTicks = function (t) { var e = this._interval, n = this._extent, i = this._niceExtent, r = this._intervalPrecision, o = []; if (!e) return o; n[0] < i[0] && (t ? o.push({ value: Px(i[0] - e, r) }) : o.push({ value: n[0] })); for (var a = i[0]; a <= i[1] && (o.push({ value: a }), (a = Px(a + e, r)) !== o[o.length - 1].value);)if (o.length > 1e4) return []; var s = o.length ? o[o.length - 1].value : i[1]; return n[1] > s && (t ? o.push({ value: Px(s + e, r) }) : o.push({ value: n[1] })), o }, e.prototype.getMinorTicks = function (t) { for (var e = this.getTicks(!0), n = [], i = this.getExtent(), r = 1; r < e.length; r++) { for (var o = e[r], a = e[r - 1], s = 0, l = [], u = (o.value - a.value) / t; s < t - 1;) { var h = Px(a.value + (s + 1) * u); h > i[0] && h < i[1] && l.push(h), s++ } n.push(l) } return n }, e.prototype.getLabel = function (t, e) { if (null == t) return ""; var n = e && e.precision; return null == n ? n = qr(t.value) || 0 : "auto" === n && (n = this._intervalPrecision), pp(Px(t.value, n, !0)) }, e.prototype.calcNiceTicks = function (t, e, n) { t = t || 5; var i = this._extent, r = i[1] - i[0]; if (isFinite(r)) { r < 0 && (r = -r, i.reverse()); var o = Mx(i, t, e, n); this._intervalPrecision = o.intervalPrecision, this._interval = o.interval, this._niceExtent = o.niceTickExtent } }, e.prototype.calcNiceExtent = function (t) { var e = this._extent; if (e[0] === e[1]) if (0 !== e[0]) { var n = Math.abs(e[0]); t.fixMax || (e[1] += n / 2), e[0] -= n / 2 } else e[1] = 1; var i = e[1] - e[0]; isFinite(i) || (e[0] = 0, e[1] = 1), this.calcNiceTicks(t.splitNumber, t.minInterval, t.maxInterval); var r = this._interval; t.fixMin || (e[0] = Px(Math.floor(e[0] / r) * r)), t.fixMax || (e[1] = Px(Math.ceil(e[1] / r) * r)) }, e.prototype.setNiceExtent = function (t, e) { this._niceExtent = [t, e] }, e.type = "interval", e }(mx); mx.registerClass(Ox); var Rx = "undefined" != typeof Float32Array, Nx = Rx ? Float32Array : Array; function Ex(t) { return Y(t) ? Rx ? new Float32Array(t) : t : new Nx(t) } var zx = "__ec_stack_"; function Vx(t) { return t.get("stack") || zx + t.seriesIndex } function Bx(t) { return t.dim + t.index } function Fx(t, e) { var n = []; return e.eachSeriesByType(t, (function (t) { Xx(t) && n.push(t) })), n } function Gx(t) { var e = function (t) { var e = {}; E(t, (function (t) { var n = t.coordinateSystem.getBaseAxis(); if ("time" === n.type || "value" === n.type) for (var i = t.getData(), r = n.dim + "_" + n.index, o = i.getDimensionIndex(i.mapDimension(n.dim)), a = i.getStore(), s = 0, l = a.count(); s < l; ++s) { var u = a.get(o, s); e[r] ? e[r].push(u) : e[r] = [u] } })); var n = {}; for (var i in e) if (e.hasOwnProperty(i)) { var r = e[i]; if (r) { r.sort((function (t, e) { return t - e })); for (var o = null, a = 1; a < r.length; ++a) { var s = r[a] - r[a - 1]; s > 0 && (o = null === o ? s : Math.min(o, s)) } n[i] = o } } return n }(t), n = []; return E(t, (function (t) { var i, r = t.coordinateSystem.getBaseAxis(), o = r.getExtent(); if ("category" === r.type) i = r.getBandWidth(); else if ("value" === r.type || "time" === r.type) { var a = r.dim + "_" + r.index, s = e[a], l = Math.abs(o[1] - o[0]), u = r.scale.getExtent(), h = Math.abs(u[1] - u[0]); i = s ? l / h * s : l } else { var c = t.getData(); i = Math.abs(o[1] - o[0]) / c.count() } var p = Ur(t.get("barWidth"), i), d = Ur(t.get("barMaxWidth"), i), f = Ur(t.get("barMinWidth") || (Ux(t) ? .5 : 1), i), g = t.get("barGap"), y = t.get("barCategoryGap"); n.push({ bandWidth: i, barWidth: p, barMaxWidth: d, barMinWidth: f, barGap: g, barCategoryGap: y, axisKey: Bx(r), stackId: Vx(t) }) })), Wx(n) } function Wx(t) { var e = {}; E(t, (function (t, n) { var i = t.axisKey, r = t.bandWidth, o = e[i] || { bandWidth: r, remainedWidth: r, autoWidthCount: 0, categoryGap: null, gap: "20%", stacks: {} }, a = o.stacks; e[i] = o; var s = t.stackId; a[s] || o.autoWidthCount++, a[s] = a[s] || { width: 0, maxWidth: 0 }; var l = t.barWidth; l && !a[s].width && (a[s].width = l, l = Math.min(o.remainedWidth, l), o.remainedWidth -= l); var u = t.barMaxWidth; u && (a[s].maxWidth = u); var h = t.barMinWidth; h && (a[s].minWidth = h); var c = t.barGap; null != c && (o.gap = c); var p = t.barCategoryGap; null != p && (o.categoryGap = p) })); var n = {}; return E(e, (function (t, e) { n[e] = {}; var i = t.stacks, r = t.bandWidth, o = t.categoryGap; if (null == o) { var a = G(i).length; o = Math.max(35 - 4 * a, 15) + "%" } var s = Ur(o, r), l = Ur(t.gap, 1), u = t.remainedWidth, h = t.autoWidthCount, c = (u - s) / (h + (h - 1) * l); c = Math.max(c, 0), E(i, (function (t) { var e = t.maxWidth, n = t.minWidth; if (t.width) { i = t.width; e && (i = Math.min(i, e)), n && (i = Math.max(i, n)), t.width = i, u -= i + l * i, h-- } else { var i = c; e && e < i && (i = Math.min(e, u)), n && n > i && (i = n), i !== c && (t.width = i, u -= i + l * i, h--) } })), c = (u - s) / (h + (h - 1) * l), c = Math.max(c, 0); var p, d = 0; E(i, (function (t, e) { t.width || (t.width = c), p = t, d += t.width * (1 + l) })), p && (d -= p.width * l); var f = -d / 2; E(i, (function (t, i) { n[e][i] = n[e][i] || { bandWidth: r, offset: f, width: t.width }, f += t.width * (1 + l) })) })), n } function Hx(t, e) { var n = Fx(t, e), i = Gx(n); E(n, (function (t) { var e = t.getData(), n = t.coordinateSystem.getBaseAxis(), r = Vx(t), o = i[Bx(n)][r], a = o.offset, s = o.width; e.setLayout({ bandWidth: o.bandWidth, offset: a, size: s }) })) } function Yx(t) { return { seriesType: t, plan: Cg(), reset: function (t) { if (Xx(t)) { var e = t.getData(), n = t.coordinateSystem, i = n.getBaseAxis(), r = n.getOtherAxis(i), o = e.getDimensionIndex(e.mapDimension(r.dim)), a = e.getDimensionIndex(e.mapDimension(i.dim)), s = t.get("showBackground", !0), l = e.mapDimension(r.dim), u = e.getCalculationInfo("stackResultDimension"), h = gx(e, l) && !!e.getCalculationInfo("stackedOnSeries"), c = r.isHorizontal(), p = function (t, e) { return e.toGlobalCoord(e.dataToCoord("log" === e.type ? 1 : 0)) }(0, r), d = Ux(t), f = t.get("barMinHeight") || 0, g = u && e.getDimensionIndex(u), y = e.getLayout("size"), v = e.getLayout("offset"); return { progress: function (t, e) { for (var i, r = t.count, l = d && Ex(3 * r), u = d && s && Ex(3 * r), m = d && Ex(r), x = n.master.getRect(), _ = c ? x.width : x.height, b = e.getStore(), w = 0; null != (i = t.next());) { var S = b.get(h ? g : o, i), M = b.get(a, i), I = p, T = void 0; h && (T = +S - b.get(o, i)); var C = void 0, D = void 0, A = void 0, k = void 0; if (c) { var L = n.dataToPoint([S, M]); if (h) I = n.dataToPoint([T, M])[0]; C = I, D = L[1] + v, A = L[0] - I, k = y, Math.abs(A) < f && (A = (A < 0 ? -1 : 1) * f) } else { L = n.dataToPoint([M, S]); if (h) I = n.dataToPoint([M, T])[1]; C = L[0] + v, D = I, A = y, k = L[1] - I, Math.abs(k) < f && (k = (k <= 0 ? -1 : 1) * f) } d ? (l[w] = C, l[w + 1] = D, l[w + 2] = c ? A : k, u && (u[w] = c ? x.x : C, u[w + 1] = c ? D : x.y, u[w + 2] = _), m[i] = i) : e.setItemLayout(i, { x: C, y: D, width: A, height: k }), w += 3 } d && e.setLayout({ largePoints: l, largeDataIndices: m, largeBackgroundPoints: u, valueAxisHorizontal: c }) } } } } } } function Xx(t) { return t.coordinateSystem && "cartesian2d" === t.coordinateSystem.type } function Ux(t) { return t.pipelineContext && t.pipelineContext.large } var Zx = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "time", n } return n(e, t), e.prototype.getLabel = function (t) { var e = this.getSetting("useUTC"); return qc(t.value, Hc[function (t) { switch (t) { case "year": case "month": return "day"; case "millisecond": return "millisecond"; default: return "second" } }(Zc(this._minLevelUnit))] || Hc.second, e, this.getSetting("locale")) }, e.prototype.getFormattedLabel = function (t, e, n) { var i = this.getSetting("useUTC"); return function (t, e, n, i, r) { var o = null; if (U(n)) o = n; else if (X(n)) o = n(t.value, e, { level: t.level }); else { var a = A({}, Gc); if (t.level > 0) for (var s = 0; s < Yc.length; ++s)a[Yc[s]] = "{primary|" + a[Yc[s]] + "}"; var l = n ? !1 === n.inherit ? n : k(n, a) : a, u = Kc(t.value, r); if (l[u]) o = l[u]; else if (l.inherit) { for (s = Xc.indexOf(u) - 1; s >= 0; --s)if (l[u]) { o = l[u]; break } o = o || a.none } if (Y(o)) { var h = null == t.level ? 0 : t.level >= 0 ? t.level : o.length + t.level; o = o[h = Math.min(h, o.length - 1)] } } return qc(new Date(t.value), o, r, i) }(t, e, n, this.getSetting("locale"), i) }, e.prototype.getTicks = function () { var t = this._interval, e = this._extent, n = []; if (!t) return n; n.push({ value: e[0], level: 0 }); var i = this.getSetting("useUTC"), r = function (t, e, n, i) { var r = 1e4, o = Xc, a = 0; function s(t, e, n, r, o, a, s) { for (var l = new Date(e), u = e, h = l[r](); u < n && u <= i[1];)s.push({ value: u }), h += t, l[o](h), u = l.getTime(); s.push({ value: u, notAdd: !0 }) } function l(t, r, o) { var a = [], l = !r.length; if (!function (t, e, n, i) { var r = ro(e), o = ro(n), a = function (t) { return $c(r, t, i) === $c(o, t, i) }, s = function () { return a("year") }, l = function () { return s() && a("month") }, u = function () { return l() && a("day") }, h = function () { return u() && a("hour") }, c = function () { return h() && a("minute") }, p = function () { return c() && a("second") }, d = function () { return p() && a("millisecond") }; switch (t) { case "year": return s(); case "month": return l(); case "day": return u(); case "hour": return h(); case "minute": return c(); case "second": return p(); case "millisecond": return d() } }(Zc(t), i[0], i[1], n)) { l && (r = [{ value: t_(new Date(i[0]), t, n) }, { value: i[1] }]); for (var u = 0; u < r.length - 1; u++) { var h = r[u].value, c = r[u + 1].value; if (h !== c) { var p = void 0, d = void 0, f = void 0, g = !1; switch (t) { case "year": p = Math.max(1, Math.round(e / Bc / 365)), d = Jc(n), f = op(n); break; case "half-year": case "quarter": case "month": p = Kx(e), d = Qc(n), f = ap(n); break; case "week": case "half-week": case "day": p = qx(e), d = tp(n), f = sp(n), g = !0; break; case "half-day": case "quarter-day": case "hour": p = $x(e), d = ep(n), f = lp(n); break; case "minute": p = Jx(e, !0), d = np(n), f = up(n); break; case "second": p = Jx(e, !1), d = ip(n), f = hp(n); break; case "millisecond": p = Qx(e), d = rp(n), f = cp(n) }s(p, h, c, d, f, g, a), "year" === t && o.length > 1 && 0 === u && o.unshift({ value: o[0].value - p }) } } for (u = 0; u < a.length; u++)o.push(a[u]); return a } } for (var u = [], h = [], c = 0, p = 0, d = 0; d < o.length && a++ < r; ++d) { var f = Zc(o[d]); if (jc(o[d])) if (l(o[d], u[u.length - 1] || [], h), f !== (o[d + 1] ? Zc(o[d + 1]) : null)) { if (h.length) { p = c, h.sort((function (t, e) { return t.value - e.value })); for (var g = [], y = 0; y < h.length; ++y) { var v = h[y].value; 0 !== y && h[y - 1].value === v || (g.push(h[y]), v >= i[0] && v <= i[1] && c++) } var m = (i[1] - i[0]) / e; if (c > 1.5 * m && p > m / 1.5) break; if (u.push(g), c > m || t === o[d]) break } h = [] } } 0; var x = B(z(u, (function (t) { return B(t, (function (t) { return t.value >= i[0] && t.value <= i[1] && !t.notAdd })) })), (function (t) { return t.length > 0 })), _ = [], b = x.length - 1; for (d = 0; d < x.length; ++d)for (var w = x[d], S = 0; S < w.length; ++S)_.push({ value: w[S].value, level: b - d }); _.sort((function (t, e) { return t.value - e.value })); var M = []; for (d = 0; d < _.length; ++d)0 !== d && _[d].value === _[d - 1].value || M.push(_[d]); return M }(this._minLevelUnit, this._approxInterval, i, e); return (n = n.concat(r)).push({ value: e[1], level: 0 }), n }, e.prototype.calcNiceExtent = function (t) { var e = this._extent; if (e[0] === e[1] && (e[0] -= Bc, e[1] += Bc), e[1] === -1 / 0 && e[0] === 1 / 0) { var n = new Date; e[1] = +new Date(n.getFullYear(), n.getMonth(), n.getDate()), e[0] = e[1] - Bc } this.calcNiceTicks(t.splitNumber, t.minInterval, t.maxInterval) }, e.prototype.calcNiceTicks = function (t, e, n) { t = t || 10; var i = this._extent, r = i[1] - i[0]; this._approxInterval = r / t, null != e && this._approxInterval < e && (this._approxInterval = e), null != n && this._approxInterval > n && (this._approxInterval = n); var o = jx.length, a = Math.min(function (t, e, n, i) { for (; n < i;) { var r = n + i >>> 1; t[r][1] < e ? n = r + 1 : i = r } return n }(jx, this._approxInterval, 0, o), o - 1); this._interval = jx[a][1], this._minLevelUnit = jx[Math.max(a - 1, 0)][0] }, e.prototype.parse = function (t) { return j(t) ? t : +ro(t) }, e.prototype.contain = function (t) { return Dx(this.parse(t), this._extent) }, e.prototype.normalize = function (t) { return Ax(this.parse(t), this._extent) }, e.prototype.scale = function (t) { return kx(t, this._extent) }, e.type = "time", e }(Ox), jx = [["second", Ec], ["minute", zc], ["hour", Vc], ["quarter-day", 216e5], ["half-day", 432e5], ["day", 10368e4], ["half-week", 3024e5], ["week", 6048e5], ["month", 26784e5], ["quarter", 8208e6], ["half-year", Fc / 2], ["year", Fc]]; function qx(t, e) { return (t /= Bc) > 16 ? 16 : t > 7.5 ? 7 : t > 3.5 ? 4 : t > 1.5 ? 2 : 1 } function Kx(t) { return (t /= 2592e6) > 6 ? 6 : t > 3 ? 3 : t > 2 ? 2 : 1 } function $x(t) { return (t /= Vc) > 12 ? 12 : t > 6 ? 6 : t > 3.5 ? 4 : t > 2 ? 2 : 1 } function Jx(t, e) { return (t /= e ? zc : Ec) > 30 ? 30 : t > 20 ? 20 : t > 15 ? 15 : t > 10 ? 10 : t > 5 ? 5 : t > 2 ? 2 : 1 } function Qx(t) { return so(t, !0) } function t_(t, e, n) { var i = new Date(t); switch (Zc(e)) { case "year": case "month": i[ap(n)](0); case "day": i[sp(n)](1); case "hour": i[lp(n)](0); case "minute": i[up(n)](0); case "second": i[hp(n)](0), i[cp(n)](0) }return i.getTime() } mx.registerClass(Zx); var e_ = mx.prototype, n_ = Ox.prototype, i_ = Zr, r_ = Math.floor, o_ = Math.ceil, a_ = Math.pow, s_ = Math.log, l_ = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "log", e.base = 10, e._originalScale = new Ox, e._interval = 0, e } return n(e, t), e.prototype.getTicks = function (t) { var e = this._originalScale, n = this._extent, i = e.getExtent(); return z(n_.getTicks.call(this, t), (function (t) { var e = t.value, r = Zr(a_(this.base, e)); return r = e === n[0] && this._fixMin ? h_(r, i[0]) : r, { value: r = e === n[1] && this._fixMax ? h_(r, i[1]) : r } }), this) }, e.prototype.setExtent = function (t, e) { var n = s_(this.base); t = s_(Math.max(0, t)) / n, e = s_(Math.max(0, e)) / n, n_.setExtent.call(this, t, e) }, e.prototype.getExtent = function () { var t = this.base, e = e_.getExtent.call(this); e[0] = a_(t, e[0]), e[1] = a_(t, e[1]); var n = this._originalScale.getExtent(); return this._fixMin && (e[0] = h_(e[0], n[0])), this._fixMax && (e[1] = h_(e[1], n[1])), e }, e.prototype.unionExtent = function (t) { this._originalScale.unionExtent(t); var e = this.base; t[0] = s_(t[0]) / s_(e), t[1] = s_(t[1]) / s_(e), e_.unionExtent.call(this, t) }, e.prototype.unionExtentFromData = function (t, e) { this.unionExtent(t.getApproximateExtent(e)) }, e.prototype.calcNiceTicks = function (t) { t = t || 10; var e = this._extent, n = e[1] - e[0]; if (!(n === 1 / 0 || n <= 0)) { var i = oo(n); for (t / n * i <= .5 && (i *= 10); !isNaN(i) && Math.abs(i) < 1 && Math.abs(i) > 0;)i *= 10; var r = [Zr(o_(e[0] / i) * i), Zr(r_(e[1] / i) * i)]; this._interval = i, this._niceExtent = r } }, e.prototype.calcNiceExtent = function (t) { n_.calcNiceExtent.call(this, t), this._fixMin = t.fixMin, this._fixMax = t.fixMax }, e.prototype.parse = function (t) { return t }, e.prototype.contain = function (t) { return Dx(t = s_(t) / s_(this.base), this._extent) }, e.prototype.normalize = function (t) { return Ax(t = s_(t) / s_(this.base), this._extent) }, e.prototype.scale = function (t) { return t = kx(t, this._extent), a_(this.base, t) }, e.type = "log", e }(mx), u_ = l_.prototype; function h_(t, e) { return i_(t, qr(e)) } u_.getMinorTicks = n_.getMinorTicks, u_.getLabel = n_.getLabel, mx.registerClass(l_); var c_ = function () { function t(t, e, n) { this._prepareParams(t, e, n) } return t.prototype._prepareParams = function (t, e, n) { n[1] < n[0] && (n = [NaN, NaN]), this._dataMin = n[0], this._dataMax = n[1]; var i = this._isOrdinal = "ordinal" === t.type; this._needCrossZero = "interval" === t.type && e.getNeedCrossZero && e.getNeedCrossZero(); var r = this._modelMinRaw = e.get("min", !0); X(r) ? this._modelMinNum = g_(t, r({ min: n[0], max: n[1] })) : "dataMin" !== r && (this._modelMinNum = g_(t, r)); var o = this._modelMaxRaw = e.get("max", !0); if (X(o) ? this._modelMaxNum = g_(t, o({ min: n[0], max: n[1] })) : "dataMax" !== o && (this._modelMaxNum = g_(t, o)), i) this._axisDataLen = e.getCategories().length; else { var a = e.get("boundaryGap"), s = Y(a) ? a : [a || 0, a || 0]; "boolean" == typeof s[0] || "boolean" == typeof s[1] ? this._boundaryGapInner = [0, 0] : this._boundaryGapInner = [Ir(s[0], 1), Ir(s[1], 1)] } }, t.prototype.calculate = function () { var t = this._isOrdinal, e = this._dataMin, n = this._dataMax, i = this._axisDataLen, r = this._boundaryGapInner, o = t ? null : n - e || Math.abs(e), a = "dataMin" === this._modelMinRaw ? e : this._modelMinNum, s = "dataMax" === this._modelMaxRaw ? n : this._modelMaxNum, l = null != a, u = null != s; null == a && (a = t ? i ? 0 : NaN : e - r[0] * o), null == s && (s = t ? i ? i - 1 : NaN : n + r[1] * o), (null == a || !isFinite(a)) && (a = NaN), (null == s || !isFinite(s)) && (s = NaN); var h = nt(a) || nt(s) || t && !i; this._needCrossZero && (a > 0 && s > 0 && !l && (a = 0), a < 0 && s < 0 && !u && (s = 0)); var c = this._determinedMin, p = this._determinedMax; return null != c && (a = c, l = !0), null != p && (s = p, u = !0), { min: a, max: s, minFixed: l, maxFixed: u, isBlank: h } }, t.prototype.modifyDataMinMax = function (t, e) { this[d_[t]] = e }, t.prototype.setDeterminedMinMax = function (t, e) { var n = p_[t]; this[n] = e }, t.prototype.freeze = function () { this.frozen = !0 }, t }(), p_ = { min: "_determinedMin", max: "_determinedMax" }, d_ = { min: "_dataMin", max: "_dataMax" }; function f_(t, e, n) { var i = t.rawExtentInfo; return i || (i = new c_(t, e, n), t.rawExtentInfo = i, i) } function g_(t, e) { return null == e ? null : nt(e) ? NaN : t.parse(e) } function y_(t, e) { var n = t.type, i = f_(t, e, t.getExtent()).calculate(); t.setBlank(i.isBlank); var r = i.min, o = i.max, a = e.ecModel; if (a && "time" === n) { var s = Fx("bar", a), l = !1; if (E(s, (function (t) { l = l || t.getBaseAxis() === e.axis })), l) { var u = Gx(s), h = function (t, e, n, i) { var r = n.axis.getExtent(), o = r[1] - r[0], a = function (t, e, n) { if (t && e) { var i = t[Bx(e)]; return null != i && null != n ? i[Vx(n)] : i } }(i, n.axis); if (void 0 === a) return { min: t, max: e }; var s = 1 / 0; E(a, (function (t) { s = Math.min(t.offset, s) })); var l = -1 / 0; E(a, (function (t) { l = Math.max(t.offset + t.width, l) })), s = Math.abs(s), l = Math.abs(l); var u = s + l, h = e - t, c = h / (1 - (s + l) / o) - h; return e += c * (l / u), t -= c * (s / u), { min: t, max: e } }(r, o, e, u); r = h.min, o = h.max } } return { extent: [r, o], fixMin: i.minFixed, fixMax: i.maxFixed } } function v_(t, e) { var n = e, i = y_(t, n), r = i.extent, o = n.get("splitNumber"); t instanceof l_ && (t.base = n.get("logBase")); var a = t.type, s = n.get("interval"), l = "interval" === a || "time" === a; t.setExtent(r[0], r[1]), t.calcNiceExtent({ splitNumber: o, fixMin: i.fixMin, fixMax: i.fixMax, minInterval: l ? n.get("minInterval") : null, maxInterval: l ? n.get("maxInterval") : null }), null != s && t.setInterval && t.setInterval(s) } function m_(t, e) { if (e = e || t.get("type")) switch (e) { case "category": return new Lx({ ordinalMeta: t.getOrdinalMeta ? t.getOrdinalMeta() : t.getCategories(), extent: [1 / 0, -1 / 0] }); case "time": return new Zx({ locale: t.ecModel.getLocaleModel(), useUTC: t.ecModel.get("useUTC") }); default: return new (mx.getClass(e) || Ox) } } function x_(t) { var e, n, i = t.getLabelModel().get("formatter"), r = "category" === t.type ? t.scale.getExtent()[0] : null; return "time" === t.scale.type ? (n = i, function (e, i) { return t.scale.getFormattedLabel(e, i, n) }) : U(i) ? function (e) { return function (n) { var i = t.scale.getLabel(n); return e.replace("{value}", null != i ? i : "") } }(i) : X(i) ? (e = i, function (n, i) { return null != r && (i = n.value - r), e(__(t, n), i, null != n.level ? { level: n.level } : null) }) : function (e) { return t.scale.getLabel(e) } } function __(t, e) { return "category" === t.type ? t.scale.getLabel(e) : e.value } function b_(t, e) { var n = e * Math.PI / 180, i = t.width, r = t.height, o = i * Math.abs(Math.cos(n)) + Math.abs(r * Math.sin(n)), a = i * Math.abs(Math.sin(n)) + Math.abs(r * Math.cos(n)); return new ze(t.x, t.y, o, a) } function w_(t) { var e = t.get("interval"); return null == e ? "auto" : e } function S_(t) { return "category" === t.type && 0 === w_(t.getLabelModel()) } function M_(t, e) { var n = {}; return E(t.mapDimensionsAll(e), (function (e) { n[yx(t, e)] = !0 })), G(n) } var I_ = function () { function t() { } return t.prototype.getNeedCrossZero = function () { return !this.option.scale }, t.prototype.getCoordSysModel = function () { }, t }(); var T_ = { isDimensionStacked: gx, enableDataStack: fx, getStackedDimension: yx }; var C_ = Object.freeze({ __proto__: null, createList: function (t) { return vx(null, t) }, getLayoutRect: Cp, dataStack: T_, createScale: function (t, e) { var n = e; e instanceof Mc || (n = new Mc(e)); var i = m_(n); return i.setExtent(t[0], t[1]), v_(i, n), i }, mixinAxisModelCommonMethods: function (t) { R(t, I_) }, getECData: Qs, createTextStyle: function (t, e) { return nc(t, null, null, "normal" !== (e = e || {}).state) }, createDimensions: function (t, e) { return ux(t, e).dimensions }, createSymbol: Wy, enableHoverEmphasis: Hl }); function D_(t, e) { return Math.abs(t - e) < 1e-8 } function A_(t, e, n) { var i = 0, r = t[0]; if (!r) return !1; for (var o = 1; o < t.length; o++) { var a = t[o]; i += ds(r[0], r[1], a[0], a[1], e, n), r = a } var s = t[0]; return D_(r[0], s[0]) && D_(r[1], s[1]) || (i += ds(r[0], r[1], s[0], s[1], e, n)), 0 !== i } var k_ = []; function L_(t, e) { for (var n = 0; n < t.length; n++)Wt(t[n], t[n], e) } function P_(t, e, n, i) { for (var r = 0; r < t.length; r++) { var o = t[r]; i && (o = i.project(o)), o && isFinite(o[0]) && isFinite(o[1]) && (Ht(e, e, o), Yt(n, n, o)) } } var O_ = function () { function t(t) { this.name = t } return t.prototype.setCenter = function (t) { this._center = t }, t.prototype.getCenter = function () { var t = this._center; return t || (t = this._center = this.calcCenter()), t }, t }(), R_ = function (t, e) { this.type = "polygon", this.exterior = t, this.interiors = e }, N_ = function (t) { this.type = "linestring", this.points = t }, E_ = function (t) { function e(e, n, i) { var r = t.call(this, e) || this; return r.type = "geoJSON", r.geometries = n, r._center = i && [i[0], i[1]], r } return n(e, t), e.prototype.calcCenter = function () { for (var t, e = this.geometries, n = 0, i = 0; i < e.length; i++) { var r = e[i], o = r.exterior, a = o && o.length; a > n && (t = r, n = a) } if (t) return function (t) { for (var e = 0, n = 0, i = 0, r = t.length, o = t[r - 1][0], a = t[r - 1][1], s = 0; s < r; s++) { var l = t[s][0], u = t[s][1], h = o * u - l * a; e += h, n += (o + l) * h, i += (a + u) * h, o = l, a = u } return e ? [n / e / 3, i / e / 3, e] : [t[0][0] || 0, t[0][1] || 0] }(t.exterior); var s = this.getBoundingRect(); return [s.x + s.width / 2, s.y + s.height / 2] }, e.prototype.getBoundingRect = function (t) { var e = this._rect; if (e && !t) return e; var n = [1 / 0, 1 / 0], i = [-1 / 0, -1 / 0]; return E(this.geometries, (function (e) { "polygon" === e.type ? P_(e.exterior, n, i, t) : E(e.points, (function (e) { P_(e, n, i, t) })) })), isFinite(n[0]) && isFinite(n[1]) && isFinite(i[0]) && isFinite(i[1]) || (n[0] = n[1] = i[0] = i[1] = 0), e = new ze(n[0], n[1], i[0] - n[0], i[1] - n[1]), t || (this._rect = e), e }, e.prototype.contain = function (t) { var e = this.getBoundingRect(), n = this.geometries; if (!e.contain(t[0], t[1])) return !1; t: for (var i = 0, r = n.length; i < r; i++) { var o = n[i]; if ("polygon" === o.type) { var a = o.exterior, s = o.interiors; if (A_(a, t[0], t[1])) { for (var l = 0; l < (s ? s.length : 0); l++)if (A_(s[l], t[0], t[1])) continue t; return !0 } } } return !1 }, e.prototype.transformTo = function (t, e, n, i) { var r = this.getBoundingRect(), o = r.width / r.height; n ? i || (i = n / o) : n = o * i; for (var a = new ze(t, e, n, i), s = r.calculateTransform(a), l = this.geometries, u = 0; u < l.length; u++) { var h = l[u]; "polygon" === h.type ? (L_(h.exterior, s), E(h.interiors, (function (t) { L_(t, s) }))) : E(h.points, (function (t) { L_(t, s) })) } (r = this._rect).copy(a), this._center = [r.x + r.width / 2, r.y + r.height / 2] }, e.prototype.cloneShallow = function (t) { null == t && (t = this.name); var n = new e(t, this.geometries, this._center); return n._rect = this._rect, n.transformTo = null, n }, e }(O_), z_ = function (t) { function e(e, n) { var i = t.call(this, e) || this; return i.type = "geoSVG", i._elOnlyForCalculate = n, i } return n(e, t), e.prototype.calcCenter = function () { for (var t = this._elOnlyForCalculate, e = t.getBoundingRect(), n = [e.x + e.width / 2, e.y + e.height / 2], i = xe(k_), r = t; r && !r.isGeoSVGGraphicRoot;)be(i, r.getLocalTransform(), i), r = r.parent; return Ie(i, i), Wt(n, n, i), n }, e }(O_); function V_(t, e, n) { for (var i = 0; i < t.length; i++)t[i] = B_(t[i], e[i], n) } function B_(t, e, n) { for (var i = [], r = e[0], o = e[1], a = 0; a < t.length; a += 2) { var s = t.charCodeAt(a) - 64, l = t.charCodeAt(a + 1) - 64; s = s >> 1 ^ -(1 & s), l = l >> 1 ^ -(1 & l), r = s += r, o = l += o, i.push([s / n, l / n]) } return i } function F_(t, e) { return z(B((t = function (t) { if (!t.UTF8Encoding) return t; var e = t, n = e.UTF8Scale; return null == n && (n = 1024), E(e.features, (function (t) { var e = t.geometry, i = e.encodeOffsets, r = e.coordinates; if (i) switch (e.type) { case "LineString": e.coordinates = B_(r, i, n); break; case "Polygon": case "MultiLineString": V_(r, i, n); break; case "MultiPolygon": E(r, (function (t, e) { return V_(t, i[e], n) })) } })), e.UTF8Encoding = !1, e }(t)).features, (function (t) { return t.geometry && t.properties && t.geometry.coordinates.length > 0 })), (function (t) { var n = t.properties, i = t.geometry, r = []; switch (i.type) { case "Polygon": var o = i.coordinates; r.push(new R_(o[0], o.slice(1))); break; case "MultiPolygon": E(i.coordinates, (function (t) { t[0] && r.push(new R_(t[0], t.slice(1))) })); break; case "LineString": r.push(new N_([i.coordinates])); break; case "MultiLineString": r.push(new N_(i.coordinates)) }var a = new E_(n[e || "name"], r, n.cp); return a.properties = n, a })) } var G_ = Object.freeze({ __proto__: null, linearMap: Xr, round: Zr, asc: jr, getPrecision: qr, getPrecisionSafe: Kr, getPixelPrecision: $r, getPercentWithPrecision: function (t, e, n) { return t[e] && Jr(t, n)[e] || 0 }, MAX_SAFE_INTEGER: to, remRadian: eo, isRadianAroundZero: no, parseDate: ro, quantity: oo, quantityExponent: ao, nice: so, quantile: lo, reformIntervals: uo, isNumeric: co, numericToNumber: ho }), W_ = Object.freeze({ __proto__: null, parse: ro, format: qc }), H_ = Object.freeze({ __proto__: null, extendShape: Mh, extendPath: Th, makePath: Ah, makeImage: kh, mergePath: Ph, resizePath: Oh, createIcon: Hh, updateProps: fh, initProps: gh, getTransform: Eh, clipPointsByRect: Gh, clipRectByRect: Wh, registerShape: Ch, getShapeClass: Dh, Group: zr, Image: ks, Text: Fs, Circle: _u, Ellipse: wu, Sector: zu, Ring: Bu, Polygon: Wu, Polyline: Yu, Rect: zs, Line: Zu, BezierCurve: $u, Arc: Qu, IncrementalDisplayable: hh, CompoundPath: th, LinearGradient: nh, RadialGradient: ih, BoundingRect: ze }), Y_ = Object.freeze({ __proto__: null, addCommas: pp, toCamelCase: dp, normalizeCssArray: fp, encodeHTML: re, formatTpl: mp, getTooltipMarker: xp, formatTime: function (t, e, n) { "week" !== t && "month" !== t && "quarter" !== t && "half-year" !== t && "year" !== t || (t = "MM-dd\nyyyy"); var i = ro(e), r = n ? "getUTC" : "get", o = i[r + "FullYear"](), a = i[r + "Month"]() + 1, s = i[r + "Date"](), l = i[r + "Hours"](), u = i[r + "Minutes"](), h = i[r + "Seconds"](), c = i[r + "Milliseconds"](); return t = t.replace("MM", Uc(a, 2)).replace("M", a).replace("yyyy", o).replace("yy", Uc(o % 100 + "", 2)).replace("dd", Uc(s, 2)).replace("d", s).replace("hh", Uc(l, 2)).replace("h", l).replace("mm", Uc(u, 2)).replace("m", u).replace("ss", Uc(h, 2)).replace("s", h).replace("SSS", Uc(c, 3)) }, capitalFirst: function (t) { return t ? t.charAt(0).toUpperCase() + t.substr(1) : t }, truncateText: sa, getTextRect: function (t, e, n, i, r, o, a, s) { return new Fs({ style: { text: t, font: e, align: n, verticalAlign: i, padding: r, rich: o, overflow: a ? "truncate" : null, lineHeight: s } }).getBoundingRect() } }), X_ = Object.freeze({ __proto__: null, map: z, each: E, indexOf: P, inherits: O, reduce: V, filter: B, bind: W, curry: H, isArray: Y, isString: U, isObject: q, isFunction: X, extend: A, defaults: k, clone: T, merge: C }), U_ = Oo(); function Z_(t) { return "category" === t.type ? function (t) { var e = t.getLabelModel(), n = q_(t, e); return !e.get("show") || t.scale.isBlank() ? { labels: [], labelCategoryInterval: n.labelCategoryInterval } : n }(t) : function (t) { var e = t.scale.getTicks(), n = x_(t); return { labels: z(e, (function (e, i) { return { level: e.level, formattedLabel: n(e, i), rawLabel: t.scale.getLabel(e), tickValue: e.value } })) } }(t) } function j_(t, e) { return "category" === t.type ? function (t, e) { var n, i, r = K_(t, "ticks"), o = w_(e), a = $_(r, o); if (a) return a; e.get("show") && !t.scale.isBlank() || (n = []); if (X(o)) n = tb(t, o, !0); else if ("auto" === o) { var s = q_(t, t.getLabelModel()); i = s.labelCategoryInterval, n = z(s.labels, (function (t) { return t.tickValue })) } else n = Q_(t, i = o, !0); return J_(r, o, { ticks: n, tickCategoryInterval: i }) }(t, e) : { ticks: z(t.scale.getTicks(), (function (t) { return t.value })) } } function q_(t, e) { var n, i, r = K_(t, "labels"), o = w_(e), a = $_(r, o); return a || (X(o) ? n = tb(t, o) : (i = "auto" === o ? function (t) { var e = U_(t).autoInterval; return null != e ? e : U_(t).autoInterval = t.calculateCategoryInterval() }(t) : o, n = Q_(t, i)), J_(r, o, { labels: n, labelCategoryInterval: i })) } function K_(t, e) { return U_(t)[e] || (U_(t)[e] = []) } function $_(t, e) { for (var n = 0; n < t.length; n++)if (t[n].key === e) return t[n].value } function J_(t, e, n) { return t.push({ key: e, value: n }), n } function Q_(t, e, n) { var i = x_(t), r = t.scale, o = r.getExtent(), a = t.getLabelModel(), s = [], l = Math.max((e || 0) + 1, 1), u = o[0], h = r.count(); 0 !== u && l > 1 && h / l > 2 && (u = Math.round(Math.ceil(u / l) * l)); var c = S_(t), p = a.get("showMinLabel") || c, d = a.get("showMaxLabel") || c; p && u !== o[0] && g(o[0]); for (var f = u; f <= o[1]; f += l)g(f); function g(t) { var e = { value: t }; s.push(n ? t : { formattedLabel: i(e), rawLabel: r.getLabel(e), tickValue: t }) } return d && f - l !== o[1] && g(o[1]), s } function tb(t, e, n) { var i = t.scale, r = x_(t), o = []; return E(i.getTicks(), (function (t) { var a = i.getLabel(t), s = t.value; e(t.value, a) && o.push(n ? s : { formattedLabel: r(t), rawLabel: a, tickValue: s }) })), o } var eb = [0, 1], nb = function () { function t(t, e, n) { this.onBand = !1, this.inverse = !1, this.dim = t, this.scale = e, this._extent = n || [0, 0] } return t.prototype.contain = function (t) { var e = this._extent, n = Math.min(e[0], e[1]), i = Math.max(e[0], e[1]); return t >= n && t <= i }, t.prototype.containData = function (t) { return this.scale.contain(t) }, t.prototype.getExtent = function () { return this._extent.slice() }, t.prototype.getPixelPrecision = function (t) { return $r(t || this.scale.getExtent(), this._extent) }, t.prototype.setExtent = function (t, e) { var n = this._extent; n[0] = t, n[1] = e }, t.prototype.dataToCoord = function (t, e) { var n = this._extent, i = this.scale; return t = i.normalize(t), this.onBand && "ordinal" === i.type && ib(n = n.slice(), i.count()), Xr(t, eb, n, e) }, t.prototype.coordToData = function (t, e) { var n = this._extent, i = this.scale; this.onBand && "ordinal" === i.type && ib(n = n.slice(), i.count()); var r = Xr(t, n, eb, e); return this.scale.scale(r) }, t.prototype.pointToData = function (t, e) { }, t.prototype.getTicksCoords = function (t) { var e = (t = t || {}).tickModel || this.getTickModel(), n = z(j_(this, e).ticks, (function (t) { return { coord: this.dataToCoord("ordinal" === this.scale.type ? this.scale.getRawOrdinalNumber(t) : t), tickValue: t } }), this); return function (t, e, n, i) { var r = e.length; if (!t.onBand || n || !r) return; var o, a, s = t.getExtent(); if (1 === r) e[0].coord = s[0], o = e[1] = { coord: s[1] }; else { var l = e[r - 1].tickValue - e[0].tickValue, u = (e[r - 1].coord - e[0].coord) / l; E(e, (function (t) { t.coord -= u / 2 })), a = 1 + t.scale.getExtent()[1] - e[r - 1].tickValue, o = { coord: e[r - 1].coord + u * a }, e.push(o) } var h = s[0] > s[1]; c(e[0].coord, s[0]) && (i ? e[0].coord = s[0] : e.shift()); i && c(s[0], e[0].coord) && e.unshift({ coord: s[0] }); c(s[1], o.coord) && (i ? o.coord = s[1] : e.pop()); i && c(o.coord, s[1]) && e.push({ coord: s[1] }); function c(t, e) { return t = Zr(t), e = Zr(e), h ? t > e : t < e } }(this, n, e.get("alignWithLabel"), t.clamp), n }, t.prototype.getMinorTicksCoords = function () { if ("ordinal" === this.scale.type) return []; var t = this.model.getModel("minorTick").get("splitNumber"); return t > 0 && t < 100 || (t = 5), z(this.scale.getMinorTicks(t), (function (t) { return z(t, (function (t) { return { coord: this.dataToCoord(t), tickValue: t } }), this) }), this) }, t.prototype.getViewLabels = function () { return Z_(this).labels }, t.prototype.getLabelModel = function () { return this.model.getModel("axisLabel") }, t.prototype.getTickModel = function () { return this.model.getModel("axisTick") }, t.prototype.getBandWidth = function () { var t = this._extent, e = this.scale.getExtent(), n = e[1] - e[0] + (this.onBand ? 1 : 0); 0 === n && (n = 1); var i = Math.abs(t[1] - t[0]); return Math.abs(i) / n }, t.prototype.calculateCategoryInterval = function () { return function (t) { var e = function (t) { var e = t.getLabelModel(); return { axisRotate: t.getRotate ? t.getRotate() : t.isHorizontal && !t.isHorizontal() ? 90 : 0, labelRotate: e.get("rotate") || 0, font: e.getFont() } }(t), n = x_(t), i = (e.axisRotate - e.labelRotate) / 180 * Math.PI, r = t.scale, o = r.getExtent(), a = r.count(); if (o[1] - o[0] < 1) return 0; var s = 1; a > 40 && (s = Math.max(1, Math.floor(a / 40))); for (var l = o[0], u = t.dataToCoord(l + 1) - t.dataToCoord(l), h = Math.abs(u * Math.cos(i)), c = Math.abs(u * Math.sin(i)), p = 0, d = 0; l <= o[1]; l += s) { var f, g, y = br(n({ value: l }), e.font, "center", "top"); f = 1.3 * y.width, g = 1.3 * y.height, p = Math.max(p, f, 7), d = Math.max(d, g, 7) } var v = p / h, m = d / c; isNaN(v) && (v = 1 / 0), isNaN(m) && (m = 1 / 0); var x = Math.max(0, Math.floor(Math.min(v, m))), _ = U_(t.model), b = t.getExtent(), w = _.lastAutoInterval, S = _.lastTickCount; return null != w && null != S && Math.abs(w - x) <= 1 && Math.abs(S - a) <= 1 && w > x && _.axisExtent0 === b[0] && _.axisExtent1 === b[1] ? x = w : (_.lastTickCount = a, _.lastAutoInterval = x, _.axisExtent0 = b[0], _.axisExtent1 = b[1]), x }(this) }, t }(); function ib(t, e) { var n = (t[1] - t[0]) / e / 2; t[0] += n, t[1] -= n } var rb = 2 * Math.PI, ob = os.CMD, ab = ["top", "right", "bottom", "left"]; function sb(t, e, n, i, r) { var o = n.width, a = n.height; switch (t) { case "top": i.set(n.x + o / 2, n.y - e), r.set(0, -1); break; case "bottom": i.set(n.x + o / 2, n.y + a + e), r.set(0, 1); break; case "left": i.set(n.x - e, n.y + a / 2), r.set(-1, 0); break; case "right": i.set(n.x + o + e, n.y + a / 2), r.set(1, 0) } } function lb(t, e, n, i, r, o, a, s, l) { a -= t, s -= e; var u = Math.sqrt(a * a + s * s), h = (a /= u) * n + t, c = (s /= u) * n + e; if (Math.abs(i - r) % rb < 1e-4) return l[0] = h, l[1] = c, u - n; if (o) { var p = i; i = hs(r), r = hs(p) } else i = hs(i), r = hs(r); i > r && (r += rb); var d = Math.atan2(s, a); if (d < 0 && (d += rb), d >= i && d <= r || d + rb >= i && d + rb <= r) return l[0] = h, l[1] = c, u - n; var f = n * Math.cos(i) + t, g = n * Math.sin(i) + e, y = n * Math.cos(r) + t, v = n * Math.sin(r) + e, m = (f - a) * (f - a) + (g - s) * (g - s), x = (y - a) * (y - a) + (v - s) * (v - s); return m < x ? (l[0] = f, l[1] = g, Math.sqrt(m)) : (l[0] = y, l[1] = v, Math.sqrt(x)) } function ub(t, e, n, i, r, o, a, s) { var l = r - t, u = o - e, h = n - t, c = i - e, p = Math.sqrt(h * h + c * c), d = (l * (h /= p) + u * (c /= p)) / p; s && (d = Math.min(Math.max(d, 0), 1)), d *= p; var f = a[0] = t + d * h, g = a[1] = e + d * c; return Math.sqrt((f - r) * (f - r) + (g - o) * (g - o)) } function hb(t, e, n, i, r, o, a) { n < 0 && (t += n, n = -n), i < 0 && (e += i, i = -i); var s = t + n, l = e + i, u = a[0] = Math.min(Math.max(r, t), s), h = a[1] = Math.min(Math.max(o, e), l); return Math.sqrt((u - r) * (u - r) + (h - o) * (h - o)) } var cb = []; function pb(t, e, n) { var i = hb(e.x, e.y, e.width, e.height, t.x, t.y, cb); return n.set(cb[0], cb[1]), i } function db(t, e, n) { for (var i, r, o = 0, a = 0, s = 0, l = 0, u = 1 / 0, h = e.data, c = t.x, p = t.y, d = 0; d < h.length;) { var f = h[d++]; 1 === d && (s = o = h[d], l = a = h[d + 1]); var g = u; switch (f) { case ob.M: o = s = h[d++], a = l = h[d++]; break; case ob.L: g = ub(o, a, h[d], h[d + 1], c, p, cb, !0), o = h[d++], a = h[d++]; break; case ob.C: g = Sn(o, a, h[d++], h[d++], h[d++], h[d++], h[d], h[d + 1], c, p, cb), o = h[d++], a = h[d++]; break; case ob.Q: g = An(o, a, h[d++], h[d++], h[d], h[d + 1], c, p, cb), o = h[d++], a = h[d++]; break; case ob.A: var y = h[d++], v = h[d++], m = h[d++], x = h[d++], _ = h[d++], b = h[d++]; d += 1; var w = !!(1 - h[d++]); i = Math.cos(_) * m + y, r = Math.sin(_) * x + v, d <= 1 && (s = i, l = r), g = lb(y, v, x, _, _ + b, w, (c - y) * x / m + y, p, cb), o = Math.cos(_ + b) * m + y, a = Math.sin(_ + b) * x + v; break; case ob.R: g = hb(s = o = h[d++], l = a = h[d++], h[d++], h[d++], c, p, cb); break; case ob.Z: g = ub(o, a, s, l, c, p, cb, !0), o = s, a = l }g < u && (u = g, n.set(cb[0], cb[1])) } return u } var fb = new De, gb = new De, yb = new De, vb = new De, mb = new De; function xb(t, e) { if (t) { var n = t.getTextGuideLine(), i = t.getTextContent(); if (i && n) { var r = t.textGuideLineConfig || {}, o = [[0, 0], [0, 0], [0, 0]], a = r.candidates || ab, s = i.getBoundingRect().clone(); s.applyTransform(i.getComputedTransform()); var l = 1 / 0, u = r.anchor, h = t.getComputedTransform(), c = h && Ie([], h), p = e.get("length2") || 0; u && yb.copy(u); for (var d = 0; d < a.length; d++) { sb(a[d], 0, s, fb, vb), De.scaleAndAdd(gb, fb, vb, p), gb.transform(c); var f = t.getBoundingRect(), g = u ? u.distance(gb) : t instanceof Is ? db(gb, t.path, yb) : pb(gb, f, yb); g < l && (l = g, gb.transform(h), yb.transform(h), yb.toArray(o[0]), gb.toArray(o[1]), fb.toArray(o[2])) } wb(o, e.get("minTurnAngle")), n.setShape({ points: o }) } } } var _b = [], bb = new De; function wb(t, e) { if (e <= 180 && e > 0) { e = e / 180 * Math.PI, fb.fromArray(t[0]), gb.fromArray(t[1]), yb.fromArray(t[2]), De.sub(vb, fb, gb), De.sub(mb, yb, gb); var n = vb.len(), i = mb.len(); if (!(n < .001 || i < .001)) { vb.scale(1 / n), mb.scale(1 / i); var r = vb.dot(mb); if (Math.cos(e) < r) { var o = ub(gb.x, gb.y, yb.x, yb.y, fb.x, fb.y, _b, !1); bb.fromArray(_b), bb.scaleAndAdd(mb, o / Math.tan(Math.PI - e)); var a = yb.x !== gb.x ? (bb.x - gb.x) / (yb.x - gb.x) : (bb.y - gb.y) / (yb.y - gb.y); if (isNaN(a)) return; a < 0 ? De.copy(bb, gb) : a > 1 && De.copy(bb, yb), bb.toArray(t[1]) } } } } function Sb(t, e, n) { if (n <= 180 && n > 0) { n = n / 180 * Math.PI, fb.fromArray(t[0]), gb.fromArray(t[1]), yb.fromArray(t[2]), De.sub(vb, gb, fb), De.sub(mb, yb, gb); var i = vb.len(), r = mb.len(); if (!(i < .001 || r < .001)) if (vb.scale(1 / i), mb.scale(1 / r), vb.dot(e) < Math.cos(n)) { var o = ub(gb.x, gb.y, yb.x, yb.y, fb.x, fb.y, _b, !1); bb.fromArray(_b); var a = Math.PI / 2, s = a + Math.acos(mb.dot(e)) - n; if (s >= a) De.copy(bb, yb); else { bb.scaleAndAdd(mb, o / Math.tan(Math.PI / 2 - s)); var l = yb.x !== gb.x ? (bb.x - gb.x) / (yb.x - gb.x) : (bb.y - gb.y) / (yb.y - gb.y); if (isNaN(l)) return; l < 0 ? De.copy(bb, gb) : l > 1 && De.copy(bb, yb) } bb.toArray(t[1]) } } } function Mb(t, e, n, i) { var r = "normal" === n, o = r ? t : t.ensureState(n); o.ignore = e; var a = i.get("smooth"); a && !0 === a && (a = .3), o.shape = o.shape || {}, a > 0 && (o.shape.smooth = a); var s = i.getModel("lineStyle").getLineStyle(); r ? t.useStyle(s) : o.style = s } function Ib(t, e) { var n = e.smooth, i = e.points; if (i) if (t.moveTo(i[0][0], i[0][1]), n > 0 && i.length >= 3) { var r = Vt(i[0], i[1]), o = Vt(i[1], i[2]); if (!r || !o) return t.lineTo(i[1][0], i[1][1]), void t.lineTo(i[2][0], i[2][1]); var a = Math.min(r, o) * n, s = Gt([], i[1], i[0], a / r), l = Gt([], i[1], i[2], a / o), u = Gt([], s, l, .5); t.bezierCurveTo(s[0], s[1], s[0], s[1], u[0], u[1]), t.bezierCurveTo(l[0], l[1], l[0], l[1], i[2][0], i[2][1]) } else for (var h = 1; h < i.length; h++)t.lineTo(i[h][0], i[h][1]) } function Tb(t, e, n) { var i = t.getTextGuideLine(), r = t.getTextContent(); if (r) { for (var o = e.normal, a = o.get("show"), s = r.ignore, l = 0; l < al.length; l++) { var u = al[l], h = e[u], c = "normal" === u; if (h) { var p = h.get("show"); if ((c ? s : rt(r.states[u] && r.states[u].ignore, s)) || !rt(p, a)) { var d = c ? i : i && i.states[u]; d && (d.ignore = !0); continue } i || (i = new Yu, t.setTextGuideLine(i), c || !s && a || Mb(i, !0, "normal", e.normal), t.stateProxy && (i.stateProxy = t.stateProxy)), Mb(i, !1, u, h) } } if (i) { k(i.style, n), i.style.fill = null; var f = o.get("showAbove"); (t.textGuideLineConfig = t.textGuideLineConfig || {}).showAbove = f || !1, i.buildPath = Ib } } else i && t.removeTextGuideLine() } function Cb(t, e) { e = e || "labelLine"; for (var n = { normal: t.getModel(e) }, i = 0; i < ol.length; i++) { var r = ol[i]; n[r] = t.getModel([r, e]) } return n } function Db(t) { for (var e = [], n = 0; n < t.length; n++) { var i = t[n]; if (!i.defaultAttr.ignore) { var r = i.label, o = r.getComputedTransform(), a = r.getBoundingRect(), s = !o || o[1] < 1e-5 && o[2] < 1e-5, l = r.style.margin || 0, u = a.clone(); u.applyTransform(o), u.x -= l / 2, u.y -= l / 2, u.width += l, u.height += l; var h = s ? new lh(a, o) : null; e.push({ label: r, labelLine: i.labelLine, rect: u, localRect: a, obb: h, priority: i.priority, defaultAttr: i.defaultAttr, layoutOption: i.computedLayoutOption, axisAligned: s, transform: o }) } } return e } function Ab(t, e, n, i, r, o) { var a = t.length; if (!(a < 2)) { t.sort((function (t, n) { return t.rect[e] - n.rect[e] })); for (var s, l = 0, u = !1, h = 0, c = 0; c < a; c++) { var p = t[c], d = p.rect; (s = d[e] - l) < 0 && (d[e] -= s, p.label[e] -= s, u = !0), h += Math.max(-s, 0), l = d[e] + d[n] } h > 0 && o && _(-h / a, 0, a); var f, g, y = t[0], v = t[a - 1]; return m(), f < 0 && b(-f, .8), g < 0 && b(g, .8), m(), x(f, g, 1), x(g, f, -1), m(), f < 0 && w(-f), g < 0 && w(g), u } function m() { f = y.rect[e] - i, g = r - v.rect[e] - v.rect[n] } function x(t, e, n) { if (t < 0) { var i = Math.min(e, -t); if (i > 0) { _(i * n, 0, a); var r = i + t; r < 0 && b(-r * n, 1) } else b(-t * n, 1) } } function _(n, i, r) { 0 !== n && (u = !0); for (var o = i; o < r; o++) { var a = t[o]; a.rect[e] += n, a.label[e] += n } } function b(i, r) { for (var o = [], s = 0, l = 1; l < a; l++) { var u = t[l - 1].rect, h = Math.max(t[l].rect[e] - u[e] - u[n], 0); o.push(h), s += h } if (s) { var c = Math.min(Math.abs(i) / s, r); if (i > 0) for (l = 0; l < a - 1; l++) { _(o[l] * c, 0, l + 1) } else for (l = a - 1; l > 0; l--) { _(-(o[l - 1] * c), l, a) } } } function w(t) { var e = t < 0 ? -1 : 1; t = Math.abs(t); for (var n = Math.ceil(t / (a - 1)), i = 0; i < a - 1; i++)if (e > 0 ? _(n, 0, i + 1) : _(-n, a - i - 1, a), (t -= n) <= 0) return } } function kb(t, e, n, i) { return Ab(t, "y", "height", e, n, i) } function Lb(t) { var e = []; t.sort((function (t, e) { return e.priority - t.priority })); var n = new ze(0, 0, 0, 0); function i(t) { if (!t.ignore) { var e = t.ensureState("emphasis"); null == e.ignore && (e.ignore = !1) } t.ignore = !0 } for (var r = 0; r < t.length; r++) { var o = t[r], a = o.axisAligned, s = o.localRect, l = o.transform, u = o.label, h = o.labelLine; n.copy(o.rect), n.width -= .1, n.height -= .1, n.x += .05, n.y += .05; for (var c = o.obb, p = !1, d = 0; d < e.length; d++) { var f = e[d]; if (n.intersect(f.rect)) { if (a && f.axisAligned) { p = !0; break } if (f.obb || (f.obb = new lh(f.localRect, f.transform)), c || (c = new lh(s, l)), c.intersect(f.obb)) { p = !0; break } } } p ? (i(u), h && i(h)) : (u.attr("ignore", o.defaultAttr.ignore), h && h.attr("ignore", o.defaultAttr.labelGuideIgnore), e.push(o)) } } function Pb(t) { if (t) { for (var e = [], n = 0; n < t.length; n++)e.push(t[n].slice()); return e } } function Ob(t, e) { var n = t.label, i = e && e.getTextGuideLine(); return { dataIndex: t.dataIndex, dataType: t.dataType, seriesIndex: t.seriesModel.seriesIndex, text: t.label.style.text, rect: t.hostRect, labelRect: t.rect, align: n.style.align, verticalAlign: n.style.verticalAlign, labelLinePoints: Pb(i && i.shape.points) } } var Rb = ["align", "verticalAlign", "width", "height", "fontSize"], Nb = new gr, Eb = Oo(), zb = Oo(); function Vb(t, e, n) { for (var i = 0; i < n.length; i++) { var r = n[i]; null != e[r] && (t[r] = e[r]) } } var Bb = ["x", "y", "rotation"], Fb = function () { function t() { this._labelList = [], this._chartViewList = [] } return t.prototype.clearLabels = function () { this._labelList = [], this._chartViewList = [] }, t.prototype._addLabel = function (t, e, n, i, r) { var o = i.style, a = i.__hostTarget.textConfig || {}, s = i.getComputedTransform(), l = i.getBoundingRect().plain(); ze.applyTransform(l, l, s), s ? Nb.setLocalTransform(s) : (Nb.x = Nb.y = Nb.rotation = Nb.originX = Nb.originY = 0, Nb.scaleX = Nb.scaleY = 1), Nb.rotation = hs(Nb.rotation); var u, h = i.__hostTarget; if (h) { u = h.getBoundingRect().plain(); var c = h.getComputedTransform(); ze.applyTransform(u, u, c) } var p = u && h.getTextGuideLine(); this._labelList.push({ label: i, labelLine: p, seriesModel: n, dataIndex: t, dataType: e, layoutOption: r, computedLayoutOption: null, rect: l, hostRect: u, priority: u ? u.width * u.height : 0, defaultAttr: { ignore: i.ignore, labelGuideIgnore: p && p.ignore, x: Nb.x, y: Nb.y, scaleX: Nb.scaleX, scaleY: Nb.scaleY, rotation: Nb.rotation, style: { x: o.x, y: o.y, align: o.align, verticalAlign: o.verticalAlign, width: o.width, height: o.height, fontSize: o.fontSize }, cursor: i.cursor, attachedPos: a.position, attachedRot: a.rotation } }) }, t.prototype.addLabelsOfSeries = function (t) { var e = this; this._chartViewList.push(t); var n = t.__model, i = n.get("labelLayout"); (X(i) || G(i).length) && t.group.traverse((function (t) { if (t.ignore) return !0; var r = t.getTextContent(), o = Qs(t); r && !r.disableLabelLayout && e._addLabel(o.dataIndex, o.dataType, n, r, i) })) }, t.prototype.updateLayoutConfig = function (t) { var e = t.getWidth(), n = t.getHeight(); function i(t, e) { return function () { xb(t, e) } } for (var r = 0; r < this._labelList.length; r++) { var o = this._labelList[r], a = o.label, s = a.__hostTarget, l = o.defaultAttr, u = void 0; u = (u = X(o.layoutOption) ? o.layoutOption(Ob(o, s)) : o.layoutOption) || {}, o.computedLayoutOption = u; var h = Math.PI / 180; s && s.setTextConfig({ local: !1, position: null != u.x || null != u.y ? null : l.attachedPos, rotation: null != u.rotate ? u.rotate * h : l.attachedRot, offset: [u.dx || 0, u.dy || 0] }); var c = !1; if (null != u.x ? (a.x = Ur(u.x, e), a.setStyle("x", 0), c = !0) : (a.x = l.x, a.setStyle("x", l.style.x)), null != u.y ? (a.y = Ur(u.y, n), a.setStyle("y", 0), c = !0) : (a.y = l.y, a.setStyle("y", l.style.y)), u.labelLinePoints) { var p = s.getTextGuideLine(); p && (p.setShape({ points: u.labelLinePoints }), c = !1) } Eb(a).needsUpdateLabelLine = c, a.rotation = null != u.rotate ? u.rotate * h : l.rotation, a.scaleX = l.scaleX, a.scaleY = l.scaleY; for (var d = 0; d < Rb.length; d++) { var f = Rb[d]; a.setStyle(f, null != u[f] ? u[f] : l.style[f]) } if (u.draggable) { if (a.draggable = !0, a.cursor = "move", s) { var g = o.seriesModel; if (null != o.dataIndex) g = o.seriesModel.getData(o.dataType).getItemModel(o.dataIndex); a.on("drag", i(s, g.getModel("labelLine"))) } } else a.off("drag"), a.cursor = l.cursor } }, t.prototype.layout = function (t) { var e, n = t.getWidth(), i = t.getHeight(), r = Db(this._labelList), o = B(r, (function (t) { return "shiftX" === t.layoutOption.moveOverlap })), a = B(r, (function (t) { return "shiftY" === t.layoutOption.moveOverlap })); Ab(o, "x", "width", 0, n, e), kb(a, 0, i), Lb(B(r, (function (t) { return t.layoutOption.hideOverlap }))) }, t.prototype.processLabelsOverall = function () { var t = this; E(this._chartViewList, (function (e) { var n = e.__model, i = e.ignoreLabelLineUpdate, r = n.isAnimationEnabled(); e.group.traverse((function (e) { if (e.ignore && !e.forceLabelAnimation) return !0; var o = !i, a = e.getTextContent(); !o && a && (o = Eb(a).needsUpdateLabelLine), o && t._updateLabelLine(e, n), r && t._animateLabels(e, n) })) })) }, t.prototype._updateLabelLine = function (t, e) { var n = t.getTextContent(), i = Qs(t), r = i.dataIndex; if (n && null != r) { var o = e.getData(i.dataType), a = o.getItemModel(r), s = {}, l = o.getItemVisual(r, "style"); if (l) { var u = o.getVisual("drawType"); s.stroke = l[u] } var h = a.getModel("labelLine"); Tb(t, Cb(a), s), xb(t, h) } }, t.prototype._animateLabels = function (t, e) { var n = t.getTextContent(), i = t.getTextGuideLine(); if (n && (t.forceLabelAnimation || !n.ignore && !n.invisible && !t.disableLabelAnimation && !yh(t))) { var r = (d = Eb(n)).oldLayout, o = Qs(t), a = o.dataIndex, s = { x: n.x, y: n.y, rotation: n.rotation }, l = e.getData(o.dataType); if (r) { n.attr(r); var u = t.prevStates; u && (P(u, "select") >= 0 && n.attr(d.oldLayoutSelect), P(u, "emphasis") >= 0 && n.attr(d.oldLayoutEmphasis)), fh(n, s, e, a) } else if (n.attr(s), !uc(n).valueAnimation) { var h = rt(n.style.opacity, 1); n.style.opacity = 0, gh(n, { style: { opacity: h } }, e, a) } if (d.oldLayout = s, n.states.select) { var c = d.oldLayoutSelect = {}; Vb(c, s, Bb), Vb(c, n.states.select, Bb) } if (n.states.emphasis) { var p = d.oldLayoutEmphasis = {}; Vb(p, s, Bb), Vb(p, n.states.emphasis, Bb) } cc(n, a, l, e, e) } if (i && !i.ignore && !i.invisible) { r = (d = zb(i)).oldLayout; var d, f = { points: i.shape.points }; r ? (i.attr({ shape: r }), fh(i, { shape: f }, e)) : (i.setShape(f), i.style.strokePercent = 0, gh(i, { style: { strokePercent: 1 } }, e)), d.oldLayout = f } }, t }(), Gb = Oo(); var Wb = Math.sin, Hb = Math.cos, Yb = Math.PI, Xb = 2 * Math.PI, Ub = 180 / Yb, Zb = function () { function t() { } return t.prototype.reset = function (t) { this._start = !0, this._d = [], this._str = "", this._p = Math.pow(10, t || 4) }, t.prototype.moveTo = function (t, e) { this._add("M", t, e) }, t.prototype.lineTo = function (t, e) { this._add("L", t, e) }, t.prototype.bezierCurveTo = function (t, e, n, i, r, o) { this._add("C", t, e, n, i, r, o) }, t.prototype.quadraticCurveTo = function (t, e, n, i) { this._add("Q", t, e, n, i) }, t.prototype.arc = function (t, e, n, i, r, o) { this.ellipse(t, e, n, n, 0, i, r, o) }, t.prototype.ellipse = function (t, e, n, i, r, o, a, s) { var l = a - o, u = !s, h = Math.abs(l), c = hi(h - Xb) || (u ? l >= Xb : -l >= Xb), p = l > 0 ? l % Xb : l % Xb + Xb, d = !1; d = !!c || !hi(h) && p >= Yb == !!u; var f = t + n * Hb(o), g = e + i * Wb(o); this._start && this._add("M", f, g); var y = Math.round(r * Ub); if (c) { var v = 1 / this._p, m = (u ? 1 : -1) * (Xb - v); this._add("A", n, i, y, 1, +u, t + n * Hb(o + m), e + i * Wb(o + m)), v > .01 && this._add("A", n, i, y, 0, +u, f, g) } else { var x = t + n * Hb(a), _ = e + i * Wb(a); this._add("A", n, i, y, +d, +u, x, _) } }, t.prototype.rect = function (t, e, n, i) { this._add("M", t, e), this._add("l", n, 0), this._add("l", 0, i), this._add("l", -n, 0), this._add("Z") }, t.prototype.closePath = function () { this._d.length > 0 && this._add("Z") }, t.prototype._add = function (t, e, n, i, r, o, a, s, l) { for (var u = [], h = this._p, c = 1; c < arguments.length; c++) { var p = arguments[c]; if (isNaN(p)) return void (this._invalid = !0); u.push(Math.round(p * h) / h) } this._d.push(t + u.join(" ")), this._start = "Z" === t }, t.prototype.generateStr = function () { this._str = this._invalid ? "" : this._d.join(""), this._d = [] }, t.prototype.getStr = function () { return this._str }, t }(), jb = "none", qb = Math.round; var Kb = ["lineCap", "miterLimit", "lineJoin"], $b = z(Kb, (function (t) { return "stroke-" + t.toLowerCase() })); function Jb(t, e, n, i) { var r = null == e.opacity ? 1 : e.opacity; if (n instanceof ks) t("opacity", r); else { if (function (t) { var e = t.fill; return null != e && e !== jb }(e)) { var o = li(e.fill); t("fill", o.color); var a = null != e.fillOpacity ? e.fillOpacity * o.opacity * r : o.opacity * r; (i || a < 1) && t("fill-opacity", a) } else t("fill", jb); if (function (t) { var e = t.stroke; return null != e && e !== jb }(e)) { var s = li(e.stroke); t("stroke", s.color); var l = e.strokeNoScale ? n.getLineScale() : 1, u = l ? (e.lineWidth || 0) / l : 0, h = null != e.strokeOpacity ? e.strokeOpacity * s.opacity * r : s.opacity * r, c = e.strokeFirst; if ((i || 1 !== u) && t("stroke-width", u), (i || c) && t("paint-order", c ? "stroke" : "fill"), (i || h < 1) && t("stroke-opacity", h), e.lineDash) { var p = qy(n), d = p[0], f = p[1]; d && (f = qb(f || 0), t("stroke-dasharray", d.join(",")), (f || i) && t("stroke-dashoffset", f)) } else i && t("stroke-dasharray", jb); for (var g = 0; g < Kb.length; g++) { var y = Kb[g]; if (i || e[y] !== ws[y]) { var v = e[y] || ws[y]; v && t($b[g], v) } } } else i && t("stroke", jb) } } var Qb = "http://www.w3.org/2000/svg", tw = "http://www.w3.org/1999/xlink"; function ew(t) { return document.createElementNS(Qb, t) } function nw(t, e, n, i, r) { return { tag: t, attrs: n || {}, children: i, text: r, key: e } } function iw(t, e) { var n = (e = e || {}).newline ? "\n" : ""; return function t(e) { var i = e.children, r = e.tag, o = e.attrs, a = e.text; return function (t, e) { var n = []; if (e) for (var i in e) { var r = e[i], o = i; !1 !== r && (!0 !== r && null != r && (o += '="' + r + '"'), n.push(o)) } return "<" + t + " " + n.join(" ") + ">" }(r, o) + ("style" !== r ? re(a) : a || "") + (i ? "" + n + z(i, (function (e) { return t(e) })).join(n) + n : "") + ("</" + r + ">") }(t) } function rw(t) { return { zrId: t, shadowCache: {}, patternCache: {}, gradientCache: {}, clipPathCache: {}, defs: {}, cssNodes: {}, cssAnims: {}, cssClassIdx: 0, cssAnimIdx: 0, shadowIdx: 0, gradientIdx: 0, patternIdx: 0, clipPathIdx: 0 } } function ow(t, e, n, i) { return nw("svg", "root", { width: t, height: e, xmlns: Qb, "xmlns:xlink": tw, version: "1.1", baseProfile: "full", viewBox: !!i && "0 0 " + t + " " + e }, n) } var aw = { cubicIn: "0.32,0,0.67,0", cubicOut: "0.33,1,0.68,1", cubicInOut: "0.65,0,0.35,1", quadraticIn: "0.11,0,0.5,0", quadraticOut: "0.5,1,0.89,1", quadraticInOut: "0.45,0,0.55,1", quarticIn: "0.5,0,0.75,0", quarticOut: "0.25,1,0.5,1", quarticInOut: "0.76,0,0.24,1", quinticIn: "0.64,0,0.78,0", quinticOut: "0.22,1,0.36,1", quinticInOut: "0.83,0,0.17,1", sinusoidalIn: "0.12,0,0.39,0", sinusoidalOut: "0.61,1,0.88,1", sinusoidalInOut: "0.37,0,0.63,1", exponentialIn: "0.7,0,0.84,0", exponentialOut: "0.16,1,0.3,1", exponentialInOut: "0.87,0,0.13,1", circularIn: "0.55,0,1,0.45", circularOut: "0,0.55,0.45,1", circularInOut: "0.85,0,0.15,1" }, sw = "transform-origin"; function lw(t, e, n) { var i = A({}, t.shape); A(i, e), t.buildPath(n, i); var r = new Zb; return r.reset(_i(t)), n.rebuildPath(r, 1), r.generateStr(), r.getStr() } function uw(t, e) { var n = e.originX, i = e.originY; (n || i) && (t[sw] = n + "px " + i + "px") } var hw = { fill: "fill", opacity: "opacity", lineWidth: "stroke-width", lineDashOffset: "stroke-dashoffset" }; function cw(t, e) { var n = e.zrId + "-ani-" + e.cssAnimIdx++; return e.cssAnims[n] = t, n } function pw(t) { return U(t) ? aw[t] ? "cubic-bezier(" + aw[t] + ")" : Pn(t) ? t : "" : "" } function dw(t, e, n, i) { var r = t.animators, o = r.length, a = []; if (t instanceof th) { var s = function (t, e, n) { var i, r, o = t.shape.paths, a = {}; if (E(o, (function (t) { var e = rw(n.zrId); e.animation = !0, dw(t, {}, e, !0); var o = e.cssAnims, s = e.cssNodes, l = G(o), u = l.length; if (u) { var h = o[r = l[u - 1]]; for (var c in h) { var p = h[c]; a[c] = a[c] || { d: "" }, a[c].d += p.d || "" } for (var d in s) { var f = s[d].animation; f.indexOf(r) >= 0 && (i = f) } } })), i) { e.d = !1; var s = cw(a, n); return i.replace(r, s) } }(t, e, n); if (s) a.push(s); else if (!o) return } else if (!o) return; for (var l = {}, u = 0; u < o; u++) { var h = r[u], c = [h.getMaxTime() / 1e3 + "s"], p = pw(h.getClip().easing), d = h.getDelay(); p ? c.push(p) : c.push("linear"), d && c.push(d / 1e3 + "s"), h.getLoop() && c.push("infinite"); var f = c.join(" "); l[f] = l[f] || [f, []], l[f][1].push(h) } function g(r) { var o, a = r[1], s = a.length, l = {}, u = {}, h = {}, c = "animation-timing-function"; function p(t, e, n) { for (var i = t.getTracks(), r = t.getMaxTime(), o = 0; o < i.length; o++) { var a = i[o]; if (a.needsAnimate()) { var s = a.keyframes, l = a.propName; if (n && (l = n(l)), l) for (var u = 0; u < s.length; u++) { var h = s[u], p = Math.round(h.time / r * 100) + "%", d = pw(h.easing), f = h.rawValue; (U(f) || j(f)) && (e[p] = e[p] || {}, e[p][l] = h.rawValue, d && (e[p][c] = d)) } } } } for (var d = 0; d < s; d++) { (S = (w = a[d]).targetName) ? "shape" === S && p(w, u) : !i && p(w, l) } for (var f in l) { var g = {}; vr(g, t), A(g, l[f]); var y = bi(g), v = l[f][c]; h[f] = y ? { transform: y } : {}, uw(h[f], g), v && (h[f][c] = v) } var m = !0; for (var f in u) { h[f] = h[f] || {}; var x = !o; v = u[f][c]; x && (o = new os); var _ = o.len(); o.reset(), h[f].d = lw(t, u[f], o); var b = o.len(); if (!x && _ !== b) { m = !1; break } v && (h[f][c] = v) } if (!m) for (var f in h) delete h[f].d; if (!i) for (d = 0; d < s; d++) { var w, S; "style" === (S = (w = a[d]).targetName) && p(w, h, (function (t) { return hw[t] })) } var M, I = G(h), T = !0; for (d = 1; d < I.length; d++) { var C = I[d - 1], D = I[d]; if (h[C][sw] !== h[D][sw]) { T = !1; break } M = h[C][sw] } if (T && M) { for (var f in h) h[f][sw] && delete h[f][sw]; e[sw] = M } if (B(I, (function (t) { return G(h[t]).length > 0 })).length) return cw(h, n) + " " + r[0] + " both" } for (var y in l) { (s = g(l[y])) && a.push(s) } if (a.length) { var v = n.zrId + "-cls-" + n.cssClassIdx++; n.cssNodes["." + v] = { animation: a.join(",") }, e.class = v } } var fw = Math.round; function gw(t) { return t && U(t.src) } function yw(t) { return t && X(t.toDataURL) } function vw(t, e, n, i) { Jb((function (r, o) { var a = "fill" === r || "stroke" === r; a && mi(o) ? Cw(e, t, r, i) : a && gi(o) ? Dw(n, t, r, i) : t[r] = o }), e, n, !1), function (t, e, n) { var i = t.style; if (function (t) { return t && (t.shadowBlur || t.shadowOffsetX || t.shadowOffsetY) }(i)) { var r = function (t) { var e = t.style, n = t.getGlobalScale(); return [e.shadowColor, (e.shadowBlur || 0).toFixed(2), (e.shadowOffsetX || 0).toFixed(2), (e.shadowOffsetY || 0).toFixed(2), n[0], n[1]].join(",") }(t), o = n.shadowCache, a = o[r]; if (!a) { var s = t.getGlobalScale(), l = s[0], u = s[1]; if (!l || !u) return; var h = i.shadowOffsetX || 0, c = i.shadowOffsetY || 0, p = i.shadowBlur, d = li(i.shadowColor), f = d.opacity, g = d.color, y = p / 2 / l + " " + p / 2 / u; a = n.zrId + "-s" + n.shadowIdx++, n.defs[a] = nw("filter", a, { id: a, x: "-100%", y: "-100%", width: "300%", height: "300%" }, [nw("feDropShadow", "", { dx: h / l, dy: c / u, stdDeviation: y, "flood-color": g, "flood-opacity": f })]), o[r] = a } e.filter = xi(a) } }(n, t, i) } function mw(t) { return hi(t[0] - 1) && hi(t[1]) && hi(t[2]) && hi(t[3] - 1) } function xw(t, e, n) { if (e && (!function (t) { return hi(t[4]) && hi(t[5]) }(e) || !mw(e))) { var i = n ? 10 : 1e4; t.transform = mw(e) ? "translate(" + fw(e[4] * i) / i + " " + fw(e[5] * i) / i + ")" : function (t) { return "matrix(" + ci(t[0]) + "," + ci(t[1]) + "," + ci(t[2]) + "," + ci(t[3]) + "," + pi(t[4]) + "," + pi(t[5]) + ")" }(e) } } function _w(t, e, n) { for (var i = t.points, r = [], o = 0; o < i.length; o++)r.push(fw(i[o][0] * n) / n), r.push(fw(i[o][1] * n) / n); e.points = r.join(" ") } function bw(t) { return !t.smooth } var ww, Sw, Mw = { circle: [(ww = ["cx", "cy", "r"], Sw = z(ww, (function (t) { return "string" == typeof t ? [t, t] : t })), function (t, e, n) { for (var i = 0; i < Sw.length; i++) { var r = Sw[i], o = t[r[0]]; null != o && (e[r[1]] = fw(o * n) / n) } })], polyline: [_w, bw], polygon: [_w, bw] }; function Iw(t, e) { var n = t.style, i = t.shape, r = Mw[t.type], o = {}, a = e.animation, s = "path", l = t.style.strokePercent, u = e.compress && _i(t) || 4; if (!r || e.willUpdate || r[1] && !r[1](i) || a && function (t) { for (var e = t.animators, n = 0; n < e.length; n++)if ("shape" === e[n].targetName) return !0; return !1 }(t) || l < 1) { var h = !t.path || t.shapeChanged(); t.path || t.createPathProxy(); var c = t.path; h && (c.beginPath(), t.buildPath(c, t.shape), t.pathUpdated()); var p = c.getVersion(), d = t, f = d.__svgPathBuilder; d.__svgPathVersion === p && f && l === d.__svgPathStrokePercent || (f || (f = d.__svgPathBuilder = new Zb), f.reset(u), c.rebuildPath(f, l), f.generateStr(), d.__svgPathVersion = p, d.__svgPathStrokePercent = l), o.d = f.getStr() } else { s = t.type; var g = Math.pow(10, u); r[0](i, o, g) } return xw(o, t.transform), vw(o, n, t, e), e.animation && dw(t, o, e), nw(s, t.id + "", o) } function Tw(t, e) { return t instanceof Is ? Iw(t, e) : t instanceof ks ? function (t, e) { var n = t.style, i = n.image; if (i && !U(i) && (gw(i) ? i = i.src : yw(i) && (i = i.toDataURL())), i) { var r = n.x || 0, o = n.y || 0, a = { href: i, width: n.width, height: n.height }; return r && (a.x = r), o && (a.y = o), xw(a, t.transform), vw(a, n, t, e), e.animation && dw(t, a, e), nw("image", t.id + "", a) } }(t, e) : t instanceof Cs ? function (t, e) { var n = t.style, i = n.text; if (null != i && (i += ""), i && !isNaN(n.x) && !isNaN(n.y)) { var r = n.font || a, s = n.x || 0, l = function (t, e, n) { return "top" === n ? t += e / 2 : "bottom" === n && (t -= e / 2), t }(n.y || 0, Mr(r), n.textBaseline), u = { "dominant-baseline": "central", "text-anchor": di[n.textAlign] || n.textAlign }; if (Us(n)) { var h = "", c = n.fontStyle, p = Ys(n.fontSize); if (!parseFloat(p)) return; var d = n.fontFamily || o, f = n.fontWeight; h += "font-size:" + p + ";font-family:" + d + ";", c && "normal" !== c && (h += "font-style:" + c + ";"), f && "normal" !== f && (h += "font-weight:" + f + ";"), u.style = h } else u.style = "font: " + r; return i.match(/\s/) && (u["xml:space"] = "preserve"), s && (u.x = s), l && (u.y = l), xw(u, t.transform), vw(u, n, t, e), e.animation && dw(t, u, e), nw("text", t.id + "", u, void 0, i) } }(t, e) : void 0 } function Cw(t, e, n, i) { var r, o = t[n], a = { gradientUnits: o.global ? "userSpaceOnUse" : "objectBoundingBox" }; if (yi(o)) r = "linearGradient", a.x1 = o.x, a.y1 = o.y, a.x2 = o.x2, a.y2 = o.y2; else { if (!vi(o)) return void 0; r = "radialGradient", a.cx = rt(o.x, .5), a.cy = rt(o.y, .5), a.r = rt(o.r, .5) } for (var s = o.colorStops, l = [], u = 0, h = s.length; u < h; ++u) { var c = 100 * pi(s[u].offset) + "%", p = li(s[u].color), d = p.color, f = p.opacity, g = { offset: c }; g["stop-color"] = d, f < 1 && (g["stop-opacity"] = f), l.push(nw("stop", u + "", g)) } var y = iw(nw(r, "", a, l)), v = i.gradientCache, m = v[y]; m || (m = i.zrId + "-g" + i.gradientIdx++, v[y] = m, a.id = m, i.defs[m] = nw(r, m, a, l)), e[n] = xi(m) } function Dw(t, e, n, i) { var r, o = t.style[n], a = t.getBoundingRect(), s = {}, l = o.repeat, u = "no-repeat" === l, h = "repeat-x" === l, c = "repeat-y" === l; if (fi(o)) { var p = o.imageWidth, d = o.imageHeight, f = void 0, g = o.image; if (U(g) ? f = g : gw(g) ? f = g.src : yw(g) && (f = g.toDataURL()), "undefined" == typeof Image) { var y = "Image width/height must been given explictly in svg-ssr renderer."; lt(p, y), lt(d, y) } else if (null == p || null == d) { var v = function (t, e) { if (t) { var n = t.elm, i = p || e.width, r = d || e.height; "pattern" === t.tag && (h ? (r = 1, i /= a.width) : c && (i = 1, r /= a.height)), t.attrs.width = i, t.attrs.height = r, n && (n.setAttribute("width", i), n.setAttribute("height", r)) } }, m = ia(f, null, t, (function (t) { u || v(w, t), v(r, t) })); m && m.width && m.height && (p = p || m.width, d = d || m.height) } r = nw("image", "img", { href: f, width: p, height: d }), s.width = p, s.height = d } else o.svgElement && (r = T(o.svgElement), s.width = o.svgWidth, s.height = o.svgHeight); if (r) { var x, _; u ? x = _ = 1 : h ? (_ = 1, x = s.width / a.width) : c ? (x = 1, _ = s.height / a.height) : s.patternUnits = "userSpaceOnUse", null == x || isNaN(x) || (s.width = x), null == _ || isNaN(_) || (s.height = _); var b = bi(o); b && (s.patternTransform = b); var w = nw("pattern", "", s, [r]), S = iw(w), M = i.patternCache, I = M[S]; I || (I = i.zrId + "-p" + i.patternIdx++, M[S] = I, s.id = I, w = i.defs[I] = nw("pattern", I, s, [r])), e[n] = xi(I) } } function Aw(t, e, n) { var i = n.clipPathCache, r = n.defs, o = i[t.id]; if (!o) { var a = { id: o = n.zrId + "-c" + n.clipPathIdx++ }; i[t.id] = o, r[o] = nw("clipPath", o, a, [Iw(t, n)]) } e["clip-path"] = xi(o) } function kw(t) { return document.createTextNode(t) } function Lw(t, e, n) { t.insertBefore(e, n) } function Pw(t, e) { t.removeChild(e) } function Ow(t, e) { t.appendChild(e) } function Rw(t) { return t.parentNode } function Nw(t) { return t.nextSibling } function Ew(t, e) { t.textContent = e } var zw = nw("", ""); function Vw(t) { return void 0 === t } function Bw(t) { return void 0 !== t } function Fw(t, e, n) { for (var i = {}, r = e; r <= n; ++r) { var o = t[r].key; void 0 !== o && (i[o] = r) } return i } function Gw(t, e) { var n = t.key === e.key; return t.tag === e.tag && n } function Ww(t) { var e, n = t.children, i = t.tag; if (Bw(i)) { var r = t.elm = ew(i); if (Xw(zw, t), Y(n)) for (e = 0; e < n.length; ++e) { var o = n[e]; null != o && Ow(r, Ww(o)) } else Bw(t.text) && !q(t.text) && Ow(r, kw(t.text)) } else t.elm = kw(t.text); return t.elm } function Hw(t, e, n, i, r) { for (; i <= r; ++i) { var o = n[i]; null != o && Lw(t, Ww(o), e) } } function Yw(t, e, n, i) { for (; n <= i; ++n) { var r = e[n]; if (null != r) if (Bw(r.tag)) Pw(Rw(r.elm), r.elm); else Pw(t, r.elm) } } function Xw(t, e) { var n, i = e.elm, r = t && t.attrs || {}, o = e.attrs || {}; if (r !== o) { for (n in o) { var a = o[n]; r[n] !== a && (!0 === a ? i.setAttribute(n, "") : !1 === a ? i.removeAttribute(n) : 120 !== n.charCodeAt(0) ? i.setAttribute(n, a) : "xmlns:xlink" === n || "xmlns" === n ? i.setAttributeNS("http://www.w3.org/2000/xmlns/", n, a) : 58 === n.charCodeAt(3) ? i.setAttributeNS("http://www.w3.org/XML/1998/namespace", n, a) : 58 === n.charCodeAt(5) ? i.setAttributeNS(tw, n, a) : i.setAttribute(n, a)) } for (n in r) n in o || i.removeAttribute(n) } } function Uw(t, e) { var n = e.elm = t.elm, i = t.children, r = e.children; t !== e && (Xw(t, e), Vw(e.text) ? Bw(i) && Bw(r) ? i !== r && function (t, e, n) { for (var i, r, o, a = 0, s = 0, l = e.length - 1, u = e[0], h = e[l], c = n.length - 1, p = n[0], d = n[c]; a <= l && s <= c;)null == u ? u = e[++a] : null == h ? h = e[--l] : null == p ? p = n[++s] : null == d ? d = n[--c] : Gw(u, p) ? (Uw(u, p), u = e[++a], p = n[++s]) : Gw(h, d) ? (Uw(h, d), h = e[--l], d = n[--c]) : Gw(u, d) ? (Uw(u, d), Lw(t, u.elm, Nw(h.elm)), u = e[++a], d = n[--c]) : Gw(h, p) ? (Uw(h, p), Lw(t, h.elm, u.elm), h = e[--l], p = n[++s]) : (Vw(i) && (i = Fw(e, a, l)), Vw(r = i[p.key]) || (o = e[r]).tag !== p.tag ? Lw(t, Ww(p), u.elm) : (Uw(o, p), e[r] = void 0, Lw(t, o.elm, u.elm)), p = n[++s]); (a <= l || s <= c) && (a > l ? Hw(t, null == n[c + 1] ? null : n[c + 1].elm, n, s, c) : Yw(t, e, a, l)) }(n, i, r) : Bw(r) ? (Bw(t.text) && Ew(n, ""), Hw(n, null, r, 0, r.length - 1)) : Bw(i) ? Yw(n, i, 0, i.length - 1) : Bw(t.text) && Ew(n, "") : t.text !== e.text && (Bw(i) && Yw(n, i, 0, i.length - 1), Ew(n, e.text))) } var Zw = 0, jw = function () { function t(t, e, n) { if (this.type = "svg", this.refreshHover = qw("refreshHover"), this.configLayer = qw("configLayer"), this.storage = e, this._opts = n = A({}, n), this.root = t, this._id = "zr" + Zw++, this._oldVNode = ow(n.width, n.height), t && !n.ssr) { var i = this._viewport = document.createElement("div"); i.style.cssText = "position:relative;overflow:hidden"; var r = this._svgDom = this._oldVNode.elm = ew("svg"); Xw(null, this._oldVNode), i.appendChild(r), t.appendChild(i) } this.resize(n.width, n.height) } return t.prototype.getType = function () { return this.type }, t.prototype.getViewportRoot = function () { return this._viewport }, t.prototype.getViewportRootOffset = function () { var t = this.getViewportRoot(); if (t) return { offsetLeft: t.offsetLeft || 0, offsetTop: t.offsetTop || 0 } }, t.prototype.getSvgDom = function () { return this._svgDom }, t.prototype.refresh = function () { if (this.root) { var t = this.renderToVNode({ willUpdate: !0 }); t.attrs.style = "position:absolute;left:0;top:0;user-select:none", function (t, e) { if (Gw(t, e)) Uw(t, e); else { var n = t.elm, i = Rw(n); Ww(e), null !== i && (Lw(i, e.elm, Nw(n)), Yw(i, [t], 0, 0)) } }(this._oldVNode, t), this._oldVNode = t } }, t.prototype.renderOneToVNode = function (t) { return Tw(t, rw(this._id)) }, t.prototype.renderToVNode = function (t) { t = t || {}; var e = this.storage.getDisplayList(!0), n = this._width, i = this._height, r = rw(this._id); r.animation = t.animation, r.willUpdate = t.willUpdate, r.compress = t.compress; var o = [], a = this._bgVNode = function (t, e, n, i) { var r; if (n && "none" !== n) if (r = nw("rect", "bg", { width: t, height: e, x: "0", y: "0", id: "0" }), mi(n)) Cw({ fill: n }, r.attrs, "fill", i); else if (gi(n)) Dw({ style: { fill: n }, dirty: bt, getBoundingRect: function () { return { width: t, height: e } } }, r.attrs, "fill", i); else { var o = li(n), a = o.color, s = o.opacity; r.attrs.fill = a, s < 1 && (r.attrs["fill-opacity"] = s) } return r }(n, i, this._backgroundColor, r); a && o.push(a); var s = t.compress ? null : this._mainVNode = nw("g", "main", {}, []); this._paintList(e, r, s ? s.children : o), s && o.push(s); var l = z(G(r.defs), (function (t) { return r.defs[t] })); if (l.length && o.push(nw("defs", "defs", {}, l)), t.animation) { var u = function (t, e, n) { var i = (n = n || {}).newline ? "\n" : "", r = " {" + i, o = i + "}", a = z(G(t), (function (e) { return e + r + z(G(t[e]), (function (n) { return n + ":" + t[e][n] + ";" })).join(i) + o })).join(i), s = z(G(e), (function (t) { return "@keyframes " + t + r + z(G(e[t]), (function (n) { return n + r + z(G(e[t][n]), (function (i) { var r = e[t][n][i]; return "d" === i && (r = 'path("' + r + '")'), i + ":" + r + ";" })).join(i) + o })).join(i) + o })).join(i); return a || s ? ["<![CDATA[", a, s, "]]>"].join(i) : "" }(r.cssNodes, r.cssAnims, { newline: !0 }); if (u) { var h = nw("style", "stl", {}, [], u); o.push(h) } } return ow(n, i, o, t.useViewBox) }, t.prototype.renderToString = function (t) { return t = t || {}, iw(this.renderToVNode({ animation: rt(t.cssAnimation, !0), willUpdate: !1, compress: !0, useViewBox: rt(t.useViewBox, !0) }), { newline: !0 }) }, t.prototype.setBackgroundColor = function (t) { this._backgroundColor = t }, t.prototype.getSvgRoot = function () { return this._mainVNode && this._mainVNode.elm }, t.prototype._paintList = function (t, e, n) { for (var i, r, o = t.length, a = [], s = 0, l = 0, u = 0; u < o; u++) { var h = t[u]; if (!h.invisible) { var c = h.__clipPaths, p = c && c.length || 0, d = r && r.length || 0, f = void 0; for (f = Math.max(p - 1, d - 1); f >= 0 && (!c || !r || c[f] !== r[f]); f--); for (var g = d - 1; g > f; g--)i = a[--s - 1]; for (var y = f + 1; y < p; y++) { var v = {}; Aw(c[y], v, e); var m = nw("g", "clip-g-" + l++, v, []); (i ? i.children : n).push(m), a[s++] = m, i = m } r = c; var x = Tw(h, e); x && (i ? i.children : n).push(x) } } }, t.prototype.resize = function (t, e) { var n = this._opts, i = this.root, r = this._viewport; if (null != t && (n.width = t), null != e && (n.height = e), i && r && (r.style.display = "none", t = jy(i, 0, n), e = jy(i, 1, n), r.style.display = ""), this._width !== t || this._height !== e) { if (this._width = t, this._height = e, r) { var o = r.style; o.width = t + "px", o.height = e + "px" } if (gi(this._backgroundColor)) this.refresh(); else { var a = this._svgDom; a && (a.setAttribute("width", t), a.setAttribute("height", e)); var s = this._bgVNode && this._bgVNode.elm; s && (s.setAttribute("width", t), s.setAttribute("height", e)) } } }, t.prototype.getWidth = function () { return this._width }, t.prototype.getHeight = function () { return this._height }, t.prototype.dispose = function () { this.root && (this.root.innerHTML = ""), this._svgDom = this._viewport = this.storage = this._oldVNode = this._bgVNode = this._mainVNode = null }, t.prototype.clear = function () { this._svgDom && (this._svgDom.innerHTML = null), this._oldVNode = null }, t.prototype.toDataURL = function (t) { var e = this.renderToString(), n = "data:image/svg+xml;"; return t ? (e = wi(e)) && n + "base64," + e : n + "charset=UTF-8," + encodeURIComponent(e) }, t }(); function qw(t) { return function () { 0 } } function Kw(t, e, n) { var i = h.createCanvas(), r = e.getWidth(), o = e.getHeight(), a = i.style; return a && (a.position = "absolute", a.left = "0", a.top = "0", a.width = r + "px", a.height = o + "px", i.setAttribute("data-zr-dom-id", t)), i.width = r * n, i.height = o * n, i } var $w = function (t) { function e(e, n, i) { var r, o = t.call(this) || this; o.motionBlur = !1, o.lastFrameAlpha = .7, o.dpr = 1, o.virtual = !1, o.config = {}, o.incremental = !1, o.zlevel = 0, o.maxRepaintRectCount = 5, o.__dirty = !0, o.__firstTimePaint = !0, o.__used = !1, o.__drawIndex = 0, o.__startIndex = 0, o.__endIndex = 0, o.__prevStartIndex = null, o.__prevEndIndex = null, i = i || or, "string" == typeof e ? r = Kw(e, n, i) : q(e) && (e = (r = e).id), o.id = e, o.dom = r; var a = r.style; return a && (xt(r), r.onselectstart = function () { return !1 }, a.padding = "0", a.margin = "0", a.borderWidth = "0"), o.painter = n, o.dpr = i, o } return n(e, t), e.prototype.getElementCount = function () { return this.__endIndex - this.__startIndex }, e.prototype.afterBrush = function () { this.__prevStartIndex = this.__startIndex, this.__prevEndIndex = this.__endIndex }, e.prototype.initContext = function () { this.ctx = this.dom.getContext("2d"), this.ctx.dpr = this.dpr }, e.prototype.setUnpainted = function () { this.__firstTimePaint = !0 }, e.prototype.createBackBuffer = function () { var t = this.dpr; this.domBack = Kw("back-" + this.id, this.painter, t), this.ctxBack = this.domBack.getContext("2d"), 1 !== t && this.ctxBack.scale(t, t) }, e.prototype.createRepaintRects = function (t, e, n, i) { if (this.__firstTimePaint) return this.__firstTimePaint = !1, null; var r, o = [], a = this.maxRepaintRectCount, s = !1, l = new ze(0, 0, 0, 0); function u(t) { if (t.isFinite() && !t.isZero()) if (0 === o.length) { (e = new ze(0, 0, 0, 0)).copy(t), o.push(e) } else { for (var e, n = !1, i = 1 / 0, r = 0, u = 0; u < o.length; ++u) { var h = o[u]; if (h.intersect(t)) { var c = new ze(0, 0, 0, 0); c.copy(h), c.union(t), o[u] = c, n = !0; break } if (s) { l.copy(t), l.union(h); var p = t.width * t.height, d = h.width * h.height, f = l.width * l.height - p - d; f < i && (i = f, r = u) } } if (s && (o[r].union(t), n = !0), !n) (e = new ze(0, 0, 0, 0)).copy(t), o.push(e); s || (s = o.length >= a) } } for (var h = this.__startIndex; h < this.__endIndex; ++h) { if (d = t[h]) { var c = d.shouldBePainted(n, i, !0, !0); (f = d.__isRendered && (1 & d.__dirty || !c) ? d.getPrevPaintRect() : null) && u(f); var p = c && (1 & d.__dirty || !d.__isRendered) ? d.getPaintRect() : null; p && u(p) } } for (h = this.__prevStartIndex; h < this.__prevEndIndex; ++h) { var d, f; c = (d = e[h]).shouldBePainted(n, i, !0, !0); if (d && (!c || !d.__zr) && d.__isRendered) (f = d.getPrevPaintRect()) && u(f) } do { r = !1; for (h = 0; h < o.length;)if (o[h].isZero()) o.splice(h, 1); else { for (var g = h + 1; g < o.length;)o[h].intersect(o[g]) ? (r = !0, o[h].union(o[g]), o.splice(g, 1)) : g++; h++ } } while (r); return this._paintRects = o, o }, e.prototype.debugGetPaintRects = function () { return (this._paintRects || []).slice() }, e.prototype.resize = function (t, e) { var n = this.dpr, i = this.dom, r = i.style, o = this.domBack; r && (r.width = t + "px", r.height = e + "px"), i.width = t * n, i.height = e * n, o && (o.width = t * n, o.height = e * n, 1 !== n && this.ctxBack.scale(n, n)) }, e.prototype.clear = function (t, e, n) { var i = this.dom, r = this.ctx, o = i.width, a = i.height; e = e || this.clearColor; var s = this.motionBlur && !t, l = this.lastFrameAlpha, u = this.dpr, h = this; s && (this.domBack || this.createBackBuffer(), this.ctxBack.globalCompositeOperation = "copy", this.ctxBack.drawImage(i, 0, 0, o / u, a / u)); var c = this.domBack; function p(t, n, i, o) { if (r.clearRect(t, n, i, o), e && "transparent" !== e) { var a = void 0; if (Q(e)) a = (e.global || e.__width === i && e.__height === o) && e.__canvasGradient || Uy(r, e, { x: 0, y: 0, width: i, height: o }), e.__canvasGradient = a, e.__width = i, e.__height = o; else tt(e) && (e.scaleX = e.scaleX || u, e.scaleY = e.scaleY || u, a = nv(r, e, { dirty: function () { h.setUnpainted(), h.__painter.refresh() } })); r.save(), r.fillStyle = a || e, r.fillRect(t, n, i, o), r.restore() } s && (r.save(), r.globalAlpha = l, r.drawImage(c, t, n, i, o), r.restore()) } !n || s ? p(0, 0, o, a) : n.length && E(n, (function (t) { p(t.x * u, t.y * u, t.width * u, t.height * u) })) }, e }(jt), Jw = 1e5, Qw = 314159, tS = .01; var eS = function () { function t(t, e, n, i) { this.type = "canvas", this._zlevelList = [], this._prevDisplayList = [], this._layers = {}, this._layerConfig = {}, this._needsManuallyCompositing = !1, this.type = "canvas"; var r = !t.nodeName || "CANVAS" === t.nodeName.toUpperCase(); this._opts = n = A({}, n || {}), this.dpr = n.devicePixelRatio || or, this._singleCanvas = r, this.root = t, t.style && (xt(t), t.innerHTML = ""), this.storage = e; var o = this._zlevelList; this._prevDisplayList = []; var a = this._layers; if (r) { var s = t, l = s.width, u = s.height; null != n.width && (l = n.width), null != n.height && (u = n.height), this.dpr = n.devicePixelRatio || 1, s.width = l * this.dpr, s.height = u * this.dpr, this._width = l, this._height = u; var h = new $w(s, this, this.dpr); h.__builtin__ = !0, h.initContext(), a[314159] = h, h.zlevel = Qw, o.push(Qw), this._domRoot = t } else { this._width = jy(t, 0, n), this._height = jy(t, 1, n); var c = this._domRoot = function (t, e) { var n = document.createElement("div"); return n.style.cssText = ["position:relative", "width:" + t + "px", "height:" + e + "px", "padding:0", "margin:0", "border-width:0"].join(";") + ";", n }(this._width, this._height); t.appendChild(c) } } return t.prototype.getType = function () { return "canvas" }, t.prototype.isSingleCanvas = function () { return this._singleCanvas }, t.prototype.getViewportRoot = function () { return this._domRoot }, t.prototype.getViewportRootOffset = function () { var t = this.getViewportRoot(); if (t) return { offsetLeft: t.offsetLeft || 0, offsetTop: t.offsetTop || 0 } }, t.prototype.refresh = function (t) { var e = this.storage.getDisplayList(!0), n = this._prevDisplayList, i = this._zlevelList; this._redrawId = Math.random(), this._paintList(e, n, t, this._redrawId); for (var r = 0; r < i.length; r++) { var o = i[r], a = this._layers[o]; if (!a.__builtin__ && a.refresh) { var s = 0 === r ? this._backgroundColor : null; a.refresh(s) } } return this._opts.useDirtyRect && (this._prevDisplayList = e.slice()), this }, t.prototype.refreshHover = function () { this._paintHoverList(this.storage.getDisplayList(!1)) }, t.prototype._paintHoverList = function (t) { var e = t.length, n = this._hoverlayer; if (n && n.clear(), e) { for (var i, r = { inHover: !0, viewWidth: this._width, viewHeight: this._height }, o = 0; o < e; o++) { var a = t[o]; a.__inHover && (n || (n = this._hoverlayer = this.getLayer(Jw)), i || (i = n.ctx).save(), cv(i, a, r, o === e - 1)) } i && i.restore() } }, t.prototype.getHoverLayer = function () { return this.getLayer(Jw) }, t.prototype.paintOne = function (t, e) { hv(t, e) }, t.prototype._paintList = function (t, e, n, i) { if (this._redrawId === i) { n = n || !1, this._updateLayerStatus(t); var r = this._doPaintList(t, e, n), o = r.finished, a = r.needsRefreshHover; if (this._needsManuallyCompositing && this._compositeManually(), a && this._paintHoverList(t), o) this.eachLayer((function (t) { t.afterBrush && t.afterBrush() })); else { var s = this; on((function () { s._paintList(t, e, n, i) })) } } }, t.prototype._compositeManually = function () { var t = this.getLayer(Qw).ctx, e = this._domRoot.width, n = this._domRoot.height; t.clearRect(0, 0, e, n), this.eachBuiltinLayer((function (i) { i.virtual && t.drawImage(i.dom, 0, 0, e, n) })) }, t.prototype._doPaintList = function (t, e, n) { for (var i = this, o = [], a = this._opts.useDirtyRect, s = 0; s < this._zlevelList.length; s++) { var l = this._zlevelList[s], u = this._layers[l]; u.__builtin__ && u !== this._hoverlayer && (u.__dirty || n) && o.push(u) } for (var h = !0, c = !1, p = function (r) { var s, l = o[r], u = l.ctx, p = a && l.createRepaintRects(t, e, d._width, d._height), f = n ? l.__startIndex : l.__drawIndex, g = !n && l.incremental && Date.now, y = g && Date.now(), v = l.zlevel === d._zlevelList[0] ? d._backgroundColor : null; if (l.__startIndex === l.__endIndex) l.clear(!1, v, p); else if (f === l.__startIndex) { var m = t[f]; m.incremental && m.notClear && !n || l.clear(!1, v, p) } -1 === f && (console.error("For some unknown reason. drawIndex is -1"), f = l.__startIndex); var x = function (e) { var n = { inHover: !1, allClipped: !1, prevEl: null, viewWidth: i._width, viewHeight: i._height }; for (s = f; s < l.__endIndex; s++) { var r = t[s]; if (r.__inHover && (c = !0), i._doPaintEl(r, l, a, e, n, s === l.__endIndex - 1), g) if (Date.now() - y > 15) break } n.prevElClipPaths && u.restore() }; if (p) if (0 === p.length) s = l.__endIndex; else for (var _ = d.dpr, b = 0; b < p.length; ++b) { var w = p[b]; u.save(), u.beginPath(), u.rect(w.x * _, w.y * _, w.width * _, w.height * _), u.clip(), x(w), u.restore() } else u.save(), x(), u.restore(); l.__drawIndex = s, l.__drawIndex < l.__endIndex && (h = !1) }, d = this, f = 0; f < o.length; f++)p(f); return r.wxa && E(this._layers, (function (t) { t && t.ctx && t.ctx.draw && t.ctx.draw() })), { finished: h, needsRefreshHover: c } }, t.prototype._doPaintEl = function (t, e, n, i, r, o) { var a = e.ctx; if (n) { var s = t.getPaintRect(); (!i || s && s.intersect(i)) && (cv(a, t, r, o), t.setPrevPaintRect(s)) } else cv(a, t, r, o) }, t.prototype.getLayer = function (t, e) { this._singleCanvas && !this._needsManuallyCompositing && (t = Qw); var n = this._layers[t]; return n || ((n = new $w("zr_" + t, this, this.dpr)).zlevel = t, n.__builtin__ = !0, this._layerConfig[t] ? C(n, this._layerConfig[t], !0) : this._layerConfig[t - tS] && C(n, this._layerConfig[t - tS], !0), e && (n.virtual = e), this.insertLayer(t, n), n.initContext()), n }, t.prototype.insertLayer = function (t, e) { var n = this._layers, i = this._zlevelList, r = i.length, o = this._domRoot, a = null, s = -1; if (!n[t] && function (t) { return !!t && (!!t.__builtin__ || "function" == typeof t.resize && "function" == typeof t.refresh) }(e)) { if (r > 0 && t > i[0]) { for (s = 0; s < r - 1 && !(i[s] < t && i[s + 1] > t); s++); a = n[i[s]] } if (i.splice(s + 1, 0, t), n[t] = e, !e.virtual) if (a) { var l = a.dom; l.nextSibling ? o.insertBefore(e.dom, l.nextSibling) : o.appendChild(e.dom) } else o.firstChild ? o.insertBefore(e.dom, o.firstChild) : o.appendChild(e.dom); e.__painter = this } }, t.prototype.eachLayer = function (t, e) { for (var n = this._zlevelList, i = 0; i < n.length; i++) { var r = n[i]; t.call(e, this._layers[r], r) } }, t.prototype.eachBuiltinLayer = function (t, e) { for (var n = this._zlevelList, i = 0; i < n.length; i++) { var r = n[i], o = this._layers[r]; o.__builtin__ && t.call(e, o, r) } }, t.prototype.eachOtherLayer = function (t, e) { for (var n = this._zlevelList, i = 0; i < n.length; i++) { var r = n[i], o = this._layers[r]; o.__builtin__ || t.call(e, o, r) } }, t.prototype.getLayers = function () { return this._layers }, t.prototype._updateLayerStatus = function (t) { function e(t) { o && (o.__endIndex !== t && (o.__dirty = !0), o.__endIndex = t) } if (this.eachBuiltinLayer((function (t, e) { t.__dirty = t.__used = !1 })), this._singleCanvas) for (var n = 1; n < t.length; n++) { if ((s = t[n]).zlevel !== t[n - 1].zlevel || s.incremental) { this._needsManuallyCompositing = !0; break } } var i, r, o = null, a = 0; for (r = 0; r < t.length; r++) { var s, l = (s = t[r]).zlevel, u = void 0; i !== l && (i = l, a = 0), s.incremental ? ((u = this.getLayer(l + .001, this._needsManuallyCompositing)).incremental = !0, a = 1) : u = this.getLayer(l + (a > 0 ? tS : 0), this._needsManuallyCompositing), u.__builtin__ || I("ZLevel " + l + " has been used by unkown layer " + u.id), u !== o && (u.__used = !0, u.__startIndex !== r && (u.__dirty = !0), u.__startIndex = r, u.incremental ? u.__drawIndex = -1 : u.__drawIndex = r, e(r), o = u), 1 & s.__dirty && !s.__inHover && (u.__dirty = !0, u.incremental && u.__drawIndex < 0 && (u.__drawIndex = r)) } e(r), this.eachBuiltinLayer((function (t, e) { !t.__used && t.getElementCount() > 0 && (t.__dirty = !0, t.__startIndex = t.__endIndex = t.__drawIndex = 0), t.__dirty && t.__drawIndex < 0 && (t.__drawIndex = t.__startIndex) })) }, t.prototype.clear = function () { return this.eachBuiltinLayer(this._clearLayer), this }, t.prototype._clearLayer = function (t) { t.clear() }, t.prototype.setBackgroundColor = function (t) { this._backgroundColor = t, E(this._layers, (function (t) { t.setUnpainted() })) }, t.prototype.configLayer = function (t, e) { if (e) { var n = this._layerConfig; n[t] ? C(n[t], e, !0) : n[t] = e; for (var i = 0; i < this._zlevelList.length; i++) { var r = this._zlevelList[i]; if (r === t || r === t + tS) C(this._layers[r], n[t], !0) } } }, t.prototype.delLayer = function (t) { var e = this._layers, n = this._zlevelList, i = e[t]; i && (i.dom.parentNode.removeChild(i.dom), delete e[t], n.splice(P(n, t), 1)) }, t.prototype.resize = function (t, e) { if (this._domRoot.style) { var n = this._domRoot; n.style.display = "none"; var i = this._opts, r = this.root; if (null != t && (i.width = t), null != e && (i.height = e), t = jy(r, 0, i), e = jy(r, 1, i), n.style.display = "", this._width !== t || e !== this._height) { for (var o in n.style.width = t + "px", n.style.height = e + "px", this._layers) this._layers.hasOwnProperty(o) && this._layers[o].resize(t, e); this.refresh(!0) } this._width = t, this._height = e } else { if (null == t || null == e) return; this._width = t, this._height = e, this.getLayer(Qw).resize(t, e) } return this }, t.prototype.clearLayer = function (t) { var e = this._layers[t]; e && e.clear() }, t.prototype.dispose = function () { this.root.innerHTML = "", this.root = this.storage = this._domRoot = this._layers = null }, t.prototype.getRenderedCanvas = function (t) { if (t = t || {}, this._singleCanvas && !this._compositeManually) return this._layers[314159].dom; var e = new $w("image", this, t.pixelRatio || this.dpr); e.initContext(), e.clear(!1, t.backgroundColor || this._backgroundColor); var n = e.ctx; if (t.pixelRatio <= this.dpr) { this.refresh(); var i = e.dom.width, r = e.dom.height; this.eachLayer((function (t) { t.__builtin__ ? n.drawImage(t.dom, 0, 0, i, r) : t.renderToCanvas && (n.save(), t.renderToCanvas(n), n.restore()) })) } else for (var o = { inHover: !1, viewWidth: this._width, viewHeight: this._height }, a = this.storage.getDisplayList(!0), s = 0, l = a.length; s < l; s++) { var u = a[s]; cv(n, u, o, s === l - 1) } return e.dom }, t.prototype.getWidth = function () { return this._width }, t.prototype.getHeight = function () { return this._height }, t }(); var nS = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.hasSymbolVisual = !0, n } return n(e, t), e.prototype.getInitialData = function (t) { return vx(null, this, { useEncodeDefaulter: !0 }) }, e.prototype.getLegendIcon = function (t) { var e = new zr, n = Wy("line", 0, t.itemHeight / 2, t.itemWidth, 0, t.lineStyle.stroke, !1); e.add(n), n.setStyle(t.lineStyle); var i = this.getData().getVisual("symbol"), r = this.getData().getVisual("symbolRotate"), o = "none" === i ? "circle" : i, a = .8 * t.itemHeight, s = Wy(o, (t.itemWidth - a) / 2, (t.itemHeight - a) / 2, a, a, t.itemStyle.fill); e.add(s), s.setStyle(t.itemStyle); var l = "inherit" === t.iconRotate ? r : t.iconRotate || 0; return s.rotation = l * Math.PI / 180, s.setOrigin([t.itemWidth / 2, t.itemHeight / 2]), o.indexOf("empty") > -1 && (s.style.stroke = s.style.fill, s.style.fill = "#fff", s.style.lineWidth = 2), e }, e.type = "series.line", e.dependencies = ["grid", "polar"], e.defaultOption = { z: 3, coordinateSystem: "cartesian2d", legendHoverLink: !0, clip: !0, label: { position: "top" }, endLabel: { show: !1, valueAnimation: !0, distance: 8 }, lineStyle: { width: 2, type: "solid" }, emphasis: { scale: !0 }, step: !1, smooth: !1, smoothMonotone: null, symbol: "emptyCircle", symbolSize: 4, symbolRotate: null, showSymbol: !0, showAllSymbol: "auto", connectNulls: !1, sampling: "none", animationEasing: "linear", progressive: 0, hoverLayerThreshold: 1 / 0, universalTransition: { divideShape: "clone" }, triggerLineEvent: !1 }, e }(mg); function iS(t, e) { var n = t.mapDimensionsAll("defaultedLabel"), i = n.length; if (1 === i) { var r = gf(t, e, n[0]); return null != r ? r + "" : null } if (i) { for (var o = [], a = 0; a < n.length; a++)o.push(gf(t, e, n[a])); return o.join(" ") } } function rS(t, e) { var n = t.mapDimensionsAll("defaultedLabel"); if (!Y(e)) return e + ""; for (var i = [], r = 0; r < n.length; r++) { var o = t.getDimensionIndex(n[r]); o >= 0 && i.push(e[o]) } return i.join(" ") } var oS = function (t) { function e(e, n, i, r) { var o = t.call(this) || this; return o.updateData(e, n, i, r), o } return n(e, t), e.prototype._createSymbol = function (t, e, n, i, r) { this.removeAll(); var o = Wy(t, -1, -1, 2, 2, null, r); o.attr({ z2: 100, culling: !0, scaleX: i[0] / 2, scaleY: i[1] / 2 }), o.drift = aS, this._symbolType = t, this.add(o) }, e.prototype.stopSymbolAnimation = function (t) { this.childAt(0).stopAnimation(null, t) }, e.prototype.getSymbolType = function () { return this._symbolType }, e.prototype.getSymbolPath = function () { return this.childAt(0) }, e.prototype.highlight = function () { kl(this.childAt(0)) }, e.prototype.downplay = function () { Ll(this.childAt(0)) }, e.prototype.setZ = function (t, e) { var n = this.childAt(0); n.zlevel = t, n.z = e }, e.prototype.setDraggable = function (t, e) { var n = this.childAt(0); n.draggable = t, n.cursor = !e && t ? "move" : n.cursor }, e.prototype.updateData = function (t, n, i, r) { this.silent = !1; var o = t.getItemVisual(n, "symbol") || "circle", a = t.hostModel, s = e.getSymbolSize(t, n), l = o !== this._symbolType, u = r && r.disableAnimation; if (l) { var h = t.getItemVisual(n, "symbolKeepAspect"); this._createSymbol(o, t, n, s, h) } else { (p = this.childAt(0)).silent = !1; var c = { scaleX: s[0] / 2, scaleY: s[1] / 2 }; u ? p.attr(c) : fh(p, c, a, n), _h(p) } if (this._updateCommon(t, n, s, i, r), l) { var p = this.childAt(0); if (!u) { c = { scaleX: this._sizeX, scaleY: this._sizeY, style: { opacity: p.style.opacity } }; p.scaleX = p.scaleY = 0, p.style.opacity = 0, gh(p, c, a, n) } } u && this.childAt(0).stopAnimation("leave") }, e.prototype._updateCommon = function (t, e, n, i, r) { var o, a, s, l, u, h, c, p, d, f = this.childAt(0), g = t.hostModel; if (i && (o = i.emphasisItemStyle, a = i.blurItemStyle, s = i.selectItemStyle, l = i.focus, u = i.blurScope, c = i.labelStatesModels, p = i.hoverScale, d = i.cursorStyle, h = i.emphasisDisabled), !i || t.hasItemOption) { var y = i && i.itemModel ? i.itemModel : t.getItemModel(e), v = y.getModel("emphasis"); o = v.getModel("itemStyle").getItemStyle(), s = y.getModel(["select", "itemStyle"]).getItemStyle(), a = y.getModel(["blur", "itemStyle"]).getItemStyle(), l = v.get("focus"), u = v.get("blurScope"), h = v.get("disabled"), c = ec(y), p = v.getShallow("scale"), d = y.getShallow("cursor") } var m = t.getItemVisual(e, "symbolRotate"); f.attr("rotation", (m || 0) * Math.PI / 180 || 0); var x = Yy(t.getItemVisual(e, "symbolOffset"), n); x && (f.x = x[0], f.y = x[1]), d && f.attr("cursor", d); var _ = t.getItemVisual(e, "style"), b = _.fill; if (f instanceof ks) { var w = f.style; f.useStyle(A({ image: w.image, x: w.x, y: w.y, width: w.width, height: w.height }, _)) } else f.__isEmptyBrush ? f.useStyle(A({}, _)) : f.useStyle(_), f.style.decal = null, f.setColor(b, r && r.symbolInnerColor), f.style.strokeNoScale = !0; var S = t.getItemVisual(e, "liftZ"), M = this._z2; null != S ? null == M && (this._z2 = f.z2, f.z2 += S) : null != M && (f.z2 = M, this._z2 = null); var I = r && r.useNameLabel; tc(f, c, { labelFetcher: g, labelDataIndex: e, defaultText: function (e) { return I ? t.getName(e) : iS(t, e) }, inheritColor: b, defaultOpacity: _.opacity }), this._sizeX = n[0] / 2, this._sizeY = n[1] / 2; var T = f.ensureState("emphasis"); T.style = o, f.ensureState("select").style = s, f.ensureState("blur").style = a; var C = null == p || !0 === p ? Math.max(1.1, 3 / this._sizeY) : isFinite(p) && p > 0 ? +p : 1; T.scaleX = this._sizeX * C, T.scaleY = this._sizeY * C, this.setSymbolScale(1), Yl(this, l, u, h) }, e.prototype.setSymbolScale = function (t) { this.scaleX = this.scaleY = t }, e.prototype.fadeOut = function (t, e, n) { var i = this.childAt(0), r = Qs(this).dataIndex, o = n && n.animation; if (this.silent = i.silent = !0, n && n.fadeLabel) { var a = i.getTextContent(); a && vh(a, { style: { opacity: 0 } }, e, { dataIndex: r, removeOpt: o, cb: function () { i.removeTextContent() } }) } else i.removeTextContent(); vh(i, { style: { opacity: 0 }, scaleX: 0, scaleY: 0 }, e, { dataIndex: r, cb: t, removeOpt: o }) }, e.getSymbolSize = function (t, e) { return Hy(t.getItemVisual(e, "symbolSize")) }, e }(zr); function aS(t, e) { this.parent.drift(t, e) } function sS(t, e, n, i) { return e && !isNaN(e[0]) && !isNaN(e[1]) && !(i.isIgnore && i.isIgnore(n)) && !(i.clipShape && !i.clipShape.contain(e[0], e[1])) && "none" !== t.getItemVisual(n, "symbol") } function lS(t) { return null == t || q(t) || (t = { isIgnore: t }), t || {} } function uS(t) { var e = t.hostModel, n = e.getModel("emphasis"); return { emphasisItemStyle: n.getModel("itemStyle").getItemStyle(), blurItemStyle: e.getModel(["blur", "itemStyle"]).getItemStyle(), selectItemStyle: e.getModel(["select", "itemStyle"]).getItemStyle(), focus: n.get("focus"), blurScope: n.get("blurScope"), emphasisDisabled: n.get("disabled"), hoverScale: n.get("scale"), labelStatesModels: ec(e), cursorStyle: e.get("cursor") } } var hS = function () { function t(t) { this.group = new zr, this._SymbolCtor = t || oS } return t.prototype.updateData = function (t, e) { this._progressiveEls = null, e = lS(e); var n = this.group, i = t.hostModel, r = this._data, o = this._SymbolCtor, a = e.disableAnimation, s = uS(t), l = { disableAnimation: a }, u = e.getSymbolPoint || function (e) { return t.getItemLayout(e) }; r || n.removeAll(), t.diff(r).add((function (i) { var r = u(i); if (sS(t, r, i, e)) { var a = new o(t, i, s, l); a.setPosition(r), t.setItemGraphicEl(i, a), n.add(a) } })).update((function (h, c) { var p = r.getItemGraphicEl(c), d = u(h); if (sS(t, d, h, e)) { var f = t.getItemVisual(h, "symbol") || "circle", g = p && p.getSymbolType && p.getSymbolType(); if (!p || g && g !== f) n.remove(p), (p = new o(t, h, s, l)).setPosition(d); else { p.updateData(t, h, s, l); var y = { x: d[0], y: d[1] }; a ? p.attr(y) : fh(p, y, i) } n.add(p), t.setItemGraphicEl(h, p) } else n.remove(p) })).remove((function (t) { var e = r.getItemGraphicEl(t); e && e.fadeOut((function () { n.remove(e) }), i) })).execute(), this._getSymbolPoint = u, this._data = t }, t.prototype.updateLayout = function () { var t = this, e = this._data; e && e.eachItemGraphicEl((function (e, n) { var i = t._getSymbolPoint(n); e.setPosition(i), e.markRedraw() })) }, t.prototype.incrementalPrepareUpdate = function (t) { this._seriesScope = uS(t), this._data = null, this.group.removeAll() }, t.prototype.incrementalUpdate = function (t, e, n) { function i(t) { t.isGroup || (t.incremental = !0, t.ensureState("emphasis").hoverLayer = !0) } this._progressiveEls = [], n = lS(n); for (var r = t.start; r < t.end; r++) { var o = e.getItemLayout(r); if (sS(e, o, r, n)) { var a = new this._SymbolCtor(e, r, this._seriesScope); a.traverse(i), a.setPosition(o), this.group.add(a), e.setItemGraphicEl(r, a), this._progressiveEls.push(a) } } }, t.prototype.eachRendered = function (t) { qh(this._progressiveEls || this.group, t) }, t.prototype.remove = function (t) { var e = this.group, n = this._data; n && t ? n.eachItemGraphicEl((function (t) { t.fadeOut((function () { e.remove(t) }), n.hostModel) })) : e.removeAll() }, t }(); function cS(t, e, n) { var i = t.getBaseAxis(), r = t.getOtherAxis(i), o = function (t, e) { var n = 0, i = t.scale.getExtent(); "start" === e ? n = i[0] : "end" === e ? n = i[1] : j(e) && !isNaN(e) ? n = e : i[0] > 0 ? n = i[0] : i[1] < 0 && (n = i[1]); return n }(r, n), a = i.dim, s = r.dim, l = e.mapDimension(s), u = e.mapDimension(a), h = "x" === s || "radius" === s ? 1 : 0, c = z(t.dimensions, (function (t) { return e.mapDimension(t) })), p = !1, d = e.getCalculationInfo("stackResultDimension"); return gx(e, c[0]) && (p = !0, c[0] = d), gx(e, c[1]) && (p = !0, c[1] = d), { dataDimsForPoint: c, valueStart: o, valueAxisDim: s, baseAxisDim: a, stacked: !!p, valueDim: l, baseDim: u, baseDataOffset: h, stackedOverDimension: e.getCalculationInfo("stackedOverDimension") } } function pS(t, e, n, i) { var r = NaN; t.stacked && (r = n.get(n.getCalculationInfo("stackedOverDimension"), i)), isNaN(r) && (r = t.valueStart); var o = t.baseDataOffset, a = []; return a[o] = n.get(t.baseDim, i), a[1 - o] = r, e.dataToPoint(a) } var dS = Math.min, fS = Math.max; function gS(t, e) { return isNaN(t) || isNaN(e) } function yS(t, e, n, i, r, o, a, s, l) { for (var u, h, c, p, d, f, g = n, y = 0; y < i; y++) { var v = e[2 * g], m = e[2 * g + 1]; if (g >= r || g < 0) break; if (gS(v, m)) { if (l) { g += o; continue } break } if (g === n) t[o > 0 ? "moveTo" : "lineTo"](v, m), c = v, p = m; else { var x = v - u, _ = m - h; if (x * x + _ * _ < .5) { g += o; continue } if (a > 0) { for (var b = g + o, w = e[2 * b], S = e[2 * b + 1]; w === v && S === m && y < i;)y++, g += o, w = e[2 * (b += o)], S = e[2 * b + 1], x = (v = e[2 * g]) - u, _ = (m = e[2 * g + 1]) - h; var M = y + 1; if (l) for (; gS(w, S) && M < i;)M++, w = e[2 * (b += o)], S = e[2 * b + 1]; var I = .5, T = 0, C = 0, D = void 0, A = void 0; if (M >= i || gS(w, S)) d = v, f = m; else { T = w - u, C = S - h; var k = v - u, L = w - v, P = m - h, O = S - m, R = void 0, N = void 0; if ("x" === s) { var E = T > 0 ? 1 : -1; d = v - E * (R = Math.abs(k)) * a, f = m, D = v + E * (N = Math.abs(L)) * a, A = m } else if ("y" === s) { var z = C > 0 ? 1 : -1; d = v, f = m - z * (R = Math.abs(P)) * a, D = v, A = m + z * (N = Math.abs(O)) * a } else R = Math.sqrt(k * k + P * P), d = v - T * a * (1 - (I = (N = Math.sqrt(L * L + O * O)) / (N + R))), f = m - C * a * (1 - I), A = m + C * a * I, D = dS(D = v + T * a * I, fS(w, v)), A = dS(A, fS(S, m)), D = fS(D, dS(w, v)), f = m - (C = (A = fS(A, dS(S, m))) - m) * R / N, d = dS(d = v - (T = D - v) * R / N, fS(u, v)), f = dS(f, fS(h, m)), D = v + (T = v - (d = fS(d, dS(u, v)))) * N / R, A = m + (C = m - (f = fS(f, dS(h, m)))) * N / R } t.bezierCurveTo(c, p, d, f, v, m), c = D, p = A } else t.lineTo(v, m) } u = v, h = m, g += o } return y } var vS = function () { this.smooth = 0, this.smoothConstraint = !0 }, mS = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "ec-polyline", n } return n(e, t), e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new vS }, e.prototype.buildPath = function (t, e) { var n = e.points, i = 0, r = n.length / 2; if (e.connectNulls) { for (; r > 0 && gS(n[2 * r - 2], n[2 * r - 1]); r--); for (; i < r && gS(n[2 * i], n[2 * i + 1]); i++); } for (; i < r;)i += yS(t, n, i, r, r, 1, e.smooth, e.smoothMonotone, e.connectNulls) + 1 }, e.prototype.getPointOn = function (t, e) { this.path || (this.createPathProxy(), this.buildPath(this.path, this.shape)); for (var n, i, r = this.path.data, o = os.CMD, a = "x" === e, s = [], l = 0; l < r.length;) { var u = void 0, h = void 0, c = void 0, p = void 0, d = void 0, f = void 0, g = void 0; switch (r[l++]) { case o.M: n = r[l++], i = r[l++]; break; case o.L: if (u = r[l++], h = r[l++], (g = a ? (t - n) / (u - n) : (t - i) / (h - i)) <= 1 && g >= 0) { var y = a ? (h - i) * g + i : (u - n) * g + n; return a ? [t, y] : [y, t] } n = u, i = h; break; case o.C: u = r[l++], h = r[l++], c = r[l++], p = r[l++], d = r[l++], f = r[l++]; var v = a ? _n(n, u, c, d, t, s) : _n(i, h, p, f, t, s); if (v > 0) for (var m = 0; m < v; m++) { var x = s[m]; if (x <= 1 && x >= 0) { y = a ? mn(i, h, p, f, x) : mn(n, u, c, d, x); return a ? [t, y] : [y, t] } } n = d, i = f } } }, e }(Is), xS = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e }(vS), _S = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "ec-polygon", n } return n(e, t), e.prototype.getDefaultShape = function () { return new xS }, e.prototype.buildPath = function (t, e) { var n = e.points, i = e.stackedOnPoints, r = 0, o = n.length / 2, a = e.smoothMonotone; if (e.connectNulls) { for (; o > 0 && gS(n[2 * o - 2], n[2 * o - 1]); o--); for (; r < o && gS(n[2 * r], n[2 * r + 1]); r++); } for (; r < o;) { var s = yS(t, n, r, o, o, 1, e.smooth, a, e.connectNulls); yS(t, i, r + s - 1, s, o, -1, e.stackedOnSmooth, a, e.connectNulls), r += s + 1, t.closePath() } }, e }(Is); function bS(t, e, n, i, r) { var o = t.getArea(), a = o.x, s = o.y, l = o.width, u = o.height, h = n.get(["lineStyle", "width"]) || 2; a -= h / 2, s -= h / 2, l += h, u += h, a = Math.floor(a), l = Math.round(l); var c = new zs({ shape: { x: a, y: s, width: l, height: u } }); if (e) { var p = t.getBaseAxis(), d = p.isHorizontal(), f = p.inverse; d ? (f && (c.shape.x += l), c.shape.width = 0) : (f || (c.shape.y += u), c.shape.height = 0); var g = X(r) ? function (t) { r(t, c) } : null; gh(c, { shape: { width: l, height: u, x: a, y: s } }, n, null, i, g) } return c } function wS(t, e, n) { var i = t.getArea(), r = Zr(i.r0, 1), o = Zr(i.r, 1), a = new zu({ shape: { cx: Zr(t.cx, 1), cy: Zr(t.cy, 1), r0: r, r: o, startAngle: i.startAngle, endAngle: i.endAngle, clockwise: i.clockwise } }); e && ("angle" === t.getBaseAxis().dim ? a.shape.endAngle = i.startAngle : a.shape.r = r, gh(a, { shape: { endAngle: i.endAngle, r: o } }, n)); return a } function SS(t, e, n, i, r) { return t ? "polar" === t.type ? wS(t, e, n) : "cartesian2d" === t.type ? bS(t, e, n, i, r) : null : null } function MS(t, e) { return t.type === e } function IS(t, e) { if (t.length === e.length) { for (var n = 0; n < t.length; n++)if (t[n] !== e[n]) return; return !0 } } function TS(t) { for (var e = 1 / 0, n = 1 / 0, i = -1 / 0, r = -1 / 0, o = 0; o < t.length;) { var a = t[o++], s = t[o++]; isNaN(a) || (e = Math.min(a, e), i = Math.max(a, i)), isNaN(s) || (n = Math.min(s, n), r = Math.max(s, r)) } return [[e, n], [i, r]] } function CS(t, e) { var n = TS(t), i = n[0], r = n[1], o = TS(e), a = o[0], s = o[1]; return Math.max(Math.abs(i[0] - a[0]), Math.abs(i[1] - a[1]), Math.abs(r[0] - s[0]), Math.abs(r[1] - s[1])) } function DS(t) { return j(t) ? t : t ? .5 : 0 } function AS(t, e, n, i) { var r = e.getBaseAxis(), o = "x" === r.dim || "radius" === r.dim ? 0 : 1, a = [], s = 0, l = [], u = [], h = [], c = []; if (i) { for (s = 0; s < t.length; s += 2)isNaN(t[s]) || isNaN(t[s + 1]) || c.push(t[s], t[s + 1]); t = c } for (s = 0; s < t.length - 2; s += 2)switch (h[0] = t[s + 2], h[1] = t[s + 3], u[0] = t[s], u[1] = t[s + 1], a.push(u[0], u[1]), n) { case "end": l[o] = h[o], l[1 - o] = u[1 - o], a.push(l[0], l[1]); break; case "middle": var p = (u[o] + h[o]) / 2, d = []; l[o] = d[o] = p, l[1 - o] = u[1 - o], d[1 - o] = h[1 - o], a.push(l[0], l[1]), a.push(d[0], d[1]); break; default: l[o] = u[o], l[1 - o] = h[1 - o], a.push(l[0], l[1]) }return a.push(t[s++], t[s++]), a } function kS(t, e, n) { var i = t.getVisual("visualMeta"); if (i && i.length && t.count() && "cartesian2d" === e.type) { for (var r, o, a = i.length - 1; a >= 0; a--) { var s = t.getDimensionInfo(i[a].dimension); if ("x" === (r = s && s.coordDim) || "y" === r) { o = i[a]; break } } if (o) { var l = e.getAxis(r), u = z(o.stops, (function (t) { return { coord: l.toGlobalCoord(l.dataToCoord(t.value)), color: t.color } })), h = u.length, c = o.outerColors.slice(); h && u[0].coord > u[h - 1].coord && (u.reverse(), c.reverse()); var p = function (t, e) { var n, i, r = [], o = t.length; function a(t, e, n) { var i = t.coord; return { coord: n, color: ti((n - i) / (e.coord - i), [t.color, e.color]) } } for (var s = 0; s < o; s++) { var l = t[s], u = l.coord; if (u < 0) n = l; else { if (u > e) { i ? r.push(a(i, l, e)) : n && r.push(a(n, l, 0), a(n, l, e)); break } n && (r.push(a(n, l, 0)), n = null), r.push(l), i = l } } return r }(u, "x" === r ? n.getWidth() : n.getHeight()), d = p.length; if (!d && h) return u[0].coord < 0 ? c[1] ? c[1] : u[h - 1].color : c[0] ? c[0] : u[0].color; var f = p[0].coord - 10, g = p[d - 1].coord + 10, y = g - f; if (y < .001) return "transparent"; E(p, (function (t) { t.offset = (t.coord - f) / y })), p.push({ offset: d ? p[d - 1].offset : .5, color: c[1] || "transparent" }), p.unshift({ offset: d ? p[0].offset : .5, color: c[0] || "transparent" }); var v = new nh(0, 0, 0, 0, p, !0); return v[r] = f, v[r + "2"] = g, v } } } function LS(t, e, n) { var i = t.get("showAllSymbol"), r = "auto" === i; if (!i || r) { var o = n.getAxesByScale("ordinal")[0]; if (o && (!r || !function (t, e) { var n = t.getExtent(), i = Math.abs(n[1] - n[0]) / t.scale.count(); isNaN(i) && (i = 0); for (var r = e.count(), o = Math.max(1, Math.round(r / 5)), a = 0; a < r; a += o)if (1.5 * oS.getSymbolSize(e, a)[t.isHorizontal() ? 1 : 0] > i) return !1; return !0 }(o, e))) { var a = e.mapDimension(o.dim), s = {}; return E(o.getViewLabels(), (function (t) { var e = o.scale.getRawOrdinalNumber(t.tickValue); s[e] = 1 })), function (t) { return !s.hasOwnProperty(e.get(a, t)) } } } } function PS(t, e) { return [t[2 * e], t[2 * e + 1]] } function OS(t) { if (t.get(["endLabel", "show"])) return !0; for (var e = 0; e < ol.length; e++)if (t.get([ol[e], "endLabel", "show"])) return !0; return !1 } function RS(t, e, n, i) { if (MS(e, "cartesian2d")) { var r = i.getModel("endLabel"), o = r.get("valueAnimation"), a = i.getData(), s = { lastFrameIndex: 0 }, l = OS(i) ? function (n, i) { t._endLabelOnDuring(n, i, a, s, o, r, e) } : null, u = e.getBaseAxis().isHorizontal(), h = bS(e, n, i, (function () { var e = t._endLabel; e && n && null != s.originalX && e.attr({ x: s.originalX, y: s.originalY }) }), l); if (!i.get("clip", !0)) { var c = h.shape, p = Math.max(c.width, c.height); u ? (c.y -= p, c.height += 2 * p) : (c.x -= p, c.width += 2 * p) } return l && l(1, h), h } return wS(e, n, i) } var NS = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.init = function () { var t = new zr, e = new hS; this.group.add(e.group), this._symbolDraw = e, this._lineGroup = t }, e.prototype.render = function (t, e, n) { var i = this, r = t.coordinateSystem, o = this.group, a = t.getData(), s = t.getModel("lineStyle"), l = t.getModel("areaStyle"), u = a.getLayout("points") || [], h = "polar" === r.type, c = this._coordSys, p = this._symbolDraw, d = this._polyline, f = this._polygon, g = this._lineGroup, y = !e.ssr && t.isAnimationEnabled(), v = !l.isEmpty(), m = l.get("origin"), x = cS(r, a, m), _ = v && function (t, e, n) { if (!n.valueDim) return []; for (var i = e.count(), r = Ex(2 * i), o = 0; o < i; o++) { var a = pS(n, t, e, o); r[2 * o] = a[0], r[2 * o + 1] = a[1] } return r }(r, a, x), b = t.get("showSymbol"), w = t.get("connectNulls"), S = b && !h && LS(t, a, r), M = this._data; M && M.eachItemGraphicEl((function (t, e) { t.__temp && (o.remove(t), M.setItemGraphicEl(e, null)) })), b || p.remove(), o.add(g); var I, T = !h && t.get("step"); r && r.getArea && t.get("clip", !0) && (null != (I = r.getArea()).width ? (I.x -= .1, I.y -= .1, I.width += .2, I.height += .2) : I.r0 && (I.r0 -= .5, I.r += .5)), this._clipShapeForSymbol = I; var C = kS(a, r, n) || a.getVisual("style")[a.getVisual("drawType")]; if (d && c.type === r.type && T === this._step) { v && !f ? f = this._newPolygon(u, _) : f && !v && (g.remove(f), f = this._polygon = null), h || this._initOrUpdateEndLabel(t, r, _p(C)); var D = g.getClipPath(); if (D) gh(D, { shape: RS(this, r, !1, t).shape }, t); else g.setClipPath(RS(this, r, !0, t)); b && p.updateData(a, { isIgnore: S, clipShape: I, disableAnimation: !0, getSymbolPoint: function (t) { return [u[2 * t], u[2 * t + 1]] } }), IS(this._stackedOnPoints, _) && IS(this._points, u) || (y ? this._doUpdateAnimation(a, _, r, n, T, m, w) : (T && (u = AS(u, r, T, w), _ && (_ = AS(_, r, T, w))), d.setShape({ points: u }), f && f.setShape({ points: u, stackedOnPoints: _ }))) } else b && p.updateData(a, { isIgnore: S, clipShape: I, disableAnimation: !0, getSymbolPoint: function (t) { return [u[2 * t], u[2 * t + 1]] } }), y && this._initSymbolLabelAnimation(a, r, I), T && (u = AS(u, r, T, w), _ && (_ = AS(_, r, T, w))), d = this._newPolyline(u), v ? f = this._newPolygon(u, _) : f && (g.remove(f), f = this._polygon = null), h || this._initOrUpdateEndLabel(t, r, _p(C)), g.setClipPath(RS(this, r, !0, t)); var A = t.getModel("emphasis"), L = A.get("focus"), P = A.get("blurScope"), O = A.get("disabled"); (d.useStyle(k(s.getLineStyle(), { fill: "none", stroke: C, lineJoin: "bevel" })), jl(d, t, "lineStyle"), d.style.lineWidth > 0 && "bolder" === t.get(["emphasis", "lineStyle", "width"])) && (d.getState("emphasis").style.lineWidth = +d.style.lineWidth + 1); Qs(d).seriesIndex = t.seriesIndex, Yl(d, L, P, O); var R = DS(t.get("smooth")), N = t.get("smoothMonotone"); if (d.setShape({ smooth: R, smoothMonotone: N, connectNulls: w }), f) { var E = a.getCalculationInfo("stackedOnSeries"), z = 0; f.useStyle(k(l.getAreaStyle(), { fill: C, opacity: .7, lineJoin: "bevel", decal: a.getVisual("style").decal })), E && (z = DS(E.get("smooth"))), f.setShape({ smooth: R, stackedOnSmooth: z, smoothMonotone: N, connectNulls: w }), jl(f, t, "areaStyle"), Qs(f).seriesIndex = t.seriesIndex, Yl(f, L, P, O) } var V = function (t) { i._changePolyState(t) }; a.eachItemGraphicEl((function (t) { t && (t.onHoverStateChange = V) })), this._polyline.onHoverStateChange = V, this._data = a, this._coordSys = r, this._stackedOnPoints = _, this._points = u, this._step = T, this._valueOrigin = m, t.get("triggerLineEvent") && (this.packEventData(t, d), f && this.packEventData(t, f)) }, e.prototype.packEventData = function (t, e) { Qs(e).eventData = { componentType: "series", componentSubType: "line", componentIndex: t.componentIndex, seriesIndex: t.seriesIndex, seriesName: t.name, seriesType: "line" } }, e.prototype.highlight = function (t, e, n, i) { var r = t.getData(), o = Po(r, i); if (this._changePolyState("emphasis"), !(o instanceof Array) && null != o && o >= 0) { var a = r.getLayout("points"), s = r.getItemGraphicEl(o); if (!s) { var l = a[2 * o], u = a[2 * o + 1]; if (isNaN(l) || isNaN(u)) return; if (this._clipShapeForSymbol && !this._clipShapeForSymbol.contain(l, u)) return; var h = t.get("zlevel") || 0, c = t.get("z") || 0; (s = new oS(r, o)).x = l, s.y = u, s.setZ(h, c); var p = s.getSymbolPath().getTextContent(); p && (p.zlevel = h, p.z = c, p.z2 = this._polyline.z2 + 1), s.__temp = !0, r.setItemGraphicEl(o, s), s.stopSymbolAnimation(!0), this.group.add(s) } s.highlight() } else kg.prototype.highlight.call(this, t, e, n, i) }, e.prototype.downplay = function (t, e, n, i) { var r = t.getData(), o = Po(r, i); if (this._changePolyState("normal"), null != o && o >= 0) { var a = r.getItemGraphicEl(o); a && (a.__temp ? (r.setItemGraphicEl(o, null), this.group.remove(a)) : a.downplay()) } else kg.prototype.downplay.call(this, t, e, n, i) }, e.prototype._changePolyState = function (t) { var e = this._polygon; Il(this._polyline, t), e && Il(e, t) }, e.prototype._newPolyline = function (t) { var e = this._polyline; return e && this._lineGroup.remove(e), e = new mS({ shape: { points: t }, segmentIgnoreThreshold: 2, z2: 10 }), this._lineGroup.add(e), this._polyline = e, e }, e.prototype._newPolygon = function (t, e) { var n = this._polygon; return n && this._lineGroup.remove(n), n = new _S({ shape: { points: t, stackedOnPoints: e }, segmentIgnoreThreshold: 2 }), this._lineGroup.add(n), this._polygon = n, n }, e.prototype._initSymbolLabelAnimation = function (t, e, n) { var i, r, o = e.getBaseAxis(), a = o.inverse; "cartesian2d" === e.type ? (i = o.isHorizontal(), r = !1) : "polar" === e.type && (i = "angle" === o.dim, r = !0); var s = t.hostModel, l = s.get("animationDuration"); X(l) && (l = l(null)); var u = s.get("animationDelay") || 0, h = X(u) ? u(null) : u; t.eachItemGraphicEl((function (t, o) { var s = t; if (s) { var c = [t.x, t.y], p = void 0, d = void 0, f = void 0; if (n) if (r) { var g = n, y = e.pointToCoord(c); i ? (p = g.startAngle, d = g.endAngle, f = -y[1] / 180 * Math.PI) : (p = g.r0, d = g.r, f = y[0]) } else { var v = n; i ? (p = v.x, d = v.x + v.width, f = t.x) : (p = v.y + v.height, d = v.y, f = t.y) } var m = d === p ? 0 : (f - p) / (d - p); a && (m = 1 - m); var x = X(u) ? u(o) : l * m + h, _ = s.getSymbolPath(), b = _.getTextContent(); s.attr({ scaleX: 0, scaleY: 0 }), s.animateTo({ scaleX: 1, scaleY: 1 }, { duration: 200, setToFinal: !0, delay: x }), b && b.animateFrom({ style: { opacity: 0 } }, { duration: 300, delay: x }), _.disableLabelAnimation = !0 } })) }, e.prototype._initOrUpdateEndLabel = function (t, e, n) { var i = t.getModel("endLabel"); if (OS(t)) { var r = t.getData(), o = this._polyline, a = r.getLayout("points"); if (!a) return o.removeTextContent(), void (this._endLabel = null); var s = this._endLabel; s || ((s = this._endLabel = new Fs({ z2: 200 })).ignoreClip = !0, o.setTextContent(this._endLabel), o.disableLabelAnimation = !0); var l = function (t) { for (var e, n, i = t.length / 2; i > 0 && (e = t[2 * i - 2], n = t[2 * i - 1], isNaN(e) || isNaN(n)); i--); return i - 1 }(a); l >= 0 && (tc(o, ec(t, "endLabel"), { inheritColor: n, labelFetcher: t, labelDataIndex: l, defaultText: function (t, e, n) { return null != n ? rS(r, n) : iS(r, t) }, enableTextSetter: !0 }, function (t, e) { var n = e.getBaseAxis(), i = n.isHorizontal(), r = n.inverse, o = i ? r ? "right" : "left" : "center", a = i ? "middle" : r ? "top" : "bottom"; return { normal: { align: t.get("align") || o, verticalAlign: t.get("verticalAlign") || a } } }(i, e)), o.textConfig.position = null) } else this._endLabel && (this._polyline.removeTextContent(), this._endLabel = null) }, e.prototype._endLabelOnDuring = function (t, e, n, i, r, o, a) { var s = this._endLabel, l = this._polyline; if (s) { t < 1 && null == i.originalX && (i.originalX = s.x, i.originalY = s.y); var u = n.getLayout("points"), h = n.hostModel, c = h.get("connectNulls"), p = o.get("precision"), d = o.get("distance") || 0, f = a.getBaseAxis(), g = f.isHorizontal(), y = f.inverse, v = e.shape, m = y ? g ? v.x : v.y + v.height : g ? v.x + v.width : v.y, x = (g ? d : 0) * (y ? -1 : 1), _ = (g ? 0 : -d) * (y ? -1 : 1), b = g ? "x" : "y", w = function (t, e, n) { for (var i, r, o = t.length / 2, a = "x" === n ? 0 : 1, s = 0, l = -1, u = 0; u < o; u++)if (r = t[2 * u + a], !isNaN(r) && !isNaN(t[2 * u + 1 - a])) if (0 !== u) { if (i <= e && r >= e || i >= e && r <= e) { l = u; break } s = u, i = r } else i = r; return { range: [s, l], t: (e - i) / (r - i) } }(u, m, b), S = w.range, M = S[1] - S[0], I = void 0; if (M >= 1) { if (M > 1 && !c) { var T = PS(u, S[0]); s.attr({ x: T[0] + x, y: T[1] + _ }), r && (I = h.getRawValue(S[0])) } else { (T = l.getPointOn(m, b)) && s.attr({ x: T[0] + x, y: T[1] + _ }); var C = h.getRawValue(S[0]), D = h.getRawValue(S[1]); r && (I = Wo(n, p, C, D, w.t)) } i.lastFrameIndex = S[0] } else { var A = 1 === t || i.lastFrameIndex > 0 ? S[0] : 0; T = PS(u, A); r && (I = h.getRawValue(A)), s.attr({ x: T[0] + x, y: T[1] + _ }) } if (r) { var k = uc(s); "function" == typeof k.setLabelText && k.setLabelText(I) } } }, e.prototype._doUpdateAnimation = function (t, e, n, i, r, o, a) { var s = this._polyline, l = this._polygon, u = t.hostModel, h = function (t, e, n, i, r, o, a, s) { for (var l = function (t, e) { var n = []; return e.diff(t).add((function (t) { n.push({ cmd: "+", idx: t }) })).update((function (t, e) { n.push({ cmd: "=", idx: e, idx1: t }) })).remove((function (t) { n.push({ cmd: "-", idx: t }) })).execute(), n }(t, e), u = [], h = [], c = [], p = [], d = [], f = [], g = [], y = cS(r, e, a), v = t.getLayout("points") || [], m = e.getLayout("points") || [], x = 0; x < l.length; x++) { var _ = l[x], b = !0, w = void 0, S = void 0; switch (_.cmd) { case "=": w = 2 * _.idx, S = 2 * _.idx1; var M = v[w], I = v[w + 1], T = m[S], C = m[S + 1]; (isNaN(M) || isNaN(I)) && (M = T, I = C), u.push(M, I), h.push(T, C), c.push(n[w], n[w + 1]), p.push(i[S], i[S + 1]), g.push(e.getRawIndex(_.idx1)); break; case "+": var D = _.idx, A = y.dataDimsForPoint, k = r.dataToPoint([e.get(A[0], D), e.get(A[1], D)]); S = 2 * D, u.push(k[0], k[1]), h.push(m[S], m[S + 1]); var L = pS(y, r, e, D); c.push(L[0], L[1]), p.push(i[S], i[S + 1]), g.push(e.getRawIndex(D)); break; case "-": b = !1 }b && (d.push(_), f.push(f.length)) } f.sort((function (t, e) { return g[t] - g[e] })); var P = u.length, O = Ex(P), R = Ex(P), N = Ex(P), E = Ex(P), z = []; for (x = 0; x < f.length; x++) { var V = f[x], B = 2 * x, F = 2 * V; O[B] = u[F], O[B + 1] = u[F + 1], R[B] = h[F], R[B + 1] = h[F + 1], N[B] = c[F], N[B + 1] = c[F + 1], E[B] = p[F], E[B + 1] = p[F + 1], z[x] = d[V] } return { current: O, next: R, stackedOnCurrent: N, stackedOnNext: E, status: z } }(this._data, t, this._stackedOnPoints, e, this._coordSys, 0, this._valueOrigin), c = h.current, p = h.stackedOnCurrent, d = h.next, f = h.stackedOnNext; if (r && (c = AS(h.current, n, r, a), p = AS(h.stackedOnCurrent, n, r, a), d = AS(h.next, n, r, a), f = AS(h.stackedOnNext, n, r, a)), CS(c, d) > 3e3 || l && CS(p, f) > 3e3) return s.stopAnimation(), s.setShape({ points: d }), void (l && (l.stopAnimation(), l.setShape({ points: d, stackedOnPoints: f }))); s.shape.__points = h.current, s.shape.points = c; var g = { shape: { points: d } }; h.current !== c && (g.shape.__points = h.next), s.stopAnimation(), fh(s, g, u), l && (l.setShape({ points: c, stackedOnPoints: p }), l.stopAnimation(), fh(l, { shape: { stackedOnPoints: f } }, u), s.shape.points !== l.shape.points && (l.shape.points = s.shape.points)); for (var y = [], v = h.status, m = 0; m < v.length; m++) { if ("=" === v[m].cmd) { var x = t.getItemGraphicEl(v[m].idx1); x && y.push({ el: x, ptIdx: m }) } } s.animators && s.animators.length && s.animators[0].during((function () { l && l.dirtyShape(); for (var t = s.shape.__points, e = 0; e < y.length; e++) { var n = y[e].el, i = 2 * y[e].ptIdx; n.x = t[i], n.y = t[i + 1], n.markRedraw() } })) }, e.prototype.remove = function (t) { var e = this.group, n = this._data; this._lineGroup.removeAll(), this._symbolDraw.remove(!0), n && n.eachItemGraphicEl((function (t, i) { t.__temp && (e.remove(t), n.setItemGraphicEl(i, null)) })), this._polyline = this._polygon = this._coordSys = this._points = this._stackedOnPoints = this._endLabel = this._data = null }, e.type = "line", e }(kg); function ES(t, e) { return { seriesType: t, plan: Cg(), reset: function (t) { var n = t.getData(), i = t.coordinateSystem, r = t.pipelineContext, o = e || r.large; if (i) { var a = z(i.dimensions, (function (t) { return n.mapDimension(t) })).slice(0, 2), s = a.length, l = n.getCalculationInfo("stackResultDimension"); gx(n, a[0]) && (a[0] = l), gx(n, a[1]) && (a[1] = l); var u = n.getStore(), h = n.getDimensionIndex(a[0]), c = n.getDimensionIndex(a[1]); return s && { progress: function (t, e) { for (var n = t.end - t.start, r = o && Ex(n * s), a = [], l = [], p = t.start, d = 0; p < t.end; p++) { var f = void 0; if (1 === s) { var g = u.get(h, p); f = i.dataToPoint(g, null, l) } else a[0] = u.get(h, p), a[1] = u.get(c, p), f = i.dataToPoint(a, null, l); o ? (r[d++] = f[0], r[d++] = f[1]) : e.setItemLayout(p, f.slice()) } o && e.setLayout("points", r) } } } } } } var zS = { average: function (t) { for (var e = 0, n = 0, i = 0; i < t.length; i++)isNaN(t[i]) || (e += t[i], n++); return 0 === n ? NaN : e / n }, sum: function (t) { for (var e = 0, n = 0; n < t.length; n++)e += t[n] || 0; return e }, max: function (t) { for (var e = -1 / 0, n = 0; n < t.length; n++)t[n] > e && (e = t[n]); return isFinite(e) ? e : NaN }, min: function (t) { for (var e = 1 / 0, n = 0; n < t.length; n++)t[n] < e && (e = t[n]); return isFinite(e) ? e : NaN }, nearest: function (t) { return t[0] } }, VS = function (t) { return Math.round(t.length / 2) }; function BS(t) { return { seriesType: t, reset: function (t, e, n) { var i = t.getData(), r = t.get("sampling"), o = t.coordinateSystem, a = i.count(); if (a > 10 && "cartesian2d" === o.type && r) { var s = o.getBaseAxis(), l = o.getOtherAxis(s), u = s.getExtent(), h = n.getDevicePixelRatio(), c = Math.abs(u[1] - u[0]) * (h || 1), p = Math.round(a / c); if (isFinite(p) && p > 1) { "lttb" === r && t.setData(i.lttbDownSample(i.mapDimension(l.dim), 1 / p)); var d = void 0; U(r) ? d = zS[r] : X(r) && (d = r), d && t.setData(i.downSample(i.mapDimension(l.dim), 1 / p, d, VS)) } } } } } var FS = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.getInitialData = function (t, e) { return vx(null, this, { useEncodeDefaulter: !0 }) }, e.prototype.getMarkerPosition = function (t, e, n) { var i = this.coordinateSystem; if (i && i.clampData) { var r = i.clampData(t), o = i.dataToPoint(r); if (n) E(i.getAxes(), (function (t, n) { if ("category" === t.type && null != e) { var i = t.getTicksCoords(), a = r[n], s = "x1" === e[n] || "y1" === e[n]; if (s && (a += 1), i.length < 2) return; if (2 === i.length) return void (o[n] = t.toGlobalCoord(t.getExtent()[s ? 1 : 0])); for (var l = void 0, u = void 0, h = 1, c = 0; c < i.length; c++) { var p = i[c].coord, d = c === i.length - 1 ? i[c - 1].tickValue + h : i[c].tickValue; if (d === a) { u = p; break } if (d < a) l = p; else if (null != l && d > a) { u = (p + l) / 2; break } 1 === c && (h = d - i[0].tickValue) } null == u && (l ? l && (u = i[i.length - 1].coord) : u = i[0].coord), o[n] = t.toGlobalCoord(u) } })); else { var a = this.getData(), s = a.getLayout("offset"), l = a.getLayout("size"), u = i.getBaseAxis().isHorizontal() ? 0 : 1; o[u] += s + l / 2 } return o } return [NaN, NaN] }, e.type = "series.__base_bar__", e.defaultOption = { z: 2, coordinateSystem: "cartesian2d", legendHoverLink: !0, barMinHeight: 0, barMinAngle: 0, large: !1, largeThreshold: 400, progressive: 3e3, progressiveChunkMode: "mod" }, e }(mg); mg.registerClass(FS); var GS = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.getInitialData = function () { return vx(null, this, { useEncodeDefaulter: !0, createInvertedIndices: !!this.get("realtimeSort", !0) || null }) }, e.prototype.getProgressive = function () { return !!this.get("large") && this.get("progressive") }, e.prototype.getProgressiveThreshold = function () { var t = this.get("progressiveThreshold"), e = this.get("largeThreshold"); return e > t && (t = e), t }, e.prototype.brushSelector = function (t, e, n) { return n.rect(e.getItemLayout(t)) }, e.type = "series.bar", e.dependencies = ["grid", "polar"], e.defaultOption = Cc(FS.defaultOption, { clip: !0, roundCap: !1, showBackground: !1, backgroundStyle: { color: "rgba(180, 180, 180, 0.2)", borderColor: null, borderWidth: 0, borderType: "solid", borderRadius: 0, shadowBlur: 0, shadowColor: null, shadowOffsetX: 0, shadowOffsetY: 0, opacity: 1 }, select: { itemStyle: { borderColor: "#212121" } }, realtimeSort: !1 }), e }(FS), WS = function () { this.cx = 0, this.cy = 0, this.r0 = 0, this.r = 0, this.startAngle = 0, this.endAngle = 2 * Math.PI, this.clockwise = !0 }, HS = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "sausage", n } return n(e, t), e.prototype.getDefaultShape = function () { return new WS }, e.prototype.buildPath = function (t, e) { var n = e.cx, i = e.cy, r = Math.max(e.r0 || 0, 0), o = Math.max(e.r, 0), a = .5 * (o - r), s = r + a, l = e.startAngle, u = e.endAngle, h = e.clockwise, c = 2 * Math.PI, p = h ? u - l < c : l - u < c; p || (l = u - (h ? c : -c)); var d = Math.cos(l), f = Math.sin(l), g = Math.cos(u), y = Math.sin(u); p ? (t.moveTo(d * r + n, f * r + i), t.arc(d * s + n, f * s + i, a, -Math.PI + l, l, !h)) : t.moveTo(d * o + n, f * o + i), t.arc(n, i, o, l, u, !h), t.arc(g * s + n, y * s + i, a, u - 2 * Math.PI, u - Math.PI, !h), 0 !== r && t.arc(n, i, r, u, l, h) }, e }(Is); function YS(t, e, n) { return e * Math.sin(t) * (n ? -1 : 1) } function XS(t, e, n) { return e * Math.cos(t) * (n ? 1 : -1) } function US(t, e, n) { var i = t.get("borderRadius"); if (null == i) return n ? { cornerRadius: 0 } : null; Y(i) || (i = [i, i, i, i]); var r = Math.abs(e.r || 0 - e.r0 || 0); return { cornerRadius: z(i, (function (t) { return Ir(t, r) })) } } var ZS = Math.max, jS = Math.min; var qS = function (t) { function e() { var n = t.call(this) || this; return n.type = e.type, n._isFirstFrame = !0, n } return n(e, t), e.prototype.render = function (t, e, n, i) { this._model = t, this._removeOnRenderedListener(n), this._updateDrawMode(t); var r = t.get("coordinateSystem"); ("cartesian2d" === r || "polar" === r) && (this._progressiveEls = null, this._isLargeDraw ? this._renderLarge(t, e, n) : this._renderNormal(t, e, n, i)) }, e.prototype.incrementalPrepareRender = function (t) { this._clear(), this._updateDrawMode(t), this._updateLargeClip(t) }, e.prototype.incrementalRender = function (t, e) { this._progressiveEls = [], this._incrementalRenderLarge(t, e) }, e.prototype.eachRendered = function (t) { qh(this._progressiveEls || this.group, t) }, e.prototype._updateDrawMode = function (t) { var e = t.pipelineContext.large; null != this._isLargeDraw && e === this._isLargeDraw || (this._isLargeDraw = e, this._clear()) }, e.prototype._renderNormal = function (t, e, n, i) { var r, o = this.group, a = t.getData(), s = this._data, l = t.coordinateSystem, u = l.getBaseAxis(); "cartesian2d" === l.type ? r = u.isHorizontal() : "polar" === l.type && (r = "angle" === u.dim); var h = t.isAnimationEnabled() ? t : null, c = function (t, e) { var n = t.get("realtimeSort", !0), i = e.getBaseAxis(); 0; if (n && "category" === i.type && "cartesian2d" === e.type) return { baseAxis: i, otherAxis: e.getOtherAxis(i) } }(t, l); c && this._enableRealtimeSort(c, a, n); var p = t.get("clip", !0) || c, d = function (t, e) { var n = t.getArea && t.getArea(); if (MS(t, "cartesian2d")) { var i = t.getBaseAxis(); if ("category" !== i.type || !i.onBand) { var r = e.getLayout("bandWidth"); i.isHorizontal() ? (n.x -= r, n.width += 2 * r) : (n.y -= r, n.height += 2 * r) } } return n }(l, a); o.removeClipPath(); var f = t.get("roundCap", !0), g = t.get("showBackground", !0), y = t.getModel("backgroundStyle"), v = y.get("borderRadius") || 0, m = [], x = this._backgroundEls, _ = i && i.isInitSort, b = i && "changeAxisOrder" === i.type; function w(t) { var e = iM[l.type](a, t), n = function (t, e, n) { var i = "polar" === t.type ? zu : zs; return new i({ shape: hM(e, n, t), silent: !0, z2: 0 }) }(l, r, e); return n.useStyle(y.getItemStyle()), "cartesian2d" === l.type ? n.setShape("r", v) : n.setShape("cornerRadius", v), m[t] = n, n } a.diff(s).add((function (e) { var n = a.getItemModel(e), i = iM[l.type](a, e, n); if (g && w(e), a.hasValue(e) && nM[l.type](i)) { var s = !1; p && (s = KS[l.type](d, i)); var y = $S[l.type](t, a, e, i, r, h, u.model, !1, f); c && (y.forceLabelAnimation = !0), oM(y, a, e, n, i, t, r, "polar" === l.type), _ ? y.attr({ shape: i }) : c ? JS(c, h, y, i, e, r, !1, !1) : gh(y, { shape: i }, t, e), a.setItemGraphicEl(e, y), o.add(y), y.ignore = s } })).update((function (e, n) { var i = a.getItemModel(e), S = iM[l.type](a, e, i); if (g) { var M = void 0; 0 === x.length ? M = w(n) : ((M = x[n]).useStyle(y.getItemStyle()), "cartesian2d" === l.type ? M.setShape("r", v) : M.setShape("cornerRadius", v), m[e] = M); var I = iM[l.type](a, e); fh(M, { shape: hM(r, I, l) }, h, e) } var T = s.getItemGraphicEl(n); if (a.hasValue(e) && nM[l.type](S)) { var C = !1; if (p && (C = KS[l.type](d, S)) && o.remove(T), T ? _h(T) : T = $S[l.type](t, a, e, S, r, h, u.model, !!T, f), c && (T.forceLabelAnimation = !0), b) { var D = T.getTextContent(); if (D) { var A = uc(D); null != A.prevValue && (A.prevValue = A.value) } } else oM(T, a, e, i, S, t, r, "polar" === l.type); _ ? T.attr({ shape: S }) : c ? JS(c, h, T, S, e, r, !0, b) : fh(T, { shape: S }, t, e, null), a.setItemGraphicEl(e, T), T.ignore = C, o.add(T) } else o.remove(T) })).remove((function (e) { var n = s.getItemGraphicEl(e); n && xh(n, t, e) })).execute(); var S = this._backgroundGroup || (this._backgroundGroup = new zr); S.removeAll(); for (var M = 0; M < m.length; ++M)S.add(m[M]); o.add(S), this._backgroundEls = m, this._data = a }, e.prototype._renderLarge = function (t, e, n) { this._clear(), lM(t, this.group), this._updateLargeClip(t) }, e.prototype._incrementalRenderLarge = function (t, e) { this._removeBackground(), lM(e, this.group, this._progressiveEls, !0) }, e.prototype._updateLargeClip = function (t) { var e = t.get("clip", !0) && SS(t.coordinateSystem, !1, t), n = this.group; e ? n.setClipPath(e) : n.removeClipPath() }, e.prototype._enableRealtimeSort = function (t, e, n) { var i = this; if (e.count()) { var r = t.baseAxis; if (this._isFirstFrame) this._dispatchInitSort(e, t, n), this._isFirstFrame = !1; else { var o = function (t) { var n = e.getItemGraphicEl(t), i = n && n.shape; return i && Math.abs(r.isHorizontal() ? i.height : i.width) || 0 }; this._onRendered = function () { i._updateSortWithinSameData(e, o, r, n) }, n.getZr().on("rendered", this._onRendered) } } }, e.prototype._dataSort = function (t, e, n) { var i = []; return t.each(t.mapDimension(e.dim), (function (t, e) { var r = n(e); r = null == r ? NaN : r, i.push({ dataIndex: e, mappedValue: r, ordinalNumber: t }) })), i.sort((function (t, e) { return e.mappedValue - t.mappedValue })), { ordinalNumbers: z(i, (function (t) { return t.ordinalNumber })) } }, e.prototype._isOrderChangedWithinSameData = function (t, e, n) { for (var i = n.scale, r = t.mapDimension(n.dim), o = Number.MAX_VALUE, a = 0, s = i.getOrdinalMeta().categories.length; a < s; ++a) { var l = t.rawIndexOf(r, i.getRawOrdinalNumber(a)), u = l < 0 ? Number.MIN_VALUE : e(t.indexOfRawIndex(l)); if (u > o) return !0; o = u } return !1 }, e.prototype._isOrderDifferentInView = function (t, e) { for (var n = e.scale, i = n.getExtent(), r = Math.max(0, i[0]), o = Math.min(i[1], n.getOrdinalMeta().categories.length - 1); r <= o; ++r)if (t.ordinalNumbers[r] !== n.getRawOrdinalNumber(r)) return !0 }, e.prototype._updateSortWithinSameData = function (t, e, n, i) { if (this._isOrderChangedWithinSameData(t, e, n)) { var r = this._dataSort(t, n, e); this._isOrderDifferentInView(r, n) && (this._removeOnRenderedListener(i), i.dispatchAction({ type: "changeAxisOrder", componentType: n.dim + "Axis", axisId: n.index, sortInfo: r })) } }, e.prototype._dispatchInitSort = function (t, e, n) { var i = e.baseAxis, r = this._dataSort(t, i, (function (n) { return t.get(t.mapDimension(e.otherAxis.dim), n) })); n.dispatchAction({ type: "changeAxisOrder", componentType: i.dim + "Axis", isInitSort: !0, axisId: i.index, sortInfo: r }) }, e.prototype.remove = function (t, e) { this._clear(this._model), this._removeOnRenderedListener(e) }, e.prototype.dispose = function (t, e) { this._removeOnRenderedListener(e) }, e.prototype._removeOnRenderedListener = function (t) { this._onRendered && (t.getZr().off("rendered", this._onRendered), this._onRendered = null) }, e.prototype._clear = function (t) { var e = this.group, n = this._data; t && t.isAnimationEnabled() && n && !this._isLargeDraw ? (this._removeBackground(), this._backgroundEls = [], n.eachItemGraphicEl((function (e) { xh(e, t, Qs(e).dataIndex) }))) : e.removeAll(), this._data = null, this._isFirstFrame = !0 }, e.prototype._removeBackground = function () { this.group.remove(this._backgroundGroup), this._backgroundGroup = null }, e.type = "bar", e }(kg), KS = { cartesian2d: function (t, e) { var n = e.width < 0 ? -1 : 1, i = e.height < 0 ? -1 : 1; n < 0 && (e.x += e.width, e.width = -e.width), i < 0 && (e.y += e.height, e.height = -e.height); var r = t.x + t.width, o = t.y + t.height, a = ZS(e.x, t.x), s = jS(e.x + e.width, r), l = ZS(e.y, t.y), u = jS(e.y + e.height, o), h = s < a, c = u < l; return e.x = h && a > r ? s : a, e.y = c && l > o ? u : l, e.width = h ? 0 : s - a, e.height = c ? 0 : u - l, n < 0 && (e.x += e.width, e.width = -e.width), i < 0 && (e.y += e.height, e.height = -e.height), h || c }, polar: function (t, e) { var n = e.r0 <= e.r ? 1 : -1; if (n < 0) { var i = e.r; e.r = e.r0, e.r0 = i } var r = jS(e.r, t.r), o = ZS(e.r0, t.r0); e.r = r, e.r0 = o; var a = r - o < 0; if (n < 0) { i = e.r; e.r = e.r0, e.r0 = i } return a } }, $S = { cartesian2d: function (t, e, n, i, r, o, a, s, l) { var u = new zs({ shape: A({}, i), z2: 1 }); (u.__dataIndex = n, u.name = "item", o) && (u.shape[r ? "height" : "width"] = 0); return u }, polar: function (t, e, n, i, r, o, a, s, l) { var u = !r && l ? HS : zu, h = new u({ shape: i, z2: 1 }); h.name = "item"; var c, p, d = rM(r); if (h.calculateTextPosition = (c = d, p = ({ isRoundCap: u === HS } || {}).isRoundCap, function (t, e, n) { var i = e.position; if (!i || i instanceof Array) return Tr(t, e, n); var r = c(i), o = null != e.distance ? e.distance : 5, a = this.shape, s = a.cx, l = a.cy, u = a.r, h = a.r0, d = (u + h) / 2, f = a.startAngle, g = a.endAngle, y = (f + g) / 2, v = p ? Math.abs(u - h) / 2 : 0, m = Math.cos, x = Math.sin, _ = s + u * m(f), b = l + u * x(f), w = "left", S = "top"; switch (r) { case "startArc": _ = s + (h - o) * m(y), b = l + (h - o) * x(y), w = "center", S = "top"; break; case "insideStartArc": _ = s + (h + o) * m(y), b = l + (h + o) * x(y), w = "center", S = "bottom"; break; case "startAngle": _ = s + d * m(f) + YS(f, o + v, !1), b = l + d * x(f) + XS(f, o + v, !1), w = "right", S = "middle"; break; case "insideStartAngle": _ = s + d * m(f) + YS(f, -o + v, !1), b = l + d * x(f) + XS(f, -o + v, !1), w = "left", S = "middle"; break; case "middle": _ = s + d * m(y), b = l + d * x(y), w = "center", S = "middle"; break; case "endArc": _ = s + (u + o) * m(y), b = l + (u + o) * x(y), w = "center", S = "bottom"; break; case "insideEndArc": _ = s + (u - o) * m(y), b = l + (u - o) * x(y), w = "center", S = "top"; break; case "endAngle": _ = s + d * m(g) + YS(g, o + v, !0), b = l + d * x(g) + XS(g, o + v, !0), w = "left", S = "middle"; break; case "insideEndAngle": _ = s + d * m(g) + YS(g, -o + v, !0), b = l + d * x(g) + XS(g, -o + v, !0), w = "right", S = "middle"; break; default: return Tr(t, e, n) }return (t = t || {}).x = _, t.y = b, t.align = w, t.verticalAlign = S, t }), o) { var f = r ? "r" : "endAngle", g = {}; h.shape[f] = r ? i.r0 : i.startAngle, g[f] = i[f], (s ? fh : gh)(h, { shape: g }, o) } return h } }; function JS(t, e, n, i, r, o, a, s) { var l, u; o ? (u = { x: i.x, width: i.width }, l = { y: i.y, height: i.height }) : (u = { y: i.y, height: i.height }, l = { x: i.x, width: i.width }), s || (a ? fh : gh)(n, { shape: l }, e, r, null), (a ? fh : gh)(n, { shape: u }, e ? t.baseAxis.model : null, r) } function QS(t, e) { for (var n = 0; n < e.length; n++)if (!isFinite(t[e[n]])) return !0; return !1 } var tM = ["x", "y", "width", "height"], eM = ["cx", "cy", "r", "startAngle", "endAngle"], nM = { cartesian2d: function (t) { return !QS(t, tM) }, polar: function (t) { return !QS(t, eM) } }, iM = { cartesian2d: function (t, e, n) { var i = t.getItemLayout(e), r = n ? function (t, e) { var n = t.get(["itemStyle", "borderColor"]); if (!n || "none" === n) return 0; var i = t.get(["itemStyle", "borderWidth"]) || 0, r = isNaN(e.width) ? Number.MAX_VALUE : Math.abs(e.width), o = isNaN(e.height) ? Number.MAX_VALUE : Math.abs(e.height); return Math.min(i, r, o) }(n, i) : 0, o = i.width > 0 ? 1 : -1, a = i.height > 0 ? 1 : -1; return { x: i.x + o * r / 2, y: i.y + a * r / 2, width: i.width - o * r, height: i.height - a * r } }, polar: function (t, e, n) { var i = t.getItemLayout(e); return { cx: i.cx, cy: i.cy, r0: i.r0, r: i.r, startAngle: i.startAngle, endAngle: i.endAngle, clockwise: i.clockwise } } }; function rM(t) { return function (t) { var e = t ? "Arc" : "Angle"; return function (t) { switch (t) { case "start": case "insideStart": case "end": case "insideEnd": return t + e; default: return t } } }(t) } function oM(t, e, n, i, r, o, a, s) { var l = e.getItemVisual(n, "style"); if (s) { if (!o.get("roundCap")) { var u = t.shape; A(u, US(i.getModel("itemStyle"), u, !0)), t.setShape(u) } } else { var h = i.get(["itemStyle", "borderRadius"]) || 0; t.setShape("r", h) } t.useStyle(l); var c = i.getShallow("cursor"); c && t.attr("cursor", c); var p = s ? a ? r.r >= r.r0 ? "endArc" : "startArc" : r.endAngle >= r.startAngle ? "endAngle" : "startAngle" : a ? r.height >= 0 ? "bottom" : "top" : r.width >= 0 ? "right" : "left", d = ec(i); tc(t, d, { labelFetcher: o, labelDataIndex: n, defaultText: iS(o.getData(), n), inheritColor: l.fill, defaultOpacity: l.opacity, defaultOutsidePosition: p }); var f = t.getTextContent(); if (s && f) { var g = i.get(["label", "position"]); t.textConfig.inside = "middle" === g || null, function (t, e, n, i) { if (j(i)) t.setTextConfig({ rotation: i }); else if (Y(e)) t.setTextConfig({ rotation: 0 }); else { var r, o = t.shape, a = o.clockwise ? o.startAngle : o.endAngle, s = o.clockwise ? o.endAngle : o.startAngle, l = (a + s) / 2, u = n(e); switch (u) { case "startArc": case "insideStartArc": case "middle": case "insideEndArc": case "endArc": r = l; break; case "startAngle": case "insideStartAngle": r = a; break; case "endAngle": case "insideEndAngle": r = s; break; default: return void t.setTextConfig({ rotation: 0 }) }var h = 1.5 * Math.PI - r; "middle" === u && h > Math.PI / 2 && h < 1.5 * Math.PI && (h -= Math.PI), t.setTextConfig({ rotation: h }) } }(t, "outside" === g ? p : g, rM(a), i.get(["label", "rotate"])) } hc(f, d, o.getRawValue(n), (function (t) { return rS(e, t) })); var y = i.getModel(["emphasis"]); Yl(t, y.get("focus"), y.get("blurScope"), y.get("disabled")), jl(t, i), function (t) { return null != t.startAngle && null != t.endAngle && t.startAngle === t.endAngle }(r) && (t.style.fill = "none", t.style.stroke = "none", E(t.states, (function (t) { t.style && (t.style.fill = t.style.stroke = "none") }))) } var aM = function () { }, sM = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "largeBar", n } return n(e, t), e.prototype.getDefaultShape = function () { return new aM }, e.prototype.buildPath = function (t, e) { for (var n = e.points, i = this.baseDimIdx, r = 1 - this.baseDimIdx, o = [], a = [], s = this.barWidth, l = 0; l < n.length; l += 3)a[i] = s, a[r] = n[l + 2], o[i] = n[l + i], o[r] = n[l + r], t.rect(o[0], o[1], a[0], a[1]) }, e }(Is); function lM(t, e, n, i) { var r = t.getData(), o = r.getLayout("valueAxisHorizontal") ? 1 : 0, a = r.getLayout("largeDataIndices"), s = r.getLayout("size"), l = t.getModel("backgroundStyle"), u = r.getLayout("largeBackgroundPoints"); if (u) { var h = new sM({ shape: { points: u }, incremental: !!i, silent: !0, z2: 0 }); h.baseDimIdx = o, h.largeDataIndices = a, h.barWidth = s, h.useStyle(l.getItemStyle()), e.add(h), n && n.push(h) } var c = new sM({ shape: { points: r.getLayout("largePoints") }, incremental: !!i, ignoreCoarsePointer: !0, z2: 1 }); c.baseDimIdx = o, c.largeDataIndices = a, c.barWidth = s, e.add(c), c.useStyle(r.getVisual("style")), Qs(c).seriesIndex = t.seriesIndex, t.get("silent") || (c.on("mousedown", uM), c.on("mousemove", uM)), n && n.push(c) } var uM = Bg((function (t) { var e = function (t, e, n) { for (var i = t.baseDimIdx, r = 1 - i, o = t.shape.points, a = t.largeDataIndices, s = [], l = [], u = t.barWidth, h = 0, c = o.length / 3; h < c; h++) { var p = 3 * h; if (l[i] = u, l[r] = o[p + 2], s[i] = o[p + i], s[r] = o[p + r], l[r] < 0 && (s[r] += l[r], l[r] = -l[r]), e >= s[0] && e <= s[0] + l[0] && n >= s[1] && n <= s[1] + l[1]) return a[h] } return -1 }(this, t.offsetX, t.offsetY); Qs(this).dataIndex = e >= 0 ? e : null }), 30, !1); function hM(t, e, n) { if (MS(n, "cartesian2d")) { var i = e, r = n.getArea(); return { x: t ? i.x : r.x, y: t ? r.y : i.y, width: t ? i.width : r.width, height: t ? r.height : i.height } } var o = e; return { cx: (r = n.getArea()).cx, cy: r.cy, r0: t ? r.r0 : o.r0, r: t ? r.r : o.r, startAngle: t ? o.startAngle : 0, endAngle: t ? o.endAngle : 2 * Math.PI } } var cM = 2 * Math.PI, pM = Math.PI / 180; function dM(t, e) { return Cp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }) } function fM(t, e) { var n = dM(t, e), i = t.get("center"), r = t.get("radius"); Y(r) || (r = [0, r]); var o, a, s = Ur(n.width, e.getWidth()), l = Ur(n.height, e.getHeight()), u = Math.min(s, l), h = Ur(r[0], u / 2), c = Ur(r[1], u / 2), p = t.coordinateSystem; if (p) { var d = p.dataToPoint(i); o = d[0] || 0, a = d[1] || 0 } else Y(i) || (i = [i, i]), o = Ur(i[0], s) + n.x, a = Ur(i[1], l) + n.y; return { cx: o, cy: a, r0: h, r: c } } function gM(t, e, n) { e.eachSeriesByType(t, (function (t) { var e = t.getData(), i = e.mapDimension("value"), r = dM(t, n), o = fM(t, n), a = o.cx, s = o.cy, l = o.r, u = o.r0, h = -t.get("startAngle") * pM, c = t.get("minAngle") * pM, p = 0; e.each(i, (function (t) { !isNaN(t) && p++ })); var d = e.getSum(i), f = Math.PI / (d || p) * 2, g = t.get("clockwise"), y = t.get("roseType"), v = t.get("stillShowZeroSum"), m = e.getDataExtent(i); m[0] = 0; var x = cM, _ = 0, b = h, w = g ? 1 : -1; if (e.setLayout({ viewRect: r, r: l }), e.each(i, (function (t, n) { var i; if (isNaN(t)) e.setItemLayout(n, { angle: NaN, startAngle: NaN, endAngle: NaN, clockwise: g, cx: a, cy: s, r0: u, r: y ? NaN : l }); else { (i = "area" !== y ? 0 === d && v ? f : t * f : cM / p) < c ? (i = c, x -= c) : _ += t; var r = b + w * i; e.setItemLayout(n, { angle: i, startAngle: b, endAngle: r, clockwise: g, cx: a, cy: s, r0: u, r: y ? Xr(t, m, [u, l]) : l }), b = r } })), x < cM && p) if (x <= .001) { var S = cM / p; e.each(i, (function (t, n) { if (!isNaN(t)) { var i = e.getItemLayout(n); i.angle = S, i.startAngle = h + w * n * S, i.endAngle = h + w * (n + 1) * S } })) } else f = x / _, b = h, e.each(i, (function (t, n) { if (!isNaN(t)) { var i = e.getItemLayout(n), r = i.angle === c ? c : t * f; i.startAngle = b, i.endAngle = b + w * r, b += w * r } })) })) } function yM(t) { return { seriesType: t, reset: function (t, e) { var n = e.findComponents({ mainType: "legend" }); if (n && n.length) { var i = t.getData(); i.filterSelf((function (t) { for (var e = i.getName(t), r = 0; r < n.length; r++)if (!n[r].isSelected(e)) return !1; return !0 })) } } } } var vM = Math.PI / 180; function mM(t, e, n, i, r, o, a, s, l, u) { if (!(t.length < 2)) { for (var h = t.length, c = 0; c < h; c++)if ("outer" === t[c].position && "labelLine" === t[c].labelAlignTo) { var p = t[c].label.x - u; t[c].linePoints[1][0] += p, t[c].label.x = u } kb(t, l, l + a) && function (t) { for (var o = { list: [], maxY: 0 }, a = { list: [], maxY: 0 }, s = 0; s < t.length; s++)if ("none" === t[s].labelAlignTo) { var l = t[s], u = l.label.y > n ? a : o, h = Math.abs(l.label.y - n); if (h >= u.maxY) { var c = l.label.x - e - l.len2 * r, p = i + l.len, f = Math.abs(c) < p ? Math.sqrt(h * h / (1 - c * c / p / p)) : p; u.rB = f, u.maxY = h } u.list.push(l) } d(o), d(a) }(t) } function d(t) { for (var o = t.rB, a = o * o, s = 0; s < t.list.length; s++) { var l = t.list[s], u = Math.abs(l.label.y - n), h = i + l.len, c = h * h, p = Math.sqrt((1 - Math.abs(u * u / a)) * c), d = e + (p + l.len2) * r, f = d - l.label.x; xM(l, l.targetTextWidth - f * r, !0), l.label.x = d } } } function xM(t, e, n) { if (void 0 === n && (n = !1), null == t.labelStyleWidth) { var i = t.label, r = i.style, o = t.rect, a = r.backgroundColor, s = r.padding, l = s ? s[1] + s[3] : 0, u = r.overflow, h = o.width + (a ? 0 : l); if (e < h || n) { var c = o.height; if (u && u.match("break")) { i.setStyle("backgroundColor", null), i.setStyle("width", e - l); var p = i.getBoundingRect(); i.setStyle("width", Math.ceil(p.width)), i.setStyle("backgroundColor", a) } else { var d = e - l, f = e < h ? d : n ? d > t.unconstrainedWidth ? null : d : null; i.setStyle("width", f) } var g = i.getBoundingRect(); o.width = g.width; var y = (i.style.margin || 0) + 2.1; o.height = g.height + y, o.y -= (o.height - c) / 2 } } } function _M(t) { return "center" === t.position } function bM(t) { var e, n, i = t.getData(), r = [], o = !1, a = (t.get("minShowLabelAngle") || 0) * vM, s = i.getLayout("viewRect"), l = i.getLayout("r"), u = s.width, h = s.x, c = s.y, p = s.height; function d(t) { t.ignore = !0 } i.each((function (t) { var s = i.getItemGraphicEl(t), c = s.shape, p = s.getTextContent(), f = s.getTextGuideLine(), g = i.getItemModel(t), y = g.getModel("label"), v = y.get("position") || g.get(["emphasis", "label", "position"]), m = y.get("distanceToLabelLine"), x = y.get("alignTo"), _ = Ur(y.get("edgeDistance"), u), b = y.get("bleedMargin"), w = g.getModel("labelLine"), S = w.get("length"); S = Ur(S, u); var M = w.get("length2"); if (M = Ur(M, u), Math.abs(c.endAngle - c.startAngle) < a) return E(p.states, d), p.ignore = !0, void (f && (E(f.states, d), f.ignore = !0)); if (function (t) { if (!t.ignore) return !0; for (var e in t.states) if (!1 === t.states[e].ignore) return !0; return !1 }(p)) { var I, T, C, D, A = (c.startAngle + c.endAngle) / 2, k = Math.cos(A), L = Math.sin(A); e = c.cx, n = c.cy; var P = "inside" === v || "inner" === v; if ("center" === v) I = c.cx, T = c.cy, D = "center"; else { var O = (P ? (c.r + c.r0) / 2 * k : c.r * k) + e, R = (P ? (c.r + c.r0) / 2 * L : c.r * L) + n; if (I = O + 3 * k, T = R + 3 * L, !P) { var N = O + k * (S + l - c.r), z = R + L * (S + l - c.r), V = N + (k < 0 ? -1 : 1) * M; I = "edge" === x ? k < 0 ? h + _ : h + u - _ : V + (k < 0 ? -m : m), T = z, C = [[O, R], [N, z], [V, z]] } D = P ? "center" : "edge" === x ? k > 0 ? "right" : "left" : k > 0 ? "left" : "right" } var B = Math.PI, F = 0, G = y.get("rotate"); if (j(G)) F = G * (B / 180); else if ("center" === v) F = 0; else if ("radial" === G || !0 === G) { F = k < 0 ? -A + B : -A } else if ("tangential" === G && "outside" !== v && "outer" !== v) { var W = Math.atan2(k, L); W < 0 && (W = 2 * B + W), L > 0 && (W = B + W), F = W - B } if (o = !!F, p.x = I, p.y = T, p.rotation = F, p.setStyle({ verticalAlign: "middle" }), P) { p.setStyle({ align: D }); var H = p.states.select; H && (H.x += p.x, H.y += p.y) } else { var Y = p.getBoundingRect().clone(); Y.applyTransform(p.getComputedTransform()); var X = (p.style.margin || 0) + 2.1; Y.y -= X / 2, Y.height += X, r.push({ label: p, labelLine: f, position: v, len: S, len2: M, minTurnAngle: w.get("minTurnAngle"), maxSurfaceAngle: w.get("maxSurfaceAngle"), surfaceNormal: new De(k, L), linePoints: C, textAlign: D, labelDistance: m, labelAlignTo: x, edgeDistance: _, bleedMargin: b, rect: Y, unconstrainedWidth: Y.width, labelStyleWidth: p.style.width }) } s.setTextConfig({ inside: P }) } })), !o && t.get("avoidLabelOverlap") && function (t, e, n, i, r, o, a, s) { for (var l = [], u = [], h = Number.MAX_VALUE, c = -Number.MAX_VALUE, p = 0; p < t.length; p++) { var d = t[p].label; _M(t[p]) || (d.x < e ? (h = Math.min(h, d.x), l.push(t[p])) : (c = Math.max(c, d.x), u.push(t[p]))) } for (p = 0; p < t.length; p++)if (!_M(y = t[p]) && y.linePoints) { if (null != y.labelStyleWidth) continue; d = y.label; var f = y.linePoints, g = void 0; g = "edge" === y.labelAlignTo ? d.x < e ? f[2][0] - y.labelDistance - a - y.edgeDistance : a + r - y.edgeDistance - f[2][0] - y.labelDistance : "labelLine" === y.labelAlignTo ? d.x < e ? h - a - y.bleedMargin : a + r - c - y.bleedMargin : d.x < e ? d.x - a - y.bleedMargin : a + r - d.x - y.bleedMargin, y.targetTextWidth = g, xM(y, g) } for (mM(u, e, n, i, 1, 0, o, 0, s, c), mM(l, e, n, i, -1, 0, o, 0, s, h), p = 0; p < t.length; p++) { var y; if (!_M(y = t[p]) && y.linePoints) { d = y.label, f = y.linePoints; var v = "edge" === y.labelAlignTo, m = d.style.padding, x = m ? m[1] + m[3] : 0, _ = d.style.backgroundColor ? 0 : x, b = y.rect.width + _, w = f[1][0] - f[2][0]; v ? d.x < e ? f[2][0] = a + y.edgeDistance + b + y.labelDistance : f[2][0] = a + r - y.edgeDistance - b - y.labelDistance : (d.x < e ? f[2][0] = d.x + y.labelDistance : f[2][0] = d.x - y.labelDistance, f[1][0] = f[2][0] + w), f[1][1] = f[2][1] = d.y } } }(r, e, n, l, u, p, h, c); for (var f = 0; f < r.length; f++) { var g = r[f], y = g.label, v = g.labelLine, m = isNaN(y.x) || isNaN(y.y); if (y) { y.setStyle({ align: g.textAlign }), m && (E(y.states, d), y.ignore = !0); var x = y.states.select; x && (x.x += y.x, x.y += y.y) } if (v) { var _ = g.linePoints; m || !_ ? (E(v.states, d), v.ignore = !0) : (wb(_, g.minTurnAngle), Sb(_, g.surfaceNormal, g.maxSurfaceAngle), v.setShape({ points: _ }), y.__hostTarget.textGuideLineConfig = { anchor: new De(_[0][0], _[0][1]) }) } } } var wM = function (t) { function e(e, n, i) { var r = t.call(this) || this; r.z2 = 2; var o = new Fs; return r.setTextContent(o), r.updateData(e, n, i, !0), r } return n(e, t), e.prototype.updateData = function (t, e, n, i) { var r = this, o = t.hostModel, a = t.getItemModel(e), s = a.getModel("emphasis"), l = t.getItemLayout(e), u = A(US(a.getModel("itemStyle"), l, !0), l); if (isNaN(u.startAngle)) r.setShape(u); else { if (i) { r.setShape(u); var h = o.getShallow("animationType"); o.ecModel.ssr ? (gh(r, { scaleX: 0, scaleY: 0 }, o, { dataIndex: e, isFrom: !0 }), r.originX = u.cx, r.originY = u.cy) : "scale" === h ? (r.shape.r = l.r0, gh(r, { shape: { r: l.r } }, o, e)) : null != n ? (r.setShape({ startAngle: n, endAngle: n }), gh(r, { shape: { startAngle: l.startAngle, endAngle: l.endAngle } }, o, e)) : (r.shape.endAngle = l.startAngle, fh(r, { shape: { endAngle: l.endAngle } }, o, e)) } else _h(r), fh(r, { shape: u }, o, e); r.useStyle(t.getItemVisual(e, "style")), jl(r, a); var c = (l.startAngle + l.endAngle) / 2, p = o.get("selectedOffset"), d = Math.cos(c) * p, f = Math.sin(c) * p, g = a.getShallow("cursor"); g && r.attr("cursor", g), this._updateLabel(o, t, e), r.ensureState("emphasis").shape = A({ r: l.r + (s.get("scale") && s.get("scaleSize") || 0) }, US(s.getModel("itemStyle"), l)), A(r.ensureState("select"), { x: d, y: f, shape: US(a.getModel(["select", "itemStyle"]), l) }), A(r.ensureState("blur"), { shape: US(a.getModel(["blur", "itemStyle"]), l) }); var y = r.getTextGuideLine(), v = r.getTextContent(); y && A(y.ensureState("select"), { x: d, y: f }), A(v.ensureState("select"), { x: d, y: f }), Yl(this, s.get("focus"), s.get("blurScope"), s.get("disabled")) } }, e.prototype._updateLabel = function (t, e, n) { var i = this, r = e.getItemModel(n), o = r.getModel("labelLine"), a = e.getItemVisual(n, "style"), s = a && a.fill, l = a && a.opacity; tc(i, ec(r), { labelFetcher: e.hostModel, labelDataIndex: n, inheritColor: s, defaultOpacity: l, defaultText: t.getFormattedLabel(n, "normal") || e.getName(n) }); var u = i.getTextContent(); i.setTextConfig({ position: null, rotation: null }), u.attr({ z2: 10 }); var h = t.get(["label", "position"]); if ("outside" !== h && "outer" !== h) i.removeTextGuideLine(); else { var c = this.getTextGuideLine(); c || (c = new Yu, this.setTextGuideLine(c)), Tb(this, Cb(r), { stroke: s, opacity: ot(o.get(["lineStyle", "opacity"]), l, 1) }) } }, e }(zu), SM = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.ignoreLabelLineUpdate = !0, e } return n(e, t), e.prototype.render = function (t, e, n, i) { var r, o = t.getData(), a = this._data, s = this.group; if (!a && o.count() > 0) { for (var l = o.getItemLayout(0), u = 1; isNaN(l && l.startAngle) && u < o.count(); ++u)l = o.getItemLayout(u); l && (r = l.startAngle) } if (this._emptyCircleSector && s.remove(this._emptyCircleSector), 0 === o.count() && t.get("showEmptyCircle")) { var h = new zu({ shape: fM(t, n) }); h.useStyle(t.getModel("emptyCircleStyle").getItemStyle()), this._emptyCircleSector = h, s.add(h) } o.diff(a).add((function (t) { var e = new wM(o, t, r); o.setItemGraphicEl(t, e), s.add(e) })).update((function (t, e) { var n = a.getItemGraphicEl(e); n.updateData(o, t, r), n.off("click"), s.add(n), o.setItemGraphicEl(t, n) })).remove((function (e) { xh(a.getItemGraphicEl(e), t, e) })).execute(), bM(t), "expansion" !== t.get("animationTypeUpdate") && (this._data = o) }, e.prototype.dispose = function () { }, e.prototype.containPoint = function (t, e) { var n = e.getData().getItemLayout(0); if (n) { var i = t[0] - n.cx, r = t[1] - n.cy, o = Math.sqrt(i * i + r * r); return o <= n.r && o >= n.r0 } }, e.type = "pie", e }(kg); function MM(t, e, n) { e = Y(e) && { coordDimensions: e } || A({ encodeDefine: t.getEncode() }, e); var i = t.getSource(), r = ux(i, e).dimensions, o = new lx(r, t); return o.initData(i, n), o } var IM = function () { function t(t, e) { this._getDataWithEncodedVisual = t, this._getRawData = e } return t.prototype.getAllNames = function () { var t = this._getRawData(); return t.mapArray(t.getName) }, t.prototype.containName = function (t) { return this._getRawData().indexOfName(t) >= 0 }, t.prototype.indexOfName = function (t) { return this._getDataWithEncodedVisual().indexOfName(t) }, t.prototype.getItemVisual = function (t, e) { return this._getDataWithEncodedVisual().getItemVisual(t, e) }, t }(), TM = Oo(), CM = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), this.legendVisualProvider = new IM(W(this.getData, this), W(this.getRawData, this)), this._defaultLabelLine(e) }, e.prototype.mergeOption = function () { t.prototype.mergeOption.apply(this, arguments) }, e.prototype.getInitialData = function () { return MM(this, { coordDimensions: ["value"], encodeDefaulter: H(Jp, this) }) }, e.prototype.getDataParams = function (e) { var n = this.getData(), i = TM(n), r = i.seats; if (!r) { var o = []; n.each(n.mapDimension("value"), (function (t) { o.push(t) })), r = i.seats = Jr(o, n.hostModel.get("percentPrecision")) } var a = t.prototype.getDataParams.call(this, e); return a.percent = r[e] || 0, a.$vars.push("percent"), a }, e.prototype._defaultLabelLine = function (t) { wo(t, "labelLine", ["show"]); var e = t.labelLine, n = t.emphasis.labelLine; e.show = e.show && t.label.show, n.show = n.show && t.emphasis.label.show }, e.type = "series.pie", e.defaultOption = { z: 2, legendHoverLink: !0, colorBy: "data", center: ["50%", "50%"], radius: [0, "75%"], clockwise: !0, startAngle: 90, minAngle: 0, minShowLabelAngle: 0, selectedOffset: 10, percentPrecision: 2, stillShowZeroSum: !0, left: 0, top: 0, right: 0, bottom: 0, width: null, height: null, label: { rotate: 0, show: !0, overflow: "truncate", position: "outer", alignTo: "none", edgeDistance: "25%", bleedMargin: 10, distanceToLabelLine: 5 }, labelLine: { show: !0, length: 15, length2: 15, smooth: !1, minTurnAngle: 90, maxSurfaceAngle: 90, lineStyle: { width: 1, type: "solid" } }, itemStyle: { borderWidth: 1, borderJoin: "round" }, showEmptyCircle: !0, emptyCircleStyle: { color: "lightgray", opacity: 1 }, labelLayout: { hideOverlap: !0 }, emphasis: { scale: !0, scaleSize: 5 }, avoidLabelOverlap: !0, animationType: "expansion", animationDuration: 1e3, animationTypeUpdate: "transition", animationEasingUpdate: "cubicInOut", animationDurationUpdate: 500, animationEasing: "cubicInOut" }, e }(mg); var DM = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.hasSymbolVisual = !0, n } return n(e, t), e.prototype.getInitialData = function (t, e) { return vx(null, this, { useEncodeDefaulter: !0 }) }, e.prototype.getProgressive = function () { var t = this.option.progressive; return null == t ? this.option.large ? 5e3 : this.get("progressive") : t }, e.prototype.getProgressiveThreshold = function () { var t = this.option.progressiveThreshold; return null == t ? this.option.large ? 1e4 : this.get("progressiveThreshold") : t }, e.prototype.brushSelector = function (t, e, n) { return n.point(e.getItemLayout(t)) }, e.prototype.getZLevelKey = function () { return this.getData().count() > this.getProgressiveThreshold() ? this.id : "" }, e.type = "series.scatter", e.dependencies = ["grid", "polar", "geo", "singleAxis", "calendar"], e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, legendHoverLink: !0, symbolSize: 10, large: !1, largeThreshold: 2e3, itemStyle: { opacity: .8 }, emphasis: { scale: !0 }, clip: !0, select: { itemStyle: { borderColor: "#212121" } }, universalTransition: { divideShape: "clone" } }, e }(mg), AM = function () { }, kM = function (t) { function e(e) { var n = t.call(this, e) || this; return n._off = 0, n.hoverDataIdx = -1, n } return n(e, t), e.prototype.getDefaultShape = function () { return new AM }, e.prototype.reset = function () { this.notClear = !1, this._off = 0 }, e.prototype.buildPath = function (t, e) { var n, i = e.points, r = e.size, o = this.symbolProxy, a = o.shape, s = t.getContext ? t.getContext() : t, l = s && r[0] < 4, u = this.softClipShape; if (l) this._ctx = s; else { for (this._ctx = null, n = this._off; n < i.length;) { var h = i[n++], c = i[n++]; isNaN(h) || isNaN(c) || (u && !u.contain(h, c) || (a.x = h - r[0] / 2, a.y = c - r[1] / 2, a.width = r[0], a.height = r[1], o.buildPath(t, a, !0))) } this.incremental && (this._off = n, this.notClear = !0) } }, e.prototype.afterBrush = function () { var t, e = this.shape, n = e.points, i = e.size, r = this._ctx, o = this.softClipShape; if (r) { for (t = this._off; t < n.length;) { var a = n[t++], s = n[t++]; isNaN(a) || isNaN(s) || (o && !o.contain(a, s) || r.fillRect(a - i[0] / 2, s - i[1] / 2, i[0], i[1])) } this.incremental && (this._off = t, this.notClear = !0) } }, e.prototype.findDataIndex = function (t, e) { for (var n = this.shape, i = n.points, r = n.size, o = Math.max(r[0], 4), a = Math.max(r[1], 4), s = i.length / 2 - 1; s >= 0; s--) { var l = 2 * s, u = i[l] - o / 2, h = i[l + 1] - a / 2; if (t >= u && e >= h && t <= u + o && e <= h + a) return s } return -1 }, e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e), i = this.getBoundingRect(); return t = n[0], e = n[1], i.contain(t, e) ? (this.hoverDataIdx = this.findDataIndex(t, e)) >= 0 : (this.hoverDataIdx = -1, !1) }, e.prototype.getBoundingRect = function () { var t = this._rect; if (!t) { for (var e = this.shape, n = e.points, i = e.size, r = i[0], o = i[1], a = 1 / 0, s = 1 / 0, l = -1 / 0, u = -1 / 0, h = 0; h < n.length;) { var c = n[h++], p = n[h++]; a = Math.min(c, a), l = Math.max(c, l), s = Math.min(p, s), u = Math.max(p, u) } t = this._rect = new ze(a - r / 2, s - o / 2, l - a + r, u - s + o) } return t }, e }(Is), LM = function () { function t() { this.group = new zr } return t.prototype.updateData = function (t, e) { this._clear(); var n = this._create(); n.setShape({ points: t.getLayout("points") }), this._setCommon(n, t, e) }, t.prototype.updateLayout = function (t) { var e = t.getLayout("points"); this.group.eachChild((function (t) { if (null != t.startIndex) { var n = 2 * (t.endIndex - t.startIndex), i = 4 * t.startIndex * 2; e = new Float32Array(e.buffer, i, n) } t.setShape("points", e), t.reset() })) }, t.prototype.incrementalPrepareUpdate = function (t) { this._clear() }, t.prototype.incrementalUpdate = function (t, e, n) { var i = this._newAdded[0], r = e.getLayout("points"), o = i && i.shape.points; if (o && o.length < 2e4) { var a = o.length, s = new Float32Array(a + r.length); s.set(o), s.set(r, a), i.endIndex = t.end, i.setShape({ points: s }) } else { this._newAdded = []; var l = this._create(); l.startIndex = t.start, l.endIndex = t.end, l.incremental = !0, l.setShape({ points: r }), this._setCommon(l, e, n) } }, t.prototype.eachRendered = function (t) { this._newAdded[0] && t(this._newAdded[0]) }, t.prototype._create = function () { var t = new kM({ cursor: "default" }); return t.ignoreCoarsePointer = !0, this.group.add(t), this._newAdded.push(t), t }, t.prototype._setCommon = function (t, e, n) { var i = e.hostModel; n = n || {}; var r = e.getVisual("symbolSize"); t.setShape("size", r instanceof Array ? r : [r, r]), t.softClipShape = n.clipShape || null, t.symbolProxy = Wy(e.getVisual("symbol"), 0, 0, 0, 0), t.setColor = t.symbolProxy.setColor; var o = t.shape.size[0] < 4; t.useStyle(i.getModel("itemStyle").getItemStyle(o ? ["color", "shadowBlur", "shadowColor"] : ["color"])); var a = e.getVisual("style"), s = a && a.fill; s && t.setColor(s); var l = Qs(t); l.seriesIndex = i.seriesIndex, t.on("mousemove", (function (e) { l.dataIndex = null; var n = t.hoverDataIdx; n >= 0 && (l.dataIndex = n + (t.startIndex || 0)) })) }, t.prototype.remove = function () { this._clear() }, t.prototype._clear = function () { this._newAdded = [], this.group.removeAll() }, t }(), PM = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = t.getData(); this._updateSymbolDraw(i, t).updateData(i, { clipShape: this._getClipShape(t) }), this._finished = !0 }, e.prototype.incrementalPrepareRender = function (t, e, n) { var i = t.getData(); this._updateSymbolDraw(i, t).incrementalPrepareUpdate(i), this._finished = !1 }, e.prototype.incrementalRender = function (t, e, n) { this._symbolDraw.incrementalUpdate(t, e.getData(), { clipShape: this._getClipShape(e) }), this._finished = t.end === e.getData().count() }, e.prototype.updateTransform = function (t, e, n) { var i = t.getData(); if (this.group.dirty(), !this._finished || i.count() > 1e4) return { update: !0 }; var r = ES("").reset(t, e, n); r.progress && r.progress({ start: 0, end: i.count(), count: i.count() }, i), this._symbolDraw.updateLayout(i) }, e.prototype.eachRendered = function (t) { this._symbolDraw && this._symbolDraw.eachRendered(t) }, e.prototype._getClipShape = function (t) { var e = t.coordinateSystem, n = e && e.getArea && e.getArea(); return t.get("clip", !0) ? n : null }, e.prototype._updateSymbolDraw = function (t, e) { var n = this._symbolDraw, i = e.pipelineContext.large; return n && i === this._isLargeDraw || (n && n.remove(), n = this._symbolDraw = i ? new LM : new hS, this._isLargeDraw = i, this.group.removeAll()), this.group.add(n.group), n }, e.prototype.remove = function (t, e) { this._symbolDraw && this._symbolDraw.remove(!0), this._symbolDraw = null }, e.prototype.dispose = function () { }, e.type = "scatter", e }(kg), OM = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.type = "grid", e.dependencies = ["xAxis", "yAxis"], e.layoutMode = "box", e.defaultOption = { show: !1, z: 0, left: "10%", top: 60, right: "10%", bottom: 70, containLabel: !1, backgroundColor: "rgba(0,0,0,0)", borderWidth: 1, borderColor: "#ccc" }, e }(Rp), RM = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.getCoordSysModel = function () { return this.getReferringComponents("grid", zo).models[0] }, e.type = "cartesian2dAxis", e }(Rp); R(RM, I_); var NM = { show: !0, z: 0, inverse: !1, name: "", nameLocation: "end", nameRotate: null, nameTruncate: { maxWidth: null, ellipsis: "...", placeholder: "." }, nameTextStyle: {}, nameGap: 15, silent: !1, triggerEvent: !1, tooltip: { show: !1 }, axisPointer: {}, axisLine: { show: !0, onZero: !0, onZeroAxisIndex: null, lineStyle: { color: "#6E7079", width: 1, type: "solid" }, symbol: ["none", "none"], symbolSize: [10, 15] }, axisTick: { show: !0, inside: !1, length: 5, lineStyle: { width: 1 } }, axisLabel: { show: !0, inside: !1, rotate: 0, showMinLabel: null, showMaxLabel: null, margin: 8, fontSize: 12 }, splitLine: { show: !0, lineStyle: { color: ["#E0E6F1"], width: 1, type: "solid" } }, splitArea: { show: !1, areaStyle: { color: ["rgba(250,250,250,0.2)", "rgba(210,219,238,0.2)"] } } }, EM = C({ boundaryGap: !0, deduplication: null, splitLine: { show: !1 }, axisTick: { alignWithLabel: !1, interval: "auto" }, axisLabel: { interval: "auto" } }, NM), zM = C({ boundaryGap: [0, 0], axisLine: { show: "auto" }, axisTick: { show: "auto" }, splitNumber: 5, minorTick: { show: !1, splitNumber: 5, length: 3, lineStyle: {} }, minorSplitLine: { show: !1, lineStyle: { color: "#F4F7FD", width: 1 } } }, NM), VM = { category: EM, value: zM, time: C({ splitNumber: 6, axisLabel: { showMinLabel: !1, showMaxLabel: !1, rich: { primary: { fontWeight: "bold" } } }, splitLine: { show: !1 } }, zM), log: k({ logBase: 10 }, zM) }, BM = { value: 1, category: 1, time: 1, log: 1 }; function FM(t, e, i, r) { E(BM, (function (o, a) { var s = C(C({}, VM[a], !0), r, !0), l = function (t) { function i() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e + "Axis." + a, n } return n(i, t), i.prototype.mergeDefaultAndTheme = function (t, e) { var n = Ap(this), i = n ? Lp(t) : {}; C(t, e.getTheme().get(a + "Axis")), C(t, this.getDefaultOption()), t.type = GM(t), n && kp(t, i, n) }, i.prototype.optionUpdated = function () { "category" === this.option.type && (this.__ordinalMeta = _x.createByAxisModel(this)) }, i.prototype.getCategories = function (t) { var e = this.option; if ("category" === e.type) return t ? e.data : this.__ordinalMeta.categories }, i.prototype.getOrdinalMeta = function () { return this.__ordinalMeta }, i.type = e + "Axis." + a, i.defaultOption = s, i }(i); t.registerComponentModel(l) })), t.registerSubTypeDefaulter(e + "Axis", GM) } function GM(t) { return t.type || (t.data ? "category" : "value") } var WM = function () { function t(t) { this.type = "cartesian", this._dimList = [], this._axes = {}, this.name = t || "" } return t.prototype.getAxis = function (t) { return this._axes[t] }, t.prototype.getAxes = function () { return z(this._dimList, (function (t) { return this._axes[t] }), this) }, t.prototype.getAxesByScale = function (t) { return t = t.toLowerCase(), B(this.getAxes(), (function (e) { return e.scale.type === t })) }, t.prototype.addAxis = function (t) { var e = t.dim; this._axes[e] = t, this._dimList.push(e) }, t }(), HM = ["x", "y"]; function YM(t) { return "interval" === t.type || "time" === t.type } var XM = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "cartesian2d", e.dimensions = HM, e } return n(e, t), e.prototype.calcAffineTransform = function () { this._transform = this._invTransform = null; var t = this.getAxis("x").scale, e = this.getAxis("y").scale; if (YM(t) && YM(e)) { var n = t.getExtent(), i = e.getExtent(), r = this.dataToPoint([n[0], i[0]]), o = this.dataToPoint([n[1], i[1]]), a = n[1] - n[0], s = i[1] - i[0]; if (a && s) { var l = (o[0] - r[0]) / a, u = (o[1] - r[1]) / s, h = r[0] - n[0] * l, c = r[1] - i[0] * u, p = this._transform = [l, 0, 0, u, h, c]; this._invTransform = Ie([], p) } } }, e.prototype.getBaseAxis = function () { return this.getAxesByScale("ordinal")[0] || this.getAxesByScale("time")[0] || this.getAxis("x") }, e.prototype.containPoint = function (t) { var e = this.getAxis("x"), n = this.getAxis("y"); return e.contain(e.toLocalCoord(t[0])) && n.contain(n.toLocalCoord(t[1])) }, e.prototype.containData = function (t) { return this.getAxis("x").containData(t[0]) && this.getAxis("y").containData(t[1]) }, e.prototype.containZone = function (t, e) { var n = this.dataToPoint(t), i = this.dataToPoint(e), r = this.getArea(), o = new ze(n[0], n[1], i[0] - n[0], i[1] - n[1]); return r.intersect(o) }, e.prototype.dataToPoint = function (t, e, n) { n = n || []; var i = t[0], r = t[1]; if (this._transform && null != i && isFinite(i) && null != r && isFinite(r)) return Wt(n, t, this._transform); var o = this.getAxis("x"), a = this.getAxis("y"); return n[0] = o.toGlobalCoord(o.dataToCoord(i, e)), n[1] = a.toGlobalCoord(a.dataToCoord(r, e)), n }, e.prototype.clampData = function (t, e) { var n = this.getAxis("x").scale, i = this.getAxis("y").scale, r = n.getExtent(), o = i.getExtent(), a = n.parse(t[0]), s = i.parse(t[1]); return (e = e || [])[0] = Math.min(Math.max(Math.min(r[0], r[1]), a), Math.max(r[0], r[1])), e[1] = Math.min(Math.max(Math.min(o[0], o[1]), s), Math.max(o[0], o[1])), e }, e.prototype.pointToData = function (t, e) { var n = []; if (this._invTransform) return Wt(n, t, this._invTransform); var i = this.getAxis("x"), r = this.getAxis("y"); return n[0] = i.coordToData(i.toLocalCoord(t[0]), e), n[1] = r.coordToData(r.toLocalCoord(t[1]), e), n }, e.prototype.getOtherAxis = function (t) { return this.getAxis("x" === t.dim ? "y" : "x") }, e.prototype.getArea = function () { var t = this.getAxis("x").getGlobalExtent(), e = this.getAxis("y").getGlobalExtent(), n = Math.min(t[0], t[1]), i = Math.min(e[0], e[1]), r = Math.max(t[0], t[1]) - n, o = Math.max(e[0], e[1]) - i; return new ze(n, i, r, o) }, e }(WM), UM = function (t) { function e(e, n, i, r, o) { var a = t.call(this, e, n, i) || this; return a.index = 0, a.type = r || "value", a.position = o || "bottom", a } return n(e, t), e.prototype.isHorizontal = function () { var t = this.position; return "top" === t || "bottom" === t }, e.prototype.getGlobalExtent = function (t) { var e = this.getExtent(); return e[0] = this.toGlobalCoord(e[0]), e[1] = this.toGlobalCoord(e[1]), t && e[0] > e[1] && e.reverse(), e }, e.prototype.pointToData = function (t, e) { return this.coordToData(this.toLocalCoord(t["x" === this.dim ? 0 : 1]), e) }, e.prototype.setCategorySortInfo = function (t) { if ("category" !== this.type) return !1; this.model.option.categorySortInfo = t, this.scale.setSortInfo(t) }, e }(nb); function ZM(t, e, n) { n = n || {}; var i = t.coordinateSystem, r = e.axis, o = {}, a = r.getAxesOnZeroOf()[0], s = r.position, l = a ? "onZero" : s, u = r.dim, h = i.getRect(), c = [h.x, h.x + h.width, h.y, h.y + h.height], p = { left: 0, right: 1, top: 0, bottom: 1, onZero: 2 }, d = e.get("offset") || 0, f = "x" === u ? [c[2] - d, c[3] + d] : [c[0] - d, c[1] + d]; if (a) { var g = a.toGlobalCoord(a.dataToCoord(0)); f[p.onZero] = Math.max(Math.min(g, f[1]), f[0]) } o.position = ["y" === u ? f[p[l]] : c[0], "x" === u ? f[p[l]] : c[3]], o.rotation = Math.PI / 2 * ("x" === u ? 0 : 1); o.labelDirection = o.tickDirection = o.nameDirection = { top: -1, bottom: 1, left: -1, right: 1 }[s], o.labelOffset = a ? f[p[s]] - f[p.onZero] : 0, e.get(["axisTick", "inside"]) && (o.tickDirection = -o.tickDirection), it(n.labelInside, e.get(["axisLabel", "inside"])) && (o.labelDirection = -o.labelDirection); var y = e.get(["axisLabel", "rotate"]); return o.labelRotate = "top" === l ? -y : y, o.z2 = 1, o } function jM(t) { return "cartesian2d" === t.get("coordinateSystem") } function qM(t) { var e = { xAxisModel: null, yAxisModel: null }; return E(e, (function (n, i) { var r = i.replace(/Model$/, ""), o = t.getReferringComponents(r, zo).models[0]; e[i] = o })), e } var KM = Math.log; function $M(t, e, n) { var i = Ox.prototype, r = i.getTicks.call(n), o = i.getTicks.call(n, !0), a = r.length - 1, s = i.getInterval.call(n), l = y_(t, e), u = l.extent, h = l.fixMin, c = l.fixMax; if ("log" === t.type) { var p = KM(t.base); u = [KM(u[0]) / p, KM(u[1]) / p] } t.setExtent(u[0], u[1]), t.calcNiceExtent({ splitNumber: a, fixMin: h, fixMax: c }); var d = i.getExtent.call(t); h && (u[0] = d[0]), c && (u[1] = d[1]); var f = i.getInterval.call(t), g = u[0], y = u[1]; if (h && c) f = (y - g) / a; else if (h) for (y = u[0] + f * a; y < u[1] && isFinite(y) && isFinite(u[1]);)f = Ix(f), y = u[0] + f * a; else if (c) for (g = u[1] - f * a; g > u[0] && isFinite(g) && isFinite(u[0]);)f = Ix(f), g = u[1] - f * a; else { t.getTicks().length - 1 > a && (f = Ix(f)); var v = f * a; (g = Zr((y = Math.ceil(u[1] / f) * f) - v)) < 0 && u[0] >= 0 ? (g = 0, y = Zr(v)) : y > 0 && u[1] <= 0 && (y = 0, g = -Zr(v)) } var m = (r[0].value - o[0].value) / s, x = (r[a].value - o[a].value) / s; i.setExtent.call(t, g + f * m, y + f * x), i.setInterval.call(t, f), (m || x) && i.setNiceExtent.call(t, g + f, y - f) } var JM = function () { function t(t, e, n) { this.type = "grid", this._coordsMap = {}, this._coordsList = [], this._axesMap = {}, this._axesList = [], this.axisPointerEnabled = !0, this.dimensions = HM, this._initCartesian(t, e, n), this.model = t } return t.prototype.getRect = function () { return this._rect }, t.prototype.update = function (t, e) { var n = this._axesMap; function i(t) { var e, n = G(t), i = n.length; if (i) { for (var r = [], o = i - 1; o >= 0; o--) { var a = t[+n[o]], s = a.model, l = a.scale; Sx(l) && s.get("alignTicks") && null == s.get("interval") ? r.push(a) : (v_(l, s), Sx(l) && (e = a)) } r.length && (e || v_((e = r.pop()).scale, e.model), E(r, (function (t) { $M(t.scale, t.model, e.scale) }))) } } this._updateScale(t, this.model), i(n.x), i(n.y); var r = {}; E(n.x, (function (t) { tI(n, "y", t, r) })), E(n.y, (function (t) { tI(n, "x", t, r) })), this.resize(this.model, e) }, t.prototype.resize = function (t, e, n) { var i = t.getBoxLayoutParams(), r = !n && t.get("containLabel"), o = Cp(i, { width: e.getWidth(), height: e.getHeight() }); this._rect = o; var a = this._axesList; function s() { E(a, (function (t) { var e = t.isHorizontal(), n = e ? [0, o.width] : [0, o.height], i = t.inverse ? 1 : 0; t.setExtent(n[i], n[1 - i]), function (t, e) { var n = t.getExtent(), i = n[0] + n[1]; t.toGlobalCoord = "x" === t.dim ? function (t) { return t + e } : function (t) { return i - t + e }, t.toLocalCoord = "x" === t.dim ? function (t) { return t - e } : function (t) { return i - t + e } }(t, e ? o.x : o.y) })) } s(), r && (E(a, (function (t) { if (!t.model.get(["axisLabel", "inside"])) { var e = function (t) { var e = t.model, n = t.scale; if (e.get(["axisLabel", "show"]) && !n.isBlank()) { var i, r, o = n.getExtent(); r = n instanceof Lx ? n.count() : (i = n.getTicks()).length; var a, s = t.getLabelModel(), l = x_(t), u = 1; r > 40 && (u = Math.ceil(r / 40)); for (var h = 0; h < r; h += u) { var c = l(i ? i[h] : { value: o[0] + h }, h), p = b_(s.getTextRect(c), s.get("rotate") || 0); a ? a.union(p) : a = p } return a } }(t); if (e) { var n = t.isHorizontal() ? "height" : "width", i = t.model.get(["axisLabel", "margin"]); o[n] -= e[n] + i, "top" === t.position ? o.y += e.height + i : "left" === t.position && (o.x += e.width + i) } } })), s()), E(this._coordsList, (function (t) { t.calcAffineTransform() })) }, t.prototype.getAxis = function (t, e) { var n = this._axesMap[t]; if (null != n) return n[e || 0] }, t.prototype.getAxes = function () { return this._axesList.slice() }, t.prototype.getCartesian = function (t, e) { if (null != t && null != e) { var n = "x" + t + "y" + e; return this._coordsMap[n] } q(t) && (e = t.yAxisIndex, t = t.xAxisIndex); for (var i = 0, r = this._coordsList; i < r.length; i++)if (r[i].getAxis("x").index === t || r[i].getAxis("y").index === e) return r[i] }, t.prototype.getCartesians = function () { return this._coordsList.slice() }, t.prototype.convertToPixel = function (t, e, n) { var i = this._findConvertTarget(e); return i.cartesian ? i.cartesian.dataToPoint(n) : i.axis ? i.axis.toGlobalCoord(i.axis.dataToCoord(n)) : null }, t.prototype.convertFromPixel = function (t, e, n) { var i = this._findConvertTarget(e); return i.cartesian ? i.cartesian.pointToData(n) : i.axis ? i.axis.coordToData(i.axis.toLocalCoord(n)) : null }, t.prototype._findConvertTarget = function (t) { var e, n, i = t.seriesModel, r = t.xAxisModel || i && i.getReferringComponents("xAxis", zo).models[0], o = t.yAxisModel || i && i.getReferringComponents("yAxis", zo).models[0], a = t.gridModel, s = this._coordsList; if (i) P(s, e = i.coordinateSystem) < 0 && (e = null); else if (r && o) e = this.getCartesian(r.componentIndex, o.componentIndex); else if (r) n = this.getAxis("x", r.componentIndex); else if (o) n = this.getAxis("y", o.componentIndex); else if (a) { a.coordinateSystem === this && (e = this._coordsList[0]) } return { cartesian: e, axis: n } }, t.prototype.containPoint = function (t) { var e = this._coordsList[0]; if (e) return e.containPoint(t) }, t.prototype._initCartesian = function (t, e, n) { var i = this, r = this, o = { left: !1, right: !1, top: !1, bottom: !1 }, a = { x: {}, y: {} }, s = { x: 0, y: 0 }; if (e.eachComponent("xAxis", l("x"), this), e.eachComponent("yAxis", l("y"), this), !s.x || !s.y) return this._axesMap = {}, void (this._axesList = []); function l(e) { return function (n, i) { if (QM(n, t)) { var l = n.get("position"); "x" === e ? "top" !== l && "bottom" !== l && (l = o.bottom ? "top" : "bottom") : "left" !== l && "right" !== l && (l = o.left ? "right" : "left"), o[l] = !0; var u = new UM(e, m_(n), [0, 0], n.get("type"), l), h = "category" === u.type; u.onBand = h && n.get("boundaryGap"), u.inverse = n.get("inverse"), n.axis = u, u.model = n, u.grid = r, u.index = i, r._axesList.push(u), a[e][i] = u, s[e]++ } } } this._axesMap = a, E(a.x, (function (e, n) { E(a.y, (function (r, o) { var a = "x" + n + "y" + o, s = new XM(a); s.master = i, s.model = t, i._coordsMap[a] = s, i._coordsList.push(s), s.addAxis(e), s.addAxis(r) })) })) }, t.prototype._updateScale = function (t, e) { function n(t, e) { E(M_(t, e.dim), (function (n) { e.scale.unionExtentFromData(t, n) })) } E(this._axesList, (function (t) { if (t.scale.setExtent(1 / 0, -1 / 0), "category" === t.type) { var e = t.model.get("categorySortInfo"); t.scale.setSortInfo(e) } })), t.eachSeries((function (t) { if (jM(t)) { var i = qM(t), r = i.xAxisModel, o = i.yAxisModel; if (!QM(r, e) || !QM(o, e)) return; var a = this.getCartesian(r.componentIndex, o.componentIndex), s = t.getData(), l = a.getAxis("x"), u = a.getAxis("y"); n(s, l), n(s, u) } }), this) }, t.prototype.getTooltipAxes = function (t) { var e = [], n = []; return E(this.getCartesians(), (function (i) { var r = null != t && "auto" !== t ? i.getAxis(t) : i.getBaseAxis(), o = i.getOtherAxis(r); P(e, r) < 0 && e.push(r), P(n, o) < 0 && n.push(o) })), { baseAxes: e, otherAxes: n } }, t.create = function (e, n) { var i = []; return e.eachComponent("grid", (function (r, o) { var a = new t(r, e, n); a.name = "grid_" + o, a.resize(r, n, !0), r.coordinateSystem = a, i.push(a) })), e.eachSeries((function (t) { if (jM(t)) { var e = qM(t), n = e.xAxisModel, i = e.yAxisModel, r = n.getCoordSysModel(); 0; var o = r.coordinateSystem; t.coordinateSystem = o.getCartesian(n.componentIndex, i.componentIndex) } })), i }, t.dimensions = HM, t }(); function QM(t, e) { return t.getCoordSysModel() === e } function tI(t, e, n, i) { n.getAxesOnZeroOf = function () { return r ? [r] : [] }; var r, o = t[e], a = n.model, s = a.get(["axisLine", "onZero"]), l = a.get(["axisLine", "onZeroAxisIndex"]); if (s) { if (null != l) eI(o[l]) && (r = o[l]); else for (var u in o) if (o.hasOwnProperty(u) && eI(o[u]) && !i[h(o[u])]) { r = o[u]; break } r && (i[h(r)] = !0) } function h(t) { return t.dim + "_" + t.index } } function eI(t) { return t && "category" !== t.type && "time" !== t.type && function (t) { var e = t.scale.getExtent(), n = e[0], i = e[1]; return !(n > 0 && i > 0 || n < 0 && i < 0) }(t) } var nI = Math.PI, iI = function () { function t(t, e) { this.group = new zr, this.opt = e, this.axisModel = t, k(e, { labelOffset: 0, nameDirection: 1, tickDirection: 1, labelDirection: 1, silent: !0, handleAutoShown: function () { return !0 } }); var n = new zr({ x: e.position[0], y: e.position[1], rotation: e.rotation }); n.updateTransform(), this._transformGroup = n } return t.prototype.hasBuilder = function (t) { return !!rI[t] }, t.prototype.add = function (t) { rI[t](this.opt, this.axisModel, this.group, this._transformGroup) }, t.prototype.getGroup = function () { return this.group }, t.innerTextLayout = function (t, e, n) { var i, r, o = eo(e - t); return no(o) ? (r = n > 0 ? "top" : "bottom", i = "center") : no(o - nI) ? (r = n > 0 ? "bottom" : "top", i = "center") : (r = "middle", i = o > 0 && o < nI ? n > 0 ? "right" : "left" : n > 0 ? "left" : "right"), { rotation: o, textAlign: i, textVerticalAlign: r } }, t.makeAxisEventDataBase = function (t) { var e = { componentType: t.mainType, componentIndex: t.componentIndex }; return e[t.mainType + "Index"] = t.componentIndex, e }, t.isLabelSilent = function (t) { var e = t.get("tooltip"); return t.get("silent") || !(t.get("triggerEvent") || e && e.show) }, t }(), rI = { axisLine: function (t, e, n, i) { var r = e.get(["axisLine", "show"]); if ("auto" === r && t.handleAutoShown && (r = t.handleAutoShown("axisLine")), r) { var o = e.axis.getExtent(), a = i.transform, s = [o[0], 0], l = [o[1], 0], u = s[0] > l[0]; a && (Wt(s, s, a), Wt(l, l, a)); var h = A({ lineCap: "round" }, e.getModel(["axisLine", "lineStyle"]).getLineStyle()), c = new Zu({ shape: { x1: s[0], y1: s[1], x2: l[0], y2: l[1] }, style: h, strokeContainThreshold: t.strokeContainThreshold || 5, silent: !0, z2: 1 }); Rh(c.shape, c.style.lineWidth), c.anid = "line", n.add(c); var p = e.get(["axisLine", "symbol"]); if (null != p) { var d = e.get(["axisLine", "symbolSize"]); U(p) && (p = [p, p]), (U(d) || j(d)) && (d = [d, d]); var f = Yy(e.get(["axisLine", "symbolOffset"]) || 0, d), g = d[0], y = d[1]; E([{ rotate: t.rotation + Math.PI / 2, offset: f[0], r: 0 }, { rotate: t.rotation - Math.PI / 2, offset: f[1], r: Math.sqrt((s[0] - l[0]) * (s[0] - l[0]) + (s[1] - l[1]) * (s[1] - l[1])) }], (function (e, i) { if ("none" !== p[i] && null != p[i]) { var r = Wy(p[i], -g / 2, -y / 2, g, y, h.stroke, !0), o = e.r + e.offset, a = u ? l : s; r.attr({ rotation: e.rotate, x: a[0] + o * Math.cos(t.rotation), y: a[1] - o * Math.sin(t.rotation), silent: !0, z2: 11 }), n.add(r) } })) } } }, axisTickLabel: function (t, e, n, i) { var r = function (t, e, n, i) { var r = n.axis, o = n.getModel("axisTick"), a = o.get("show"); "auto" === a && i.handleAutoShown && (a = i.handleAutoShown("axisTick")); if (!a || r.scale.isBlank()) return; for (var s = o.getModel("lineStyle"), l = i.tickDirection * o.get("length"), u = lI(r.getTicksCoords(), e.transform, l, k(s.getLineStyle(), { stroke: n.get(["axisLine", "lineStyle", "color"]) }), "ticks"), h = 0; h < u.length; h++)t.add(u[h]); return u }(n, i, e, t), o = function (t, e, n, i) { var r = n.axis, o = it(i.axisLabelShow, n.get(["axisLabel", "show"])); if (!o || r.scale.isBlank()) return; var a = n.getModel("axisLabel"), s = a.get("margin"), l = r.getViewLabels(), u = (it(i.labelRotate, a.get("rotate")) || 0) * nI / 180, h = iI.innerTextLayout(i.rotation, u, i.labelDirection), c = n.getCategories && n.getCategories(!0), p = [], d = iI.isLabelSilent(n), f = n.get("triggerEvent"); return E(l, (function (o, l) { var u = "ordinal" === r.scale.type ? r.scale.getRawOrdinalNumber(o.tickValue) : o.tickValue, g = o.formattedLabel, y = o.rawLabel, v = a; if (c && c[u]) { var m = c[u]; q(m) && m.textStyle && (v = new Mc(m.textStyle, a, n.ecModel)) } var x = v.getTextColor() || n.get(["axisLine", "lineStyle", "color"]), _ = r.dataToCoord(u), b = new Fs({ x: _, y: i.labelOffset + i.labelDirection * s, rotation: h.rotation, silent: d, z2: 10 + (o.level || 0), style: nc(v, { text: g, align: v.getShallow("align", !0) || h.textAlign, verticalAlign: v.getShallow("verticalAlign", !0) || v.getShallow("baseline", !0) || h.textVerticalAlign, fill: X(x) ? x("category" === r.type ? y : "value" === r.type ? u + "" : u, l) : x }) }); if (b.anid = "label_" + u, f) { var w = iI.makeAxisEventDataBase(n); w.targetType = "axisLabel", w.value = y, w.tickIndex = l, "category" === r.type && (w.dataIndex = u), Qs(b).eventData = w } e.add(b), b.updateTransform(), p.push(b), t.add(b), b.decomposeTransform() })), p }(n, i, e, t); (function (t, e, n) { if (S_(t.axis)) return; var i = t.get(["axisLabel", "showMinLabel"]), r = t.get(["axisLabel", "showMaxLabel"]); e = e || [], n = n || []; var o = e[0], a = e[1], s = e[e.length - 1], l = e[e.length - 2], u = n[0], h = n[1], c = n[n.length - 1], p = n[n.length - 2]; !1 === i ? (oI(o), oI(u)) : aI(o, a) && (i ? (oI(a), oI(h)) : (oI(o), oI(u))); !1 === r ? (oI(s), oI(c)) : aI(l, s) && (r ? (oI(l), oI(p)) : (oI(s), oI(c))) }(e, o, r), function (t, e, n, i) { var r = n.axis, o = n.getModel("minorTick"); if (!o.get("show") || r.scale.isBlank()) return; var a = r.getMinorTicksCoords(); if (!a.length) return; for (var s = o.getModel("lineStyle"), l = i * o.get("length"), u = k(s.getLineStyle(), k(n.getModel("axisTick").getLineStyle(), { stroke: n.get(["axisLine", "lineStyle", "color"]) })), h = 0; h < a.length; h++)for (var c = lI(a[h], e.transform, l, u, "minorticks_" + h), p = 0; p < c.length; p++)t.add(c[p]) }(n, i, e, t.tickDirection), e.get(["axisLabel", "hideOverlap"])) && Lb(Db(z(o, (function (t) { return { label: t, priority: t.z2, defaultAttr: { ignore: t.ignore } } })))) }, axisName: function (t, e, n, i) { var r = it(t.axisName, e.get("name")); if (r) { var o, a, s = e.get("nameLocation"), l = t.nameDirection, u = e.getModel("nameTextStyle"), h = e.get("nameGap") || 0, c = e.axis.getExtent(), p = c[0] > c[1] ? -1 : 1, d = ["start" === s ? c[0] - p * h : "end" === s ? c[1] + p * h : (c[0] + c[1]) / 2, sI(s) ? t.labelOffset + l * h : 0], f = e.get("nameRotate"); null != f && (f = f * nI / 180), sI(s) ? o = iI.innerTextLayout(t.rotation, null != f ? f : t.rotation, l) : (o = function (t, e, n, i) { var r, o, a = eo(n - t), s = i[0] > i[1], l = "start" === e && !s || "start" !== e && s; no(a - nI / 2) ? (o = l ? "bottom" : "top", r = "center") : no(a - 1.5 * nI) ? (o = l ? "top" : "bottom", r = "center") : (o = "middle", r = a < 1.5 * nI && a > nI / 2 ? l ? "left" : "right" : l ? "right" : "left"); return { rotation: a, textAlign: r, textVerticalAlign: o } }(t.rotation, s, f || 0, c), null != (a = t.axisNameAvailableWidth) && (a = Math.abs(a / Math.sin(o.rotation)), !isFinite(a) && (a = null))); var g = u.getFont(), y = e.get("nameTruncate", !0) || {}, v = y.ellipsis, m = it(t.nameTruncateMaxWidth, y.maxWidth, a), x = new Fs({ x: d[0], y: d[1], rotation: o.rotation, silent: iI.isLabelSilent(e), style: nc(u, { text: r, font: g, overflow: "truncate", width: m, ellipsis: v, fill: u.getTextColor() || e.get(["axisLine", "lineStyle", "color"]), align: u.get("align") || o.textAlign, verticalAlign: u.get("verticalAlign") || o.textVerticalAlign }), z2: 1 }); if (Zh({ el: x, componentModel: e, itemName: r }), x.__fullText = r, x.anid = "name", e.get("triggerEvent")) { var _ = iI.makeAxisEventDataBase(e); _.targetType = "axisName", _.name = r, Qs(x).eventData = _ } i.add(x), x.updateTransform(), n.add(x), x.decomposeTransform() } } }; function oI(t) { t && (t.ignore = !0) } function aI(t, e) { var n = t && t.getBoundingRect().clone(), i = e && e.getBoundingRect().clone(); if (n && i) { var r = xe([]); return Se(r, r, -t.rotation), n.applyTransform(be([], r, t.getLocalTransform())), i.applyTransform(be([], r, e.getLocalTransform())), n.intersect(i) } } function sI(t) { return "middle" === t || "center" === t } function lI(t, e, n, i, r) { for (var o = [], a = [], s = [], l = 0; l < t.length; l++) { var u = t[l].coord; a[0] = u, a[1] = 0, s[0] = u, s[1] = n, e && (Wt(a, a, e), Wt(s, s, e)); var h = new Zu({ shape: { x1: a[0], y1: a[1], x2: s[0], y2: s[1] }, style: i, z2: 2, autoBatch: !0, silent: !0 }); Rh(h.shape, h.style.lineWidth), h.anid = r + "_" + t[l].tickValue, o.push(h) } return o } function uI(t, e) { var n = { axesInfo: {}, seriesInvolved: !1, coordSysAxesInfo: {}, coordSysMap: {} }; return function (t, e, n) { var i = e.getComponent("tooltip"), r = e.getComponent("axisPointer"), o = r.get("link", !0) || [], a = []; E(n.getCoordinateSystems(), (function (n) { if (n.axisPointerEnabled) { var s = fI(n.model), l = t.coordSysAxesInfo[s] = {}; t.coordSysMap[s] = n; var u = n.model.getModel("tooltip", i); if (E(n.getAxes(), H(d, !1, null)), n.getTooltipAxes && i && u.get("show")) { var h = "axis" === u.get("trigger"), c = "cross" === u.get(["axisPointer", "type"]), p = n.getTooltipAxes(u.get(["axisPointer", "axis"])); (h || c) && E(p.baseAxes, H(d, !c || "cross", h)), c && E(p.otherAxes, H(d, "cross", !1)) } } function d(i, s, h) { var c = h.model.getModel("axisPointer", r), p = c.get("show"); if (p && ("auto" !== p || i || dI(c))) { null == s && (s = c.get("triggerTooltip")), c = i ? function (t, e, n, i, r, o) { var a = e.getModel("axisPointer"), s = {}; E(["type", "snap", "lineStyle", "shadowStyle", "label", "animation", "animationDurationUpdate", "animationEasingUpdate", "z"], (function (t) { s[t] = T(a.get(t)) })), s.snap = "category" !== t.type && !!o, "cross" === a.get("type") && (s.type = "line"); var l = s.label || (s.label = {}); if (null == l.show && (l.show = !1), "cross" === r) { var u = a.get(["label", "show"]); if (l.show = null == u || u, !o) { var h = s.lineStyle = a.get("crossStyle"); h && k(l, h.textStyle) } } return t.model.getModel("axisPointer", new Mc(s, n, i)) }(h, u, r, e, i, s) : c; var d = c.get("snap"), f = c.get("triggerEmphasis"), g = fI(h.model), y = s || d || "category" === h.type, v = t.axesInfo[g] = { key: g, axis: h, coordSys: n, axisPointerModel: c, triggerTooltip: s, triggerEmphasis: f, involveSeries: y, snap: d, useHandle: dI(c), seriesModels: [], linkGroup: null }; l[g] = v, t.seriesInvolved = t.seriesInvolved || y; var m = function (t, e) { for (var n = e.model, i = e.dim, r = 0; r < t.length; r++) { var o = t[r] || {}; if (hI(o[i + "AxisId"], n.id) || hI(o[i + "AxisIndex"], n.componentIndex) || hI(o[i + "AxisName"], n.name)) return r } }(o, h); if (null != m) { var x = a[m] || (a[m] = { axesInfo: {} }); x.axesInfo[g] = v, x.mapper = o[m].mapper, v.linkGroup = x } } } })) }(n, t, e), n.seriesInvolved && function (t, e) { e.eachSeries((function (e) { var n = e.coordinateSystem, i = e.get(["tooltip", "trigger"], !0), r = e.get(["tooltip", "show"], !0); n && "none" !== i && !1 !== i && "item" !== i && !1 !== r && !1 !== e.get(["axisPointer", "show"], !0) && E(t.coordSysAxesInfo[fI(n.model)], (function (t) { var i = t.axis; n.getAxis(i.dim) === i && (t.seriesModels.push(e), null == t.seriesDataCount && (t.seriesDataCount = 0), t.seriesDataCount += e.getData().count()) })) })) }(n, t), n } function hI(t, e) { return "all" === t || Y(t) && P(t, e) >= 0 || t === e } function cI(t) { var e = pI(t); if (e) { var n = e.axisPointerModel, i = e.axis.scale, r = n.option, o = n.get("status"), a = n.get("value"); null != a && (a = i.parse(a)); var s = dI(n); null == o && (r.status = s ? "show" : "hide"); var l = i.getExtent().slice(); l[0] > l[1] && l.reverse(), (null == a || a > l[1]) && (a = l[1]), a < l[0] && (a = l[0]), r.value = a, s && (r.status = e.axis.scale.isBlank() ? "hide" : "show") } } function pI(t) { var e = (t.ecModel.getComponent("axisPointer") || {}).coordSysAxesInfo; return e && e.axesInfo[fI(t)] } function dI(t) { return !!t.get(["handle", "show"]) } function fI(t) { return t.type + "||" + t.id } var gI = {}, yI = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (e, n, i, r) { this.axisPointerClass && cI(e), t.prototype.render.apply(this, arguments), this._doUpdateAxisPointerClass(e, i, !0) }, e.prototype.updateAxisPointer = function (t, e, n, i) { this._doUpdateAxisPointerClass(t, n, !1) }, e.prototype.remove = function (t, e) { var n = this._axisPointer; n && n.remove(e) }, e.prototype.dispose = function (e, n) { this._disposeAxisPointer(n), t.prototype.dispose.apply(this, arguments) }, e.prototype._doUpdateAxisPointerClass = function (t, n, i) { var r = e.getAxisPointerClass(this.axisPointerClass); if (r) { var o = function (t) { var e = pI(t); return e && e.axisPointerModel }(t); o ? (this._axisPointer || (this._axisPointer = new r)).render(t, o, n, i) : this._disposeAxisPointer(n) } }, e.prototype._disposeAxisPointer = function (t) { this._axisPointer && this._axisPointer.dispose(t), this._axisPointer = null }, e.registerAxisPointerClass = function (t, e) { gI[t] = e }, e.getAxisPointerClass = function (t) { return t && gI[t] }, e.type = "axis", e }(Tg), vI = Oo(); function mI(t, e, n, i) { var r = n.axis; if (!r.scale.isBlank()) { var o = n.getModel("splitArea"), a = o.getModel("areaStyle"), s = a.get("color"), l = i.coordinateSystem.getRect(), u = r.getTicksCoords({ tickModel: o, clamp: !0 }); if (u.length) { var h = s.length, c = vI(t).splitAreaColors, p = yt(), d = 0; if (c) for (var f = 0; f < u.length; f++) { var g = c.get(u[f].tickValue); if (null != g) { d = (g + (h - 1) * f) % h; break } } var y = r.toGlobalCoord(u[0].coord), v = a.getAreaStyle(); s = Y(s) ? s : [s]; for (f = 1; f < u.length; f++) { var m = r.toGlobalCoord(u[f].coord), x = void 0, _ = void 0, b = void 0, w = void 0; r.isHorizontal() ? (x = y, _ = l.y, b = m - x, w = l.height, y = x + b) : (x = l.x, _ = y, b = l.width, y = _ + (w = m - _)); var S = u[f - 1].tickValue; null != S && p.set(S, d), e.add(new zs({ anid: null != S ? "area_" + S : null, shape: { x: x, y: _, width: b, height: w }, style: k({ fill: s[d] }, v), autoBatch: !0, silent: !0 })), d = (d + 1) % h } vI(t).splitAreaColors = p } } } function xI(t) { vI(t).splitAreaColors = null } var _I = ["axisLine", "axisTickLabel", "axisName"], bI = ["splitArea", "splitLine", "minorSplitLine"], wI = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.axisPointerClass = "CartesianAxisPointer", n } return n(e, t), e.prototype.render = function (e, n, i, r) { this.group.removeAll(); var o = this._axisGroup; if (this._axisGroup = new zr, this.group.add(this._axisGroup), e.get("show")) { var a = e.getCoordSysModel(), s = ZM(a, e), l = new iI(e, A({ handleAutoShown: function (t) { for (var n = a.coordinateSystem.getCartesians(), i = 0; i < n.length; i++)if (Sx(n[i].getOtherAxis(e.axis).scale)) return !0; return !1 } }, s)); E(_I, l.add, l), this._axisGroup.add(l.getGroup()), E(bI, (function (t) { e.get([t, "show"]) && SI[t](this, this._axisGroup, e, a) }), this), r && "changeAxisOrder" === r.type && r.isInitSort || Fh(o, this._axisGroup, e), t.prototype.render.call(this, e, n, i, r) } }, e.prototype.remove = function () { xI(this) }, e.type = "cartesianAxis", e }(yI), SI = { splitLine: function (t, e, n, i) { var r = n.axis; if (!r.scale.isBlank()) { var o = n.getModel("splitLine"), a = o.getModel("lineStyle"), s = a.get("color"); s = Y(s) ? s : [s]; for (var l = i.coordinateSystem.getRect(), u = r.isHorizontal(), h = 0, c = r.getTicksCoords({ tickModel: o }), p = [], d = [], f = a.getLineStyle(), g = 0; g < c.length; g++) { var y = r.toGlobalCoord(c[g].coord); u ? (p[0] = y, p[1] = l.y, d[0] = y, d[1] = l.y + l.height) : (p[0] = l.x, p[1] = y, d[0] = l.x + l.width, d[1] = y); var v = h++ % s.length, m = c[g].tickValue, x = new Zu({ anid: null != m ? "line_" + c[g].tickValue : null, autoBatch: !0, shape: { x1: p[0], y1: p[1], x2: d[0], y2: d[1] }, style: k({ stroke: s[v] }, f), silent: !0 }); Rh(x.shape, f.lineWidth), e.add(x) } } }, minorSplitLine: function (t, e, n, i) { var r = n.axis, o = n.getModel("minorSplitLine").getModel("lineStyle"), a = i.coordinateSystem.getRect(), s = r.isHorizontal(), l = r.getMinorTicksCoords(); if (l.length) for (var u = [], h = [], c = o.getLineStyle(), p = 0; p < l.length; p++)for (var d = 0; d < l[p].length; d++) { var f = r.toGlobalCoord(l[p][d].coord); s ? (u[0] = f, u[1] = a.y, h[0] = f, h[1] = a.y + a.height) : (u[0] = a.x, u[1] = f, h[0] = a.x + a.width, h[1] = f); var g = new Zu({ anid: "minor_line_" + l[p][d].tickValue, autoBatch: !0, shape: { x1: u[0], y1: u[1], x2: h[0], y2: h[1] }, style: c, silent: !0 }); Rh(g.shape, c.lineWidth), e.add(g) } }, splitArea: function (t, e, n, i) { mI(t, e, n, i) } }, MI = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "xAxis", e }(wI), II = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = MI.type, e } return n(e, t), e.type = "yAxis", e }(wI), TI = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "grid", e } return n(e, t), e.prototype.render = function (t, e) { this.group.removeAll(), t.get("show") && this.group.add(new zs({ shape: t.coordinateSystem.getRect(), style: k({ fill: t.get("backgroundColor") }, t.getItemStyle()), silent: !0, z2: -1 })) }, e.type = "grid", e }(Tg), CI = { offset: 0 }; function DI(t) { t.registerComponentView(TI), t.registerComponentModel(OM), t.registerCoordinateSystem("cartesian2d", JM), FM(t, "x", RM, CI), FM(t, "y", RM, CI), t.registerComponentView(MI), t.registerComponentView(II), t.registerPreprocessor((function (t) { t.xAxis && t.yAxis && !t.grid && (t.grid = {}) })) } function AI(t) { t.eachSeriesByType("radar", (function (t) { var e = t.getData(), n = [], i = t.coordinateSystem; if (i) { var r = i.getIndicatorAxes(); E(r, (function (t, o) { e.each(e.mapDimension(r[o].dim), (function (t, e) { n[e] = n[e] || []; var r = i.dataToPoint(t, o); n[e][o] = kI(r) ? r : LI(i) })) })), e.each((function (t) { var r = F(n[t], (function (t) { return kI(t) })) || LI(i); n[t].push(r.slice()), e.setItemLayout(t, n[t]) })) } })) } function kI(t) { return !isNaN(t[0]) && !isNaN(t[1]) } function LI(t) { return [t.cx, t.cy] } function PI(t) { var e = t.polar; if (e) { Y(e) || (e = [e]); var n = []; E(e, (function (e, i) { e.indicator ? (e.type && !e.shape && (e.shape = e.type), t.radar = t.radar || [], Y(t.radar) || (t.radar = [t.radar]), t.radar.push(e)) : n.push(e) })), t.polar = n } E(t.series, (function (t) { t && "radar" === t.type && t.polarIndex && (t.radarIndex = t.polarIndex) })) } var OI = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = t.coordinateSystem, r = this.group, o = t.getData(), a = this._data; function s(t, e) { var n = t.getItemVisual(e, "symbol") || "circle"; if ("none" !== n) { var i = Hy(t.getItemVisual(e, "symbolSize")), r = Wy(n, -1, -1, 2, 2), o = t.getItemVisual(e, "symbolRotate") || 0; return r.attr({ style: { strokeNoScale: !0 }, z2: 100, scaleX: i[0] / 2, scaleY: i[1] / 2, rotation: o * Math.PI / 180 || 0 }), r } } function l(e, n, i, r, o, a) { i.removeAll(); for (var l = 0; l < n.length - 1; l++) { var u = s(r, o); u && (u.__dimIdx = l, e[l] ? (u.setPosition(e[l]), Kh[a ? "initProps" : "updateProps"](u, { x: n[l][0], y: n[l][1] }, t, o)) : u.setPosition(n[l]), i.add(u)) } } function u(t) { return z(t, (function (t) { return [i.cx, i.cy] })) } o.diff(a).add((function (e) { var n = o.getItemLayout(e); if (n) { var i = new Wu, r = new Yu, a = { shape: { points: n } }; i.shape.points = u(n), r.shape.points = u(n), gh(i, a, t, e), gh(r, a, t, e); var s = new zr, h = new zr; s.add(r), s.add(i), s.add(h), l(r.shape.points, n, h, o, e, !0), o.setItemGraphicEl(e, s) } })).update((function (e, n) { var i = a.getItemGraphicEl(n), r = i.childAt(0), s = i.childAt(1), u = i.childAt(2), h = { shape: { points: o.getItemLayout(e) } }; h.shape.points && (l(r.shape.points, h.shape.points, u, o, e, !1), _h(s), _h(r), fh(r, h, t), fh(s, h, t), o.setItemGraphicEl(e, i)) })).remove((function (t) { r.remove(a.getItemGraphicEl(t)) })).execute(), o.eachItemGraphicEl((function (t, e) { var n = o.getItemModel(e), i = t.childAt(0), a = t.childAt(1), s = t.childAt(2), l = o.getItemVisual(e, "style"), u = l.fill; r.add(t), i.useStyle(k(n.getModel("lineStyle").getLineStyle(), { fill: "none", stroke: u })), jl(i, n, "lineStyle"), jl(a, n, "areaStyle"); var h = n.getModel("areaStyle"), c = h.isEmpty() && h.parentModel.isEmpty(); a.ignore = c, E(["emphasis", "select", "blur"], (function (t) { var e = n.getModel([t, "areaStyle"]), i = e.isEmpty() && e.parentModel.isEmpty(); a.ensureState(t).ignore = i && c })), a.useStyle(k(h.getAreaStyle(), { fill: u, opacity: .7, decal: l.decal })); var p = n.getModel("emphasis"), d = p.getModel("itemStyle").getItemStyle(); s.eachChild((function (t) { if (t instanceof ks) { var i = t.style; t.useStyle(A({ image: i.image, x: i.x, y: i.y, width: i.width, height: i.height }, l)) } else t.useStyle(l), t.setColor(u), t.style.strokeNoScale = !0; t.ensureState("emphasis").style = T(d); var r = o.getStore().get(o.getDimensionIndex(t.__dimIdx), e); (null == r || isNaN(r)) && (r = ""), tc(t, ec(n), { labelFetcher: o.hostModel, labelDataIndex: e, labelDimIndex: t.__dimIdx, defaultText: r, inheritColor: u, defaultOpacity: l.opacity }) })), Yl(t, p.get("focus"), p.get("blurScope"), p.get("disabled")) })), this._data = o }, e.prototype.remove = function () { this.group.removeAll(), this._data = null }, e.type = "radar", e }(kg), RI = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.hasSymbolVisual = !0, n } return n(e, t), e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), this.legendVisualProvider = new IM(W(this.getData, this), W(this.getRawData, this)) }, e.prototype.getInitialData = function (t, e) { return MM(this, { generateCoord: "indicator_", generateCoordCount: 1 / 0 }) }, e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(), r = this.coordinateSystem.getIndicatorAxes(), o = this.getData().getName(t), a = "" === o ? this.name : o, s = cg(this, t); return ng("section", { header: a, sortBlocks: !0, blocks: z(r, (function (e) { var n = i.get(i.mapDimension(e.dim), t); return ng("nameValue", { markerType: "subItem", markerColor: s, name: e.name, value: n, sortParam: n }) })) }) }, e.prototype.getTooltipPosition = function (t) { if (null != t) for (var e = this.getData(), n = this.coordinateSystem, i = e.getValues(z(n.dimensions, (function (t) { return e.mapDimension(t) })), t), r = 0, o = i.length; r < o; r++)if (!isNaN(i[r])) { var a = n.getIndicatorAxes(); return n.coordToPoint(a[r].dataToCoord(i[r]), r) } }, e.type = "series.radar", e.dependencies = ["radar"], e.defaultOption = { z: 2, colorBy: "data", coordinateSystem: "radar", legendHoverLink: !0, radarIndex: 0, lineStyle: { width: 2, type: "solid", join: "round" }, label: { position: "top" }, symbolSize: 8 }, e }(mg), NI = VM.value; function EI(t, e) { return k({ show: e }, t) } var zI = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.optionUpdated = function () { var t = this.get("boundaryGap"), e = this.get("splitNumber"), n = this.get("scale"), i = this.get("axisLine"), r = this.get("axisTick"), o = this.get("axisLabel"), a = this.get("axisName"), s = this.get(["axisName", "show"]), l = this.get(["axisName", "formatter"]), u = this.get("axisNameGap"), h = this.get("triggerEvent"), c = z(this.get("indicator") || [], (function (c) { null != c.max && c.max > 0 && !c.min ? c.min = 0 : null != c.min && c.min < 0 && !c.max && (c.max = 0); var p = a; null != c.color && (p = k({ color: c.color }, a)); var d = C(T(c), { boundaryGap: t, splitNumber: e, scale: n, axisLine: i, axisTick: r, axisLabel: o, name: c.text, showName: s, nameLocation: "end", nameGap: u, nameTextStyle: p, triggerEvent: h }, !1); if (U(l)) { var f = d.name; d.name = l.replace("{value}", null != f ? f : "") } else X(l) && (d.name = l(d.name, d)); var g = new Mc(d, null, this.ecModel); return R(g, I_.prototype), g.mainType = "radar", g.componentIndex = this.componentIndex, g }), this); this._indicatorModels = c }, e.prototype.getIndicatorModels = function () { return this._indicatorModels }, e.type = "radar", e.defaultOption = { z: 0, center: ["50%", "50%"], radius: "75%", startAngle: 90, axisName: { show: !0 }, boundaryGap: [0, 0], splitNumber: 5, axisNameGap: 15, scale: !1, shape: "polygon", axisLine: C({ lineStyle: { color: "#bbb" } }, NI.axisLine), axisLabel: EI(NI.axisLabel, !1), axisTick: EI(NI.axisTick, !1), splitLine: EI(NI.splitLine, !0), splitArea: EI(NI.splitArea, !0), indicator: [] }, e }(Rp), VI = ["axisLine", "axisTickLabel", "axisName"], BI = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { this.group.removeAll(), this._buildAxes(t), this._buildSplitLineAndArea(t) }, e.prototype._buildAxes = function (t) { var e = t.coordinateSystem; E(z(e.getIndicatorAxes(), (function (t) { var n = t.model.get("showName") ? t.name : ""; return new iI(t.model, { axisName: n, position: [e.cx, e.cy], rotation: t.angle, labelDirection: -1, tickDirection: -1, nameDirection: 1 }) })), (function (t) { E(VI, t.add, t), this.group.add(t.getGroup()) }), this) }, e.prototype._buildSplitLineAndArea = function (t) { var e = t.coordinateSystem, n = e.getIndicatorAxes(); if (n.length) { var i = t.get("shape"), r = t.getModel("splitLine"), o = t.getModel("splitArea"), a = r.getModel("lineStyle"), s = o.getModel("areaStyle"), l = r.get("show"), u = o.get("show"), h = a.get("color"), c = s.get("color"), p = Y(h) ? h : [h], d = Y(c) ? c : [c], f = [], g = []; if ("circle" === i) for (var y = n[0].getTicksCoords(), v = e.cx, m = e.cy, x = 0; x < y.length; x++) { if (l) f[C(f, p, x)].push(new _u({ shape: { cx: v, cy: m, r: y[x].coord } })); if (u && x < y.length - 1) g[C(g, d, x)].push(new Bu({ shape: { cx: v, cy: m, r0: y[x].coord, r: y[x + 1].coord } })) } else { var _, b = z(n, (function (t, n) { var i = t.getTicksCoords(); return _ = null == _ ? i.length - 1 : Math.min(i.length - 1, _), z(i, (function (t) { return e.coordToPoint(t.coord, n) })) })), w = []; for (x = 0; x <= _; x++) { for (var S = [], M = 0; M < n.length; M++)S.push(b[M][x]); if (S[0] && S.push(S[0].slice()), l) f[C(f, p, x)].push(new Yu({ shape: { points: S } })); if (u && w) g[C(g, d, x - 1)].push(new Wu({ shape: { points: S.concat(w) } })); w = S.slice().reverse() } } var I = a.getLineStyle(), T = s.getAreaStyle(); E(g, (function (t, e) { this.group.add(Ph(t, { style: k({ stroke: "none", fill: d[e % d.length] }, T), silent: !0 })) }), this), E(f, (function (t, e) { this.group.add(Ph(t, { style: k({ fill: "none", stroke: p[e % p.length] }, I), silent: !0 })) }), this) } function C(t, e, n) { var i = n % e.length; return t[i] = t[i] || [], i } }, e.type = "radar", e }(Tg), FI = function (t) { function e(e, n, i) { var r = t.call(this, e, n, i) || this; return r.type = "value", r.angle = 0, r.name = "", r } return n(e, t), e }(nb), GI = function () { function t(t, e, n) { this.dimensions = [], this._model = t, this._indicatorAxes = z(t.getIndicatorModels(), (function (t, e) { var n = "indicator_" + e, i = new FI(n, new Ox); return i.name = t.get("name"), i.model = t, t.axis = i, this.dimensions.push(n), i }), this), this.resize(t, n) } return t.prototype.getIndicatorAxes = function () { return this._indicatorAxes }, t.prototype.dataToPoint = function (t, e) { var n = this._indicatorAxes[e]; return this.coordToPoint(n.dataToCoord(t), e) }, t.prototype.coordToPoint = function (t, e) { var n = this._indicatorAxes[e].angle; return [this.cx + t * Math.cos(n), this.cy - t * Math.sin(n)] }, t.prototype.pointToData = function (t) { var e = t[0] - this.cx, n = t[1] - this.cy, i = Math.sqrt(e * e + n * n); e /= i, n /= i; for (var r, o = Math.atan2(-n, e), a = 1 / 0, s = -1, l = 0; l < this._indicatorAxes.length; l++) { var u = this._indicatorAxes[l], h = Math.abs(o - u.angle); h < a && (r = u, s = l, a = h) } return [s, +(r && r.coordToData(i))] }, t.prototype.resize = function (t, e) { var n = t.get("center"), i = e.getWidth(), r = e.getHeight(), o = Math.min(i, r) / 2; this.cx = Ur(n[0], i), this.cy = Ur(n[1], r), this.startAngle = t.get("startAngle") * Math.PI / 180; var a = t.get("radius"); (U(a) || j(a)) && (a = [0, a]), this.r0 = Ur(a[0], o), this.r = Ur(a[1], o), E(this._indicatorAxes, (function (t, e) { t.setExtent(this.r0, this.r); var n = this.startAngle + e * Math.PI * 2 / this._indicatorAxes.length; n = Math.atan2(Math.sin(n), Math.cos(n)), t.angle = n }), this) }, t.prototype.update = function (t, e) { var n = this._indicatorAxes, i = this._model; E(n, (function (t) { t.scale.setExtent(1 / 0, -1 / 0) })), t.eachSeriesByType("radar", (function (e, r) { if ("radar" === e.get("coordinateSystem") && t.getComponent("radar", e.get("radarIndex")) === i) { var o = e.getData(); E(n, (function (t) { t.scale.unionExtentFromData(o, o.mapDimension(t.dim)) })) } }), this); var r = i.get("splitNumber"), o = new Ox; o.setExtent(0, r), o.setInterval(1), E(n, (function (t, e) { $M(t.scale, t.model, o) })) }, t.prototype.convertToPixel = function (t, e, n) { return console.warn("Not implemented."), null }, t.prototype.convertFromPixel = function (t, e, n) { return console.warn("Not implemented."), null }, t.prototype.containPoint = function (t) { return console.warn("Not implemented."), !1 }, t.create = function (e, n) { var i = []; return e.eachComponent("radar", (function (r) { var o = new t(r, e, n); i.push(o), r.coordinateSystem = o })), e.eachSeriesByType("radar", (function (t) { "radar" === t.get("coordinateSystem") && (t.coordinateSystem = i[t.get("radarIndex") || 0]) })), i }, t.dimensions = [], t }(); function WI(t) { t.registerCoordinateSystem("radar", GI), t.registerComponentModel(zI), t.registerComponentView(BI), t.registerVisual({ seriesType: "radar", reset: function (t) { var e = t.getData(); e.each((function (t) { e.setItemVisual(t, "legendIcon", "roundRect") })), e.setVisual("legendIcon", "roundRect") } }) } var HI = "\0_ec_interaction_mutex"; function YI(t, e) { return !!XI(t)[e] } function XI(t) { return t[HI] || (t[HI] = {}) } Mm({ type: "takeGlobalCursor", event: "globalCursorTaken", update: "update" }, bt); var UI = function (t) { function e(e) { var n = t.call(this) || this; n._zr = e; var i = W(n._mousedownHandler, n), r = W(n._mousemoveHandler, n), o = W(n._mouseupHandler, n), a = W(n._mousewheelHandler, n), s = W(n._pinchHandler, n); return n.enable = function (t, n) { this.disable(), this._opt = k(T(n) || {}, { zoomOnMouseWheel: !0, moveOnMouseMove: !0, moveOnMouseWheel: !1, preventDefaultMouseMove: !0 }), null == t && (t = !0), !0 !== t && "move" !== t && "pan" !== t || (e.on("mousedown", i), e.on("mousemove", r), e.on("mouseup", o)), !0 !== t && "scale" !== t && "zoom" !== t || (e.on("mousewheel", a), e.on("pinch", s)) }, n.disable = function () { e.off("mousedown", i), e.off("mousemove", r), e.off("mouseup", o), e.off("mousewheel", a), e.off("pinch", s) }, n } return n(e, t), e.prototype.isDragging = function () { return this._dragging }, e.prototype.isPinching = function () { return this._pinching }, e.prototype.setPointerChecker = function (t) { this.pointerChecker = t }, e.prototype.dispose = function () { this.disable() }, e.prototype._mousedownHandler = function (t) { if (!fe(t)) { for (var e = t.target; e;) { if (e.draggable) return; e = e.__hostTarget || e.parent } var n = t.offsetX, i = t.offsetY; this.pointerChecker && this.pointerChecker(t, n, i) && (this._x = n, this._y = i, this._dragging = !0) } }, e.prototype._mousemoveHandler = function (t) { if (this._dragging && qI("moveOnMouseMove", t, this._opt) && "pinch" !== t.gestureEvent && !YI(this._zr, "globalPan")) { var e = t.offsetX, n = t.offsetY, i = this._x, r = this._y, o = e - i, a = n - r; this._x = e, this._y = n, this._opt.preventDefaultMouseMove && de(t.event), jI(this, "pan", "moveOnMouseMove", t, { dx: o, dy: a, oldX: i, oldY: r, newX: e, newY: n, isAvailableBehavior: null }) } }, e.prototype._mouseupHandler = function (t) { fe(t) || (this._dragging = !1) }, e.prototype._mousewheelHandler = function (t) { var e = qI("zoomOnMouseWheel", t, this._opt), n = qI("moveOnMouseWheel", t, this._opt), i = t.wheelDelta, r = Math.abs(i), o = t.offsetX, a = t.offsetY; if (0 !== i && (e || n)) { if (e) { var s = r > 3 ? 1.4 : r > 1 ? 1.2 : 1.1; ZI(this, "zoom", "zoomOnMouseWheel", t, { scale: i > 0 ? s : 1 / s, originX: o, originY: a, isAvailableBehavior: null }) } if (n) { var l = Math.abs(i); ZI(this, "scrollMove", "moveOnMouseWheel", t, { scrollDelta: (i > 0 ? 1 : -1) * (l > 3 ? .4 : l > 1 ? .15 : .05), originX: o, originY: a, isAvailableBehavior: null }) } } }, e.prototype._pinchHandler = function (t) { YI(this._zr, "globalPan") || ZI(this, "zoom", null, t, { scale: t.pinchScale > 1 ? 1.1 : 1 / 1.1, originX: t.pinchX, originY: t.pinchY, isAvailableBehavior: null }) }, e }(jt); function ZI(t, e, n, i, r) { t.pointerChecker && t.pointerChecker(i, r.originX, r.originY) && (de(i.event), jI(t, e, n, i, r)) } function jI(t, e, n, i, r) { r.isAvailableBehavior = W(qI, null, n, i), t.trigger(e, r) } function qI(t, e, n) { var i = n[t]; return !t || i && (!U(i) || e.event[i + "Key"]) } function KI(t, e, n) { var i = t.target; i.x += e, i.y += n, i.dirty() } function $I(t, e, n, i) { var r = t.target, o = t.zoomLimit, a = t.zoom = t.zoom || 1; if (a *= e, o) { var s = o.min || 0, l = o.max || 1 / 0; a = Math.max(Math.min(l, a), s) } var u = a / t.zoom; t.zoom = a, r.x -= (n - r.x) * (u - 1), r.y -= (i - r.y) * (u - 1), r.scaleX *= u, r.scaleY *= u, r.dirty() } var JI, QI = { axisPointer: 1, tooltip: 1, brush: 1 }; function tT(t, e, n) { var i = e.getComponentByElement(t.topTarget), r = i && i.coordinateSystem; return i && i !== n && !QI.hasOwnProperty(i.mainType) && r && r.model !== n } function eT(t) { U(t) && (t = (new DOMParser).parseFromString(t, "text/xml")); var e = t; for (9 === e.nodeType && (e = e.firstChild); "svg" !== e.nodeName.toLowerCase() || 1 !== e.nodeType;)e = e.nextSibling; return e } var nT = { fill: "fill", stroke: "stroke", "stroke-width": "lineWidth", opacity: "opacity", "fill-opacity": "fillOpacity", "stroke-opacity": "strokeOpacity", "stroke-dasharray": "lineDash", "stroke-dashoffset": "lineDashOffset", "stroke-linecap": "lineCap", "stroke-linejoin": "lineJoin", "stroke-miterlimit": "miterLimit", "font-family": "fontFamily", "font-size": "fontSize", "font-style": "fontStyle", "font-weight": "fontWeight", "text-anchor": "textAlign", visibility: "visibility", display: "display" }, iT = G(nT), rT = { "alignment-baseline": "textBaseline", "stop-color": "stopColor" }, oT = G(rT), aT = function () { function t() { this._defs = {}, this._root = null } return t.prototype.parse = function (t, e) { e = e || {}; var n = eT(t); this._defsUsePending = []; var i = new zr; this._root = i; var r = [], o = n.getAttribute("viewBox") || "", a = parseFloat(n.getAttribute("width") || e.width), s = parseFloat(n.getAttribute("height") || e.height); isNaN(a) && (a = null), isNaN(s) && (s = null), pT(n, i, null, !0, !1); for (var l, u, h = n.firstChild; h;)this._parseNode(h, i, r, null, !1, !1), h = h.nextSibling; if (function (t, e) { for (var n = 0; n < e.length; n++) { var i = e[n]; i[0].style[i[1]] = t[i[2]] } }(this._defs, this._defsUsePending), this._defsUsePending = [], o) { var c = yT(o); c.length >= 4 && (l = { x: parseFloat(c[0] || 0), y: parseFloat(c[1] || 0), width: parseFloat(c[2]), height: parseFloat(c[3]) }) } if (l && null != a && null != s && (u = bT(l, { x: 0, y: 0, width: a, height: s }), !e.ignoreViewBox)) { var p = i; (i = new zr).add(p), p.scaleX = p.scaleY = u.scale, p.x = u.x, p.y = u.y } return e.ignoreRootClip || null == a || null == s || i.setClipPath(new zs({ shape: { x: 0, y: 0, width: a, height: s } })), { root: i, width: a, height: s, viewBoxRect: l, viewBoxTransform: u, named: r } }, t.prototype._parseNode = function (t, e, n, i, r, o) { var a, s = t.nodeName.toLowerCase(), l = i; if ("defs" === s && (r = !0), "text" === s && (o = !0), "defs" === s || "switch" === s) a = e; else { if (!r) { var u = JI[s]; if (u && _t(JI, s)) { a = u.call(this, t, e); var h = t.getAttribute("name"); if (h) { var c = { name: h, namedFrom: null, svgNodeTagLower: s, el: a }; n.push(c), "g" === s && (l = c) } else i && n.push({ name: i.name, namedFrom: i, svgNodeTagLower: s, el: a }); e.add(a) } } var p = sT[s]; if (p && _t(sT, s)) { var d = p.call(this, t), f = t.getAttribute("id"); f && (this._defs[f] = d) } } if (a && a.isGroup) for (var g = t.firstChild; g;)1 === g.nodeType ? this._parseNode(g, a, n, l, r, o) : 3 === g.nodeType && o && this._parseText(g, a), g = g.nextSibling }, t.prototype._parseText = function (t, e) { var n = new Cs({ style: { text: t.textContent }, silent: !0, x: this._textX || 0, y: this._textY || 0 }); hT(e, n), pT(t, n, this._defsUsePending, !1, !1), function (t, e) { var n = e.__selfStyle; if (n) { var i = n.textBaseline, r = i; i && "auto" !== i ? "baseline" === i ? r = "alphabetic" : "before-edge" === i || "text-before-edge" === i ? r = "top" : "after-edge" === i || "text-after-edge" === i ? r = "bottom" : "central" !== i && "mathematical" !== i || (r = "middle") : r = "alphabetic", t.style.textBaseline = r } var o = e.__inheritedStyle; if (o) { var a = o.textAlign, s = a; a && ("middle" === a && (s = "center"), t.style.textAlign = s) } }(n, e); var i = n.style, r = i.fontSize; r && r < 9 && (i.fontSize = 9, n.scaleX *= r / 9, n.scaleY *= r / 9); var o = (i.fontSize || i.fontFamily) && [i.fontStyle, i.fontWeight, (i.fontSize || 12) + "px", i.fontFamily || "sans-serif"].join(" "); i.font = o; var a = n.getBoundingRect(); return this._textX += a.width, e.add(n), n }, t.internalField = void (JI = { g: function (t, e) { var n = new zr; return hT(e, n), pT(t, n, this._defsUsePending, !1, !1), n }, rect: function (t, e) { var n = new zs; return hT(e, n), pT(t, n, this._defsUsePending, !1, !1), n.setShape({ x: parseFloat(t.getAttribute("x") || "0"), y: parseFloat(t.getAttribute("y") || "0"), width: parseFloat(t.getAttribute("width") || "0"), height: parseFloat(t.getAttribute("height") || "0") }), n.silent = !0, n }, circle: function (t, e) { var n = new _u; return hT(e, n), pT(t, n, this._defsUsePending, !1, !1), n.setShape({ cx: parseFloat(t.getAttribute("cx") || "0"), cy: parseFloat(t.getAttribute("cy") || "0"), r: parseFloat(t.getAttribute("r") || "0") }), n.silent = !0, n }, line: function (t, e) { var n = new Zu; return hT(e, n), pT(t, n, this._defsUsePending, !1, !1), n.setShape({ x1: parseFloat(t.getAttribute("x1") || "0"), y1: parseFloat(t.getAttribute("y1") || "0"), x2: parseFloat(t.getAttribute("x2") || "0"), y2: parseFloat(t.getAttribute("y2") || "0") }), n.silent = !0, n }, ellipse: function (t, e) { var n = new wu; return hT(e, n), pT(t, n, this._defsUsePending, !1, !1), n.setShape({ cx: parseFloat(t.getAttribute("cx") || "0"), cy: parseFloat(t.getAttribute("cy") || "0"), rx: parseFloat(t.getAttribute("rx") || "0"), ry: parseFloat(t.getAttribute("ry") || "0") }), n.silent = !0, n }, polygon: function (t, e) { var n, i = t.getAttribute("points"); i && (n = cT(i)); var r = new Wu({ shape: { points: n || [] }, silent: !0 }); return hT(e, r), pT(t, r, this._defsUsePending, !1, !1), r }, polyline: function (t, e) { var n, i = t.getAttribute("points"); i && (n = cT(i)); var r = new Yu({ shape: { points: n || [] }, silent: !0 }); return hT(e, r), pT(t, r, this._defsUsePending, !1, !1), r }, image: function (t, e) { var n = new ks; return hT(e, n), pT(t, n, this._defsUsePending, !1, !1), n.setStyle({ image: t.getAttribute("xlink:href") || t.getAttribute("href"), x: +t.getAttribute("x"), y: +t.getAttribute("y"), width: +t.getAttribute("width"), height: +t.getAttribute("height") }), n.silent = !0, n }, text: function (t, e) { var n = t.getAttribute("x") || "0", i = t.getAttribute("y") || "0", r = t.getAttribute("dx") || "0", o = t.getAttribute("dy") || "0"; this._textX = parseFloat(n) + parseFloat(r), this._textY = parseFloat(i) + parseFloat(o); var a = new zr; return hT(e, a), pT(t, a, this._defsUsePending, !1, !0), a }, tspan: function (t, e) { var n = t.getAttribute("x"), i = t.getAttribute("y"); null != n && (this._textX = parseFloat(n)), null != i && (this._textY = parseFloat(i)); var r = t.getAttribute("dx") || "0", o = t.getAttribute("dy") || "0", a = new zr; return hT(e, a), pT(t, a, this._defsUsePending, !1, !0), this._textX += parseFloat(r), this._textY += parseFloat(o), a }, path: function (t, e) { var n = vu(t.getAttribute("d") || ""); return hT(e, n), pT(t, n, this._defsUsePending, !1, !1), n.silent = !0, n } }), t }(), sT = { lineargradient: function (t) { var e = parseInt(t.getAttribute("x1") || "0", 10), n = parseInt(t.getAttribute("y1") || "0", 10), i = parseInt(t.getAttribute("x2") || "10", 10), r = parseInt(t.getAttribute("y2") || "0", 10), o = new nh(e, n, i, r); return lT(t, o), uT(t, o), o }, radialgradient: function (t) { var e = parseInt(t.getAttribute("cx") || "0", 10), n = parseInt(t.getAttribute("cy") || "0", 10), i = parseInt(t.getAttribute("r") || "0", 10), r = new ih(e, n, i); return lT(t, r), uT(t, r), r } }; function lT(t, e) { "userSpaceOnUse" === t.getAttribute("gradientUnits") && (e.global = !0) } function uT(t, e) { for (var n = t.firstChild; n;) { if (1 === n.nodeType && "stop" === n.nodeName.toLocaleLowerCase()) { var i = n.getAttribute("offset"), r = void 0; r = i && i.indexOf("%") > 0 ? parseInt(i, 10) / 100 : i ? parseFloat(i) : 0; var o = {}; _T(n, o, o); var a = o.stopColor || n.getAttribute("stop-color") || "#000000"; e.colorStops.push({ offset: r, color: a }) } n = n.nextSibling } } function hT(t, e) { t && t.__inheritedStyle && (e.__inheritedStyle || (e.__inheritedStyle = {}), k(e.__inheritedStyle, t.__inheritedStyle)) } function cT(t) { for (var e = yT(t), n = [], i = 0; i < e.length; i += 2) { var r = parseFloat(e[i]), o = parseFloat(e[i + 1]); n.push([r, o]) } return n } function pT(t, e, n, i, r) { var o = e, a = o.__inheritedStyle = o.__inheritedStyle || {}, s = {}; 1 === t.nodeType && (function (t, e) { var n = t.getAttribute("transform"); if (n) { n = n.replace(/,/g, " "); var i = [], r = null; n.replace(vT, (function (t, e, n) { return i.push(e, n), "" })); for (var o = i.length - 1; o > 0; o -= 2) { var a = i[o], s = i[o - 1], l = yT(a); switch (r = r || [1, 0, 0, 1, 0, 0], s) { case "translate": we(r, r, [parseFloat(l[0]), parseFloat(l[1] || "0")]); break; case "scale": Me(r, r, [parseFloat(l[0]), parseFloat(l[1] || l[0])]); break; case "rotate": Se(r, r, -parseFloat(l[0]) * mT); break; case "skewX": be(r, [1, 0, Math.tan(parseFloat(l[0]) * mT), 1, 0, 0], r); break; case "skewY": be(r, [1, Math.tan(parseFloat(l[0]) * mT), 0, 1, 0, 0], r); break; case "matrix": r[0] = parseFloat(l[0]), r[1] = parseFloat(l[1]), r[2] = parseFloat(l[2]), r[3] = parseFloat(l[3]), r[4] = parseFloat(l[4]), r[5] = parseFloat(l[5]) } } e.setLocalTransform(r) } }(t, e), _T(t, a, s), i || function (t, e, n) { for (var i = 0; i < iT.length; i++) { var r = iT[i]; null != (o = t.getAttribute(r)) && (e[nT[r]] = o) } for (i = 0; i < oT.length; i++) { var o; r = oT[i]; null != (o = t.getAttribute(r)) && (n[rT[r]] = o) } }(t, a, s)), o.style = o.style || {}, null != a.fill && (o.style.fill = fT(o, "fill", a.fill, n)), null != a.stroke && (o.style.stroke = fT(o, "stroke", a.stroke, n)), E(["lineWidth", "opacity", "fillOpacity", "strokeOpacity", "miterLimit", "fontSize"], (function (t) { null != a[t] && (o.style[t] = parseFloat(a[t])) })), E(["lineDashOffset", "lineCap", "lineJoin", "fontWeight", "fontFamily", "fontStyle", "textAlign"], (function (t) { null != a[t] && (o.style[t] = a[t]) })), r && (o.__selfStyle = s), a.lineDash && (o.style.lineDash = z(yT(a.lineDash), (function (t) { return parseFloat(t) }))), "hidden" !== a.visibility && "collapse" !== a.visibility || (o.invisible = !0), "none" === a.display && (o.ignore = !0) } var dT = /^url\(\s*#(.*?)\)/; function fT(t, e, n, i) { var r = n && n.match(dT); if (!r) return "none" === n && (n = null), n; var o = ut(r[1]); i.push([t, e, o]) } var gT = /-?([0-9]*\.)?[0-9]+([eE]-?[0-9]+)?/g; function yT(t) { return t.match(gT) || [] } var vT = /(translate|scale|rotate|skewX|skewY|matrix)\(([\-\s0-9\.eE,]*)\)/g, mT = Math.PI / 180; var xT = /([^\s:;]+)\s*:\s*([^:;]+)/g; function _T(t, e, n) { var i, r = t.getAttribute("style"); if (r) for (xT.lastIndex = 0; null != (i = xT.exec(r));) { var o = i[1], a = _t(nT, o) ? nT[o] : null; a && (e[a] = i[2]); var s = _t(rT, o) ? rT[o] : null; s && (n[s] = i[2]) } } function bT(t, e) { var n = e.width / t.width, i = e.height / t.height, r = Math.min(n, i); return { scale: r, x: -(t.x + t.width / 2) * r + (e.x + e.width / 2), y: -(t.y + t.height / 2) * r + (e.y + e.height / 2) } } var wT = yt(["rect", "circle", "line", "ellipse", "polygon", "polyline", "path", "text", "tspan", "g"]), ST = function () { function t(t, e) { this.type = "geoSVG", this._usedGraphicMap = yt(), this._freedGraphics = [], this._mapName = t, this._parsedXML = eT(e) } return t.prototype.load = function () { var t = this._firstGraphic; if (!t) { t = this._firstGraphic = this._buildGraphic(this._parsedXML), this._freedGraphics.push(t), this._boundingRect = this._firstGraphic.boundingRect.clone(); var e = function (t) { var e = [], n = yt(); return E(t, (function (t) { if (null == t.namedFrom) { var i = new z_(t.name, t.el); e.push(i), n.set(t.name, i) } })), { regions: e, regionsMap: n } }(t.named), n = e.regions, i = e.regionsMap; this._regions = n, this._regionsMap = i } return { boundingRect: this._boundingRect, regions: this._regions, regionsMap: this._regionsMap } }, t.prototype._buildGraphic = function (t) { var e, n, i, r; try { lt(null != (n = (e = t && (i = t, r = { ignoreViewBox: !0, ignoreRootClip: !0 }, (new aT).parse(i, r)) || {}).root)) } catch (t) { throw new Error("Invalid svg format\n" + t.message) } var o = new zr; o.add(n), o.isGeoSVGGraphicRoot = !0; var a = e.width, s = e.height, l = e.viewBoxRect, u = this._boundingRect; if (!u) { var h = void 0, c = void 0, p = void 0, d = void 0; if (null != a ? (h = 0, p = a) : l && (h = l.x, p = l.width), null != s ? (c = 0, d = s) : l && (c = l.y, d = l.height), null == h || null == c) { var f = n.getBoundingRect(); null == h && (h = f.x, p = f.width), null == c && (c = f.y, d = f.height) } u = this._boundingRect = new ze(h, c, p, d) } if (l) { var g = bT(l, u); n.scaleX = n.scaleY = g.scale, n.x = g.x, n.y = g.y } o.setClipPath(new zs({ shape: u.plain() })); var y = []; return E(e.named, (function (t) { var e; null != wT.get(t.svgNodeTagLower) && (y.push(t), (e = t.el).silent = !1, e.isGroup && e.traverse((function (t) { t.silent = !1 }))) })), { root: o, boundingRect: u, named: y } }, t.prototype.useGraphic = function (t) { var e = this._usedGraphicMap, n = e.get(t); return n || (n = this._freedGraphics.pop() || this._buildGraphic(this._parsedXML), e.set(t, n), n) }, t.prototype.freeGraphic = function (t) { var e = this._usedGraphicMap, n = e.get(t); n && (e.removeKey(t), this._freedGraphics.push(n)) }, t }(); for (var MT = [126, 25], IT = "南海诸岛", TT = [[[0, 3.5], [7, 11.2], [15, 11.9], [30, 7], [42, .7], [52, .7], [56, 7.7], [59, .7], [64, .7], [64, 0], [5, 0], [0, 3.5]], [[13, 16.1], [19, 14.7], [16, 21.7], [11, 23.1], [13, 16.1]], [[12, 32.2], [14, 38.5], [15, 38.5], [13, 32.2], [12, 32.2]], [[16, 47.6], [12, 53.2], [13, 53.2], [18, 47.6], [16, 47.6]], [[6, 64.4], [8, 70], [9, 70], [8, 64.4], [6, 64.4]], [[23, 82.6], [29, 79.8], [30, 79.8], [25, 82.6], [23, 82.6]], [[37, 70.7], [43, 62.3], [44, 62.3], [39, 70.7], [37, 70.7]], [[48, 51.1], [51, 45.5], [53, 45.5], [50, 51.1], [48, 51.1]], [[51, 35], [51, 28.7], [53, 28.7], [53, 35], [51, 35]], [[52, 22.4], [55, 17.5], [56, 17.5], [53, 22.4], [52, 22.4]], [[58, 12.6], [62, 7], [63, 7], [60, 12.6], [58, 12.6]], [[0, 3.5], [0, 93.1], [64, 93.1], [64, 0], [63, 0], [63, 92.4], [1, 92.4], [1, 3.5], [0, 3.5]]], CT = 0; CT < TT.length; CT++)for (var DT = 0; DT < TT[CT].length; DT++)TT[CT][DT][0] /= 10.5, TT[CT][DT][1] /= -14, TT[CT][DT][0] += MT[0], TT[CT][DT][1] += MT[1]; var AT = { "南海诸岛": [32, 80], "广东": [0, -10], "香港": [10, 5], "澳门": [-10, 10], "天津": [5, 5] }; var kT = [[[123.45165252685547, 25.73527164402261], [123.49731445312499, 25.73527164402261], [123.49731445312499, 25.750734064600884], [123.45165252685547, 25.750734064600884], [123.45165252685547, 25.73527164402261]]]; var LT = function () { function t(t, e, n) { var i; this.type = "geoJSON", this._parsedMap = yt(), this._mapName = t, this._specialAreas = n, this._geoJSON = U(i = e) ? "undefined" != typeof JSON && JSON.parse ? JSON.parse(i) : new Function("return (" + i + ");")() : i } return t.prototype.load = function (t, e) { e = e || "name"; var n = this._parsedMap.get(e); if (!n) { var i = this._parseToRegions(e); n = this._parsedMap.set(e, { regions: i, boundingRect: PT(i) }) } var r = yt(), o = []; return E(n.regions, (function (e) { var n = e.name; t && _t(t, n) && (e = e.cloneShallow(n = t[n])), o.push(e), r.set(n, e) })), { regions: o, boundingRect: n.boundingRect || new ze(0, 0, 0, 0), regionsMap: r } }, t.prototype._parseToRegions = function (t) { var e, n = this._mapName, i = this._geoJSON; try { e = i ? F_(i, t) : [] } catch (t) { throw new Error("Invalid geoJson format\n" + t.message) } return function (t, e) { if ("china" === t) { for (var n = 0; n < e.length; n++)if (e[n].name === IT) return; e.push(new E_(IT, z(TT, (function (t) { return { type: "polygon", exterior: t } })), MT)) } }(n, e), E(e, (function (t) { var e = t.name; !function (t, e) { if ("china" === t) { var n = AT[e.name]; if (n) { var i = e.getCenter(); i[0] += n[0] / 10.5, i[1] += -n[1] / 14, e.setCenter(i) } } }(n, t), function (t, e) { "china" === t && "台湾" === e.name && e.geometries.push({ type: "polygon", exterior: kT[0] }) }(n, t); var i = this._specialAreas && this._specialAreas[e]; i && t.transformTo(i.left, i.top, i.width, i.height) }), this), e }, t.prototype.getMapForUser = function () { return { geoJson: this._geoJSON, geoJSON: this._geoJSON, specialAreas: this._specialAreas } }, t }(); function PT(t) { for (var e, n = 0; n < t.length; n++) { var i = t[n].getBoundingRect(); (e = e || i.clone()).union(i) } return e } var OT = yt(), RT = function (t, e, n) { if (e.svg) { var i = new ST(t, e.svg); OT.set(t, i) } else { var r = e.geoJson || e.geoJSON; r && !e.features ? n = e.specialAreas : r = e; i = new LT(t, r, n); OT.set(t, i) } }, NT = function (t) { return OT.get(t) }, ET = function (t) { var e = OT.get(t); return e && "geoJSON" === e.type && e.getMapForUser() }, zT = function (t, e, n) { var i = OT.get(t); if (i) return i.load(e, n) }, VT = ["rect", "circle", "line", "ellipse", "polygon", "polyline", "path"], BT = yt(VT), FT = yt(VT.concat(["g"])), GT = yt(VT.concat(["g"])), WT = Oo(); function HT(t) { var e = t.getItemStyle(), n = t.get("areaColor"); return null != n && (e.fill = n), e } function YT(t) { var e = t.style; e && (e.stroke = e.stroke || e.fill, e.fill = null) } var XT = function () { function t(t) { var e = new zr; this.uid = Tc("ec_map_draw"), this._controller = new UI(t.getZr()), this._controllerHost = { target: e }, this.group = e, e.add(this._regionsGroup = new zr), e.add(this._svgGroup = new zr) } return t.prototype.draw = function (t, e, n, i, r) { var o = "geo" === t.mainType, a = t.getData && t.getData(); o && e.eachComponent({ mainType: "series", subType: "map" }, (function (e) { a || e.getHostGeoModel() !== t || (a = e.getData()) })); var s = t.coordinateSystem, l = this._regionsGroup, u = this.group, h = s.getTransformInfo(), c = h.raw, p = h.roam; !l.childAt(0) || r ? (u.x = p.x, u.y = p.y, u.scaleX = p.scaleX, u.scaleY = p.scaleY, u.dirty()) : fh(u, p, t); var d = a && a.getVisual("visualMeta") && a.getVisual("visualMeta").length > 0, f = { api: n, geo: s, mapOrGeoModel: t, data: a, isVisualEncodedByVisualMap: d, isGeo: o, transformInfoRaw: c }; "geoJSON" === s.resourceType ? this._buildGeoJSON(f) : "geoSVG" === s.resourceType && this._buildSVG(f), this._updateController(t, e, n), this._updateMapSelectHandler(t, l, n, i) }, t.prototype._buildGeoJSON = function (t) { var e = this._regionsGroupByName = yt(), n = yt(), i = this._regionsGroup, r = t.transformInfoRaw, o = t.mapOrGeoModel, a = t.data, s = t.geo.projection, l = s && s.stream; function u(t, e) { return e && (t = e(t)), t && [t[0] * r.scaleX + r.x, t[1] * r.scaleY + r.y] } function h(t) { for (var e = [], n = !l && s && s.project, i = 0; i < t.length; ++i) { var r = u(t[i], n); r && e.push(r) } return e } function c(t) { return { shape: { points: h(t) } } } i.removeAll(), E(t.geo.regions, (function (r) { var h = r.name, p = e.get(h), d = n.get(h) || {}, f = d.dataIdx, g = d.regionModel; p || (p = e.set(h, new zr), i.add(p), f = a ? a.indexOfName(h) : null, g = t.isGeo ? o.getRegionModel(h) : a ? a.getItemModel(f) : null, n.set(h, { dataIdx: f, regionModel: g })); var y = [], v = []; E(r.geometries, (function (t) { if ("polygon" === t.type) { var e = [t.exterior].concat(t.interiors || []); l && (e = $T(e, l)), E(e, (function (t) { y.push(new Wu(c(t))) })) } else { var n = t.points; l && (n = $T(n, l, !0)), E(n, (function (t) { v.push(new Yu(c(t))) })) } })); var m = u(r.getCenter(), s && s.project); function x(e, n) { if (e.length) { var i = new th({ culling: !0, segmentIgnoreThreshold: 1, shape: { paths: e } }); p.add(i), UT(t, i, f, g), ZT(t, i, h, g, o, f, m), n && (YT(i), E(i.states, YT)) } } x(y), x(v, !0) })), e.each((function (e, i) { var r = n.get(i), a = r.dataIdx, s = r.regionModel; jT(t, e, i, s, o, a), qT(t, e, i, s, o), KT(t, e, i, s, o) }), this) }, t.prototype._buildSVG = function (t) { var e = t.geo.map, n = t.transformInfoRaw; this._svgGroup.x = n.x, this._svgGroup.y = n.y, this._svgGroup.scaleX = n.scaleX, this._svgGroup.scaleY = n.scaleY, this._svgResourceChanged(e) && (this._freeSVG(), this._useSVG(e)); var i = this._svgDispatcherMap = yt(), r = !1; E(this._svgGraphicRecord.named, (function (e) { var n = e.name, o = t.mapOrGeoModel, a = t.data, s = e.svgNodeTagLower, l = e.el, u = a ? a.indexOfName(n) : null, h = o.getRegionModel(n); (null != BT.get(s) && l instanceof Sa && UT(t, l, u, h), l instanceof Sa && (l.culling = !0), l.z2EmphasisLift = 0, e.namedFrom) || (null != GT.get(s) && ZT(t, l, n, h, o, u, null), jT(t, l, n, h, o, u), qT(t, l, n, h, o), null != FT.get(s) && ("self" === KT(t, l, n, h, o) && (r = !0), (i.get(n) || i.set(n, [])).push(l))) }), this), this._enableBlurEntireSVG(r, t) }, t.prototype._enableBlurEntireSVG = function (t, e) { if (t && e.isGeo) { var n = e.mapOrGeoModel.getModel(["blur", "itemStyle"]).getItemStyle().opacity; this._svgGraphicRecord.root.traverse((function (t) { if (!t.isGroup) { Cl(t); var e = t.ensureState("blur").style || {}; null == e.opacity && null != n && (e.opacity = n), t.ensureState("emphasis") } })) } }, t.prototype.remove = function () { this._regionsGroup.removeAll(), this._regionsGroupByName = null, this._svgGroup.removeAll(), this._freeSVG(), this._controller.dispose(), this._controllerHost = null }, t.prototype.findHighDownDispatchers = function (t, e) { if (null == t) return []; var n = e.coordinateSystem; if ("geoJSON" === n.resourceType) { var i = this._regionsGroupByName; if (i) { var r = i.get(t); return r ? [r] : [] } } else if ("geoSVG" === n.resourceType) return this._svgDispatcherMap && this._svgDispatcherMap.get(t) || [] }, t.prototype._svgResourceChanged = function (t) { return this._svgMapName !== t }, t.prototype._useSVG = function (t) { var e = NT(t); if (e && "geoSVG" === e.type) { var n = e.useGraphic(this.uid); this._svgGroup.add(n.root), this._svgGraphicRecord = n, this._svgMapName = t } }, t.prototype._freeSVG = function () { var t = this._svgMapName; if (null != t) { var e = NT(t); e && "geoSVG" === e.type && e.freeGraphic(this.uid), this._svgGraphicRecord = null, this._svgDispatcherMap = null, this._svgGroup.removeAll(), this._svgMapName = null } }, t.prototype._updateController = function (t, e, n) { var i = t.coordinateSystem, r = this._controller, o = this._controllerHost; o.zoomLimit = t.get("scaleLimit"), o.zoom = i.getZoom(), r.enable(t.get("roam") || !1); var a = t.mainType; function s() { var e = { type: "geoRoam", componentType: a }; return e[a + "Id"] = t.id, e } r.off("pan").on("pan", (function (t) { this._mouseDownFlag = !1, KI(o, t.dx, t.dy), n.dispatchAction(A(s(), { dx: t.dx, dy: t.dy, animation: { duration: 0 } })) }), this), r.off("zoom").on("zoom", (function (t) { this._mouseDownFlag = !1, $I(o, t.scale, t.originX, t.originY), n.dispatchAction(A(s(), { zoom: t.scale, originX: t.originX, originY: t.originY, animation: { duration: 0 } })) }), this), r.setPointerChecker((function (e, r, o) { return i.containPoint([r, o]) && !tT(e, n, t) })) }, t.prototype.resetForLabelLayout = function () { this.group.traverse((function (t) { var e = t.getTextContent(); e && (e.ignore = WT(e).ignore) })) }, t.prototype._updateMapSelectHandler = function (t, e, n, i) { var r = this; e.off("mousedown"), e.off("click"), t.get("selectedMode") && (e.on("mousedown", (function () { r._mouseDownFlag = !0 })), e.on("click", (function (t) { r._mouseDownFlag && (r._mouseDownFlag = !1) }))) }, t }(); function UT(t, e, n, i) { var r = i.getModel("itemStyle"), o = i.getModel(["emphasis", "itemStyle"]), a = i.getModel(["blur", "itemStyle"]), s = i.getModel(["select", "itemStyle"]), l = HT(r), u = HT(o), h = HT(s), c = HT(a), p = t.data; if (p) { var d = p.getItemVisual(n, "style"), f = p.getItemVisual(n, "decal"); t.isVisualEncodedByVisualMap && d.fill && (l.fill = d.fill), f && (l.decal = gv(f, t.api)) } e.setStyle(l), e.style.strokeNoScale = !0, e.ensureState("emphasis").style = u, e.ensureState("select").style = h, e.ensureState("blur").style = c, Cl(e) } function ZT(t, e, n, i, r, o, a) { var s = t.data, l = t.isGeo, u = s && isNaN(s.get(s.mapDimension("value"), o)), h = s && s.getItemLayout(o); if (l || u || h && h.showLabel) { var c = l ? n : o, p = void 0; (!s || o >= 0) && (p = r); var d = a ? { normal: { align: "center", verticalAlign: "middle" } } : null; tc(e, ec(i), { labelFetcher: p, labelDataIndex: c, defaultText: n }, d); var f = e.getTextContent(); if (f && (WT(f).ignore = f.ignore, e.textConfig && a)) { var g = e.getBoundingRect().clone(); e.textConfig.layoutRect = g, e.textConfig.position = [(a[0] - g.x) / g.width * 100 + "%", (a[1] - g.y) / g.height * 100 + "%"] } e.disableLabelAnimation = !0 } else e.removeTextContent(), e.removeTextConfig(), e.disableLabelAnimation = null } function jT(t, e, n, i, r, o) { t.data ? t.data.setItemGraphicEl(o, e) : Qs(e).eventData = { componentType: "geo", componentIndex: r.componentIndex, geoIndex: r.componentIndex, name: n, region: i && i.option || {} } } function qT(t, e, n, i, r) { t.data || Zh({ el: e, componentModel: r, itemName: n, itemTooltipOption: i.get("tooltip") }) } function KT(t, e, n, i, r) { e.highDownSilentOnTouch = !!r.get("selectedMode"); var o = i.getModel("emphasis"), a = o.get("focus"); return Yl(e, a, o.get("blurScope"), o.get("disabled")), t.isGeo && function (t, e, n) { var i = Qs(t); i.componentMainType = e.mainType, i.componentIndex = e.componentIndex, i.componentHighDownName = n }(e, r, n), a } function $T(t, e, n) { var i, r = []; function o() { i = [] } function a() { i.length && (r.push(i), i = []) } var s = e({ polygonStart: o, polygonEnd: a, lineStart: o, lineEnd: a, point: function (t, e) { isFinite(t) && isFinite(e) && i.push([t, e]) }, sphere: function () { } }); return !n && s.polygonStart(), E(t, (function (t) { s.lineStart(); for (var e = 0; e < t.length; e++)s.point(t[e][0], t[e][1]); s.lineEnd() })), !n && s.polygonEnd(), r } var JT = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n, i) { if (!i || "mapToggleSelect" !== i.type || i.from !== this.uid) { var r = this.group; if (r.removeAll(), !t.getHostGeoModel()) { if (this._mapDraw && i && "geoRoam" === i.type && this._mapDraw.resetForLabelLayout(), i && "geoRoam" === i.type && "series" === i.componentType && i.seriesId === t.id) (o = this._mapDraw) && r.add(o.group); else if (t.needsDrawMap) { var o = this._mapDraw || new XT(n); r.add(o.group), o.draw(t, e, n, this, i), this._mapDraw = o } else this._mapDraw && this._mapDraw.remove(), this._mapDraw = null; t.get("showLegendSymbol") && e.getComponent("legend") && this._renderSymbols(t, e, n) } } }, e.prototype.remove = function () { this._mapDraw && this._mapDraw.remove(), this._mapDraw = null, this.group.removeAll() }, e.prototype.dispose = function () { this._mapDraw && this._mapDraw.remove(), this._mapDraw = null }, e.prototype._renderSymbols = function (t, e, n) { var i = t.originalData, r = this.group; i.each(i.mapDimension("value"), (function (e, n) { if (!isNaN(e)) { var o = i.getItemLayout(n); if (o && o.point) { var a = o.point, s = o.offset, l = new _u({ style: { fill: t.getData().getVisual("style").fill }, shape: { cx: a[0] + 9 * s, cy: a[1], r: 3 }, silent: !0, z2: 8 + (s ? 0 : 11) }); if (!s) { var u = t.mainSeries.getData(), h = i.getName(n), c = u.indexOfName(h), p = i.getItemModel(n), d = p.getModel("label"), f = u.getItemGraphicEl(c); tc(l, ec(p), { labelFetcher: { getFormattedLabel: function (e, n) { return t.getFormattedLabel(c, n) } }, defaultText: h }), l.disableLabelAnimation = !0, d.get("position") || l.setTextConfig({ position: "bottom" }), f.onHoverStateChange = function (t) { Il(l, t) } } r.add(l) } } })) }, e.type = "map", e }(kg), QT = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.needsDrawMap = !1, n.seriesGroup = [], n.getTooltipPosition = function (t) { if (null != t) { var e = this.getData().getName(t), n = this.coordinateSystem, i = n.getRegion(e); return i && n.dataToPoint(i.getCenter()) } }, n } return n(e, t), e.prototype.getInitialData = function (t) { for (var e = MM(this, { coordDimensions: ["value"], encodeDefaulter: H(Jp, this) }), n = yt(), i = [], r = 0, o = e.count(); r < o; r++) { var a = e.getName(r); n.set(a, !0) } return E(zT(this.getMapType(), this.option.nameMap, this.option.nameProperty).regions, (function (t) { var e = t.name; n.get(e) || i.push(e) })), e.appendValues([], i), e }, e.prototype.getHostGeoModel = function () { var t = this.option.geoIndex; return null != t ? this.ecModel.getComponent("geo", t) : null }, e.prototype.getMapType = function () { return (this.getHostGeoModel() || this).option.map }, e.prototype.getRawValue = function (t) { var e = this.getData(); return e.get(e.mapDimension("value"), t) }, e.prototype.getRegionModel = function (t) { var e = this.getData(); return e.getItemModel(e.indexOfName(t)) }, e.prototype.formatTooltip = function (t, e, n) { for (var i = this.getData(), r = this.getRawValue(t), o = i.getName(t), a = this.seriesGroup, s = [], l = 0; l < a.length; l++) { var u = a[l].originalData.indexOfName(o), h = i.mapDimension("value"); isNaN(a[l].originalData.get(h, u)) || s.push(a[l].name) } return ng("section", { header: s.join(", "), noHeader: !s.length, blocks: [ng("nameValue", { name: o, value: r })] }) }, e.prototype.setZoom = function (t) { this.option.zoom = t }, e.prototype.setCenter = function (t) { this.option.center = t }, e.prototype.getLegendIcon = function (t) { var e = t.icon || "roundRect", n = Wy(e, 0, 0, t.itemWidth, t.itemHeight, t.itemStyle.fill); return n.setStyle(t.itemStyle), n.style.stroke = "none", e.indexOf("empty") > -1 && (n.style.stroke = n.style.fill, n.style.fill = "#fff", n.style.lineWidth = 2), n }, e.type = "series.map", e.dependencies = ["geo"], e.layoutMode = "box", e.defaultOption = { z: 2, coordinateSystem: "geo", map: "", left: "center", top: "center", aspectScale: null, showLegendSymbol: !0, boundingCoords: null, center: null, zoom: 1, scaleLimit: null, selectedMode: !0, label: { show: !1, color: "#000" }, itemStyle: { borderWidth: .5, borderColor: "#444", areaColor: "#eee" }, emphasis: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { areaColor: "rgba(255,215,0,0.8)" } }, select: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { color: "rgba(255,215,0,0.8)" } }, nameProperty: "name" }, e }(mg); function tC(t) { var e = {}; t.eachSeriesByType("map", (function (t) { var n = t.getHostGeoModel(), i = n ? "o" + n.id : "i" + t.getMapType(); (e[i] = e[i] || []).push(t) })), E(e, (function (t, e) { for (var n, i, r, o = (n = z(t, (function (t) { return t.getData() })), i = t[0].get("mapValueCalculation"), r = {}, E(n, (function (t) { t.each(t.mapDimension("value"), (function (e, n) { var i = "ec-" + t.getName(n); r[i] = r[i] || [], isNaN(e) || r[i].push(e) })) })), n[0].map(n[0].mapDimension("value"), (function (t, e) { for (var o = "ec-" + n[0].getName(e), a = 0, s = 1 / 0, l = -1 / 0, u = r[o].length, h = 0; h < u; h++)s = Math.min(s, r[o][h]), l = Math.max(l, r[o][h]), a += r[o][h]; return 0 === u ? NaN : "min" === i ? s : "max" === i ? l : "average" === i ? a / u : a }))), a = 0; a < t.length; a++)t[a].originalData = t[a].getData(); for (a = 0; a < t.length; a++)t[a].seriesGroup = t, t[a].needsDrawMap = 0 === a && !t[a].getHostGeoModel(), t[a].setData(o.cloneShallow()), t[a].mainSeries = t[0] })) } function eC(t) { var e = {}; t.eachSeriesByType("map", (function (n) { var i = n.getMapType(); if (!n.getHostGeoModel() && !e[i]) { var r = {}; E(n.seriesGroup, (function (e) { var n = e.coordinateSystem, i = e.originalData; e.get("showLegendSymbol") && t.getComponent("legend") && i.each(i.mapDimension("value"), (function (t, e) { var o = i.getName(e), a = n.getRegion(o); if (a && !isNaN(t)) { var s = r[o] || 0, l = n.dataToPoint(a.getCenter()); r[o] = s + 1, i.setItemLayout(e, { point: l, offset: s }) } })) })); var o = n.getData(); o.each((function (t) { var e = o.getName(t), n = o.getItemLayout(t) || {}; n.showLabel = !r[e], o.setItemLayout(t, n) })), e[i] = !0 } })) } var nC = Wt, iC = function (t) { function e(e) { var n = t.call(this) || this; return n.type = "view", n.dimensions = ["x", "y"], n._roamTransformable = new gr, n._rawTransformable = new gr, n.name = e, n } return n(e, t), e.prototype.setBoundingRect = function (t, e, n, i) { return this._rect = new ze(t, e, n, i), this._rect }, e.prototype.getBoundingRect = function () { return this._rect }, e.prototype.setViewRect = function (t, e, n, i) { this._transformTo(t, e, n, i), this._viewRect = new ze(t, e, n, i) }, e.prototype._transformTo = function (t, e, n, i) { var r = this.getBoundingRect(), o = this._rawTransformable; o.transform = r.calculateTransform(new ze(t, e, n, i)); var a = o.parent; o.parent = null, o.decomposeTransform(), o.parent = a, this._updateTransform() }, e.prototype.setCenter = function (t, e) { t && (this._center = [Ur(t[0], e.getWidth()), Ur(t[1], e.getHeight())], this._updateCenterAndZoom()) }, e.prototype.setZoom = function (t) { t = t || 1; var e = this.zoomLimit; e && (null != e.max && (t = Math.min(e.max, t)), null != e.min && (t = Math.max(e.min, t))), this._zoom = t, this._updateCenterAndZoom() }, e.prototype.getDefaultCenter = function () { var t = this.getBoundingRect(); return [t.x + t.width / 2, t.y + t.height / 2] }, e.prototype.getCenter = function () { return this._center || this.getDefaultCenter() }, e.prototype.getZoom = function () { return this._zoom || 1 }, e.prototype.getRoamTransform = function () { return this._roamTransformable.getLocalTransform() }, e.prototype._updateCenterAndZoom = function () { var t = this._rawTransformable.getLocalTransform(), e = this._roamTransformable, n = this.getDefaultCenter(), i = this.getCenter(), r = this.getZoom(); i = Wt([], i, t), n = Wt([], n, t), e.originX = i[0], e.originY = i[1], e.x = n[0] - i[0], e.y = n[1] - i[1], e.scaleX = e.scaleY = r, this._updateTransform() }, e.prototype._updateTransform = function () { var t = this._roamTransformable, e = this._rawTransformable; e.parent = t, t.updateTransform(), e.updateTransform(), _e(this.transform || (this.transform = []), e.transform || [1, 0, 0, 1, 0, 0]), this._rawTransform = e.getLocalTransform(), this.invTransform = this.invTransform || [], Ie(this.invTransform, this.transform), this.decomposeTransform() }, e.prototype.getTransformInfo = function () { var t = this._rawTransformable, e = this._roamTransformable, n = new gr; return n.transform = e.transform, n.decomposeTransform(), { roam: { x: n.x, y: n.y, scaleX: n.scaleX, scaleY: n.scaleY }, raw: { x: t.x, y: t.y, scaleX: t.scaleX, scaleY: t.scaleY } } }, e.prototype.getViewRect = function () { return this._viewRect }, e.prototype.getViewRectAfterRoam = function () { var t = this.getBoundingRect().clone(); return t.applyTransform(this.transform), t }, e.prototype.dataToPoint = function (t, e, n) { var i = e ? this._rawTransform : this.transform; return n = n || [], i ? nC(n, t, i) : It(n, t) }, e.prototype.pointToData = function (t) { var e = this.invTransform; return e ? nC([], t, e) : [t[0], t[1]] }, e.prototype.convertToPixel = function (t, e, n) { var i = rC(e); return i === this ? i.dataToPoint(n) : null }, e.prototype.convertFromPixel = function (t, e, n) { var i = rC(e); return i === this ? i.pointToData(n) : null }, e.prototype.containPoint = function (t) { return this.getViewRectAfterRoam().contain(t[0], t[1]) }, e.dimensions = ["x", "y"], e }(gr); function rC(t) { var e = t.seriesModel; return e ? e.coordinateSystem : null } var oC = { geoJSON: { aspectScale: .75, invertLongitute: !0 }, geoSVG: { aspectScale: 1, invertLongitute: !1 } }, aC = ["lng", "lat"], sC = function (t) { function e(e, n, i) { var r = t.call(this, e) || this; r.dimensions = aC, r.type = "geo", r._nameCoordMap = yt(), r.map = n; var o, a = i.projection, s = zT(n, i.nameMap, i.nameProperty), l = NT(n), u = (r.resourceType = l ? l.type : null, r.regions = s.regions), h = oC[l.type]; if (r._regionsMap = s.regionsMap, r.regions = s.regions, r.projection = a, a) for (var c = 0; c < u.length; c++) { var p = u[c].getBoundingRect(a); (o = o || p.clone()).union(p) } else o = s.boundingRect; return r.setBoundingRect(o.x, o.y, o.width, o.height), r.aspectScale = a ? 1 : rt(i.aspectScale, h.aspectScale), r._invertLongitute = !a && h.invertLongitute, r } return n(e, t), e.prototype._transformTo = function (t, e, n, i) { var r = this.getBoundingRect(), o = this._invertLongitute; r = r.clone(), o && (r.y = -r.y - r.height); var a = this._rawTransformable; a.transform = r.calculateTransform(new ze(t, e, n, i)); var s = a.parent; a.parent = null, a.decomposeTransform(), a.parent = s, o && (a.scaleY = -a.scaleY), this._updateTransform() }, e.prototype.getRegion = function (t) { return this._regionsMap.get(t) }, e.prototype.getRegionByCoord = function (t) { for (var e = this.regions, n = 0; n < e.length; n++) { var i = e[n]; if ("geoJSON" === i.type && i.contain(t)) return e[n] } }, e.prototype.addGeoCoord = function (t, e) { this._nameCoordMap.set(t, e) }, e.prototype.getGeoCoord = function (t) { var e = this._regionsMap.get(t); return this._nameCoordMap.get(t) || e && e.getCenter() }, e.prototype.dataToPoint = function (t, e, n) { if (U(t) && (t = this.getGeoCoord(t)), t) { var i = this.projection; return i && (t = i.project(t)), t && this.projectedToPoint(t, e, n) } }, e.prototype.pointToData = function (t) { var e = this.projection; return e && (t = e.unproject(t)), t && this.pointToProjected(t) }, e.prototype.pointToProjected = function (e) { return t.prototype.pointToData.call(this, e) }, e.prototype.projectedToPoint = function (e, n, i) { return t.prototype.dataToPoint.call(this, e, n, i) }, e.prototype.convertToPixel = function (t, e, n) { var i = lC(e); return i === this ? i.dataToPoint(n) : null }, e.prototype.convertFromPixel = function (t, e, n) { var i = lC(e); return i === this ? i.pointToData(n) : null }, e }(iC); function lC(t) { var e = t.geoModel, n = t.seriesModel; return e ? e.coordinateSystem : n ? n.coordinateSystem || (n.getReferringComponents("geo", zo).models[0] || {}).coordinateSystem : null } function uC(t, e) { var n = t.get("boundingCoords"); if (null != n) { var i = n[0], r = n[1]; if (isFinite(i[0]) && isFinite(i[1]) && isFinite(r[0]) && isFinite(r[1])) { var o = this.projection; if (o) { var a = i[0], s = i[1], l = r[0], u = r[1]; i = [1 / 0, 1 / 0], r = [-1 / 0, -1 / 0]; var h = function (t, e, n, a) { for (var s = n - t, l = a - e, u = 0; u <= 100; u++) { var h = u / 100, c = o.project([t + s * h, e + l * h]); Ht(i, i, c), Yt(r, r, c) } }; h(a, s, l, s), h(l, s, l, u), h(l, u, a, u), h(a, u, l, s) } this.setBoundingRect(i[0], i[1], r[0] - i[0], r[1] - i[1]) } else 0 } var c, p, d, f = this.getBoundingRect(), g = t.get("layoutCenter"), y = t.get("layoutSize"), v = e.getWidth(), m = e.getHeight(), x = f.width / f.height * this.aspectScale, _ = !1; if (g && y && (c = [Ur(g[0], v), Ur(g[1], m)], p = Ur(y, Math.min(v, m)), isNaN(c[0]) || isNaN(c[1]) || isNaN(p) || (_ = !0)), _) d = {}, x > 1 ? (d.width = p, d.height = p / x) : (d.height = p, d.width = p * x), d.y = c[1] - d.height / 2, d.x = c[0] - d.width / 2; else { var b = t.getBoxLayoutParams(); b.aspect = x, d = Cp(b, { width: v, height: m }) } this.setViewRect(d.x, d.y, d.width, d.height), this.setCenter(t.get("center"), e), this.setZoom(t.get("zoom")) } R(sC, iC); var hC = function () { function t() { this.dimensions = aC } return t.prototype.create = function (t, e) { var n = []; function i(t) { return { nameProperty: t.get("nameProperty"), aspectScale: t.get("aspectScale"), projection: t.get("projection") } } t.eachComponent("geo", (function (t, r) { var o = t.get("map"), a = new sC(o + r, o, A({ nameMap: t.get("nameMap") }, i(t))); a.zoomLimit = t.get("scaleLimit"), n.push(a), t.coordinateSystem = a, a.model = t, a.resize = uC, a.resize(t, e) })), t.eachSeries((function (t) { if ("geo" === t.get("coordinateSystem")) { var e = t.get("geoIndex") || 0; t.coordinateSystem = n[e] } })); var r = {}; return t.eachSeriesByType("map", (function (t) { if (!t.getHostGeoModel()) { var e = t.getMapType(); r[e] = r[e] || [], r[e].push(t) } })), E(r, (function (t, r) { var o = z(t, (function (t) { return t.get("nameMap") })), a = new sC(r, r, A({ nameMap: D(o) }, i(t[0]))); a.zoomLimit = it.apply(null, z(t, (function (t) { return t.get("scaleLimit") }))), n.push(a), a.resize = uC, a.resize(t[0], e), E(t, (function (t) { t.coordinateSystem = a, function (t, e) { E(e.get("geoCoord"), (function (e, n) { t.addGeoCoord(n, e) })) }(a, t) })) })), n }, t.prototype.getFilledRegions = function (t, e, n, i) { for (var r = (t || []).slice(), o = yt(), a = 0; a < r.length; a++)o.set(r[a].name, r[a]); return E(zT(e, n, i).regions, (function (t) { var e = t.name; !o.get(e) && r.push({ name: e }) })), r }, t }(), cC = new hC, pC = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (t, e, n) { var i = NT(t.map); if (i && "geoJSON" === i.type) { var r = t.itemStyle = t.itemStyle || {}; "color" in r || (r.color = "#eee") } this.mergeDefaultAndTheme(t, n), wo(t, "label", ["show"]) }, e.prototype.optionUpdated = function () { var t = this, e = this.option; e.regions = cC.getFilledRegions(e.regions, e.map, e.nameMap, e.nameProperty); var n = {}; this._optionModelMap = V(e.regions || [], (function (e, i) { var r = i.name; return r && (e.set(r, new Mc(i, t, t.ecModel)), i.selected && (n[r] = !0)), e }), yt()), e.selectedMap || (e.selectedMap = n) }, e.prototype.getRegionModel = function (t) { return this._optionModelMap.get(t) || new Mc(null, this, this.ecModel) }, e.prototype.getFormattedLabel = function (t, e) { var n = this.getRegionModel(t), i = "normal" === e ? n.get(["label", "formatter"]) : n.get(["emphasis", "label", "formatter"]), r = { name: t }; return X(i) ? (r.status = e, i(r)) : U(i) ? i.replace("{a}", null != t ? t : "") : void 0 }, e.prototype.setZoom = function (t) { this.option.zoom = t }, e.prototype.setCenter = function (t) { this.option.center = t }, e.prototype.select = function (t) { var e = this.option, n = e.selectedMode; n && ("multiple" !== n && (e.selectedMap = null), (e.selectedMap || (e.selectedMap = {}))[t] = !0) }, e.prototype.unSelect = function (t) { var e = this.option.selectedMap; e && (e[t] = !1) }, e.prototype.toggleSelected = function (t) { this[this.isSelected(t) ? "unSelect" : "select"](t) }, e.prototype.isSelected = function (t) { var e = this.option.selectedMap; return !(!e || !e[t]) }, e.type = "geo", e.layoutMode = "box", e.defaultOption = { z: 0, show: !0, left: "center", top: "center", aspectScale: null, silent: !1, map: "", boundingCoords: null, center: null, zoom: 1, scaleLimit: null, label: { show: !1, color: "#000" }, itemStyle: { borderWidth: .5, borderColor: "#444" }, emphasis: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { color: "rgba(255,215,0,0.8)" } }, select: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { color: "rgba(255,215,0,0.8)" } }, regions: [] }, e }(Rp); function dC(t, e) { return t.pointToProjected ? t.pointToProjected(e) : t.pointToData(e) } function fC(t, e, n, i) { var r = t.getZoom(), o = t.getCenter(), a = e.zoom, s = t.projectedToPoint ? t.projectedToPoint(o) : t.dataToPoint(o); if (null != e.dx && null != e.dy && (s[0] -= e.dx, s[1] -= e.dy, t.setCenter(dC(t, s), i)), null != a) { if (n) { var l = n.min || 0, u = n.max || 1 / 0; a = Math.max(Math.min(r * a, u), l) / r } t.scaleX *= a, t.scaleY *= a; var h = (e.originX - t.x) * (a - 1), c = (e.originY - t.y) * (a - 1); t.x -= h, t.y -= c, t.updateTransform(), t.setCenter(dC(t, s), i), t.setZoom(a * r) } return { center: t.getCenter(), zoom: t.getZoom() } } var gC = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.focusBlurEnabled = !0, n } return n(e, t), e.prototype.init = function (t, e) { this._api = e }, e.prototype.render = function (t, e, n, i) { if (this._model = t, !t.get("show")) return this._mapDraw && this._mapDraw.remove(), void (this._mapDraw = null); this._mapDraw || (this._mapDraw = new XT(n)); var r = this._mapDraw; r.draw(t, e, n, this, i), r.group.on("click", this._handleRegionClick, this), r.group.silent = t.get("silent"), this.group.add(r.group), this.updateSelectStatus(t, e, n) }, e.prototype._handleRegionClick = function (t) { var e; ky(t.target, (function (t) { return null != (e = Qs(t).eventData) }), !0), e && this._api.dispatchAction({ type: "geoToggleSelect", geoId: this._model.id, name: e.name }) }, e.prototype.updateSelectStatus = function (t, e, n) { var i = this; this._mapDraw.group.traverse((function (t) { var e = Qs(t).eventData; if (e) return i._model.isSelected(e.name) ? n.enterSelect(t) : n.leaveSelect(t), !0 })) }, e.prototype.findHighDownDispatchers = function (t) { return this._mapDraw && this._mapDraw.findHighDownDispatchers(t, this._model) }, e.prototype.dispose = function () { this._mapDraw && this._mapDraw.remove() }, e.type = "geo", e }(Tg); function yC(t, e, n) { RT(t, e, n) } function vC(t) { function e(e, n) { n.update = "geo:updateSelectStatus", t.registerAction(n, (function (t, n) { var i = {}, r = []; return n.eachComponent({ mainType: "geo", query: t }, (function (n) { n[e](t.name), E(n.coordinateSystem.regions, (function (t) { i[t.name] = n.isSelected(t.name) || !1 })); var o = []; E(i, (function (t, e) { i[e] && o.push(e) })), r.push({ geoIndex: n.componentIndex, name: o }) })), { selected: i, allSelected: r, name: t.name } })) } t.registerCoordinateSystem("geo", cC), t.registerComponentModel(pC), t.registerComponentView(gC), t.registerImpl("registerMap", yC), t.registerImpl("getMap", (function (t) { return ET(t) })), e("toggleSelected", { type: "geoToggleSelect", event: "geoselectchanged" }), e("select", { type: "geoSelect", event: "geoselected" }), e("unSelect", { type: "geoUnSelect", event: "geounselected" }), t.registerAction({ type: "geoRoam", event: "geoRoam", update: "updateTransform" }, (function (t, e, n) { var i = t.componentType || "series"; e.eachComponent({ mainType: i, query: t }, (function (e) { var r = e.coordinateSystem; if ("geo" === r.type) { var o = fC(r, t, e.get("scaleLimit"), n); e.setCenter && e.setCenter(o.center), e.setZoom && e.setZoom(o.zoom), "series" === i && E(e.seriesGroup, (function (t) { t.setCenter(o.center), t.setZoom(o.zoom) })) } })) })) } function mC(t, e) { var n = t.isExpand ? t.children : [], i = t.parentNode.children, r = t.hierNode.i ? i[t.hierNode.i - 1] : null; if (n.length) { !function (t) { var e = t.children, n = e.length, i = 0, r = 0; for (; --n >= 0;) { var o = e[n]; o.hierNode.prelim += i, o.hierNode.modifier += i, r += o.hierNode.change, i += o.hierNode.shift + r } }(t); var o = (n[0].hierNode.prelim + n[n.length - 1].hierNode.prelim) / 2; r ? (t.hierNode.prelim = r.hierNode.prelim + e(t, r), t.hierNode.modifier = t.hierNode.prelim - o) : t.hierNode.prelim = o } else r && (t.hierNode.prelim = r.hierNode.prelim + e(t, r)); t.parentNode.hierNode.defaultAncestor = function (t, e, n, i) { if (e) { for (var r = t, o = t, a = o.parentNode.children[0], s = e, l = r.hierNode.modifier, u = o.hierNode.modifier, h = a.hierNode.modifier, c = s.hierNode.modifier; s = wC(s), o = SC(o), s && o;) { r = wC(r), a = SC(a), r.hierNode.ancestor = t; var p = s.hierNode.prelim + c - o.hierNode.prelim - u + i(s, o); p > 0 && (IC(MC(s, t, n), t, p), u += p, l += p), c += s.hierNode.modifier, u += o.hierNode.modifier, l += r.hierNode.modifier, h += a.hierNode.modifier } s && !wC(r) && (r.hierNode.thread = s, r.hierNode.modifier += c - l), o && !SC(a) && (a.hierNode.thread = o, a.hierNode.modifier += u - h, n = t) } return n }(t, r, t.parentNode.hierNode.defaultAncestor || i[0], e) } function xC(t) { var e = t.hierNode.prelim + t.parentNode.hierNode.modifier; t.setLayout({ x: e }, !0), t.hierNode.modifier += t.parentNode.hierNode.modifier } function _C(t) { return arguments.length ? t : TC } function bC(t, e) { return t -= Math.PI / 2, { x: e * Math.cos(t), y: e * Math.sin(t) } } function wC(t) { var e = t.children; return e.length && t.isExpand ? e[e.length - 1] : t.hierNode.thread } function SC(t) { var e = t.children; return e.length && t.isExpand ? e[0] : t.hierNode.thread } function MC(t, e, n) { return t.hierNode.ancestor.parentNode === e.parentNode ? t.hierNode.ancestor : n } function IC(t, e, n) { var i = n / (e.hierNode.i - t.hierNode.i); e.hierNode.change -= i, e.hierNode.shift += n, e.hierNode.modifier += n, e.hierNode.prelim += n, t.hierNode.change += i } function TC(t, e) { return t.parentNode === e.parentNode ? 1 : 2 } var CC = function () { this.parentPoint = [], this.childPoints = [] }, DC = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new CC }, e.prototype.buildPath = function (t, e) { var n = e.childPoints, i = n.length, r = e.parentPoint, o = n[0], a = n[i - 1]; if (1 === i) return t.moveTo(r[0], r[1]), void t.lineTo(o[0], o[1]); var s = e.orient, l = "TB" === s || "BT" === s ? 0 : 1, u = 1 - l, h = Ur(e.forkPosition, 1), c = []; c[l] = r[l], c[u] = r[u] + (a[u] - r[u]) * h, t.moveTo(r[0], r[1]), t.lineTo(c[0], c[1]), t.moveTo(o[0], o[1]), c[l] = o[l], t.lineTo(c[0], c[1]), c[l] = a[l], t.lineTo(c[0], c[1]), t.lineTo(a[0], a[1]); for (var p = 1; p < i - 1; p++) { var d = n[p]; t.moveTo(d[0], d[1]), c[l] = d[l], t.lineTo(c[0], c[1]) } }, e }(Is), AC = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._mainGroup = new zr, n } return n(e, t), e.prototype.init = function (t, e) { this._controller = new UI(e.getZr()), this._controllerHost = { target: this.group }, this.group.add(this._mainGroup) }, e.prototype.render = function (t, e, n) { var i = t.getData(), r = t.layoutInfo, o = this._mainGroup; "radial" === t.get("layout") ? (o.x = r.x + r.width / 2, o.y = r.y + r.height / 2) : (o.x = r.x, o.y = r.y), this._updateViewCoordSys(t, n), this._updateController(t, e, n); var a = this._data; i.diff(a).add((function (e) { kC(i, e) && LC(i, e, null, o, t) })).update((function (e, n) { var r = a.getItemGraphicEl(n); kC(i, e) ? LC(i, e, r, o, t) : r && RC(a, n, r, o, t) })).remove((function (e) { var n = a.getItemGraphicEl(e); n && RC(a, e, n, o, t) })).execute(), this._nodeScaleRatio = t.get("nodeScaleRatio"), this._updateNodeAndLinkScale(t), !0 === t.get("expandAndCollapse") && i.eachItemGraphicEl((function (e, i) { e.off("click").on("click", (function () { n.dispatchAction({ type: "treeExpandAndCollapse", seriesId: t.id, dataIndex: i }) })) })), this._data = i }, e.prototype._updateViewCoordSys = function (t, e) { var n = t.getData(), i = []; n.each((function (t) { var e = n.getItemLayout(t); !e || isNaN(e.x) || isNaN(e.y) || i.push([+e.x, +e.y]) })); var r = [], o = []; Ra(i, r, o); var a = this._min, s = this._max; o[0] - r[0] == 0 && (r[0] = a ? a[0] : r[0] - 1, o[0] = s ? s[0] : o[0] + 1), o[1] - r[1] == 0 && (r[1] = a ? a[1] : r[1] - 1, o[1] = s ? s[1] : o[1] + 1); var l = t.coordinateSystem = new iC; l.zoomLimit = t.get("scaleLimit"), l.setBoundingRect(r[0], r[1], o[0] - r[0], o[1] - r[1]), l.setCenter(t.get("center"), e), l.setZoom(t.get("zoom")), this.group.attr({ x: l.x, y: l.y, scaleX: l.scaleX, scaleY: l.scaleY }), this._min = r, this._max = o }, e.prototype._updateController = function (t, e, n) { var i = this, r = this._controller, o = this._controllerHost, a = this.group; r.setPointerChecker((function (e, i, r) { var o = a.getBoundingRect(); return o.applyTransform(a.transform), o.contain(i, r) && !tT(e, n, t) })), r.enable(t.get("roam")), o.zoomLimit = t.get("scaleLimit"), o.zoom = t.coordinateSystem.getZoom(), r.off("pan").off("zoom").on("pan", (function (e) { KI(o, e.dx, e.dy), n.dispatchAction({ seriesId: t.id, type: "treeRoam", dx: e.dx, dy: e.dy }) })).on("zoom", (function (e) { $I(o, e.scale, e.originX, e.originY), n.dispatchAction({ seriesId: t.id, type: "treeRoam", zoom: e.scale, originX: e.originX, originY: e.originY }), i._updateNodeAndLinkScale(t), n.updateLabelLayout() })) }, e.prototype._updateNodeAndLinkScale = function (t) { var e = t.getData(), n = this._getNodeGlobalScale(t); e.eachItemGraphicEl((function (t, e) { t.setSymbolScale(n) })) }, e.prototype._getNodeGlobalScale = function (t) { var e = t.coordinateSystem; if ("view" !== e.type) return 1; var n = this._nodeScaleRatio, i = e.scaleX || 1; return ((e.getZoom() - 1) * n + 1) / i }, e.prototype.dispose = function () { this._controller && this._controller.dispose(), this._controllerHost = null }, e.prototype.remove = function () { this._mainGroup.removeAll(), this._data = null }, e.type = "tree", e }(kg); function kC(t, e) { var n = t.getItemLayout(e); return n && !isNaN(n.x) && !isNaN(n.y) } function LC(t, e, n, i, r) { var o = !n, a = t.tree.getNodeByDataIndex(e), s = a.getModel(), l = a.getVisual("style").fill, u = !1 === a.isExpand && 0 !== a.children.length ? l : "#fff", h = t.tree.root, c = a.parentNode === h ? a : a.parentNode || a, p = t.getItemGraphicEl(c.dataIndex), d = c.getLayout(), f = p ? { x: p.__oldX, y: p.__oldY, rawX: p.__radialOldRawX, rawY: p.__radialOldRawY } : d, g = a.getLayout(); o ? ((n = new oS(t, e, null, { symbolInnerColor: u, useNameLabel: !0 })).x = f.x, n.y = f.y) : n.updateData(t, e, null, { symbolInnerColor: u, useNameLabel: !0 }), n.__radialOldRawX = n.__radialRawX, n.__radialOldRawY = n.__radialRawY, n.__radialRawX = g.rawX, n.__radialRawY = g.rawY, i.add(n), t.setItemGraphicEl(e, n), n.__oldX = n.x, n.__oldY = n.y, fh(n, { x: g.x, y: g.y }, r); var y = n.getSymbolPath(); if ("radial" === r.get("layout")) { var v = h.children[0], m = v.getLayout(), x = v.children.length, _ = void 0, b = void 0; if (g.x === m.x && !0 === a.isExpand && v.children.length) { var w = { x: (v.children[0].getLayout().x + v.children[x - 1].getLayout().x) / 2, y: (v.children[0].getLayout().y + v.children[x - 1].getLayout().y) / 2 }; (_ = Math.atan2(w.y - m.y, w.x - m.x)) < 0 && (_ = 2 * Math.PI + _), (b = w.x < m.x) && (_ -= Math.PI) } else (_ = Math.atan2(g.y - m.y, g.x - m.x)) < 0 && (_ = 2 * Math.PI + _), 0 === a.children.length || 0 !== a.children.length && !1 === a.isExpand ? (b = g.x < m.x) && (_ -= Math.PI) : (b = g.x > m.x) || (_ -= Math.PI); var S = b ? "left" : "right", M = s.getModel("label"), I = M.get("rotate"), T = I * (Math.PI / 180), C = y.getTextContent(); C && (y.setTextConfig({ position: M.get("position") || S, rotation: null == I ? -_ : T, origin: "center" }), C.setStyle("verticalAlign", "middle")) } var D = s.get(["emphasis", "focus"]), A = "relative" === D ? vt(a.getAncestorsIndices(), a.getDescendantIndices()) : "ancestor" === D ? a.getAncestorsIndices() : "descendant" === D ? a.getDescendantIndices() : null; A && (Qs(n).focus = A), function (t, e, n, i, r, o, a, s) { var l = e.getModel(), u = t.get("edgeShape"), h = t.get("layout"), c = t.getOrient(), p = t.get(["lineStyle", "curveness"]), d = t.get("edgeForkPosition"), f = l.getModel("lineStyle").getLineStyle(), g = i.__edge; if ("curve" === u) e.parentNode && e.parentNode !== n && (g || (g = i.__edge = new $u({ shape: NC(h, c, p, r, r) })), fh(g, { shape: NC(h, c, p, o, a) }, t)); else if ("polyline" === u) if ("orthogonal" === h) { if (e !== n && e.children && 0 !== e.children.length && !0 === e.isExpand) { for (var y = e.children, v = [], m = 0; m < y.length; m++) { var x = y[m].getLayout(); v.push([x.x, x.y]) } g || (g = i.__edge = new DC({ shape: { parentPoint: [a.x, a.y], childPoints: [[a.x, a.y]], orient: c, forkPosition: d } })), fh(g, { shape: { parentPoint: [a.x, a.y], childPoints: v } }, t) } } else 0; g && ("polyline" !== u || e.isExpand) && (g.useStyle(k({ strokeNoScale: !0, fill: null }, f)), jl(g, l, "lineStyle"), Cl(g), s.add(g)) }(r, a, h, n, f, d, g, i), n.__edge && (n.onHoverStateChange = function (e) { if ("blur" !== e) { var i = a.parentNode && t.getItemGraphicEl(a.parentNode.dataIndex); i && 1 === i.hoverState || Il(n.__edge, e) } }) } function PC(t, e, n, i, r) { var o = OC(e.tree.root, t), a = o.source, s = o.sourceLayout, l = e.getItemGraphicEl(t.dataIndex); if (l) { var u = e.getItemGraphicEl(a.dataIndex).__edge, h = l.__edge || (!1 === a.isExpand || 1 === a.children.length ? u : void 0), c = i.get("edgeShape"), p = i.get("layout"), d = i.get("orient"), f = i.get(["lineStyle", "curveness"]); h && ("curve" === c ? vh(h, { shape: NC(p, d, f, s, s), style: { opacity: 0 } }, i, { cb: function () { n.remove(h) }, removeOpt: r }) : "polyline" === c && "orthogonal" === i.get("layout") && vh(h, { shape: { parentPoint: [s.x, s.y], childPoints: [[s.x, s.y]] }, style: { opacity: 0 } }, i, { cb: function () { n.remove(h) }, removeOpt: r })) } } function OC(t, e) { for (var n, i = e.parentNode === t ? e : e.parentNode || e; null == (n = i.getLayout());)i = i.parentNode === t ? i : i.parentNode || i; return { source: i, sourceLayout: n } } function RC(t, e, n, i, r) { var o = t.tree.getNodeByDataIndex(e), a = OC(t.tree.root, o).sourceLayout, s = { duration: r.get("animationDurationUpdate"), easing: r.get("animationEasingUpdate") }; vh(n, { x: a.x + 1, y: a.y + 1 }, r, { cb: function () { i.remove(n), t.setItemGraphicEl(e, null) }, removeOpt: s }), n.fadeOut(null, t.hostModel, { fadeLabel: !0, animation: s }), o.children.forEach((function (e) { PC(e, t, i, r, s) })), PC(o, t, i, r, s) } function NC(t, e, n, i, r) { var o, a, s, l, u, h, c, p; if ("radial" === t) { u = i.rawX, c = i.rawY, h = r.rawX, p = r.rawY; var d = bC(u, c), f = bC(u, c + (p - c) * n), g = bC(h, p + (c - p) * n), y = bC(h, p); return { x1: d.x || 0, y1: d.y || 0, x2: y.x || 0, y2: y.y || 0, cpx1: f.x || 0, cpy1: f.y || 0, cpx2: g.x || 0, cpy2: g.y || 0 } } return u = i.x, c = i.y, h = r.x, p = r.y, "LR" !== e && "RL" !== e || (o = u + (h - u) * n, a = c, s = h + (u - h) * n, l = p), "TB" !== e && "BT" !== e || (o = u, a = c + (p - c) * n, s = h, l = p + (c - p) * n), { x1: u, y1: c, x2: h, y2: p, cpx1: o, cpy1: a, cpx2: s, cpy2: l } } var EC = Oo(); function zC(t) { var e = t.mainData, n = t.datas; n || (n = { main: e }, t.datasAttr = { main: "data" }), t.datas = t.mainData = null, HC(e, n, t), E(n, (function (n) { E(e.TRANSFERABLE_METHODS, (function (e) { n.wrapMethod(e, H(VC, t)) })) })), e.wrapMethod("cloneShallow", H(FC, t)), E(e.CHANGABLE_METHODS, (function (n) { e.wrapMethod(n, H(BC, t)) })), lt(n[e.dataType] === e) } function VC(t, e) { if (EC(i = this).mainData === i) { var n = A({}, EC(this).datas); n[this.dataType] = e, HC(e, n, t) } else YC(e, this.dataType, EC(this).mainData, t); var i; return e } function BC(t, e) { return t.struct && t.struct.update(), e } function FC(t, e) { return E(EC(e).datas, (function (n, i) { n !== e && YC(n.cloneShallow(), i, e, t) })), e } function GC(t) { var e = EC(this).mainData; return null == t || null == e ? e : EC(e).datas[t] } function WC() { var t = EC(this).mainData; return null == t ? [{ data: t }] : z(G(EC(t).datas), (function (e) { return { type: e, data: EC(t).datas[e] } })) } function HC(t, e, n) { EC(t).datas = {}, E(e, (function (e, i) { YC(e, i, t, n) })) } function YC(t, e, n, i) { EC(n).datas[e] = t, EC(t).mainData = n, t.dataType = e, i.struct && (t[i.structAttr] = i.struct, i.struct[i.datasAttr[e]] = t), t.getLinkedData = GC, t.getLinkedDataAll = WC } var XC = function () { function t(t, e) { this.depth = 0, this.height = 0, this.dataIndex = -1, this.children = [], this.viewChildren = [], this.isExpand = !1, this.name = t || "", this.hostTree = e } return t.prototype.isRemoved = function () { return this.dataIndex < 0 }, t.prototype.eachNode = function (t, e, n) { X(t) && (n = e, e = t, t = null), U(t = t || {}) && (t = { order: t }); var i, r = t.order || "preorder", o = this[t.attr || "children"]; "preorder" === r && (i = e.call(n, this)); for (var a = 0; !i && a < o.length; a++)o[a].eachNode(t, e, n); "postorder" === r && e.call(n, this) }, t.prototype.updateDepthAndHeight = function (t) { var e = 0; this.depth = t; for (var n = 0; n < this.children.length; n++) { var i = this.children[n]; i.updateDepthAndHeight(t + 1), i.height > e && (e = i.height) } this.height = e + 1 }, t.prototype.getNodeById = function (t) { if (this.getId() === t) return this; for (var e = 0, n = this.children, i = n.length; e < i; e++) { var r = n[e].getNodeById(t); if (r) return r } }, t.prototype.contains = function (t) { if (t === this) return !0; for (var e = 0, n = this.children, i = n.length; e < i; e++) { var r = n[e].contains(t); if (r) return r } }, t.prototype.getAncestors = function (t) { for (var e = [], n = t ? this : this.parentNode; n;)e.push(n), n = n.parentNode; return e.reverse(), e }, t.prototype.getAncestorsIndices = function () { for (var t = [], e = this; e;)t.push(e.dataIndex), e = e.parentNode; return t.reverse(), t }, t.prototype.getDescendantIndices = function () { var t = []; return this.eachNode((function (e) { t.push(e.dataIndex) })), t }, t.prototype.getValue = function (t) { var e = this.hostTree.data; return e.getStore().get(e.getDimensionIndex(t || "value"), this.dataIndex) }, t.prototype.setLayout = function (t, e) { this.dataIndex >= 0 && this.hostTree.data.setItemLayout(this.dataIndex, t, e) }, t.prototype.getLayout = function () { return this.hostTree.data.getItemLayout(this.dataIndex) }, t.prototype.getModel = function (t) { if (!(this.dataIndex < 0)) return this.hostTree.data.getItemModel(this.dataIndex).getModel(t) }, t.prototype.getLevelModel = function () { return (this.hostTree.levelModels || [])[this.depth] }, t.prototype.setVisual = function (t, e) { this.dataIndex >= 0 && this.hostTree.data.setItemVisual(this.dataIndex, t, e) }, t.prototype.getVisual = function (t) { return this.hostTree.data.getItemVisual(this.dataIndex, t) }, t.prototype.getRawIndex = function () { return this.hostTree.data.getRawIndex(this.dataIndex) }, t.prototype.getId = function () { return this.hostTree.data.getId(this.dataIndex) }, t.prototype.getChildIndex = function () { if (this.parentNode) { for (var t = this.parentNode.children, e = 0; e < t.length; ++e)if (t[e] === this) return e; return -1 } return -1 }, t.prototype.isAncestorOf = function (t) { for (var e = t.parentNode; e;) { if (e === this) return !0; e = e.parentNode } return !1 }, t.prototype.isDescendantOf = function (t) { return t !== this && t.isAncestorOf(this) }, t }(), UC = function () { function t(t) { this.type = "tree", this._nodes = [], this.hostModel = t } return t.prototype.eachNode = function (t, e, n) { this.root.eachNode(t, e, n) }, t.prototype.getNodeByDataIndex = function (t) { var e = this.data.getRawIndex(t); return this._nodes[e] }, t.prototype.getNodeById = function (t) { return this.root.getNodeById(t) }, t.prototype.update = function () { for (var t = this.data, e = this._nodes, n = 0, i = e.length; n < i; n++)e[n].dataIndex = -1; for (n = 0, i = t.count(); n < i; n++)e[t.getRawIndex(n)].dataIndex = n }, t.prototype.clearLayouts = function () { this.data.clearItemLayouts() }, t.createTree = function (e, n, i) { var r = new t(n), o = [], a = 1; !function t(e, n) { var i = e.value; a = Math.max(a, Y(i) ? i.length : 1), o.push(e); var s = new XC(Ao(e.name, ""), r); n ? function (t, e) { var n = e.children; if (t.parentNode === e) return; n.push(t), t.parentNode = e }(s, n) : r.root = s, r._nodes.push(s); var l = e.children; if (l) for (var u = 0; u < l.length; u++)t(l[u], s) }(e), r.root.updateDepthAndHeight(0); var s = ux(o, { coordDimensions: ["value"], dimensionsCount: a }).dimensions, l = new lx(s, n); return l.initData(o), i && i(l), zC({ mainData: l, struct: r, structAttr: "tree" }), r.update(), r }, t }(); function ZC(t, e, n) { if (t && P(e, t.type) >= 0) { var i = n.getData().tree.root, r = t.targetNode; if (U(r) && (r = i.getNodeById(r)), r && i.contains(r)) return { node: r }; var o = t.targetNodeId; if (null != o && (r = i.getNodeById(o))) return { node: r } } } function jC(t) { for (var e = []; t;)(t = t.parentNode) && e.push(t); return e.reverse() } function qC(t, e) { return P(jC(t), e) >= 0 } function KC(t, e) { for (var n = []; t;) { var i = t.dataIndex; n.push({ name: t.name, dataIndex: i, value: e.getRawValue(i) }), t = t.parentNode } return n.reverse(), n } var $C = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.hasSymbolVisual = !0, e.ignoreStyleOnData = !0, e } return n(e, t), e.prototype.getInitialData = function (t) { var e = { name: t.name, children: t.data }, n = t.leaves || {}, i = new Mc(n, this, this.ecModel), r = UC.createTree(e, this, (function (t) { t.wrapMethod("getItemModel", (function (t, e) { var n = r.getNodeByDataIndex(e); return n && n.children.length && n.isExpand || (t.parentModel = i), t })) })); var o = 0; r.eachNode("preorder", (function (t) { t.depth > o && (o = t.depth) })); var a = t.expandAndCollapse && t.initialTreeDepth >= 0 ? t.initialTreeDepth : o; return r.root.eachNode("preorder", (function (t) { var e = t.hostTree.data.getRawDataItem(t.dataIndex); t.isExpand = e && null != e.collapsed ? !e.collapsed : t.depth <= a })), r.data }, e.prototype.getOrient = function () { var t = this.get("orient"); return "horizontal" === t ? t = "LR" : "vertical" === t && (t = "TB"), t }, e.prototype.setZoom = function (t) { this.option.zoom = t }, e.prototype.setCenter = function (t) { this.option.center = t }, e.prototype.formatTooltip = function (t, e, n) { for (var i = this.getData().tree, r = i.root.children[0], o = i.getNodeByDataIndex(t), a = o.getValue(), s = o.name; o && o !== r;)s = o.parentNode.name + "." + s, o = o.parentNode; return ng("nameValue", { name: s, value: a, noValue: isNaN(a) || null == a }) }, e.prototype.getDataParams = function (e) { var n = t.prototype.getDataParams.apply(this, arguments), i = this.getData().tree.getNodeByDataIndex(e); return n.treeAncestors = KC(i, this), n.collapsed = !i.isExpand, n }, e.type = "series.tree", e.layoutMode = "box", e.defaultOption = { z: 2, coordinateSystem: "view", left: "12%", top: "12%", right: "12%", bottom: "12%", layout: "orthogonal", edgeShape: "curve", edgeForkPosition: "50%", roam: !1, nodeScaleRatio: .4, center: null, zoom: 1, orient: "LR", symbol: "emptyCircle", symbolSize: 7, expandAndCollapse: !0, initialTreeDepth: 2, lineStyle: { color: "#ccc", width: 1.5, curveness: .5 }, itemStyle: { color: "lightsteelblue", borderWidth: 1.5 }, label: { show: !0 }, animationEasing: "linear", animationDuration: 700, animationDurationUpdate: 500 }, e }(mg); function JC(t, e) { for (var n, i = [t]; n = i.pop();)if (e(n), n.isExpand) { var r = n.children; if (r.length) for (var o = r.length - 1; o >= 0; o--)i.push(r[o]) } } function QC(t, e) { t.eachSeriesByType("tree", (function (t) { !function (t, e) { var n = function (t, e) { return Cp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }) }(t, e); t.layoutInfo = n; var i = t.get("layout"), r = 0, o = 0, a = null; "radial" === i ? (r = 2 * Math.PI, o = Math.min(n.height, n.width) / 2, a = _C((function (t, e) { return (t.parentNode === e.parentNode ? 1 : 2) / t.depth }))) : (r = n.width, o = n.height, a = _C()); var s = t.getData().tree.root, l = s.children[0]; if (l) { !function (t) { var e = t; e.hierNode = { defaultAncestor: null, ancestor: e, prelim: 0, modifier: 0, change: 0, shift: 0, i: 0, thread: null }; for (var n, i, r = [e]; n = r.pop();)if (i = n.children, n.isExpand && i.length) for (var o = i.length - 1; o >= 0; o--) { var a = i[o]; a.hierNode = { defaultAncestor: null, ancestor: a, prelim: 0, modifier: 0, change: 0, shift: 0, i: o, thread: null }, r.push(a) } }(s), function (t, e, n) { for (var i, r = [t], o = []; i = r.pop();)if (o.push(i), i.isExpand) { var a = i.children; if (a.length) for (var s = 0; s < a.length; s++)r.push(a[s]) } for (; i = o.pop();)e(i, n) }(l, mC, a), s.hierNode.modifier = -l.hierNode.prelim, JC(l, xC); var u = l, h = l, c = l; JC(l, (function (t) { var e = t.getLayout().x; e < u.getLayout().x && (u = t), e > h.getLayout().x && (h = t), t.depth > c.depth && (c = t) })); var p = u === h ? 1 : a(u, h) / 2, d = p - u.getLayout().x, f = 0, g = 0, y = 0, v = 0; if ("radial" === i) f = r / (h.getLayout().x + p + d), g = o / (c.depth - 1 || 1), JC(l, (function (t) { y = (t.getLayout().x + d) * f, v = (t.depth - 1) * g; var e = bC(y, v); t.setLayout({ x: e.x, y: e.y, rawX: y, rawY: v }, !0) })); else { var m = t.getOrient(); "RL" === m || "LR" === m ? (g = o / (h.getLayout().x + p + d), f = r / (c.depth - 1 || 1), JC(l, (function (t) { v = (t.getLayout().x + d) * g, y = "LR" === m ? (t.depth - 1) * f : r - (t.depth - 1) * f, t.setLayout({ x: y, y: v }, !0) }))) : "TB" !== m && "BT" !== m || (f = r / (h.getLayout().x + p + d), g = o / (c.depth - 1 || 1), JC(l, (function (t) { y = (t.getLayout().x + d) * f, v = "TB" === m ? (t.depth - 1) * g : o - (t.depth - 1) * g, t.setLayout({ x: y, y: v }, !0) }))) } } }(t, e) })) } function tD(t) { t.eachSeriesByType("tree", (function (t) { var e = t.getData(); e.tree.eachNode((function (t) { var n = t.getModel().getModel("itemStyle").getItemStyle(); A(e.ensureUniqueItemVisual(t.dataIndex, "style"), n) })) })) } var eD = ["treemapZoomToNode", "treemapRender", "treemapMove"]; function nD(t) { var e = t.getData().tree, n = {}; e.eachNode((function (e) { for (var i = e; i && i.depth > 1;)i = i.parentNode; var r = ud(t.ecModel, i.name || i.dataIndex + "", n); e.setVisual("decal", r) })) } var iD = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.preventUsingHoverLayer = !0, n } return n(e, t), e.prototype.getInitialData = function (t, e) { var n = { name: t.name, children: t.data }; rD(n); var i = t.levels || [], r = this.designatedVisualItemStyle = {}, o = new Mc({ itemStyle: r }, this, e); i = t.levels = function (t, e) { var n, i, r = bo(e.get("color")), o = bo(e.get(["aria", "decal", "decals"])); if (!r) return; t = t || [], E(t, (function (t) { var e = new Mc(t), r = e.get("color"), o = e.get("decal"); (e.get(["itemStyle", "color"]) || r && "none" !== r) && (n = !0), (e.get(["itemStyle", "decal"]) || o && "none" !== o) && (i = !0) })); var a = t[0] || (t[0] = {}); n || (a.color = r.slice()); !i && o && (a.decal = o.slice()); return t }(i, e); var a = z(i || [], (function (t) { return new Mc(t, o, e) }), this), s = UC.createTree(n, this, (function (t) { t.wrapMethod("getItemModel", (function (t, e) { var n = s.getNodeByDataIndex(e), i = n ? a[n.depth] : null; return t.parentModel = i || o, t })) })); return s.data }, e.prototype.optionUpdated = function () { this.resetViewRoot() }, e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(), r = this.getRawValue(t); return ng("nameValue", { name: i.getName(t), value: r }) }, e.prototype.getDataParams = function (e) { var n = t.prototype.getDataParams.apply(this, arguments), i = this.getData().tree.getNodeByDataIndex(e); return n.treeAncestors = KC(i, this), n.treePathInfo = n.treeAncestors, n }, e.prototype.setLayoutInfo = function (t) { this.layoutInfo = this.layoutInfo || {}, A(this.layoutInfo, t) }, e.prototype.mapIdToIndex = function (t) { var e = this._idIndexMap; e || (e = this._idIndexMap = yt(), this._idIndexMapCount = 0); var n = e.get(t); return null == n && e.set(t, n = this._idIndexMapCount++), n }, e.prototype.getViewRoot = function () { return this._viewRoot }, e.prototype.resetViewRoot = function (t) { t ? this._viewRoot = t : t = this._viewRoot; var e = this.getRawData().tree.root; t && (t === e || e.contains(t)) || (this._viewRoot = e) }, e.prototype.enableAriaDecal = function () { nD(this) }, e.type = "series.treemap", e.layoutMode = "box", e.defaultOption = { progressive: 0, left: "center", top: "middle", width: "80%", height: "80%", sort: !0, clipWindow: "origin", squareRatio: .5 * (1 + Math.sqrt(5)), leafDepth: null, drillDownIcon: "▶", zoomToNodeRatio: .1024, roam: !0, nodeClick: "zoomToNode", animation: !0, animationDurationUpdate: 900, animationEasing: "quinticInOut", breadcrumb: { show: !0, height: 22, left: "center", top: "bottom", emptyItemWidth: 25, itemStyle: { color: "rgba(0,0,0,0.7)", textStyle: { color: "#fff" } }, emphasis: { itemStyle: { color: "rgba(0,0,0,0.9)" } } }, label: { show: !0, distance: 0, padding: 5, position: "inside", color: "#fff", overflow: "truncate" }, upperLabel: { show: !1, position: [0, "50%"], height: 20, overflow: "truncate", verticalAlign: "middle" }, itemStyle: { color: null, colorAlpha: null, colorSaturation: null, borderWidth: 0, gapWidth: 0, borderColor: "#fff", borderColorSaturation: null }, emphasis: { upperLabel: { show: !0, position: [0, "50%"], overflow: "truncate", verticalAlign: "middle" } }, visualDimension: 0, visualMin: null, visualMax: null, color: [], colorAlpha: null, colorSaturation: null, colorMappingBy: "index", visibleMin: 10, childrenVisibleMin: null, levels: [] }, e }(mg); function rD(t) { var e = 0; E(t.children, (function (t) { rD(t); var n = t.value; Y(n) && (n = n[0]), e += n })); var n = t.value; Y(n) && (n = n[0]), (null == n || isNaN(n)) && (n = e), n < 0 && (n = 0), Y(t.value) ? t.value[0] = n : t.value = n } var oD = function () { function t(t) { this.group = new zr, t.add(this.group) } return t.prototype.render = function (t, e, n, i) { var r = t.getModel("breadcrumb"), o = this.group; if (o.removeAll(), r.get("show") && n) { var a = r.getModel("itemStyle"), s = r.getModel("emphasis"), l = a.getModel("textStyle"), u = s.getModel(["itemStyle", "textStyle"]), h = { pos: { left: r.get("left"), right: r.get("right"), top: r.get("top"), bottom: r.get("bottom") }, box: { width: e.getWidth(), height: e.getHeight() }, emptyItemWidth: r.get("emptyItemWidth"), totalWidth: 0, renderList: [] }; this._prepare(n, h, l), this._renderContent(t, h, a, s, l, u, i), Dp(o, h.pos, h.box) } }, t.prototype._prepare = function (t, e, n) { for (var i = t; i; i = i.parentNode) { var r = Ao(i.getModel().get("name"), ""), o = n.getTextRect(r), a = Math.max(o.width + 16, e.emptyItemWidth); e.totalWidth += a + 8, e.renderList.push({ node: i, text: r, width: a }) } }, t.prototype._renderContent = function (t, e, n, i, r, o, a) { for (var s, l, u, h, c, p, d, f, g, y = 0, v = e.emptyItemWidth, m = t.get(["breadcrumb", "height"]), x = (s = e.pos, l = e.box, h = l.width, c = l.height, p = Ur(s.left, h), d = Ur(s.top, c), f = Ur(s.right, h), g = Ur(s.bottom, c), (isNaN(p) || isNaN(parseFloat(s.left))) && (p = 0), (isNaN(f) || isNaN(parseFloat(s.right))) && (f = h), (isNaN(d) || isNaN(parseFloat(s.top))) && (d = 0), (isNaN(g) || isNaN(parseFloat(s.bottom))) && (g = c), u = fp(u || 0), { width: Math.max(f - p - u[1] - u[3], 0), height: Math.max(g - d - u[0] - u[2], 0) }), _ = e.totalWidth, b = e.renderList, w = i.getModel("itemStyle").getItemStyle(), S = b.length - 1; S >= 0; S--) { var M = b[S], I = M.node, T = M.width, C = M.text; _ > x.width && (_ -= T - v, T = v, C = null); var D = new Wu({ shape: { points: aD(y, 0, T, m, S === b.length - 1, 0 === S) }, style: k(n.getItemStyle(), { lineJoin: "bevel" }), textContent: new Fs({ style: nc(r, { text: C }) }), textConfig: { position: "inside" }, z2: 1e5, onclick: H(a, I) }); D.disableLabelAnimation = !0, D.getTextContent().ensureState("emphasis").style = nc(o, { text: C }), D.ensureState("emphasis").style = w, Yl(D, i.get("focus"), i.get("blurScope"), i.get("disabled")), this.group.add(D), sD(D, t, I), y += T + 8 } }, t.prototype.remove = function () { this.group.removeAll() }, t }(); function aD(t, e, n, i, r, o) { var a = [[r ? t : t - 5, e], [t + n, e], [t + n, e + i], [r ? t : t - 5, e + i]]; return !o && a.splice(2, 0, [t + n + 5, e + i / 2]), !r && a.push([t, e + i / 2]), a } function sD(t, e, n) { Qs(t).eventData = { componentType: "series", componentSubType: "treemap", componentIndex: e.componentIndex, seriesIndex: e.seriesIndex, seriesName: e.name, seriesType: "treemap", selfType: "breadcrumb", nodeData: { dataIndex: n && n.dataIndex, name: n && n.name }, treePathInfo: n && KC(n, e) } } var lD = function () { function t() { this._storage = [], this._elExistsMap = {} } return t.prototype.add = function (t, e, n, i, r) { return !this._elExistsMap[t.id] && (this._elExistsMap[t.id] = !0, this._storage.push({ el: t, target: e, duration: n, delay: i, easing: r }), !0) }, t.prototype.finished = function (t) { return this._finishedCallback = t, this }, t.prototype.start = function () { for (var t = this, e = this._storage.length, n = function () { --e <= 0 && (t._storage.length = 0, t._elExistsMap = {}, t._finishedCallback && t._finishedCallback()) }, i = 0, r = this._storage.length; i < r; i++) { var o = this._storage[i]; o.el.animateTo(o.target, { duration: o.duration, delay: o.delay, easing: o.easing, setToFinal: !0, done: n, aborted: n }) } return this }, t }(); var uD = zr, hD = zs, cD = "label", pD = "upperLabel", dD = Jo([["fill", "color"], ["stroke", "strokeColor"], ["lineWidth", "strokeWidth"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"]]), fD = function (t) { var e = dD(t); return e.stroke = e.fill = e.lineWidth = null, e }, gD = Oo(), yD = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._state = "ready", n._storage = { nodeGroup: [], background: [], content: [] }, n } return n(e, t), e.prototype.render = function (t, e, n, i) { if (!(P(e.findComponents({ mainType: "series", subType: "treemap", query: i }), t) < 0)) { this.seriesModel = t, this.api = n, this.ecModel = e; var r = ZC(i, ["treemapZoomToNode", "treemapRootToNode"], t), o = i && i.type, a = t.layoutInfo, s = !this._oldTree, l = this._storage, u = "treemapRootToNode" === o && r && l ? { rootNodeGroup: l.nodeGroup[r.node.getRawIndex()], direction: i.direction } : null, h = this._giveContainerGroup(a), c = t.get("animation"), p = this._doRender(h, t, u); !c || s || o && "treemapZoomToNode" !== o && "treemapRootToNode" !== o ? p.renderFinally() : this._doAnimation(h, p, t, u), this._resetController(n), this._renderBreadcrumb(t, n, r) } }, e.prototype._giveContainerGroup = function (t) { var e = this._containerGroup; return e || (e = this._containerGroup = new uD, this._initEvents(e), this.group.add(e)), e.x = t.x, e.y = t.y, e }, e.prototype._doRender = function (t, e, n) { var i = e.getData().tree, r = this._oldTree, o = { nodeGroup: [], background: [], content: [] }, a = { nodeGroup: [], background: [], content: [] }, s = this._storage, l = []; function u(t, i, r, u) { return function (t, e, n, i, r, o, a, s, l, u) { if (!a) return; var h = a.getLayout(), c = t.getData(), p = a.getModel(); if (c.setItemGraphicEl(a.dataIndex, null), !h || !h.isInView) return; var d = h.width, f = h.height, g = h.borderWidth, y = h.invisible, v = a.getRawIndex(), m = s && s.getRawIndex(), x = a.viewChildren, _ = h.upperHeight, b = x && x.length, w = p.getModel("itemStyle"), S = p.getModel(["emphasis", "itemStyle"]), M = p.getModel(["blur", "itemStyle"]), I = p.getModel(["select", "itemStyle"]), T = w.get("borderRadius") || 0, C = G("nodeGroup", uD); if (!C) return; if (l.add(C), C.x = h.x || 0, C.y = h.y || 0, C.markRedraw(), gD(C).nodeWidth = d, gD(C).nodeHeight = f, h.isAboveViewRoot) return C; var D = G("background", hD, u, 20); D && E(C, D, b && h.upperLabelHeight); var k = p.getModel("emphasis"), L = k.get("focus"), P = k.get("blurScope"), O = k.get("disabled"), R = "ancestor" === L ? a.getAncestorsIndices() : "descendant" === L ? a.getDescendantIndices() : L; if (b) Kl(C) && ql(C, !1), D && (ql(D, !O), c.setItemGraphicEl(a.dataIndex, D), Xl(D, R, P)); else { var N = G("content", hD, u, 30); N && z(C, N), D.disableMorphing = !0, D && Kl(D) && ql(D, !1), ql(C, !O), c.setItemGraphicEl(a.dataIndex, C), Xl(C, R, P) } return C; function E(e, n, i) { var r = Qs(n); if (r.dataIndex = a.dataIndex, r.seriesIndex = t.seriesIndex, n.setShape({ x: 0, y: 0, width: d, height: f, r: T }), y) V(n); else { n.invisible = !1; var o = a.getVisual("style"), s = o.stroke, l = fD(w); l.fill = s; var u = dD(S); u.fill = S.get("borderColor"); var h = dD(M); h.fill = M.get("borderColor"); var c = dD(I); if (c.fill = I.get("borderColor"), i) { var p = d - 2 * g; B(n, s, o.opacity, { x: g, y: 0, width: p, height: _ }) } else n.removeTextContent(); n.setStyle(l), n.ensureState("emphasis").style = u, n.ensureState("blur").style = h, n.ensureState("select").style = c, Cl(n) } e.add(n) } function z(e, n) { var i = Qs(n); i.dataIndex = a.dataIndex, i.seriesIndex = t.seriesIndex; var r = Math.max(d - 2 * g, 0), o = Math.max(f - 2 * g, 0); if (n.culling = !0, n.setShape({ x: g, y: g, width: r, height: o, r: T }), y) V(n); else { n.invisible = !1; var s = a.getVisual("style"), l = s.fill, u = fD(w); u.fill = l, u.decal = s.decal; var h = dD(S), c = dD(M), p = dD(I); B(n, l, s.opacity, null), n.setStyle(u), n.ensureState("emphasis").style = h, n.ensureState("blur").style = c, n.ensureState("select").style = p, Cl(n) } e.add(n) } function V(t) { !t.invisible && o.push(t) } function B(e, n, i, r) { var o = p.getModel(r ? pD : cD), s = Ao(p.get("name"), null), l = o.getShallow("show"); tc(e, ec(p, r ? pD : cD), { defaultText: l ? s : null, inheritColor: n, defaultOpacity: i, labelFetcher: t, labelDataIndex: a.dataIndex }); var u = e.getTextContent(); if (u) { var c = u.style, d = st(c.padding || 0); r && (e.setTextConfig({ layoutRect: r }), u.disableLabelLayout = !0), u.beforeUpdate = function () { var t = Math.max((r ? r.width : e.shape.width) - d[1] - d[3], 0), n = Math.max((r ? r.height : e.shape.height) - d[0] - d[2], 0); c.width === t && c.height === n || u.setStyle({ width: t, height: n }) }, c.truncateMinChar = 2, c.lineOverflow = "truncate", F(c, r, h); var f = u.getState("emphasis"); F(f ? f.style : null, r, h) } } function F(e, n, i) { var r = e ? e.text : null; if (!n && i.isLeafRoot && null != r) { var o = t.get("drillDownIcon", !0); e.text = o ? o + " " + r : r } } function G(t, i, o, a) { var s = null != m && n[t][m], l = r[t]; return s ? (n[t][m] = null, W(l, s)) : y || ((s = new i) instanceof Sa && (s.z2 = function (t, e) { return 100 * t + e }(o, a)), H(l, s)), e[t][v] = s } function W(t, e) { var n = t[v] = {}; e instanceof uD ? (n.oldX = e.x, n.oldY = e.y) : n.oldShape = A({}, e.shape) } function H(t, e) { var n = t[v] = {}, o = a.parentNode, s = e instanceof zr; if (o && (!i || "drillDown" === i.direction)) { var l = 0, u = 0, h = r.background[o.getRawIndex()]; !i && h && h.oldShape && (l = h.oldShape.width, u = h.oldShape.height), s ? (n.oldX = 0, n.oldY = u) : n.oldShape = { x: l, y: u, width: 0, height: 0 } } n.fadein = !s } }(e, a, s, n, o, l, t, i, r, u) } !function t(e, n, i, r, o) { r ? (n = e, E(e, (function (t, e) { !t.isRemoved() && s(e, e) }))) : new Vm(n, e, a, a).add(s).update(s).remove(H(s, null)).execute(); function a(t) { return t.getId() } function s(a, s) { var l = null != a ? e[a] : null, h = null != s ? n[s] : null, c = u(l, h, i, o); c && t(l && l.viewChildren || [], h && h.viewChildren || [], c, r, o + 1) } }(i.root ? [i.root] : [], r && r.root ? [r.root] : [], t, i === r || !r, 0); var h = function (t) { var e = { nodeGroup: [], background: [], content: [] }; return t && E(t, (function (t, n) { var i = e[n]; E(t, (function (t) { t && (i.push(t), gD(t).willDelete = !0) })) })), e }(s); return this._oldTree = i, this._storage = a, { lastsForAnimation: o, willDeleteEls: h, renderFinally: function () { E(h, (function (t) { E(t, (function (t) { t.parent && t.parent.remove(t) })) })), E(l, (function (t) { t.invisible = !0, t.dirty() })) } } }, e.prototype._doAnimation = function (t, e, n, i) { var r = n.get("animationDurationUpdate"), o = n.get("animationEasing"), a = (X(r) ? 0 : r) || 0, s = (X(o) ? null : o) || "cubicOut", l = new lD; E(e.willDeleteEls, (function (t, e) { E(t, (function (t, n) { if (!t.invisible) { var r, o = t.parent, u = gD(o); if (i && "drillDown" === i.direction) r = o === i.rootNodeGroup ? { shape: { x: 0, y: 0, width: u.nodeWidth, height: u.nodeHeight }, style: { opacity: 0 } } : { style: { opacity: 0 } }; else { var h = 0, c = 0; u.willDelete || (h = u.nodeWidth / 2, c = u.nodeHeight / 2), r = "nodeGroup" === e ? { x: h, y: c, style: { opacity: 0 } } : { shape: { x: h, y: c, width: 0, height: 0 }, style: { opacity: 0 } } } r && l.add(t, r, a, 0, s) } })) })), E(this._storage, (function (t, n) { E(t, (function (t, i) { var r = e.lastsForAnimation[n][i], o = {}; r && (t instanceof zr ? null != r.oldX && (o.x = t.x, o.y = t.y, t.x = r.oldX, t.y = r.oldY) : (r.oldShape && (o.shape = A({}, t.shape), t.setShape(r.oldShape)), r.fadein ? (t.setStyle("opacity", 0), o.style = { opacity: 1 }) : 1 !== t.style.opacity && (o.style = { opacity: 1 })), l.add(t, o, a, 0, s)) })) }), this), this._state = "animating", l.finished(W((function () { this._state = "ready", e.renderFinally() }), this)).start() }, e.prototype._resetController = function (t) { var e = this._controller; e || ((e = this._controller = new UI(t.getZr())).enable(this.seriesModel.get("roam")), e.on("pan", W(this._onPan, this)), e.on("zoom", W(this._onZoom, this))); var n = new ze(0, 0, t.getWidth(), t.getHeight()); e.setPointerChecker((function (t, e, i) { return n.contain(e, i) })) }, e.prototype._clearController = function () { var t = this._controller; t && (t.dispose(), t = null) }, e.prototype._onPan = function (t) { if ("animating" !== this._state && (Math.abs(t.dx) > 3 || Math.abs(t.dy) > 3)) { var e = this.seriesModel.getData().tree.root; if (!e) return; var n = e.getLayout(); if (!n) return; this.api.dispatchAction({ type: "treemapMove", from: this.uid, seriesId: this.seriesModel.id, rootRect: { x: n.x + t.dx, y: n.y + t.dy, width: n.width, height: n.height } }) } }, e.prototype._onZoom = function (t) { var e = t.originX, n = t.originY; if ("animating" !== this._state) { var i = this.seriesModel.getData().tree.root; if (!i) return; var r = i.getLayout(); if (!r) return; var o = new ze(r.x, r.y, r.width, r.height), a = this.seriesModel.layoutInfo, s = [1, 0, 0, 1, 0, 0]; we(s, s, [-(e -= a.x), -(n -= a.y)]), Me(s, s, [t.scale, t.scale]), we(s, s, [e, n]), o.applyTransform(s), this.api.dispatchAction({ type: "treemapRender", from: this.uid, seriesId: this.seriesModel.id, rootRect: { x: o.x, y: o.y, width: o.width, height: o.height } }) } }, e.prototype._initEvents = function (t) { var e = this; t.on("click", (function (t) { if ("ready" === e._state) { var n = e.seriesModel.get("nodeClick", !0); if (n) { var i = e.findTarget(t.offsetX, t.offsetY); if (i) { var r = i.node; if (r.getLayout().isLeafRoot) e._rootToNode(i); else if ("zoomToNode" === n) e._zoomToNode(i); else if ("link" === n) { var o = r.hostTree.data.getItemModel(r.dataIndex), a = o.get("link", !0), s = o.get("target", !0) || "blank"; a && bp(a, s) } } } } }), this) }, e.prototype._renderBreadcrumb = function (t, e, n) { var i = this; n || (n = null != t.get("leafDepth", !0) ? { node: t.getViewRoot() } : this.findTarget(e.getWidth() / 2, e.getHeight() / 2)) || (n = { node: t.getData().tree.root }), (this._breadcrumb || (this._breadcrumb = new oD(this.group))).render(t, e, n.node, (function (e) { "animating" !== i._state && (qC(t.getViewRoot(), e) ? i._rootToNode({ node: e }) : i._zoomToNode({ node: e })) })) }, e.prototype.remove = function () { this._clearController(), this._containerGroup && this._containerGroup.removeAll(), this._storage = { nodeGroup: [], background: [], content: [] }, this._state = "ready", this._breadcrumb && this._breadcrumb.remove() }, e.prototype.dispose = function () { this._clearController() }, e.prototype._zoomToNode = function (t) { this.api.dispatchAction({ type: "treemapZoomToNode", from: this.uid, seriesId: this.seriesModel.id, targetNode: t.node }) }, e.prototype._rootToNode = function (t) { this.api.dispatchAction({ type: "treemapRootToNode", from: this.uid, seriesId: this.seriesModel.id, targetNode: t.node }) }, e.prototype.findTarget = function (t, e) { var n; return this.seriesModel.getViewRoot().eachNode({ attr: "viewChildren", order: "preorder" }, (function (i) { var r = this._storage.background[i.getRawIndex()]; if (r) { var o = r.transformCoordToLocal(t, e), a = r.shape; if (!(a.x <= o[0] && o[0] <= a.x + a.width && a.y <= o[1] && o[1] <= a.y + a.height)) return !1; n = { node: i, offsetX: o[0], offsetY: o[1] } } }), this), n }, e.type = "treemap", e }(kg); var vD = E, mD = q, xD = -1, _D = function () { function t(e) { var n = e.mappingMethod, i = e.type, r = this.option = T(e); this.type = i, this.mappingMethod = n, this._normalizeData = kD[n]; var o = t.visualHandlers[i]; this.applyVisual = o.applyVisual, this.getColorMapper = o.getColorMapper, this._normalizedToVisual = o._normalizedToVisual[n], "piecewise" === n ? (bD(r), function (t) { var e = t.pieceList; t.hasSpecialVisual = !1, E(e, (function (e, n) { e.originIndex = n, null != e.visual && (t.hasSpecialVisual = !0) })) }(r)) : "category" === n ? r.categories ? function (t) { var e = t.categories, n = t.categoryMap = {}, i = t.visual; if (vD(e, (function (t, e) { n[t] = e })), !Y(i)) { var r = []; q(i) ? vD(i, (function (t, e) { var i = n[e]; r[null != i ? i : xD] = t })) : r[-1] = i, i = AD(t, r) } for (var o = e.length - 1; o >= 0; o--)null == i[o] && (delete n[e[o]], e.pop()) }(r) : bD(r, !0) : (lt("linear" !== n || r.dataExtent), bD(r)) } return t.prototype.mapValueToVisual = function (t) { var e = this._normalizeData(t); return this._normalizedToVisual(e, t) }, t.prototype.getNormalizer = function () { return W(this._normalizeData, this) }, t.listVisualTypes = function () { return G(t.visualHandlers) }, t.isValidType = function (e) { return t.visualHandlers.hasOwnProperty(e) }, t.eachVisual = function (t, e, n) { q(t) ? E(t, e, n) : e.call(n, t) }, t.mapVisual = function (e, n, i) { var r, o = Y(e) ? [] : q(e) ? {} : (r = !0, null); return t.eachVisual(e, (function (t, e) { var a = n.call(i, t, e); r ? o = a : o[e] = a })), o }, t.retrieveVisuals = function (e) { var n, i = {}; return e && vD(t.visualHandlers, (function (t, r) { e.hasOwnProperty(r) && (i[r] = e[r], n = !0) })), n ? i : null }, t.prepareVisualTypes = function (t) { if (Y(t)) t = t.slice(); else { if (!mD(t)) return []; var e = []; vD(t, (function (t, n) { e.push(n) })), t = e } return t.sort((function (t, e) { return "color" === e && "color" !== t && 0 === t.indexOf("color") ? 1 : -1 })), t }, t.dependsOn = function (t, e) { return "color" === e ? !(!t || 0 !== t.indexOf(e)) : t === e }, t.findPieceIndex = function (t, e, n) { for (var i, r = 1 / 0, o = 0, a = e.length; o < a; o++) { var s = e[o].value; if (null != s) { if (s === t || U(s) && s === t + "") return o; n && c(s, o) } } for (o = 0, a = e.length; o < a; o++) { var l = e[o], u = l.interval, h = l.close; if (u) { if (u[0] === -1 / 0) { if (LD(h[1], t, u[1])) return o } else if (u[1] === 1 / 0) { if (LD(h[0], u[0], t)) return o } else if (LD(h[0], u[0], t) && LD(h[1], t, u[1])) return o; n && c(u[0], o), n && c(u[1], o) } } if (n) return t === 1 / 0 ? e.length - 1 : t === -1 / 0 ? 0 : i; function c(e, n) { var o = Math.abs(e - t); o < r && (r = o, i = n) } }, t.visualHandlers = { color: { applyVisual: MD("color"), getColorMapper: function () { var t = this.option; return W("category" === t.mappingMethod ? function (t, e) { return !e && (t = this._normalizeData(t)), ID.call(this, t) } : function (e, n, i) { var r = !!i; return !n && (e = this._normalizeData(e)), i = Jn(e, t.parsedVisual, i), r ? i : ri(i, "rgba") }, this) }, _normalizedToVisual: { linear: function (t) { return ri(Jn(t, this.option.parsedVisual), "rgba") }, category: ID, piecewise: function (t, e) { var n = DD.call(this, e); return null == n && (n = ri(Jn(t, this.option.parsedVisual), "rgba")), n }, fixed: TD } }, colorHue: wD((function (t, e) { return ni(t, e) })), colorSaturation: wD((function (t, e) { return ni(t, null, e) })), colorLightness: wD((function (t, e) { return ni(t, null, null, e) })), colorAlpha: wD((function (t, e) { return ii(t, e) })), decal: { applyVisual: MD("decal"), _normalizedToVisual: { linear: null, category: ID, piecewise: null, fixed: null } }, opacity: { applyVisual: MD("opacity"), _normalizedToVisual: CD([0, 1]) }, liftZ: { applyVisual: MD("liftZ"), _normalizedToVisual: { linear: TD, category: TD, piecewise: TD, fixed: TD } }, symbol: { applyVisual: function (t, e, n) { n("symbol", this.mapValueToVisual(t)) }, _normalizedToVisual: { linear: SD, category: ID, piecewise: function (t, e) { var n = DD.call(this, e); return null == n && (n = SD.call(this, t)), n }, fixed: TD } }, symbolSize: { applyVisual: MD("symbolSize"), _normalizedToVisual: CD([0, 1]) } }, t }(); function bD(t, e) { var n = t.visual, i = []; q(n) ? vD(n, (function (t) { i.push(t) })) : null != n && i.push(n); e || 1 !== i.length || { color: 1, symbol: 1 }.hasOwnProperty(t.type) || (i[1] = i[0]), AD(t, i) } function wD(t) { return { applyVisual: function (e, n, i) { var r = this.mapValueToVisual(e); i("color", t(n("color"), r)) }, _normalizedToVisual: CD([0, 1]) } } function SD(t) { var e = this.option.visual; return e[Math.round(Xr(t, [0, 1], [0, e.length - 1], !0))] || {} } function MD(t) { return function (e, n, i) { i(t, this.mapValueToVisual(e)) } } function ID(t) { var e = this.option.visual; return e[this.option.loop && t !== xD ? t % e.length : t] } function TD() { return this.option.visual[0] } function CD(t) { return { linear: function (e) { return Xr(e, t, this.option.visual, !0) }, category: ID, piecewise: function (e, n) { var i = DD.call(this, n); return null == i && (i = Xr(e, t, this.option.visual, !0)), i }, fixed: TD } } function DD(t) { var e = this.option, n = e.pieceList; if (e.hasSpecialVisual) { var i = n[_D.findPieceIndex(t, n)]; if (i && i.visual) return i.visual[this.type] } } function AD(t, e) { return t.visual = e, "color" === t.type && (t.parsedVisual = z(e, (function (t) { var e = qn(t); return e || [0, 0, 0, 1] }))), e } var kD = { linear: function (t) { return Xr(t, this.option.dataExtent, [0, 1], !0) }, piecewise: function (t) { var e = this.option.pieceList, n = _D.findPieceIndex(t, e, !0); if (null != n) return Xr(n, [0, e.length - 1], [0, 1], !0) }, category: function (t) { var e = this.option.categories ? this.option.categoryMap[t] : t; return null == e ? xD : e }, fixed: bt }; function LD(t, e, n) { return t ? e <= n : e < n } var PD = Oo(), OD = { seriesType: "treemap", reset: function (t) { var e = t.getData().tree.root; e.isRemoved() || RD(e, {}, t.getViewRoot().getAncestors(), t) } }; function RD(t, e, n, i) { var r = t.getModel(), o = t.getLayout(), a = t.hostTree.data; if (o && !o.invisible && o.isInView) { var s, l = r.getModel("itemStyle"), u = function (t, e, n) { var i = A({}, e), r = n.designatedVisualItemStyle; return E(["color", "colorAlpha", "colorSaturation"], (function (n) { r[n] = e[n]; var o = t.get(n); r[n] = null, null != o && (i[n] = o) })), i }(l, e, i), h = a.ensureUniqueItemVisual(t.dataIndex, "style"), c = l.get("borderColor"), p = l.get("borderColorSaturation"); null != p && (c = function (t, e) { return null != e ? ni(e, null, null, t) : null }(p, s = ND(u))), h.stroke = c; var d = t.viewChildren; if (d && d.length) { var f = function (t, e, n, i, r, o) { if (!o || !o.length) return; var a = zD(e, "color") || null != r.color && "none" !== r.color && (zD(e, "colorAlpha") || zD(e, "colorSaturation")); if (!a) return; var s = e.get("visualMin"), l = e.get("visualMax"), u = n.dataExtent.slice(); null != s && s < u[0] && (u[0] = s), null != l && l > u[1] && (u[1] = l); var h = e.get("colorMappingBy"), c = { type: a.name, dataExtent: u, visual: a.range }; "color" !== c.type || "index" !== h && "id" !== h ? c.mappingMethod = "linear" : (c.mappingMethod = "category", c.loop = !0); var p = new _D(c); return PD(p).drColorMappingBy = h, p }(0, r, o, 0, u, d); E(d, (function (t, e) { if (t.depth >= n.length || t === n[t.depth]) { var o = function (t, e, n, i, r, o) { var a = A({}, e); if (r) { var s = r.type, l = "color" === s && PD(r).drColorMappingBy, u = "index" === l ? i : "id" === l ? o.mapIdToIndex(n.getId()) : n.getValue(t.get("visualDimension")); a[s] = r.mapValueToVisual(u) } return a }(r, u, t, e, f, i); RD(t, o, n, i) } })) } else s = ND(u), h.fill = s } } function ND(t) { var e = ED(t, "color"); if (e) { var n = ED(t, "colorAlpha"), i = ED(t, "colorSaturation"); return i && (e = ni(e, null, null, i)), n && (e = ii(e, n)), e } } function ED(t, e) { var n = t[e]; if (null != n && "none" !== n) return n } function zD(t, e) { var n = t.get(e); return Y(n) && n.length ? { name: e, range: n } : null } var VD = Math.max, BD = Math.min, FD = it, GD = E, WD = ["itemStyle", "borderWidth"], HD = ["itemStyle", "gapWidth"], YD = ["upperLabel", "show"], XD = ["upperLabel", "height"], UD = { seriesType: "treemap", reset: function (t, e, n, i) { var r = n.getWidth(), o = n.getHeight(), a = t.option, s = Cp(t.getBoxLayoutParams(), { width: n.getWidth(), height: n.getHeight() }), l = a.size || [], u = Ur(FD(s.width, l[0]), r), h = Ur(FD(s.height, l[1]), o), c = i && i.type, p = ZC(i, ["treemapZoomToNode", "treemapRootToNode"], t), d = "treemapRender" === c || "treemapMove" === c ? i.rootRect : null, f = t.getViewRoot(), g = jC(f); if ("treemapMove" !== c) { var y = "treemapZoomToNode" === c ? function (t, e, n, i, r) { var o, a = (e || {}).node, s = [i, r]; if (!a || a === n) return s; var l = i * r, u = l * t.option.zoomToNodeRatio; for (; o = a.parentNode;) { for (var h = 0, c = o.children, p = 0, d = c.length; p < d; p++)h += c[p].getValue(); var f = a.getValue(); if (0 === f) return s; u *= h / f; var g = o.getModel(), y = g.get(WD); (u += 4 * y * y + (3 * y + Math.max(y, $D(g))) * Math.pow(u, .5)) > to && (u = to), a = o } u < l && (u = l); var v = Math.pow(u / l, .5); return [i * v, r * v] }(t, p, f, u, h) : d ? [d.width, d.height] : [u, h], v = a.sort; v && "asc" !== v && "desc" !== v && (v = "desc"); var m = { squareRatio: a.squareRatio, sort: v, leafDepth: a.leafDepth }; f.hostTree.clearLayouts(); var x = { x: 0, y: 0, width: y[0], height: y[1], area: y[0] * y[1] }; f.setLayout(x), ZD(f, m, !1, 0), x = f.getLayout(), GD(g, (function (t, e) { var n = (g[e + 1] || f).getValue(); t.setLayout(A({ dataExtent: [n, n], borderWidth: 0, upperHeight: 0 }, x)) })) } var _ = t.getData().tree.root; _.setLayout(function (t, e, n) { if (e) return { x: e.x, y: e.y }; var i = { x: 0, y: 0 }; if (!n) return i; var r = n.node, o = r.getLayout(); if (!o) return i; var a = [o.width / 2, o.height / 2], s = r; for (; s;) { var l = s.getLayout(); a[0] += l.x, a[1] += l.y, s = s.parentNode } return { x: t.width / 2 - a[0], y: t.height / 2 - a[1] } }(s, d, p), !0), t.setLayoutInfo(s), KD(_, new ze(-s.x, -s.y, r, o), g, f, 0) } }; function ZD(t, e, n, i) { var r, o; if (!t.isRemoved()) { var a = t.getLayout(); r = a.width, o = a.height; var s = t.getModel(), l = s.get(WD), u = s.get(HD) / 2, h = $D(s), c = Math.max(l, h), p = l - u, d = c - u; t.setLayout({ borderWidth: l, upperHeight: c, upperLabelHeight: h }, !0); var f = (r = VD(r - 2 * p, 0)) * (o = VD(o - p - d, 0)), g = function (t, e, n, i, r, o) { var a = t.children || [], s = i.sort; "asc" !== s && "desc" !== s && (s = null); var l = null != i.leafDepth && i.leafDepth <= o; if (r && !l) return t.viewChildren = []; a = B(a, (function (t) { return !t.isRemoved() })), function (t, e) { e && t.sort((function (t, n) { var i = "asc" === e ? t.getValue() - n.getValue() : n.getValue() - t.getValue(); return 0 === i ? "asc" === e ? t.dataIndex - n.dataIndex : n.dataIndex - t.dataIndex : i })) }(a, s); var u = function (t, e, n) { for (var i = 0, r = 0, o = e.length; r < o; r++)i += e[r].getValue(); var a, s = t.get("visualDimension"); e && e.length ? "value" === s && n ? (a = [e[e.length - 1].getValue(), e[0].getValue()], "asc" === n && a.reverse()) : (a = [1 / 0, -1 / 0], GD(e, (function (t) { var e = t.getValue(s); e < a[0] && (a[0] = e), e > a[1] && (a[1] = e) }))) : a = [NaN, NaN]; return { sum: i, dataExtent: a } }(e, a, s); if (0 === u.sum) return t.viewChildren = []; if (u.sum = function (t, e, n, i, r) { if (!i) return n; for (var o = t.get("visibleMin"), a = r.length, s = a, l = a - 1; l >= 0; l--) { var u = r["asc" === i ? a - l - 1 : l].getValue(); u / n * e < o && (s = l, n -= u) } return "asc" === i ? r.splice(0, a - s) : r.splice(s, a - s), n }(e, n, u.sum, s, a), 0 === u.sum) return t.viewChildren = []; for (var h = 0, c = a.length; h < c; h++) { var p = a[h].getValue() / u.sum * n; a[h].setLayout({ area: p }) } l && (a.length && t.setLayout({ isLeafRoot: !0 }, !0), a.length = 0); return t.viewChildren = a, t.setLayout({ dataExtent: u.dataExtent }, !0), a }(t, s, f, e, n, i); if (g.length) { var y = { x: p, y: d, width: r, height: o }, v = BD(r, o), m = 1 / 0, x = []; x.area = 0; for (var _ = 0, b = g.length; _ < b;) { var w = g[_]; x.push(w), x.area += w.getLayout().area; var S = jD(x, v, e.squareRatio); S <= m ? (_++, m = S) : (x.area -= x.pop().getLayout().area, qD(x, v, y, u, !1), v = BD(y.width, y.height), x.length = x.area = 0, m = 1 / 0) } if (x.length && qD(x, v, y, u, !0), !n) { var M = s.get("childrenVisibleMin"); null != M && f < M && (n = !0) } for (_ = 0, b = g.length; _ < b; _++)ZD(g[_], e, n, i + 1) } } } function jD(t, e, n) { for (var i = 0, r = 1 / 0, o = 0, a = void 0, s = t.length; o < s; o++)(a = t[o].getLayout().area) && (a < r && (r = a), a > i && (i = a)); var l = t.area * t.area, u = e * e * n; return l ? VD(u * i / l, l / (u * r)) : 1 / 0 } function qD(t, e, n, i, r) { var o = e === n.width ? 0 : 1, a = 1 - o, s = ["x", "y"], l = ["width", "height"], u = n[s[o]], h = e ? t.area / e : 0; (r || h > n[l[a]]) && (h = n[l[a]]); for (var c = 0, p = t.length; c < p; c++) { var d = t[c], f = {}, g = h ? d.getLayout().area / h : 0, y = f[l[a]] = VD(h - 2 * i, 0), v = n[s[o]] + n[l[o]] - u, m = c === p - 1 || v < g ? v : g, x = f[l[o]] = VD(m - 2 * i, 0); f[s[a]] = n[s[a]] + BD(i, y / 2), f[s[o]] = u + BD(i, x / 2), u += m, d.setLayout(f, !0) } n[s[a]] += h, n[l[a]] -= h } function KD(t, e, n, i, r) { var o = t.getLayout(), a = n[r], s = a && a === t; if (!(a && !s || r === n.length && t !== i)) { t.setLayout({ isInView: !0, invisible: !s && !e.intersect(o), isAboveViewRoot: s }, !0); var l = new ze(e.x - o.x, e.y - o.y, e.width, e.height); GD(t.viewChildren || [], (function (t) { KD(t, l, n, i, r + 1) })) } } function $D(t) { return t.get(YD) ? t.get(XD) : 0 } function JD(t) { var e = t.findComponents({ mainType: "legend" }); e && e.length && t.eachSeriesByType("graph", (function (t) { var n = t.getCategoriesData(), i = t.getGraph().data, r = n.mapArray(n.getName); i.filterSelf((function (t) { var n = i.getItemModel(t).getShallow("category"); if (null != n) { j(n) && (n = r[n]); for (var o = 0; o < e.length; o++)if (!e[o].isSelected(n)) return !1 } return !0 })) })) } function QD(t) { var e = {}; t.eachSeriesByType("graph", (function (t) { var n = t.getCategoriesData(), i = t.getData(), r = {}; n.each((function (i) { var o = n.getName(i); r["ec-" + o] = i; var a = n.getItemModel(i), s = a.getModel("itemStyle").getItemStyle(); s.fill || (s.fill = t.getColorFromPalette(o, e)), n.setItemVisual(i, "style", s); for (var l = ["symbol", "symbolSize", "symbolKeepAspect"], u = 0; u < l.length; u++) { var h = a.getShallow(l[u], !0); null != h && n.setItemVisual(i, l[u], h) } })), n.count() && i.each((function (t) { var e = i.getItemModel(t).getShallow("category"); if (null != e) { U(e) && (e = r["ec-" + e]); var o = n.getItemVisual(e, "style"); A(i.ensureUniqueItemVisual(t, "style"), o); for (var a = ["symbol", "symbolSize", "symbolKeepAspect"], s = 0; s < a.length; s++)i.setItemVisual(t, a[s], n.getItemVisual(e, a[s])) } })) })) } function tA(t) { return t instanceof Array || (t = [t, t]), t } function eA(t) { t.eachSeriesByType("graph", (function (t) { var e = t.getGraph(), n = t.getEdgeData(), i = tA(t.get("edgeSymbol")), r = tA(t.get("edgeSymbolSize")); n.setVisual("fromSymbol", i && i[0]), n.setVisual("toSymbol", i && i[1]), n.setVisual("fromSymbolSize", r && r[0]), n.setVisual("toSymbolSize", r && r[1]), n.setVisual("style", t.getModel("lineStyle").getLineStyle()), n.each((function (t) { var i = n.getItemModel(t), r = e.getEdgeByIndex(t), o = tA(i.getShallow("symbol", !0)), a = tA(i.getShallow("symbolSize", !0)), s = i.getModel("lineStyle").getLineStyle(), l = n.ensureUniqueItemVisual(t, "style"); switch (A(l, s), l.stroke) { case "source": var u = r.node1.getVisual("style"); l.stroke = u && u.fill; break; case "target": u = r.node2.getVisual("style"); l.stroke = u && u.fill }o[0] && r.setVisual("fromSymbol", o[0]), o[1] && r.setVisual("toSymbol", o[1]), a[0] && r.setVisual("fromSymbolSize", a[0]), a[1] && r.setVisual("toSymbolSize", a[1]) })) })) } var nA = "--\x3e", iA = function (t) { return t.get("autoCurveness") || null }, rA = function (t, e) { var n = iA(t), i = 20, r = []; if (j(n)) i = n; else if (Y(n)) return void (t.__curvenessList = n); e > i && (i = e); var o = i % 2 ? i + 2 : i + 3; r = []; for (var a = 0; a < o; a++)r.push((a % 2 ? a + 1 : a) / 10 * (a % 2 ? -1 : 1)); t.__curvenessList = r }, oA = function (t, e, n) { var i = [t.id, t.dataIndex].join("."), r = [e.id, e.dataIndex].join("."); return [n.uid, i, r].join(nA) }, aA = function (t) { var e = t.split(nA); return [e[0], e[2], e[1]].join(nA) }, sA = function (t, e) { var n = e.__edgeMap; return n[t] ? n[t].length : 0 }; function lA(t, e, n, i) { var r = iA(e), o = Y(r); if (!r) return null; var a = function (t, e) { var n = oA(t.node1, t.node2, e); return e.__edgeMap[n] }(t, e); if (!a) return null; for (var s = -1, l = 0; l < a.length; l++)if (a[l] === n) { s = l; break } var u = function (t, e) { return sA(oA(t.node1, t.node2, e), e) + sA(oA(t.node2, t.node1, e), e) }(t, e); rA(e, u), t.lineStyle = t.lineStyle || {}; var h = oA(t.node1, t.node2, e), c = e.__curvenessList, p = o || u % 2 ? 0 : 1; if (a.isForward) return c[p + s]; var d = aA(h), f = sA(d, e), g = c[s + f + p]; return i ? o ? r && 0 === r[0] ? (f + p) % 2 ? g : -g : ((f % 2 ? 0 : 1) + p) % 2 ? g : -g : (f + p) % 2 ? g : -g : c[s + f + p] } function uA(t) { var e = t.coordinateSystem; if (!e || "view" === e.type) { var n = t.getGraph(); n.eachNode((function (t) { var e = t.getModel(); t.setLayout([+e.get("x"), +e.get("y")]) })), hA(n, t) } } function hA(t, e) { t.eachEdge((function (t, n) { var i = ot(t.getModel().get(["lineStyle", "curveness"]), -lA(t, e, n, !0), 0), r = Tt(t.node1.getLayout()), o = Tt(t.node2.getLayout()), a = [r, o]; +i && a.push([(r[0] + o[0]) / 2 - (r[1] - o[1]) * i, (r[1] + o[1]) / 2 - (o[0] - r[0]) * i]), t.setLayout(a) })) } function cA(t, e) { t.eachSeriesByType("graph", (function (t) { var e = t.get("layout"), n = t.coordinateSystem; if (n && "view" !== n.type) { var i = t.getData(), r = []; E(n.dimensions, (function (t) { r = r.concat(i.mapDimensionsAll(t)) })); for (var o = 0; o < i.count(); o++) { for (var a = [], s = !1, l = 0; l < r.length; l++) { var u = i.get(r[l], o); isNaN(u) || (s = !0), a.push(u) } s ? i.setItemLayout(o, n.dataToPoint(a)) : i.setItemLayout(o, [NaN, NaN]) } hA(i.graph, t) } else e && "none" !== e || uA(t) })) } function pA(t) { var e = t.coordinateSystem; if ("view" !== e.type) return 1; var n = t.option.nodeScaleRatio, i = e.scaleX; return ((e.getZoom() - 1) * n + 1) / i } function dA(t) { var e = t.getVisual("symbolSize"); return e instanceof Array && (e = (e[0] + e[1]) / 2), +e } var fA = Math.PI, gA = []; function yA(t, e, n, i) { var r = t.coordinateSystem; if (!r || "view" === r.type) { var o = r.getBoundingRect(), a = t.getData(), s = a.graph, l = o.width / 2 + o.x, u = o.height / 2 + o.y, h = Math.min(o.width, o.height) / 2, c = a.count(); if (a.setLayout({ cx: l, cy: u }), c) { if (n) { var p = r.pointToData(i), d = p[0], f = p[1], g = [d - l, f - u]; Et(g, g), Nt(g, g, h), n.setLayout([l + g[0], u + g[1]], !0), mA(n, t.get(["circular", "rotateLabel"]), l, u) } vA[e](t, s, a, h, l, u, c), s.eachEdge((function (e, n) { var i, r = ot(e.getModel().get(["lineStyle", "curveness"]), lA(e, t, n), 0), o = Tt(e.node1.getLayout()), a = Tt(e.node2.getLayout()), s = (o[0] + a[0]) / 2, h = (o[1] + a[1]) / 2; +r && (i = [l * (r *= 3) + s * (1 - r), u * r + h * (1 - r)]), e.setLayout([o, a, i]) })) } } } var vA = { value: function (t, e, n, i, r, o, a) { var s = 0, l = n.getSum("value"), u = 2 * Math.PI / (l || a); e.eachNode((function (t) { var e = t.getValue("value"), n = u * (l ? e : 1) / 2; s += n, t.setLayout([i * Math.cos(s) + r, i * Math.sin(s) + o]), s += n })) }, symbolSize: function (t, e, n, i, r, o, a) { var s = 0; gA.length = a; var l = pA(t); e.eachNode((function (t) { var e = dA(t); isNaN(e) && (e = 2), e < 0 && (e = 0), e *= l; var n = Math.asin(e / 2 / i); isNaN(n) && (n = fA / 2), gA[t.dataIndex] = n, s += 2 * n })); var u = (2 * fA - s) / a / 2, h = 0; e.eachNode((function (t) { var e = u + gA[t.dataIndex]; h += e, (!t.getLayout() || !t.getLayout().fixed) && t.setLayout([i * Math.cos(h) + r, i * Math.sin(h) + o]), h += e })) } }; function mA(t, e, n, i) { var r = t.getGraphicEl(); if (r) { var o = t.getModel().get(["label", "rotate"]) || 0, a = r.getSymbolPath(); if (e) { var s = t.getLayout(), l = Math.atan2(s[1] - i, s[0] - n); l < 0 && (l = 2 * Math.PI + l); var u = s[0] < n; u && (l -= Math.PI); var h = u ? "left" : "right"; a.setTextConfig({ rotation: -l, position: h, origin: "center" }); var c = a.ensureState("emphasis"); A(c.textConfig || (c.textConfig = {}), { position: h }) } else a.setTextConfig({ rotation: o *= Math.PI / 180 }) } } function xA(t) { t.eachSeriesByType("graph", (function (t) { "circular" === t.get("layout") && yA(t, "symbolSize") })) } var _A = At; function bA(t) { t.eachSeriesByType("graph", (function (t) { var e = t.coordinateSystem; if (!e || "view" === e.type) if ("force" === t.get("layout")) { var n = t.preservedPoints || {}, i = t.getGraph(), r = i.data, o = i.edgeData, a = t.getModel("force"), s = a.get("initLayout"); t.preservedPoints ? r.each((function (t) { var e = r.getId(t); r.setItemLayout(t, n[e] || [NaN, NaN]) })) : s && "none" !== s ? "circular" === s && yA(t, "value") : uA(t); var l = r.getDataExtent("value"), u = o.getDataExtent("value"), h = a.get("repulsion"), c = a.get("edgeLength"), p = Y(h) ? h : [h, h], d = Y(c) ? c : [c, c]; d = [d[1], d[0]]; var f = r.mapArray("value", (function (t, e) { var n = r.getItemLayout(e), i = Xr(t, l, p); return isNaN(i) && (i = (p[0] + p[1]) / 2), { w: i, rep: i, fixed: r.getItemModel(e).get("fixed"), p: !n || isNaN(n[0]) || isNaN(n[1]) ? null : n } })), g = o.mapArray("value", (function (e, n) { var r = i.getEdgeByIndex(n), o = Xr(e, u, d); isNaN(o) && (o = (d[0] + d[1]) / 2); var a = r.getModel(), s = ot(r.getModel().get(["lineStyle", "curveness"]), -lA(r, t, n, !0), 0); return { n1: f[r.node1.dataIndex], n2: f[r.node2.dataIndex], d: o, curveness: s, ignoreForceLayout: a.get("ignoreForceLayout") } })), y = e.getBoundingRect(), v = function (t, e, n) { for (var i = t, r = e, o = n.rect, a = o.width, s = o.height, l = [o.x + a / 2, o.y + s / 2], u = null == n.gravity ? .1 : n.gravity, h = 0; h < i.length; h++) { var c = i[h]; c.p || (c.p = Mt(a * (Math.random() - .5) + l[0], s * (Math.random() - .5) + l[1])), c.pp = Tt(c.p), c.edges = null } var p, d, f = null == n.friction ? .6 : n.friction, g = f; return { warmUp: function () { g = .8 * f }, setFixed: function (t) { i[t].fixed = !0 }, setUnfixed: function (t) { i[t].fixed = !1 }, beforeStep: function (t) { p = t }, afterStep: function (t) { d = t }, step: function (t) { p && p(i, r); for (var e = [], n = i.length, o = 0; o < r.length; o++) { var a = r[o]; if (!a.ignoreForceLayout) { var s = a.n1; kt(e, (y = a.n2).p, s.p); var h = Lt(e) - a.d, c = y.w / (s.w + y.w); isNaN(c) && (c = 0), Et(e, e), !s.fixed && _A(s.p, s.p, e, c * h * g), !y.fixed && _A(y.p, y.p, e, -(1 - c) * h * g) } } for (o = 0; o < n; o++)(x = i[o]).fixed || (kt(e, l, x.p), _A(x.p, x.p, e, u * g)); for (o = 0; o < n; o++) { s = i[o]; for (var f = o + 1; f < n; f++) { var y; kt(e, (y = i[f]).p, s.p), 0 === (h = Lt(e)) && (Ct(e, Math.random() - .5, Math.random() - .5), h = 1); var v = (s.rep + y.rep) / h / h; !s.fixed && _A(s.pp, s.pp, e, v), !y.fixed && _A(y.pp, y.pp, e, -v) } } var m = []; for (o = 0; o < n; o++) { var x; (x = i[o]).fixed || (kt(m, x.p, x.pp), _A(x.p, x.p, m, g), It(x.pp, x.p)) } var _ = (g *= .992) < .01; d && d(i, r, _), t && t(_) } } }(f, g, { rect: y, gravity: a.get("gravity"), friction: a.get("friction") }); v.beforeStep((function (t, e) { for (var n = 0, r = t.length; n < r; n++)t[n].fixed && It(t[n].p, i.getNodeByIndex(n).getLayout()) })), v.afterStep((function (t, e, o) { for (var a = 0, s = t.length; a < s; a++)t[a].fixed || i.getNodeByIndex(a).setLayout(t[a].p), n[r.getId(a)] = t[a].p; for (a = 0, s = e.length; a < s; a++) { var l = e[a], u = i.getEdgeByIndex(a), h = l.n1.p, c = l.n2.p, p = u.getLayout(); (p = p ? p.slice() : [])[0] = p[0] || [], p[1] = p[1] || [], It(p[0], h), It(p[1], c), +l.curveness && (p[2] = [(h[0] + c[0]) / 2 - (h[1] - c[1]) * l.curveness, (h[1] + c[1]) / 2 - (c[0] - h[0]) * l.curveness]), u.setLayout(p) } })), t.forceLayout = v, t.preservedPoints = n, v.step() } else t.forceLayout = null })) } function wA(t, e) { var n = []; return t.eachSeriesByType("graph", (function (t) { var i = t.get("coordinateSystem"); if (!i || "view" === i) { var r = t.getData(), o = [], a = []; Ra(r.mapArray((function (t) { var e = r.getItemModel(t); return [+e.get("x"), +e.get("y")] })), o, a), a[0] - o[0] == 0 && (a[0] += 1, o[0] -= 1), a[1] - o[1] == 0 && (a[1] += 1, o[1] -= 1); var s = (a[0] - o[0]) / (a[1] - o[1]), l = function (t, e, n) { return Cp(A(t.getBoxLayoutParams(), { aspect: n }), { width: e.getWidth(), height: e.getHeight() }) }(t, e, s); isNaN(s) && (o = [l.x, l.y], a = [l.x + l.width, l.y + l.height]); var u = a[0] - o[0], h = a[1] - o[1], c = l.width, p = l.height, d = t.coordinateSystem = new iC; d.zoomLimit = t.get("scaleLimit"), d.setBoundingRect(o[0], o[1], u, h), d.setViewRect(l.x, l.y, c, p), d.setCenter(t.get("center"), e), d.setZoom(t.get("zoom")), n.push(d) } })), n } var SA = Zu.prototype, MA = $u.prototype, IA = function () { this.x1 = 0, this.y1 = 0, this.x2 = 0, this.y2 = 0, this.percent = 1 }; !function (t) { function e() { return null !== t && t.apply(this, arguments) || this } n(e, t) }(IA); function TA(t) { return isNaN(+t.cpx1) || isNaN(+t.cpy1) } var CA = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "ec-line", n } return n(e, t), e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new IA }, e.prototype.buildPath = function (t, e) { TA(e) ? SA.buildPath.call(this, t, e) : MA.buildPath.call(this, t, e) }, e.prototype.pointAt = function (t) { return TA(this.shape) ? SA.pointAt.call(this, t) : MA.pointAt.call(this, t) }, e.prototype.tangentAt = function (t) { var e = this.shape, n = TA(e) ? [e.x2 - e.x1, e.y2 - e.y1] : MA.tangentAt.call(this, t); return Et(n, n) }, e }(Is), DA = ["fromSymbol", "toSymbol"]; function AA(t) { return "_" + t + "Type" } function kA(t, e, n) { var i = e.getItemVisual(n, t); if (!i || "none" === i) return i; var r = e.getItemVisual(n, t + "Size"), o = e.getItemVisual(n, t + "Rotate"), a = e.getItemVisual(n, t + "Offset"), s = e.getItemVisual(n, t + "KeepAspect"), l = Hy(r); return i + l + Yy(a || 0, l) + (o || "") + (s || "") } function LA(t, e, n) { var i = e.getItemVisual(n, t); if (i && "none" !== i) { var r = e.getItemVisual(n, t + "Size"), o = e.getItemVisual(n, t + "Rotate"), a = e.getItemVisual(n, t + "Offset"), s = e.getItemVisual(n, t + "KeepAspect"), l = Hy(r), u = Yy(a || 0, l), h = Wy(i, -l[0] / 2 + u[0], -l[1] / 2 + u[1], l[0], l[1], null, s); return h.__specifiedRotation = null == o || isNaN(o) ? void 0 : +o * Math.PI / 180 || 0, h.name = t, h } } function PA(t, e) { t.x1 = e[0][0], t.y1 = e[0][1], t.x2 = e[1][0], t.y2 = e[1][1], t.percent = 1; var n = e[2]; n ? (t.cpx1 = n[0], t.cpy1 = n[1]) : (t.cpx1 = NaN, t.cpy1 = NaN) } var OA = function (t) { function e(e, n, i) { var r = t.call(this) || this; return r._createLine(e, n, i), r } return n(e, t), e.prototype._createLine = function (t, e, n) { var i = t.hostModel, r = function (t) { var e = new CA({ name: "line", subPixelOptimize: !0 }); return PA(e.shape, t), e }(t.getItemLayout(e)); r.shape.percent = 0, gh(r, { shape: { percent: 1 } }, i, e), this.add(r), E(DA, (function (n) { var i = LA(n, t, e); this.add(i), this[AA(n)] = kA(n, t, e) }), this), this._updateCommonStl(t, e, n) }, e.prototype.updateData = function (t, e, n) { var i = t.hostModel, r = this.childOfName("line"), o = t.getItemLayout(e), a = { shape: {} }; PA(a.shape, o), fh(r, a, i, e), E(DA, (function (n) { var i = kA(n, t, e), r = AA(n); if (this[r] !== i) { this.remove(this.childOfName(n)); var o = LA(n, t, e); this.add(o) } this[r] = i }), this), this._updateCommonStl(t, e, n) }, e.prototype.getLinePath = function () { return this.childAt(0) }, e.prototype._updateCommonStl = function (t, e, n) { var i = t.hostModel, r = this.childOfName("line"), o = n && n.emphasisLineStyle, a = n && n.blurLineStyle, s = n && n.selectLineStyle, l = n && n.labelStatesModels, u = n && n.emphasisDisabled, h = n && n.focus, c = n && n.blurScope; if (!n || t.hasItemOption) { var p = t.getItemModel(e), d = p.getModel("emphasis"); o = d.getModel("lineStyle").getLineStyle(), a = p.getModel(["blur", "lineStyle"]).getLineStyle(), s = p.getModel(["select", "lineStyle"]).getLineStyle(), u = d.get("disabled"), h = d.get("focus"), c = d.get("blurScope"), l = ec(p) } var f = t.getItemVisual(e, "style"), g = f.stroke; r.useStyle(f), r.style.fill = null, r.style.strokeNoScale = !0, r.ensureState("emphasis").style = o, r.ensureState("blur").style = a, r.ensureState("select").style = s, E(DA, (function (t) { var e = this.childOfName(t); if (e) { e.setColor(g), e.style.opacity = f.opacity; for (var n = 0; n < ol.length; n++) { var i = ol[n], o = r.getState(i); if (o) { var a = o.style || {}, s = e.ensureState(i), l = s.style || (s.style = {}); null != a.stroke && (l[e.__isEmptyBrush ? "stroke" : "fill"] = a.stroke), null != a.opacity && (l.opacity = a.opacity) } } e.markRedraw() } }), this); var y = i.getRawValue(e); tc(this, l, { labelDataIndex: e, labelFetcher: { getFormattedLabel: function (e, n) { return i.getFormattedLabel(e, n, t.dataType) } }, inheritColor: g || "#000", defaultOpacity: f.opacity, defaultText: (null == y ? t.getName(e) : isFinite(y) ? Zr(y) : y) + "" }); var v = this.getTextContent(); if (v) { var m = l.normal; v.__align = v.style.align, v.__verticalAlign = v.style.verticalAlign, v.__position = m.get("position") || "middle"; var x = m.get("distance"); Y(x) || (x = [x, x]), v.__labelDistance = x } this.setTextConfig({ position: null, local: !0, inside: !1 }), Yl(this, h, c, u) }, e.prototype.highlight = function () { kl(this) }, e.prototype.downplay = function () { Ll(this) }, e.prototype.updateLayout = function (t, e) { this.setLinePoints(t.getItemLayout(e)) }, e.prototype.setLinePoints = function (t) { var e = this.childOfName("line"); PA(e.shape, t), e.dirty() }, e.prototype.beforeUpdate = function () { var t = this, e = t.childOfName("fromSymbol"), n = t.childOfName("toSymbol"), i = t.getTextContent(); if (e || n || i && !i.ignore) { for (var r = 1, o = this.parent; o;)o.scaleX && (r /= o.scaleX), o = o.parent; var a = t.childOfName("line"); if (this.__dirty || a.__dirty) { var s = a.shape.percent, l = a.pointAt(0), u = a.pointAt(s), h = kt([], u, l); if (Et(h, h), e && (e.setPosition(l), S(e, 0), e.scaleX = e.scaleY = r * s, e.markRedraw()), n && (n.setPosition(u), S(n, 1), n.scaleX = n.scaleY = r * s, n.markRedraw()), i && !i.ignore) { i.x = i.y = 0, i.originX = i.originY = 0; var c = void 0, p = void 0, d = i.__labelDistance, f = d[0] * r, g = d[1] * r, y = s / 2, v = a.tangentAt(y), m = [v[1], -v[0]], x = a.pointAt(y); m[1] > 0 && (m[0] = -m[0], m[1] = -m[1]); var _ = v[0] < 0 ? -1 : 1; if ("start" !== i.__position && "end" !== i.__position) { var b = -Math.atan2(v[1], v[0]); u[0] < l[0] && (b = Math.PI + b), i.rotation = b } var w = void 0; switch (i.__position) { case "insideStartTop": case "insideMiddleTop": case "insideEndTop": case "middle": w = -g, p = "bottom"; break; case "insideStartBottom": case "insideMiddleBottom": case "insideEndBottom": w = g, p = "top"; break; default: w = 0, p = "middle" }switch (i.__position) { case "end": i.x = h[0] * f + u[0], i.y = h[1] * g + u[1], c = h[0] > .8 ? "left" : h[0] < -.8 ? "right" : "center", p = h[1] > .8 ? "top" : h[1] < -.8 ? "bottom" : "middle"; break; case "start": i.x = -h[0] * f + l[0], i.y = -h[1] * g + l[1], c = h[0] > .8 ? "right" : h[0] < -.8 ? "left" : "center", p = h[1] > .8 ? "bottom" : h[1] < -.8 ? "top" : "middle"; break; case "insideStartTop": case "insideStart": case "insideStartBottom": i.x = f * _ + l[0], i.y = l[1] + w, c = v[0] < 0 ? "right" : "left", i.originX = -f * _, i.originY = -w; break; case "insideMiddleTop": case "insideMiddle": case "insideMiddleBottom": case "middle": i.x = x[0], i.y = x[1] + w, c = "center", i.originY = -w; break; case "insideEndTop": case "insideEnd": case "insideEndBottom": i.x = -f * _ + u[0], i.y = u[1] + w, c = v[0] >= 0 ? "right" : "left", i.originX = f * _, i.originY = -w }i.scaleX = i.scaleY = r, i.setStyle({ verticalAlign: i.__verticalAlign || p, align: i.__align || c }) } } } function S(t, e) { var n = t.__specifiedRotation; if (null == n) { var i = a.tangentAt(e); t.attr("rotation", (1 === e ? -1 : 1) * Math.PI / 2 - Math.atan2(i[1], i[0])) } else t.attr("rotation", n) } }, e }(zr), RA = function () { function t(t) { this.group = new zr, this._LineCtor = t || OA } return t.prototype.updateData = function (t) { var e = this; this._progressiveEls = null; var n = this, i = n.group, r = n._lineData; n._lineData = t, r || i.removeAll(); var o = NA(t); t.diff(r).add((function (n) { e._doAdd(t, n, o) })).update((function (n, i) { e._doUpdate(r, t, i, n, o) })).remove((function (t) { i.remove(r.getItemGraphicEl(t)) })).execute() }, t.prototype.updateLayout = function () { var t = this._lineData; t && t.eachItemGraphicEl((function (e, n) { e.updateLayout(t, n) }), this) }, t.prototype.incrementalPrepareUpdate = function (t) { this._seriesScope = NA(t), this._lineData = null, this.group.removeAll() }, t.prototype.incrementalUpdate = function (t, e) { function n(t) { t.isGroup || function (t) { return t.animators && t.animators.length > 0 }(t) || (t.incremental = !0, t.ensureState("emphasis").hoverLayer = !0) } this._progressiveEls = []; for (var i = t.start; i < t.end; i++) { if (zA(e.getItemLayout(i))) { var r = new this._LineCtor(e, i, this._seriesScope); r.traverse(n), this.group.add(r), e.setItemGraphicEl(i, r), this._progressiveEls.push(r) } } }, t.prototype.remove = function () { this.group.removeAll() }, t.prototype.eachRendered = function (t) { qh(this._progressiveEls || this.group, t) }, t.prototype._doAdd = function (t, e, n) { if (zA(t.getItemLayout(e))) { var i = new this._LineCtor(t, e, n); t.setItemGraphicEl(e, i), this.group.add(i) } }, t.prototype._doUpdate = function (t, e, n, i, r) { var o = t.getItemGraphicEl(n); zA(e.getItemLayout(i)) ? (o ? o.updateData(e, i, r) : o = new this._LineCtor(e, i, r), e.setItemGraphicEl(i, o), this.group.add(o)) : this.group.remove(o) }, t }(); function NA(t) { var e = t.hostModel, n = e.getModel("emphasis"); return { lineStyle: e.getModel("lineStyle").getLineStyle(), emphasisLineStyle: n.getModel(["lineStyle"]).getLineStyle(), blurLineStyle: e.getModel(["blur", "lineStyle"]).getLineStyle(), selectLineStyle: e.getModel(["select", "lineStyle"]).getLineStyle(), emphasisDisabled: n.get("disabled"), blurScope: n.get("blurScope"), focus: n.get("focus"), labelStatesModels: ec(e) } } function EA(t) { return isNaN(t[0]) || isNaN(t[1]) } function zA(t) { return t && !EA(t[0]) && !EA(t[1]) } var VA = [], BA = [], FA = [], GA = In, WA = Ft, HA = Math.abs; function YA(t, e, n) { for (var i, r = t[0], o = t[1], a = t[2], s = 1 / 0, l = n * n, u = .1, h = .1; h <= .9; h += .1) { VA[0] = GA(r[0], o[0], a[0], h), VA[1] = GA(r[1], o[1], a[1], h), (d = HA(WA(VA, e) - l)) < s && (s = d, i = h) } for (var c = 0; c < 32; c++) { var p = i + u; BA[0] = GA(r[0], o[0], a[0], i), BA[1] = GA(r[1], o[1], a[1], i), FA[0] = GA(r[0], o[0], a[0], p), FA[1] = GA(r[1], o[1], a[1], p); var d = WA(BA, e) - l; if (HA(d) < .01) break; var f = WA(FA, e) - l; u /= 2, d < 0 ? f >= 0 ? i += u : i -= u : f >= 0 ? i -= u : i += u } return i } function XA(t, e) { var n = [], i = Dn, r = [[], [], []], o = [[], []], a = []; e /= 2, t.eachEdge((function (t, s) { var l = t.getLayout(), u = t.getVisual("fromSymbol"), h = t.getVisual("toSymbol"); l.__original || (l.__original = [Tt(l[0]), Tt(l[1])], l[2] && l.__original.push(Tt(l[2]))); var c = l.__original; if (null != l[2]) { if (It(r[0], c[0]), It(r[1], c[2]), It(r[2], c[1]), u && "none" !== u) { var p = dA(t.node1), d = YA(r, c[0], p * e); i(r[0][0], r[1][0], r[2][0], d, n), r[0][0] = n[3], r[1][0] = n[4], i(r[0][1], r[1][1], r[2][1], d, n), r[0][1] = n[3], r[1][1] = n[4] } if (h && "none" !== h) { p = dA(t.node2), d = YA(r, c[1], p * e); i(r[0][0], r[1][0], r[2][0], d, n), r[1][0] = n[1], r[2][0] = n[2], i(r[0][1], r[1][1], r[2][1], d, n), r[1][1] = n[1], r[2][1] = n[2] } It(l[0], r[0]), It(l[1], r[2]), It(l[2], r[1]) } else { if (It(o[0], c[0]), It(o[1], c[1]), kt(a, o[1], o[0]), Et(a, a), u && "none" !== u) { p = dA(t.node1); At(o[0], o[0], a, p * e) } if (h && "none" !== h) { p = dA(t.node2); At(o[1], o[1], a, -p * e) } It(l[0], o[0]), It(l[1], o[1]) } })) } function UA(t) { return "view" === t.type } var ZA = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (t, e) { var n = new hS, i = new RA, r = this.group; this._controller = new UI(e.getZr()), this._controllerHost = { target: r }, r.add(n.group), r.add(i.group), this._symbolDraw = n, this._lineDraw = i, this._firstRender = !0 }, e.prototype.render = function (t, e, n) { var i = this, r = t.coordinateSystem; this._model = t; var o = this._symbolDraw, a = this._lineDraw, s = this.group; if (UA(r)) { var l = { x: r.x, y: r.y, scaleX: r.scaleX, scaleY: r.scaleY }; this._firstRender ? s.attr(l) : fh(s, l, t) } XA(t.getGraph(), pA(t)); var u = t.getData(); o.updateData(u); var h = t.getEdgeData(); a.updateData(h), this._updateNodeAndLinkScale(), this._updateController(t, e, n), clearTimeout(this._layoutTimeout); var c = t.forceLayout, p = t.get(["force", "layoutAnimation"]); c && this._startForceLayoutIteration(c, p); var d = t.get("layout"); u.graph.eachNode((function (e) { var n = e.dataIndex, r = e.getGraphicEl(), o = e.getModel(); if (r) { r.off("drag").off("dragend"); var a = o.get("draggable"); a && r.on("drag", (function (o) { switch (d) { case "force": c.warmUp(), !i._layouting && i._startForceLayoutIteration(c, p), c.setFixed(n), u.setItemLayout(n, [r.x, r.y]); break; case "circular": u.setItemLayout(n, [r.x, r.y]), e.setLayout({ fixed: !0 }, !0), yA(t, "symbolSize", e, [o.offsetX, o.offsetY]), i.updateLayout(t); break; default: u.setItemLayout(n, [r.x, r.y]), hA(t.getGraph(), t), i.updateLayout(t) } })).on("dragend", (function () { c && c.setUnfixed(n) })), r.setDraggable(a, !!o.get("cursor")), "adjacency" === o.get(["emphasis", "focus"]) && (Qs(r).focus = e.getAdjacentDataIndices()) } })), u.graph.eachEdge((function (t) { var e = t.getGraphicEl(), n = t.getModel().get(["emphasis", "focus"]); e && "adjacency" === n && (Qs(e).focus = { edge: [t.dataIndex], node: [t.node1.dataIndex, t.node2.dataIndex] }) })); var f = "circular" === t.get("layout") && t.get(["circular", "rotateLabel"]), g = u.getLayout("cx"), y = u.getLayout("cy"); u.graph.eachNode((function (t) { mA(t, f, g, y) })), this._firstRender = !1 }, e.prototype.dispose = function () { this._controller && this._controller.dispose(), this._controllerHost = null }, e.prototype._startForceLayoutIteration = function (t, e) { var n = this; !function i() { t.step((function (t) { n.updateLayout(n._model), (n._layouting = !t) && (e ? n._layoutTimeout = setTimeout(i, 16) : i()) })) }() }, e.prototype._updateController = function (t, e, n) { var i = this, r = this._controller, o = this._controllerHost, a = this.group; r.setPointerChecker((function (e, i, r) { var o = a.getBoundingRect(); return o.applyTransform(a.transform), o.contain(i, r) && !tT(e, n, t) })), UA(t.coordinateSystem) ? (r.enable(t.get("roam")), o.zoomLimit = t.get("scaleLimit"), o.zoom = t.coordinateSystem.getZoom(), r.off("pan").off("zoom").on("pan", (function (e) { KI(o, e.dx, e.dy), n.dispatchAction({ seriesId: t.id, type: "graphRoam", dx: e.dx, dy: e.dy }) })).on("zoom", (function (e) { $I(o, e.scale, e.originX, e.originY), n.dispatchAction({ seriesId: t.id, type: "graphRoam", zoom: e.scale, originX: e.originX, originY: e.originY }), i._updateNodeAndLinkScale(), XA(t.getGraph(), pA(t)), i._lineDraw.updateLayout(), n.updateLabelLayout() }))) : r.disable() }, e.prototype._updateNodeAndLinkScale = function () { var t = this._model, e = t.getData(), n = pA(t); e.eachItemGraphicEl((function (t, e) { t && t.setSymbolScale(n) })) }, e.prototype.updateLayout = function (t) { XA(t.getGraph(), pA(t)), this._symbolDraw.updateLayout(), this._lineDraw.updateLayout() }, e.prototype.remove = function (t, e) { this._symbolDraw && this._symbolDraw.remove(), this._lineDraw && this._lineDraw.remove() }, e.type = "graph", e }(kg); function jA(t) { return "_EC_" + t } var qA = function () { function t(t) { this.type = "graph", this.nodes = [], this.edges = [], this._nodesMap = {}, this._edgesMap = {}, this._directed = t || !1 } return t.prototype.isDirected = function () { return this._directed }, t.prototype.addNode = function (t, e) { t = null == t ? "" + e : "" + t; var n = this._nodesMap; if (!n[jA(t)]) { var i = new KA(t, e); return i.hostGraph = this, this.nodes.push(i), n[jA(t)] = i, i } }, t.prototype.getNodeByIndex = function (t) { var e = this.data.getRawIndex(t); return this.nodes[e] }, t.prototype.getNodeById = function (t) { return this._nodesMap[jA(t)] }, t.prototype.addEdge = function (t, e, n) { var i = this._nodesMap, r = this._edgesMap; if (j(t) && (t = this.nodes[t]), j(e) && (e = this.nodes[e]), t instanceof KA || (t = i[jA(t)]), e instanceof KA || (e = i[jA(e)]), t && e) { var o = t.id + "-" + e.id, a = new $A(t, e, n); return a.hostGraph = this, this._directed && (t.outEdges.push(a), e.inEdges.push(a)), t.edges.push(a), t !== e && e.edges.push(a), this.edges.push(a), r[o] = a, a } }, t.prototype.getEdgeByIndex = function (t) { var e = this.edgeData.getRawIndex(t); return this.edges[e] }, t.prototype.getEdge = function (t, e) { t instanceof KA && (t = t.id), e instanceof KA && (e = e.id); var n = this._edgesMap; return this._directed ? n[t + "-" + e] : n[t + "-" + e] || n[e + "-" + t] }, t.prototype.eachNode = function (t, e) { for (var n = this.nodes, i = n.length, r = 0; r < i; r++)n[r].dataIndex >= 0 && t.call(e, n[r], r) }, t.prototype.eachEdge = function (t, e) { for (var n = this.edges, i = n.length, r = 0; r < i; r++)n[r].dataIndex >= 0 && n[r].node1.dataIndex >= 0 && n[r].node2.dataIndex >= 0 && t.call(e, n[r], r) }, t.prototype.breadthFirstTraverse = function (t, e, n, i) { if (e instanceof KA || (e = this._nodesMap[jA(e)]), e) { for (var r = "out" === n ? "outEdges" : "in" === n ? "inEdges" : "edges", o = 0; o < this.nodes.length; o++)this.nodes[o].__visited = !1; if (!t.call(i, e, null)) for (var a = [e]; a.length;) { var s = a.shift(), l = s[r]; for (o = 0; o < l.length; o++) { var u = l[o], h = u.node1 === s ? u.node2 : u.node1; if (!h.__visited) { if (t.call(i, h, s)) return; a.push(h), h.__visited = !0 } } } } }, t.prototype.update = function () { for (var t = this.data, e = this.edgeData, n = this.nodes, i = this.edges, r = 0, o = n.length; r < o; r++)n[r].dataIndex = -1; for (r = 0, o = t.count(); r < o; r++)n[t.getRawIndex(r)].dataIndex = r; e.filterSelf((function (t) { var n = i[e.getRawIndex(t)]; return n.node1.dataIndex >= 0 && n.node2.dataIndex >= 0 })); for (r = 0, o = i.length; r < o; r++)i[r].dataIndex = -1; for (r = 0, o = e.count(); r < o; r++)i[e.getRawIndex(r)].dataIndex = r }, t.prototype.clone = function () { for (var e = new t(this._directed), n = this.nodes, i = this.edges, r = 0; r < n.length; r++)e.addNode(n[r].id, n[r].dataIndex); for (r = 0; r < i.length; r++) { var o = i[r]; e.addEdge(o.node1.id, o.node2.id, o.dataIndex) } return e }, t }(), KA = function () { function t(t, e) { this.inEdges = [], this.outEdges = [], this.edges = [], this.dataIndex = -1, this.id = null == t ? "" : t, this.dataIndex = null == e ? -1 : e } return t.prototype.degree = function () { return this.edges.length }, t.prototype.inDegree = function () { return this.inEdges.length }, t.prototype.outDegree = function () { return this.outEdges.length }, t.prototype.getModel = function (t) { if (!(this.dataIndex < 0)) return this.hostGraph.data.getItemModel(this.dataIndex).getModel(t) }, t.prototype.getAdjacentDataIndices = function () { for (var t = { edge: [], node: [] }, e = 0; e < this.edges.length; e++) { var n = this.edges[e]; n.dataIndex < 0 || (t.edge.push(n.dataIndex), t.node.push(n.node1.dataIndex, n.node2.dataIndex)) } return t }, t.prototype.getTrajectoryDataIndices = function () { for (var t = yt(), e = yt(), n = 0; n < this.edges.length; n++) { var i = this.edges[n]; if (!(i.dataIndex < 0)) { t.set(i.dataIndex, !0); for (var r = [i.node1], o = [i.node2], a = 0; a < r.length;) { var s = r[a]; a++, e.set(s.dataIndex, !0); for (var l = 0; l < s.inEdges.length; l++)t.set(s.inEdges[l].dataIndex, !0), r.push(s.inEdges[l].node1) } for (a = 0; a < o.length;) { var u = o[a]; a++, e.set(u.dataIndex, !0); for (l = 0; l < u.outEdges.length; l++)t.set(u.outEdges[l].dataIndex, !0), o.push(u.outEdges[l].node2) } } } return { edge: t.keys(), node: e.keys() } }, t }(), $A = function () { function t(t, e, n) { this.dataIndex = -1, this.node1 = t, this.node2 = e, this.dataIndex = null == n ? -1 : n } return t.prototype.getModel = function (t) { if (!(this.dataIndex < 0)) return this.hostGraph.edgeData.getItemModel(this.dataIndex).getModel(t) }, t.prototype.getAdjacentDataIndices = function () { return { edge: [this.dataIndex], node: [this.node1.dataIndex, this.node2.dataIndex] } }, t.prototype.getTrajectoryDataIndices = function () { var t = yt(), e = yt(); t.set(this.dataIndex, !0); for (var n = [this.node1], i = [this.node2], r = 0; r < n.length;) { var o = n[r]; r++, e.set(o.dataIndex, !0); for (var a = 0; a < o.inEdges.length; a++)t.set(o.inEdges[a].dataIndex, !0), n.push(o.inEdges[a].node1) } for (r = 0; r < i.length;) { var s = i[r]; r++, e.set(s.dataIndex, !0); for (a = 0; a < s.outEdges.length; a++)t.set(s.outEdges[a].dataIndex, !0), i.push(s.outEdges[a].node2) } return { edge: t.keys(), node: e.keys() } }, t }(); function JA(t, e) { return { getValue: function (n) { var i = this[t][e]; return i.getStore().get(i.getDimensionIndex(n || "value"), this.dataIndex) }, setVisual: function (n, i) { this.dataIndex >= 0 && this[t][e].setItemVisual(this.dataIndex, n, i) }, getVisual: function (n) { return this[t][e].getItemVisual(this.dataIndex, n) }, setLayout: function (n, i) { this.dataIndex >= 0 && this[t][e].setItemLayout(this.dataIndex, n, i) }, getLayout: function () { return this[t][e].getItemLayout(this.dataIndex) }, getGraphicEl: function () { return this[t][e].getItemGraphicEl(this.dataIndex) }, getRawIndex: function () { return this[t][e].getRawIndex(this.dataIndex) } } } function QA(t, e, n, i, r) { for (var o = new qA(i), a = 0; a < t.length; a++)o.addNode(it(t[a].id, t[a].name, a), a); var s = [], l = [], u = 0; for (a = 0; a < e.length; a++) { var h = e[a], c = h.source, p = h.target; o.addEdge(c, p, u) && (l.push(h), s.push(it(Ao(h.id, null), c + " > " + p)), u++) } var d, f = n.get("coordinateSystem"); if ("cartesian2d" === f || "polar" === f) d = vx(t, n); else { var g = xd.get(f), y = g && g.dimensions || []; P(y, "value") < 0 && y.concat(["value"]); var v = ux(t, { coordDimensions: y, encodeDefine: n.getEncode() }).dimensions; (d = new lx(v, n)).initData(t) } var m = new lx(["value"], n); return m.initData(l, s), r && r(d, m), zC({ mainData: d, struct: o, structAttr: "graph", datas: { node: d, edge: m }, datasAttr: { node: "data", edge: "edgeData" } }), o.update(), o } R(KA, JA("hostGraph", "data")), R($A, JA("hostGraph", "edgeData")); var tk = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.hasSymbolVisual = !0, n } return n(e, t), e.prototype.init = function (e) { t.prototype.init.apply(this, arguments); var n = this; function i() { return n._categoriesData } this.legendVisualProvider = new IM(i, i), this.fillDataTextStyle(e.edges || e.links), this._updateCategoriesData() }, e.prototype.mergeOption = function (e) { t.prototype.mergeOption.apply(this, arguments), this.fillDataTextStyle(e.edges || e.links), this._updateCategoriesData() }, e.prototype.mergeDefaultAndTheme = function (e) { t.prototype.mergeDefaultAndTheme.apply(this, arguments), wo(e, "edgeLabel", ["show"]) }, e.prototype.getInitialData = function (t, e) { var n, i = t.edges || t.links || [], r = t.data || t.nodes || [], o = this; if (r && i) { iA(n = this) && (n.__curvenessList = [], n.__edgeMap = {}, rA(n)); var a = QA(r, i, this, !0, (function (t, e) { t.wrapMethod("getItemModel", (function (t) { var e = o._categoriesModels[t.getShallow("category")]; return e && (e.parentModel = t.parentModel, t.parentModel = e), t })); var n = Mc.prototype.getModel; function i(t, e) { var i = n.call(this, t, e); return i.resolveParentPath = r, i } function r(t) { if (t && ("label" === t[0] || "label" === t[1])) { var e = t.slice(); return "label" === t[0] ? e[0] = "edgeLabel" : "label" === t[1] && (e[1] = "edgeLabel"), e } return t } e.wrapMethod("getItemModel", (function (t) { return t.resolveParentPath = r, t.getModel = i, t })) })); return E(a.edges, (function (t) { !function (t, e, n, i) { if (iA(n)) { var r = oA(t, e, n), o = n.__edgeMap, a = o[aA(r)]; o[r] && !a ? o[r].isForward = !0 : a && o[r] && (a.isForward = !0, o[r].isForward = !1), o[r] = o[r] || [], o[r].push(i) } }(t.node1, t.node2, this, t.dataIndex) }), this), a.data } }, e.prototype.getGraph = function () { return this.getData().graph }, e.prototype.getEdgeData = function () { return this.getGraph().edgeData }, e.prototype.getCategoriesData = function () { return this._categoriesData }, e.prototype.formatTooltip = function (t, e, n) { if ("edge" === n) { var i = this.getData(), r = this.getDataParams(t, n), o = i.graph.getEdgeByIndex(t), a = i.getName(o.node1.dataIndex), s = i.getName(o.node2.dataIndex), l = []; return null != a && l.push(a), null != s && l.push(s), ng("nameValue", { name: l.join(" > "), value: r.value, noValue: null == r.value }) } return fg({ series: this, dataIndex: t, multipleSeries: e }) }, e.prototype._updateCategoriesData = function () { var t = z(this.option.categories || [], (function (t) { return null != t.value ? t : A({ value: 0 }, t) })), e = new lx(["value"], this); e.initData(t), this._categoriesData = e, this._categoriesModels = e.mapArray((function (t) { return e.getItemModel(t) })) }, e.prototype.setZoom = function (t) { this.option.zoom = t }, e.prototype.setCenter = function (t) { this.option.center = t }, e.prototype.isAnimationEnabled = function () { return t.prototype.isAnimationEnabled.call(this) && !("force" === this.get("layout") && this.get(["force", "layoutAnimation"])) }, e.type = "series.graph", e.dependencies = ["grid", "polar", "geo", "singleAxis", "calendar"], e.defaultOption = { z: 2, coordinateSystem: "view", legendHoverLink: !0, layout: null, circular: { rotateLabel: !1 }, force: { initLayout: null, repulsion: [0, 50], gravity: .1, friction: .6, edgeLength: 30, layoutAnimation: !0 }, left: "center", top: "center", symbol: "circle", symbolSize: 10, edgeSymbol: ["none", "none"], edgeSymbolSize: 10, edgeLabel: { position: "middle", distance: 5 }, draggable: !1, roam: !1, center: null, zoom: 1, nodeScaleRatio: .6, label: { show: !1, formatter: "{b}" }, itemStyle: {}, lineStyle: { color: "#aaa", width: 1, opacity: .5 }, emphasis: { scale: !0, label: { show: !0 } }, select: { itemStyle: { borderColor: "#212121" } } }, e }(mg), ek = { type: "graphRoam", event: "graphRoam", update: "none" }; var nk = function () { this.angle = 0, this.width = 10, this.r = 10, this.x = 0, this.y = 0 }, ik = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "pointer", n } return n(e, t), e.prototype.getDefaultShape = function () { return new nk }, e.prototype.buildPath = function (t, e) { var n = Math.cos, i = Math.sin, r = e.r, o = e.width, a = e.angle, s = e.x - n(a) * o * (o >= r / 3 ? 1 : 2), l = e.y - i(a) * o * (o >= r / 3 ? 1 : 2); a = e.angle - Math.PI / 2, t.moveTo(s, l), t.lineTo(e.x + n(a) * o, e.y + i(a) * o), t.lineTo(e.x + n(e.angle) * r, e.y + i(e.angle) * r), t.lineTo(e.x - n(a) * o, e.y - i(a) * o), t.lineTo(s, l) }, e }(Is); function rk(t, e) { var n = null == t ? "" : t + ""; return e && (U(e) ? n = e.replace("{value}", n) : X(e) && (n = e(t))), n } var ok = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { this.group.removeAll(); var i = t.get(["axisLine", "lineStyle", "color"]), r = function (t, e) { var n = t.get("center"), i = e.getWidth(), r = e.getHeight(), o = Math.min(i, r); return { cx: Ur(n[0], e.getWidth()), cy: Ur(n[1], e.getHeight()), r: Ur(t.get("radius"), o / 2) } }(t, n); this._renderMain(t, e, n, i, r), this._data = t.getData() }, e.prototype.dispose = function () { }, e.prototype._renderMain = function (t, e, n, i, r) { var o = this.group, a = t.get("clockwise"), s = -t.get("startAngle") / 180 * Math.PI, l = -t.get("endAngle") / 180 * Math.PI, u = t.getModel("axisLine"), h = u.get("roundCap") ? HS : zu, c = u.get("show"), p = u.getModel("lineStyle"), d = p.get("width"), f = [s, l]; rs(f, !a); for (var g = (l = f[1]) - (s = f[0]), y = s, v = [], m = 0; c && m < i.length; m++) { var x = new h({ shape: { startAngle: y, endAngle: l = s + g * Math.min(Math.max(i[m][0], 0), 1), cx: r.cx, cy: r.cy, clockwise: a, r0: r.r - d, r: r.r }, silent: !0 }); x.setStyle({ fill: i[m][1] }), x.setStyle(p.getLineStyle(["color", "width"])), v.push(x), y = l } v.reverse(), E(v, (function (t) { return o.add(t) })); var _ = function (t) { if (t <= 0) return i[0][1]; var e; for (e = 0; e < i.length; e++)if (i[e][0] >= t && (0 === e ? 0 : i[e - 1][0]) < t) return i[e][1]; return i[e - 1][1] }; this._renderTicks(t, e, n, _, r, s, l, a, d), this._renderTitleAndDetail(t, e, n, _, r), this._renderAnchor(t, r), this._renderPointer(t, e, n, _, r, s, l, a, d) }, e.prototype._renderTicks = function (t, e, n, i, r, o, a, s, l) { for (var u, h, c = this.group, p = r.cx, d = r.cy, f = r.r, g = +t.get("min"), y = +t.get("max"), v = t.getModel("splitLine"), m = t.getModel("axisTick"), x = t.getModel("axisLabel"), _ = t.get("splitNumber"), b = m.get("splitNumber"), w = Ur(v.get("length"), f), S = Ur(m.get("length"), f), M = o, I = (a - o) / _, T = I / b, C = v.getModel("lineStyle").getLineStyle(), D = m.getModel("lineStyle").getLineStyle(), A = v.get("distance"), k = 0; k <= _; k++) { if (u = Math.cos(M), h = Math.sin(M), v.get("show")) { var L = new Zu({ shape: { x1: u * (f - (P = A ? A + l : l)) + p, y1: h * (f - P) + d, x2: u * (f - w - P) + p, y2: h * (f - w - P) + d }, style: C, silent: !0 }); "auto" === C.stroke && L.setStyle({ stroke: i(k / _) }), c.add(L) } if (x.get("show")) { var P = x.get("distance") + A, O = rk(Zr(k / _ * (y - g) + g), x.get("formatter")), R = i(k / _), N = u * (f - w - P) + p, E = h * (f - w - P) + d, z = x.get("rotate"), V = 0; "radial" === z ? (V = -M + 2 * Math.PI) > Math.PI / 2 && (V += Math.PI) : "tangential" === z ? V = -M - Math.PI / 2 : j(z) && (V = z * Math.PI / 180), 0 === V ? c.add(new Fs({ style: nc(x, { text: O, x: N, y: E, verticalAlign: h < -.8 ? "top" : h > .8 ? "bottom" : "middle", align: u < -.4 ? "left" : u > .4 ? "right" : "center" }, { inheritColor: R }), silent: !0 })) : c.add(new Fs({ style: nc(x, { text: O, x: N, y: E, verticalAlign: "middle", align: "center" }, { inheritColor: R }), silent: !0, originX: N, originY: E, rotation: V })) } if (m.get("show") && k !== _) { P = (P = m.get("distance")) ? P + l : l; for (var B = 0; B <= b; B++) { u = Math.cos(M), h = Math.sin(M); var F = new Zu({ shape: { x1: u * (f - P) + p, y1: h * (f - P) + d, x2: u * (f - S - P) + p, y2: h * (f - S - P) + d }, silent: !0, style: D }); "auto" === D.stroke && F.setStyle({ stroke: i((k + B / b) / _) }), c.add(F), M += T } M -= T } else M += I } }, e.prototype._renderPointer = function (t, e, n, i, r, o, a, s, l) { var u = this.group, h = this._data, c = this._progressEls, p = [], d = t.get(["pointer", "show"]), f = t.getModel("progress"), g = f.get("show"), y = t.getData(), v = y.mapDimension("value"), m = +t.get("min"), x = +t.get("max"), _ = [m, x], b = [o, a]; function w(e, n) { var i, o = y.getItemModel(e).getModel("pointer"), a = Ur(o.get("width"), r.r), s = Ur(o.get("length"), r.r), l = t.get(["pointer", "icon"]), u = o.get("offsetCenter"), h = Ur(u[0], r.r), c = Ur(u[1], r.r), p = o.get("keepAspect"); return (i = l ? Wy(l, h - a / 2, c - s, a, s, null, p) : new ik({ shape: { angle: -Math.PI / 2, width: a, r: s, x: h, y: c } })).rotation = -(n + Math.PI / 2), i.x = r.cx, i.y = r.cy, i } function S(t, e) { var n = f.get("roundCap") ? HS : zu, i = f.get("overlap"), a = i ? f.get("width") : l / y.count(), u = i ? r.r - a : r.r - (t + 1) * a, h = i ? r.r : r.r - t * a, c = new n({ shape: { startAngle: o, endAngle: e, cx: r.cx, cy: r.cy, clockwise: s, r0: u, r: h } }); return i && (c.z2 = x - y.get(v, t) % x), c } (g || d) && (y.diff(h).add((function (e) { var n = y.get(v, e); if (d) { var i = w(e, o); gh(i, { rotation: -((isNaN(+n) ? b[0] : Xr(n, _, b, !0)) + Math.PI / 2) }, t), u.add(i), y.setItemGraphicEl(e, i) } if (g) { var r = S(e, o), a = f.get("clip"); gh(r, { shape: { endAngle: Xr(n, _, b, a) } }, t), u.add(r), tl(t.seriesIndex, y.dataType, e, r), p[e] = r } })).update((function (e, n) { var i = y.get(v, e); if (d) { var r = h.getItemGraphicEl(n), a = r ? r.rotation : o, s = w(e, a); s.rotation = a, fh(s, { rotation: -((isNaN(+i) ? b[0] : Xr(i, _, b, !0)) + Math.PI / 2) }, t), u.add(s), y.setItemGraphicEl(e, s) } if (g) { var l = c[n], m = S(e, l ? l.shape.endAngle : o), x = f.get("clip"); fh(m, { shape: { endAngle: Xr(i, _, b, x) } }, t), u.add(m), tl(t.seriesIndex, y.dataType, e, m), p[e] = m } })).execute(), y.each((function (t) { var e = y.getItemModel(t), n = e.getModel("emphasis"), r = n.get("focus"), o = n.get("blurScope"), a = n.get("disabled"); if (d) { var s = y.getItemGraphicEl(t), l = y.getItemVisual(t, "style"), u = l.fill; if (s instanceof ks) { var h = s.style; s.useStyle(A({ image: h.image, x: h.x, y: h.y, width: h.width, height: h.height }, l)) } else s.useStyle(l), "pointer" !== s.type && s.setColor(u); s.setStyle(e.getModel(["pointer", "itemStyle"]).getItemStyle()), "auto" === s.style.fill && s.setStyle("fill", i(Xr(y.get(v, t), _, [0, 1], !0))), s.z2EmphasisLift = 0, jl(s, e), Yl(s, r, o, a) } if (g) { var c = p[t]; c.useStyle(y.getItemVisual(t, "style")), c.setStyle(e.getModel(["progress", "itemStyle"]).getItemStyle()), c.z2EmphasisLift = 0, jl(c, e), Yl(c, r, o, a) } })), this._progressEls = p) }, e.prototype._renderAnchor = function (t, e) { var n = t.getModel("anchor"); if (n.get("show")) { var i = n.get("size"), r = n.get("icon"), o = n.get("offsetCenter"), a = n.get("keepAspect"), s = Wy(r, e.cx - i / 2 + Ur(o[0], e.r), e.cy - i / 2 + Ur(o[1], e.r), i, i, null, a); s.z2 = n.get("showAbove") ? 1 : 0, s.setStyle(n.getModel("itemStyle").getItemStyle()), this.group.add(s) } }, e.prototype._renderTitleAndDetail = function (t, e, n, i, r) { var o = this, a = t.getData(), s = a.mapDimension("value"), l = +t.get("min"), u = +t.get("max"), h = new zr, c = [], p = [], d = t.isAnimationEnabled(), f = t.get(["pointer", "showAbove"]); a.diff(this._data).add((function (t) { c[t] = new Fs({ silent: !0 }), p[t] = new Fs({ silent: !0 }) })).update((function (t, e) { c[t] = o._titleEls[e], p[t] = o._detailEls[e] })).execute(), a.each((function (e) { var n = a.getItemModel(e), o = a.get(s, e), g = new zr, y = i(Xr(o, [l, u], [0, 1], !0)), v = n.getModel("title"); if (v.get("show")) { var m = v.get("offsetCenter"), x = r.cx + Ur(m[0], r.r), _ = r.cy + Ur(m[1], r.r); (D = c[e]).attr({ z2: f ? 0 : 2, style: nc(v, { x: x, y: _, text: a.getName(e), align: "center", verticalAlign: "middle" }, { inheritColor: y }) }), g.add(D) } var b = n.getModel("detail"); if (b.get("show")) { var w = b.get("offsetCenter"), S = r.cx + Ur(w[0], r.r), M = r.cy + Ur(w[1], r.r), I = Ur(b.get("width"), r.r), T = Ur(b.get("height"), r.r), C = t.get(["progress", "show"]) ? a.getItemVisual(e, "style").fill : y, D = p[e], A = b.get("formatter"); D.attr({ z2: f ? 0 : 2, style: nc(b, { x: S, y: M, text: rk(o, A), width: isNaN(I) ? null : I, height: isNaN(T) ? null : T, align: "center", verticalAlign: "middle" }, { inheritColor: C }) }), hc(D, { normal: b }, o, (function (t) { return rk(t, A) })), d && cc(D, e, a, t, { getFormattedLabel: function (t, e, n, i, r, a) { return rk(a ? a.interpolatedValue : o, A) } }), g.add(D) } h.add(g) })), this.group.add(h), this._titleEls = c, this._detailEls = p }, e.type = "gauge", e }(kg), ak = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.visualStyleAccessPath = "itemStyle", n } return n(e, t), e.prototype.getInitialData = function (t, e) { return MM(this, ["value"]) }, e.type = "series.gauge", e.defaultOption = { z: 2, colorBy: "data", center: ["50%", "50%"], legendHoverLink: !0, radius: "75%", startAngle: 225, endAngle: -45, clockwise: !0, min: 0, max: 100, splitNumber: 10, axisLine: { show: !0, roundCap: !1, lineStyle: { color: [[1, "#E6EBF8"]], width: 10 } }, progress: { show: !1, overlap: !0, width: 10, roundCap: !1, clip: !0 }, splitLine: { show: !0, length: 10, distance: 10, lineStyle: { color: "#63677A", width: 3, type: "solid" } }, axisTick: { show: !0, splitNumber: 5, length: 6, distance: 10, lineStyle: { color: "#63677A", width: 1, type: "solid" } }, axisLabel: { show: !0, distance: 15, color: "#464646", fontSize: 12, rotate: 0 }, pointer: { icon: null, offsetCenter: [0, 0], show: !0, showAbove: !0, length: "60%", width: 6, keepAspect: !1 }, anchor: { show: !1, showAbove: !1, size: 6, icon: "circle", offsetCenter: [0, 0], keepAspect: !1, itemStyle: { color: "#fff", borderWidth: 0, borderColor: "#5470c6" } }, title: { show: !0, offsetCenter: [0, "20%"], color: "#464646", fontSize: 16, valueAnimation: !1 }, detail: { show: !0, backgroundColor: "rgba(0,0,0,0)", borderWidth: 0, borderColor: "#ccc", width: 100, height: null, padding: [5, 10], offsetCenter: [0, "40%"], color: "#464646", fontSize: 30, fontWeight: "bold", lineHeight: 30, valueAnimation: !1 } }, e }(mg); var sk = ["itemStyle", "opacity"], lk = function (t) { function e(e, n) { var i = t.call(this) || this, r = i, o = new Yu, a = new Fs; return r.setTextContent(a), i.setTextGuideLine(o), i.updateData(e, n, !0), i } return n(e, t), e.prototype.updateData = function (t, e, n) { var i = this, r = t.hostModel, o = t.getItemModel(e), a = t.getItemLayout(e), s = o.getModel("emphasis"), l = o.get(sk); l = null == l ? 1 : l, n || _h(i), i.useStyle(t.getItemVisual(e, "style")), i.style.lineJoin = "round", n ? (i.setShape({ points: a.points }), i.style.opacity = 0, gh(i, { style: { opacity: l } }, r, e)) : fh(i, { style: { opacity: l }, shape: { points: a.points } }, r, e), jl(i, o), this._updateLabel(t, e), Yl(this, s.get("focus"), s.get("blurScope"), s.get("disabled")) }, e.prototype._updateLabel = function (t, e) { var n = this, i = this.getTextGuideLine(), r = n.getTextContent(), o = t.hostModel, a = t.getItemModel(e), s = t.getItemLayout(e).label, l = t.getItemVisual(e, "style"), u = l.fill; tc(r, ec(a), { labelFetcher: t.hostModel, labelDataIndex: e, defaultOpacity: l.opacity, defaultText: t.getName(e) }, { normal: { align: s.textAlign, verticalAlign: s.verticalAlign } }), n.setTextConfig({ local: !0, inside: !!s.inside, insideStroke: u, outsideFill: u }); var h = s.linePoints; i.setShape({ points: h }), n.textGuideLineConfig = { anchor: h ? new De(h[0][0], h[0][1]) : null }, fh(r, { style: { x: s.x, y: s.y } }, o, e), r.attr({ rotation: s.rotation, originX: s.x, originY: s.y, z2: 10 }), Tb(n, Cb(a), { stroke: u }) }, e }(Wu), uk = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.ignoreLabelLineUpdate = !0, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = t.getData(), r = this._data, o = this.group; i.diff(r).add((function (t) { var e = new lk(i, t); i.setItemGraphicEl(t, e), o.add(e) })).update((function (t, e) { var n = r.getItemGraphicEl(e); n.updateData(i, t), o.add(n), i.setItemGraphicEl(t, n) })).remove((function (e) { xh(r.getItemGraphicEl(e), t, e) })).execute(), this._data = i }, e.prototype.remove = function () { this.group.removeAll(), this._data = null }, e.prototype.dispose = function () { }, e.type = "funnel", e }(kg), hk = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), this.legendVisualProvider = new IM(W(this.getData, this), W(this.getRawData, this)), this._defaultLabelLine(e) }, e.prototype.getInitialData = function (t, e) { return MM(this, { coordDimensions: ["value"], encodeDefaulter: H(Jp, this) }) }, e.prototype._defaultLabelLine = function (t) { wo(t, "labelLine", ["show"]); var e = t.labelLine, n = t.emphasis.labelLine; e.show = e.show && t.label.show, n.show = n.show && t.emphasis.label.show }, e.prototype.getDataParams = function (e) { var n = this.getData(), i = t.prototype.getDataParams.call(this, e), r = n.mapDimension("value"), o = n.getSum(r); return i.percent = o ? +(n.get(r, e) / o * 100).toFixed(2) : 0, i.$vars.push("percent"), i }, e.type = "series.funnel", e.defaultOption = { z: 2, legendHoverLink: !0, colorBy: "data", left: 80, top: 60, right: 80, bottom: 60, minSize: "0%", maxSize: "100%", sort: "descending", orient: "vertical", gap: 0, funnelAlign: "center", label: { show: !0, position: "outer" }, labelLine: { show: !0, length: 20, lineStyle: { width: 1 } }, itemStyle: { borderColor: "#fff", borderWidth: 1 }, emphasis: { label: { show: !0 } }, select: { itemStyle: { borderColor: "#212121" } } }, e }(mg); function ck(t, e) { t.eachSeriesByType("funnel", (function (t) { var n = t.getData(), i = n.mapDimension("value"), r = t.get("sort"), o = function (t, e) { return Cp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }) }(t, e), a = t.get("orient"), s = o.width, l = o.height, u = function (t, e) { for (var n = t.mapDimension("value"), i = t.mapArray(n, (function (t) { return t })), r = [], o = "ascending" === e, a = 0, s = t.count(); a < s; a++)r[a] = a; return X(e) ? r.sort(e) : "none" !== e && r.sort((function (t, e) { return o ? i[t] - i[e] : i[e] - i[t] })), r }(n, r), h = o.x, c = o.y, p = "horizontal" === a ? [Ur(t.get("minSize"), l), Ur(t.get("maxSize"), l)] : [Ur(t.get("minSize"), s), Ur(t.get("maxSize"), s)], d = n.getDataExtent(i), f = t.get("min"), g = t.get("max"); null == f && (f = Math.min(d[0], 0)), null == g && (g = d[1]); var y = t.get("funnelAlign"), v = t.get("gap"), m = (("horizontal" === a ? s : l) - v * (n.count() - 1)) / n.count(), x = function (t, e) { if ("horizontal" === a) { var r = Xr(n.get(i, t) || 0, [f, g], p, !0), o = void 0; switch (y) { case "top": o = c; break; case "center": o = c + (l - r) / 2; break; case "bottom": o = c + (l - r) }return [[e, o], [e, o + r]] } var u, d = Xr(n.get(i, t) || 0, [f, g], p, !0); switch (y) { case "left": u = h; break; case "center": u = h + (s - d) / 2; break; case "right": u = h + s - d }return [[u, e], [u + d, e]] }; "ascending" === r && (m = -m, v = -v, "horizontal" === a ? h += s : c += l, u = u.reverse()); for (var _ = 0; _ < u.length; _++) { var b = u[_], w = u[_ + 1], S = n.getItemModel(b); if ("horizontal" === a) { var M = S.get(["itemStyle", "width"]); null == M ? M = m : (M = Ur(M, s), "ascending" === r && (M = -M)); var I = x(b, h), T = x(w, h + M); h += M + v, n.setItemLayout(b, { points: I.concat(T.slice().reverse()) }) } else { var C = S.get(["itemStyle", "height"]); null == C ? C = m : (C = Ur(C, l), "ascending" === r && (C = -C)); I = x(b, c), T = x(w, c + C); c += C + v, n.setItemLayout(b, { points: I.concat(T.slice().reverse()) }) } } !function (t) { var e = t.hostModel.get("orient"); t.each((function (n) { var i, r, o, a, s = t.getItemModel(n), l = s.getModel("label").get("position"), u = s.getModel("labelLine"), h = t.getItemLayout(n), c = h.points, p = "inner" === l || "inside" === l || "center" === l || "insideLeft" === l || "insideRight" === l; if (p) "insideLeft" === l ? (r = (c[0][0] + c[3][0]) / 2 + 5, o = (c[0][1] + c[3][1]) / 2, i = "left") : "insideRight" === l ? (r = (c[1][0] + c[2][0]) / 2 - 5, o = (c[1][1] + c[2][1]) / 2, i = "right") : (r = (c[0][0] + c[1][0] + c[2][0] + c[3][0]) / 4, o = (c[0][1] + c[1][1] + c[2][1] + c[3][1]) / 4, i = "center"), a = [[r, o], [r, o]]; else { var d = void 0, f = void 0, g = void 0, y = void 0, v = u.get("length"); "left" === l ? (d = (c[3][0] + c[0][0]) / 2, f = (c[3][1] + c[0][1]) / 2, r = (g = d - v) - 5, i = "right") : "right" === l ? (d = (c[1][0] + c[2][0]) / 2, f = (c[1][1] + c[2][1]) / 2, r = (g = d + v) + 5, i = "left") : "top" === l ? (d = (c[3][0] + c[0][0]) / 2, o = (y = (f = (c[3][1] + c[0][1]) / 2) - v) - 5, i = "center") : "bottom" === l ? (d = (c[1][0] + c[2][0]) / 2, o = (y = (f = (c[1][1] + c[2][1]) / 2) + v) + 5, i = "center") : "rightTop" === l ? (d = "horizontal" === e ? c[3][0] : c[1][0], f = "horizontal" === e ? c[3][1] : c[1][1], "horizontal" === e ? (o = (y = f - v) - 5, i = "center") : (r = (g = d + v) + 5, i = "top")) : "rightBottom" === l ? (d = c[2][0], f = c[2][1], "horizontal" === e ? (o = (y = f + v) + 5, i = "center") : (r = (g = d + v) + 5, i = "bottom")) : "leftTop" === l ? (d = c[0][0], f = "horizontal" === e ? c[0][1] : c[1][1], "horizontal" === e ? (o = (y = f - v) - 5, i = "center") : (r = (g = d - v) - 5, i = "right")) : "leftBottom" === l ? (d = "horizontal" === e ? c[1][0] : c[3][0], f = "horizontal" === e ? c[1][1] : c[2][1], "horizontal" === e ? (o = (y = f + v) + 5, i = "center") : (r = (g = d - v) - 5, i = "right")) : (d = (c[1][0] + c[2][0]) / 2, f = (c[1][1] + c[2][1]) / 2, "horizontal" === e ? (o = (y = f + v) + 5, i = "center") : (r = (g = d + v) + 5, i = "left")), "horizontal" === e ? r = g = d : o = y = f, a = [[d, f], [g, y]] } h.label = { linePoints: a, x: r, y: o, verticalAlign: "middle", textAlign: i, inside: p } })) }(n) })) } var pk = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._dataGroup = new zr, n._initialized = !1, n } return n(e, t), e.prototype.init = function () { this.group.add(this._dataGroup) }, e.prototype.render = function (t, e, n, i) { this._progressiveEls = null; var r = this._dataGroup, o = t.getData(), a = this._data, s = t.coordinateSystem, l = s.dimensions, u = gk(t); if (o.diff(a).add((function (t) { yk(fk(o, r, t, l, s), o, t, u) })).update((function (e, n) { var i = a.getItemGraphicEl(n), r = dk(o, e, l, s); o.setItemGraphicEl(e, i), fh(i, { shape: { points: r } }, t, e), _h(i), yk(i, o, e, u) })).remove((function (t) { var e = a.getItemGraphicEl(t); r.remove(e) })).execute(), !this._initialized) { this._initialized = !0; var h = function (t, e, n) { var i = t.model, r = t.getRect(), o = new zs({ shape: { x: r.x, y: r.y, width: r.width, height: r.height } }), a = "horizontal" === i.get("layout") ? "width" : "height"; return o.setShape(a, 0), gh(o, { shape: { width: r.width, height: r.height } }, e, n), o }(s, t, (function () { setTimeout((function () { r.removeClipPath() })) })); r.setClipPath(h) } this._data = o }, e.prototype.incrementalPrepareRender = function (t, e, n) { this._initialized = !0, this._data = null, this._dataGroup.removeAll() }, e.prototype.incrementalRender = function (t, e, n) { for (var i = e.getData(), r = e.coordinateSystem, o = r.dimensions, a = gk(e), s = this._progressiveEls = [], l = t.start; l < t.end; l++) { var u = fk(i, this._dataGroup, l, o, r); u.incremental = !0, yk(u, i, l, a), s.push(u) } }, e.prototype.remove = function () { this._dataGroup && this._dataGroup.removeAll(), this._data = null }, e.type = "parallel", e }(kg); function dk(t, e, n, i) { for (var r, o = [], a = 0; a < n.length; a++) { var s = n[a], l = t.get(t.mapDimension(s), e); r = l, ("category" === i.getAxis(s).type ? null == r : null == r || isNaN(r)) || o.push(i.dataToPoint(l, s)) } return o } function fk(t, e, n, i, r) { var o = dk(t, n, i, r), a = new Yu({ shape: { points: o }, z2: 10 }); return e.add(a), t.setItemGraphicEl(n, a), a } function gk(t) { var e = t.get("smooth", !0); return !0 === e && (e = .3), nt(e = ho(e)) && (e = 0), { smooth: e } } function yk(t, e, n, i) { t.useStyle(e.getItemVisual(n, "style")), t.style.fill = null, t.setShape("smooth", i.smooth); var r = e.getItemModel(n), o = r.getModel("emphasis"); jl(t, r, "lineStyle"), Yl(t, o.get("focus"), o.get("blurScope"), o.get("disabled")) } var vk = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.visualStyleAccessPath = "lineStyle", n.visualDrawType = "stroke", n } return n(e, t), e.prototype.getInitialData = function (t, e) { return vx(null, this, { useEncodeDefaulter: W(mk, null, this) }) }, e.prototype.getRawIndicesByActiveState = function (t) { var e = this.coordinateSystem, n = this.getData(), i = []; return e.eachActiveState(n, (function (e, r) { t === e && i.push(n.getRawIndex(r)) })), i }, e.type = "series.parallel", e.dependencies = ["parallel"], e.defaultOption = { z: 2, coordinateSystem: "parallel", parallelIndex: 0, label: { show: !1 }, inactiveOpacity: .05, activeOpacity: 1, lineStyle: { width: 1, opacity: .45, type: "solid" }, emphasis: { label: { show: !1 } }, progressive: 500, smooth: !1, animationEasing: "linear" }, e }(mg); function mk(t) { var e = t.ecModel.getComponent("parallel", t.get("parallelIndex")); if (e) { var n = {}; return E(e.dimensions, (function (t) { var e = +t.replace("dim", ""); n[t] = e })), n } } var xk = ["lineStyle", "opacity"], _k = { seriesType: "parallel", reset: function (t, e) { var n = t.coordinateSystem, i = { normal: t.get(["lineStyle", "opacity"]), active: t.get("activeOpacity"), inactive: t.get("inactiveOpacity") }; return { progress: function (t, e) { n.eachActiveState(e, (function (t, n) { var r = i[t]; if ("normal" === t && e.hasItemOption) { var o = e.getItemModel(n).get(xk, !0); null != o && (r = o) } e.ensureUniqueItemVisual(n, "style").opacity = r }), t.start, t.end) } } } }; function bk(t) { !function (t) { if (t.parallel) return; var e = !1; E(t.series, (function (t) { t && "parallel" === t.type && (e = !0) })), e && (t.parallel = [{}]) }(t), function (t) { var e = bo(t.parallelAxis); E(e, (function (e) { if (q(e)) { var n = e.parallelIndex || 0, i = bo(t.parallel)[n]; i && i.parallelAxisDefault && C(e, i.parallelAxisDefault, !1) } })) }(t) } var wk = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { this._model = t, this._api = n, this._handlers || (this._handlers = {}, E(Sk, (function (t, e) { n.getZr().on(e, this._handlers[e] = W(t, this)) }), this)), Fg(this, "_throttledDispatchExpand", t.get("axisExpandRate"), "fixRate") }, e.prototype.dispose = function (t, e) { Gg(this, "_throttledDispatchExpand"), E(this._handlers, (function (t, n) { e.getZr().off(n, t) })), this._handlers = null }, e.prototype._throttledDispatchExpand = function (t) { this._dispatchExpand(t) }, e.prototype._dispatchExpand = function (t) { t && this._api.dispatchAction(A({ type: "parallelAxisExpand" }, t)) }, e.type = "parallel", e }(Tg), Sk = { mousedown: function (t) { Mk(this, "click") && (this._mouseDownPoint = [t.offsetX, t.offsetY]) }, mouseup: function (t) { var e = this._mouseDownPoint; if (Mk(this, "click") && e) { var n = [t.offsetX, t.offsetY]; if (Math.pow(e[0] - n[0], 2) + Math.pow(e[1] - n[1], 2) > 5) return; var i = this._model.coordinateSystem.getSlidedAxisExpandWindow([t.offsetX, t.offsetY]); "none" !== i.behavior && this._dispatchExpand({ axisExpandWindow: i.axisExpandWindow }) } this._mouseDownPoint = null }, mousemove: function (t) { if (!this._mouseDownPoint && Mk(this, "mousemove")) { var e = this._model, n = e.coordinateSystem.getSlidedAxisExpandWindow([t.offsetX, t.offsetY]), i = n.behavior; "jump" === i && this._throttledDispatchExpand.debounceNextCall(e.get("axisExpandDebounce")), this._throttledDispatchExpand("none" === i ? null : { axisExpandWindow: n.axisExpandWindow, animation: "jump" === i ? null : { duration: 0 } }) } } }; function Mk(t, e) { var n = t._model; return n.get("axisExpandable") && n.get("axisExpandTriggerOn") === e } var Ik = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function () { t.prototype.init.apply(this, arguments), this.mergeOption({}) }, e.prototype.mergeOption = function (t) { var e = this.option; t && C(e, t, !0), this._initDimensions() }, e.prototype.contains = function (t, e) { var n = t.get("parallelIndex"); return null != n && e.getComponent("parallel", n) === this }, e.prototype.setAxisExpand = function (t) { E(["axisExpandable", "axisExpandCenter", "axisExpandCount", "axisExpandWidth", "axisExpandWindow"], (function (e) { t.hasOwnProperty(e) && (this.option[e] = t[e]) }), this) }, e.prototype._initDimensions = function () { var t = this.dimensions = [], e = this.parallelAxisIndex = []; E(B(this.ecModel.queryComponents({ mainType: "parallelAxis" }), (function (t) { return (t.get("parallelIndex") || 0) === this.componentIndex }), this), (function (n) { t.push("dim" + n.get("dim")), e.push(n.componentIndex) })) }, e.type = "parallel", e.dependencies = ["parallelAxis"], e.layoutMode = "box", e.defaultOption = { z: 0, left: 80, top: 60, right: 80, bottom: 60, layout: "horizontal", axisExpandable: !1, axisExpandCenter: null, axisExpandCount: 0, axisExpandWidth: 50, axisExpandRate: 17, axisExpandDebounce: 50, axisExpandSlideTriggerArea: [-.15, .05, .4], axisExpandTriggerOn: "click", parallelAxisDefault: null }, e }(Rp), Tk = function (t) { function e(e, n, i, r, o) { var a = t.call(this, e, n, i) || this; return a.type = r || "value", a.axisIndex = o, a } return n(e, t), e.prototype.isHorizontal = function () { return "horizontal" !== this.coordinateSystem.getModel().get("layout") }, e }(nb); function Ck(t, e, n, i, r, o) { t = t || 0; var a = n[1] - n[0]; if (null != r && (r = Ak(r, [0, a])), null != o && (o = Math.max(o, null != r ? r : 0)), "all" === i) { var s = Math.abs(e[1] - e[0]); s = Ak(s, [0, a]), r = o = Ak(s, [r, o]), i = 0 } e[0] = Ak(e[0], n), e[1] = Ak(e[1], n); var l = Dk(e, i); e[i] += t; var u, h = r || 0, c = n.slice(); return l.sign < 0 ? c[0] += h : c[1] -= h, e[i] = Ak(e[i], c), u = Dk(e, i), null != r && (u.sign !== l.sign || u.span < r) && (e[1 - i] = e[i] + l.sign * r), u = Dk(e, i), null != o && u.span > o && (e[1 - i] = e[i] + u.sign * o), e } function Dk(t, e) { var n = t[e] - t[1 - e]; return { span: Math.abs(n), sign: n > 0 ? -1 : n < 0 ? 1 : e ? -1 : 1 } } function Ak(t, e) { return Math.min(null != e[1] ? e[1] : 1 / 0, Math.max(null != e[0] ? e[0] : -1 / 0, t)) } var kk = E, Lk = Math.min, Pk = Math.max, Ok = Math.floor, Rk = Math.ceil, Nk = Zr, Ek = Math.PI, zk = function () { function t(t, e, n) { this.type = "parallel", this._axesMap = yt(), this._axesLayout = {}, this.dimensions = t.dimensions, this._model = t, this._init(t, e, n) } return t.prototype._init = function (t, e, n) { var i = t.dimensions, r = t.parallelAxisIndex; kk(i, (function (t, n) { var i = r[n], o = e.getComponent("parallelAxis", i), a = this._axesMap.set(t, new Tk(t, m_(o), [0, 0], o.get("type"), i)), s = "category" === a.type; a.onBand = s && o.get("boundaryGap"), a.inverse = o.get("inverse"), o.axis = a, a.model = o, a.coordinateSystem = o.coordinateSystem = this }), this) }, t.prototype.update = function (t, e) { this._updateAxesFromSeries(this._model, t) }, t.prototype.containPoint = function (t) { var e = this._makeLayoutInfo(), n = e.axisBase, i = e.layoutBase, r = e.pixelDimIndex, o = t[1 - r], a = t[r]; return o >= n && o <= n + e.axisLength && a >= i && a <= i + e.layoutLength }, t.prototype.getModel = function () { return this._model }, t.prototype._updateAxesFromSeries = function (t, e) { e.eachSeries((function (n) { if (t.contains(n, e)) { var i = n.getData(); kk(this.dimensions, (function (t) { var e = this._axesMap.get(t); e.scale.unionExtentFromData(i, i.mapDimension(t)), v_(e.scale, e.model) }), this) } }), this) }, t.prototype.resize = function (t, e) { this._rect = Cp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }), this._layoutAxes() }, t.prototype.getRect = function () { return this._rect }, t.prototype._makeLayoutInfo = function () { var t, e = this._model, n = this._rect, i = ["x", "y"], r = ["width", "height"], o = e.get("layout"), a = "horizontal" === o ? 0 : 1, s = n[r[a]], l = [0, s], u = this.dimensions.length, h = Vk(e.get("axisExpandWidth"), l), c = Vk(e.get("axisExpandCount") || 0, [0, u]), p = e.get("axisExpandable") && u > 3 && u > c && c > 1 && h > 0 && s > 0, d = e.get("axisExpandWindow"); d ? (t = Vk(d[1] - d[0], l), d[1] = d[0] + t) : (t = Vk(h * (c - 1), l), (d = [h * (e.get("axisExpandCenter") || Ok(u / 2)) - t / 2])[1] = d[0] + t); var f = (s - t) / (u - c); f < 3 && (f = 0); var g = [Ok(Nk(d[0] / h, 1)) + 1, Rk(Nk(d[1] / h, 1)) - 1], y = f / h * d[0]; return { layout: o, pixelDimIndex: a, layoutBase: n[i[a]], layoutLength: s, axisBase: n[i[1 - a]], axisLength: n[r[1 - a]], axisExpandable: p, axisExpandWidth: h, axisCollapseWidth: f, axisExpandWindow: d, axisCount: u, winInnerIndices: g, axisExpandWindow0Pos: y } }, t.prototype._layoutAxes = function () { var t = this._rect, e = this._axesMap, n = this.dimensions, i = this._makeLayoutInfo(), r = i.layout; e.each((function (t) { var e = [0, i.axisLength], n = t.inverse ? 1 : 0; t.setExtent(e[n], e[1 - n]) })), kk(n, (function (e, n) { var o = (i.axisExpandable ? Fk : Bk)(n, i), a = { horizontal: { x: o.position, y: i.axisLength }, vertical: { x: 0, y: o.position } }, s = { horizontal: Ek / 2, vertical: 0 }, l = [a[r].x + t.x, a[r].y + t.y], u = s[r], h = [1, 0, 0, 1, 0, 0]; Se(h, h, u), we(h, h, l), this._axesLayout[e] = { position: l, rotation: u, transform: h, axisNameAvailableWidth: o.axisNameAvailableWidth, axisLabelShow: o.axisLabelShow, nameTruncateMaxWidth: o.nameTruncateMaxWidth, tickDirection: 1, labelDirection: 1 } }), this) }, t.prototype.getAxis = function (t) { return this._axesMap.get(t) }, t.prototype.dataToPoint = function (t, e) { return this.axisCoordToPoint(this._axesMap.get(e).dataToCoord(t), e) }, t.prototype.eachActiveState = function (t, e, n, i) { null == n && (n = 0), null == i && (i = t.count()); var r = this._axesMap, o = this.dimensions, a = [], s = []; E(o, (function (e) { a.push(t.mapDimension(e)), s.push(r.get(e).model) })); for (var l = this.hasAxisBrushed(), u = n; u < i; u++) { var h = void 0; if (l) { h = "active"; for (var c = t.getValues(a, u), p = 0, d = o.length; p < d; p++) { if ("inactive" === s[p].getActiveState(c[p])) { h = "inactive"; break } } } else h = "normal"; e(h, u) } }, t.prototype.hasAxisBrushed = function () { for (var t = this.dimensions, e = this._axesMap, n = !1, i = 0, r = t.length; i < r; i++)"normal" !== e.get(t[i]).model.getActiveState() && (n = !0); return n }, t.prototype.axisCoordToPoint = function (t, e) { return zh([t, 0], this._axesLayout[e].transform) }, t.prototype.getAxisLayout = function (t) { return T(this._axesLayout[t]) }, t.prototype.getSlidedAxisExpandWindow = function (t) { var e = this._makeLayoutInfo(), n = e.pixelDimIndex, i = e.axisExpandWindow.slice(), r = i[1] - i[0], o = [0, e.axisExpandWidth * (e.axisCount - 1)]; if (!this.containPoint(t)) return { behavior: "none", axisExpandWindow: i }; var a, s = t[n] - e.layoutBase - e.axisExpandWindow0Pos, l = "slide", u = e.axisCollapseWidth, h = this._model.get("axisExpandSlideTriggerArea"), c = null != h[0]; if (u) c && u && s < r * h[0] ? (l = "jump", a = s - r * h[2]) : c && u && s > r * (1 - h[0]) ? (l = "jump", a = s - r * (1 - h[2])) : (a = s - r * h[1]) >= 0 && (a = s - r * (1 - h[1])) <= 0 && (a = 0), (a *= e.axisExpandWidth / u) ? Ck(a, i, o, "all") : l = "none"; else { var p = i[1] - i[0]; (i = [Pk(0, o[1] * s / p - p / 2)])[1] = Lk(o[1], i[0] + p), i[0] = i[1] - p } return { axisExpandWindow: i, behavior: l } }, t }(); function Vk(t, e) { return Lk(Pk(t, e[0]), e[1]) } function Bk(t, e) { var n = e.layoutLength / (e.axisCount - 1); return { position: n * t, axisNameAvailableWidth: n, axisLabelShow: !0 } } function Fk(t, e) { var n, i, r = e.layoutLength, o = e.axisExpandWidth, a = e.axisCount, s = e.axisCollapseWidth, l = e.winInnerIndices, u = s, h = !1; return t < l[0] ? (n = t * s, i = s) : t <= l[1] ? (n = e.axisExpandWindow0Pos + t * o - e.axisExpandWindow[0], u = o, h = !0) : (n = r - (a - 1 - t) * s, i = s), { position: n, axisNameAvailableWidth: u, axisLabelShow: h, nameTruncateMaxWidth: i } } var Gk = { create: function (t, e) { var n = []; return t.eachComponent("parallel", (function (i, r) { var o = new zk(i, t, e); o.name = "parallel_" + r, o.resize(i, e), i.coordinateSystem = o, o.model = i, n.push(o) })), t.eachSeries((function (t) { if ("parallel" === t.get("coordinateSystem")) { var e = t.getReferringComponents("parallel", zo).models[0]; t.coordinateSystem = e.coordinateSystem } })), n } }, Wk = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.activeIntervals = [], n } return n(e, t), e.prototype.getAreaSelectStyle = function () { return Jo([["fill", "color"], ["lineWidth", "borderWidth"], ["stroke", "borderColor"], ["width", "width"], ["opacity", "opacity"]])(this.getModel("areaSelectStyle")) }, e.prototype.setActiveIntervals = function (t) { var e = this.activeIntervals = T(t); if (e) for (var n = e.length - 1; n >= 0; n--)jr(e[n]) }, e.prototype.getActiveState = function (t) { var e = this.activeIntervals; if (!e.length) return "normal"; if (null == t || isNaN(+t)) return "inactive"; if (1 === e.length) { var n = e[0]; if (n[0] <= t && t <= n[1]) return "active" } else for (var i = 0, r = e.length; i < r; i++)if (e[i][0] <= t && t <= e[i][1]) return "active"; return "inactive" }, e }(Rp); R(Wk, I_); var Hk = !0, Yk = Math.min, Xk = Math.max, Uk = Math.pow, Zk = "globalPan", jk = { w: [0, 0], e: [0, 1], n: [1, 0], s: [1, 1] }, qk = { w: "ew", e: "ew", n: "ns", s: "ns", ne: "nesw", sw: "nesw", nw: "nwse", se: "nwse" }, Kk = { brushStyle: { lineWidth: 2, stroke: "rgba(210,219,238,0.3)", fill: "#D2DBEE" }, transformable: !0, brushMode: "single", removeOnClick: !1 }, $k = 0, Jk = function (t) { function e(e) { var n = t.call(this) || this; return n._track = [], n._covers = [], n._handlers = {}, n._zr = e, n.group = new zr, n._uid = "brushController_" + $k++, E(IL, (function (t, e) { this._handlers[e] = W(t, this) }), n), n } return n(e, t), e.prototype.enableBrush = function (t) { return this._brushType && this._doDisableBrush(), t.brushType && this._doEnableBrush(t), this }, e.prototype._doEnableBrush = function (t) { var e = this._zr; this._enableGlobalPan || function (t, e, n) { XI(t)[e] = n }(e, Zk, this._uid), E(this._handlers, (function (t, n) { e.on(n, t) })), this._brushType = t.brushType, this._brushOption = C(T(Kk), t, !0) }, e.prototype._doDisableBrush = function () { var t = this._zr; !function (t, e, n) { var i = XI(t); i[e] === n && (i[e] = null) }(t, Zk, this._uid), E(this._handlers, (function (e, n) { t.off(n, e) })), this._brushType = this._brushOption = null }, e.prototype.setPanels = function (t) { if (t && t.length) { var e = this._panels = {}; E(t, (function (t) { e[t.panelId] = T(t) })) } else this._panels = null; return this }, e.prototype.mount = function (t) { t = t || {}, this._enableGlobalPan = t.enableGlobalPan; var e = this.group; return this._zr.add(e), e.attr({ x: t.x || 0, y: t.y || 0, rotation: t.rotation || 0, scaleX: t.scaleX || 1, scaleY: t.scaleY || 1 }), this._transform = e.getLocalTransform(), this }, e.prototype.updateCovers = function (t) { t = z(t, (function (t) { return C(T(Kk), t, !0) })); var e = this._covers, n = this._covers = [], i = this, r = this._creatingCover; return new Vm(e, t, (function (t, e) { return o(t.__brushOption, e) }), o).add(a).update(a).remove((function (t) { e[t] !== r && i.group.remove(e[t]) })).execute(), this; function o(t, e) { return (null != t.id ? t.id : "\0-brush-index-" + e) + "-" + t.brushType } function a(o, a) { var s = t[o]; if (null != a && e[a] === r) n[o] = e[a]; else { var l = n[o] = null != a ? (e[a].__brushOption = s, e[a]) : tL(i, Qk(i, s)); iL(i, l) } } }, e.prototype.unmount = function () { return this.enableBrush(!1), sL(this), this._zr.remove(this.group), this }, e.prototype.dispose = function () { this.unmount(), this.off() }, e }(jt); function Qk(t, e) { var n = CL[e.brushType].createCover(t, e); return n.__brushOption = e, nL(n, e), t.group.add(n), n } function tL(t, e) { var n = rL(e); return n.endCreating && (n.endCreating(t, e), nL(e, e.__brushOption)), e } function eL(t, e) { var n = e.__brushOption; rL(e).updateCoverShape(t, e, n.range, n) } function nL(t, e) { var n = e.z; null == n && (n = 1e4), t.traverse((function (t) { t.z = n, t.z2 = n })) } function iL(t, e) { rL(e).updateCommon(t, e), eL(t, e) } function rL(t) { return CL[t.__brushOption.brushType] } function oL(t, e, n) { var i, r = t._panels; if (!r) return Hk; var o = t._transform; return E(r, (function (t) { t.isTargetByCursor(e, n, o) && (i = t) })), i } function aL(t, e) { var n = t._panels; if (!n) return Hk; var i = e.__brushOption.panelId; return null != i ? n[i] : Hk } function sL(t) { var e = t._covers, n = e.length; return E(e, (function (e) { t.group.remove(e) }), t), e.length = 0, !!n } function lL(t, e) { var n = z(t._covers, (function (t) { var e = t.__brushOption, n = T(e.range); return { brushType: e.brushType, panelId: e.panelId, range: n } })); t.trigger("brush", { areas: n, isEnd: !!e.isEnd, removeOnClick: !!e.removeOnClick }) } function uL(t) { var e = t.length - 1; return e < 0 && (e = 0), [t[0], t[e]] } function hL(t, e, n, i) { var r = new zr; return r.add(new zs({ name: "main", style: fL(n), silent: !0, draggable: !0, cursor: "move", drift: H(vL, t, e, r, ["n", "s", "w", "e"]), ondragend: H(lL, e, { isEnd: !0 }) })), E(i, (function (n) { r.add(new zs({ name: n.join(""), style: { opacity: 0 }, draggable: !0, silent: !0, invisible: !0, drift: H(vL, t, e, r, n), ondragend: H(lL, e, { isEnd: !0 }) })) })), r } function cL(t, e, n, i) { var r = i.brushStyle.lineWidth || 0, o = Xk(r, 6), a = n[0][0], s = n[1][0], l = a - r / 2, u = s - r / 2, h = n[0][1], c = n[1][1], p = h - o + r / 2, d = c - o + r / 2, f = h - a, g = c - s, y = f + r, v = g + r; dL(t, e, "main", a, s, f, g), i.transformable && (dL(t, e, "w", l, u, o, v), dL(t, e, "e", p, u, o, v), dL(t, e, "n", l, u, y, o), dL(t, e, "s", l, d, y, o), dL(t, e, "nw", l, u, o, o), dL(t, e, "ne", p, u, o, o), dL(t, e, "sw", l, d, o, o), dL(t, e, "se", p, d, o, o)) } function pL(t, e) { var n = e.__brushOption, i = n.transformable, r = e.childAt(0); r.useStyle(fL(n)), r.attr({ silent: !i, cursor: i ? "move" : "default" }), E([["w"], ["e"], ["n"], ["s"], ["s", "e"], ["s", "w"], ["n", "e"], ["n", "w"]], (function (n) { var r = e.childOfName(n.join("")), o = 1 === n.length ? yL(t, n[0]) : function (t, e) { var n = [yL(t, e[0]), yL(t, e[1])]; return ("e" === n[0] || "w" === n[0]) && n.reverse(), n.join("") }(t, n); r && r.attr({ silent: !i, invisible: !i, cursor: i ? qk[o] + "-resize" : null }) })) } function dL(t, e, n, i, r, o, a) { var s = e.childOfName(n); s && s.setShape(function (t) { var e = Yk(t[0][0], t[1][0]), n = Yk(t[0][1], t[1][1]), i = Xk(t[0][0], t[1][0]), r = Xk(t[0][1], t[1][1]); return { x: e, y: n, width: i - e, height: r - n } }(_L(t, e, [[i, r], [i + o, r + a]]))) } function fL(t) { return k({ strokeNoScale: !0 }, t.brushStyle) } function gL(t, e, n, i) { var r = [Yk(t, n), Yk(e, i)], o = [Xk(t, n), Xk(e, i)]; return [[r[0], o[0]], [r[1], o[1]]] } function yL(t, e) { var n = Vh({ w: "left", e: "right", n: "top", s: "bottom" }[e], function (t) { return Eh(t.group) }(t)); return { left: "w", right: "e", top: "n", bottom: "s" }[n] } function vL(t, e, n, i, r, o) { var a = n.__brushOption, s = t.toRectRange(a.range), l = xL(e, r, o); E(i, (function (t) { var e = jk[t]; s[e[0]][e[1]] += l[e[0]] })), a.range = t.fromRectRange(gL(s[0][0], s[1][0], s[0][1], s[1][1])), iL(e, n), lL(e, { isEnd: !1 }) } function mL(t, e, n, i) { var r = e.__brushOption.range, o = xL(t, n, i); E(r, (function (t) { t[0] += o[0], t[1] += o[1] })), iL(t, e), lL(t, { isEnd: !1 }) } function xL(t, e, n) { var i = t.group, r = i.transformCoordToLocal(e, n), o = i.transformCoordToLocal(0, 0); return [r[0] - o[0], r[1] - o[1]] } function _L(t, e, n) { var i = aL(t, e); return i && i !== Hk ? i.clipPath(n, t._transform) : T(n) } function bL(t) { var e = t.event; e.preventDefault && e.preventDefault() } function wL(t, e, n) { return t.childOfName("main").contain(e, n) } function SL(t, e, n, i) { var r, o = t._creatingCover, a = t._creatingPanel, s = t._brushOption; if (t._track.push(n.slice()), function (t) { var e = t._track; if (!e.length) return !1; var n = e[e.length - 1], i = e[0], r = n[0] - i[0], o = n[1] - i[1]; return Uk(r * r + o * o, .5) > 6 }(t) || o) { if (a && !o) { "single" === s.brushMode && sL(t); var l = T(s); l.brushType = ML(l.brushType, a), l.panelId = a === Hk ? null : a.panelId, o = t._creatingCover = Qk(t, l), t._covers.push(o) } if (o) { var u = CL[ML(t._brushType, a)]; o.__brushOption.range = u.getCreatingRange(_L(t, o, t._track)), i && (tL(t, o), u.updateCommon(t, o)), eL(t, o), r = { isEnd: i } } } else i && "single" === s.brushMode && s.removeOnClick && oL(t, e, n) && sL(t) && (r = { isEnd: i, removeOnClick: !0 }); return r } function ML(t, e) { return "auto" === t ? e.defaultBrushType : t } var IL = { mousedown: function (t) { if (this._dragging) TL(this, t); else if (!t.target || !t.target.draggable) { bL(t); var e = this.group.transformCoordToLocal(t.offsetX, t.offsetY); this._creatingCover = null, (this._creatingPanel = oL(this, t, e)) && (this._dragging = !0, this._track = [e.slice()]) } }, mousemove: function (t) { var e = t.offsetX, n = t.offsetY, i = this.group.transformCoordToLocal(e, n); if (function (t, e, n) { if (t._brushType && !function (t, e, n) { var i = t._zr; return e < 0 || e > i.getWidth() || n < 0 || n > i.getHeight() }(t, e.offsetX, e.offsetY)) { var i = t._zr, r = t._covers, o = oL(t, e, n); if (!t._dragging) for (var a = 0; a < r.length; a++) { var s = r[a].__brushOption; if (o && (o === Hk || s.panelId === o.panelId) && CL[s.brushType].contain(r[a], n[0], n[1])) return } o && i.setCursorStyle("crosshair") } }(this, t, i), this._dragging) { bL(t); var r = SL(this, t, i, !1); r && lL(this, r) } }, mouseup: function (t) { TL(this, t) } }; function TL(t, e) { if (t._dragging) { bL(e); var n = e.offsetX, i = e.offsetY, r = t.group.transformCoordToLocal(n, i), o = SL(t, e, r, !0); t._dragging = !1, t._track = [], t._creatingCover = null, o && lL(t, o) } } var CL = { lineX: DL(0), lineY: DL(1), rect: { createCover: function (t, e) { function n(t) { return t } return hL({ toRectRange: n, fromRectRange: n }, t, e, [["w"], ["e"], ["n"], ["s"], ["s", "e"], ["s", "w"], ["n", "e"], ["n", "w"]]) }, getCreatingRange: function (t) { var e = uL(t); return gL(e[1][0], e[1][1], e[0][0], e[0][1]) }, updateCoverShape: function (t, e, n, i) { cL(t, e, n, i) }, updateCommon: pL, contain: wL }, polygon: { createCover: function (t, e) { var n = new zr; return n.add(new Yu({ name: "main", style: fL(e), silent: !0 })), n }, getCreatingRange: function (t) { return t }, endCreating: function (t, e) { e.remove(e.childAt(0)), e.add(new Wu({ name: "main", draggable: !0, drift: H(mL, t, e), ondragend: H(lL, t, { isEnd: !0 }) })) }, updateCoverShape: function (t, e, n, i) { e.childAt(0).setShape({ points: _L(t, e, n) }) }, updateCommon: pL, contain: wL } }; function DL(t) { return { createCover: function (e, n) { return hL({ toRectRange: function (e) { var n = [e, [0, 100]]; return t && n.reverse(), n }, fromRectRange: function (e) { return e[t] } }, e, n, [[["w"], ["e"]], [["n"], ["s"]]][t]) }, getCreatingRange: function (e) { var n = uL(e); return [Yk(n[0][t], n[1][t]), Xk(n[0][t], n[1][t])] }, updateCoverShape: function (e, n, i, r) { var o, a = aL(e, n); if (a !== Hk && a.getLinearBrushOtherExtent) o = a.getLinearBrushOtherExtent(t); else { var s = e._zr; o = [0, [s.getWidth(), s.getHeight()][1 - t]] } var l = [i, o]; t && l.reverse(), cL(e, n, l, r) }, updateCommon: pL, contain: wL } } function AL(t) { return t = PL(t), function (e) { return Gh(e, t) } } function kL(t, e) { return t = PL(t), function (n) { var i = null != e ? e : n, r = i ? t.width : t.height, o = i ? t.x : t.y; return [o, o + (r || 0)] } } function LL(t, e, n) { var i = PL(t); return function (t, r) { return i.contain(r[0], r[1]) && !tT(t, e, n) } } function PL(t) { return ze.create(t) } var OL = ["axisLine", "axisTickLabel", "axisName"], RL = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (e, n) { t.prototype.init.apply(this, arguments), (this._brushController = new Jk(n.getZr())).on("brush", W(this._onBrush, this)) }, e.prototype.render = function (t, e, n, i) { if (!function (t, e, n) { return n && "axisAreaSelect" === n.type && e.findComponents({ mainType: "parallelAxis", query: n })[0] === t }(t, e, i)) { this.axisModel = t, this.api = n, this.group.removeAll(); var r = this._axisGroup; if (this._axisGroup = new zr, this.group.add(this._axisGroup), t.get("show")) { var o = function (t, e) { return e.getComponent("parallel", t.get("parallelIndex")) }(t, e), a = o.coordinateSystem, s = t.getAreaSelectStyle(), l = s.width, u = t.axis.dim, h = A({ strokeContainThreshold: l }, a.getAxisLayout(u)), c = new iI(t, h); E(OL, c.add, c), this._axisGroup.add(c.getGroup()), this._refreshBrushController(h, s, t, o, l, n), Fh(r, this._axisGroup, t) } } }, e.prototype._refreshBrushController = function (t, e, n, i, r, o) { var a = n.axis.getExtent(), s = a[1] - a[0], l = Math.min(30, .1 * Math.abs(s)), u = ze.create({ x: a[0], y: -r / 2, width: s, height: r }); u.x -= l, u.width += 2 * l, this._brushController.mount({ enableGlobalPan: !0, rotation: t.rotation, x: t.position[0], y: t.position[1] }).setPanels([{ panelId: "pl", clipPath: AL(u), isTargetByCursor: LL(u, o, i), getLinearBrushOtherExtent: kL(u, 0) }]).enableBrush({ brushType: "lineX", brushStyle: e, removeOnClick: !0 }).updateCovers(function (t) { var e = t.axis; return z(t.activeIntervals, (function (t) { return { brushType: "lineX", panelId: "pl", range: [e.dataToCoord(t[0], !0), e.dataToCoord(t[1], !0)] } })) }(n)) }, e.prototype._onBrush = function (t) { var e = t.areas, n = this.axisModel, i = n.axis, r = z(e, (function (t) { return [i.coordToData(t.range[0], !0), i.coordToData(t.range[1], !0)] })); (!n.option.realtime === t.isEnd || t.removeOnClick) && this.api.dispatchAction({ type: "axisAreaSelect", parallelAxisId: n.id, intervals: r }) }, e.prototype.dispose = function () { this._brushController.dispose() }, e.type = "parallelAxis", e }(Tg); var NL = { type: "axisAreaSelect", event: "axisAreaSelected" }; var EL = { type: "value", areaSelectStyle: { width: 20, borderWidth: 1, borderColor: "rgba(160,197,232)", color: "rgba(160,197,232)", opacity: .3 }, realtime: !0, z: 10 }; function zL(t) { t.registerComponentView(wk), t.registerComponentModel(Ik), t.registerCoordinateSystem("parallel", Gk), t.registerPreprocessor(bk), t.registerComponentModel(Wk), t.registerComponentView(RL), FM(t, "parallel", Wk, EL), function (t) { t.registerAction(NL, (function (t, e) { e.eachComponent({ mainType: "parallelAxis", query: t }, (function (e) { e.axis.model.setActiveIntervals(t.intervals) })) })), t.registerAction("parallelAxisExpand", (function (t, e) { e.eachComponent({ mainType: "parallel", query: t }, (function (e) { e.setAxisExpand(t) })) })) }(t) } var VL = function () { this.x1 = 0, this.y1 = 0, this.x2 = 0, this.y2 = 0, this.cpx1 = 0, this.cpy1 = 0, this.cpx2 = 0, this.cpy2 = 0, this.extent = 0 }, BL = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new VL }, e.prototype.buildPath = function (t, e) { var n = e.extent; t.moveTo(e.x1, e.y1), t.bezierCurveTo(e.cpx1, e.cpy1, e.cpx2, e.cpy2, e.x2, e.y2), "vertical" === e.orient ? (t.lineTo(e.x2 + n, e.y2), t.bezierCurveTo(e.cpx2 + n, e.cpy2, e.cpx1 + n, e.cpy1, e.x1 + n, e.y1)) : (t.lineTo(e.x2, e.y2 + n), t.bezierCurveTo(e.cpx2, e.cpy2 + n, e.cpx1, e.cpy1 + n, e.x1, e.y1 + n)), t.closePath() }, e.prototype.highlight = function () { kl(this) }, e.prototype.downplay = function () { Ll(this) }, e }(Is), FL = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._focusAdjacencyDisabled = !1, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = this, r = t.getGraph(), o = this.group, a = t.layoutInfo, s = a.width, l = a.height, u = t.getData(), h = t.getData("edge"), c = t.get("orient"); this._model = t, o.removeAll(), o.x = a.x, o.y = a.y, r.eachEdge((function (e) { var n = new BL, i = Qs(n); i.dataIndex = e.dataIndex, i.seriesIndex = t.seriesIndex, i.dataType = "edge"; var r, a, u, p, d, f, g, y, v = e.getModel(), m = v.getModel("lineStyle"), x = m.get("curveness"), _ = e.node1.getLayout(), b = e.node1.getModel(), w = b.get("localX"), S = b.get("localY"), M = e.node2.getLayout(), I = e.node2.getModel(), T = I.get("localX"), C = I.get("localY"), D = e.getLayout(); n.shape.extent = Math.max(1, D.dy), n.shape.orient = c, "vertical" === c ? (r = (null != w ? w * s : _.x) + D.sy, a = (null != S ? S * l : _.y) + _.dy, u = (null != T ? T * s : M.x) + D.ty, d = r, f = a * (1 - x) + (p = null != C ? C * l : M.y) * x, g = u, y = a * x + p * (1 - x)) : (r = (null != w ? w * s : _.x) + _.dx, a = (null != S ? S * l : _.y) + D.sy, d = r * (1 - x) + (u = null != T ? T * s : M.x) * x, f = a, g = r * x + u * (1 - x), y = p = (null != C ? C * l : M.y) + D.ty), n.setShape({ x1: r, y1: a, x2: u, y2: p, cpx1: d, cpy1: f, cpx2: g, cpy2: y }), n.useStyle(m.getItemStyle()), GL(n.style, c, e); var A = "" + v.get("value"), k = ec(v, "edgeLabel"); tc(n, k, { labelFetcher: { getFormattedLabel: function (e, n, i, r, o, a) { return t.getFormattedLabel(e, n, "edge", r, ot(o, k.normal && k.normal.get("formatter"), A), a) } }, labelDataIndex: e.dataIndex, defaultText: A }), n.setTextConfig({ position: "inside" }); var L = v.getModel("emphasis"); jl(n, v, "lineStyle", (function (t) { var n = t.getItemStyle(); return GL(n, c, e), n })), o.add(n), h.setItemGraphicEl(e.dataIndex, n); var P = L.get("focus"); Yl(n, "adjacency" === P ? e.getAdjacentDataIndices() : "trajectory" === P ? e.getTrajectoryDataIndices() : P, L.get("blurScope"), L.get("disabled")) })), r.eachNode((function (e) { var n = e.getLayout(), i = e.getModel(), r = i.get("localX"), a = i.get("localY"), h = i.getModel("emphasis"), c = new zs({ shape: { x: null != r ? r * s : n.x, y: null != a ? a * l : n.y, width: n.dx, height: n.dy }, style: i.getModel("itemStyle").getItemStyle(), z2: 10 }); tc(c, ec(i), { labelFetcher: { getFormattedLabel: function (e, n) { return t.getFormattedLabel(e, n, "node") } }, labelDataIndex: e.dataIndex, defaultText: e.id }), c.disableLabelAnimation = !0, c.setStyle("fill", e.getVisual("color")), c.setStyle("decal", e.getVisual("style").decal), jl(c, i), o.add(c), u.setItemGraphicEl(e.dataIndex, c), Qs(c).dataType = "node"; var p = h.get("focus"); Yl(c, "adjacency" === p ? e.getAdjacentDataIndices() : "trajectory" === p ? e.getTrajectoryDataIndices() : p, h.get("blurScope"), h.get("disabled")) })), u.eachItemGraphicEl((function (e, r) { u.getItemModel(r).get("draggable") && (e.drift = function (e, o) { i._focusAdjacencyDisabled = !0, this.shape.x += e, this.shape.y += o, this.dirty(), n.dispatchAction({ type: "dragNode", seriesId: t.id, dataIndex: u.getRawIndex(r), localX: this.shape.x / s, localY: this.shape.y / l }) }, e.ondragend = function () { i._focusAdjacencyDisabled = !1 }, e.draggable = !0, e.cursor = "move") })), !this._data && t.isAnimationEnabled() && o.setClipPath(function (t, e, n) { var i = new zs({ shape: { x: t.x - 10, y: t.y - 10, width: 0, height: t.height + 20 } }); return gh(i, { shape: { width: t.width + 20 } }, e, n), i }(o.getBoundingRect(), t, (function () { o.removeClipPath() }))), this._data = t.getData() }, e.prototype.dispose = function () { }, e.type = "sankey", e }(kg); function GL(t, e, n) { switch (t.fill) { case "source": t.fill = n.node1.getVisual("color"), t.decal = n.node1.getVisual("style").decal; break; case "target": t.fill = n.node2.getVisual("color"), t.decal = n.node2.getVisual("style").decal; break; case "gradient": var i = n.node1.getVisual("color"), r = n.node2.getVisual("color"); U(i) && U(r) && (t.fill = new nh(0, 0, +("horizontal" === e), +("vertical" === e), [{ color: i, offset: 0 }, { color: r, offset: 1 }])) } } var WL = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.getInitialData = function (t, e) { var n = t.edges || t.links, i = t.data || t.nodes, r = t.levels; this.levelModels = []; for (var o = this.levelModels, a = 0; a < r.length; a++)null != r[a].depth && r[a].depth >= 0 && (o[r[a].depth] = new Mc(r[a], this, e)); if (i && n) { var s = QA(i, n, this, !0, (function (t, e) { t.wrapMethod("getItemModel", (function (t, e) { var n = t.parentModel, i = n.getData().getItemLayout(e); if (i) { var r = i.depth, o = n.levelModels[r]; o && (t.parentModel = o) } return t })), e.wrapMethod("getItemModel", (function (t, e) { var n = t.parentModel, i = n.getGraph().getEdgeByIndex(e).node1.getLayout(); if (i) { var r = i.depth, o = n.levelModels[r]; o && (t.parentModel = o) } return t })) })); return s.data } }, e.prototype.setNodePosition = function (t, e) { var n = (this.option.data || this.option.nodes)[t]; n.localX = e[0], n.localY = e[1] }, e.prototype.getGraph = function () { return this.getData().graph }, e.prototype.getEdgeData = function () { return this.getGraph().edgeData }, e.prototype.formatTooltip = function (t, e, n) { function i(t) { return isNaN(t) || null == t } if ("edge" === n) { var r = this.getDataParams(t, n), o = r.data, a = r.value; return ng("nameValue", { name: o.source + " -- " + o.target, value: a, noValue: i(a) }) } var s = this.getGraph().getNodeByIndex(t).getLayout().value, l = this.getDataParams(t, n).data.name; return ng("nameValue", { name: null != l ? l + "" : null, value: s, noValue: i(s) }) }, e.prototype.optionUpdated = function () { }, e.prototype.getDataParams = function (e, n) { var i = t.prototype.getDataParams.call(this, e, n); if (null == i.value && "node" === n) { var r = this.getGraph().getNodeByIndex(e).getLayout().value; i.value = r } return i }, e.type = "series.sankey", e.defaultOption = { z: 2, coordinateSystem: "view", left: "5%", top: "5%", right: "20%", bottom: "5%", orient: "horizontal", nodeWidth: 20, nodeGap: 8, draggable: !0, layoutIterations: 32, label: { show: !0, position: "right", fontSize: 12 }, edgeLabel: { show: !1, fontSize: 12 }, levels: [], nodeAlign: "justify", lineStyle: { color: "#314656", opacity: .2, curveness: .5 }, emphasis: { label: { show: !0 }, lineStyle: { opacity: .5 } }, select: { itemStyle: { borderColor: "#212121" } }, animationEasing: "linear", animationDuration: 1e3 }, e }(mg); function HL(t, e) { t.eachSeriesByType("sankey", (function (t) { var n = t.get("nodeWidth"), i = t.get("nodeGap"), r = function (t, e) { return Cp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }) }(t, e); t.layoutInfo = r; var o = r.width, a = r.height, s = t.getGraph(), l = s.nodes, u = s.edges; !function (t) { E(t, (function (t) { var e = QL(t.outEdges, JL), n = QL(t.inEdges, JL), i = t.getValue() || 0, r = Math.max(e, n, i); t.setLayout({ value: r }, !0) })) }(l), function (t, e, n, i, r, o, a, s, l) { (function (t, e, n, i, r, o, a) { for (var s = [], l = [], u = [], h = [], c = 0, p = 0; p < e.length; p++)s[p] = 1; for (p = 0; p < t.length; p++)l[p] = t[p].inEdges.length, 0 === l[p] && u.push(t[p]); var d = -1; for (; u.length;) { for (var f = 0; f < u.length; f++) { var g = u[f], y = g.hostGraph.data.getRawDataItem(g.dataIndex), v = null != y.depth && y.depth >= 0; v && y.depth > d && (d = y.depth), g.setLayout({ depth: v ? y.depth : c }, !0), "vertical" === o ? g.setLayout({ dy: n }, !0) : g.setLayout({ dx: n }, !0); for (var m = 0; m < g.outEdges.length; m++) { var x = g.outEdges[m]; s[e.indexOf(x)] = 0; var _ = x.node2; 0 == --l[t.indexOf(_)] && h.indexOf(_) < 0 && h.push(_) } } ++c, u = h, h = [] } for (p = 0; p < s.length; p++)if (1 === s[p]) throw new Error("Sankey is a DAG, the original data has cycle!"); var b = d > c - 1 ? d : c - 1; a && "left" !== a && function (t, e, n, i) { if ("right" === e) { for (var r = [], o = t, a = 0; o.length;) { for (var s = 0; s < o.length; s++) { var l = o[s]; l.setLayout({ skNodeHeight: a }, !0); for (var u = 0; u < l.inEdges.length; u++) { var h = l.inEdges[u]; r.indexOf(h.node1) < 0 && r.push(h.node1) } } o = r, r = [], ++a } E(t, (function (t) { YL(t) || t.setLayout({ depth: Math.max(0, i - t.getLayout().skNodeHeight) }, !0) })) } else "justify" === e && function (t, e) { E(t, (function (t) { YL(t) || t.outEdges.length || t.setLayout({ depth: e }, !0) })) }(t, i) }(t, a, 0, b); var w = "vertical" === o ? (r - n) / b : (i - n) / b; !function (t, e, n) { E(t, (function (t) { var i = t.getLayout().depth * e; "vertical" === n ? t.setLayout({ y: i }, !0) : t.setLayout({ x: i }, !0) })) }(t, w, o) })(t, e, n, r, o, s, l), function (t, e, n, i, r, o, a) { var s = function (t, e) { var n = [], i = "vertical" === e ? "y" : "x", r = Go(t, (function (t) { return t.getLayout()[i] })); return r.keys.sort((function (t, e) { return t - e })), E(r.keys, (function (t) { n.push(r.buckets.get(t)) })), n }(t, a); (function (t, e, n, i, r, o) { var a = 1 / 0; E(t, (function (t) { var e = t.length, s = 0; E(t, (function (t) { s += t.getLayout().value })); var l = "vertical" === o ? (i - (e - 1) * r) / s : (n - (e - 1) * r) / s; l < a && (a = l) })), E(t, (function (t) { E(t, (function (t, e) { var n = t.getLayout().value * a; "vertical" === o ? (t.setLayout({ x: e }, !0), t.setLayout({ dx: n }, !0)) : (t.setLayout({ y: e }, !0), t.setLayout({ dy: n }, !0)) })) })), E(e, (function (t) { var e = +t.getValue() * a; t.setLayout({ dy: e }, !0) })) })(s, e, n, i, r, a), XL(s, r, n, i, a); for (var l = 1; o > 0; o--)UL(s, l *= .99, a), XL(s, r, n, i, a), tP(s, l, a), XL(s, r, n, i, a) }(t, e, o, r, i, a, s), function (t, e) { var n = "vertical" === e ? "x" : "y"; E(t, (function (t) { t.outEdges.sort((function (t, e) { return t.node2.getLayout()[n] - e.node2.getLayout()[n] })), t.inEdges.sort((function (t, e) { return t.node1.getLayout()[n] - e.node1.getLayout()[n] })) })), E(t, (function (t) { var e = 0, n = 0; E(t.outEdges, (function (t) { t.setLayout({ sy: e }, !0), e += t.getLayout().dy })), E(t.inEdges, (function (t) { t.setLayout({ ty: n }, !0), n += t.getLayout().dy })) })) }(t, s) }(l, u, n, i, o, a, 0 !== B(l, (function (t) { return 0 === t.getLayout().value })).length ? 0 : t.get("layoutIterations"), t.get("orient"), t.get("nodeAlign")) })) } function YL(t) { var e = t.hostGraph.data.getRawDataItem(t.dataIndex); return null != e.depth && e.depth >= 0 } function XL(t, e, n, i, r) { var o = "vertical" === r ? "x" : "y"; E(t, (function (t) { var a, s, l; t.sort((function (t, e) { return t.getLayout()[o] - e.getLayout()[o] })); for (var u = 0, h = t.length, c = "vertical" === r ? "dx" : "dy", p = 0; p < h; p++)(l = u - (s = t[p]).getLayout()[o]) > 0 && (a = s.getLayout()[o] + l, "vertical" === r ? s.setLayout({ x: a }, !0) : s.setLayout({ y: a }, !0)), u = s.getLayout()[o] + s.getLayout()[c] + e; if ((l = u - e - ("vertical" === r ? i : n)) > 0) { a = s.getLayout()[o] - l, "vertical" === r ? s.setLayout({ x: a }, !0) : s.setLayout({ y: a }, !0), u = a; for (p = h - 2; p >= 0; --p)(l = (s = t[p]).getLayout()[o] + s.getLayout()[c] + e - u) > 0 && (a = s.getLayout()[o] - l, "vertical" === r ? s.setLayout({ x: a }, !0) : s.setLayout({ y: a }, !0)), u = s.getLayout()[o] } })) } function UL(t, e, n) { E(t.slice().reverse(), (function (t) { E(t, (function (t) { if (t.outEdges.length) { var i = QL(t.outEdges, ZL, n) / QL(t.outEdges, JL); if (isNaN(i)) { var r = t.outEdges.length; i = r ? QL(t.outEdges, jL, n) / r : 0 } if ("vertical" === n) { var o = t.getLayout().x + (i - $L(t, n)) * e; t.setLayout({ x: o }, !0) } else { var a = t.getLayout().y + (i - $L(t, n)) * e; t.setLayout({ y: a }, !0) } } })) })) } function ZL(t, e) { return $L(t.node2, e) * t.getValue() } function jL(t, e) { return $L(t.node2, e) } function qL(t, e) { return $L(t.node1, e) * t.getValue() } function KL(t, e) { return $L(t.node1, e) } function $L(t, e) { return "vertical" === e ? t.getLayout().x + t.getLayout().dx / 2 : t.getLayout().y + t.getLayout().dy / 2 } function JL(t) { return t.getValue() } function QL(t, e, n) { for (var i = 0, r = t.length, o = -1; ++o < r;) { var a = +e(t[o], n); isNaN(a) || (i += a) } return i } function tP(t, e, n) { E(t, (function (t) { E(t, (function (t) { if (t.inEdges.length) { var i = QL(t.inEdges, qL, n) / QL(t.inEdges, JL); if (isNaN(i)) { var r = t.inEdges.length; i = r ? QL(t.inEdges, KL, n) / r : 0 } if ("vertical" === n) { var o = t.getLayout().x + (i - $L(t, n)) * e; t.setLayout({ x: o }, !0) } else { var a = t.getLayout().y + (i - $L(t, n)) * e; t.setLayout({ y: a }, !0) } } })) })) } function eP(t) { t.eachSeriesByType("sankey", (function (t) { var e = t.getGraph(), n = e.nodes, i = e.edges; if (n.length) { var r = 1 / 0, o = -1 / 0; E(n, (function (t) { var e = t.getLayout().value; e < r && (r = e), e > o && (o = e) })), E(n, (function (e) { var n = new _D({ type: "color", mappingMethod: "linear", dataExtent: [r, o], visual: t.get("color") }).mapValueToVisual(e.getLayout().value), i = e.getModel().get(["itemStyle", "color"]); null != i ? (e.setVisual("color", i), e.setVisual("style", { fill: i })) : (e.setVisual("color", n), e.setVisual("style", { fill: n })) })) } i.length && E(i, (function (t) { var e = t.getModel().get("lineStyle"); t.setVisual("style", e) })) })) } var nP = function () { function t() { } return t.prototype.getInitialData = function (t, e) { var n, i, r = e.getComponent("xAxis", this.get("xAxisIndex")), o = e.getComponent("yAxis", this.get("yAxisIndex")), a = r.get("type"), s = o.get("type"); "category" === a ? (t.layout = "horizontal", n = r.getOrdinalMeta(), i = !0) : "category" === s ? (t.layout = "vertical", n = o.getOrdinalMeta(), i = !0) : t.layout = t.layout || "horizontal"; var l = ["x", "y"], u = "horizontal" === t.layout ? 0 : 1, h = this._baseAxisDim = l[u], c = l[1 - u], p = [r, o], d = p[u].get("type"), f = p[1 - u].get("type"), g = t.data; if (g && i) { var y = []; E(g, (function (t, e) { var n; Y(t) ? (n = t.slice(), t.unshift(e)) : Y(t.value) ? ((n = A({}, t)).value = n.value.slice(), t.value.unshift(e)) : n = t, y.push(n) })), t.data = y } var v = this.defaultValueDimensions, m = [{ name: h, type: Gm(d), ordinalMeta: n, otherDims: { tooltip: !1, itemName: 0 }, dimsDef: ["base"] }, { name: c, type: Gm(f), dimsDef: v.slice() }]; return MM(this, { coordDimensions: m, dimensionsCount: v.length + 1, encodeDefaulter: H($p, m, this) }) }, t.prototype.getBaseAxis = function () { var t = this._baseAxisDim; return this.ecModel.getComponent(t + "Axis", this.get(t + "AxisIndex")).axis }, t }(), iP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.defaultValueDimensions = [{ name: "min", defaultTooltip: !0 }, { name: "Q1", defaultTooltip: !0 }, { name: "median", defaultTooltip: !0 }, { name: "Q3", defaultTooltip: !0 }, { name: "max", defaultTooltip: !0 }], n.visualDrawType = "stroke", n } return n(e, t), e.type = "series.boxplot", e.dependencies = ["xAxis", "yAxis", "grid"], e.defaultOption = { z: 2, coordinateSystem: "cartesian2d", legendHoverLink: !0, layout: null, boxWidth: [7, 50], itemStyle: { color: "#fff", borderWidth: 1 }, emphasis: { scale: !0, itemStyle: { borderWidth: 2, shadowBlur: 5, shadowOffsetX: 1, shadowOffsetY: 1, shadowColor: "rgba(0,0,0,0.2)" } }, animationDuration: 800 }, e }(mg); R(iP, nP, !0); var rP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = t.getData(), r = this.group, o = this._data; this._data || r.removeAll(); var a = "horizontal" === t.get("layout") ? 1 : 0; i.diff(o).add((function (t) { if (i.hasValue(t)) { var e = sP(i.getItemLayout(t), i, t, a, !0); i.setItemGraphicEl(t, e), r.add(e) } })).update((function (t, e) { var n = o.getItemGraphicEl(e); if (i.hasValue(t)) { var s = i.getItemLayout(t); n ? (_h(n), lP(s, n, i, t)) : n = sP(s, i, t, a), r.add(n), i.setItemGraphicEl(t, n) } else r.remove(n) })).remove((function (t) { var e = o.getItemGraphicEl(t); e && r.remove(e) })).execute(), this._data = i }, e.prototype.remove = function (t) { var e = this.group, n = this._data; this._data = null, n && n.eachItemGraphicEl((function (t) { t && e.remove(t) })) }, e.type = "boxplot", e }(kg), oP = function () { }, aP = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "boxplotBoxPath", n } return n(e, t), e.prototype.getDefaultShape = function () { return new oP }, e.prototype.buildPath = function (t, e) { var n = e.points, i = 0; for (t.moveTo(n[i][0], n[i][1]), i++; i < 4; i++)t.lineTo(n[i][0], n[i][1]); for (t.closePath(); i < n.length; i++)t.moveTo(n[i][0], n[i][1]), i++, t.lineTo(n[i][0], n[i][1]) }, e }(Is); function sP(t, e, n, i, r) { var o = t.ends, a = new aP({ shape: { points: r ? uP(o, i, t) : o } }); return lP(t, a, e, n, r), a } function lP(t, e, n, i, r) { var o = n.hostModel; (0, Kh[r ? "initProps" : "updateProps"])(e, { shape: { points: t.ends } }, o, i), e.useStyle(n.getItemVisual(i, "style")), e.style.strokeNoScale = !0, e.z2 = 100; var a = n.getItemModel(i), s = a.getModel("emphasis"); jl(e, a), Yl(e, s.get("focus"), s.get("blurScope"), s.get("disabled")) } function uP(t, e, n) { return z(t, (function (t) { return (t = t.slice())[e] = n.initBaseline, t })) } var hP = E; function cP(t) { var e = function (t) { var e = [], n = []; return t.eachSeriesByType("boxplot", (function (t) { var i = t.getBaseAxis(), r = P(n, i); r < 0 && (r = n.length, n[r] = i, e[r] = { axis: i, seriesModels: [] }), e[r].seriesModels.push(t) })), e }(t); hP(e, (function (t) { var e = t.seriesModels; e.length && (!function (t) { var e, n = t.axis, i = t.seriesModels, r = i.length, o = t.boxWidthList = [], a = t.boxOffsetList = [], s = []; if ("category" === n.type) e = n.getBandWidth(); else { var l = 0; hP(i, (function (t) { l = Math.max(l, t.getData().count()) })); var u = n.getExtent(); e = Math.abs(u[1] - u[0]) / l } hP(i, (function (t) { var n = t.get("boxWidth"); Y(n) || (n = [n, n]), s.push([Ur(n[0], e) || 0, Ur(n[1], e) || 0]) })); var h = .8 * e - 2, c = h / r * .3, p = (h - c * (r - 1)) / r, d = p / 2 - h / 2; hP(i, (function (t, e) { a.push(d), d += c + p, o.push(Math.min(Math.max(p, s[e][0]), s[e][1])) })) }(t), hP(e, (function (e, n) { !function (t, e, n) { var i = t.coordinateSystem, r = t.getData(), o = n / 2, a = "horizontal" === t.get("layout") ? 0 : 1, s = 1 - a, l = ["x", "y"], u = r.mapDimension(l[a]), h = r.mapDimensionsAll(l[s]); if (null == u || h.length < 5) return; for (var c = 0; c < r.count(); c++) { var p = r.get(u, c), d = x(p, h[2], c), f = x(p, h[0], c), g = x(p, h[1], c), y = x(p, h[3], c), v = x(p, h[4], c), m = []; _(m, g, !1), _(m, y, !0), m.push(f, g, v, y), b(m, f), b(m, v), b(m, d), r.setItemLayout(c, { initBaseline: d[s], ends: m }) } function x(t, n, o) { var l, u = r.get(n, o), h = []; return h[a] = t, h[s] = u, isNaN(t) || isNaN(u) ? l = [NaN, NaN] : (l = i.dataToPoint(h))[a] += e, l } function _(t, e, n) { var i = e.slice(), r = e.slice(); i[a] += o, r[a] -= o, n ? t.push(i, r) : t.push(r, i) } function b(t, e) { var n = e.slice(), i = e.slice(); n[a] -= o, i[a] += o, t.push(n, i) } }(e, t.boxOffsetList[n], t.boxWidthList[n]) }))) })) } var pP = { type: "echarts:boxplot", transform: function (t) { var e = t.upstream; if (e.sourceFormat !== Fp) { var n = ""; 0, vo(n) } var i = function (t, e) { for (var n = [], i = [], r = (e = e || {}).boundIQR, o = "none" === r || 0 === r, a = 0; a < t.length; a++) { var s = jr(t[a].slice()), l = lo(s, .25), u = lo(s, .5), h = lo(s, .75), c = s[0], p = s[s.length - 1], d = (null == r ? 1.5 : r) * (h - l), f = o ? c : Math.max(c, l - d), g = o ? p : Math.min(p, h + d), y = e.itemNameFormatter, v = X(y) ? y({ value: a }) : U(y) ? y.replace("{value}", a + "") : a + ""; n.push([v, f, l, u, h, g]); for (var m = 0; m < s.length; m++) { var x = s[m]; if (x < f || x > g) { var _ = [v, x]; i.push(_) } } } return { boxData: n, outliers: i } }(e.getRawData(), t.config); return [{ dimensions: ["ItemName", "Low", "Q1", "Q2", "Q3", "High"], data: i.boxData }, { data: i.outliers }] } }; var dP = ["color", "borderColor"], fP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { this.group.removeClipPath(), this._progressiveEls = null, this._updateDrawMode(t), this._isLargeDraw ? this._renderLarge(t) : this._renderNormal(t) }, e.prototype.incrementalPrepareRender = function (t, e, n) { this._clear(), this._updateDrawMode(t) }, e.prototype.incrementalRender = function (t, e, n, i) { this._progressiveEls = [], this._isLargeDraw ? this._incrementalRenderLarge(t, e) : this._incrementalRenderNormal(t, e) }, e.prototype.eachRendered = function (t) { qh(this._progressiveEls || this.group, t) }, e.prototype._updateDrawMode = function (t) { var e = t.pipelineContext.large; null != this._isLargeDraw && e === this._isLargeDraw || (this._isLargeDraw = e, this._clear()) }, e.prototype._renderNormal = function (t) { var e = t.getData(), n = this._data, i = this.group, r = e.getLayout("isSimpleBox"), o = t.get("clip", !0), a = t.coordinateSystem, s = a.getArea && a.getArea(); this._data || i.removeAll(), e.diff(n).add((function (n) { if (e.hasValue(n)) { var a = e.getItemLayout(n); if (o && mP(s, a)) return; var l = vP(a, n, !0); gh(l, { shape: { points: a.ends } }, t, n), xP(l, e, n, r), i.add(l), e.setItemGraphicEl(n, l) } })).update((function (a, l) { var u = n.getItemGraphicEl(l); if (e.hasValue(a)) { var h = e.getItemLayout(a); o && mP(s, h) ? i.remove(u) : (u ? (fh(u, { shape: { points: h.ends } }, t, a), _h(u)) : u = vP(h), xP(u, e, a, r), i.add(u), e.setItemGraphicEl(a, u)) } else i.remove(u) })).remove((function (t) { var e = n.getItemGraphicEl(t); e && i.remove(e) })).execute(), this._data = e }, e.prototype._renderLarge = function (t) { this._clear(), SP(t, this.group); var e = t.get("clip", !0) ? SS(t.coordinateSystem, !1, t) : null; e ? this.group.setClipPath(e) : this.group.removeClipPath() }, e.prototype._incrementalRenderNormal = function (t, e) { for (var n, i = e.getData(), r = i.getLayout("isSimpleBox"); null != (n = t.next());) { var o = vP(i.getItemLayout(n)); xP(o, i, n, r), o.incremental = !0, this.group.add(o), this._progressiveEls.push(o) } }, e.prototype._incrementalRenderLarge = function (t, e) { SP(e, this.group, this._progressiveEls, !0) }, e.prototype.remove = function (t) { this._clear() }, e.prototype._clear = function () { this.group.removeAll(), this._data = null }, e.type = "candlestick", e }(kg), gP = function () { }, yP = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "normalCandlestickBox", n } return n(e, t), e.prototype.getDefaultShape = function () { return new gP }, e.prototype.buildPath = function (t, e) { var n = e.points; this.__simpleBox ? (t.moveTo(n[4][0], n[4][1]), t.lineTo(n[6][0], n[6][1])) : (t.moveTo(n[0][0], n[0][1]), t.lineTo(n[1][0], n[1][1]), t.lineTo(n[2][0], n[2][1]), t.lineTo(n[3][0], n[3][1]), t.closePath(), t.moveTo(n[4][0], n[4][1]), t.lineTo(n[5][0], n[5][1]), t.moveTo(n[6][0], n[6][1]), t.lineTo(n[7][0], n[7][1])) }, e }(Is); function vP(t, e, n) { var i = t.ends; return new yP({ shape: { points: n ? _P(i, t) : i }, z2: 100 }) } function mP(t, e) { for (var n = !0, i = 0; i < e.ends.length; i++)if (t.contain(e.ends[i][0], e.ends[i][1])) { n = !1; break } return n } function xP(t, e, n, i) { var r = e.getItemModel(n); t.useStyle(e.getItemVisual(n, "style")), t.style.strokeNoScale = !0, t.__simpleBox = i, jl(t, r) } function _P(t, e) { return z(t, (function (t) { return (t = t.slice())[1] = e.initBaseline, t })) } var bP = function () { }, wP = function (t) { function e(e) { var n = t.call(this, e) || this; return n.type = "largeCandlestickBox", n } return n(e, t), e.prototype.getDefaultShape = function () { return new bP }, e.prototype.buildPath = function (t, e) { for (var n = e.points, i = 0; i < n.length;)if (this.__sign === n[i++]) { var r = n[i++]; t.moveTo(r, n[i++]), t.lineTo(r, n[i++]) } else i += 3 }, e }(Is); function SP(t, e, n, i) { var r = t.getData().getLayout("largePoints"), o = new wP({ shape: { points: r }, __sign: 1, ignoreCoarsePointer: !0 }); e.add(o); var a = new wP({ shape: { points: r }, __sign: -1, ignoreCoarsePointer: !0 }); e.add(a); var s = new wP({ shape: { points: r }, __sign: 0, ignoreCoarsePointer: !0 }); e.add(s), MP(1, o, t), MP(-1, a, t), MP(0, s, t), i && (o.incremental = !0, a.incremental = !0), n && n.push(o, a) } function MP(t, e, n, i) { var r = n.get(["itemStyle", t > 0 ? "borderColor" : "borderColor0"]) || n.get(["itemStyle", t > 0 ? "color" : "color0"]); 0 === t && (r = n.get(["itemStyle", "borderColorDoji"])); var o = n.getModel("itemStyle").getItemStyle(dP); e.useStyle(o), e.style.fill = null, e.style.stroke = r } var IP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.defaultValueDimensions = [{ name: "open", defaultTooltip: !0 }, { name: "close", defaultTooltip: !0 }, { name: "lowest", defaultTooltip: !0 }, { name: "highest", defaultTooltip: !0 }], n } return n(e, t), e.prototype.getShadowDim = function () { return "open" }, e.prototype.brushSelector = function (t, e, n) { var i = e.getItemLayout(t); return i && n.rect(i.brushRect) }, e.type = "series.candlestick", e.dependencies = ["xAxis", "yAxis", "grid"], e.defaultOption = { z: 2, coordinateSystem: "cartesian2d", legendHoverLink: !0, layout: null, clip: !0, itemStyle: { color: "#eb5454", color0: "#47b262", borderColor: "#eb5454", borderColor0: "#47b262", borderColorDoji: null, borderWidth: 1 }, emphasis: { scale: !0, itemStyle: { borderWidth: 2 } }, barMaxWidth: null, barMinWidth: null, barWidth: null, large: !0, largeThreshold: 600, progressive: 3e3, progressiveThreshold: 1e4, progressiveChunkMode: "mod", animationEasing: "linear", animationDuration: 300 }, e }(mg); function TP(t) { t && Y(t.series) && E(t.series, (function (t) { q(t) && "k" === t.type && (t.type = "candlestick") })) } R(IP, nP, !0); var CP = ["itemStyle", "borderColor"], DP = ["itemStyle", "borderColor0"], AP = ["itemStyle", "borderColorDoji"], kP = ["itemStyle", "color"], LP = ["itemStyle", "color0"], PP = { seriesType: "candlestick", plan: Cg(), performRawSeries: !0, reset: function (t, e) { function n(t, e) { return e.get(t > 0 ? kP : LP) } function i(t, e) { return e.get(0 === t ? AP : t > 0 ? CP : DP) } if (!e.isSeriesFiltered(t)) return !t.pipelineContext.large && { progress: function (t, e) { for (var r; null != (r = t.next());) { var o = e.getItemModel(r), a = e.getItemLayout(r).sign, s = o.getItemStyle(); s.fill = n(a, o), s.stroke = i(a, o) || s.fill, A(e.ensureUniqueItemVisual(r, "style"), s) } } } } }, OP = { seriesType: "candlestick", plan: Cg(), reset: function (t) { var e = t.coordinateSystem, n = t.getData(), i = function (t, e) { var n, i = t.getBaseAxis(), r = "category" === i.type ? i.getBandWidth() : (n = i.getExtent(), Math.abs(n[1] - n[0]) / e.count()), o = Ur(rt(t.get("barMaxWidth"), r), r), a = Ur(rt(t.get("barMinWidth"), 1), r), s = t.get("barWidth"); return null != s ? Ur(s, r) : Math.max(Math.min(r / 2, o), a) }(t, n), r = ["x", "y"], o = n.getDimensionIndex(n.mapDimension(r[0])), a = z(n.mapDimensionsAll(r[1]), n.getDimensionIndex, n), s = a[0], l = a[1], u = a[2], h = a[3]; if (n.setLayout({ candleWidth: i, isSimpleBox: i <= 1.3 }), !(o < 0 || a.length < 4)) return { progress: t.pipelineContext.large ? function (n, i) { var r, a, c = Ex(4 * n.count), p = 0, d = [], f = [], g = i.getStore(), y = !!t.get(["itemStyle", "borderColorDoji"]); for (; null != (a = n.next());) { var v = g.get(o, a), m = g.get(s, a), x = g.get(l, a), _ = g.get(u, a), b = g.get(h, a); isNaN(v) || isNaN(_) || isNaN(b) ? (c[p++] = NaN, p += 3) : (c[p++] = RP(g, a, m, x, l, y), d[0] = v, d[1] = _, r = e.dataToPoint(d, null, f), c[p++] = r ? r[0] : NaN, c[p++] = r ? r[1] : NaN, d[1] = b, r = e.dataToPoint(d, null, f), c[p++] = r ? r[1] : NaN) } i.setLayout("largePoints", c) } : function (t, n) { var r, a = n.getStore(); for (; null != (r = t.next());) { var c = a.get(o, r), p = a.get(s, r), d = a.get(l, r), f = a.get(u, r), g = a.get(h, r), y = Math.min(p, d), v = Math.max(p, d), m = M(y, c), x = M(v, c), _ = M(f, c), b = M(g, c), w = []; I(w, x, 0), I(w, m, 1), w.push(C(b), C(x), C(_), C(m)); var S = !!n.getItemModel(r).get(["itemStyle", "borderColorDoji"]); n.setItemLayout(r, { sign: RP(a, r, p, d, l, S), initBaseline: p > d ? x[1] : m[1], ends: w, brushRect: T(f, g, c) }) } function M(t, n) { var i = []; return i[0] = n, i[1] = t, isNaN(n) || isNaN(t) ? [NaN, NaN] : e.dataToPoint(i) } function I(t, e, n) { var r = e.slice(), o = e.slice(); r[0] = Nh(r[0] + i / 2, 1, !1), o[0] = Nh(o[0] - i / 2, 1, !0), n ? t.push(r, o) : t.push(o, r) } function T(t, e, n) { var r = M(t, n), o = M(e, n); return r[0] -= i / 2, o[0] -= i / 2, { x: r[0], y: r[1], width: i, height: o[1] - r[1] } } function C(t) { return t[0] = Nh(t[0], 1), t } } } } }; function RP(t, e, n, i, r, o) { return n > i ? -1 : n < i ? 1 : o ? 0 : e > 0 ? t.get(r, e - 1) <= i ? 1 : -1 : 1 } function NP(t, e) { var n = e.rippleEffectColor || e.color; t.eachChild((function (t) { t.attr({ z: e.z, zlevel: e.zlevel, style: { stroke: "stroke" === e.brushType ? n : null, fill: "fill" === e.brushType ? n : null } }) })) } var EP = function (t) { function e(e, n) { var i = t.call(this) || this, r = new oS(e, n), o = new zr; return i.add(r), i.add(o), i.updateData(e, n), i } return n(e, t), e.prototype.stopEffectAnimation = function () { this.childAt(1).removeAll() }, e.prototype.startEffectAnimation = function (t) { for (var e = t.symbolType, n = t.color, i = t.rippleNumber, r = this.childAt(1), o = 0; o < i; o++) { var a = Wy(e, -1, -1, 2, 2, n); a.attr({ style: { strokeNoScale: !0 }, z2: 99, silent: !0, scaleX: .5, scaleY: .5 }); var s = -o / i * t.period + t.effectOffset; a.animate("", !0).when(t.period, { scaleX: t.rippleScale / 2, scaleY: t.rippleScale / 2 }).delay(s).start(), a.animateStyle(!0).when(t.period, { opacity: 0 }).delay(s).start(), r.add(a) } NP(r, t) }, e.prototype.updateEffectAnimation = function (t) { for (var e = this._effectCfg, n = this.childAt(1), i = ["symbolType", "period", "rippleScale", "rippleNumber"], r = 0; r < i.length; r++) { var o = i[r]; if (e[o] !== t[o]) return this.stopEffectAnimation(), void this.startEffectAnimation(t) } NP(n, t) }, e.prototype.highlight = function () { kl(this) }, e.prototype.downplay = function () { Ll(this) }, e.prototype.getSymbolType = function () { var t = this.childAt(0); return t && t.getSymbolType() }, e.prototype.updateData = function (t, e) { var n = this, i = t.hostModel; this.childAt(0).updateData(t, e); var r = this.childAt(1), o = t.getItemModel(e), a = t.getItemVisual(e, "symbol"), s = Hy(t.getItemVisual(e, "symbolSize")), l = t.getItemVisual(e, "style"), u = l && l.fill, h = o.getModel("emphasis"); r.setScale(s), r.traverse((function (t) { t.setStyle("fill", u) })); var c = Yy(t.getItemVisual(e, "symbolOffset"), s); c && (r.x = c[0], r.y = c[1]); var p = t.getItemVisual(e, "symbolRotate"); r.rotation = (p || 0) * Math.PI / 180 || 0; var d = {}; d.showEffectOn = i.get("showEffectOn"), d.rippleScale = o.get(["rippleEffect", "scale"]), d.brushType = o.get(["rippleEffect", "brushType"]), d.period = 1e3 * o.get(["rippleEffect", "period"]), d.effectOffset = e / t.count(), d.z = i.getShallow("z") || 0, d.zlevel = i.getShallow("zlevel") || 0, d.symbolType = a, d.color = u, d.rippleEffectColor = o.get(["rippleEffect", "color"]), d.rippleNumber = o.get(["rippleEffect", "number"]), "render" === d.showEffectOn ? (this._effectCfg ? this.updateEffectAnimation(d) : this.startEffectAnimation(d), this._effectCfg = d) : (this._effectCfg = null, this.stopEffectAnimation(), this.onHoverStateChange = function (t) { "emphasis" === t ? "render" !== d.showEffectOn && n.startEffectAnimation(d) : "normal" === t && "render" !== d.showEffectOn && n.stopEffectAnimation() }), this._effectCfg = d, Yl(this, h.get("focus"), h.get("blurScope"), h.get("disabled")) }, e.prototype.fadeOut = function (t) { t && t() }, e }(zr), zP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function () { this._symbolDraw = new hS(EP) }, e.prototype.render = function (t, e, n) { var i = t.getData(), r = this._symbolDraw; r.updateData(i, { clipShape: this._getClipShape(t) }), this.group.add(r.group) }, e.prototype._getClipShape = function (t) { var e = t.coordinateSystem, n = e && e.getArea && e.getArea(); return t.get("clip", !0) ? n : null }, e.prototype.updateTransform = function (t, e, n) { var i = t.getData(); this.group.dirty(); var r = ES("").reset(t, e, n); r.progress && r.progress({ start: 0, end: i.count(), count: i.count() }, i), this._symbolDraw.updateLayout() }, e.prototype._updateGroupTransform = function (t) { var e = t.coordinateSystem; e && e.getRoamTransform && (this.group.transform = Te(e.getRoamTransform()), this.group.decomposeTransform()) }, e.prototype.remove = function (t, e) { this._symbolDraw && this._symbolDraw.remove(!0) }, e.type = "effectScatter", e }(kg), VP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.hasSymbolVisual = !0, n } return n(e, t), e.prototype.getInitialData = function (t, e) { return vx(null, this, { useEncodeDefaulter: !0 }) }, e.prototype.brushSelector = function (t, e, n) { return n.point(e.getItemLayout(t)) }, e.type = "series.effectScatter", e.dependencies = ["grid", "polar"], e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, legendHoverLink: !0, effectType: "ripple", progressive: 0, showEffectOn: "render", clip: !0, rippleEffect: { period: 4, scale: 2.5, brushType: "fill", number: 3 }, universalTransition: { divideShape: "clone" }, symbolSize: 10 }, e }(mg); var BP = function (t) { function e(e, n, i) { var r = t.call(this) || this; return r.add(r.createLine(e, n, i)), r._updateEffectSymbol(e, n), r } return n(e, t), e.prototype.createLine = function (t, e, n) { return new OA(t, e, n) }, e.prototype._updateEffectSymbol = function (t, e) { var n = t.getItemModel(e).getModel("effect"), i = n.get("symbolSize"), r = n.get("symbol"); Y(i) || (i = [i, i]); var o = t.getItemVisual(e, "style"), a = n.get("color") || o && o.stroke, s = this.childAt(1); this._symbolType !== r && (this.remove(s), (s = Wy(r, -.5, -.5, 1, 1, a)).z2 = 100, s.culling = !0, this.add(s)), s && (s.setStyle("shadowColor", a), s.setStyle(n.getItemStyle(["color"])), s.scaleX = i[0], s.scaleY = i[1], s.setColor(a), this._symbolType = r, this._symbolScale = i, this._updateEffectAnimation(t, n, e)) }, e.prototype._updateEffectAnimation = function (t, e, n) { var i = this.childAt(1); if (i) { var r = t.getItemLayout(n), o = 1e3 * e.get("period"), a = e.get("loop"), s = e.get("roundTrip"), l = e.get("constantSpeed"), u = it(e.get("delay"), (function (e) { return e / t.count() * o / 3 })); if (i.ignore = !0, this._updateAnimationPoints(i, r), l > 0 && (o = this._getLineLength(i) / l * 1e3), o !== this._period || a !== this._loop || s !== this._roundTrip) { i.stopAnimation(); var h = void 0; h = X(u) ? u(n) : u, i.__t > 0 && (h = -o * i.__t), this._animateSymbol(i, o, h, a, s) } this._period = o, this._loop = a, this._roundTrip = s } }, e.prototype._animateSymbol = function (t, e, n, i, r) { if (e > 0) { t.__t = 0; var o = this, a = t.animate("", i).when(r ? 2 * e : e, { __t: r ? 2 : 1 }).delay(n).during((function () { o._updateSymbolPosition(t) })); i || a.done((function () { o.remove(t) })), a.start() } }, e.prototype._getLineLength = function (t) { return Vt(t.__p1, t.__cp1) + Vt(t.__cp1, t.__p2) }, e.prototype._updateAnimationPoints = function (t, e) { t.__p1 = e[0], t.__p2 = e[1], t.__cp1 = e[2] || [(e[0][0] + e[1][0]) / 2, (e[0][1] + e[1][1]) / 2] }, e.prototype.updateData = function (t, e, n) { this.childAt(0).updateData(t, e, n), this._updateEffectSymbol(t, e) }, e.prototype._updateSymbolPosition = function (t) { var e = t.__p1, n = t.__p2, i = t.__cp1, r = t.__t < 1 ? t.__t : 2 - t.__t, o = [t.x, t.y], a = o.slice(), s = In, l = Tn; o[0] = s(e[0], i[0], n[0], r), o[1] = s(e[1], i[1], n[1], r); var u = t.__t < 1 ? l(e[0], i[0], n[0], r) : l(n[0], i[0], e[0], 1 - r), h = t.__t < 1 ? l(e[1], i[1], n[1], r) : l(n[1], i[1], e[1], 1 - r); t.rotation = -Math.atan2(h, u) - Math.PI / 2, "line" !== this._symbolType && "rect" !== this._symbolType && "roundRect" !== this._symbolType || (void 0 !== t.__lastT && t.__lastT < t.__t ? (t.scaleY = 1.05 * Vt(a, o), 1 === r && (o[0] = a[0] + (o[0] - a[0]) / 2, o[1] = a[1] + (o[1] - a[1]) / 2)) : 1 === t.__lastT ? t.scaleY = 2 * Vt(e, o) : t.scaleY = this._symbolScale[1]), t.__lastT = t.__t, t.ignore = !1, t.x = o[0], t.y = o[1] }, e.prototype.updateLayout = function (t, e) { this.childAt(0).updateLayout(t, e); var n = t.getItemModel(e).getModel("effect"); this._updateEffectAnimation(t, n, e) }, e }(zr), FP = function (t) { function e(e, n, i) { var r = t.call(this) || this; return r._createPolyline(e, n, i), r } return n(e, t), e.prototype._createPolyline = function (t, e, n) { var i = t.getItemLayout(e), r = new Yu({ shape: { points: i } }); this.add(r), this._updateCommonStl(t, e, n) }, e.prototype.updateData = function (t, e, n) { var i = t.hostModel; fh(this.childAt(0), { shape: { points: t.getItemLayout(e) } }, i, e), this._updateCommonStl(t, e, n) }, e.prototype._updateCommonStl = function (t, e, n) { var i = this.childAt(0), r = t.getItemModel(e), o = n && n.emphasisLineStyle, a = n && n.focus, s = n && n.blurScope, l = n && n.emphasisDisabled; if (!n || t.hasItemOption) { var u = r.getModel("emphasis"); o = u.getModel("lineStyle").getLineStyle(), l = u.get("disabled"), a = u.get("focus"), s = u.get("blurScope") } i.useStyle(t.getItemVisual(e, "style")), i.style.fill = null, i.style.strokeNoScale = !0, i.ensureState("emphasis").style = o, Yl(this, a, s, l) }, e.prototype.updateLayout = function (t, e) { this.childAt(0).setShape("points", t.getItemLayout(e)) }, e }(zr), GP = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e._lastFrame = 0, e._lastFramePercent = 0, e } return n(e, t), e.prototype.createLine = function (t, e, n) { return new FP(t, e, n) }, e.prototype._updateAnimationPoints = function (t, e) { this._points = e; for (var n = [0], i = 0, r = 1; r < e.length; r++) { var o = e[r - 1], a = e[r]; i += Vt(o, a), n.push(i) } if (0 !== i) { for (r = 0; r < n.length; r++)n[r] /= i; this._offsets = n, this._length = i } else this._length = 0 }, e.prototype._getLineLength = function () { return this._length }, e.prototype._updateSymbolPosition = function (t) { var e = t.__t < 1 ? t.__t : 2 - t.__t, n = this._points, i = this._offsets, r = n.length; if (i) { var o, a = this._lastFrame; if (e < this._lastFramePercent) { for (o = Math.min(a + 1, r - 1); o >= 0 && !(i[o] <= e); o--); o = Math.min(o, r - 2) } else { for (o = a; o < r && !(i[o] > e); o++); o = Math.min(o - 1, r - 2) } var s = (e - i[o]) / (i[o + 1] - i[o]), l = n[o], u = n[o + 1]; t.x = l[0] * (1 - s) + s * u[0], t.y = l[1] * (1 - s) + s * u[1]; var h = t.__t < 1 ? u[0] - l[0] : l[0] - u[0], c = t.__t < 1 ? u[1] - l[1] : l[1] - u[1]; t.rotation = -Math.atan2(c, h) - Math.PI / 2, this._lastFrame = o, this._lastFramePercent = e, t.ignore = !1 } }, e }(BP), WP = function () { this.polyline = !1, this.curveness = 0, this.segs = [] }, HP = function (t) { function e(e) { var n = t.call(this, e) || this; return n._off = 0, n.hoverDataIdx = -1, n } return n(e, t), e.prototype.reset = function () { this.notClear = !1, this._off = 0 }, e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null } }, e.prototype.getDefaultShape = function () { return new WP }, e.prototype.buildPath = function (t, e) { var n, i = e.segs, r = e.curveness; if (e.polyline) for (n = this._off; n < i.length;) { var o = i[n++]; if (o > 0) { t.moveTo(i[n++], i[n++]); for (var a = 1; a < o; a++)t.lineTo(i[n++], i[n++]) } } else for (n = this._off; n < i.length;) { var s = i[n++], l = i[n++], u = i[n++], h = i[n++]; if (t.moveTo(s, l), r > 0) { var c = (s + u) / 2 - (l - h) * r, p = (l + h) / 2 - (u - s) * r; t.quadraticCurveTo(c, p, u, h) } else t.lineTo(u, h) } this.incremental && (this._off = n, this.notClear = !0) }, e.prototype.findDataIndex = function (t, e) { var n = this.shape, i = n.segs, r = n.curveness, o = this.style.lineWidth; if (n.polyline) for (var a = 0, s = 0; s < i.length;) { var l = i[s++]; if (l > 0) for (var u = i[s++], h = i[s++], c = 1; c < l; c++) { if (as(u, h, p = i[s++], d = i[s++], o, t, e)) return a } a++ } else for (a = 0, s = 0; s < i.length;) { u = i[s++], h = i[s++]; var p = i[s++], d = i[s++]; if (r > 0) { if (ls(u, h, (u + p) / 2 - (h - d) * r, (h + d) / 2 - (p - u) * r, p, d, o, t, e)) return a } else if (as(u, h, p, d, o, t, e)) return a; a++ } return -1 }, e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e), i = this.getBoundingRect(); return t = n[0], e = n[1], i.contain(t, e) ? (this.hoverDataIdx = this.findDataIndex(t, e)) >= 0 : (this.hoverDataIdx = -1, !1) }, e.prototype.getBoundingRect = function () { var t = this._rect; if (!t) { for (var e = this.shape.segs, n = 1 / 0, i = 1 / 0, r = -1 / 0, o = -1 / 0, a = 0; a < e.length;) { var s = e[a++], l = e[a++]; n = Math.min(s, n), r = Math.max(s, r), i = Math.min(l, i), o = Math.max(l, o) } t = this._rect = new ze(n, i, r, o) } return t }, e }(Is), YP = function () { function t() { this.group = new zr } return t.prototype.updateData = function (t) { this._clear(); var e = this._create(); e.setShape({ segs: t.getLayout("linesPoints") }), this._setCommon(e, t) }, t.prototype.incrementalPrepareUpdate = function (t) { this.group.removeAll(), this._clear() }, t.prototype.incrementalUpdate = function (t, e) { var n = this._newAdded[0], i = e.getLayout("linesPoints"), r = n && n.shape.segs; if (r && r.length < 2e4) { var o = r.length, a = new Float32Array(o + i.length); a.set(r), a.set(i, o), n.setShape({ segs: a }) } else { this._newAdded = []; var s = this._create(); s.incremental = !0, s.setShape({ segs: i }), this._setCommon(s, e), s.__startIndex = t.start } }, t.prototype.remove = function () { this._clear() }, t.prototype.eachRendered = function (t) { this._newAdded[0] && t(this._newAdded[0]) }, t.prototype._create = function () { var t = new HP({ cursor: "default", ignoreCoarsePointer: !0 }); return this._newAdded.push(t), this.group.add(t), t }, t.prototype._setCommon = function (t, e, n) { var i = e.hostModel; t.setShape({ polyline: i.get("polyline"), curveness: i.get(["lineStyle", "curveness"]) }), t.useStyle(i.getModel("lineStyle").getLineStyle()), t.style.strokeNoScale = !0; var r = e.getVisual("style"); r && r.stroke && t.setStyle("stroke", r.stroke), t.setStyle("fill", null); var o = Qs(t); o.seriesIndex = i.seriesIndex, t.on("mousemove", (function (e) { o.dataIndex = null; var n = t.hoverDataIdx; n > 0 && (o.dataIndex = n + t.__startIndex) })) }, t.prototype._clear = function () { this._newAdded = [], this.group.removeAll() }, t }(), XP = { seriesType: "lines", plan: Cg(), reset: function (t) { var e = t.coordinateSystem; if (e) { var n = t.get("polyline"), i = t.pipelineContext.large; return { progress: function (r, o) { var a = []; if (i) { var s = void 0, l = r.end - r.start; if (n) { for (var u = 0, h = r.start; h < r.end; h++)u += t.getLineCoordsCount(h); s = new Float32Array(l + 2 * u) } else s = new Float32Array(4 * l); var c = 0, p = []; for (h = r.start; h < r.end; h++) { var d = t.getLineCoords(h, a); n && (s[c++] = d); for (var f = 0; f < d; f++)p = e.dataToPoint(a[f], !1, p), s[c++] = p[0], s[c++] = p[1] } o.setLayout("linesPoints", s) } else for (h = r.start; h < r.end; h++) { var g = o.getItemModel(h), y = (d = t.getLineCoords(h, a), []); if (n) for (var v = 0; v < d; v++)y.push(e.dataToPoint(a[v])); else { y[0] = e.dataToPoint(a[0]), y[1] = e.dataToPoint(a[1]); var m = g.get(["lineStyle", "curveness"]); +m && (y[2] = [(y[0][0] + y[1][0]) / 2 - (y[0][1] - y[1][1]) * m, (y[0][1] + y[1][1]) / 2 - (y[1][0] - y[0][0]) * m]) } o.setItemLayout(h, y) } } } } } }, UP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = t.getData(), r = this._updateLineDraw(i, t), o = t.get("zlevel"), a = t.get(["effect", "trailLength"]), s = n.getZr(), l = "svg" === s.painter.getType(); l || s.painter.getLayer(o).clear(!0), null == this._lastZlevel || l || s.configLayer(this._lastZlevel, { motionBlur: !1 }), this._showEffect(t) && a > 0 && (l || s.configLayer(o, { motionBlur: !0, lastFrameAlpha: Math.max(Math.min(a / 10 + .9, 1), 0) })), r.updateData(i); var u = t.get("clip", !0) && SS(t.coordinateSystem, !1, t); u ? this.group.setClipPath(u) : this.group.removeClipPath(), this._lastZlevel = o, this._finished = !0 }, e.prototype.incrementalPrepareRender = function (t, e, n) { var i = t.getData(); this._updateLineDraw(i, t).incrementalPrepareUpdate(i), this._clearLayer(n), this._finished = !1 }, e.prototype.incrementalRender = function (t, e, n) { this._lineDraw.incrementalUpdate(t, e.getData()), this._finished = t.end === e.getData().count() }, e.prototype.eachRendered = function (t) { this._lineDraw && this._lineDraw.eachRendered(t) }, e.prototype.updateTransform = function (t, e, n) { var i = t.getData(), r = t.pipelineContext; if (!this._finished || r.large || r.progressiveRender) return { update: !0 }; var o = XP.reset(t, e, n); o.progress && o.progress({ start: 0, end: i.count(), count: i.count() }, i), this._lineDraw.updateLayout(), this._clearLayer(n) }, e.prototype._updateLineDraw = function (t, e) { var n = this._lineDraw, i = this._showEffect(e), r = !!e.get("polyline"), o = e.pipelineContext.large; return n && i === this._hasEffet && r === this._isPolyline && o === this._isLargeDraw || (n && n.remove(), n = this._lineDraw = o ? new YP : new RA(r ? i ? GP : FP : i ? BP : OA), this._hasEffet = i, this._isPolyline = r, this._isLargeDraw = o), this.group.add(n.group), n }, e.prototype._showEffect = function (t) { return !!t.get(["effect", "show"]) }, e.prototype._clearLayer = function (t) { var e = t.getZr(); "svg" === e.painter.getType() || null == this._lastZlevel || e.painter.getLayer(this._lastZlevel).clear(!0) }, e.prototype.remove = function (t, e) { this._lineDraw && this._lineDraw.remove(), this._lineDraw = null, this._clearLayer(e) }, e.prototype.dispose = function (t, e) { this.remove(t, e) }, e.type = "lines", e }(kg), ZP = "undefined" == typeof Uint32Array ? Array : Uint32Array, jP = "undefined" == typeof Float64Array ? Array : Float64Array; function qP(t) { var e = t.data; e && e[0] && e[0][0] && e[0][0].coord && (t.data = z(e, (function (t) { var e = { coords: [t[0].coord, t[1].coord] }; return t[0].name && (e.fromName = t[0].name), t[1].name && (e.toName = t[1].name), D([e, t[0], t[1]]) }))) } var KP = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.visualStyleAccessPath = "lineStyle", n.visualDrawType = "stroke", n } return n(e, t), e.prototype.init = function (e) { e.data = e.data || [], qP(e); var n = this._processFlatCoordsArray(e.data); this._flatCoords = n.flatCoords, this._flatCoordsOffset = n.flatCoordsOffset, n.flatCoords && (e.data = new Float32Array(n.count)), t.prototype.init.apply(this, arguments) }, e.prototype.mergeOption = function (e) { if (qP(e), e.data) { var n = this._processFlatCoordsArray(e.data); this._flatCoords = n.flatCoords, this._flatCoordsOffset = n.flatCoordsOffset, n.flatCoords && (e.data = new Float32Array(n.count)) } t.prototype.mergeOption.apply(this, arguments) }, e.prototype.appendData = function (t) { var e = this._processFlatCoordsArray(t.data); e.flatCoords && (this._flatCoords ? (this._flatCoords = vt(this._flatCoords, e.flatCoords), this._flatCoordsOffset = vt(this._flatCoordsOffset, e.flatCoordsOffset)) : (this._flatCoords = e.flatCoords, this._flatCoordsOffset = e.flatCoordsOffset), t.data = new Float32Array(e.count)), this.getRawData().appendData(t.data) }, e.prototype._getCoordsFromItemModel = function (t) { var e = this.getData().getItemModel(t), n = e.option instanceof Array ? e.option : e.getShallow("coords"); return n }, e.prototype.getLineCoordsCount = function (t) { return this._flatCoordsOffset ? this._flatCoordsOffset[2 * t + 1] : this._getCoordsFromItemModel(t).length }, e.prototype.getLineCoords = function (t, e) { if (this._flatCoordsOffset) { for (var n = this._flatCoordsOffset[2 * t], i = this._flatCoordsOffset[2 * t + 1], r = 0; r < i; r++)e[r] = e[r] || [], e[r][0] = this._flatCoords[n + 2 * r], e[r][1] = this._flatCoords[n + 2 * r + 1]; return i } var o = this._getCoordsFromItemModel(t); for (r = 0; r < o.length; r++)e[r] = e[r] || [], e[r][0] = o[r][0], e[r][1] = o[r][1]; return o.length }, e.prototype._processFlatCoordsArray = function (t) { var e = 0; if (this._flatCoords && (e = this._flatCoords.length), j(t[0])) { for (var n = t.length, i = new ZP(n), r = new jP(n), o = 0, a = 0, s = 0, l = 0; l < n;) { s++; var u = t[l++]; i[a++] = o + e, i[a++] = u; for (var h = 0; h < u; h++) { var c = t[l++], p = t[l++]; r[o++] = c, r[o++] = p } } return { flatCoordsOffset: new Uint32Array(i.buffer, 0, a), flatCoords: r, count: s } } return { flatCoordsOffset: null, flatCoords: null, count: t.length } }, e.prototype.getInitialData = function (t, e) { var n = new lx(["value"], this); return n.hasItemOption = !1, n.initData(t.data, [], (function (t, e, i, r) { if (t instanceof Array) return NaN; n.hasItemOption = !0; var o = t.value; return null != o ? o instanceof Array ? o[r] : o : void 0 })), n }, e.prototype.formatTooltip = function (t, e, n) { var i = this.getData().getItemModel(t), r = i.get("name"); if (r) return r; var o = i.get("fromName"), a = i.get("toName"), s = []; return null != o && s.push(o), null != a && s.push(a), ng("nameValue", { name: s.join(" > ") }) }, e.prototype.preventIncremental = function () { return !!this.get(["effect", "show"]) }, e.prototype.getProgressive = function () { var t = this.option.progressive; return null == t ? this.option.large ? 1e4 : this.get("progressive") : t }, e.prototype.getProgressiveThreshold = function () { var t = this.option.progressiveThreshold; return null == t ? this.option.large ? 2e4 : this.get("progressiveThreshold") : t }, e.prototype.getZLevelKey = function () { var t = this.getModel("effect"), e = t.get("trailLength"); return this.getData().count() > this.getProgressiveThreshold() ? this.id : t.get("show") && e > 0 ? e + "" : "" }, e.type = "series.lines", e.dependencies = ["grid", "polar", "geo", "calendar"], e.defaultOption = { coordinateSystem: "geo", z: 2, legendHoverLink: !0, xAxisIndex: 0, yAxisIndex: 0, symbol: ["none", "none"], symbolSize: [10, 10], geoIndex: 0, effect: { show: !1, period: 4, constantSpeed: 0, symbol: "circle", symbolSize: 3, loop: !0, trailLength: .2 }, large: !1, largeThreshold: 2e3, polyline: !1, clip: !0, label: { show: !1, position: "end" }, lineStyle: { opacity: .5 } }, e }(mg); function $P(t) { return t instanceof Array || (t = [t, t]), t } var JP = { seriesType: "lines", reset: function (t) { var e = $P(t.get("symbol")), n = $P(t.get("symbolSize")), i = t.getData(); return i.setVisual("fromSymbol", e && e[0]), i.setVisual("toSymbol", e && e[1]), i.setVisual("fromSymbolSize", n && n[0]), i.setVisual("toSymbolSize", n && n[1]), { dataEach: i.hasItemOption ? function (t, e) { var n = t.getItemModel(e), i = $P(n.getShallow("symbol", !0)), r = $P(n.getShallow("symbolSize", !0)); i[0] && t.setItemVisual(e, "fromSymbol", i[0]), i[1] && t.setItemVisual(e, "toSymbol", i[1]), r[0] && t.setItemVisual(e, "fromSymbolSize", r[0]), r[1] && t.setItemVisual(e, "toSymbolSize", r[1]) } : null } } }; var QP = function () { function t() { this.blurSize = 30, this.pointSize = 20, this.maxOpacity = 1, this.minOpacity = 0, this._gradientPixels = { inRange: null, outOfRange: null }; var t = h.createCanvas(); this.canvas = t } return t.prototype.update = function (t, e, n, i, r, o) { var a = this._getBrush(), s = this._getGradient(r, "inRange"), l = this._getGradient(r, "outOfRange"), u = this.pointSize + this.blurSize, h = this.canvas, c = h.getContext("2d"), p = t.length; h.width = e, h.height = n; for (var d = 0; d < p; ++d) { var f = t[d], g = f[0], y = f[1], v = i(f[2]); c.globalAlpha = v, c.drawImage(a, g - u, y - u) } if (!h.width || !h.height) return h; for (var m = c.getImageData(0, 0, h.width, h.height), x = m.data, _ = 0, b = x.length, w = this.minOpacity, S = this.maxOpacity - w; _ < b;) { v = x[_ + 3] / 256; var M = 4 * Math.floor(255 * v); if (v > 0) { var I = o(v) ? s : l; v > 0 && (v = v * S + w), x[_++] = I[M], x[_++] = I[M + 1], x[_++] = I[M + 2], x[_++] = I[M + 3] * v * 256 } else _ += 4 } return c.putImageData(m, 0, 0), h }, t.prototype._getBrush = function () { var t = this._brushCanvas || (this._brushCanvas = h.createCanvas()), e = this.pointSize + this.blurSize, n = 2 * e; t.width = n, t.height = n; var i = t.getContext("2d"); return i.clearRect(0, 0, n, n), i.shadowOffsetX = n, i.shadowBlur = this.blurSize, i.shadowColor = "#000", i.beginPath(), i.arc(-e, e, this.pointSize, 0, 2 * Math.PI, !0), i.closePath(), i.fill(), t }, t.prototype._getGradient = function (t, e) { for (var n = this._gradientPixels, i = n[e] || (n[e] = new Uint8ClampedArray(1024)), r = [0, 0, 0, 0], o = 0, a = 0; a < 256; a++)t[e](a / 255, !0, r), i[o++] = r[0], i[o++] = r[1], i[o++] = r[2], i[o++] = r[3]; return i }, t }(); function tO(t) { var e = t.dimensions; return "lng" === e[0] && "lat" === e[1] } var eO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i; e.eachComponent("visualMap", (function (e) { e.eachTargetSeries((function (n) { n === t && (i = e) })) })), this._progressiveEls = null, this.group.removeAll(); var r = t.coordinateSystem; "cartesian2d" === r.type || "calendar" === r.type ? this._renderOnCartesianAndCalendar(t, n, 0, t.getData().count()) : tO(r) && this._renderOnGeo(r, t, i, n) }, e.prototype.incrementalPrepareRender = function (t, e, n) { this.group.removeAll() }, e.prototype.incrementalRender = function (t, e, n, i) { var r = e.coordinateSystem; r && (tO(r) ? this.render(e, n, i) : (this._progressiveEls = [], this._renderOnCartesianAndCalendar(e, i, t.start, t.end, !0))) }, e.prototype.eachRendered = function (t) { qh(this._progressiveEls || this.group, t) }, e.prototype._renderOnCartesianAndCalendar = function (t, e, n, i, r) { var o, a, s, l, u = t.coordinateSystem, h = MS(u, "cartesian2d"); if (h) { var c = u.getAxis("x"), p = u.getAxis("y"); 0, o = c.getBandWidth() + .5, a = p.getBandWidth() + .5, s = c.scale.getExtent(), l = p.scale.getExtent() } for (var d = this.group, f = t.getData(), g = t.getModel(["emphasis", "itemStyle"]).getItemStyle(), y = t.getModel(["blur", "itemStyle"]).getItemStyle(), v = t.getModel(["select", "itemStyle"]).getItemStyle(), m = t.get(["itemStyle", "borderRadius"]), x = ec(t), _ = t.getModel("emphasis"), b = _.get("focus"), w = _.get("blurScope"), S = _.get("disabled"), M = h ? [f.mapDimension("x"), f.mapDimension("y"), f.mapDimension("value")] : [f.mapDimension("time"), f.mapDimension("value")], I = n; I < i; I++) { var T = void 0, C = f.getItemVisual(I, "style"); if (h) { var D = f.get(M[0], I), A = f.get(M[1], I); if (isNaN(f.get(M[2], I)) || isNaN(D) || isNaN(A) || D < s[0] || D > s[1] || A < l[0] || A > l[1]) continue; var k = u.dataToPoint([D, A]); T = new zs({ shape: { x: k[0] - o / 2, y: k[1] - a / 2, width: o, height: a }, style: C }) } else { if (isNaN(f.get(M[1], I))) continue; T = new zs({ z2: 1, shape: u.dataToRect([f.get(M[0], I)]).contentShape, style: C }) } if (f.hasItemOption) { var L = f.getItemModel(I), P = L.getModel("emphasis"); g = P.getModel("itemStyle").getItemStyle(), y = L.getModel(["blur", "itemStyle"]).getItemStyle(), v = L.getModel(["select", "itemStyle"]).getItemStyle(), m = L.get(["itemStyle", "borderRadius"]), b = P.get("focus"), w = P.get("blurScope"), S = P.get("disabled"), x = ec(L) } T.shape.r = m; var O = t.getRawValue(I), R = "-"; O && null != O[2] && (R = O[2] + ""), tc(T, x, { labelFetcher: t, labelDataIndex: I, defaultOpacity: C.opacity, defaultText: R }), T.ensureState("emphasis").style = g, T.ensureState("blur").style = y, T.ensureState("select").style = v, Yl(T, b, w, S), T.incremental = r, r && (T.states.emphasis.hoverLayer = !0), d.add(T), f.setItemGraphicEl(I, T), this._progressiveEls && this._progressiveEls.push(T) } }, e.prototype._renderOnGeo = function (t, e, n, i) { var r = n.targetVisuals.inRange, o = n.targetVisuals.outOfRange, a = e.getData(), s = this._hmLayer || this._hmLayer || new QP; s.blurSize = e.get("blurSize"), s.pointSize = e.get("pointSize"), s.minOpacity = e.get("minOpacity"), s.maxOpacity = e.get("maxOpacity"); var l = t.getViewRect().clone(), u = t.getRoamTransform(); l.applyTransform(u); var h = Math.max(l.x, 0), c = Math.max(l.y, 0), p = Math.min(l.width + l.x, i.getWidth()), d = Math.min(l.height + l.y, i.getHeight()), f = p - h, g = d - c, y = [a.mapDimension("lng"), a.mapDimension("lat"), a.mapDimension("value")], v = a.mapArray(y, (function (e, n, i) { var r = t.dataToPoint([e, n]); return r[0] -= h, r[1] -= c, r.push(i), r })), m = n.getExtent(), x = "visualMap.continuous" === n.type ? function (t, e) { var n = t[1] - t[0]; return e = [(e[0] - t[0]) / n, (e[1] - t[0]) / n], function (t) { return t >= e[0] && t <= e[1] } }(m, n.option.range) : function (t, e, n) { var i = t[1] - t[0], r = (e = z(e, (function (e) { return { interval: [(e.interval[0] - t[0]) / i, (e.interval[1] - t[0]) / i] } }))).length, o = 0; return function (t) { var i; for (i = o; i < r; i++)if ((a = e[i].interval)[0] <= t && t <= a[1]) { o = i; break } if (i === r) for (i = o - 1; i >= 0; i--) { var a; if ((a = e[i].interval)[0] <= t && t <= a[1]) { o = i; break } } return i >= 0 && i < r && n[i] } }(m, n.getPieceList(), n.option.selected); s.update(v, f, g, r.color.getNormalizer(), { inRange: r.color.getColorMapper(), outOfRange: o.color.getColorMapper() }, x); var _ = new ks({ style: { width: f, height: g, x: h, y: c, image: s.canvas }, silent: !0 }); this.group.add(_) }, e.type = "heatmap", e }(kg), nO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.getInitialData = function (t, e) { return vx(null, this, { generateCoord: "value" }) }, e.prototype.preventIncremental = function () { var t = xd.get(this.get("coordinateSystem")); if (t && t.dimensions) return "lng" === t.dimensions[0] && "lat" === t.dimensions[1] }, e.type = "series.heatmap", e.dependencies = ["grid", "geo", "calendar"], e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, geoIndex: 0, blurSize: 30, pointSize: 20, maxOpacity: 1, minOpacity: 0, select: { itemStyle: { borderColor: "#212121" } } }, e }(mg); var iO = ["itemStyle", "borderWidth"], rO = [{ xy: "x", wh: "width", index: 0, posDesc: ["left", "right"] }, { xy: "y", wh: "height", index: 1, posDesc: ["top", "bottom"] }], oO = new _u, aO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = this.group, r = t.getData(), o = this._data, a = t.coordinateSystem, s = a.getBaseAxis().isHorizontal(), l = a.master.getRect(), u = { ecSize: { width: n.getWidth(), height: n.getHeight() }, seriesModel: t, coordSys: a, coordSysExtent: [[l.x, l.x + l.width], [l.y, l.y + l.height]], isHorizontal: s, valueDim: rO[+s], categoryDim: rO[1 - +s] }; return r.diff(o).add((function (t) { if (r.hasValue(t)) { var e = fO(r, t), n = sO(r, t, e, u), o = vO(r, u, n); r.setItemGraphicEl(t, o), i.add(o), wO(o, u, n) } })).update((function (t, e) { var n = o.getItemGraphicEl(e); if (r.hasValue(t)) { var a = fO(r, t), s = sO(r, t, a, u), l = xO(r, s); n && l !== n.__pictorialShapeStr && (i.remove(n), r.setItemGraphicEl(t, null), n = null), n ? function (t, e, n) { var i = n.animationModel, r = n.dataIndex, o = t.__pictorialBundle; fh(o, { x: n.bundlePosition[0], y: n.bundlePosition[1] }, i, r), n.symbolRepeat ? hO(t, e, n, !0) : cO(t, e, n, !0); pO(t, n, !0), dO(t, e, n, !0) }(n, u, s) : n = vO(r, u, s, !0), r.setItemGraphicEl(t, n), n.__pictorialSymbolMeta = s, i.add(n), wO(n, u, s) } else i.remove(n) })).remove((function (t) { var e = o.getItemGraphicEl(t); e && mO(o, t, e.__pictorialSymbolMeta.animationModel, e) })).execute(), this._data = r, this.group }, e.prototype.remove = function (t, e) { var n = this.group, i = this._data; t.get("animation") ? i && i.eachItemGraphicEl((function (e) { mO(i, Qs(e).dataIndex, t, e) })) : n.removeAll() }, e.type = "pictorialBar", e }(kg); function sO(t, e, n, i) { var r = t.getItemLayout(e), o = n.get("symbolRepeat"), a = n.get("symbolClip"), s = n.get("symbolPosition") || "start", l = (n.get("symbolRotate") || 0) * Math.PI / 180 || 0, u = n.get("symbolPatternSize") || 2, h = n.isAnimationEnabled(), c = { dataIndex: e, layout: r, itemModel: n, symbolType: t.getItemVisual(e, "symbol") || "circle", style: t.getItemVisual(e, "style"), symbolClip: a, symbolRepeat: o, symbolRepeatDirection: n.get("symbolRepeatDirection"), symbolPatternSize: u, rotation: l, animationModel: h ? n : null, hoverScale: h && n.get(["emphasis", "scale"]), z2: n.getShallow("z", !0) || 0 }; !function (t, e, n, i, r) { var o, a = i.valueDim, s = t.get("symbolBoundingData"), l = i.coordSys.getOtherAxis(i.coordSys.getBaseAxis()), u = l.toGlobalCoord(l.dataToCoord(0)), h = 1 - +(n[a.wh] <= 0); if (Y(s)) { var c = [lO(l, s[0]) - u, lO(l, s[1]) - u]; c[1] < c[0] && c.reverse(), o = c[h] } else o = null != s ? lO(l, s) - u : e ? i.coordSysExtent[a.index][h] - u : n[a.wh]; r.boundingLength = o, e && (r.repeatCutLength = n[a.wh]); r.pxSign = o > 0 ? 1 : -1 }(n, o, r, i, c), function (t, e, n, i, r, o, a, s, l, u) { var h, c = l.valueDim, p = l.categoryDim, d = Math.abs(n[p.wh]), f = t.getItemVisual(e, "symbolSize"); h = Y(f) ? f.slice() : null == f ? ["100%", "100%"] : [f, f]; h[p.index] = Ur(h[p.index], d), h[c.index] = Ur(h[c.index], i ? d : Math.abs(o)), u.symbolSize = h; var g = u.symbolScale = [h[0] / s, h[1] / s]; g[c.index] *= (l.isHorizontal ? -1 : 1) * a }(t, e, r, o, 0, c.boundingLength, c.pxSign, u, i, c), function (t, e, n, i, r) { var o = t.get(iO) || 0; o && (oO.attr({ scaleX: e[0], scaleY: e[1], rotation: n }), oO.updateTransform(), o /= oO.getLineScale(), o *= e[i.valueDim.index]); r.valueLineWidth = o || 0 }(n, c.symbolScale, l, i, c); var p = c.symbolSize, d = Yy(n.get("symbolOffset"), p); return function (t, e, n, i, r, o, a, s, l, u, h, c) { var p = h.categoryDim, d = h.valueDim, f = c.pxSign, g = Math.max(e[d.index] + s, 0), y = g; if (i) { var v = Math.abs(l), m = it(t.get("symbolMargin"), "15%") + "", x = !1; m.lastIndexOf("!") === m.length - 1 && (x = !0, m = m.slice(0, m.length - 1)); var _ = Ur(m, e[d.index]), b = Math.max(g + 2 * _, 0), w = x ? 0 : 2 * _, S = co(i), M = S ? i : SO((v + w) / b); b = g + 2 * (_ = (v - M * g) / 2 / (x ? M : Math.max(M - 1, 1))), w = x ? 0 : 2 * _, S || "fixed" === i || (M = u ? SO((Math.abs(u) + w) / b) : 0), y = M * b - w, c.repeatTimes = M, c.symbolMargin = _ } var I = f * (y / 2), T = c.pathPosition = []; T[p.index] = n[p.wh] / 2, T[d.index] = "start" === a ? I : "end" === a ? l - I : l / 2, o && (T[0] += o[0], T[1] += o[1]); var C = c.bundlePosition = []; C[p.index] = n[p.xy], C[d.index] = n[d.xy]; var D = c.barRectShape = A({}, n); D[d.wh] = f * Math.max(Math.abs(n[d.wh]), Math.abs(T[d.index] + I)), D[p.wh] = n[p.wh]; var k = c.clipShape = {}; k[p.xy] = -n[p.xy], k[p.wh] = h.ecSize[p.wh], k[d.xy] = 0, k[d.wh] = n[d.wh] }(n, p, r, o, 0, d, s, c.valueLineWidth, c.boundingLength, c.repeatCutLength, i, c), c } function lO(t, e) { return t.toGlobalCoord(t.dataToCoord(t.scale.parse(e))) } function uO(t) { var e = t.symbolPatternSize, n = Wy(t.symbolType, -e / 2, -e / 2, e, e); return n.attr({ culling: !0 }), "image" !== n.type && n.setStyle({ strokeNoScale: !0 }), n } function hO(t, e, n, i) { var r = t.__pictorialBundle, o = n.symbolSize, a = n.valueLineWidth, s = n.pathPosition, l = e.valueDim, u = n.repeatTimes || 0, h = 0, c = o[e.valueDim.index] + a + 2 * n.symbolMargin; for (_O(t, (function (t) { t.__pictorialAnimationIndex = h, t.__pictorialRepeatTimes = u, h < u ? bO(t, null, f(h), n, i) : bO(t, null, { scaleX: 0, scaleY: 0 }, n, i, (function () { r.remove(t) })), h++ })); h < u; h++) { var p = uO(n); p.__pictorialAnimationIndex = h, p.__pictorialRepeatTimes = u, r.add(p); var d = f(h); bO(p, { x: d.x, y: d.y, scaleX: 0, scaleY: 0 }, { scaleX: d.scaleX, scaleY: d.scaleY, rotation: d.rotation }, n, i) } function f(t) { var e = s.slice(), i = n.pxSign, r = t; return ("start" === n.symbolRepeatDirection ? i > 0 : i < 0) && (r = u - 1 - t), e[l.index] = c * (r - u / 2 + .5) + s[l.index], { x: e[0], y: e[1], scaleX: n.symbolScale[0], scaleY: n.symbolScale[1], rotation: n.rotation } } } function cO(t, e, n, i) { var r = t.__pictorialBundle, o = t.__pictorialMainPath; o ? bO(o, null, { x: n.pathPosition[0], y: n.pathPosition[1], scaleX: n.symbolScale[0], scaleY: n.symbolScale[1], rotation: n.rotation }, n, i) : (o = t.__pictorialMainPath = uO(n), r.add(o), bO(o, { x: n.pathPosition[0], y: n.pathPosition[1], scaleX: 0, scaleY: 0, rotation: n.rotation }, { scaleX: n.symbolScale[0], scaleY: n.symbolScale[1] }, n, i)) } function pO(t, e, n) { var i = A({}, e.barRectShape), r = t.__pictorialBarRect; r ? bO(r, null, { shape: i }, e, n) : ((r = t.__pictorialBarRect = new zs({ z2: 2, shape: i, silent: !0, style: { stroke: "transparent", fill: "transparent", lineWidth: 0 } })).disableMorphing = !0, t.add(r)) } function dO(t, e, n, i) { if (n.symbolClip) { var r = t.__pictorialClipPath, o = A({}, n.clipShape), a = e.valueDim, s = n.animationModel, l = n.dataIndex; if (r) fh(r, { shape: o }, s, l); else { o[a.wh] = 0, r = new zs({ shape: o }), t.__pictorialBundle.setClipPath(r), t.__pictorialClipPath = r; var u = {}; u[a.wh] = n.clipShape[a.wh], Kh[i ? "updateProps" : "initProps"](r, { shape: u }, s, l) } } } function fO(t, e) { var n = t.getItemModel(e); return n.getAnimationDelayParams = gO, n.isAnimationEnabled = yO, n } function gO(t) { return { index: t.__pictorialAnimationIndex, count: t.__pictorialRepeatTimes } } function yO() { return this.parentModel.isAnimationEnabled() && !!this.getShallow("animation") } function vO(t, e, n, i) { var r = new zr, o = new zr; return r.add(o), r.__pictorialBundle = o, o.x = n.bundlePosition[0], o.y = n.bundlePosition[1], n.symbolRepeat ? hO(r, e, n) : cO(r, 0, n), pO(r, n, i), dO(r, e, n, i), r.__pictorialShapeStr = xO(t, n), r.__pictorialSymbolMeta = n, r } function mO(t, e, n, i) { var r = i.__pictorialBarRect; r && r.removeTextContent(); var o = []; _O(i, (function (t) { o.push(t) })), i.__pictorialMainPath && o.push(i.__pictorialMainPath), i.__pictorialClipPath && (n = null), E(o, (function (t) { vh(t, { scaleX: 0, scaleY: 0 }, n, e, (function () { i.parent && i.parent.remove(i) })) })), t.setItemGraphicEl(e, null) } function xO(t, e) { return [t.getItemVisual(e.dataIndex, "symbol") || "none", !!e.symbolRepeat, !!e.symbolClip].join(":") } function _O(t, e, n) { E(t.__pictorialBundle.children(), (function (i) { i !== t.__pictorialBarRect && e.call(n, i) })) } function bO(t, e, n, i, r, o) { e && t.attr(e), i.symbolClip && !r ? n && t.attr(n) : n && Kh[r ? "updateProps" : "initProps"](t, n, i.animationModel, i.dataIndex, o) } function wO(t, e, n) { var i = n.dataIndex, r = n.itemModel, o = r.getModel("emphasis"), a = o.getModel("itemStyle").getItemStyle(), s = r.getModel(["blur", "itemStyle"]).getItemStyle(), l = r.getModel(["select", "itemStyle"]).getItemStyle(), u = r.getShallow("cursor"), h = o.get("focus"), c = o.get("blurScope"), p = o.get("scale"); _O(t, (function (t) { if (t instanceof ks) { var e = t.style; t.useStyle(A({ image: e.image, x: e.x, y: e.y, width: e.width, height: e.height }, n.style)) } else t.useStyle(n.style); var i = t.ensureState("emphasis"); i.style = a, p && (i.scaleX = 1.1 * t.scaleX, i.scaleY = 1.1 * t.scaleY), t.ensureState("blur").style = s, t.ensureState("select").style = l, u && (t.cursor = u), t.z2 = n.z2 })); var d = e.valueDim.posDesc[+(n.boundingLength > 0)]; tc(t.__pictorialBarRect, ec(r), { labelFetcher: e.seriesModel, labelDataIndex: i, defaultText: iS(e.seriesModel.getData(), i), inheritColor: n.style.fill, defaultOpacity: n.style.opacity, defaultOutsidePosition: d }), Yl(t, h, c, o.get("disabled")) } function SO(t) { var e = Math.round(t); return Math.abs(t - e) < 1e-4 ? e : Math.ceil(t) } var MO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.hasSymbolVisual = !0, n.defaultSymbol = "roundRect", n } return n(e, t), e.prototype.getInitialData = function (e) { return e.stack = null, t.prototype.getInitialData.apply(this, arguments) }, e.type = "series.pictorialBar", e.dependencies = ["grid"], e.defaultOption = Cc(FS.defaultOption, { symbol: "circle", symbolSize: null, symbolRotate: null, symbolPosition: null, symbolOffset: null, symbolMargin: null, symbolRepeat: !1, symbolRepeatDirection: "end", symbolClip: !1, symbolBoundingData: null, symbolPatternSize: 400, barGap: "-100%", progressive: 0, emphasis: { scale: !1 }, select: { itemStyle: { borderColor: "#212121" } } }), e }(FS); var IO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._layers = [], n } return n(e, t), e.prototype.render = function (t, e, n) { var i = t.getData(), r = this, o = this.group, a = t.getLayerSeries(), s = i.getLayout("layoutInfo"), l = s.rect, u = s.boundaryGap; function h(t) { return t.name } o.x = 0, o.y = l.y + u[0]; var c = new Vm(this._layersSeries || [], a, h, h), p = []; function d(e, n, s) { var l = r._layers; if ("remove" !== e) { for (var u, h, c = [], d = [], f = a[n].indices, g = 0; g < f.length; g++) { var y = i.getItemLayout(f[g]), v = y.x, m = y.y0, x = y.y; c.push(v, m), d.push(v, m + x), u = i.getItemVisual(f[g], "style") } var _ = i.getItemLayout(f[0]), b = t.getModel("label").get("margin"), w = t.getModel("emphasis"); if ("add" === e) { var S = p[n] = new zr; h = new _S({ shape: { points: c, stackedOnPoints: d, smooth: .4, stackedOnSmooth: .4, smoothConstraint: !1 }, z2: 0 }), S.add(h), o.add(S), t.isAnimationEnabled() && h.setClipPath(function (t, e, n) { var i = new zs({ shape: { x: t.x - 10, y: t.y - 10, width: 0, height: t.height + 20 } }); return gh(i, { shape: { x: t.x - 50, width: t.width + 100, height: t.height + 20 } }, e, n), i }(h.getBoundingRect(), t, (function () { h.removeClipPath() }))) } else { S = l[s]; h = S.childAt(0), o.add(S), p[n] = S, fh(h, { shape: { points: c, stackedOnPoints: d } }, t), _h(h) } tc(h, ec(t), { labelDataIndex: f[g - 1], defaultText: i.getName(f[g - 1]), inheritColor: u.fill }, { normal: { verticalAlign: "middle" } }), h.setTextConfig({ position: null, local: !0 }); var M = h.getTextContent(); M && (M.x = _.x - b, M.y = _.y0 + _.y / 2), h.useStyle(u), i.setItemGraphicEl(n, h), jl(h, t), Yl(h, w.get("focus"), w.get("blurScope"), w.get("disabled")) } else o.remove(l[n]) } c.add(W(d, this, "add")).update(W(d, this, "update")).remove(W(d, this, "remove")).execute(), this._layersSeries = a, this._layers = p }, e.type = "themeRiver", e }(kg); var TO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), this.legendVisualProvider = new IM(W(this.getData, this), W(this.getRawData, this)) }, e.prototype.fixData = function (t) { var e = t.length, n = {}, i = Go(t, (function (t) { return n.hasOwnProperty(t[0] + "") || (n[t[0] + ""] = -1), t[2] })), r = []; i.buckets.each((function (t, e) { r.push({ name: e, dataList: t }) })); for (var o = r.length, a = 0; a < o; ++a) { for (var s = r[a].name, l = 0; l < r[a].dataList.length; ++l) { var u = r[a].dataList[l][0] + ""; n[u] = a } for (var u in n) n.hasOwnProperty(u) && n[u] !== a && (n[u] = a, t[e] = [u, 0, s], e++) } return t }, e.prototype.getInitialData = function (t, e) { for (var n = this.getReferringComponents("singleAxis", zo).models[0].get("type"), i = B(t.data, (function (t) { return void 0 !== t[2] })), r = this.fixData(i || []), o = [], a = this.nameMap = yt(), s = 0, l = 0; l < r.length; ++l)o.push(r[l][2]), a.get(r[l][2]) || (a.set(r[l][2], s), s++); var u = ux(r, { coordDimensions: ["single"], dimensionsDefine: [{ name: "time", type: Gm(n) }, { name: "value", type: "float" }, { name: "name", type: "ordinal" }], encodeDefine: { single: 0, value: 1, itemName: 2 } }).dimensions, h = new lx(u, this); return h.initData(r), h }, e.prototype.getLayerSeries = function () { for (var t = this.getData(), e = t.count(), n = [], i = 0; i < e; ++i)n[i] = i; var r = t.mapDimension("single"), o = Go(n, (function (e) { return t.get("name", e) })), a = []; return o.buckets.each((function (e, n) { e.sort((function (e, n) { return t.get(r, e) - t.get(r, n) })), a.push({ name: n, indices: e }) })), a }, e.prototype.getAxisTooltipData = function (t, e, n) { Y(t) || (t = t ? [t] : []); for (var i, r = this.getData(), o = this.getLayerSeries(), a = [], s = o.length, l = 0; l < s; ++l) { for (var u = Number.MAX_VALUE, h = -1, c = o[l].indices.length, p = 0; p < c; ++p) { var d = r.get(t[0], o[l].indices[p]), f = Math.abs(d - e); f <= u && (i = d, u = f, h = o[l].indices[p]) } a.push(h) } return { dataIndices: a, nestestValue: i } }, e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(); return ng("nameValue", { name: i.getName(t), value: i.get(i.mapDimension("value"), t) }) }, e.type = "series.themeRiver", e.dependencies = ["singleAxis"], e.defaultOption = { z: 2, colorBy: "data", coordinateSystem: "singleAxis", boundaryGap: ["10%", "10%"], singleAxisIndex: 0, animationEasing: "linear", label: { margin: 4, show: !0, position: "left", fontSize: 11 }, emphasis: { label: { show: !0 } } }, e }(mg); function CO(t, e) { t.eachSeriesByType("themeRiver", (function (t) { var e = t.getData(), n = t.coordinateSystem, i = {}, r = n.getRect(); i.rect = r; var o = t.get("boundaryGap"), a = n.getAxis(); (i.boundaryGap = o, "horizontal" === a.orient) ? (o[0] = Ur(o[0], r.height), o[1] = Ur(o[1], r.height), DO(e, t, r.height - o[0] - o[1])) : (o[0] = Ur(o[0], r.width), o[1] = Ur(o[1], r.width), DO(e, t, r.width - o[0] - o[1])); e.setLayout("layoutInfo", i) })) } function DO(t, e, n) { if (t.count()) for (var i, r = e.coordinateSystem, o = e.getLayerSeries(), a = t.mapDimension("single"), s = t.mapDimension("value"), l = z(o, (function (e) { return z(e.indices, (function (e) { var n = r.dataToPoint(t.get(a, e)); return n[1] = t.get(s, e), n })) })), u = function (t) { for (var e = t.length, n = t[0].length, i = [], r = [], o = 0, a = 0; a < n; ++a) { for (var s = 0, l = 0; l < e; ++l)s += t[l][a][1]; s > o && (o = s), i.push(s) } for (var u = 0; u < n; ++u)r[u] = (o - i[u]) / 2; o = 0; for (var h = 0; h < n; ++h) { var c = i[h] + r[h]; c > o && (o = c) } return { y0: r, max: o } }(l), h = u.y0, c = n / u.max, p = o.length, d = o[0].indices.length, f = 0; f < d; ++f) { i = h[f] * c, t.setItemLayout(o[0].indices[f], { layerIndex: 0, x: l[0][f][0], y0: i, y: l[0][f][1] * c }); for (var g = 1; g < p; ++g)i += l[g - 1][f][1] * c, t.setItemLayout(o[g].indices[f], { layerIndex: g, x: l[g][f][0], y0: i, y: l[g][f][1] * c }) } } var AO = function (t) { function e(e, n, i, r) { var o = t.call(this) || this; o.z2 = 2, o.textConfig = { inside: !0 }, Qs(o).seriesIndex = n.seriesIndex; var a = new Fs({ z2: 4, silent: e.getModel().get(["label", "silent"]) }); return o.setTextContent(a), o.updateData(!0, e, n, i, r), o } return n(e, t), e.prototype.updateData = function (t, e, n, i, r) { this.node = e, e.piece = this, n = n || this._seriesModel, i = i || this._ecModel; var o = this; Qs(o).dataIndex = e.dataIndex; var a = e.getModel(), s = a.getModel("emphasis"), l = e.getLayout(), u = A({}, l); u.label = null; var h = e.getVisual("style"); h.lineJoin = "bevel"; var c = e.getVisual("decal"); c && (h.decal = gv(c, r)); var p = US(a.getModel("itemStyle"), u, !0); A(u, p), E(ol, (function (t) { var e = o.ensureState(t), n = a.getModel([t, "itemStyle"]); e.style = n.getItemStyle(); var i = US(n, u); i && (e.shape = i) })), t ? (o.setShape(u), o.shape.r = l.r0, gh(o, { shape: { r: l.r } }, n, e.dataIndex)) : (fh(o, { shape: u }, n), _h(o)), o.useStyle(h), this._updateLabel(n); var d = a.getShallow("cursor"); d && o.attr("cursor", d), this._seriesModel = n || this._seriesModel, this._ecModel = i || this._ecModel; var f = s.get("focus"); Yl(this, "ancestor" === f ? e.getAncestorsIndices() : "descendant" === f ? e.getDescendantIndices() : f, s.get("blurScope"), s.get("disabled")) }, e.prototype._updateLabel = function (t) { var e = this, n = this.node.getModel(), i = n.getModel("label"), r = this.node.getLayout(), o = r.endAngle - r.startAngle, a = (r.startAngle + r.endAngle) / 2, s = Math.cos(a), l = Math.sin(a), u = this, h = u.getTextContent(), c = this.node.dataIndex, p = i.get("minAngle") / 180 * Math.PI, d = i.get("show") && !(null != p && Math.abs(o) < p); function f(t, e) { var n = t.get(e); return null == n ? i.get(e) : n } h.ignore = !d, E(al, (function (i) { var p = "normal" === i ? n.getModel("label") : n.getModel([i, "label"]), d = "normal" === i, g = d ? h : h.ensureState(i), y = t.getFormattedLabel(c, i); d && (y = y || e.node.name), g.style = nc(p, {}, null, "normal" !== i, !0), y && (g.style.text = y); var v = p.get("show"); null == v || d || (g.ignore = !v); var m, x = f(p, "position"), _ = d ? u : u.states[i], b = _.style.fill; _.textConfig = { outsideFill: "inherit" === p.get("color") ? b : null, inside: "outside" !== x }; var w = f(p, "distance") || 0, S = f(p, "align"); "outside" === x ? (m = r.r + w, S = a > Math.PI / 2 ? "right" : "left") : S && "center" !== S ? "left" === S ? (m = r.r0 + w, a > Math.PI / 2 && (S = "right")) : "right" === S && (m = r.r - w, a > Math.PI / 2 && (S = "left")) : (m = o === 2 * Math.PI && 0 === r.r0 ? 0 : (r.r + r.r0) / 2, S = "center"), g.style.align = S, g.style.verticalAlign = f(p, "verticalAlign") || "middle", g.x = m * s + r.cx, g.y = m * l + r.cy; var M = f(p, "rotate"), I = 0; "radial" === M ? (I = hs(-a)) > Math.PI / 2 && I < 1.5 * Math.PI && (I += Math.PI) : "tangential" === M ? (I = Math.PI / 2 - a) > Math.PI / 2 ? I -= Math.PI : I < -Math.PI / 2 && (I += Math.PI) : j(M) && (I = M * Math.PI / 180), g.rotation = hs(I) })), h.dirtyStyle() }, e }(zu), kO = "sunburstRootToNode", LO = "sunburstHighlight"; var PO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n, i) { var r = this; this.seriesModel = t, this.api = n, this.ecModel = e; var o = t.getData(), a = o.tree.root, s = t.getViewRoot(), l = this.group, u = t.get("renderLabelForZeroData"), h = []; s.eachNode((function (t) { h.push(t) })); var c = this._oldChildren || []; !function (i, r) { if (0 === i.length && 0 === r.length) return; function s(t) { return t.getId() } function h(s, h) { !function (i, r) { u || !i || i.getValue() || (i = null); if (i !== a && r !== a) if (r && r.piece) i ? (r.piece.updateData(!1, i, t, e, n), o.setItemGraphicEl(i.dataIndex, r.piece)) : function (t) { if (!t) return; t.piece && (l.remove(t.piece), t.piece = null) }(r); else if (i) { var s = new AO(i, t, e, n); l.add(s), o.setItemGraphicEl(i.dataIndex, s) } }(null == s ? null : i[s], null == h ? null : r[h]) } new Vm(r, i, s, s).add(h).update(h).remove(H(h, null)).execute() }(h, c), function (i, o) { o.depth > 0 ? (r.virtualPiece ? r.virtualPiece.updateData(!1, i, t, e, n) : (r.virtualPiece = new AO(i, t, e, n), l.add(r.virtualPiece)), o.piece.off("click"), r.virtualPiece.on("click", (function (t) { r._rootToNode(o.parentNode) }))) : r.virtualPiece && (l.remove(r.virtualPiece), r.virtualPiece = null) }(a, s), this._initEvents(), this._oldChildren = h }, e.prototype._initEvents = function () { var t = this; this.group.off("click"), this.group.on("click", (function (e) { var n = !1; t.seriesModel.getViewRoot().eachNode((function (i) { if (!n && i.piece && i.piece === e.target) { var r = i.getModel().get("nodeClick"); if ("rootToNode" === r) t._rootToNode(i); else if ("link" === r) { var o = i.getModel(), a = o.get("link"); if (a) bp(a, o.get("target", !0) || "_blank") } n = !0 } })) })) }, e.prototype._rootToNode = function (t) { t !== this.seriesModel.getViewRoot() && this.api.dispatchAction({ type: kO, from: this.uid, seriesId: this.seriesModel.id, targetNode: t }) }, e.prototype.containPoint = function (t, e) { var n = e.getData().getItemLayout(0); if (n) { var i = t[0] - n.cx, r = t[1] - n.cy, o = Math.sqrt(i * i + r * r); return o <= n.r && o >= n.r0 } }, e.type = "sunburst", e }(kg), OO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.ignoreStyleOnData = !0, n } return n(e, t), e.prototype.getInitialData = function (t, e) { var n = { name: t.name, children: t.data }; RO(n); var i = this._levelModels = z(t.levels || [], (function (t) { return new Mc(t, this, e) }), this), r = UC.createTree(n, this, (function (t) { t.wrapMethod("getItemModel", (function (t, e) { var n = r.getNodeByDataIndex(e), o = i[n.depth]; return o && (t.parentModel = o), t })) })); return r.data }, e.prototype.optionUpdated = function () { this.resetViewRoot() }, e.prototype.getDataParams = function (e) { var n = t.prototype.getDataParams.apply(this, arguments), i = this.getData().tree.getNodeByDataIndex(e); return n.treePathInfo = KC(i, this), n }, e.prototype.getLevelModel = function (t) { return this._levelModels && this._levelModels[t.depth] }, e.prototype.getViewRoot = function () { return this._viewRoot }, e.prototype.resetViewRoot = function (t) { t ? this._viewRoot = t : t = this._viewRoot; var e = this.getRawData().tree.root; t && (t === e || e.contains(t)) || (this._viewRoot = e) }, e.prototype.enableAriaDecal = function () { nD(this) }, e.type = "series.sunburst", e.defaultOption = { z: 2, center: ["50%", "50%"], radius: [0, "75%"], clockwise: !0, startAngle: 90, minAngle: 0, stillShowZeroSum: !0, nodeClick: "rootToNode", renderLabelForZeroData: !1, label: { rotate: "radial", show: !0, opacity: 1, align: "center", position: "inside", distance: 5, silent: !0 }, itemStyle: { borderWidth: 1, borderColor: "white", borderType: "solid", shadowBlur: 0, shadowColor: "rgba(0, 0, 0, 0.2)", shadowOffsetX: 0, shadowOffsetY: 0, opacity: 1 }, emphasis: { focus: "descendant" }, blur: { itemStyle: { opacity: .2 }, label: { opacity: .1 } }, animationType: "expansion", animationDuration: 1e3, animationDurationUpdate: 500, data: [], sort: "desc" }, e }(mg); function RO(t) { var e = 0; E(t.children, (function (t) { RO(t); var n = t.value; Y(n) && (n = n[0]), e += n })); var n = t.value; Y(n) && (n = n[0]), (null == n || isNaN(n)) && (n = e), n < 0 && (n = 0), Y(t.value) ? t.value[0] = n : t.value = n } var NO = Math.PI / 180; function EO(t, e, n) { e.eachSeriesByType(t, (function (t) { var e = t.get("center"), i = t.get("radius"); Y(i) || (i = [0, i]), Y(e) || (e = [e, e]); var r = n.getWidth(), o = n.getHeight(), a = Math.min(r, o), s = Ur(e[0], r), l = Ur(e[1], o), u = Ur(i[0], a / 2), h = Ur(i[1], a / 2), c = -t.get("startAngle") * NO, p = t.get("minAngle") * NO, d = t.getData().tree.root, f = t.getViewRoot(), g = f.depth, y = t.get("sort"); null != y && zO(f, y); var v = 0; E(f.children, (function (t) { !isNaN(t.getValue()) && v++ })); var m = f.getValue(), x = Math.PI / (m || v) * 2, _ = f.depth > 0, b = f.height - (_ ? -1 : 1), w = (h - u) / (b || 1), S = t.get("clockwise"), M = t.get("stillShowZeroSum"), I = S ? 1 : -1, T = function (e, n) { if (e) { var i = n; if (e !== d) { var r = e.getValue(), o = 0 === m && M ? x : r * x; o < p && (o = p), i = n + I * o; var h = e.depth - g - (_ ? -1 : 1), c = u + w * h, f = u + w * (h + 1), y = t.getLevelModel(e); if (y) { var v = y.get("r0", !0), b = y.get("r", !0), C = y.get("radius", !0); null != C && (v = C[0], b = C[1]), null != v && (c = Ur(v, a / 2)), null != b && (f = Ur(b, a / 2)) } e.setLayout({ angle: o, startAngle: n, endAngle: i, clockwise: S, cx: s, cy: l, r0: c, r: f }) } if (e.children && e.children.length) { var D = 0; E(e.children, (function (t) { D += T(t, n + D) })) } return i - n } }; if (_) { var C = u, D = u + w, A = 2 * Math.PI; d.setLayout({ angle: A, startAngle: c, endAngle: c + A, clockwise: S, cx: s, cy: l, r0: C, r: D }) } T(f, c) })) } function zO(t, e) { var n = t.children || []; t.children = function (t, e) { if (X(e)) { var n = z(t, (function (t, e) { var n = t.getValue(); return { params: { depth: t.depth, height: t.height, dataIndex: t.dataIndex, getValue: function () { return n } }, index: e } })); return n.sort((function (t, n) { return e(t.params, n.params) })), z(n, (function (e) { return t[e.index] })) } var i = "asc" === e; return t.sort((function (t, e) { var n = (t.getValue() - e.getValue()) * (i ? 1 : -1); return 0 === n ? (t.dataIndex - e.dataIndex) * (i ? -1 : 1) : n })) }(n, e), n.length && E(t.children, (function (t) { zO(t, e) })) } function VO(t) { var e = {}; t.eachSeriesByType("sunburst", (function (t) { var n = t.getData(), i = n.tree; i.eachNode((function (r) { var o = r.getModel().getModel("itemStyle").getItemStyle(); o.fill || (o.fill = function (t, n, i) { for (var r = t; r && r.depth > 1;)r = r.parentNode; var o = n.getColorFromPalette(r.name || r.dataIndex + "", e); return t.depth > 1 && U(o) && (o = $n(o, (t.depth - 1) / (i - 1) * .5)), o }(r, t, i.root.height)), A(n.ensureUniqueItemVisual(r.dataIndex, "style"), o) })) })) } var BO = { color: "fill", borderColor: "stroke" }, FO = { symbol: 1, symbolSize: 1, symbolKeepAspect: 1, legendIcon: 1, visualMeta: 1, liftZ: 1, decal: 1 }, GO = Oo(), WO = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.optionUpdated = function () { this.currentZLevel = this.get("zlevel", !0), this.currentZ = this.get("z", !0) }, e.prototype.getInitialData = function (t, e) { return vx(null, this) }, e.prototype.getDataParams = function (e, n, i) { var r = t.prototype.getDataParams.call(this, e, n); return i && (r.info = GO(i).info), r }, e.type = "series.custom", e.dependencies = ["grid", "polar", "geo", "singleAxis", "calendar"], e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, legendHoverLink: !0, clip: !1 }, e }(mg); function HO(t, e) { return e = e || [0, 0], z(["x", "y"], (function (n, i) { var r = this.getAxis(n), o = e[i], a = t[i] / 2; return "category" === r.type ? r.getBandWidth() : Math.abs(r.dataToCoord(o - a) - r.dataToCoord(o + a)) }), this) } function YO(t, e) { return e = e || [0, 0], z([0, 1], (function (n) { var i = e[n], r = t[n] / 2, o = [], a = []; return o[n] = i - r, a[n] = i + r, o[1 - n] = a[1 - n] = e[1 - n], Math.abs(this.dataToPoint(o)[n] - this.dataToPoint(a)[n]) }), this) } function XO(t, e) { var n = this.getAxis(), i = e instanceof Array ? e[0] : e, r = (t instanceof Array ? t[0] : t) / 2; return "category" === n.type ? n.getBandWidth() : Math.abs(n.dataToCoord(i - r) - n.dataToCoord(i + r)) } function UO(t, e) { return e = e || [0, 0], z(["Radius", "Angle"], (function (n, i) { var r = this["get" + n + "Axis"](), o = e[i], a = t[i] / 2, s = "category" === r.type ? r.getBandWidth() : Math.abs(r.dataToCoord(o - a) - r.dataToCoord(o + a)); return "Angle" === n && (s = s * Math.PI / 180), s }), this) } function ZO(t, e, n, i) { return t && (t.legacy || !1 !== t.legacy && !n && !i && "tspan" !== e && ("text" === e || _t(t, "text"))) } function jO(t, e, n) { var i, r, o, a = t; if ("text" === e) o = a; else { o = {}, _t(a, "text") && (o.text = a.text), _t(a, "rich") && (o.rich = a.rich), _t(a, "textFill") && (o.fill = a.textFill), _t(a, "textStroke") && (o.stroke = a.textStroke), _t(a, "fontFamily") && (o.fontFamily = a.fontFamily), _t(a, "fontSize") && (o.fontSize = a.fontSize), _t(a, "fontStyle") && (o.fontStyle = a.fontStyle), _t(a, "fontWeight") && (o.fontWeight = a.fontWeight), r = { type: "text", style: o, silent: !0 }, i = {}; var s = _t(a, "textPosition"); n ? i.position = s ? a.textPosition : "inside" : s && (i.position = a.textPosition), _t(a, "textPosition") && (i.position = a.textPosition), _t(a, "textOffset") && (i.offset = a.textOffset), _t(a, "textRotation") && (i.rotation = a.textRotation), _t(a, "textDistance") && (i.distance = a.textDistance) } return qO(o, t), E(o.rich, (function (t) { qO(t, t) })), { textConfig: i, textContent: r } } function qO(t, e) { e && (e.font = e.textFont || e.font, _t(e, "textStrokeWidth") && (t.lineWidth = e.textStrokeWidth), _t(e, "textAlign") && (t.align = e.textAlign), _t(e, "textVerticalAlign") && (t.verticalAlign = e.textVerticalAlign), _t(e, "textLineHeight") && (t.lineHeight = e.textLineHeight), _t(e, "textWidth") && (t.width = e.textWidth), _t(e, "textHeight") && (t.height = e.textHeight), _t(e, "textBackgroundColor") && (t.backgroundColor = e.textBackgroundColor), _t(e, "textPadding") && (t.padding = e.textPadding), _t(e, "textBorderColor") && (t.borderColor = e.textBorderColor), _t(e, "textBorderWidth") && (t.borderWidth = e.textBorderWidth), _t(e, "textBorderRadius") && (t.borderRadius = e.textBorderRadius), _t(e, "textBoxShadowColor") && (t.shadowColor = e.textBoxShadowColor), _t(e, "textBoxShadowBlur") && (t.shadowBlur = e.textBoxShadowBlur), _t(e, "textBoxShadowOffsetX") && (t.shadowOffsetX = e.textBoxShadowOffsetX), _t(e, "textBoxShadowOffsetY") && (t.shadowOffsetY = e.textBoxShadowOffsetY)) } function KO(t, e, n) { var i = t; i.textPosition = i.textPosition || n.position || "inside", null != n.offset && (i.textOffset = n.offset), null != n.rotation && (i.textRotation = n.rotation), null != n.distance && (i.textDistance = n.distance); var r = i.textPosition.indexOf("inside") >= 0, o = t.fill || "#000"; $O(i, e); var a = null == i.textFill; return r ? a && (i.textFill = n.insideFill || "#fff", !i.textStroke && n.insideStroke && (i.textStroke = n.insideStroke), !i.textStroke && (i.textStroke = o), null == i.textStrokeWidth && (i.textStrokeWidth = 2)) : (a && (i.textFill = t.fill || n.outsideFill || "#000"), !i.textStroke && n.outsideStroke && (i.textStroke = n.outsideStroke)), i.text = e.text, i.rich = e.rich, E(e.rich, (function (t) { $O(t, t) })), i } function $O(t, e) { e && (_t(e, "fill") && (t.textFill = e.fill), _t(e, "stroke") && (t.textStroke = e.fill), _t(e, "lineWidth") && (t.textStrokeWidth = e.lineWidth), _t(e, "font") && (t.font = e.font), _t(e, "fontStyle") && (t.fontStyle = e.fontStyle), _t(e, "fontWeight") && (t.fontWeight = e.fontWeight), _t(e, "fontSize") && (t.fontSize = e.fontSize), _t(e, "fontFamily") && (t.fontFamily = e.fontFamily), _t(e, "align") && (t.textAlign = e.align), _t(e, "verticalAlign") && (t.textVerticalAlign = e.verticalAlign), _t(e, "lineHeight") && (t.textLineHeight = e.lineHeight), _t(e, "width") && (t.textWidth = e.width), _t(e, "height") && (t.textHeight = e.height), _t(e, "backgroundColor") && (t.textBackgroundColor = e.backgroundColor), _t(e, "padding") && (t.textPadding = e.padding), _t(e, "borderColor") && (t.textBorderColor = e.borderColor), _t(e, "borderWidth") && (t.textBorderWidth = e.borderWidth), _t(e, "borderRadius") && (t.textBorderRadius = e.borderRadius), _t(e, "shadowColor") && (t.textBoxShadowColor = e.shadowColor), _t(e, "shadowBlur") && (t.textBoxShadowBlur = e.shadowBlur), _t(e, "shadowOffsetX") && (t.textBoxShadowOffsetX = e.shadowOffsetX), _t(e, "shadowOffsetY") && (t.textBoxShadowOffsetY = e.shadowOffsetY), _t(e, "textShadowColor") && (t.textShadowColor = e.textShadowColor), _t(e, "textShadowBlur") && (t.textShadowBlur = e.textShadowBlur), _t(e, "textShadowOffsetX") && (t.textShadowOffsetX = e.textShadowOffsetX), _t(e, "textShadowOffsetY") && (t.textShadowOffsetY = e.textShadowOffsetY)) } var JO = { position: ["x", "y"], scale: ["scaleX", "scaleY"], origin: ["originX", "originY"] }, QO = G(JO), tR = (V(yr, (function (t, e) { return t[e] = 1, t }), {}), yr.join(", "), ["", "style", "shape", "extra"]), eR = Oo(); function nR(t, e, n, i, r) { var o = t + "Animation", a = ph(t, i, r) || {}, s = eR(e).userDuring; return a.duration > 0 && (a.during = s ? W(uR, { el: e, userDuring: s }) : null, a.setToFinal = !0, a.scope = t), A(a, n[o]), a } function iR(t, e, n, i) { var r = (i = i || {}).dataIndex, o = i.isInit, a = i.clearStyle, s = n.isAnimationEnabled(), l = eR(t), u = e.style; l.userDuring = e.during; var h = {}, c = {}; if (function (t, e, n) { for (var i = 0; i < QO.length; i++) { var r = QO[i], o = JO[r], a = e[r]; a && (n[o[0]] = a[0], n[o[1]] = a[1]) } for (i = 0; i < yr.length; i++) { var s = yr[i]; null != e[s] && (n[s] = e[s]) } }(0, e, c), cR("shape", e, c), cR("extra", e, c), !o && s && (function (t, e, n) { for (var i = e.transition, r = aR(i) ? yr : bo(i || []), o = 0; o < r.length; o++) { var a = r[o]; if ("style" !== a && "shape" !== a && "extra" !== a) { var s = t[a]; 0, n[a] = s } } }(t, e, h), hR("shape", t, e, h), hR("extra", t, e, h), function (t, e, n, i) { if (!n) return; var r, o = t.style; if (o) { var a = n.transition, s = e.transition; if (a && !aR(a)) { var l = bo(a); !r && (r = i.style = {}); for (var u = 0; u < l.length; u++) { var h = o[f = l[u]]; r[f] = h } } else if (t.getAnimationStyleProps && (aR(s) || aR(a) || P(s, "style") >= 0)) { var c = t.getAnimationStyleProps(), p = c ? c.style : null; if (p) { !r && (r = i.style = {}); var d = G(n); for (u = 0; u < d.length; u++) { var f; if (p[f = d[u]]) { h = o[f]; r[f] = h } } } } } }(t, e, u, h)), c.style = u, function (t, e, n) { var i = e.style; if (!t.isGroup && i) { if (n) { t.useStyle({}); for (var r = t.animators, o = 0; o < r.length; o++) { var a = r[o]; "style" === a.targetName && a.changeTarget(t.style) } } t.setStyle(i) } e && (e.style = null, e && t.attr(e), e.style = i) }(t, c, a), function (t, e) { _t(e, "silent") && (t.silent = e.silent), _t(e, "ignore") && (t.ignore = e.ignore), t instanceof Sa && _t(e, "invisible") && (t.invisible = e.invisible); t instanceof Is && _t(e, "autoBatch") && (t.autoBatch = e.autoBatch) }(t, e), s) if (o) { var p = {}; E(tR, (function (t) { var n = t ? e[t] : e; n && n.enterFrom && (t && (p[t] = p[t] || {}), A(t ? p[t] : p, n.enterFrom)) })); var d = nR("enter", t, e, n, r); d.duration > 0 && t.animateFrom(p, d) } else !function (t, e, n, i, r) { if (r) { var o = nR("update", t, e, i, n); o.duration > 0 && t.animateFrom(r, o) } }(t, e, r || 0, n, h); rR(t, e), u ? t.dirty() : t.markRedraw() } function rR(t, e) { for (var n = eR(t).leaveToProps, i = 0; i < tR.length; i++) { var r = tR[i], o = r ? e[r] : e; o && o.leaveTo && (n || (n = eR(t).leaveToProps = {}), r && (n[r] = n[r] || {}), A(r ? n[r] : n, o.leaveTo)) } } function oR(t, e, n, i) { if (t) { var r = t.parent, o = eR(t).leaveToProps; if (o) { var a = nR("update", t, e, n, 0); a.done = function () { r.remove(t), i && i() }, t.animateTo(o, a) } else r.remove(t), i && i() } } function aR(t) { return "all" === t } var sR = {}, lR = { setTransform: function (t, e) { return sR.el[t] = e, this }, getTransform: function (t) { return sR.el[t] }, setShape: function (t, e) { var n = sR.el; return (n.shape || (n.shape = {}))[t] = e, n.dirtyShape && n.dirtyShape(), this }, getShape: function (t) { var e = sR.el.shape; if (e) return e[t] }, setStyle: function (t, e) { var n = sR.el, i = n.style; return i && (i[t] = e, n.dirtyStyle && n.dirtyStyle()), this }, getStyle: function (t) { var e = sR.el.style; if (e) return e[t] }, setExtra: function (t, e) { return (sR.el.extra || (sR.el.extra = {}))[t] = e, this }, getExtra: function (t) { var e = sR.el.extra; if (e) return e[t] } }; function uR() { var t = this, e = t.el; if (e) { var n = eR(e).userDuring, i = t.userDuring; n === i ? (sR.el = e, i(lR)) : t.el = t.userDuring = null } } function hR(t, e, n, i) { var r = n[t]; if (r) { var o, a = e[t]; if (a) { var s = n.transition, l = r.transition; if (l) if (!o && (o = i[t] = {}), aR(l)) A(o, a); else for (var u = bo(l), h = 0; h < u.length; h++) { var c = a[d = u[h]]; o[d] = c } else if (aR(s) || P(s, t) >= 0) { !o && (o = i[t] = {}); var p = G(a); for (h = 0; h < p.length; h++) { var d; c = a[d = p[h]]; pR(r[d], c) && (o[d] = c) } } } } } function cR(t, e, n) { var i = e[t]; if (i) for (var r = n[t] = {}, o = G(i), a = 0; a < o.length; a++) { var s = o[a]; r[s] = ki(i[s]) } } function pR(t, e) { return N(t) ? t !== e : null != t && isFinite(t) } var dR = Oo(), fR = ["percent", "easing", "shape", "style", "extra"]; function gR(t) { t.stopAnimation("keyframe"), t.attr(dR(t)) } function yR(t, e, n) { if (n.isAnimationEnabled() && e) if (Y(e)) E(e, (function (e) { yR(t, e, n) })); else { var i = e.keyframes, r = e.duration; if (n && null == r) { var o = ph("enter", n, 0); r = o && o.duration } if (i && r) { var a = dR(t); E(tR, (function (n) { if (!n || t[n]) { var o; i.sort((function (t, e) { return t.percent - e.percent })), E(i, (function (i) { var s = t.animators, l = n ? i[n] : i; if (l) { var u = G(l); if (n || (u = B(u, (function (t) { return P(fR, t) < 0 }))), u.length) { o || ((o = t.animate(n, e.loop, !0)).scope = "keyframe"); for (var h = 0; h < s.length; h++)s[h] !== o && s[h].targetName === o.targetName && s[h].stopTracks(u); n && (a[n] = a[n] || {}); var c = n ? a[n] : a; E(u, (function (e) { c[e] = ((n ? t[n] : t) || {})[e] })), o.whenWithKeys(r * i.percent, l, u, i.easing) } } })), o && o.delay(e.delay || 0).duration(r).start(e.easing) } })) } } } var vR = "emphasis", mR = "normal", xR = "blur", _R = "select", bR = [mR, vR, xR, _R], wR = { normal: ["itemStyle"], emphasis: [vR, "itemStyle"], blur: [xR, "itemStyle"], select: [_R, "itemStyle"] }, SR = { normal: ["label"], emphasis: [vR, "label"], blur: [xR, "label"], select: [_R, "label"] }, MR = ["x", "y"], IR = { normal: {}, emphasis: {}, blur: {}, select: {} }, TR = { cartesian2d: function (t) { var e = t.master.getRect(); return { coordSys: { type: "cartesian2d", x: e.x, y: e.y, width: e.width, height: e.height }, api: { coord: function (e) { return t.dataToPoint(e) }, size: W(HO, t) } } }, geo: function (t) { var e = t.getBoundingRect(); return { coordSys: { type: "geo", x: e.x, y: e.y, width: e.width, height: e.height, zoom: t.getZoom() }, api: { coord: function (e) { return t.dataToPoint(e) }, size: W(YO, t) } } }, single: function (t) { var e = t.getRect(); return { coordSys: { type: "singleAxis", x: e.x, y: e.y, width: e.width, height: e.height }, api: { coord: function (e) { return t.dataToPoint(e) }, size: W(XO, t) } } }, polar: function (t) { var e = t.getRadiusAxis(), n = t.getAngleAxis(), i = e.getExtent(); return i[0] > i[1] && i.reverse(), { coordSys: { type: "polar", cx: t.cx, cy: t.cy, r: i[1], r0: i[0] }, api: { coord: function (i) { var r = e.dataToRadius(i[0]), o = n.dataToAngle(i[1]), a = t.coordToPoint([r, o]); return a.push(r, o * Math.PI / 180), a }, size: W(UO, t) } } }, calendar: function (t) { var e = t.getRect(), n = t.getRangeInfo(); return { coordSys: { type: "calendar", x: e.x, y: e.y, width: e.width, height: e.height, cellWidth: t.getCellWidth(), cellHeight: t.getCellHeight(), rangeInfo: { start: n.start, end: n.end, weeks: n.weeks, dayCount: n.allDay } }, api: { coord: function (e, n) { return t.dataToPoint(e, n) } } } } }; function CR(t) { return t instanceof Is } function DR(t) { return t instanceof Sa } var AR = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n, i) { this._progressiveEls = null; var r = this._data, o = t.getData(), a = this.group, s = RR(t, o, e, n); r || a.removeAll(), o.diff(r).add((function (e) { ER(n, null, e, s(e, i), t, a, o) })).remove((function (e) { var n = r.getItemGraphicEl(e); n && oR(n, GO(n).option, t) })).update((function (e, l) { var u = r.getItemGraphicEl(l); ER(n, u, e, s(e, i), t, a, o) })).execute(); var l = t.get("clip", !0) ? SS(t.coordinateSystem, !1, t) : null; l ? a.setClipPath(l) : a.removeClipPath(), this._data = o }, e.prototype.incrementalPrepareRender = function (t, e, n) { this.group.removeAll(), this._data = null }, e.prototype.incrementalRender = function (t, e, n, i, r) { var o = e.getData(), a = RR(e, o, n, i), s = this._progressiveEls = []; function l(t) { t.isGroup || (t.incremental = !0, t.ensureState("emphasis").hoverLayer = !0) } for (var u = t.start; u < t.end; u++) { var h = ER(null, null, u, a(u, r), e, this.group, o); h && (h.traverse(l), s.push(h)) } }, e.prototype.eachRendered = function (t) { qh(this._progressiveEls || this.group, t) }, e.prototype.filterForExposedEvent = function (t, e, n, i) { var r = e.element; if (null == r || n.name === r) return !0; for (; (n = n.__hostTarget || n.parent) && n !== this.group;)if (n.name === r) return !0; return !1 }, e.type = "custom", e }(kg); function kR(t) { var e, n = t.type; if ("path" === n) { var i = t.shape, r = null != i.width && null != i.height ? { x: i.x || 0, y: i.y || 0, width: i.width, height: i.height } : null, o = UR(i); e = Ah(o, null, r, i.layout || "center"), GO(e).customPathData = o } else if ("image" === n) e = new ks({}), GO(e).customImagePath = t.style.image; else if ("text" === n) e = new Fs({}); else if ("group" === n) e = new zr; else { if ("compoundPath" === n) throw new Error('"compoundPath" is not supported yet.'); var a = Dh(n); if (!a) { var s = ""; 0, vo(s) } e = new a } return GO(e).customGraphicType = n, e.name = t.name, e.z2EmphasisLift = 1, e.z2SelectLift = 1, e } function LR(t, e, n, i, r, o, a) { gR(e); var s = r && r.normal.cfg; s && e.setTextConfig(s), i && null == i.transition && (i.transition = MR); var l = i && i.style; if (l) { if ("text" === e.type) { var u = l; _t(u, "textFill") && (u.fill = u.textFill), _t(u, "textStroke") && (u.stroke = u.textStroke) } var h = void 0, c = CR(e) ? l.decal : null; t && c && (c.dirty = !0, h = gv(c, t)), l.__decalPattern = h } DR(e) && (l && (h = l.__decalPattern) && (l.decal = h)); iR(e, i, o, { dataIndex: n, isInit: a, clearStyle: !0 }), yR(e, i.keyframeAnimation, o) } function PR(t, e, n, i, r) { var o = e.isGroup ? null : e, a = r && r[t].cfg; if (o) { var s = o.ensureState(t); if (!1 === i) { var l = o.getState(t); l && (l.style = null) } else s.style = i || null; a && (s.textConfig = a), Cl(o) } } function OR(t, e, n) { var i = n === mR, r = i ? e : FR(e, n), o = r ? r.z2 : null; null != o && ((i ? t : t.ensureState(n)).z2 = o || 0) } function RR(t, e, n, i) { var r = t.get("renderItem"), o = t.coordinateSystem, a = {}; o && (a = o.prepareCustoms ? o.prepareCustoms(o) : TR[o.type](o)); for (var s, l, u = k({ getWidth: i.getWidth, getHeight: i.getHeight, getZr: i.getZr, getDevicePixelRatio: i.getDevicePixelRatio, value: function (t, n) { return null == n && (n = s), e.getStore().get(e.getDimensionIndex(t || 0), n) }, style: function (n, i) { 0; null == i && (i = s); var r = e.getItemVisual(i, "style"), o = r && r.fill, a = r && r.opacity, l = m(i, mR).getItemStyle(); null != o && (l.fill = o), null != a && (l.opacity = a); var u = { inheritColor: U(o) ? o : "#000" }, h = x(i, mR), c = nc(h, null, u, !1, !0); c.text = h.getShallow("show") ? rt(t.getFormattedLabel(i, mR), iS(e, i)) : null; var p = ic(h, u, !1); return b(n, l), l = KO(l, c, p), n && _(l, n), l.legacy = !0, l }, ordinalRawValue: function (t, n) { null == n && (n = s), t = t || 0; var i = e.getDimensionInfo(t); if (!i) { var r = e.getDimensionIndex(t); return r >= 0 ? e.getStore().get(r, n) : void 0 } var o = e.get(i.name, n), a = i && i.ordinalMeta; return a ? a.categories[o] : o }, styleEmphasis: function (n, i) { 0; null == i && (i = s); var r = m(i, vR).getItemStyle(), o = x(i, vR), a = nc(o, null, null, !0, !0); a.text = o.getShallow("show") ? ot(t.getFormattedLabel(i, vR), t.getFormattedLabel(i, mR), iS(e, i)) : null; var l = ic(o, null, !0); return b(n, r), r = KO(r, a, l), n && _(r, n), r.legacy = !0, r }, visual: function (t, n) { if (null == n && (n = s), _t(BO, t)) { var i = e.getItemVisual(n, "style"); return i ? i[BO[t]] : null } if (_t(FO, t)) return e.getItemVisual(n, t) }, barLayout: function (t) { if ("cartesian2d" === o.type) { return function (t) { var e = [], n = t.axis, i = "axis0"; if ("category" === n.type) { for (var r = n.getBandWidth(), o = 0; o < t.count; o++)e.push(k({ bandWidth: r, axisKey: i, stackId: zx + o }, t)); var a = Wx(e), s = []; for (o = 0; o < t.count; o++) { var l = a[i][zx + o]; l.offsetCenter = l.offset + l.width / 2, s.push(l) } return s } }(k({ axis: o.getBaseAxis() }, t)) } }, currentSeriesIndices: function () { return n.getCurrentSeriesIndices() }, font: function (t) { return lc(t, n) } }, a.api || {}), h = { context: {}, seriesId: t.id, seriesName: t.name, seriesIndex: t.seriesIndex, coordSys: a.coordSys, dataInsideLength: e.count(), encode: NR(t.getData()) }, c = {}, p = {}, d = {}, f = {}, g = 0; g < bR.length; g++) { var y = bR[g]; d[y] = t.getModel(wR[y]), f[y] = t.getModel(SR[y]) } function v(t) { return t === s ? l || (l = e.getItemModel(t)) : e.getItemModel(t) } function m(t, n) { return e.hasItemOption ? t === s ? c[n] || (c[n] = v(t).getModel(wR[n])) : v(t).getModel(wR[n]) : d[n] } function x(t, n) { return e.hasItemOption ? t === s ? p[n] || (p[n] = v(t).getModel(SR[n])) : v(t).getModel(SR[n]) : f[n] } return function (t, n) { return s = t, l = null, c = {}, p = {}, r && r(k({ dataIndexInside: t, dataIndex: e.getRawIndex(t), actionType: n ? n.type : null }, h), u) }; function _(t, e) { for (var n in e) _t(e, n) && (t[n] = e[n]) } function b(t, e) { t && (t.textFill && (e.textFill = t.textFill), t.textPosition && (e.textPosition = t.textPosition)) } } function NR(t) { var e = {}; return E(t.dimensions, (function (n) { var i = t.getDimensionInfo(n); if (!i.isExtraCoord) { var r = i.coordDim; (e[r] = e[r] || [])[i.coordDimIndex] = t.getDimensionIndex(n) } })), e } function ER(t, e, n, i, r, o, a) { if (i) { var s = zR(t, e, n, i, r, o); return s && a.setItemGraphicEl(n, s), s && Yl(s, i.focus, i.blurScope, i.emphasisDisabled), s } o.remove(e) } function zR(t, e, n, i, r, o) { var a = -1, s = e; e && VR(e, i, r) && (a = P(o.childrenRef(), e), e = null); var l, u, h = !e, c = e; c ? c.clearStates() : (c = kR(i), s && (l = s, (u = c).copyTransform(l), DR(u) && DR(l) && (u.setStyle(l.style), u.z = l.z, u.z2 = l.z2, u.zlevel = l.zlevel, u.invisible = l.invisible, u.ignore = l.ignore, CR(u) && CR(l) && u.setShape(l.shape)))), !1 === i.morph ? c.disableMorphing = !0 : c.disableMorphing && (c.disableMorphing = !1), IR.normal.cfg = IR.normal.conOpt = IR.emphasis.cfg = IR.emphasis.conOpt = IR.blur.cfg = IR.blur.conOpt = IR.select.cfg = IR.select.conOpt = null, IR.isLegacy = !1, function (t, e, n, i, r, o) { if (t.isGroup) return; BR(n, null, o), BR(n, vR, o); var a = o.normal.conOpt, s = o.emphasis.conOpt, l = o.blur.conOpt, u = o.select.conOpt; if (null != a || null != s || null != u || null != l) { var h = t.getTextContent(); if (!1 === a) h && t.removeTextContent(); else { a = o.normal.conOpt = a || { type: "text" }, h ? h.clearStates() : (h = kR(a), t.setTextContent(h)), LR(null, h, e, a, null, i, r); for (var c = a && a.style, p = 0; p < bR.length; p++) { var d = bR[p]; if (d !== mR) { var f = o[d].conOpt; PR(d, h, 0, GR(a, f, d), null) } } c ? h.dirty() : h.markRedraw() } } }(c, n, i, r, h, IR), function (t, e, n, i, r) { var o = n.clipPath; if (!1 === o) t && t.getClipPath() && t.removeClipPath(); else if (o) { var a = t.getClipPath(); a && VR(a, o, i) && (a = null), a || (a = kR(o), t.setClipPath(a)), LR(null, a, e, o, null, i, r) } }(c, n, i, r, h), LR(t, c, n, i, IR, r, h), _t(i, "info") && (GO(c).info = i.info); for (var p = 0; p < bR.length; p++) { var d = bR[p]; if (d !== mR) { var f = FR(i, d); PR(d, c, 0, GR(i, f, d), IR) } } return function (t, e, n) { if (!t.isGroup) { var i = t, r = n.currentZ, o = n.currentZLevel; i.z = r, i.zlevel = o; var a = e.z2; null != a && (i.z2 = a || 0); for (var s = 0; s < bR.length; s++)OR(i, e, bR[s]) } }(c, i, r), "group" === i.type && function (t, e, n, i, r) { var o = i.children, a = o ? o.length : 0, s = i.$mergeChildren, l = "byName" === s || i.diffChildrenByName, u = !1 === s; if (!a && !l && !u) return; if (l) return h = { api: t, oldChildren: e.children() || [], newChildren: o || [], dataIndex: n, seriesModel: r, group: e }, void new Vm(h.oldChildren, h.newChildren, HR, HR, h).add(YR).update(YR).remove(XR).execute(); var h; u && e.removeAll(); for (var c = 0; c < a; c++) { var p = o[c], d = e.childAt(c); p ? (null == p.ignore && (p.ignore = !1), zR(t, d, n, p, r, e)) : d.ignore = !0 } for (var f = e.childCount() - 1; f >= c; f--) { var g = e.childAt(f); WR(e, g, r) } }(t, c, n, i, r), a >= 0 ? o.replaceAt(c, a) : o.add(c), c } function VR(t, e, n) { var i, r = GO(t), o = e.type, a = e.shape, s = e.style; return n.isUniversalTransitionEnabled() || null != o && o !== r.customGraphicType || "path" === o && ((i = a) && (_t(i, "pathData") || _t(i, "d"))) && UR(a) !== r.customPathData || "image" === o && _t(s, "image") && s.image !== r.customImagePath } function BR(t, e, n) { var i = e ? FR(t, e) : t, r = e ? GR(t, i, vR) : t.style, o = t.type, a = i ? i.textConfig : null, s = t.textContent, l = s ? e ? FR(s, e) : s : null; if (r && (n.isLegacy || ZO(r, o, !!a, !!l))) { n.isLegacy = !0; var u = jO(r, o, !e); !a && u.textConfig && (a = u.textConfig), !l && u.textContent && (l = u.textContent) } if (!e && l) { var h = l; !h.type && (h.type = "text") } var c = e ? n[e] : n.normal; c.cfg = a, c.conOpt = l } function FR(t, e) { return e ? t ? t[e] : null : t } function GR(t, e, n) { var i = e && e.style; return null == i && n === vR && t && (i = t.styleEmphasis), i } function WR(t, e, n) { e && oR(e, GO(t).option, n) } function HR(t, e) { var n = t && t.name; return null != n ? n : "e\0\0" + e } function YR(t, e) { var n = this.context, i = null != t ? n.newChildren[t] : null, r = null != e ? n.oldChildren[e] : null; zR(n.api, r, n.dataIndex, i, n.seriesModel, n.group) } function XR(t) { var e = this.context, n = e.oldChildren[t]; n && oR(n, GO(n).option, e.seriesModel) } function UR(t) { return t && (t.pathData || t.d) } var ZR = Oo(), jR = T, qR = W, KR = function () { function t() { this._dragging = !1, this.animationThreshold = 15 } return t.prototype.render = function (t, e, n, i) { var r = e.get("value"), o = e.get("status"); if (this._axisModel = t, this._axisPointerModel = e, this._api = n, i || this._lastValue !== r || this._lastStatus !== o) { this._lastValue = r, this._lastStatus = o; var a = this._group, s = this._handle; if (!o || "hide" === o) return a && a.hide(), void (s && s.hide()); a && a.show(), s && s.show(); var l = {}; this.makeElOption(l, r, t, e, n); var u = l.graphicKey; u !== this._lastGraphicKey && this.clear(n), this._lastGraphicKey = u; var h = this._moveAnimation = this.determineAnimation(t, e); if (a) { var c = H($R, e, h); this.updatePointerEl(a, l, c), this.updateLabelEl(a, l, c, e) } else a = this._group = new zr, this.createPointerEl(a, l, t, e), this.createLabelEl(a, l, t, e), n.getZr().add(a); eN(a, e, !0), this._renderHandle(r) } }, t.prototype.remove = function (t) { this.clear(t) }, t.prototype.dispose = function (t) { this.clear(t) }, t.prototype.determineAnimation = function (t, e) { var n = e.get("animation"), i = t.axis, r = "category" === i.type, o = e.get("snap"); if (!o && !r) return !1; if ("auto" === n || null == n) { var a = this.animationThreshold; if (r && i.getBandWidth() > a) return !0; if (o) { var s = pI(t).seriesDataCount, l = i.getExtent(); return Math.abs(l[0] - l[1]) / s > a } return !1 } return !0 === n }, t.prototype.makeElOption = function (t, e, n, i, r) { }, t.prototype.createPointerEl = function (t, e, n, i) { var r = e.pointer; if (r) { var o = ZR(t).pointerEl = new Kh[r.type](jR(e.pointer)); t.add(o) } }, t.prototype.createLabelEl = function (t, e, n, i) { if (e.label) { var r = ZR(t).labelEl = new Fs(jR(e.label)); t.add(r), QR(r, i) } }, t.prototype.updatePointerEl = function (t, e, n) { var i = ZR(t).pointerEl; i && e.pointer && (i.setStyle(e.pointer.style), n(i, { shape: e.pointer.shape })) }, t.prototype.updateLabelEl = function (t, e, n, i) { var r = ZR(t).labelEl; r && (r.setStyle(e.label.style), n(r, { x: e.label.x, y: e.label.y }), QR(r, i)) }, t.prototype._renderHandle = function (t) { if (!this._dragging && this.updateHandleTransform) { var e, n = this._axisPointerModel, i = this._api.getZr(), r = this._handle, o = n.getModel("handle"), a = n.get("status"); if (!o.get("show") || !a || "hide" === a) return r && i.remove(r), void (this._handle = null); this._handle || (e = !0, r = this._handle = Hh(o.get("icon"), { cursor: "move", draggable: !0, onmousemove: function (t) { de(t.event) }, onmousedown: qR(this._onHandleDragMove, this, 0, 0), drift: qR(this._onHandleDragMove, this), ondragend: qR(this._onHandleDragEnd, this) }), i.add(r)), eN(r, n, !1), r.setStyle(o.getItemStyle(null, ["color", "borderColor", "borderWidth", "opacity", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY"])); var s = o.get("size"); Y(s) || (s = [s, s]), r.scaleX = s[0] / 2, r.scaleY = s[1] / 2, Fg(this, "_doDispatchAxisPointer", o.get("throttle") || 0, "fixRate"), this._moveHandleToValue(t, e) } }, t.prototype._moveHandleToValue = function (t, e) { $R(this._axisPointerModel, !e && this._moveAnimation, this._handle, tN(this.getHandleTransform(t, this._axisModel, this._axisPointerModel))) }, t.prototype._onHandleDragMove = function (t, e) { var n = this._handle; if (n) { this._dragging = !0; var i = this.updateHandleTransform(tN(n), [t, e], this._axisModel, this._axisPointerModel); this._payloadInfo = i, n.stopAnimation(), n.attr(tN(i)), ZR(n).lastProp = null, this._doDispatchAxisPointer() } }, t.prototype._doDispatchAxisPointer = function () { if (this._handle) { var t = this._payloadInfo, e = this._axisModel; this._api.dispatchAction({ type: "updateAxisPointer", x: t.cursorPoint[0], y: t.cursorPoint[1], tooltipOption: t.tooltipOption, axesInfo: [{ axisDim: e.axis.dim, axisIndex: e.componentIndex }] }) } }, t.prototype._onHandleDragEnd = function () { if (this._dragging = !1, this._handle) { var t = this._axisPointerModel.get("value"); this._moveHandleToValue(t), this._api.dispatchAction({ type: "hideTip" }) } }, t.prototype.clear = function (t) { this._lastValue = null, this._lastStatus = null; var e = t.getZr(), n = this._group, i = this._handle; e && n && (this._lastGraphicKey = null, n && e.remove(n), i && e.remove(i), this._group = null, this._handle = null, this._payloadInfo = null), Gg(this, "_doDispatchAxisPointer") }, t.prototype.doClear = function () { }, t.prototype.buildLabel = function (t, e, n) { return { x: t[n = n || 0], y: t[1 - n], width: e[n], height: e[1 - n] } }, t }(); function $R(t, e, n, i) { JR(ZR(n).lastProp, i) || (ZR(n).lastProp = i, e ? fh(n, i, t) : (n.stopAnimation(), n.attr(i))) } function JR(t, e) { if (q(t) && q(e)) { var n = !0; return E(e, (function (e, i) { n = n && JR(t[i], e) })), !!n } return t === e } function QR(t, e) { t[e.get(["label", "show"]) ? "show" : "hide"]() } function tN(t) { return { x: t.x || 0, y: t.y || 0, rotation: t.rotation || 0 } } function eN(t, e, n) { var i = e.get("z"), r = e.get("zlevel"); t && t.traverse((function (t) { "group" !== t.type && (null != i && (t.z = i), null != r && (t.zlevel = r), t.silent = n) })) } function nN(t) { var e, n = t.get("type"), i = t.getModel(n + "Style"); return "line" === n ? (e = i.getLineStyle()).fill = null : "shadow" === n && ((e = i.getAreaStyle()).stroke = null), e } function iN(t, e, n, i, r) { var o = rN(n.get("value"), e.axis, e.ecModel, n.get("seriesDataIndices"), { precision: n.get(["label", "precision"]), formatter: n.get(["label", "formatter"]) }), a = n.getModel("label"), s = fp(a.get("padding") || 0), l = a.getFont(), u = br(o, l), h = r.position, c = u.width + s[1] + s[3], p = u.height + s[0] + s[2], d = r.align; "right" === d && (h[0] -= c), "center" === d && (h[0] -= c / 2); var f = r.verticalAlign; "bottom" === f && (h[1] -= p), "middle" === f && (h[1] -= p / 2), function (t, e, n, i) { var r = i.getWidth(), o = i.getHeight(); t[0] = Math.min(t[0] + e, r) - e, t[1] = Math.min(t[1] + n, o) - n, t[0] = Math.max(t[0], 0), t[1] = Math.max(t[1], 0) }(h, c, p, i); var g = a.get("backgroundColor"); g && "auto" !== g || (g = e.get(["axisLine", "lineStyle", "color"])), t.label = { x: h[0], y: h[1], style: nc(a, { text: o, font: l, fill: a.getTextColor(), padding: s, backgroundColor: g }), z2: 10 } } function rN(t, e, n, i, r) { t = e.scale.parse(t); var o = e.scale.getLabel({ value: t }, { precision: r.precision }), a = r.formatter; if (a) { var s = { value: __(e, { value: t }), axisDimension: e.dim, axisIndex: e.index, seriesData: [] }; E(i, (function (t) { var e = n.getSeriesByIndex(t.seriesIndex), i = t.dataIndexInside, r = e && e.getDataParams(i); r && s.seriesData.push(r) })), U(a) ? o = a.replace("{value}", o) : X(a) && (o = a(s)) } return o } function oN(t, e, n) { var i = [1, 0, 0, 1, 0, 0]; return Se(i, i, n.rotation), we(i, i, n.position), zh([t.dataToCoord(e), (n.labelOffset || 0) + (n.labelDirection || 1) * (n.labelMargin || 0)], i) } function aN(t, e, n, i, r, o) { var a = iI.innerTextLayout(n.rotation, 0, n.labelDirection); n.labelMargin = r.get(["label", "margin"]), iN(e, i, r, o, { position: oN(i.axis, t, n), align: a.textAlign, verticalAlign: a.textVerticalAlign }) } function sN(t, e, n) { return { x1: t[n = n || 0], y1: t[1 - n], x2: e[n], y2: e[1 - n] } } function lN(t, e, n) { return { x: t[n = n || 0], y: t[1 - n], width: e[n], height: e[1 - n] } } function uN(t, e, n, i, r, o) { return { cx: t, cy: e, r0: n, r: i, startAngle: r, endAngle: o, clockwise: !0 } } var hN = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.makeElOption = function (t, e, n, i, r) { var o = n.axis, a = o.grid, s = i.get("type"), l = cN(a, o).getOtherAxis(o).getGlobalExtent(), u = o.toGlobalCoord(o.dataToCoord(e, !0)); if (s && "none" !== s) { var h = nN(i), c = pN[s](o, u, l); c.style = h, t.graphicKey = c.type, t.pointer = c } aN(e, t, ZM(a.model, n), n, i, r) }, e.prototype.getHandleTransform = function (t, e, n) { var i = ZM(e.axis.grid.model, e, { labelInside: !1 }); i.labelMargin = n.get(["handle", "margin"]); var r = oN(e.axis, t, i); return { x: r[0], y: r[1], rotation: i.rotation + (i.labelDirection < 0 ? Math.PI : 0) } }, e.prototype.updateHandleTransform = function (t, e, n, i) { var r = n.axis, o = r.grid, a = r.getGlobalExtent(!0), s = cN(o, r).getOtherAxis(r).getGlobalExtent(), l = "x" === r.dim ? 0 : 1, u = [t.x, t.y]; u[l] += e[l], u[l] = Math.min(a[1], u[l]), u[l] = Math.max(a[0], u[l]); var h = (s[1] + s[0]) / 2, c = [h, h]; c[l] = u[l]; return { x: u[0], y: u[1], rotation: t.rotation, cursorPoint: c, tooltipOption: [{ verticalAlign: "middle" }, { align: "center" }][l] } }, e }(KR); function cN(t, e) { var n = {}; return n[e.dim + "AxisIndex"] = e.index, t.getCartesian(n) } var pN = { line: function (t, e, n) { return { type: "Line", subPixelOptimize: !0, shape: sN([e, n[0]], [e, n[1]], dN(t)) } }, shadow: function (t, e, n) { var i = Math.max(1, t.getBandWidth()), r = n[1] - n[0]; return { type: "Rect", shape: lN([e - i / 2, n[0]], [i, r], dN(t)) } } }; function dN(t) { return "x" === t.dim ? 0 : 1 } var fN = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "axisPointer", e.defaultOption = { show: "auto", z: 50, type: "line", snap: !1, triggerTooltip: !0, triggerEmphasis: !0, value: null, status: null, link: [], animation: null, animationDurationUpdate: 200, lineStyle: { color: "#B9BEC9", width: 1, type: "dashed" }, shadowStyle: { color: "rgba(210,219,238,0.2)" }, label: { show: !0, formatter: null, precision: "auto", margin: 3, color: "#fff", padding: [5, 7, 5, 7], backgroundColor: "auto", borderColor: null, borderWidth: 0, borderRadius: 3 }, handle: { show: !1, icon: "M10.7,11.9v-1.3H9.3v1.3c-4.9,0.3-8.8,4.4-8.8,9.4c0,5,3.9,9.1,8.8,9.4h1.3c4.9-0.3,8.8-4.4,8.8-9.4C19.5,16.3,15.6,12.2,10.7,11.9z M13.3,24.4H6.7v-1.2h6.6z M13.3,22H6.7v-1.2h6.6z M13.3,19.6H6.7v-1.2h6.6z", size: 45, margin: 50, color: "#333", shadowBlur: 3, shadowColor: "#aaa", shadowOffsetX: 0, shadowOffsetY: 2, throttle: 40 } }, e }(Rp), gN = Oo(), yN = E; function vN(t, e, n) { if (!r.node) { var i = e.getZr(); gN(i).records || (gN(i).records = {}), function (t, e) { if (gN(t).initialized) return; function n(n, i) { t.on(n, (function (n) { var r = function (t) { var e = { showTip: [], hideTip: [] }, n = function (i) { var r = e[i.type]; r ? r.push(i) : (i.dispatchAction = n, t.dispatchAction(i)) }; return { dispatchAction: n, pendings: e } }(e); yN(gN(t).records, (function (t) { t && i(t, n, r.dispatchAction) })), function (t, e) { var n, i = t.showTip.length, r = t.hideTip.length; i ? n = t.showTip[i - 1] : r && (n = t.hideTip[r - 1]); n && (n.dispatchAction = null, e.dispatchAction(n)) }(r.pendings, e) })) } gN(t).initialized = !0, n("click", H(xN, "click")), n("mousemove", H(xN, "mousemove")), n("globalout", mN) }(i, e), (gN(i).records[t] || (gN(i).records[t] = {})).handler = n } } function mN(t, e, n) { t.handler("leave", null, n) } function xN(t, e, n, i) { e.handler(t, n, i) } function _N(t, e) { if (!r.node) { var n = e.getZr(); (gN(n).records || {})[t] && (gN(n).records[t] = null) } } var bN = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = e.getComponent("tooltip"), r = t.get("triggerOn") || i && i.get("triggerOn") || "mousemove|click"; vN("axisPointer", n, (function (t, e, n) { "none" !== r && ("leave" === t || r.indexOf(t) >= 0) && n({ type: "updateAxisPointer", currTrigger: t, x: e && e.offsetX, y: e && e.offsetY }) })) }, e.prototype.remove = function (t, e) { _N("axisPointer", e) }, e.prototype.dispose = function (t, e) { _N("axisPointer", e) }, e.type = "axisPointer", e }(Tg); function wN(t, e) { var n, i = [], r = t.seriesIndex; if (null == r || !(n = e.getSeriesByIndex(r))) return { point: [] }; var o = n.getData(), a = Po(o, t); if (null == a || a < 0 || Y(a)) return { point: [] }; var s = o.getItemGraphicEl(a), l = n.coordinateSystem; if (n.getTooltipPosition) i = n.getTooltipPosition(a) || []; else if (l && l.dataToPoint) if (t.isStacked) { var u = l.getBaseAxis(), h = l.getOtherAxis(u).dim, c = u.dim, p = "x" === h || "radius" === h ? 1 : 0, d = o.mapDimension(c), f = []; f[p] = o.get(d, a), f[1 - p] = o.get(o.getCalculationInfo("stackResultDimension"), a), i = l.dataToPoint(f) || [] } else i = l.dataToPoint(o.getValues(z(l.dimensions, (function (t) { return o.mapDimension(t) })), a)) || []; else if (s) { var g = s.getBoundingRect().clone(); g.applyTransform(s.transform), i = [g.x + g.width / 2, g.y + g.height / 2] } return { point: i, el: s } } var SN = Oo(); function MN(t, e, n) { var i = t.currTrigger, r = [t.x, t.y], o = t, a = t.dispatchAction || W(n.dispatchAction, n), s = e.getComponent("axisPointer").coordSysAxesInfo; if (s) { AN(r) && (r = wN({ seriesIndex: o.seriesIndex, dataIndex: o.dataIndex }, e).point); var l = AN(r), u = o.axesInfo, h = s.axesInfo, c = "leave" === i || AN(r), p = {}, d = {}, f = { list: [], map: {} }, g = { showPointer: H(TN, d), showTooltip: H(CN, f) }; E(s.coordSysMap, (function (t, e) { var n = l || t.containPoint(r); E(s.coordSysAxesInfo[e], (function (t, e) { var i = t.axis, o = function (t, e) { for (var n = 0; n < (t || []).length; n++) { var i = t[n]; if (e.axis.dim === i.axisDim && e.axis.model.componentIndex === i.axisIndex) return i } }(u, t); if (!c && n && (!u || o)) { var a = o && o.value; null != a || l || (a = i.pointToData(r)), null != a && IN(t, a, g, !1, p) } })) })); var y = {}; return E(h, (function (t, e) { var n = t.linkGroup; n && !d[e] && E(n.axesInfo, (function (e, i) { var r = d[i]; if (e !== t && r) { var o = r.value; n.mapper && (o = t.axis.scale.parse(n.mapper(o, DN(e), DN(t)))), y[t.key] = o } })) })), E(y, (function (t, e) { IN(h[e], t, g, !0, p) })), function (t, e, n) { var i = n.axesInfo = []; E(e, (function (e, n) { var r = e.axisPointerModel.option, o = t[n]; o ? (!e.useHandle && (r.status = "show"), r.value = o.value, r.seriesDataIndices = (o.payloadBatch || []).slice()) : !e.useHandle && (r.status = "hide"), "show" === r.status && i.push({ axisDim: e.axis.dim, axisIndex: e.axis.model.componentIndex, value: r.value }) })) }(d, h, p), function (t, e, n, i) { if (AN(e) || !t.list.length) return void i({ type: "hideTip" }); var r = ((t.list[0].dataByAxis[0] || {}).seriesDataIndices || [])[0] || {}; i({ type: "showTip", escapeConnect: !0, x: e[0], y: e[1], tooltipOption: n.tooltipOption, position: n.position, dataIndexInside: r.dataIndexInside, dataIndex: r.dataIndex, seriesIndex: r.seriesIndex, dataByCoordSys: t.list }) }(f, r, t, a), function (t, e, n) { var i = n.getZr(), r = "axisPointerLastHighlights", o = SN(i)[r] || {}, a = SN(i)[r] = {}; E(t, (function (t, e) { var n = t.axisPointerModel.option; "show" === n.status && t.triggerEmphasis && E(n.seriesDataIndices, (function (t) { var e = t.seriesIndex + " | " + t.dataIndex; a[e] = t })) })); var s = [], l = []; E(o, (function (t, e) { !a[e] && l.push(t) })), E(a, (function (t, e) { !o[e] && s.push(t) })), l.length && n.dispatchAction({ type: "downplay", escapeConnect: !0, notBlur: !0, batch: l }), s.length && n.dispatchAction({ type: "highlight", escapeConnect: !0, notBlur: !0, batch: s }) }(h, 0, n), p } } function IN(t, e, n, i, r) { var o = t.axis; if (!o.scale.isBlank() && o.containData(e)) if (t.involveSeries) { var a = function (t, e) { var n = e.axis, i = n.dim, r = t, o = [], a = Number.MAX_VALUE, s = -1; return E(e.seriesModels, (function (e, l) { var u, h, c = e.getData().mapDimensionsAll(i); if (e.getAxisTooltipData) { var p = e.getAxisTooltipData(c, t, n); h = p.dataIndices, u = p.nestestValue } else { if (!(h = e.getData().indicesOfNearest(c[0], t, "category" === n.type ? .5 : null)).length) return; u = e.getData().get(c[0], h[0]) } if (null != u && isFinite(u)) { var d = t - u, f = Math.abs(d); f <= a && ((f < a || d >= 0 && s < 0) && (a = f, s = d, r = u, o.length = 0), E(h, (function (t) { o.push({ seriesIndex: e.seriesIndex, dataIndexInside: t, dataIndex: e.getData().getRawIndex(t) }) }))) } })), { payloadBatch: o, snapToValue: r } }(e, t), s = a.payloadBatch, l = a.snapToValue; s[0] && null == r.seriesIndex && A(r, s[0]), !i && t.snap && o.containData(l) && null != l && (e = l), n.showPointer(t, e, s), n.showTooltip(t, a, l) } else n.showPointer(t, e) } function TN(t, e, n, i) { t[e.key] = { value: n, payloadBatch: i } } function CN(t, e, n, i) { var r = n.payloadBatch, o = e.axis, a = o.model, s = e.axisPointerModel; if (e.triggerTooltip && r.length) { var l = e.coordSys.model, u = fI(l), h = t.map[u]; h || (h = t.map[u] = { coordSysId: l.id, coordSysIndex: l.componentIndex, coordSysType: l.type, coordSysMainType: l.mainType, dataByAxis: [] }, t.list.push(h)), h.dataByAxis.push({ axisDim: o.dim, axisIndex: a.componentIndex, axisType: a.type, axisId: a.id, value: i, valueLabelOpt: { precision: s.get(["label", "precision"]), formatter: s.get(["label", "formatter"]) }, seriesDataIndices: r.slice() }) } } function DN(t) { var e = t.axis.model, n = {}, i = n.axisDim = t.axis.dim; return n.axisIndex = n[i + "AxisIndex"] = e.componentIndex, n.axisName = n[i + "AxisName"] = e.name, n.axisId = n[i + "AxisId"] = e.id, n } function AN(t) { return !t || null == t[0] || isNaN(t[0]) || null == t[1] || isNaN(t[1]) } function kN(t) { yI.registerAxisPointerClass("CartesianAxisPointer", hN), t.registerComponentModel(fN), t.registerComponentView(bN), t.registerPreprocessor((function (t) { if (t) { (!t.axisPointer || 0 === t.axisPointer.length) && (t.axisPointer = {}); var e = t.axisPointer.link; e && !Y(e) && (t.axisPointer.link = [e]) } })), t.registerProcessor(t.PRIORITY.PROCESSOR.STATISTIC, (function (t, e) { t.getComponent("axisPointer").coordSysAxesInfo = uI(t, e) })), t.registerAction({ type: "updateAxisPointer", event: "updateAxisPointer", update: ":updateAxisPointer" }, MN) } var LN = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.makeElOption = function (t, e, n, i, r) { var o = n.axis; "angle" === o.dim && (this.animationThreshold = Math.PI / 18); var a = o.polar, s = a.getOtherAxis(o).getExtent(), l = o.dataToCoord(e), u = i.get("type"); if (u && "none" !== u) { var h = nN(i), c = PN[u](o, a, l, s); c.style = h, t.graphicKey = c.type, t.pointer = c } var p = function (t, e, n, i, r) { var o = e.axis, a = o.dataToCoord(t), s = i.getAngleAxis().getExtent()[0]; s = s / 180 * Math.PI; var l, u, h, c = i.getRadiusAxis().getExtent(); if ("radius" === o.dim) { var p = [1, 0, 0, 1, 0, 0]; Se(p, p, s), we(p, p, [i.cx, i.cy]), l = zh([a, -r], p); var d = e.getModel("axisLabel").get("rotate") || 0, f = iI.innerTextLayout(s, d * Math.PI / 180, -1); u = f.textAlign, h = f.textVerticalAlign } else { var g = c[1]; l = i.coordToPoint([g + r, a]); var y = i.cx, v = i.cy; u = Math.abs(l[0] - y) / g < .3 ? "center" : l[0] > y ? "left" : "right", h = Math.abs(l[1] - v) / g < .3 ? "middle" : l[1] > v ? "top" : "bottom" } return { position: l, align: u, verticalAlign: h } }(e, n, 0, a, i.get(["label", "margin"])); iN(t, n, i, r, p) }, e }(KR); var PN = { line: function (t, e, n, i) { return "angle" === t.dim ? { type: "Line", shape: sN(e.coordToPoint([i[0], n]), e.coordToPoint([i[1], n])) } : { type: "Circle", shape: { cx: e.cx, cy: e.cy, r: n } } }, shadow: function (t, e, n, i) { var r = Math.max(1, t.getBandWidth()), o = Math.PI / 180; return "angle" === t.dim ? { type: "Sector", shape: uN(e.cx, e.cy, i[0], i[1], (-n - r / 2) * o, (r / 2 - n) * o) } : { type: "Sector", shape: uN(e.cx, e.cy, n - r / 2, n + r / 2, 0, 2 * Math.PI) } } }, ON = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.findAxisModel = function (t) { var e; return this.ecModel.eachComponent(t, (function (t) { t.getCoordSysModel() === this && (e = t) }), this), e }, e.type = "polar", e.dependencies = ["radiusAxis", "angleAxis"], e.defaultOption = { z: 0, center: ["50%", "50%"], radius: "80%" }, e }(Rp), RN = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.getCoordSysModel = function () { return this.getReferringComponents("polar", zo).models[0] }, e.type = "polarAxis", e }(Rp); R(RN, I_); var NN = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "angleAxis", e }(RN), EN = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "radiusAxis", e }(RN), zN = function (t) { function e(e, n) { return t.call(this, "radius", e, n) || this } return n(e, t), e.prototype.pointToData = function (t, e) { return this.polar.pointToData(t, e)["radius" === this.dim ? 0 : 1] }, e }(nb); zN.prototype.dataToRadius = nb.prototype.dataToCoord, zN.prototype.radiusToData = nb.prototype.coordToData; var VN = Oo(), BN = function (t) { function e(e, n) { return t.call(this, "angle", e, n || [0, 360]) || this } return n(e, t), e.prototype.pointToData = function (t, e) { return this.polar.pointToData(t, e)["radius" === this.dim ? 0 : 1] }, e.prototype.calculateCategoryInterval = function () { var t = this, e = t.getLabelModel(), n = t.scale, i = n.getExtent(), r = n.count(); if (i[1] - i[0] < 1) return 0; var o = i[0], a = t.dataToCoord(o + 1) - t.dataToCoord(o), s = Math.abs(a), l = br(null == o ? "" : o + "", e.getFont(), "center", "top"), u = Math.max(l.height, 7) / s; isNaN(u) && (u = 1 / 0); var h = Math.max(0, Math.floor(u)), c = VN(t.model), p = c.lastAutoInterval, d = c.lastTickCount; return null != p && null != d && Math.abs(p - h) <= 1 && Math.abs(d - r) <= 1 && p > h ? h = p : (c.lastTickCount = r, c.lastAutoInterval = h), h }, e }(nb); BN.prototype.dataToAngle = nb.prototype.dataToCoord, BN.prototype.angleToData = nb.prototype.coordToData; var FN = ["radius", "angle"], GN = function () { function t(t) { this.dimensions = FN, this.type = "polar", this.cx = 0, this.cy = 0, this._radiusAxis = new zN, this._angleAxis = new BN, this.axisPointerEnabled = !0, this.name = t || "", this._radiusAxis.polar = this._angleAxis.polar = this } return t.prototype.containPoint = function (t) { var e = this.pointToCoord(t); return this._radiusAxis.contain(e[0]) && this._angleAxis.contain(e[1]) }, t.prototype.containData = function (t) { return this._radiusAxis.containData(t[0]) && this._angleAxis.containData(t[1]) }, t.prototype.getAxis = function (t) { return this["_" + t + "Axis"] }, t.prototype.getAxes = function () { return [this._radiusAxis, this._angleAxis] }, t.prototype.getAxesByScale = function (t) { var e = [], n = this._angleAxis, i = this._radiusAxis; return n.scale.type === t && e.push(n), i.scale.type === t && e.push(i), e }, t.prototype.getAngleAxis = function () { return this._angleAxis }, t.prototype.getRadiusAxis = function () { return this._radiusAxis }, t.prototype.getOtherAxis = function (t) { var e = this._angleAxis; return t === e ? this._radiusAxis : e }, t.prototype.getBaseAxis = function () { return this.getAxesByScale("ordinal")[0] || this.getAxesByScale("time")[0] || this.getAngleAxis() }, t.prototype.getTooltipAxes = function (t) { var e = null != t && "auto" !== t ? this.getAxis(t) : this.getBaseAxis(); return { baseAxes: [e], otherAxes: [this.getOtherAxis(e)] } }, t.prototype.dataToPoint = function (t, e) { return this.coordToPoint([this._radiusAxis.dataToRadius(t[0], e), this._angleAxis.dataToAngle(t[1], e)]) }, t.prototype.pointToData = function (t, e) { var n = this.pointToCoord(t); return [this._radiusAxis.radiusToData(n[0], e), this._angleAxis.angleToData(n[1], e)] }, t.prototype.pointToCoord = function (t) { var e = t[0] - this.cx, n = t[1] - this.cy, i = this.getAngleAxis(), r = i.getExtent(), o = Math.min(r[0], r[1]), a = Math.max(r[0], r[1]); i.inverse ? o = a - 360 : a = o + 360; var s = Math.sqrt(e * e + n * n); e /= s, n /= s; for (var l = Math.atan2(-n, e) / Math.PI * 180, u = l < o ? 1 : -1; l < o || l > a;)l += 360 * u; return [s, l] }, t.prototype.coordToPoint = function (t) { var e = t[0], n = t[1] / 180 * Math.PI; return [Math.cos(n) * e + this.cx, -Math.sin(n) * e + this.cy] }, t.prototype.getArea = function () { var t = this.getAngleAxis(), e = this.getRadiusAxis().getExtent().slice(); e[0] > e[1] && e.reverse(); var n = t.getExtent(), i = Math.PI / 180; return { cx: this.cx, cy: this.cy, r0: e[0], r: e[1], startAngle: -n[0] * i, endAngle: -n[1] * i, clockwise: t.inverse, contain: function (t, e) { var n = t - this.cx, i = e - this.cy, r = n * n + i * i - 1e-4, o = this.r, a = this.r0; return r <= o * o && r >= a * a } } }, t.prototype.convertToPixel = function (t, e, n) { return WN(e) === this ? this.dataToPoint(n) : null }, t.prototype.convertFromPixel = function (t, e, n) { return WN(e) === this ? this.pointToData(n) : null }, t }(); function WN(t) { var e = t.seriesModel, n = t.polarModel; return n && n.coordinateSystem || e && e.coordinateSystem } function HN(t, e) { var n = this, i = n.getAngleAxis(), r = n.getRadiusAxis(); if (i.scale.setExtent(1 / 0, -1 / 0), r.scale.setExtent(1 / 0, -1 / 0), t.eachSeries((function (t) { if (t.coordinateSystem === n) { var e = t.getData(); E(M_(e, "radius"), (function (t) { r.scale.unionExtentFromData(e, t) })), E(M_(e, "angle"), (function (t) { i.scale.unionExtentFromData(e, t) })) } })), v_(i.scale, i.model), v_(r.scale, r.model), "category" === i.type && !i.onBand) { var o = i.getExtent(), a = 360 / i.scale.count(); i.inverse ? o[1] += a : o[1] -= a, i.setExtent(o[0], o[1]) } } function YN(t, e) { if (t.type = e.get("type"), t.scale = m_(e), t.onBand = e.get("boundaryGap") && "category" === t.type, t.inverse = e.get("inverse"), function (t) { return "angleAxis" === t.mainType }(e)) { t.inverse = t.inverse !== e.get("clockwise"); var n = e.get("startAngle"); t.setExtent(n, n + (t.inverse ? -360 : 360)) } e.axis = t, t.model = e } var XN = { dimensions: FN, create: function (t, e) { var n = []; return t.eachComponent("polar", (function (t, i) { var r = new GN(i + ""); r.update = HN; var o = r.getRadiusAxis(), a = r.getAngleAxis(), s = t.findAxisModel("radiusAxis"), l = t.findAxisModel("angleAxis"); YN(o, s), YN(a, l), function (t, e, n) { var i = e.get("center"), r = n.getWidth(), o = n.getHeight(); t.cx = Ur(i[0], r), t.cy = Ur(i[1], o); var a = t.getRadiusAxis(), s = Math.min(r, o) / 2, l = e.get("radius"); null == l ? l = [0, "100%"] : Y(l) || (l = [0, l]); var u = [Ur(l[0], s), Ur(l[1], s)]; a.inverse ? a.setExtent(u[1], u[0]) : a.setExtent(u[0], u[1]) }(r, t, e), n.push(r), t.coordinateSystem = r, r.model = t })), t.eachSeries((function (t) { if ("polar" === t.get("coordinateSystem")) { var e = t.getReferringComponents("polar", zo).models[0]; 0, t.coordinateSystem = e.coordinateSystem } })), n } }, UN = ["axisLine", "axisLabel", "axisTick", "minorTick", "splitLine", "minorSplitLine", "splitArea"]; function ZN(t, e, n) { e[1] > e[0] && (e = e.slice().reverse()); var i = t.coordToPoint([e[0], n]), r = t.coordToPoint([e[1], n]); return { x1: i[0], y1: i[1], x2: r[0], y2: r[1] } } function jN(t) { return t.getRadiusAxis().inverse ? 0 : 1 } function qN(t) { var e = t[0], n = t[t.length - 1]; e && n && Math.abs(Math.abs(e.coord - n.coord) - 360) < 1e-4 && t.pop() } var KN = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.axisPointerClass = "PolarAxisPointer", n } return n(e, t), e.prototype.render = function (t, e) { if (this.group.removeAll(), t.get("show")) { var n = t.axis, i = n.polar, r = i.getRadiusAxis().getExtent(), o = n.getTicksCoords(), a = n.getMinorTicksCoords(), s = z(n.getViewLabels(), (function (t) { t = T(t); var e = n.scale, i = "ordinal" === e.type ? e.getRawOrdinalNumber(t.tickValue) : t.tickValue; return t.coord = n.dataToCoord(i), t })); qN(s), qN(o), E(UN, (function (e) { !t.get([e, "show"]) || n.scale.isBlank() && "axisLine" !== e || $N[e](this.group, t, i, o, a, r, s) }), this) } }, e.type = "angleAxis", e }(yI), $N = { axisLine: function (t, e, n, i, r, o) { var a, s = e.getModel(["axisLine", "lineStyle"]), l = jN(n), u = l ? 0 : 1; (a = 0 === o[u] ? new _u({ shape: { cx: n.cx, cy: n.cy, r: o[l] }, style: s.getLineStyle(), z2: 1, silent: !0 }) : new Bu({ shape: { cx: n.cx, cy: n.cy, r: o[l], r0: o[u] }, style: s.getLineStyle(), z2: 1, silent: !0 })).style.fill = null, t.add(a) }, axisTick: function (t, e, n, i, r, o) { var a = e.getModel("axisTick"), s = (a.get("inside") ? -1 : 1) * a.get("length"), l = o[jN(n)], u = z(i, (function (t) { return new Zu({ shape: ZN(n, [l, l + s], t.coord) }) })); t.add(Ph(u, { style: k(a.getModel("lineStyle").getLineStyle(), { stroke: e.get(["axisLine", "lineStyle", "color"]) }) })) }, minorTick: function (t, e, n, i, r, o) { if (r.length) { for (var a = e.getModel("axisTick"), s = e.getModel("minorTick"), l = (a.get("inside") ? -1 : 1) * s.get("length"), u = o[jN(n)], h = [], c = 0; c < r.length; c++)for (var p = 0; p < r[c].length; p++)h.push(new Zu({ shape: ZN(n, [u, u + l], r[c][p].coord) })); t.add(Ph(h, { style: k(s.getModel("lineStyle").getLineStyle(), k(a.getLineStyle(), { stroke: e.get(["axisLine", "lineStyle", "color"]) })) })) } }, axisLabel: function (t, e, n, i, r, o, a) { var s = e.getCategories(!0), l = e.getModel("axisLabel"), u = l.get("margin"), h = e.get("triggerEvent"); E(a, (function (i, r) { var a = l, c = i.tickValue, p = o[jN(n)], d = n.coordToPoint([p + u, i.coord]), f = n.cx, g = n.cy, y = Math.abs(d[0] - f) / p < .3 ? "center" : d[0] > f ? "left" : "right", v = Math.abs(d[1] - g) / p < .3 ? "middle" : d[1] > g ? "top" : "bottom"; if (s && s[c]) { var m = s[c]; q(m) && m.textStyle && (a = new Mc(m.textStyle, l, l.ecModel)) } var x = new Fs({ silent: iI.isLabelSilent(e), style: nc(a, { x: d[0], y: d[1], fill: a.getTextColor() || e.get(["axisLine", "lineStyle", "color"]), text: i.formattedLabel, align: y, verticalAlign: v }) }); if (t.add(x), h) { var _ = iI.makeAxisEventDataBase(e); _.targetType = "axisLabel", _.value = i.rawLabel, Qs(x).eventData = _ } }), this) }, splitLine: function (t, e, n, i, r, o) { var a = e.getModel("splitLine").getModel("lineStyle"), s = a.get("color"), l = 0; s = s instanceof Array ? s : [s]; for (var u = [], h = 0; h < i.length; h++) { var c = l++ % s.length; u[c] = u[c] || [], u[c].push(new Zu({ shape: ZN(n, o, i[h].coord) })) } for (h = 0; h < u.length; h++)t.add(Ph(u[h], { style: k({ stroke: s[h % s.length] }, a.getLineStyle()), silent: !0, z: e.get("z") })) }, minorSplitLine: function (t, e, n, i, r, o) { if (r.length) { for (var a = e.getModel("minorSplitLine").getModel("lineStyle"), s = [], l = 0; l < r.length; l++)for (var u = 0; u < r[l].length; u++)s.push(new Zu({ shape: ZN(n, o, r[l][u].coord) })); t.add(Ph(s, { style: a.getLineStyle(), silent: !0, z: e.get("z") })) } }, splitArea: function (t, e, n, i, r, o) { if (i.length) { var a = e.getModel("splitArea").getModel("areaStyle"), s = a.get("color"), l = 0; s = s instanceof Array ? s : [s]; for (var u = [], h = Math.PI / 180, c = -i[0].coord * h, p = Math.min(o[0], o[1]), d = Math.max(o[0], o[1]), f = e.get("clockwise"), g = 1, y = i.length; g <= y; g++) { var v = g === y ? i[0].coord : i[g].coord, m = l++ % s.length; u[m] = u[m] || [], u[m].push(new zu({ shape: { cx: n.cx, cy: n.cy, r0: p, r: d, startAngle: c, endAngle: -v * h, clockwise: f }, silent: !0 })), c = -v * h } for (g = 0; g < u.length; g++)t.add(Ph(u[g], { style: k({ fill: s[g % s.length] }, a.getAreaStyle()), silent: !0 })) } } }, JN = ["axisLine", "axisTickLabel", "axisName"], QN = ["splitLine", "splitArea", "minorSplitLine"], tE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.axisPointerClass = "PolarAxisPointer", n } return n(e, t), e.prototype.render = function (t, e) { if (this.group.removeAll(), t.get("show")) { var n = this._axisGroup, i = this._axisGroup = new zr; this.group.add(i); var r = t.axis, o = r.polar, a = o.getAngleAxis(), s = r.getTicksCoords(), l = r.getMinorTicksCoords(), u = a.getExtent()[0], h = r.getExtent(), c = function (t, e, n) { return { position: [t.cx, t.cy], rotation: n / 180 * Math.PI, labelDirection: -1, tickDirection: -1, nameDirection: 1, labelRotate: e.getModel("axisLabel").get("rotate"), z2: 1 } }(o, t, u), p = new iI(t, c); E(JN, p.add, p), i.add(p.getGroup()), Fh(n, i, t), E(QN, (function (e) { t.get([e, "show"]) && !r.scale.isBlank() && eE[e](this.group, t, o, u, h, s, l) }), this) } }, e.type = "radiusAxis", e }(yI), eE = { splitLine: function (t, e, n, i, r, o) { var a = e.getModel("splitLine").getModel("lineStyle"), s = a.get("color"), l = 0; s = s instanceof Array ? s : [s]; for (var u = [], h = 0; h < o.length; h++) { var c = l++ % s.length; u[c] = u[c] || [], u[c].push(new _u({ shape: { cx: n.cx, cy: n.cy, r: Math.max(o[h].coord, 0) } })) } for (h = 0; h < u.length; h++)t.add(Ph(u[h], { style: k({ stroke: s[h % s.length], fill: null }, a.getLineStyle()), silent: !0 })) }, minorSplitLine: function (t, e, n, i, r, o, a) { if (a.length) { for (var s = e.getModel("minorSplitLine").getModel("lineStyle"), l = [], u = 0; u < a.length; u++)for (var h = 0; h < a[u].length; h++)l.push(new _u({ shape: { cx: n.cx, cy: n.cy, r: a[u][h].coord } })); t.add(Ph(l, { style: k({ fill: null }, s.getLineStyle()), silent: !0 })) } }, splitArea: function (t, e, n, i, r, o) { if (o.length) { var a = e.getModel("splitArea").getModel("areaStyle"), s = a.get("color"), l = 0; s = s instanceof Array ? s : [s]; for (var u = [], h = o[0].coord, c = 1; c < o.length; c++) { var p = l++ % s.length; u[p] = u[p] || [], u[p].push(new zu({ shape: { cx: n.cx, cy: n.cy, r0: h, r: o[c].coord, startAngle: 0, endAngle: 2 * Math.PI }, silent: !0 })), h = o[c].coord } for (c = 0; c < u.length; c++)t.add(Ph(u[c], { style: k({ fill: s[c % s.length] }, a.getAreaStyle()), silent: !0 })) } } }; function nE(t) { return t.get("stack") || "__ec_stack_" + t.seriesIndex } function iE(t, e) { return e.dim + t.model.componentIndex } function rE(t, e, n) { var i = {}, r = function (t) { var e = {}; E(t, (function (t, n) { var i = t.getData(), r = t.coordinateSystem, o = r.getBaseAxis(), a = iE(r, o), s = o.getExtent(), l = "category" === o.type ? o.getBandWidth() : Math.abs(s[1] - s[0]) / i.count(), u = e[a] || { bandWidth: l, remainedWidth: l, autoWidthCount: 0, categoryGap: "20%", gap: "30%", stacks: {} }, h = u.stacks; e[a] = u; var c = nE(t); h[c] || u.autoWidthCount++, h[c] = h[c] || { width: 0, maxWidth: 0 }; var p = Ur(t.get("barWidth"), l), d = Ur(t.get("barMaxWidth"), l), f = t.get("barGap"), g = t.get("barCategoryGap"); p && !h[c].width && (p = Math.min(u.remainedWidth, p), h[c].width = p, u.remainedWidth -= p), d && (h[c].maxWidth = d), null != f && (u.gap = f), null != g && (u.categoryGap = g) })); var n = {}; return E(e, (function (t, e) { n[e] = {}; var i = t.stacks, r = t.bandWidth, o = Ur(t.categoryGap, r), a = Ur(t.gap, 1), s = t.remainedWidth, l = t.autoWidthCount, u = (s - o) / (l + (l - 1) * a); u = Math.max(u, 0), E(i, (function (t, e) { var n = t.maxWidth; n && n < u && (n = Math.min(n, s), t.width && (n = Math.min(n, t.width)), s -= n, t.width = n, l--) })), u = (s - o) / (l + (l - 1) * a), u = Math.max(u, 0); var h, c = 0; E(i, (function (t, e) { t.width || (t.width = u), h = t, c += t.width * (1 + a) })), h && (c -= h.width * a); var p = -c / 2; E(i, (function (t, i) { n[e][i] = n[e][i] || { offset: p, width: t.width }, p += t.width * (1 + a) })) })), n }(B(e.getSeriesByType(t), (function (t) { return !e.isSeriesFiltered(t) && t.coordinateSystem && "polar" === t.coordinateSystem.type }))); e.eachSeriesByType(t, (function (t) { if ("polar" === t.coordinateSystem.type) { var e = t.getData(), n = t.coordinateSystem, o = n.getBaseAxis(), a = iE(n, o), s = nE(t), l = r[a][s], u = l.offset, h = l.width, c = n.getOtherAxis(o), p = t.coordinateSystem.cx, d = t.coordinateSystem.cy, f = t.get("barMinHeight") || 0, g = t.get("barMinAngle") || 0; i[s] = i[s] || []; for (var y = e.mapDimension(c.dim), v = e.mapDimension(o.dim), m = gx(e, y), x = "radius" !== o.dim || !t.get("roundCap", !0), _ = c.dataToCoord(0), b = 0, w = e.count(); b < w; b++) { var S = e.get(y, b), M = e.get(v, b), I = S >= 0 ? "p" : "n", T = _; m && (i[s][M] || (i[s][M] = { p: _, n: _ }), T = i[s][M][I]); var C = void 0, D = void 0, A = void 0, k = void 0; if ("radius" === c.dim) { var L = c.dataToCoord(S) - _, P = o.dataToCoord(M); Math.abs(L) < f && (L = (L < 0 ? -1 : 1) * f), C = T, D = T + L, k = (A = P - u) - h, m && (i[s][M][I] = D) } else { var O = c.dataToCoord(S, x) - _, R = o.dataToCoord(M); Math.abs(O) < g && (O = (O < 0 ? -1 : 1) * g), D = (C = R + u) + h, A = T, k = T + O, m && (i[s][M][I] = k) } e.setItemLayout(b, { cx: p, cy: d, r0: C, r: D, startAngle: -A * Math.PI / 180, endAngle: -k * Math.PI / 180, clockwise: A >= k }) } } })) } var oE = { startAngle: 90, clockwise: !0, splitNumber: 12, axisLabel: { rotate: 0 } }, aE = { splitNumber: 5 }, sE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "polar", e }(Tg); function lE(t, e) { e = e || {}; var n = t.coordinateSystem, i = t.axis, r = {}, o = i.position, a = i.orient, s = n.getRect(), l = [s.x, s.x + s.width, s.y, s.y + s.height], u = { horizontal: { top: l[2], bottom: l[3] }, vertical: { left: l[0], right: l[1] } }; r.position = ["vertical" === a ? u.vertical[o] : l[0], "horizontal" === a ? u.horizontal[o] : l[3]]; r.rotation = Math.PI / 2 * { horizontal: 0, vertical: 1 }[a]; r.labelDirection = r.tickDirection = r.nameDirection = { top: -1, bottom: 1, right: 1, left: -1 }[o], t.get(["axisTick", "inside"]) && (r.tickDirection = -r.tickDirection), it(e.labelInside, t.get(["axisLabel", "inside"])) && (r.labelDirection = -r.labelDirection); var h = e.rotate; return null == h && (h = t.get(["axisLabel", "rotate"])), r.labelRotation = "top" === o ? -h : h, r.z2 = 1, r } var uE = ["axisLine", "axisTickLabel", "axisName"], hE = ["splitArea", "splitLine"], cE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.axisPointerClass = "SingleAxisPointer", n } return n(e, t), e.prototype.render = function (e, n, i, r) { var o = this.group; o.removeAll(); var a = this._axisGroup; this._axisGroup = new zr; var s = lE(e), l = new iI(e, s); E(uE, l.add, l), o.add(this._axisGroup), o.add(l.getGroup()), E(hE, (function (t) { e.get([t, "show"]) && pE[t](this, this.group, this._axisGroup, e) }), this), Fh(a, this._axisGroup, e), t.prototype.render.call(this, e, n, i, r) }, e.prototype.remove = function () { xI(this) }, e.type = "singleAxis", e }(yI), pE = { splitLine: function (t, e, n, i) { var r = i.axis; if (!r.scale.isBlank()) { var o = i.getModel("splitLine"), a = o.getModel("lineStyle"), s = a.get("color"); s = s instanceof Array ? s : [s]; for (var l = a.get("width"), u = i.coordinateSystem.getRect(), h = r.isHorizontal(), c = [], p = 0, d = r.getTicksCoords({ tickModel: o }), f = [], g = [], y = 0; y < d.length; ++y) { var v = r.toGlobalCoord(d[y].coord); h ? (f[0] = v, f[1] = u.y, g[0] = v, g[1] = u.y + u.height) : (f[0] = u.x, f[1] = v, g[0] = u.x + u.width, g[1] = v); var m = new Zu({ shape: { x1: f[0], y1: f[1], x2: g[0], y2: g[1] }, silent: !0 }); Rh(m.shape, l); var x = p++ % s.length; c[x] = c[x] || [], c[x].push(m) } var _ = a.getLineStyle(["color"]); for (y = 0; y < c.length; ++y)e.add(Ph(c[y], { style: k({ stroke: s[y % s.length] }, _), silent: !0 })) } }, splitArea: function (t, e, n, i) { mI(t, n, i, i) } }, dE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.getCoordSysModel = function () { return this }, e.type = "singleAxis", e.layoutMode = "box", e.defaultOption = { left: "5%", top: "5%", right: "5%", bottom: "5%", type: "value", position: "bottom", orient: "horizontal", axisLine: { show: !0, lineStyle: { width: 1, type: "solid" } }, tooltip: { show: !0 }, axisTick: { show: !0, length: 6, lineStyle: { width: 1 } }, axisLabel: { show: !0, interval: "auto" }, splitLine: { show: !0, lineStyle: { type: "dashed", opacity: .2 } } }, e }(Rp); R(dE, I_.prototype); var fE = function (t) { function e(e, n, i, r, o) { var a = t.call(this, e, n, i) || this; return a.type = r || "value", a.position = o || "bottom", a } return n(e, t), e.prototype.isHorizontal = function () { var t = this.position; return "top" === t || "bottom" === t }, e.prototype.pointToData = function (t, e) { return this.coordinateSystem.pointToData(t)[0] }, e }(nb), gE = ["single"], yE = function () { function t(t, e, n) { this.type = "single", this.dimension = "single", this.dimensions = gE, this.axisPointerEnabled = !0, this.model = t, this._init(t, e, n) } return t.prototype._init = function (t, e, n) { var i = this.dimension, r = new fE(i, m_(t), [0, 0], t.get("type"), t.get("position")), o = "category" === r.type; r.onBand = o && t.get("boundaryGap"), r.inverse = t.get("inverse"), r.orient = t.get("orient"), t.axis = r, r.model = t, r.coordinateSystem = this, this._axis = r }, t.prototype.update = function (t, e) { t.eachSeries((function (t) { if (t.coordinateSystem === this) { var e = t.getData(); E(e.mapDimensionsAll(this.dimension), (function (t) { this._axis.scale.unionExtentFromData(e, t) }), this), v_(this._axis.scale, this._axis.model) } }), this) }, t.prototype.resize = function (t, e) { this._rect = Cp({ left: t.get("left"), top: t.get("top"), right: t.get("right"), bottom: t.get("bottom"), width: t.get("width"), height: t.get("height") }, { width: e.getWidth(), height: e.getHeight() }), this._adjustAxis() }, t.prototype.getRect = function () { return this._rect }, t.prototype._adjustAxis = function () { var t = this._rect, e = this._axis, n = e.isHorizontal(), i = n ? [0, t.width] : [0, t.height], r = e.inverse ? 1 : 0; e.setExtent(i[r], i[1 - r]), this._updateAxisTransform(e, n ? t.x : t.y) }, t.prototype._updateAxisTransform = function (t, e) { var n = t.getExtent(), i = n[0] + n[1], r = t.isHorizontal(); t.toGlobalCoord = r ? function (t) { return t + e } : function (t) { return i - t + e }, t.toLocalCoord = r ? function (t) { return t - e } : function (t) { return i - t + e } }, t.prototype.getAxis = function () { return this._axis }, t.prototype.getBaseAxis = function () { return this._axis }, t.prototype.getAxes = function () { return [this._axis] }, t.prototype.getTooltipAxes = function () { return { baseAxes: [this.getAxis()], otherAxes: [] } }, t.prototype.containPoint = function (t) { var e = this.getRect(), n = this.getAxis(); return "horizontal" === n.orient ? n.contain(n.toLocalCoord(t[0])) && t[1] >= e.y && t[1] <= e.y + e.height : n.contain(n.toLocalCoord(t[1])) && t[0] >= e.y && t[0] <= e.y + e.height }, t.prototype.pointToData = function (t) { var e = this.getAxis(); return [e.coordToData(e.toLocalCoord(t["horizontal" === e.orient ? 0 : 1]))] }, t.prototype.dataToPoint = function (t) { var e = this.getAxis(), n = this.getRect(), i = [], r = "horizontal" === e.orient ? 0 : 1; return t instanceof Array && (t = t[0]), i[r] = e.toGlobalCoord(e.dataToCoord(+t)), i[1 - r] = 0 === r ? n.y + n.height / 2 : n.x + n.width / 2, i }, t.prototype.convertToPixel = function (t, e, n) { return vE(e) === this ? this.dataToPoint(n) : null }, t.prototype.convertFromPixel = function (t, e, n) { return vE(e) === this ? this.pointToData(n) : null }, t }(); function vE(t) { var e = t.seriesModel, n = t.singleAxisModel; return n && n.coordinateSystem || e && e.coordinateSystem } var mE = { create: function (t, e) { var n = []; return t.eachComponent("singleAxis", (function (i, r) { var o = new yE(i, t, e); o.name = "single_" + r, o.resize(i, e), i.coordinateSystem = o, n.push(o) })), t.eachSeries((function (t) { if ("singleAxis" === t.get("coordinateSystem")) { var e = t.getReferringComponents("singleAxis", zo).models[0]; t.coordinateSystem = e && e.coordinateSystem } })), n }, dimensions: gE }, xE = ["x", "y"], _E = ["width", "height"], bE = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.makeElOption = function (t, e, n, i, r) { var o = n.axis, a = o.coordinateSystem, s = ME(a, 1 - SE(o)), l = a.dataToPoint(e)[0], u = i.get("type"); if (u && "none" !== u) { var h = nN(i), c = wE[u](o, l, s); c.style = h, t.graphicKey = c.type, t.pointer = c } aN(e, t, lE(n), n, i, r) }, e.prototype.getHandleTransform = function (t, e, n) { var i = lE(e, { labelInside: !1 }); i.labelMargin = n.get(["handle", "margin"]); var r = oN(e.axis, t, i); return { x: r[0], y: r[1], rotation: i.rotation + (i.labelDirection < 0 ? Math.PI : 0) } }, e.prototype.updateHandleTransform = function (t, e, n, i) { var r = n.axis, o = r.coordinateSystem, a = SE(r), s = ME(o, a), l = [t.x, t.y]; l[a] += e[a], l[a] = Math.min(s[1], l[a]), l[a] = Math.max(s[0], l[a]); var u = ME(o, 1 - a), h = (u[1] + u[0]) / 2, c = [h, h]; return c[a] = l[a], { x: l[0], y: l[1], rotation: t.rotation, cursorPoint: c, tooltipOption: { verticalAlign: "middle" } } }, e }(KR), wE = { line: function (t, e, n) { return { type: "Line", subPixelOptimize: !0, shape: sN([e, n[0]], [e, n[1]], SE(t)) } }, shadow: function (t, e, n) { var i = t.getBandWidth(), r = n[1] - n[0]; return { type: "Rect", shape: lN([e - i / 2, n[0]], [i, r], SE(t)) } } }; function SE(t) { return t.isHorizontal() ? 0 : 1 } function ME(t, e) { var n = t.getRect(); return [n[xE[e]], n[xE[e]] + n[_E[e]]] } var IE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "single", e }(Tg); var TE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (e, n, i) { var r = Lp(e); t.prototype.init.apply(this, arguments), CE(e, r) }, e.prototype.mergeOption = function (e) { t.prototype.mergeOption.apply(this, arguments), CE(this.option, e) }, e.prototype.getCellSize = function () { return this.option.cellSize }, e.type = "calendar", e.defaultOption = { z: 2, left: 80, top: 60, cellSize: 20, orient: "horizontal", splitLine: { show: !0, lineStyle: { color: "#000", width: 1, type: "solid" } }, itemStyle: { color: "#fff", borderWidth: 1, borderColor: "#ccc" }, dayLabel: { show: !0, firstDay: 0, position: "start", margin: "50%", color: "#000" }, monthLabel: { show: !0, position: "start", margin: 5, align: "center", formatter: null, color: "#000" }, yearLabel: { show: !0, position: null, margin: 30, formatter: null, color: "#ccc", fontFamily: "sans-serif", fontWeight: "bolder", fontSize: 20 } }, e }(Rp); function CE(t, e) { var n, i = t.cellSize; 1 === (n = Y(i) ? i : t.cellSize = [i, i]).length && (n[1] = n[0]); var r = z([0, 1], (function (t) { return function (t, e) { return null != t[Mp[e][0]] || null != t[Mp[e][1]] && null != t[Mp[e][2]] }(e, t) && (n[t] = "auto"), null != n[t] && "auto" !== n[t] })); kp(t, e, { type: "box", ignoreSize: r }) } var DE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { var i = this.group; i.removeAll(); var r = t.coordinateSystem, o = r.getRangeInfo(), a = r.getOrient(), s = e.getLocaleModel(); this._renderDayRect(t, o, i), this._renderLines(t, o, a, i), this._renderYearText(t, o, a, i), this._renderMonthText(t, s, a, i), this._renderWeekText(t, s, o, a, i) }, e.prototype._renderDayRect = function (t, e, n) { for (var i = t.coordinateSystem, r = t.getModel("itemStyle").getItemStyle(), o = i.getCellWidth(), a = i.getCellHeight(), s = e.start.time; s <= e.end.time; s = i.getNextNDay(s, 1).time) { var l = i.dataToRect([s], !1).tl, u = new zs({ shape: { x: l[0], y: l[1], width: o, height: a }, cursor: "default", style: r }); n.add(u) } }, e.prototype._renderLines = function (t, e, n, i) { var r = this, o = t.coordinateSystem, a = t.getModel(["splitLine", "lineStyle"]).getLineStyle(), s = t.get(["splitLine", "show"]), l = a.lineWidth; this._tlpoints = [], this._blpoints = [], this._firstDayOfMonth = [], this._firstDayPoints = []; for (var u = e.start, h = 0; u.time <= e.end.time; h++) { p(u.formatedDate), 0 === h && (u = o.getDateInfo(e.start.y + "-" + e.start.m)); var c = u.date; c.setMonth(c.getMonth() + 1), u = o.getDateInfo(c) } function p(e) { r._firstDayOfMonth.push(o.getDateInfo(e)), r._firstDayPoints.push(o.dataToRect([e], !1).tl); var l = r._getLinePointsOfOneWeek(t, e, n); r._tlpoints.push(l[0]), r._blpoints.push(l[l.length - 1]), s && r._drawSplitline(l, a, i) } p(o.getNextNDay(e.end.time, 1).formatedDate), s && this._drawSplitline(r._getEdgesPoints(r._tlpoints, l, n), a, i), s && this._drawSplitline(r._getEdgesPoints(r._blpoints, l, n), a, i) }, e.prototype._getEdgesPoints = function (t, e, n) { var i = [t[0].slice(), t[t.length - 1].slice()], r = "horizontal" === n ? 0 : 1; return i[0][r] = i[0][r] - e / 2, i[1][r] = i[1][r] + e / 2, i }, e.prototype._drawSplitline = function (t, e, n) { var i = new Yu({ z2: 20, shape: { points: t }, style: e }); n.add(i) }, e.prototype._getLinePointsOfOneWeek = function (t, e, n) { for (var i = t.coordinateSystem, r = i.getDateInfo(e), o = [], a = 0; a < 7; a++) { var s = i.getNextNDay(r.time, a), l = i.dataToRect([s.time], !1); o[2 * s.day] = l.tl, o[2 * s.day + 1] = l["horizontal" === n ? "bl" : "tr"] } return o }, e.prototype._formatterLabel = function (t, e) { return U(t) && t ? (n = t, E(e, (function (t, e) { n = n.replace("{" + e + "}", i ? re(t) : t) })), n) : X(t) ? t(e) : e.nameMap; var n, i }, e.prototype._yearTextPositionControl = function (t, e, n, i, r) { var o = e[0], a = e[1], s = ["center", "bottom"]; "bottom" === i ? (a += r, s = ["center", "top"]) : "left" === i ? o -= r : "right" === i ? (o += r, s = ["center", "top"]) : a -= r; var l = 0; return "left" !== i && "right" !== i || (l = Math.PI / 2), { rotation: l, x: o, y: a, style: { align: s[0], verticalAlign: s[1] } } }, e.prototype._renderYearText = function (t, e, n, i) { var r = t.getModel("yearLabel"); if (r.get("show")) { var o = r.get("margin"), a = r.get("position"); a || (a = "horizontal" !== n ? "top" : "left"); var s = [this._tlpoints[this._tlpoints.length - 1], this._blpoints[0]], l = (s[0][0] + s[1][0]) / 2, u = (s[0][1] + s[1][1]) / 2, h = "horizontal" === n ? 0 : 1, c = { top: [l, s[h][1]], bottom: [l, s[1 - h][1]], left: [s[1 - h][0], u], right: [s[h][0], u] }, p = e.start.y; +e.end.y > +e.start.y && (p = p + "-" + e.end.y); var d = r.get("formatter"), f = { start: e.start.y, end: e.end.y, nameMap: p }, g = this._formatterLabel(d, f), y = new Fs({ z2: 30, style: nc(r, { text: g }) }); y.attr(this._yearTextPositionControl(y, c[a], n, a, o)), i.add(y) } }, e.prototype._monthTextPositionControl = function (t, e, n, i, r) { var o = "left", a = "top", s = t[0], l = t[1]; return "horizontal" === n ? (l += r, e && (o = "center"), "start" === i && (a = "bottom")) : (s += r, e && (a = "middle"), "start" === i && (o = "right")), { x: s, y: l, align: o, verticalAlign: a } }, e.prototype._renderMonthText = function (t, e, n, i) { var r = t.getModel("monthLabel"); if (r.get("show")) { var o = r.get("nameMap"), a = r.get("margin"), s = r.get("position"), l = r.get("align"), u = [this._tlpoints, this._blpoints]; o && !U(o) || (o && (e = Nc(o) || e), o = e.get(["time", "monthAbbr"]) || []); var h = "start" === s ? 0 : 1, c = "horizontal" === n ? 0 : 1; a = "start" === s ? -a : a; for (var p = "center" === l, d = 0; d < u[h].length - 1; d++) { var f = u[h][d].slice(), g = this._firstDayOfMonth[d]; if (p) { var y = this._firstDayPoints[d]; f[c] = (y[c] + u[0][d + 1][c]) / 2 } var v = r.get("formatter"), m = o[+g.m - 1], x = { yyyy: g.y, yy: (g.y + "").slice(2), MM: g.m, M: +g.m, nameMap: m }, _ = this._formatterLabel(v, x), b = new Fs({ z2: 30, style: A(nc(r, { text: _ }), this._monthTextPositionControl(f, p, n, s, a)) }); i.add(b) } } }, e.prototype._weekTextPositionControl = function (t, e, n, i, r) { var o = "center", a = "middle", s = t[0], l = t[1], u = "start" === n; return "horizontal" === e ? (s = s + i + (u ? 1 : -1) * r[0] / 2, o = u ? "right" : "left") : (l = l + i + (u ? 1 : -1) * r[1] / 2, a = u ? "bottom" : "top"), { x: s, y: l, align: o, verticalAlign: a } }, e.prototype._renderWeekText = function (t, e, n, i, r) { var o = t.getModel("dayLabel"); if (o.get("show")) { var a = t.coordinateSystem, s = o.get("position"), l = o.get("nameMap"), u = o.get("margin"), h = a.getFirstDayOfWeek(); if (!l || U(l)) l && (e = Nc(l) || e), l = e.get(["time", "dayOfWeekShort"]) || z(e.get(["time", "dayOfWeekAbbr"]), (function (t) { return t[0] })); var c = a.getNextNDay(n.end.time, 7 - n.lweek).time, p = [a.getCellWidth(), a.getCellHeight()]; u = Ur(u, Math.min(p[1], p[0])), "start" === s && (c = a.getNextNDay(n.start.time, -(7 + n.fweek)).time, u = -u); for (var d = 0; d < 7; d++) { var f, g = a.getNextNDay(c, d), y = a.dataToRect([g.time], !1).center; f = Math.abs((d + h) % 7); var v = new Fs({ z2: 30, style: A(nc(o, { text: l[f] }), this._weekTextPositionControl(y, i, s, u, p)) }); r.add(v) } } }, e.type = "calendar", e }(Tg), AE = 864e5, kE = function () { function t(e, n, i) { this.type = "calendar", this.dimensions = t.dimensions, this.getDimensionsInfo = t.getDimensionsInfo, this._model = e } return t.getDimensionsInfo = function () { return [{ name: "time", type: "time" }, "value"] }, t.prototype.getRangeInfo = function () { return this._rangeInfo }, t.prototype.getModel = function () { return this._model }, t.prototype.getRect = function () { return this._rect }, t.prototype.getCellWidth = function () { return this._sw }, t.prototype.getCellHeight = function () { return this._sh }, t.prototype.getOrient = function () { return this._orient }, t.prototype.getFirstDayOfWeek = function () { return this._firstDayOfWeek }, t.prototype.getDateInfo = function (t) { var e = (t = ro(t)).getFullYear(), n = t.getMonth() + 1, i = n < 10 ? "0" + n : "" + n, r = t.getDate(), o = r < 10 ? "0" + r : "" + r, a = t.getDay(); return { y: e + "", m: i, d: o, day: a = Math.abs((a + 7 - this.getFirstDayOfWeek()) % 7), time: t.getTime(), formatedDate: e + "-" + i + "-" + o, date: t } }, t.prototype.getNextNDay = function (t, e) { return 0 === (e = e || 0) || (t = new Date(this.getDateInfo(t).time)).setDate(t.getDate() + e), this.getDateInfo(t) }, t.prototype.update = function (t, e) { this._firstDayOfWeek = +this._model.getModel("dayLabel").get("firstDay"), this._orient = this._model.get("orient"), this._lineWidth = this._model.getModel("itemStyle").getItemStyle().lineWidth || 0, this._rangeInfo = this._getRangeInfo(this._initRangeOption()); var n = this._rangeInfo.weeks || 1, i = ["width", "height"], r = this._model.getCellSize().slice(), o = this._model.getBoxLayoutParams(), a = "horizontal" === this._orient ? [n, 7] : [7, n]; E([0, 1], (function (t) { u(r, t) && (o[i[t]] = r[t] * a[t]) })); var s = { width: e.getWidth(), height: e.getHeight() }, l = this._rect = Cp(o, s); function u(t, e) { return null != t[e] && "auto" !== t[e] } E([0, 1], (function (t) { u(r, t) || (r[t] = l[i[t]] / a[t]) })), this._sw = r[0], this._sh = r[1] }, t.prototype.dataToPoint = function (t, e) { Y(t) && (t = t[0]), null == e && (e = !0); var n = this.getDateInfo(t), i = this._rangeInfo, r = n.formatedDate; if (e && !(n.time >= i.start.time && n.time < i.end.time + AE)) return [NaN, NaN]; var o = n.day, a = this._getRangeInfo([i.start.time, r]).nthWeek; return "vertical" === this._orient ? [this._rect.x + o * this._sw + this._sw / 2, this._rect.y + a * this._sh + this._sh / 2] : [this._rect.x + a * this._sw + this._sw / 2, this._rect.y + o * this._sh + this._sh / 2] }, t.prototype.pointToData = function (t) { var e = this.pointToDate(t); return e && e.time }, t.prototype.dataToRect = function (t, e) { var n = this.dataToPoint(t, e); return { contentShape: { x: n[0] - (this._sw - this._lineWidth) / 2, y: n[1] - (this._sh - this._lineWidth) / 2, width: this._sw - this._lineWidth, height: this._sh - this._lineWidth }, center: n, tl: [n[0] - this._sw / 2, n[1] - this._sh / 2], tr: [n[0] + this._sw / 2, n[1] - this._sh / 2], br: [n[0] + this._sw / 2, n[1] + this._sh / 2], bl: [n[0] - this._sw / 2, n[1] + this._sh / 2] } }, t.prototype.pointToDate = function (t) { var e = Math.floor((t[0] - this._rect.x) / this._sw) + 1, n = Math.floor((t[1] - this._rect.y) / this._sh) + 1, i = this._rangeInfo.range; return "vertical" === this._orient ? this._getDateByWeeksAndDay(n, e - 1, i) : this._getDateByWeeksAndDay(e, n - 1, i) }, t.prototype.convertToPixel = function (t, e, n) { var i = LE(e); return i === this ? i.dataToPoint(n) : null }, t.prototype.convertFromPixel = function (t, e, n) { var i = LE(e); return i === this ? i.pointToData(n) : null }, t.prototype.containPoint = function (t) { return console.warn("Not implemented."), !1 }, t.prototype._initRangeOption = function () { var t, e = this._model.get("range"); if (Y(e) && 1 === e.length && (e = e[0]), Y(e)) t = e; else { var n = e.toString(); if (/^\d{4}$/.test(n) && (t = [n + "-01-01", n + "-12-31"]), /^\d{4}[\/|-]\d{1,2}$/.test(n)) { var i = this.getDateInfo(n), r = i.date; r.setMonth(r.getMonth() + 1); var o = this.getNextNDay(r, -1); t = [i.formatedDate, o.formatedDate] } /^\d{4}[\/|-]\d{1,2}[\/|-]\d{1,2}$/.test(n) && (t = [n, n]) } if (!t) return e; var a = this._getRangeInfo(t); return a.start.time > a.end.time && t.reverse(), t }, t.prototype._getRangeInfo = function (t) { var e, n = [this.getDateInfo(t[0]), this.getDateInfo(t[1])]; n[0].time > n[1].time && (e = !0, n.reverse()); var i = Math.floor(n[1].time / AE) - Math.floor(n[0].time / AE) + 1, r = new Date(n[0].time), o = r.getDate(), a = n[1].date.getDate(); r.setDate(o + i - 1); var s = r.getDate(); if (s !== a) for (var l = r.getTime() - n[1].time > 0 ? 1 : -1; (s = r.getDate()) !== a && (r.getTime() - n[1].time) * l > 0;)i -= l, r.setDate(s - l); var u = Math.floor((i + n[0].day + 6) / 7), h = e ? 1 - u : u - 1; return e && n.reverse(), { range: [n[0].formatedDate, n[1].formatedDate], start: n[0], end: n[1], allDay: i, weeks: u, nthWeek: h, fweek: n[0].day, lweek: n[1].day } }, t.prototype._getDateByWeeksAndDay = function (t, e, n) { var i = this._getRangeInfo(n); if (t > i.weeks || 0 === t && e < i.fweek || t === i.weeks && e > i.lweek) return null; var r = 7 * (t - 1) - i.fweek + e, o = new Date(i.start.time); return o.setDate(+i.start.d + r), this.getDateInfo(o) }, t.create = function (e, n) { var i = []; return e.eachComponent("calendar", (function (r) { var o = new t(r, e, n); i.push(o), r.coordinateSystem = o })), e.eachSeries((function (t) { "calendar" === t.get("coordinateSystem") && (t.coordinateSystem = i[t.get("calendarIndex") || 0]) })), i }, t.dimensions = ["time", "value"], t }(); function LE(t) { var e = t.calendarModel, n = t.seriesModel; return e ? e.coordinateSystem : n ? n.coordinateSystem : null } function PE(t, e) { var n; return E(e, (function (e) { null != t[e] && "auto" !== t[e] && (n = !0) })), n } var OE = ["transition", "enterFrom", "leaveTo"], RE = OE.concat(["enterAnimation", "updateAnimation", "leaveAnimation"]); function NE(t, e, n) { if (n && (!t[n] && e[n] && (t[n] = {}), t = t[n], e = e[n]), t && e) for (var i = n ? OE : RE, r = 0; r < i.length; r++) { var o = i[r]; null == t[o] && null != e[o] && (t[o] = e[o]) } } var EE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.preventAutoZ = !0, n } return n(e, t), e.prototype.mergeOption = function (e, n) { var i = this.option.elements; this.option.elements = null, t.prototype.mergeOption.call(this, e, n), this.option.elements = i }, e.prototype.optionUpdated = function (t, e) { var n = this.option, i = (e ? n : t).elements, r = n.elements = e ? [] : n.elements, o = []; this._flatten(i, o, null); var a = To(r, o, "normalMerge"), s = this._elOptionsToUpdate = []; E(a, (function (t, e) { var n = t.newOption; n && (s.push(n), function (t, e) { var n = t.existing; if (e.id = t.keyInfo.id, !e.type && n && (e.type = n.type), null == e.parentId) { var i = e.parentOption; i ? e.parentId = i.id : n && (e.parentId = n.parentId) } e.parentOption = null }(t, n), function (t, e, n) { var i = A({}, n), r = t[e], o = n.$action || "merge"; "merge" === o ? r ? (C(r, i, !0), kp(r, i, { ignoreSize: !0 }), Pp(n, r), NE(n, r), NE(n, r, "shape"), NE(n, r, "style"), NE(n, r, "extra"), n.clipPath = r.clipPath) : t[e] = i : "replace" === o ? t[e] = i : "remove" === o && r && (t[e] = null) }(r, e, n), function (t, e) { if (t && (t.hv = e.hv = [PE(e, ["left", "right"]), PE(e, ["top", "bottom"])], "group" === t.type)) { var n = t, i = e; null == n.width && (n.width = i.width = 0), null == n.height && (n.height = i.height = 0) } }(r[e], n)) }), this), n.elements = B(r, (function (t) { return t && delete t.$action, null != t })) }, e.prototype._flatten = function (t, e, n) { E(t, (function (t) { if (t) { n && (t.parentOption = n), e.push(t); var i = t.children; i && i.length && this._flatten(i, e, t), delete t.children } }), this) }, e.prototype.useElOptionsToUpdate = function () { var t = this._elOptionsToUpdate; return this._elOptionsToUpdate = null, t }, e.type = "graphic", e.defaultOption = { elements: [] }, e }(Rp), zE = { path: null, compoundPath: null, group: zr, image: ks, text: Fs }, VE = Oo(), BE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function () { this._elMap = yt() }, e.prototype.render = function (t, e, n) { t !== this._lastGraphicModel && this._clear(), this._lastGraphicModel = t, this._updateElements(t), this._relocate(t, n) }, e.prototype._updateElements = function (t) { var e = t.useElOptionsToUpdate(); if (e) { var n = this._elMap, i = this.group, r = t.get("z"), o = t.get("zlevel"); E(e, (function (e) { var a = Ao(e.id, null), s = null != a ? n.get(a) : null, l = Ao(e.parentId, null), u = null != l ? n.get(l) : i, h = e.type, c = e.style; "text" === h && c && e.hv && e.hv[1] && (c.textVerticalAlign = c.textBaseline = c.verticalAlign = c.align = null); var p = e.textContent, d = e.textConfig; if (c && ZO(c, h, !!d, !!p)) { var f = jO(c, h, !0); !d && f.textConfig && (d = e.textConfig = f.textConfig), !p && f.textContent && (p = f.textContent) } var g = function (t) { return t = A({}, t), E(["id", "parentId", "$action", "hv", "bounding", "textContent", "clipPath"].concat(Sp), (function (e) { delete t[e] })), t }(e); var y = e.$action || "merge", v = "merge" === y, m = "replace" === y; if (v) { var x = s; (T = !s) ? x = GE(a, u, e.type, n) : (x && (VE(x).isNew = !1), gR(x)), x && (iR(x, g, t, { isInit: T }), HE(x, e, r, o)) } else if (m) { WE(s, e, n, t); var _ = GE(a, u, e.type, n); _ && (iR(_, g, t, { isInit: !0 }), HE(_, e, r, o)) } else "remove" === y && (rR(s, e), WE(s, e, n, t)); var b = n.get(a); if (b && p) if (v) { var w = b.getTextContent(); w ? w.attr(p) : b.setTextContent(new Fs(p)) } else m && b.setTextContent(new Fs(p)); if (b) { var S = e.clipPath; if (S) { var M = S.type, I = void 0, T = !1; if (v) { var C = b.getClipPath(); I = (T = !C || VE(C).type !== M) ? FE(M) : C } else m && (T = !0, I = FE(M)); b.setClipPath(I), iR(I, S, t, { isInit: T }), yR(I, S.keyframeAnimation, t) } var D = VE(b); b.setTextConfig(d), D.option = e, function (t, e, n) { var i = Qs(t).eventData; t.silent || t.ignore || i || (i = Qs(t).eventData = { componentType: "graphic", componentIndex: e.componentIndex, name: t.name }); i && (i.info = n.info) }(b, t, e), Zh({ el: b, componentModel: t, itemName: b.name, itemTooltipOption: e.tooltip }), yR(b, e.keyframeAnimation, t) } })) } }, e.prototype._relocate = function (t, e) { for (var n = t.option.elements, i = this.group, r = this._elMap, o = e.getWidth(), a = e.getHeight(), s = ["x", "y"], l = 0; l < n.length; l++) { if ((f = null != (d = Ao((p = n[l]).id, null)) ? r.get(d) : null) && f.isGroup) { var u = (g = f.parent) === i, h = VE(f), c = VE(g); h.width = Ur(h.option.width, u ? o : c.width) || 0, h.height = Ur(h.option.height, u ? a : c.height) || 0 } } for (l = n.length - 1; l >= 0; l--) { var p, d, f; if (f = null != (d = Ao((p = n[l]).id, null)) ? r.get(d) : null) { var g = f.parent, y = (c = VE(g), {}), v = Dp(f, p, g === i ? { width: o, height: a } : { width: c.width, height: c.height }, null, { hv: p.hv, boundingMode: p.bounding }, y); if (!VE(f).isNew && v) { for (var m = p.transition, x = {}, _ = 0; _ < s.length; _++) { var b = s[_], w = y[b]; m && (aR(m) || P(m, b) >= 0) ? x[b] = w : f[b] = w } fh(f, x, t, 0) } else f.attr(y) } } }, e.prototype._clear = function () { var t = this, e = this._elMap; e.each((function (n) { WE(n, VE(n).option, e, t._lastGraphicModel) })), this._elMap = yt() }, e.prototype.dispose = function () { this._clear() }, e.type = "graphic", e }(Tg); function FE(t) { var e = _t(zE, t) ? zE[t] : Dh(t); var n = new e({}); return VE(n).type = t, n } function GE(t, e, n, i) { var r = FE(n); return e.add(r), i.set(t, r), VE(r).id = t, VE(r).isNew = !0, r } function WE(t, e, n, i) { t && t.parent && ("group" === t.type && t.traverse((function (t) { WE(t, e, n, i) })), oR(t, e, i), n.removeKey(VE(t).id)) } function HE(t, e, n, i) { t.isGroup || E([["cursor", Sa.prototype.cursor], ["zlevel", i || 0], ["z", n || 0], ["z2", 0]], (function (n) { var i = n[0]; _t(e, i) ? t[i] = rt(e[i], n[1]) : null == t[i] && (t[i] = n[1]) })), E(G(e), (function (n) { if (0 === n.indexOf("on")) { var i = e[n]; t[n] = X(i) ? i : null } })), _t(e, "draggable") && (t.draggable = e.draggable), null != e.name && (t.name = e.name), null != e.id && (t.id = e.id) } var YE = ["x", "y", "radius", "angle", "single"], XE = ["cartesian2d", "polar", "singleAxis"]; function UE(t) { return t + "Axis" } function ZE(t, e) { var n, i = yt(), r = [], o = yt(); t.eachComponent({ mainType: "dataZoom", query: e }, (function (t) { o.get(t.uid) || s(t) })); do { n = !1, t.eachComponent("dataZoom", a) } while (n); function a(t) { !o.get(t.uid) && function (t) { var e = !1; return t.eachTargetAxis((function (t, n) { var r = i.get(t); r && r[n] && (e = !0) })), e }(t) && (s(t), n = !0) } function s(t) { o.set(t.uid, !0), r.push(t), t.eachTargetAxis((function (t, e) { (i.get(t) || i.set(t, []))[e] = !0 })) } return r } function jE(t) { var e = t.ecModel, n = { infoList: [], infoMap: yt() }; return t.eachTargetAxis((function (t, i) { var r = e.getComponent(UE(t), i); if (r) { var o = r.getCoordSysModel(); if (o) { var a = o.uid, s = n.infoMap.get(a); s || (s = { model: o, axisModels: [] }, n.infoList.push(s), n.infoMap.set(a, s)), s.axisModels.push(r) } } })), n } var qE = function () { function t() { this.indexList = [], this.indexMap = [] } return t.prototype.add = function (t) { this.indexMap[t] || (this.indexList.push(t), this.indexMap[t] = !0) }, t }(), KE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._autoThrottle = !0, n._noTarget = !0, n._rangePropMode = ["percent", "percent"], n } return n(e, t), e.prototype.init = function (t, e, n) { var i = $E(t); this.settledOption = i, this.mergeDefaultAndTheme(t, n), this._doInit(i) }, e.prototype.mergeOption = function (t) { var e = $E(t); C(this.option, t, !0), C(this.settledOption, e, !0), this._doInit(e) }, e.prototype._doInit = function (t) { var e = this.option; this._setDefaultThrottle(t), this._updateRangeUse(t); var n = this.settledOption; E([["start", "startValue"], ["end", "endValue"]], (function (t, i) { "value" === this._rangePropMode[i] && (e[t[0]] = n[t[0]] = null) }), this), this._resetTarget() }, e.prototype._resetTarget = function () { var t = this.get("orient", !0), e = this._targetAxisInfoMap = yt(); this._fillSpecifiedTargetAxis(e) ? this._orient = t || this._makeAutoOrientByTargetAxis() : (this._orient = t || "horizontal", this._fillAutoTargetAxisByOrient(e, this._orient)), this._noTarget = !0, e.each((function (t) { t.indexList.length && (this._noTarget = !1) }), this) }, e.prototype._fillSpecifiedTargetAxis = function (t) { var e = !1; return E(YE, (function (n) { var i = this.getReferringComponents(UE(n), Vo); if (i.specified) { e = !0; var r = new qE; E(i.models, (function (t) { r.add(t.componentIndex) })), t.set(n, r) } }), this), e }, e.prototype._fillAutoTargetAxisByOrient = function (t, e) { var n = this.ecModel, i = !0; if (i) { var r = "vertical" === e ? "y" : "x"; o(n.findComponents({ mainType: r + "Axis" }), r) } i && o(n.findComponents({ mainType: "singleAxis", filter: function (t) { return t.get("orient", !0) === e } }), "single"); function o(e, n) { var r = e[0]; if (r) { var o = new qE; if (o.add(r.componentIndex), t.set(n, o), i = !1, "x" === n || "y" === n) { var a = r.getReferringComponents("grid", zo).models[0]; a && E(e, (function (t) { r.componentIndex !== t.componentIndex && a === t.getReferringComponents("grid", zo).models[0] && o.add(t.componentIndex) })) } } } i && E(YE, (function (e) { if (i) { var r = n.findComponents({ mainType: UE(e), filter: function (t) { return "category" === t.get("type", !0) } }); if (r[0]) { var o = new qE; o.add(r[0].componentIndex), t.set(e, o), i = !1 } } }), this) }, e.prototype._makeAutoOrientByTargetAxis = function () { var t; return this.eachTargetAxis((function (e) { !t && (t = e) }), this), "y" === t ? "vertical" : "horizontal" }, e.prototype._setDefaultThrottle = function (t) { if (t.hasOwnProperty("throttle") && (this._autoThrottle = !1), this._autoThrottle) { var e = this.ecModel.option; this.option.throttle = e.animation && e.animationDurationUpdate > 0 ? 100 : 20 } }, e.prototype._updateRangeUse = function (t) { var e = this._rangePropMode, n = this.get("rangeMode"); E([["start", "startValue"], ["end", "endValue"]], (function (i, r) { var o = null != t[i[0]], a = null != t[i[1]]; o && !a ? e[r] = "percent" : !o && a ? e[r] = "value" : n ? e[r] = n[r] : o && (e[r] = "percent") })) }, e.prototype.noTarget = function () { return this._noTarget }, e.prototype.getFirstTargetAxisModel = function () { var t; return this.eachTargetAxis((function (e, n) { null == t && (t = this.ecModel.getComponent(UE(e), n)) }), this), t }, e.prototype.eachTargetAxis = function (t, e) { this._targetAxisInfoMap.each((function (n, i) { E(n.indexList, (function (n) { t.call(e, i, n) })) })) }, e.prototype.getAxisProxy = function (t, e) { var n = this.getAxisModel(t, e); if (n) return n.__dzAxisProxy }, e.prototype.getAxisModel = function (t, e) { var n = this._targetAxisInfoMap.get(t); if (n && n.indexMap[e]) return this.ecModel.getComponent(UE(t), e) }, e.prototype.setRawRange = function (t) { var e = this.option, n = this.settledOption; E([["start", "startValue"], ["end", "endValue"]], (function (i) { null == t[i[0]] && null == t[i[1]] || (e[i[0]] = n[i[0]] = t[i[0]], e[i[1]] = n[i[1]] = t[i[1]]) }), this), this._updateRangeUse(t) }, e.prototype.setCalculatedRange = function (t) { var e = this.option; E(["start", "startValue", "end", "endValue"], (function (n) { e[n] = t[n] })) }, e.prototype.getPercentRange = function () { var t = this.findRepresentativeAxisProxy(); if (t) return t.getDataPercentWindow() }, e.prototype.getValueRange = function (t, e) { if (null != t || null != e) return this.getAxisProxy(t, e).getDataValueWindow(); var n = this.findRepresentativeAxisProxy(); return n ? n.getDataValueWindow() : void 0 }, e.prototype.findRepresentativeAxisProxy = function (t) { if (t) return t.__dzAxisProxy; for (var e, n = this._targetAxisInfoMap.keys(), i = 0; i < n.length; i++)for (var r = n[i], o = this._targetAxisInfoMap.get(r), a = 0; a < o.indexList.length; a++) { var s = this.getAxisProxy(r, o.indexList[a]); if (s.hostedBy(this)) return s; e || (e = s) } return e }, e.prototype.getRangePropMode = function () { return this._rangePropMode.slice() }, e.prototype.getOrient = function () { return this._orient }, e.type = "dataZoom", e.dependencies = ["xAxis", "yAxis", "radiusAxis", "angleAxis", "singleAxis", "series", "toolbox"], e.defaultOption = { z: 4, filterMode: "filter", start: 0, end: 100 }, e }(Rp); function $E(t) { var e = {}; return E(["start", "end", "startValue", "endValue", "throttle"], (function (n) { t.hasOwnProperty(n) && (e[n] = t[n]) })), e } var JE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "dataZoom.select", e }(KE), QE = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n, i) { this.dataZoomModel = t, this.ecModel = e, this.api = n }, e.type = "dataZoom", e }(Tg), tz = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "dataZoom.select", e }(QE), ez = E, nz = jr, iz = function () { function t(t, e, n, i) { this._dimName = t, this._axisIndex = e, this.ecModel = i, this._dataZoomModel = n } return t.prototype.hostedBy = function (t) { return this._dataZoomModel === t }, t.prototype.getDataValueWindow = function () { return this._valueWindow.slice() }, t.prototype.getDataPercentWindow = function () { return this._percentWindow.slice() }, t.prototype.getTargetSeriesModels = function () { var t = []; return this.ecModel.eachSeries((function (e) { if (function (t) { var e = t.get("coordinateSystem"); return P(XE, e) >= 0 }(e)) { var n = UE(this._dimName), i = e.getReferringComponents(n, zo).models[0]; i && this._axisIndex === i.componentIndex && t.push(e) } }), this), t }, t.prototype.getAxisModel = function () { return this.ecModel.getComponent(this._dimName + "Axis", this._axisIndex) }, t.prototype.getMinMaxSpan = function () { return T(this._minMaxSpan) }, t.prototype.calculateDataWindow = function (t) { var e, n = this._dataExtent, i = this.getAxisModel().axis.scale, r = this._dataZoomModel.getRangePropMode(), o = [0, 100], a = [], s = []; ez(["start", "end"], (function (l, u) { var h = t[l], c = t[l + "Value"]; "percent" === r[u] ? (null == h && (h = o[u]), c = i.parse(Xr(h, o, n))) : (e = !0, h = Xr(c = null == c ? n[u] : i.parse(c), n, o)), s[u] = null == c || isNaN(c) ? n[u] : c, a[u] = null == h || isNaN(h) ? o[u] : h })), nz(s), nz(a); var l = this._minMaxSpan; function u(t, e, n, r, o) { var a = o ? "Span" : "ValueSpan"; Ck(0, t, n, "all", l["min" + a], l["max" + a]); for (var s = 0; s < 2; s++)e[s] = Xr(t[s], n, r, !0), o && (e[s] = i.parse(e[s])) } return e ? u(s, a, n, o, !1) : u(a, s, o, n, !0), { valueWindow: s, percentWindow: a } }, t.prototype.reset = function (t) { if (t === this._dataZoomModel) { var e = this.getTargetSeriesModels(); this._dataExtent = function (t, e, n) { var i = [1 / 0, -1 / 0]; ez(n, (function (t) { !function (t, e, n) { e && E(M_(e, n), (function (n) { var i = e.getApproximateExtent(n); i[0] < t[0] && (t[0] = i[0]), i[1] > t[1] && (t[1] = i[1]) })) }(i, t.getData(), e) })); var r = t.getAxisModel(), o = f_(r.axis.scale, r, i).calculate(); return [o.min, o.max] }(this, this._dimName, e), this._updateMinMaxSpan(); var n = this.calculateDataWindow(t.settledOption); this._valueWindow = n.valueWindow, this._percentWindow = n.percentWindow, this._setAxisModel() } }, t.prototype.filterData = function (t, e) { if (t === this._dataZoomModel) { var n = this._dimName, i = this.getTargetSeriesModels(), r = t.get("filterMode"), o = this._valueWindow; "none" !== r && ez(i, (function (t) { var e = t.getData(), i = e.mapDimensionsAll(n); if (i.length) { if ("weakFilter" === r) { var a = e.getStore(), s = z(i, (function (t) { return e.getDimensionIndex(t) }), e); e.filterSelf((function (t) { for (var e, n, r, l = 0; l < i.length; l++) { var u = a.get(s[l], t), h = !isNaN(u), c = u < o[0], p = u > o[1]; if (h && !c && !p) return !0; h && (r = !0), c && (e = !0), p && (n = !0) } return r && e && n })) } else ez(i, (function (n) { if ("empty" === r) t.setData(e = e.map(n, (function (t) { return function (t) { return t >= o[0] && t <= o[1] }(t) ? t : NaN }))); else { var i = {}; i[n] = o, e.selectRange(i) } })); ez(i, (function (t) { e.setApproximateExtent(o, t) })) } })) } }, t.prototype._updateMinMaxSpan = function () { var t = this._minMaxSpan = {}, e = this._dataZoomModel, n = this._dataExtent; ez(["min", "max"], (function (i) { var r = e.get(i + "Span"), o = e.get(i + "ValueSpan"); null != o && (o = this.getAxisModel().axis.scale.parse(o)), null != o ? r = Xr(n[0] + o, n, [0, 100], !0) : null != r && (o = Xr(r, [0, 100], n, !0) - n[0]), t[i + "Span"] = r, t[i + "ValueSpan"] = o }), this) }, t.prototype._setAxisModel = function () { var t = this.getAxisModel(), e = this._percentWindow, n = this._valueWindow; if (e) { var i = $r(n, [0, 500]); i = Math.min(i, 20); var r = t.axis.scale.rawExtentInfo; 0 !== e[0] && r.setDeterminedMinMax("min", +n[0].toFixed(i)), 100 !== e[1] && r.setDeterminedMinMax("max", +n[1].toFixed(i)), r.freeze() } }, t }(); var rz = { getTargetSeries: function (t) { function e(e) { t.eachComponent("dataZoom", (function (n) { n.eachTargetAxis((function (i, r) { var o = t.getComponent(UE(i), r); e(i, r, o, n) })) })) } e((function (t, e, n, i) { n.__dzAxisProxy = null })); var n = []; e((function (e, i, r, o) { r.__dzAxisProxy || (r.__dzAxisProxy = new iz(e, i, o, t), n.push(r.__dzAxisProxy)) })); var i = yt(); return E(n, (function (t) { E(t.getTargetSeriesModels(), (function (t) { i.set(t.uid, t) })) })), i }, overallReset: function (t, e) { t.eachComponent("dataZoom", (function (t) { t.eachTargetAxis((function (e, n) { t.getAxisProxy(e, n).reset(t) })), t.eachTargetAxis((function (n, i) { t.getAxisProxy(n, i).filterData(t, e) })) })), t.eachComponent("dataZoom", (function (t) { var e = t.findRepresentativeAxisProxy(); if (e) { var n = e.getDataPercentWindow(), i = e.getDataValueWindow(); t.setCalculatedRange({ start: n[0], end: n[1], startValue: i[0], endValue: i[1] }) } })) } }; var oz = !1; function az(t) { oz || (oz = !0, t.registerProcessor(t.PRIORITY.PROCESSOR.FILTER, rz), function (t) { t.registerAction("dataZoom", (function (t, e) { E(ZE(e, t), (function (e) { e.setRawRange({ start: t.start, end: t.end, startValue: t.startValue, endValue: t.endValue }) })) })) }(t), t.registerSubTypeDefaulter("dataZoom", (function () { return "slider" }))) } function sz(t) { t.registerComponentModel(JE), t.registerComponentView(tz), az(t) } var lz = function () { }, uz = {}; function hz(t, e) { uz[t] = e } function cz(t) { return uz[t] } var pz = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.optionUpdated = function () { t.prototype.optionUpdated.apply(this, arguments); var e = this.ecModel; E(this.option.feature, (function (t, n) { var i = cz(n); i && (i.getDefaultOption && (i.defaultOption = i.getDefaultOption(e)), C(t, i.defaultOption)) })) }, e.type = "toolbox", e.layoutMode = { type: "box", ignoreSize: !0 }, e.defaultOption = { show: !0, z: 6, orient: "horizontal", left: "right", top: "top", backgroundColor: "transparent", borderColor: "#ccc", borderRadius: 0, borderWidth: 0, padding: 5, itemSize: 15, itemGap: 8, showTitle: !0, iconStyle: { borderColor: "#666", color: "none" }, emphasis: { iconStyle: { borderColor: "#3E98C5" } }, tooltip: { show: !1, position: "bottom" } }, e }(Rp); function dz(t, e) { var n = fp(e.get("padding")), i = e.getItemStyle(["color", "opacity"]); return i.fill = e.get("backgroundColor"), t = new zs({ shape: { x: t.x - n[3], y: t.y - n[0], width: t.width + n[1] + n[3], height: t.height + n[0] + n[2], r: e.get("borderRadius") }, style: i, silent: !0, z2: -1 }) } var fz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.render = function (t, e, n, i) { var r = this.group; if (r.removeAll(), t.get("show")) { var o = +t.get("itemSize"), a = "vertical" === t.get("orient"), s = t.get("feature") || {}, l = this._features || (this._features = {}), u = []; E(s, (function (t, e) { u.push(e) })), new Vm(this._featureNames || [], u).add(h).update(h).remove(H(h, null)).execute(), this._featureNames = u, function (t, e, n) { var i = e.getBoxLayoutParams(), r = e.get("padding"), o = { width: n.getWidth(), height: n.getHeight() }, a = Cp(i, o, r); Tp(e.get("orient"), t, e.get("itemGap"), a.width, a.height), Dp(t, i, o, r) }(r, t, n), r.add(dz(r.getBoundingRect(), t)), a || r.eachChild((function (t) { var e = t.__title, i = t.ensureState("emphasis"), a = i.textConfig || (i.textConfig = {}), s = t.getTextContent(), l = s && s.ensureState("emphasis"); if (l && !X(l) && e) { var u = l.style || (l.style = {}), h = br(e, Fs.makeFont(u)), c = t.x + r.x, p = !1; t.y + r.y + o + h.height > n.getHeight() && (a.position = "top", p = !0); var d = p ? -5 - h.height : o + 10; c + h.width / 2 > n.getWidth() ? (a.position = ["100%", d], u.align = "right") : c - h.width / 2 < 0 && (a.position = [0, d], u.align = "left") } })) } function h(h, c) { var p, d = u[h], f = u[c], g = s[d], y = new Mc(g, t, t.ecModel); if (i && null != i.newTitle && i.featureName === d && (g.title = i.newTitle), d && !f) { if (function (t) { return 0 === t.indexOf("my") }(d)) p = { onclick: y.option.onclick, featureName: d }; else { var v = cz(d); if (!v) return; p = new v } l[d] = p } else if (!(p = l[f])) return; p.uid = Tc("toolbox-feature"), p.model = y, p.ecModel = e, p.api = n; var m = p instanceof lz; d || !f ? !y.get("show") || m && p.unusable ? m && p.remove && p.remove(e, n) : (!function (i, s, l) { var u, h, c = i.getModel("iconStyle"), p = i.getModel(["emphasis", "iconStyle"]), d = s instanceof lz && s.getIcons ? s.getIcons() : i.get("icon"), f = i.get("title") || {}; U(d) ? (u = {})[l] = d : u = d; U(f) ? (h = {})[l] = f : h = f; var g = i.iconPaths = {}; E(u, (function (l, u) { var d = Hh(l, {}, { x: -o / 2, y: -o / 2, width: o, height: o }); d.setStyle(c.getItemStyle()), d.ensureState("emphasis").style = p.getItemStyle(); var f = new Fs({ style: { text: h[u], align: p.get("textAlign"), borderRadius: p.get("textBorderRadius"), padding: p.get("textPadding"), fill: null }, ignore: !0 }); d.setTextContent(f), Zh({ el: d, componentModel: t, itemName: u, formatterParamsExtra: { title: h[u] } }), d.__title = h[u], d.on("mouseover", (function () { var e = p.getItemStyle(), i = a ? null == t.get("right") && "right" !== t.get("left") ? "right" : "left" : null == t.get("bottom") && "bottom" !== t.get("top") ? "bottom" : "top"; f.setStyle({ fill: p.get("textFill") || e.fill || e.stroke || "#000", backgroundColor: p.get("textBackgroundColor") }), d.setTextConfig({ position: p.get("textPosition") || i }), f.ignore = !t.get("showTitle"), n.enterEmphasis(this) })).on("mouseout", (function () { "emphasis" !== i.get(["iconStatus", u]) && n.leaveEmphasis(this), f.hide() })), ("emphasis" === i.get(["iconStatus", u]) ? kl : Ll)(d), r.add(d), d.on("click", W(s.onclick, s, e, n, u)), g[u] = d })) }(y, p, d), y.setIconStatus = function (t, e) { var n = this.option, i = this.iconPaths; n.iconStatus = n.iconStatus || {}, n.iconStatus[t] = e, i[t] && ("emphasis" === e ? kl : Ll)(i[t]) }, p instanceof lz && p.render && p.render(y, e, n, i)) : m && p.dispose && p.dispose(e, n) } }, e.prototype.updateView = function (t, e, n, i) { E(this._features, (function (t) { t instanceof lz && t.updateView && t.updateView(t.model, e, n, i) })) }, e.prototype.remove = function (t, e) { E(this._features, (function (n) { n instanceof lz && n.remove && n.remove(t, e) })), this.group.removeAll() }, e.prototype.dispose = function (t, e) { E(this._features, (function (n) { n instanceof lz && n.dispose && n.dispose(t, e) })) }, e.type = "toolbox", e }(Tg); var gz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.onclick = function (t, e) { var n = this.model, i = n.get("name") || t.get("title.0.text") || "echarts", o = "svg" === e.getZr().painter.getType(), a = o ? "svg" : n.get("type", !0) || "png", s = e.getConnectedDataURL({ type: a, backgroundColor: n.get("backgroundColor", !0) || t.get("backgroundColor") || "#fff", connectedBackgroundColor: n.get("connectedBackgroundColor"), excludeComponents: n.get("excludeComponents"), pixelRatio: n.get("pixelRatio") }), l = r.browser; if (X(MouseEvent) && (l.newEdge || !l.ie && !l.edge)) { var u = document.createElement("a"); u.download = i + "." + a, u.target = "_blank", u.href = s; var h = new MouseEvent("click", { view: document.defaultView, bubbles: !0, cancelable: !1 }); u.dispatchEvent(h) } else if (window.navigator.msSaveOrOpenBlob || o) { var c = s.split(","), p = c[0].indexOf("base64") > -1, d = o ? decodeURIComponent(c[1]) : c[1]; p && (d = window.atob(d)); var f = i + "." + a; if (window.navigator.msSaveOrOpenBlob) { for (var g = d.length, y = new Uint8Array(g); g--;)y[g] = d.charCodeAt(g); var v = new Blob([y]); window.navigator.msSaveOrOpenBlob(v, f) } else { var m = document.createElement("iframe"); document.body.appendChild(m); var x = m.contentWindow, _ = x.document; _.open("image/svg+xml", "replace"), _.write(d), _.close(), x.focus(), _.execCommand("SaveAs", !0, f), document.body.removeChild(m) } } else { var b = n.get("lang"), w = '<body style="margin:0;"><img src="' + s + '" style="max-width:100%;" title="' + (b && b[0] || "") + '" /></body>', S = window.open(); S.document.write(w), S.document.title = i } }, e.getDefaultOption = function (t) { return { show: !0, icon: "M4.7,22.9L29.3,45.5L54.7,23.4M4.6,43.6L4.6,58L53.8,58L53.8,43.6M29.2,45.1L29.2,0", title: t.getLocaleModel().get(["toolbox", "saveAsImage", "title"]), type: "png", connectedBackgroundColor: "#fff", name: "", excludeComponents: ["toolbox"], lang: t.getLocaleModel().get(["toolbox", "saveAsImage", "lang"]) } }, e }(lz), yz = "__ec_magicType_stack__", vz = [["line", "bar"], ["stack"]], mz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.getIcons = function () { var t = this.model, e = t.get("icon"), n = {}; return E(t.get("type"), (function (t) { e[t] && (n[t] = e[t]) })), n }, e.getDefaultOption = function (t) { return { show: !0, type: [], icon: { line: "M4.1,28.9h7.1l9.3-22l7.4,38l9.7-19.7l3,12.8h14.9M4.1,58h51.4", bar: "M6.7,22.9h10V48h-10V22.9zM24.9,13h10v35h-10V13zM43.2,2h10v46h-10V2zM3.1,58h53.7", stack: "M8.2,38.4l-8.4,4.1l30.6,15.3L60,42.5l-8.1-4.1l-21.5,11L8.2,38.4z M51.9,30l-8.1,4.2l-13.4,6.9l-13.9-6.9L8.2,30l-8.4,4.2l8.4,4.2l22.2,11l21.5-11l8.1-4.2L51.9,30z M51.9,21.7l-8.1,4.2L35.7,30l-5.3,2.8L24.9,30l-8.4-4.1l-8.3-4.2l-8.4,4.2L8.2,30l8.3,4.2l13.9,6.9l13.4-6.9l8.1-4.2l8.1-4.1L51.9,21.7zM30.4,2.2L-0.2,17.5l8.4,4.1l8.3,4.2l8.4,4.2l5.5,2.7l5.3-2.7l8.1-4.2l8.1-4.2l8.1-4.1L30.4,2.2z" }, title: t.getLocaleModel().get(["toolbox", "magicType", "title"]), option: {}, seriesIndex: {} } }, e.prototype.onclick = function (t, e, n) { var i = this.model, r = i.get(["seriesIndex", n]); if (xz[n]) { var o, a = { series: [] }; E(vz, (function (t) { P(t, n) >= 0 && E(t, (function (t) { i.setIconStatus(t, "normal") })) })), i.setIconStatus(n, "emphasis"), t.eachComponent({ mainType: "series", query: null == r ? null : { seriesIndex: r } }, (function (t) { var e = t.subType, r = t.id, o = xz[n](e, r, t, i); o && (k(o, t.option), a.series.push(o)); var s = t.coordinateSystem; if (s && "cartesian2d" === s.type && ("line" === n || "bar" === n)) { var l = s.getAxesByScale("ordinal")[0]; if (l) { var u = l.dim + "Axis", h = t.getReferringComponents(u, zo).models[0].componentIndex; a[u] = a[u] || []; for (var c = 0; c <= h; c++)a[u][h] = a[u][h] || {}; a[u][h].boundaryGap = "bar" === n } } })); var s = n; "stack" === n && (o = C({ stack: i.option.title.tiled, tiled: i.option.title.stack }, i.option.title), "emphasis" !== i.get(["iconStatus", n]) && (s = "tiled")), e.dispatchAction({ type: "changeMagicType", currentType: s, newOption: a, newTitle: o, featureName: "magicType" }) } }, e }(lz), xz = { line: function (t, e, n, i) { if ("bar" === t) return C({ id: e, type: "line", data: n.get("data"), stack: n.get("stack"), markPoint: n.get("markPoint"), markLine: n.get("markLine") }, i.get(["option", "line"]) || {}, !0) }, bar: function (t, e, n, i) { if ("line" === t) return C({ id: e, type: "bar", data: n.get("data"), stack: n.get("stack"), markPoint: n.get("markPoint"), markLine: n.get("markLine") }, i.get(["option", "bar"]) || {}, !0) }, stack: function (t, e, n, i) { var r = n.get("stack") === yz; if ("line" === t || "bar" === t) return i.setIconStatus("stack", r ? "normal" : "emphasis"), C({ id: e, stack: r ? "" : yz }, i.get(["option", "stack"]) || {}, !0) } }; Mm({ type: "changeMagicType", event: "magicTypeChanged", update: "prepareAndUpdate" }, (function (t, e) { e.mergeOption(t.newOption) })); var _z = new Array(60).join("-"), bz = "\t"; function wz(t) { return t.replace(/^\s\s*/, "").replace(/\s\s*$/, "") } var Sz = new RegExp("[\t]+", "g"); function Mz(t, e) { var n = t.split(new RegExp("\n*" + _z + "\n*", "g")), i = { series: [] }; return E(n, (function (t, n) { if (function (t) { if (t.slice(0, t.indexOf("\n")).indexOf(bz) >= 0) return !0 }(t)) { var r = function (t) { for (var e = t.split(/\n+/g), n = [], i = z(wz(e.shift()).split(Sz), (function (t) { return { name: t, data: [] } })), r = 0; r < e.length; r++) { var o = wz(e[r]).split(Sz); n.push(o.shift()); for (var a = 0; a < o.length; a++)i[a] && (i[a].data[r] = o[a]) } return { series: i, categories: n } }(t), o = e[n], a = o.axisDim + "Axis"; o && (i[a] = i[a] || [], i[a][o.axisIndex] = { data: r.categories }, i.series = i.series.concat(r.series)) } else { r = function (t) { for (var e = t.split(/\n+/g), n = wz(e.shift()), i = [], r = 0; r < e.length; r++) { var o = wz(e[r]); if (o) { var a = o.split(Sz), s = "", l = void 0, u = !1; isNaN(a[0]) ? (u = !0, s = a[0], a = a.slice(1), i[r] = { name: s, value: [] }, l = i[r].value) : l = i[r] = []; for (var h = 0; h < a.length; h++)l.push(+a[h]); 1 === l.length && (u ? i[r].value = l[0] : i[r] = l[0]) } } return { name: n, data: i } }(t); i.series.push(r) } })), i } var Iz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.onclick = function (t, e) { setTimeout((function () { e.dispatchAction({ type: "hideTip" }) })); var n = e.getDom(), i = this.model; this._dom && n.removeChild(this._dom); var r = document.createElement("div"); r.style.cssText = "position:absolute;top:0;bottom:0;left:0;right:0;padding:5px", r.style.backgroundColor = i.get("backgroundColor") || "#fff"; var o = document.createElement("h4"), a = i.get("lang") || []; o.innerHTML = a[0] || i.get("title"), o.style.cssText = "margin:10px 20px", o.style.color = i.get("textColor"); var s = document.createElement("div"), l = document.createElement("textarea"); s.style.cssText = "overflow:auto"; var u = i.get("optionToContent"), h = i.get("contentToOption"), c = function (t) { var e, n, i, r = function (t) { var e = {}, n = [], i = []; return t.eachRawSeries((function (t) { var r = t.coordinateSystem; if (!r || "cartesian2d" !== r.type && "polar" !== r.type) n.push(t); else { var o = r.getBaseAxis(); if ("category" === o.type) { var a = o.dim + "_" + o.index; e[a] || (e[a] = { categoryAxis: o, valueAxis: r.getOtherAxis(o), series: [] }, i.push({ axisDim: o.dim, axisIndex: o.index })), e[a].series.push(t) } else n.push(t) } })), { seriesGroupByCategoryAxis: e, other: n, meta: i } }(t); return { value: B([(n = r.seriesGroupByCategoryAxis, i = [], E(n, (function (t, e) { var n = t.categoryAxis, r = t.valueAxis.dim, o = [" "].concat(z(t.series, (function (t) { return t.name }))), a = [n.model.getCategories()]; E(t.series, (function (t) { var e = t.getRawData(); a.push(t.getRawData().mapArray(e.mapDimension(r), (function (t) { return t }))) })); for (var s = [o.join(bz)], l = 0; l < a[0].length; l++) { for (var u = [], h = 0; h < a.length; h++)u.push(a[h][l]); s.push(u.join(bz)) } i.push(s.join("\n")) })), i.join("\n\n" + _z + "\n\n")), (e = r.other, z(e, (function (t) { var e = t.getRawData(), n = [t.name], i = []; return e.each(e.dimensions, (function () { for (var t = arguments.length, r = arguments[t - 1], o = e.getName(r), a = 0; a < t - 1; a++)i[a] = arguments[a]; n.push((o ? o + bz : "") + i.join(bz)) })), n.join("\n") })).join("\n\n" + _z + "\n\n"))], (function (t) { return !!t.replace(/[\n\t\s]/g, "") })).join("\n\n" + _z + "\n\n"), meta: r.meta } }(t); if (X(u)) { var p = u(e.getOption()); U(p) ? s.innerHTML = p : J(p) && s.appendChild(p) } else { l.readOnly = i.get("readOnly"); var d = l.style; d.cssText = "display:block;width:100%;height:100%;font-family:monospace;font-size:14px;line-height:1.6rem;resize:none;box-sizing:border-box;outline:none", d.color = i.get("textColor"), d.borderColor = i.get("textareaBorderColor"), d.backgroundColor = i.get("textareaColor"), l.value = c.value, s.appendChild(l) } var f = c.meta, g = document.createElement("div"); g.style.cssText = "position:absolute;bottom:5px;left:0;right:0"; var y = "float:right;margin-right:20px;border:none;cursor:pointer;padding:2px 5px;font-size:12px;border-radius:3px", v = document.createElement("div"), m = document.createElement("div"); y += ";background-color:" + i.get("buttonColor"), y += ";color:" + i.get("buttonTextColor"); var x = this; function _() { n.removeChild(r), x._dom = null } pe(v, "click", _), pe(m, "click", (function () { if (null == h && null != u || null != h && null == u) _(); else { var t; try { t = X(h) ? h(s, e.getOption()) : Mz(l.value, f) } catch (t) { throw _(), new Error("Data view format error " + t) } t && e.dispatchAction({ type: "changeDataView", newOption: t }), _() } })), v.innerHTML = a[1], m.innerHTML = a[2], m.style.cssText = v.style.cssText = y, !i.get("readOnly") && g.appendChild(m), g.appendChild(v), r.appendChild(o), r.appendChild(s), r.appendChild(g), s.style.height = n.clientHeight - 80 + "px", n.appendChild(r), this._dom = r }, e.prototype.remove = function (t, e) { this._dom && e.getDom().removeChild(this._dom) }, e.prototype.dispose = function (t, e) { this.remove(t, e) }, e.getDefaultOption = function (t) { return { show: !0, readOnly: !1, optionToContent: null, contentToOption: null, icon: "M17.5,17.3H33 M17.5,17.3H33 M45.4,29.5h-28 M11.5,2v56H51V14.8L38.4,2H11.5z M38.4,2.2v12.7H51 M45.4,41.7h-28", title: t.getLocaleModel().get(["toolbox", "dataView", "title"]), lang: t.getLocaleModel().get(["toolbox", "dataView", "lang"]), backgroundColor: "#fff", textColor: "#000", textareaColor: "#fff", textareaBorderColor: "#333", buttonColor: "#c23531", buttonTextColor: "#fff" } }, e }(lz); function Tz(t, e) { return z(t, (function (t, n) { var i = e && e[n]; if (q(i) && !Y(i)) { q(t) && !Y(t) || (t = { value: t }); var r = null != i.name && null == t.name; return t = k(t, i), r && delete t.name, t } return t })) } Mm({ type: "changeDataView", event: "dataViewChanged", update: "prepareAndUpdate" }, (function (t, e) { var n = []; E(t.newOption.series, (function (t) { var i = e.getSeriesByName(t.name)[0]; if (i) { var r = i.get("data"); n.push({ name: t.name, data: Tz(t.data, r) }) } else n.push(A({ type: "scatter" }, t)) })), e.mergeOption(k({ series: n }, t.newOption)) })); var Cz = E, Dz = Oo(); function Az(t) { var e = Dz(t); return e.snapshots || (e.snapshots = [{}]), e.snapshots } var kz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.onclick = function (t, e) { !function (t) { Dz(t).snapshots = null }(t), e.dispatchAction({ type: "restore", from: this.uid }) }, e.getDefaultOption = function (t) { return { show: !0, icon: "M3.8,33.4 M47,18.9h9.8V8.7 M56.3,20.1 C52.1,9,40.5,0.6,26.8,2.1C12.6,3.7,1.6,16.2,2.1,30.6 M13,41.1H3.1v10.2 M3.7,39.9c4.2,11.1,15.8,19.5,29.5,18 c14.2-1.6,25.2-14.1,24.7-28.5", title: t.getLocaleModel().get(["toolbox", "restore", "title"]) } }, e }(lz); Mm({ type: "restore", event: "restore", update: "prepareAndUpdate" }, (function (t, e) { e.resetOption("recreate") })); var Lz = ["grid", "xAxis", "yAxis", "geo", "graph", "polar", "radiusAxis", "angleAxis", "bmap"], Pz = function () { function t(t, e, n) { var i = this; this._targetInfoList = []; var r = Rz(e, t); E(Nz, (function (t, e) { (!n || !n.include || P(n.include, e) >= 0) && t(r, i._targetInfoList) })) } return t.prototype.setOutputRanges = function (t, e) { return this.matchOutputRanges(t, e, (function (t, e, n) { if ((t.coordRanges || (t.coordRanges = [])).push(e), !t.coordRange) { t.coordRange = e; var i = Vz[t.brushType](0, n, e); t.__rangeOffset = { offset: Fz[t.brushType](i.values, t.range, [1, 1]), xyMinMax: i.xyMinMax } } })), t }, t.prototype.matchOutputRanges = function (t, e, n) { E(t, (function (t) { var i = this.findTargetInfo(t, e); i && !0 !== i && E(i.coordSyses, (function (i) { var r = Vz[t.brushType](1, i, t.range, !0); n(t, r.values, i, e) })) }), this) }, t.prototype.setInputRanges = function (t, e) { E(t, (function (t) { var n, i, r, o, a, s = this.findTargetInfo(t, e); if (t.range = t.range || [], s && !0 !== s) { t.panelId = s.panelId; var l = Vz[t.brushType](0, s.coordSys, t.coordRange), u = t.__rangeOffset; t.range = u ? Fz[t.brushType](l.values, u.offset, (n = l.xyMinMax, i = u.xyMinMax, r = Wz(n), o = Wz(i), a = [r[0] / o[0], r[1] / o[1]], isNaN(a[0]) && (a[0] = 1), isNaN(a[1]) && (a[1] = 1), a)) : l.values } }), this) }, t.prototype.makePanelOpts = function (t, e) { return z(this._targetInfoList, (function (n) { var i = n.getPanelRect(); return { panelId: n.panelId, defaultBrushType: e ? e(n) : null, clipPath: AL(i), isTargetByCursor: LL(i, t, n.coordSysModel), getLinearBrushOtherExtent: kL(i) } })) }, t.prototype.controlSeries = function (t, e, n) { var i = this.findTargetInfo(t, n); return !0 === i || i && P(i.coordSyses, e.coordinateSystem) >= 0 }, t.prototype.findTargetInfo = function (t, e) { for (var n = this._targetInfoList, i = Rz(e, t), r = 0; r < n.length; r++) { var o = n[r], a = t.panelId; if (a) { if (o.panelId === a) return o } else for (var s = 0; s < Ez.length; s++)if (Ez[s](i, o)) return o } return !0 }, t }(); function Oz(t) { return t[0] > t[1] && t.reverse(), t } function Rz(t, e) { return No(t, e, { includeMainTypes: Lz }) } var Nz = { grid: function (t, e) { var n = t.xAxisModels, i = t.yAxisModels, r = t.gridModels, o = yt(), a = {}, s = {}; (n || i || r) && (E(n, (function (t) { var e = t.axis.grid.model; o.set(e.id, e), a[e.id] = !0 })), E(i, (function (t) { var e = t.axis.grid.model; o.set(e.id, e), s[e.id] = !0 })), E(r, (function (t) { o.set(t.id, t), a[t.id] = !0, s[t.id] = !0 })), o.each((function (t) { var r = t.coordinateSystem, o = []; E(r.getCartesians(), (function (t, e) { (P(n, t.getAxis("x").model) >= 0 || P(i, t.getAxis("y").model) >= 0) && o.push(t) })), e.push({ panelId: "grid--" + t.id, gridModel: t, coordSysModel: t, coordSys: o[0], coordSyses: o, getPanelRect: zz.grid, xAxisDeclared: a[t.id], yAxisDeclared: s[t.id] }) }))) }, geo: function (t, e) { E(t.geoModels, (function (t) { var n = t.coordinateSystem; e.push({ panelId: "geo--" + t.id, geoModel: t, coordSysModel: t, coordSys: n, coordSyses: [n], getPanelRect: zz.geo }) })) } }, Ez = [function (t, e) { var n = t.xAxisModel, i = t.yAxisModel, r = t.gridModel; return !r && n && (r = n.axis.grid.model), !r && i && (r = i.axis.grid.model), r && r === e.gridModel }, function (t, e) { var n = t.geoModel; return n && n === e.geoModel }], zz = { grid: function () { return this.coordSys.master.getRect().clone() }, geo: function () { var t = this.coordSys, e = t.getBoundingRect().clone(); return e.applyTransform(Eh(t)), e } }, Vz = { lineX: H(Bz, 0), lineY: H(Bz, 1), rect: function (t, e, n, i) { var r = t ? e.pointToData([n[0][0], n[1][0]], i) : e.dataToPoint([n[0][0], n[1][0]], i), o = t ? e.pointToData([n[0][1], n[1][1]], i) : e.dataToPoint([n[0][1], n[1][1]], i), a = [Oz([r[0], o[0]]), Oz([r[1], o[1]])]; return { values: a, xyMinMax: a } }, polygon: function (t, e, n, i) { var r = [[1 / 0, -1 / 0], [1 / 0, -1 / 0]]; return { values: z(n, (function (n) { var o = t ? e.pointToData(n, i) : e.dataToPoint(n, i); return r[0][0] = Math.min(r[0][0], o[0]), r[1][0] = Math.min(r[1][0], o[1]), r[0][1] = Math.max(r[0][1], o[0]), r[1][1] = Math.max(r[1][1], o[1]), o })), xyMinMax: r } } }; function Bz(t, e, n, i) { var r = n.getAxis(["x", "y"][t]), o = Oz(z([0, 1], (function (t) { return e ? r.coordToData(r.toLocalCoord(i[t]), !0) : r.toGlobalCoord(r.dataToCoord(i[t])) }))), a = []; return a[t] = o, a[1 - t] = [NaN, NaN], { values: o, xyMinMax: a } } var Fz = { lineX: H(Gz, 0), lineY: H(Gz, 1), rect: function (t, e, n) { return [[t[0][0] - n[0] * e[0][0], t[0][1] - n[0] * e[0][1]], [t[1][0] - n[1] * e[1][0], t[1][1] - n[1] * e[1][1]]] }, polygon: function (t, e, n) { return z(t, (function (t, i) { return [t[0] - n[0] * e[i][0], t[1] - n[1] * e[i][1]] })) } }; function Gz(t, e, n, i) { return [e[0] - i[t] * n[0], e[1] - i[t] * n[1]] } function Wz(t) { return t ? [t[0][1] - t[0][0], t[1][1] - t[1][0]] : [NaN, NaN] } var Hz, Yz, Xz = E, Uz = _o + "toolbox-dataZoom_", Zz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.render = function (t, e, n, i) { this._brushController || (this._brushController = new Jk(n.getZr()), this._brushController.on("brush", W(this._onBrush, this)).mount()), function (t, e, n, i, r) { var o = n._isZoomActive; i && "takeGlobalCursor" === i.type && (o = "dataZoomSelect" === i.key && i.dataZoomSelectActive); n._isZoomActive = o, t.setIconStatus("zoom", o ? "emphasis" : "normal"); var a = new Pz(qz(t), e, { include: ["grid"] }), s = a.makePanelOpts(r, (function (t) { return t.xAxisDeclared && !t.yAxisDeclared ? "lineX" : !t.xAxisDeclared && t.yAxisDeclared ? "lineY" : "rect" })); n._brushController.setPanels(s).enableBrush(!(!o || !s.length) && { brushType: "auto", brushStyle: t.getModel("brushStyle").getItemStyle() }) }(t, e, this, i, n), function (t, e) { t.setIconStatus("back", function (t) { return Az(t).length }(e) > 1 ? "emphasis" : "normal") }(t, e) }, e.prototype.onclick = function (t, e, n) { jz[n].call(this) }, e.prototype.remove = function (t, e) { this._brushController && this._brushController.unmount() }, e.prototype.dispose = function (t, e) { this._brushController && this._brushController.dispose() }, e.prototype._onBrush = function (t) { var e = t.areas; if (t.isEnd && e.length) { var n = {}, i = this.ecModel; this._brushController.updateCovers([]), new Pz(qz(this.model), i, { include: ["grid"] }).matchOutputRanges(e, i, (function (t, e, n) { if ("cartesian2d" === n.type) { var i = t.brushType; "rect" === i ? (r("x", n, e[0]), r("y", n, e[1])) : r({ lineX: "x", lineY: "y" }[i], n, e) } })), function (t, e) { var n = Az(t); Cz(e, (function (e, i) { for (var r = n.length - 1; r >= 0 && !n[r][i]; r--); if (r < 0) { var o = t.queryComponents({ mainType: "dataZoom", subType: "select", id: i })[0]; if (o) { var a = o.getPercentRange(); n[0][i] = { dataZoomId: i, start: a[0], end: a[1] } } } })), n.push(e) }(i, n), this._dispatchZoomAction(n) } function r(t, e, r) { var o = e.getAxis(t), a = o.model, s = function (t, e, n) { var i; return n.eachComponent({ mainType: "dataZoom", subType: "select" }, (function (n) { n.getAxisModel(t, e.componentIndex) && (i = n) })), i }(t, a, i), l = s.findRepresentativeAxisProxy(a).getMinMaxSpan(); null == l.minValueSpan && null == l.maxValueSpan || (r = Ck(0, r.slice(), o.scale.getExtent(), 0, l.minValueSpan, l.maxValueSpan)), s && (n[s.id] = { dataZoomId: s.id, startValue: r[0], endValue: r[1] }) } }, e.prototype._dispatchZoomAction = function (t) { var e = []; Xz(t, (function (t, n) { e.push(T(t)) })), e.length && this.api.dispatchAction({ type: "dataZoom", from: this.uid, batch: e }) }, e.getDefaultOption = function (t) { return { show: !0, filterMode: "filter", icon: { zoom: "M0,13.5h26.9 M13.5,26.9V0 M32.1,13.5H58V58H13.5 V32.1", back: "M22,1.4L9.9,13.5l12.3,12.3 M10.3,13.5H54.9v44.6 H10.3v-26" }, title: t.getLocaleModel().get(["toolbox", "dataZoom", "title"]), brushStyle: { borderWidth: 0, color: "rgba(210,219,238,0.2)" } } }, e }(lz), jz = { zoom: function () { var t = !this._isZoomActive; this.api.dispatchAction({ type: "takeGlobalCursor", key: "dataZoomSelect", dataZoomSelectActive: t }) }, back: function () { this._dispatchZoomAction(function (t) { var e = Az(t), n = e[e.length - 1]; e.length > 1 && e.pop(); var i = {}; return Cz(n, (function (t, n) { for (var r = e.length - 1; r >= 0; r--)if (t = e[r][n]) { i[n] = t; break } })), i }(this.ecModel)) } }; function qz(t) { var e = { xAxisIndex: t.get("xAxisIndex", !0), yAxisIndex: t.get("yAxisIndex", !0), xAxisId: t.get("xAxisId", !0), yAxisId: t.get("yAxisId", !0) }; return null == e.xAxisIndex && null == e.xAxisId && (e.xAxisIndex = "all"), null == e.yAxisIndex && null == e.yAxisId && (e.yAxisIndex = "all"), e } Hz = "dataZoom", Yz = function (t) { var e = t.getComponent("toolbox", 0), n = ["feature", "dataZoom"]; if (e && null != e.get(n)) { var i = e.getModel(n), r = [], o = No(t, qz(i)); return Xz(o.xAxisModels, (function (t) { return a(t, "xAxis", "xAxisIndex") })), Xz(o.yAxisModels, (function (t) { return a(t, "yAxis", "yAxisIndex") })), r } function a(t, e, n) { var o = t.componentIndex, a = { type: "select", $fromToolbox: !0, filterMode: i.get("filterMode", !0) || "filter", id: Uz + e + o }; a[n] = o, r.push(a) } }, lt(null == nd.get(Hz) && Yz), nd.set(Hz, Yz); var Kz = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "tooltip", e.dependencies = ["axisPointer"], e.defaultOption = { z: 60, show: !0, showContent: !0, trigger: "item", triggerOn: "mousemove|click", alwaysShowContent: !1, displayMode: "single", renderMode: "auto", confine: null, showDelay: 0, hideDelay: 100, transitionDuration: .4, enterable: !1, backgroundColor: "#fff", shadowBlur: 10, shadowColor: "rgba(0, 0, 0, .2)", shadowOffsetX: 1, shadowOffsetY: 2, borderRadius: 4, borderWidth: 1, padding: null, extraCssText: "", axisPointer: { type: "line", axis: "auto", animation: "auto", animationDurationUpdate: 200, animationEasingUpdate: "exponentialOut", crossStyle: { color: "#999", width: 1, type: "dashed", textStyle: {} } }, textStyle: { color: "#666", fontSize: 14 } }, e }(Rp); function $z(t) { var e = t.get("confine"); return null != e ? !!e : "richText" === t.get("renderMode") } function Jz(t) { if (r.domSupported) for (var e = document.documentElement.style, n = 0, i = t.length; n < i; n++)if (t[n] in e) return t[n] } var Qz = Jz(["transform", "webkitTransform", "OTransform", "MozTransform", "msTransform"]); function tV(t, e) { if (!t) return e; e = dp(e, !0); var n = t.indexOf(e); return (t = -1 === n ? e : "-" + t.slice(0, n) + "-" + e).toLowerCase() } var eV = tV(Jz(["webkitTransition", "transition", "OTransition", "MozTransition", "msTransition"]), "transition"), nV = tV(Qz, "transform"), iV = "position:absolute;display:block;border-style:solid;white-space:nowrap;z-index:9999999;" + (r.transform3dSupported ? "will-change:transform;" : ""); function rV(t, e, n) { var i = t.toFixed(0) + "px", o = e.toFixed(0) + "px"; if (!r.transformSupported) return n ? "top:" + o + ";left:" + i + ";" : [["top", o], ["left", i]]; var a = r.transform3dSupported, s = "translate" + (a ? "3d" : "") + "(" + i + "," + o + (a ? ",0" : "") + ")"; return n ? "top:0;left:0;" + nV + ":" + s + ";" : [["top", 0], ["left", 0], [Qz, s]] } function oV(t, e, n) { var i = [], o = t.get("transitionDuration"), a = t.get("backgroundColor"), s = t.get("shadowBlur"), l = t.get("shadowColor"), u = t.get("shadowOffsetX"), h = t.get("shadowOffsetY"), c = t.getModel("textStyle"), p = pg(t, "html"), d = u + "px " + h + "px " + s + "px " + l; return i.push("box-shadow:" + d), e && o && i.push(function (t, e) { var n = "cubic-bezier(0.23,1,0.32,1)", i = " " + t / 2 + "s " + n, o = "opacity" + i + ",visibility" + i; return e || (i = " " + t + "s " + n, o += r.transformSupported ? "," + nV + i : ",left" + i + ",top" + i), eV + ":" + o }(o, n)), a && i.push("background-color:" + a), E(["width", "color", "radius"], (function (e) { var n = "border-" + e, r = dp(n), o = t.get(r); null != o && i.push(n + ":" + o + ("color" === e ? "" : "px")) })), i.push(function (t) { var e = [], n = t.get("fontSize"), i = t.getTextColor(); i && e.push("color:" + i), e.push("font:" + t.getFont()), n && e.push("line-height:" + Math.round(3 * n / 2) + "px"); var r = t.get("textShadowColor"), o = t.get("textShadowBlur") || 0, a = t.get("textShadowOffsetX") || 0, s = t.get("textShadowOffsetY") || 0; return r && o && e.push("text-shadow:" + a + "px " + s + "px " + o + "px " + r), E(["decoration", "align"], (function (n) { var i = t.get(n); i && e.push("text-" + n + ":" + i) })), e.join(";") }(c)), null != p && i.push("padding:" + fp(p).join("px ") + "px"), i.join(";") + ";" } function aV(t, e, n, i, r) { var o = e && e.painter; if (n) { var a = o && o.getViewportRoot(); a && function (t, e, n, i, r) { te(Qt, e, i, r, !0) && te(t, n, Qt[0], Qt[1]) }(t, a, document.body, i, r) } else { t[0] = i, t[1] = r; var s = o && o.getViewportRootOffset(); s && (t[0] += s.offsetLeft, t[1] += s.offsetTop) } t[2] = t[0] / e.getWidth(), t[3] = t[1] / e.getHeight() } var sV = function () { function t(t, e, n) { if (this._show = !1, this._styleCoord = [0, 0, 0, 0], this._enterable = !0, this._alwaysShowContent = !1, this._firstShow = !0, this._longHide = !0, r.wxa) return null; var i = document.createElement("div"); i.domBelongToZr = !0, this.el = i; var o = this._zr = e.getZr(), a = this._appendToBody = n && n.appendToBody; aV(this._styleCoord, o, a, e.getWidth() / 2, e.getHeight() / 2), a ? document.body.appendChild(i) : t.appendChild(i), this._container = t; var s = this; i.onmouseenter = function () { s._enterable && (clearTimeout(s._hideTimeout), s._show = !0), s._inContent = !0 }, i.onmousemove = function (t) { if (t = t || window.event, !s._enterable) { var e = o.handler; ce(o.painter.getViewportRoot(), t, !0), e.dispatch("mousemove", t) } }, i.onmouseleave = function () { s._inContent = !1, s._enterable && s._show && s.hideLater(s._hideDelay) } } return t.prototype.update = function (t) { var e, n, i, r = this._container, o = (n = "position", (i = (e = r).currentStyle || document.defaultView && document.defaultView.getComputedStyle(e)) ? n ? i[n] : i : null), a = r.style; "absolute" !== a.position && "absolute" !== o && (a.position = "relative"); var s = t.get("alwaysShowContent"); s && this._moveIfResized(), this._alwaysShowContent = s, this.el.className = t.get("className") || "" }, t.prototype.show = function (t, e) { clearTimeout(this._hideTimeout), clearTimeout(this._longHideTimeout); var n = this.el, i = n.style, r = this._styleCoord; n.innerHTML ? i.cssText = iV + oV(t, !this._firstShow, this._longHide) + rV(r[0], r[1], !0) + "border-color:" + _p(e) + ";" + (t.get("extraCssText") || "") + ";pointer-events:" + (this._enterable ? "auto" : "none") : i.display = "none", this._show = !0, this._firstShow = !1, this._longHide = !1 }, t.prototype.setContent = function (t, e, n, i, r) { var o = this.el; if (null != t) { var a = ""; if (U(r) && "item" === n.get("trigger") && !$z(n) && (a = function (t, e, n) { if (!U(n) || "inside" === n) return ""; var i = t.get("backgroundColor"), r = t.get("borderWidth"); e = _p(e); var o, a, s = "left" === (o = n) ? "right" : "right" === o ? "left" : "top" === o ? "bottom" : "top", l = Math.max(1.5 * Math.round(r), 6), u = "", h = nV + ":"; P(["left", "right"], s) > -1 ? (u += "top:50%", h += "translateY(-50%) rotate(" + (a = "left" === s ? -225 : -45) + "deg)") : (u += "left:50%", h += "translateX(-50%) rotate(" + (a = "top" === s ? 225 : 45) + "deg)"); var c = a * Math.PI / 180, p = l + r, d = p * Math.abs(Math.cos(c)) + p * Math.abs(Math.sin(c)), f = e + " solid " + r + "px;"; return '<div style="' + ["position:absolute;width:" + l + "px;height:" + l + "px;z-index:-1;", (u += ";" + s + ":-" + Math.round(100 * ((d - Math.SQRT2 * r) / 2 + Math.SQRT2 * r - (d - p) / 2)) / 100 + "px") + ";" + h + ";", "border-bottom:" + f, "border-right:" + f, "background-color:" + i + ";"].join("") + '"></div>' }(n, i, r)), U(t)) o.innerHTML = t + a; else if (t) { o.innerHTML = "", Y(t) || (t = [t]); for (var s = 0; s < t.length; s++)J(t[s]) && t[s].parentNode !== o && o.appendChild(t[s]); if (a && o.childNodes.length) { var l = document.createElement("div"); l.innerHTML = a, o.appendChild(l) } } } else o.innerHTML = "" }, t.prototype.setEnterable = function (t) { this._enterable = t }, t.prototype.getSize = function () { var t = this.el; return [t.offsetWidth, t.offsetHeight] }, t.prototype.moveTo = function (t, e) { var n = this._styleCoord; if (aV(n, this._zr, this._appendToBody, t, e), null != n[0] && null != n[1]) { var i = this.el.style; E(rV(n[0], n[1]), (function (t) { i[t[0]] = t[1] })) } }, t.prototype._moveIfResized = function () { var t = this._styleCoord[2], e = this._styleCoord[3]; this.moveTo(t * this._zr.getWidth(), e * this._zr.getHeight()) }, t.prototype.hide = function () { var t = this, e = this.el.style; e.visibility = "hidden", e.opacity = "0", r.transform3dSupported && (e.willChange = ""), this._show = !1, this._longHideTimeout = setTimeout((function () { return t._longHide = !0 }), 500) }, t.prototype.hideLater = function (t) { !this._show || this._inContent && this._enterable || this._alwaysShowContent || (t ? (this._hideDelay = t, this._show = !1, this._hideTimeout = setTimeout(W(this.hide, this), t)) : this.hide()) }, t.prototype.isShow = function () { return this._show }, t.prototype.dispose = function () { this.el.parentNode.removeChild(this.el) }, t }(), lV = function () { function t(t) { this._show = !1, this._styleCoord = [0, 0, 0, 0], this._alwaysShowContent = !1, this._enterable = !0, this._zr = t.getZr(), cV(this._styleCoord, this._zr, t.getWidth() / 2, t.getHeight() / 2) } return t.prototype.update = function (t) { var e = t.get("alwaysShowContent"); e && this._moveIfResized(), this._alwaysShowContent = e }, t.prototype.show = function () { this._hideTimeout && clearTimeout(this._hideTimeout), this.el.show(), this._show = !0 }, t.prototype.setContent = function (t, e, n, i, r) { var o = this; q(t) && vo(""), this.el && this._zr.remove(this.el); var a = n.getModel("textStyle"); this.el = new Fs({ style: { rich: e.richTextStyles, text: t, lineHeight: 22, borderWidth: 1, borderColor: i, textShadowColor: a.get("textShadowColor"), fill: n.get(["textStyle", "color"]), padding: pg(n, "richText"), verticalAlign: "top", align: "left" }, z: n.get("z") }), E(["backgroundColor", "borderRadius", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY"], (function (t) { o.el.style[t] = n.get(t) })), E(["textShadowBlur", "textShadowOffsetX", "textShadowOffsetY"], (function (t) { o.el.style[t] = a.get(t) || 0 })), this._zr.add(this.el); var s = this; this.el.on("mouseover", (function () { s._enterable && (clearTimeout(s._hideTimeout), s._show = !0), s._inContent = !0 })), this.el.on("mouseout", (function () { s._enterable && s._show && s.hideLater(s._hideDelay), s._inContent = !1 })) }, t.prototype.setEnterable = function (t) { this._enterable = t }, t.prototype.getSize = function () { var t = this.el, e = this.el.getBoundingRect(), n = hV(t.style); return [e.width + n.left + n.right, e.height + n.top + n.bottom] }, t.prototype.moveTo = function (t, e) { var n = this.el; if (n) { var i = this._styleCoord; cV(i, this._zr, t, e), t = i[0], e = i[1]; var r = n.style, o = uV(r.borderWidth || 0), a = hV(r); n.x = t + o + a.left, n.y = e + o + a.top, n.markRedraw() } }, t.prototype._moveIfResized = function () { var t = this._styleCoord[2], e = this._styleCoord[3]; this.moveTo(t * this._zr.getWidth(), e * this._zr.getHeight()) }, t.prototype.hide = function () { this.el && this.el.hide(), this._show = !1 }, t.prototype.hideLater = function (t) { !this._show || this._inContent && this._enterable || this._alwaysShowContent || (t ? (this._hideDelay = t, this._show = !1, this._hideTimeout = setTimeout(W(this.hide, this), t)) : this.hide()) }, t.prototype.isShow = function () { return this._show }, t.prototype.dispose = function () { this._zr.remove(this.el) }, t }(); function uV(t) { return Math.max(0, t) } function hV(t) { var e = uV(t.shadowBlur || 0), n = uV(t.shadowOffsetX || 0), i = uV(t.shadowOffsetY || 0); return { left: uV(e - n), right: uV(e + n), top: uV(e - i), bottom: uV(e + i) } } function cV(t, e, n, i) { t[0] = n, t[1] = i, t[2] = t[0] / e.getWidth(), t[3] = t[1] / e.getHeight() } var pV = new zs({ shape: { x: -1, y: -1, width: 2, height: 2 } }), dV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (t, e) { if (!r.node && e.getDom()) { var n, i = t.getComponent("tooltip"), o = this._renderMode = "auto" === (n = i.get("renderMode")) ? r.domSupported ? "html" : "richText" : n || "html"; this._tooltipContent = "richText" === o ? new lV(e) : new sV(e.getDom(), e, { appendToBody: i.get("appendToBody", !0) }) } }, e.prototype.render = function (t, e, n) { if (!r.node && n.getDom()) { this.group.removeAll(), this._tooltipModel = t, this._ecModel = e, this._api = n; var i = this._tooltipContent; i.update(t), i.setEnterable(t.get("enterable")), this._initGlobalListener(), this._keepShow(), "richText" !== this._renderMode && t.get("transitionDuration") ? Fg(this, "_updatePosition", 50, "fixRate") : Gg(this, "_updatePosition") } }, e.prototype._initGlobalListener = function () { var t = this._tooltipModel.get("triggerOn"); vN("itemTooltip", this._api, W((function (e, n, i) { "none" !== t && (t.indexOf(e) >= 0 ? this._tryShow(n, i) : "leave" === e && this._hide(i)) }), this)) }, e.prototype._keepShow = function () { var t = this._tooltipModel, e = this._ecModel, n = this._api, i = t.get("triggerOn"); if (null != this._lastX && null != this._lastY && "none" !== i && "click" !== i) { var r = this; clearTimeout(this._refreshUpdateTimeout), this._refreshUpdateTimeout = setTimeout((function () { !n.isDisposed() && r.manuallyShowTip(t, e, n, { x: r._lastX, y: r._lastY, dataByCoordSys: r._lastDataByCoordSys }) })) } }, e.prototype.manuallyShowTip = function (t, e, n, i) { if (i.from !== this.uid && !r.node && n.getDom()) { var o = gV(i, n); this._ticket = ""; var a = i.dataByCoordSys, s = function (t, e, n) { var i = Eo(t).queryOptionMap, r = i.keys()[0]; if (!r || "series" === r) return; var o = Bo(e, r, i.get(r), { useDefault: !1, enableAll: !1, enableNone: !1 }), a = o.models[0]; if (!a) return; var s, l = n.getViewOfComponentModel(a); if (l.group.traverse((function (e) { var n = Qs(e).tooltipConfig; if (n && n.name === t.name) return s = e, !0 })), s) return { componentMainType: r, componentIndex: a.componentIndex, el: s } }(i, e, n); if (s) { var l = s.el.getBoundingRect().clone(); l.applyTransform(s.el.transform), this._tryShow({ offsetX: l.x + l.width / 2, offsetY: l.y + l.height / 2, target: s.el, position: i.position, positionDefault: "bottom" }, o) } else if (i.tooltip && null != i.x && null != i.y) { var u = pV; u.x = i.x, u.y = i.y, u.update(), Qs(u).tooltipConfig = { name: null, option: i.tooltip }, this._tryShow({ offsetX: i.x, offsetY: i.y, target: u }, o) } else if (a) this._tryShow({ offsetX: i.x, offsetY: i.y, position: i.position, dataByCoordSys: a, tooltipOption: i.tooltipOption }, o); else if (null != i.seriesIndex) { if (this._manuallyAxisShowTip(t, e, n, i)) return; var h = wN(i, e), c = h.point[0], p = h.point[1]; null != c && null != p && this._tryShow({ offsetX: c, offsetY: p, target: h.el, position: i.position, positionDefault: "bottom" }, o) } else null != i.x && null != i.y && (n.dispatchAction({ type: "updateAxisPointer", x: i.x, y: i.y }), this._tryShow({ offsetX: i.x, offsetY: i.y, position: i.position, target: n.getZr().findHover(i.x, i.y).target }, o)) } }, e.prototype.manuallyHideTip = function (t, e, n, i) { var r = this._tooltipContent; this._tooltipModel && r.hideLater(this._tooltipModel.get("hideDelay")), this._lastX = this._lastY = this._lastDataByCoordSys = null, i.from !== this.uid && this._hide(gV(i, n)) }, e.prototype._manuallyAxisShowTip = function (t, e, n, i) { var r = i.seriesIndex, o = i.dataIndex, a = e.getComponent("axisPointer").coordSysAxesInfo; if (null != r && null != o && null != a) { var s = e.getSeriesByIndex(r); if (s) if ("axis" === fV([s.getData().getItemModel(o), s, (s.coordinateSystem || {}).model], this._tooltipModel).get("trigger")) return n.dispatchAction({ type: "updateAxisPointer", seriesIndex: r, dataIndex: o, position: i.position }), !0 } }, e.prototype._tryShow = function (t, e) { var n = t.target; if (this._tooltipModel) { this._lastX = t.offsetX, this._lastY = t.offsetY; var i = t.dataByCoordSys; if (i && i.length) this._showAxisTooltip(i, t); else if (n) { var r, o; this._lastDataByCoordSys = null, ky(n, (function (t) { return null != Qs(t).dataIndex ? (r = t, !0) : null != Qs(t).tooltipConfig ? (o = t, !0) : void 0 }), !0), r ? this._showSeriesItemTooltip(t, r, e) : o ? this._showComponentItemTooltip(t, o, e) : this._hide(e) } else this._lastDataByCoordSys = null, this._hide(e) } }, e.prototype._showOrMove = function (t, e) { var n = t.get("showDelay"); e = W(e, this), clearTimeout(this._showTimout), n > 0 ? this._showTimout = setTimeout(e, n) : e() }, e.prototype._showAxisTooltip = function (t, e) { var n = this._ecModel, i = this._tooltipModel, r = [e.offsetX, e.offsetY], o = fV([e.tooltipOption], i), a = this._renderMode, s = [], l = ng("section", { blocks: [], noHeader: !0 }), u = [], h = new dg; E(t, (function (t) { E(t.dataByAxis, (function (t) { var e = n.getComponent(t.axisDim + "Axis", t.axisIndex), r = t.value; if (e && null != r) { var o = rN(r, e.axis, n, t.seriesDataIndices, t.valueLabelOpt), c = ng("section", { header: o, noHeader: !ut(o), sortBlocks: !0, blocks: [] }); l.blocks.push(c), E(t.seriesDataIndices, (function (l) { var p = n.getSeriesByIndex(l.seriesIndex), d = l.dataIndexInside, f = p.getDataParams(d); if (!(f.dataIndex < 0)) { f.axisDim = t.axisDim, f.axisIndex = t.axisIndex, f.axisType = t.axisType, f.axisId = t.axisId, f.axisValue = __(e.axis, { value: r }), f.axisValueLabel = o, f.marker = h.makeTooltipMarker("item", _p(f.color), a); var g = mf(p.formatTooltip(d, !0, null)), y = g.frag; if (y) { var v = fV([p], i).get("valueFormatter"); c.blocks.push(v ? A({ valueFormatter: v }, y) : y) } g.text && u.push(g.text), s.push(f) } })) } })) })), l.blocks.reverse(), u.reverse(); var c = e.position, p = o.get("order"), d = lg(l, h, a, p, n.get("useUTC"), o.get("textStyle")); d && u.unshift(d); var f = "richText" === a ? "\n\n" : "<br/>", g = u.join(f); this._showOrMove(o, (function () { this._updateContentNotChangedOnAxis(t, s) ? this._updatePosition(o, c, r[0], r[1], this._tooltipContent, s) : this._showTooltipContent(o, g, s, Math.random() + "", r[0], r[1], c, null, h) })) }, e.prototype._showSeriesItemTooltip = function (t, e, n) { var i = this._ecModel, r = Qs(e), o = r.seriesIndex, a = i.getSeriesByIndex(o), s = r.dataModel || a, l = r.dataIndex, u = r.dataType, h = s.getData(u), c = this._renderMode, p = t.positionDefault, d = fV([h.getItemModel(l), s, a && (a.coordinateSystem || {}).model], this._tooltipModel, p ? { position: p } : null), f = d.get("trigger"); if (null == f || "item" === f) { var g = s.getDataParams(l, u), y = new dg; g.marker = y.makeTooltipMarker("item", _p(g.color), c); var v = mf(s.formatTooltip(l, !1, u)), m = d.get("order"), x = d.get("valueFormatter"), _ = v.frag, b = _ ? lg(x ? A({ valueFormatter: x }, _) : _, y, c, m, i.get("useUTC"), d.get("textStyle")) : v.text, w = "item_" + s.name + "_" + l; this._showOrMove(d, (function () { this._showTooltipContent(d, b, g, w, t.offsetX, t.offsetY, t.position, t.target, y) })), n({ type: "showTip", dataIndexInside: l, dataIndex: h.getRawIndex(l), seriesIndex: o, from: this.uid }) } }, e.prototype._showComponentItemTooltip = function (t, e, n) { var i = Qs(e), r = i.tooltipConfig.option || {}; if (U(r)) { r = { content: r, formatter: r } } var o = [r], a = this._ecModel.getComponent(i.componentMainType, i.componentIndex); a && o.push(a), o.push({ formatter: r.content }); var s = t.positionDefault, l = fV(o, this._tooltipModel, s ? { position: s } : null), u = l.get("content"), h = Math.random() + "", c = new dg; this._showOrMove(l, (function () { var n = T(l.get("formatterParams") || {}); this._showTooltipContent(l, u, n, h, t.offsetX, t.offsetY, t.position, e, c) })), n({ type: "showTip", from: this.uid }) }, e.prototype._showTooltipContent = function (t, e, n, i, r, o, a, s, l) { if (this._ticket = "", t.get("showContent") && t.get("show")) { var u = this._tooltipContent; u.setEnterable(t.get("enterable")); var h = t.get("formatter"); a = a || t.get("position"); var c = e, p = this._getNearestPoint([r, o], n, t.get("trigger"), t.get("borderColor")).color; if (h) if (U(h)) { var d = t.ecModel.get("useUTC"), f = Y(n) ? n[0] : n; c = h, f && f.axisType && f.axisType.indexOf("time") >= 0 && (c = qc(f.axisValue, c, d)), c = mp(c, n, !0) } else if (X(h)) { var g = W((function (e, i) { e === this._ticket && (u.setContent(i, l, t, p, a), this._updatePosition(t, a, r, o, u, n, s)) }), this); this._ticket = i, c = h(n, i, g) } else c = h; u.setContent(c, l, t, p, a), u.show(t, p), this._updatePosition(t, a, r, o, u, n, s) } }, e.prototype._getNearestPoint = function (t, e, n, i) { return "axis" === n || Y(e) ? { color: i || ("html" === this._renderMode ? "#fff" : "none") } : Y(e) ? void 0 : { color: i || e.color || e.borderColor } }, e.prototype._updatePosition = function (t, e, n, i, r, o, a) { var s = this._api.getWidth(), l = this._api.getHeight(); e = e || t.get("position"); var u = r.getSize(), h = t.get("align"), c = t.get("verticalAlign"), p = a && a.getBoundingRect().clone(); if (a && p.applyTransform(a.transform), X(e) && (e = e([n, i], o, r.el, p, { viewSize: [s, l], contentSize: u.slice() })), Y(e)) n = Ur(e[0], s), i = Ur(e[1], l); else if (q(e)) { var d = e; d.width = u[0], d.height = u[1]; var f = Cp(d, { width: s, height: l }); n = f.x, i = f.y, h = null, c = null } else if (U(e) && a) { var g = function (t, e, n, i) { var r = n[0], o = n[1], a = Math.ceil(Math.SQRT2 * i) + 8, s = 0, l = 0, u = e.width, h = e.height; switch (t) { case "inside": s = e.x + u / 2 - r / 2, l = e.y + h / 2 - o / 2; break; case "top": s = e.x + u / 2 - r / 2, l = e.y - o - a; break; case "bottom": s = e.x + u / 2 - r / 2, l = e.y + h + a; break; case "left": s = e.x - r - a, l = e.y + h / 2 - o / 2; break; case "right": s = e.x + u + a, l = e.y + h / 2 - o / 2 }return [s, l] }(e, p, u, t.get("borderWidth")); n = g[0], i = g[1] } else { g = function (t, e, n, i, r, o, a) { var s = n.getSize(), l = s[0], u = s[1]; null != o && (t + l + o + 2 > i ? t -= l + o : t += o); null != a && (e + u + a > r ? e -= u + a : e += a); return [t, e] }(n, i, r, s, l, h ? null : 20, c ? null : 20); n = g[0], i = g[1] } if (h && (n -= yV(h) ? u[0] / 2 : "right" === h ? u[0] : 0), c && (i -= yV(c) ? u[1] / 2 : "bottom" === c ? u[1] : 0), $z(t)) { g = function (t, e, n, i, r) { var o = n.getSize(), a = o[0], s = o[1]; return t = Math.min(t + a, i) - a, e = Math.min(e + s, r) - s, t = Math.max(t, 0), e = Math.max(e, 0), [t, e] }(n, i, r, s, l); n = g[0], i = g[1] } r.moveTo(n, i) }, e.prototype._updateContentNotChangedOnAxis = function (t, e) { var n = this._lastDataByCoordSys, i = this._cbParamsList, r = !!n && n.length === t.length; return r && E(n, (function (n, o) { var a = n.dataByAxis || [], s = (t[o] || {}).dataByAxis || []; (r = r && a.length === s.length) && E(a, (function (t, n) { var o = s[n] || {}, a = t.seriesDataIndices || [], l = o.seriesDataIndices || []; (r = r && t.value === o.value && t.axisType === o.axisType && t.axisId === o.axisId && a.length === l.length) && E(a, (function (t, e) { var n = l[e]; r = r && t.seriesIndex === n.seriesIndex && t.dataIndex === n.dataIndex })), i && E(t.seriesDataIndices, (function (t) { var n = t.seriesIndex, o = e[n], a = i[n]; o && a && a.data !== o.data && (r = !1) })) })) })), this._lastDataByCoordSys = t, this._cbParamsList = e, !!r }, e.prototype._hide = function (t) { this._lastDataByCoordSys = null, t({ type: "hideTip", from: this.uid }) }, e.prototype.dispose = function (t, e) { !r.node && e.getDom() && (Gg(this, "_updatePosition"), this._tooltipContent.dispose(), _N("itemTooltip", e)) }, e.type = "tooltip", e }(Tg); function fV(t, e, n) { var i, r = e.ecModel; n ? (i = new Mc(n, r, r), i = new Mc(e.option, i, r)) : i = e; for (var o = t.length - 1; o >= 0; o--) { var a = t[o]; a && (a instanceof Mc && (a = a.get("tooltip", !0)), U(a) && (a = { formatter: a }), a && (i = new Mc(a, i, r))) } return i } function gV(t, e) { return t.dispatchAction || W(e.dispatchAction, e) } function yV(t) { return "center" === t || "middle" === t } var vV = ["rect", "polygon", "keep", "clear"]; function mV(t, e) { var n = bo(t ? t.brush : []); if (n.length) { var i = []; E(n, (function (t) { var e = t.hasOwnProperty("toolbox") ? t.toolbox : []; e instanceof Array && (i = i.concat(e)) })); var r = t && t.toolbox; Y(r) && (r = r[0]), r || (r = { feature: {} }, t.toolbox = [r]); var o = r.feature || (r.feature = {}), a = o.brush || (o.brush = {}), s = a.type || (a.type = []); s.push.apply(s, i), function (t) { var e = {}; E(t, (function (t) { e[t] = 1 })), t.length = 0, E(e, (function (e, n) { t.push(n) })) }(s), e && !s.length && s.push.apply(s, vV) } } var xV = E; function _V(t) { if (t) for (var e in t) if (t.hasOwnProperty(e)) return !0 } function bV(t, e, n) { var i = {}; return xV(e, (function (e) { var r, o = i[e] = ((r = function () { }).prototype.__hidden = r.prototype, new r); xV(t[e], (function (t, i) { if (_D.isValidType(i)) { var r = { type: i, visual: t }; n && n(r, e), o[i] = new _D(r), "opacity" === i && ((r = T(r)).type = "colorAlpha", o.__hidden.__alphaForOpacity = new _D(r)) } })) })), i } function wV(t, e, n) { var i; E(n, (function (t) { e.hasOwnProperty(t) && _V(e[t]) && (i = !0) })), i && E(n, (function (n) { e.hasOwnProperty(n) && _V(e[n]) ? t[n] = T(e[n]) : delete t[n] })) } var SV = { lineX: MV(0), lineY: MV(1), rect: { point: function (t, e, n) { return t && n.boundingRect.contain(t[0], t[1]) }, rect: function (t, e, n) { return t && n.boundingRect.intersect(t) } }, polygon: { point: function (t, e, n) { return t && n.boundingRect.contain(t[0], t[1]) && A_(n.range, t[0], t[1]) }, rect: function (t, e, n) { var i = n.range; if (!t || i.length <= 1) return !1; var r = t.x, o = t.y, a = t.width, s = t.height, l = i[0]; return !!(A_(i, r, o) || A_(i, r + a, o) || A_(i, r, o + s) || A_(i, r + a, o + s) || ze.create(t).contain(l[0], l[1]) || Yh(r, o, r + a, o, i) || Yh(r, o, r, o + s, i) || Yh(r + a, o, r + a, o + s, i) || Yh(r, o + s, r + a, o + s, i)) || void 0 } } }; function MV(t) { var e = ["x", "y"], n = ["width", "height"]; return { point: function (e, n, i) { if (e) { var r = i.range; return IV(e[t], r) } }, rect: function (i, r, o) { if (i) { var a = o.range, s = [i[e[t]], i[e[t]] + i[n[t]]]; return s[1] < s[0] && s.reverse(), IV(s[0], a) || IV(s[1], a) || IV(a[0], s) || IV(a[1], s) } } } } function IV(t, e) { return e[0] <= t && t <= e[1] } var TV = ["inBrush", "outOfBrush"], CV = "__ecBrushSelect", DV = "__ecInBrushSelectEvent"; function AV(t) { t.eachComponent({ mainType: "brush" }, (function (e) { (e.brushTargetManager = new Pz(e.option, t)).setInputRanges(e.areas, t) })) } function kV(t, e, n) { var i, r, o = []; t.eachComponent({ mainType: "brush" }, (function (t) { n && "takeGlobalCursor" === n.type && t.setBrushOption("brush" === n.key ? n.brushOption : { brushType: !1 }) })), AV(t), t.eachComponent({ mainType: "brush" }, (function (e, n) { var a = { brushId: e.id, brushIndex: n, brushName: e.name, areas: T(e.areas), selected: [] }; o.push(a); var s = e.option, l = s.brushLink, u = [], h = [], c = [], p = !1; n || (i = s.throttleType, r = s.throttleDelay); var d = z(e.areas, (function (t) { var e = OV[t.brushType], n = k({ boundingRect: e ? e(t) : void 0 }, t); return n.selectors = function (t) { var e = t.brushType, n = { point: function (i) { return SV[e].point(i, n, t) }, rect: function (i) { return SV[e].rect(i, n, t) } }; return n }(n), n })), f = bV(e.option, TV, (function (t) { t.mappingMethod = "fixed" })); function g(t) { return "all" === l || !!u[t] } function y(t) { return !!t.length } Y(l) && E(l, (function (t) { u[t] = 1 })), t.eachSeries((function (n, i) { var r = c[i] = []; "parallel" === n.subType ? function (t, e) { var n = t.coordinateSystem; p = p || n.hasAxisBrushed(), g(e) && n.eachActiveState(t.getData(), (function (t, e) { "active" === t && (h[e] = 1) })) }(n, i) : function (n, i, r) { if (!n.brushSelector || function (t, e) { var n = t.option.seriesIndex; return null != n && "all" !== n && (Y(n) ? P(n, e) < 0 : e !== n) }(e, i)) return; if (E(d, (function (i) { e.brushTargetManager.controlSeries(i, n, t) && r.push(i), p = p || y(r) })), g(i) && y(r)) { var o = n.getData(); o.each((function (t) { PV(n, r, o, t) && (h[t] = 1) })) } }(n, i, r) })), t.eachSeries((function (t, e) { var n = { seriesId: t.id, seriesIndex: e, seriesName: t.name, dataIndex: [] }; a.selected.push(n); var i = c[e], r = t.getData(), o = g(e) ? function (t) { return h[t] ? (n.dataIndex.push(r.getRawIndex(t)), "inBrush") : "outOfBrush" } : function (e) { return PV(t, i, r, e) ? (n.dataIndex.push(r.getRawIndex(e)), "inBrush") : "outOfBrush" }; (g(e) ? p : y(i)) && function (t, e, n, i, r, o) { var a, s = {}; function l(t) { return Iy(n, a, t) } function u(t, e) { Cy(n, a, t, e) } function h(t, h) { a = null == o ? t : h; var c = n.getRawDataItem(a); if (!c || !1 !== c.visualMap) for (var p = i.call(r, t), d = e[p], f = s[p], g = 0, y = f.length; g < y; g++) { var v = f[g]; d[v] && d[v].applyVisual(t, l, u) } } E(t, (function (t) { var n = _D.prepareVisualTypes(e[t]); s[t] = n })), null == o ? n.each(h) : n.each([o], h) }(TV, f, r, o) })) })), function (t, e, n, i, r) { if (!r) return; var o = t.getZr(); if (o[DV]) return; o[CV] || (o[CV] = LV); var a = Fg(o, CV, n, e); a(t, i) }(e, i, r, o, n) } function LV(t, e) { if (!t.isDisposed()) { var n = t.getZr(); n[DV] = !0, t.dispatchAction({ type: "brushSelect", batch: e }), n[DV] = !1 } } function PV(t, e, n, i) { for (var r = 0, o = e.length; r < o; r++) { var a = e[r]; if (t.brushSelector(i, n, a.selectors, a)) return !0 } } var OV = { rect: function (t) { return RV(t.range) }, polygon: function (t) { for (var e, n = t.range, i = 0, r = n.length; i < r; i++) { e = e || [[1 / 0, -1 / 0], [1 / 0, -1 / 0]]; var o = n[i]; o[0] < e[0][0] && (e[0][0] = o[0]), o[0] > e[0][1] && (e[0][1] = o[0]), o[1] < e[1][0] && (e[1][0] = o[1]), o[1] > e[1][1] && (e[1][1] = o[1]) } return e && RV(e) } }; function RV(t) { return new ze(t[0][0], t[1][0], t[0][1] - t[0][0], t[1][1] - t[1][0]) } var NV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (t, e) { this.ecModel = t, this.api = e, this.model, (this._brushController = new Jk(e.getZr())).on("brush", W(this._onBrush, this)).mount() }, e.prototype.render = function (t, e, n, i) { this.model = t, this._updateController(t, e, n, i) }, e.prototype.updateTransform = function (t, e, n, i) { AV(e), this._updateController(t, e, n, i) }, e.prototype.updateVisual = function (t, e, n, i) { this.updateTransform(t, e, n, i) }, e.prototype.updateView = function (t, e, n, i) { this._updateController(t, e, n, i) }, e.prototype._updateController = function (t, e, n, i) { (!i || i.$from !== t.id) && this._brushController.setPanels(t.brushTargetManager.makePanelOpts(n)).enableBrush(t.brushOption).updateCovers(t.areas.slice()) }, e.prototype.dispose = function () { this._brushController.dispose() }, e.prototype._onBrush = function (t) { var e = this.model.id, n = this.model.brushTargetManager.setOutputRanges(t.areas, this.ecModel); (!t.isEnd || t.removeOnClick) && this.api.dispatchAction({ type: "brush", brushId: e, areas: T(n), $from: e }), t.isEnd && this.api.dispatchAction({ type: "brushEnd", brushId: e, areas: T(n), $from: e }) }, e.type = "brush", e }(Tg), EV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.areas = [], n.brushOption = {}, n } return n(e, t), e.prototype.optionUpdated = function (t, e) { var n = this.option; !e && wV(n, t, ["inBrush", "outOfBrush"]); var i = n.inBrush = n.inBrush || {}; n.outOfBrush = n.outOfBrush || { color: "#ddd" }, i.hasOwnProperty("liftZ") || (i.liftZ = 5) }, e.prototype.setAreas = function (t) { t && (this.areas = z(t, (function (t) { return zV(this.option, t) }), this)) }, e.prototype.setBrushOption = function (t) { this.brushOption = zV(this.option, t), this.brushType = this.brushOption.brushType }, e.type = "brush", e.dependencies = ["geo", "grid", "xAxis", "yAxis", "parallel", "series"], e.defaultOption = { seriesIndex: "all", brushType: "rect", brushMode: "single", transformable: !0, brushStyle: { borderWidth: 1, color: "rgba(210,219,238,0.3)", borderColor: "#D2DBEE" }, throttleType: "fixRate", throttleDelay: 0, removeOnClick: !0, z: 1e4 }, e }(Rp); function zV(t, e) { return C({ brushType: t.brushType, brushMode: t.brushMode, transformable: t.transformable, brushStyle: new Mc(t.brushStyle).getItemStyle(), removeOnClick: t.removeOnClick, z: t.z }, e, !0) } var VV = ["rect", "polygon", "lineX", "lineY", "keep", "clear"], BV = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.render = function (t, e, n) { var i, r, o; e.eachComponent({ mainType: "brush" }, (function (t) { i = t.brushType, r = t.brushOption.brushMode || "single", o = o || !!t.areas.length })), this._brushType = i, this._brushMode = r, E(t.get("type", !0), (function (e) { t.setIconStatus(e, ("keep" === e ? "multiple" === r : "clear" === e ? o : e === i) ? "emphasis" : "normal") })) }, e.prototype.updateView = function (t, e, n) { this.render(t, e, n) }, e.prototype.getIcons = function () { var t = this.model, e = t.get("icon", !0), n = {}; return E(t.get("type", !0), (function (t) { e[t] && (n[t] = e[t]) })), n }, e.prototype.onclick = function (t, e, n) { var i = this._brushType, r = this._brushMode; "clear" === n ? (e.dispatchAction({ type: "axisAreaSelect", intervals: [] }), e.dispatchAction({ type: "brush", command: "clear", areas: [] })) : e.dispatchAction({ type: "takeGlobalCursor", key: "brush", brushOption: { brushType: "keep" === n ? i : i !== n && n, brushMode: "keep" === n ? "multiple" === r ? "single" : "multiple" : r } }) }, e.getDefaultOption = function (t) { return { show: !0, type: VV.slice(), icon: { rect: "M7.3,34.7 M0.4,10V-0.2h9.8 M89.6,10V-0.2h-9.8 M0.4,60v10.2h9.8 M89.6,60v10.2h-9.8 M12.3,22.4V10.5h13.1 M33.6,10.5h7.8 M49.1,10.5h7.8 M77.5,22.4V10.5h-13 M12.3,31.1v8.2 M77.7,31.1v8.2 M12.3,47.6v11.9h13.1 M33.6,59.5h7.6 M49.1,59.5 h7.7 M77.5,47.6v11.9h-13", polygon: "M55.2,34.9c1.7,0,3.1,1.4,3.1,3.1s-1.4,3.1-3.1,3.1 s-3.1-1.4-3.1-3.1S53.5,34.9,55.2,34.9z M50.4,51c1.7,0,3.1,1.4,3.1,3.1c0,1.7-1.4,3.1-3.1,3.1c-1.7,0-3.1-1.4-3.1-3.1 C47.3,52.4,48.7,51,50.4,51z M55.6,37.1l1.5-7.8 M60.1,13.5l1.6-8.7l-7.8,4 M59,19l-1,5.3 M24,16.1l6.4,4.9l6.4-3.3 M48.5,11.6 l-5.9,3.1 M19.1,12.8L9.7,5.1l1.1,7.7 M13.4,29.8l1,7.3l6.6,1.6 M11.6,18.4l1,6.1 M32.8,41.9 M26.6,40.4 M27.3,40.2l6.1,1.6 M49.9,52.1l-5.6-7.6l-4.9-1.2", lineX: "M15.2,30 M19.7,15.6V1.9H29 M34.8,1.9H40.4 M55.3,15.6V1.9H45.9 M19.7,44.4V58.1H29 M34.8,58.1H40.4 M55.3,44.4 V58.1H45.9 M12.5,20.3l-9.4,9.6l9.6,9.8 M3.1,29.9h16.5 M62.5,20.3l9.4,9.6L62.3,39.7 M71.9,29.9H55.4", lineY: "M38.8,7.7 M52.7,12h13.2v9 M65.9,26.6V32 M52.7,46.3h13.2v-9 M24.9,12H11.8v9 M11.8,26.6V32 M24.9,46.3H11.8v-9 M48.2,5.1l-9.3-9l-9.4,9.2 M38.9-3.9V12 M48.2,53.3l-9.3,9l-9.4-9.2 M38.9,62.3V46.4", keep: "M4,10.5V1h10.3 M20.7,1h6.1 M33,1h6.1 M55.4,10.5V1H45.2 M4,17.3v6.6 M55.6,17.3v6.6 M4,30.5V40h10.3 M20.7,40 h6.1 M33,40h6.1 M55.4,30.5V40H45.2 M21,18.9h62.9v48.6H21V18.9z", clear: "M22,14.7l30.9,31 M52.9,14.7L22,45.7 M4.7,16.8V4.2h13.1 M26,4.2h7.8 M41.6,4.2h7.8 M70.3,16.8V4.2H57.2 M4.7,25.9v8.6 M70.3,25.9v8.6 M4.7,43.2v12.6h13.1 M26,55.8h7.8 M41.6,55.8h7.8 M70.3,43.2v12.6H57.2" }, title: t.getLocaleModel().get(["toolbox", "brush", "title"]) } }, e }(lz); var FV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.layoutMode = { type: "box", ignoreSize: !0 }, n } return n(e, t), e.type = "title", e.defaultOption = { z: 6, show: !0, text: "", target: "blank", subtext: "", subtarget: "blank", left: 0, top: 0, backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, padding: 5, itemGap: 10, textStyle: { fontSize: 18, fontWeight: "bold", color: "#464646" }, subtextStyle: { fontSize: 12, color: "#6E7079" } }, e }(Rp), GV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.render = function (t, e, n) { if (this.group.removeAll(), t.get("show")) { var i = this.group, r = t.getModel("textStyle"), o = t.getModel("subtextStyle"), a = t.get("textAlign"), s = rt(t.get("textBaseline"), t.get("textVerticalAlign")), l = new Fs({ style: nc(r, { text: t.get("text"), fill: r.getTextColor() }, { disableBox: !0 }), z2: 10 }), u = l.getBoundingRect(), h = t.get("subtext"), c = new Fs({ style: nc(o, { text: h, fill: o.getTextColor(), y: u.height + t.get("itemGap"), verticalAlign: "top" }, { disableBox: !0 }), z2: 10 }), p = t.get("link"), d = t.get("sublink"), f = t.get("triggerEvent", !0); l.silent = !p && !f, c.silent = !d && !f, p && l.on("click", (function () { bp(p, "_" + t.get("target")) })), d && c.on("click", (function () { bp(d, "_" + t.get("subtarget")) })), Qs(l).eventData = Qs(c).eventData = f ? { componentType: "title", componentIndex: t.componentIndex } : null, i.add(l), h && i.add(c); var g = i.getBoundingRect(), y = t.getBoxLayoutParams(); y.width = g.width, y.height = g.height; var v = Cp(y, { width: n.getWidth(), height: n.getHeight() }, t.get("padding")); a || ("middle" === (a = t.get("left") || t.get("right")) && (a = "center"), "right" === a ? v.x += v.width : "center" === a && (v.x += v.width / 2)), s || ("center" === (s = t.get("top") || t.get("bottom")) && (s = "middle"), "bottom" === s ? v.y += v.height : "middle" === s && (v.y += v.height / 2), s = s || "top"), i.x = v.x, i.y = v.y, i.markRedraw(); var m = { align: a, verticalAlign: s }; l.setStyle(m), c.setStyle(m), g = i.getBoundingRect(); var x = v.margin, _ = t.getItemStyle(["color", "opacity"]); _.fill = t.get("backgroundColor"); var b = new zs({ shape: { x: g.x - x[3], y: g.y - x[0], width: g.width + x[1] + x[3], height: g.height + x[0] + x[2], r: t.get("borderRadius") }, style: _, subPixelOptimize: !0, silent: !0 }); i.add(b) } }, e.type = "title", e }(Tg); var WV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.layoutMode = "box", n } return n(e, t), e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n), this._initData() }, e.prototype.mergeOption = function (e) { t.prototype.mergeOption.apply(this, arguments), this._initData() }, e.prototype.setCurrentIndex = function (t) { null == t && (t = this.option.currentIndex); var e = this._data.count(); this.option.loop ? t = (t % e + e) % e : (t >= e && (t = e - 1), t < 0 && (t = 0)), this.option.currentIndex = t }, e.prototype.getCurrentIndex = function () { return this.option.currentIndex }, e.prototype.isIndexMax = function () { return this.getCurrentIndex() >= this._data.count() - 1 }, e.prototype.setPlayState = function (t) { this.option.autoPlay = !!t }, e.prototype.getPlayState = function () { return !!this.option.autoPlay }, e.prototype._initData = function () { var t, e = this.option, n = e.data || [], i = e.axisType, r = this._names = []; "category" === i ? (t = [], E(n, (function (e, n) { var i, o = Ao(Mo(e), ""); q(e) ? (i = T(e)).value = n : i = n, t.push(i), r.push(o) }))) : t = n; var o = { category: "ordinal", time: "time", value: "number" }[i] || "number"; (this._data = new lx([{ name: "value", type: o }], this)).initData(t, r) }, e.prototype.getData = function () { return this._data }, e.prototype.getCategories = function () { if ("category" === this.get("axisType")) return this._names.slice() }, e.type = "timeline", e.defaultOption = { z: 4, show: !0, axisType: "time", realtime: !0, left: "20%", top: null, right: "20%", bottom: 0, width: null, height: 40, padding: 5, controlPosition: "left", autoPlay: !1, rewind: !1, loop: !0, playInterval: 2e3, currentIndex: 0, itemStyle: {}, label: { color: "#000" }, data: [] }, e }(Rp), HV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "timeline.slider", e.defaultOption = Cc(WV.defaultOption, { backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, orient: "horizontal", inverse: !1, tooltip: { trigger: "item" }, symbol: "circle", symbolSize: 12, lineStyle: { show: !0, width: 2, color: "#DAE1F5" }, label: { position: "auto", show: !0, interval: "auto", rotate: 0, color: "#A4B1D7" }, itemStyle: { color: "#A4B1D7", borderWidth: 1 }, checkpointStyle: { symbol: "circle", symbolSize: 15, color: "#316bf3", borderColor: "#fff", borderWidth: 2, shadowBlur: 2, shadowOffsetX: 1, shadowOffsetY: 1, shadowColor: "rgba(0, 0, 0, 0.3)", animation: !0, animationDuration: 300, animationEasing: "quinticInOut" }, controlStyle: { show: !0, showPlayBtn: !0, showPrevBtn: !0, showNextBtn: !0, itemSize: 24, itemGap: 12, position: "left", playIcon: "path://M31.6,53C17.5,53,6,41.5,6,27.4S17.5,1.8,31.6,1.8C45.7,1.8,57.2,13.3,57.2,27.4S45.7,53,31.6,53z M31.6,3.3 C18.4,3.3,7.5,14.1,7.5,27.4c0,13.3,10.8,24.1,24.1,24.1C44.9,51.5,55.7,40.7,55.7,27.4C55.7,14.1,44.9,3.3,31.6,3.3z M24.9,21.3 c0-2.2,1.6-3.1,3.5-2l10.5,6.1c1.899,1.1,1.899,2.9,0,4l-10.5,6.1c-1.9,1.1-3.5,0.2-3.5-2V21.3z", stopIcon: "path://M30.9,53.2C16.8,53.2,5.3,41.7,5.3,27.6S16.8,2,30.9,2C45,2,56.4,13.5,56.4,27.6S45,53.2,30.9,53.2z M30.9,3.5C17.6,3.5,6.8,14.4,6.8,27.6c0,13.3,10.8,24.1,24.101,24.1C44.2,51.7,55,40.9,55,27.6C54.9,14.4,44.1,3.5,30.9,3.5z M36.9,35.8c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H36c0.5,0,0.9,0.4,0.9,1V35.8z M27.8,35.8 c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H27c0.5,0,0.9,0.4,0.9,1L27.8,35.8L27.8,35.8z", nextIcon: "M2,18.5A1.52,1.52,0,0,1,.92,18a1.49,1.49,0,0,1,0-2.12L7.81,9.36,1,3.11A1.5,1.5,0,1,1,3,.89l8,7.34a1.48,1.48,0,0,1,.49,1.09,1.51,1.51,0,0,1-.46,1.1L3,18.08A1.5,1.5,0,0,1,2,18.5Z", prevIcon: "M10,.5A1.52,1.52,0,0,1,11.08,1a1.49,1.49,0,0,1,0,2.12L4.19,9.64,11,15.89a1.5,1.5,0,1,1-2,2.22L1,10.77A1.48,1.48,0,0,1,.5,9.68,1.51,1.51,0,0,1,1,8.58L9,.92A1.5,1.5,0,0,1,10,.5Z", prevBtnSize: 18, nextBtnSize: 18, color: "#A4B1D7", borderColor: "#A4B1D7", borderWidth: 1 }, emphasis: { label: { show: !0, color: "#6f778d" }, itemStyle: { color: "#316BF3" }, controlStyle: { color: "#316BF3", borderColor: "#316BF3", borderWidth: 2 } }, progress: { lineStyle: { color: "#316BF3" }, itemStyle: { color: "#316BF3" }, label: { color: "#6f778d" } }, data: [] }), e }(WV); R(HV, vf.prototype); var YV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "timeline", e }(Tg), XV = function (t) { function e(e, n, i, r) { var o = t.call(this, e, n, i) || this; return o.type = r || "value", o } return n(e, t), e.prototype.getLabelModel = function () { return this.model.getModel("label") }, e.prototype.isHorizontal = function () { return "horizontal" === this.model.get("orient") }, e }(nb), UV = Math.PI, ZV = Oo(), jV = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function (t, e) { this.api = e }, e.prototype.render = function (t, e, n) { if (this.model = t, this.api = n, this.ecModel = e, this.group.removeAll(), t.get("show", !0)) { var i = this._layout(t, n), r = this._createGroup("_mainGroup"), o = this._createGroup("_labelGroup"), a = this._axis = this._createAxis(i, t); t.formatTooltip = function (t) { return ng("nameValue", { noName: !0, value: a.scale.getLabel({ value: t }) }) }, E(["AxisLine", "AxisTick", "Control", "CurrentPointer"], (function (e) { this["_render" + e](i, r, a, t) }), this), this._renderAxisLabel(i, o, a, t), this._position(i, t) } this._doPlayStop(), this._updateTicksStatus() }, e.prototype.remove = function () { this._clearTimer(), this.group.removeAll() }, e.prototype.dispose = function () { this._clearTimer() }, e.prototype._layout = function (t, e) { var n, i, r, o, a = t.get(["label", "position"]), s = t.get("orient"), l = function (t, e) { return Cp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }, t.get("padding")) }(t, e), u = { horizontal: "center", vertical: (n = null == a || "auto" === a ? "horizontal" === s ? l.y + l.height / 2 < e.getHeight() / 2 ? "-" : "+" : l.x + l.width / 2 < e.getWidth() / 2 ? "+" : "-" : U(a) ? { horizontal: { top: "-", bottom: "+" }, vertical: { left: "-", right: "+" } }[s][a] : a) >= 0 || "+" === n ? "left" : "right" }, h = { horizontal: n >= 0 || "+" === n ? "top" : "bottom", vertical: "middle" }, c = { horizontal: 0, vertical: UV / 2 }, p = "vertical" === s ? l.height : l.width, d = t.getModel("controlStyle"), f = d.get("show", !0), g = f ? d.get("itemSize") : 0, y = f ? d.get("itemGap") : 0, v = g + y, m = t.get(["label", "rotate"]) || 0; m = m * UV / 180; var x = d.get("position", !0), _ = f && d.get("showPlayBtn", !0), b = f && d.get("showPrevBtn", !0), w = f && d.get("showNextBtn", !0), S = 0, M = p; "left" === x || "bottom" === x ? (_ && (i = [0, 0], S += v), b && (r = [S, 0], S += v), w && (o = [M - g, 0], M -= v)) : (_ && (i = [M - g, 0], M -= v), b && (r = [0, 0], S += v), w && (o = [M - g, 0], M -= v)); var I = [S, M]; return t.get("inverse") && I.reverse(), { viewRect: l, mainLength: p, orient: s, rotation: c[s], labelRotation: m, labelPosOpt: n, labelAlign: t.get(["label", "align"]) || u[s], labelBaseline: t.get(["label", "verticalAlign"]) || t.get(["label", "baseline"]) || h[s], playPosition: i, prevBtnPosition: r, nextBtnPosition: o, axisExtent: I, controlSize: g, controlGap: y } }, e.prototype._position = function (t, e) { var n = this._mainGroup, i = this._labelGroup, r = t.viewRect; if ("vertical" === t.orient) { var o = [1, 0, 0, 1, 0, 0], a = r.x, s = r.y + r.height; we(o, o, [-a, -s]), Se(o, o, -UV / 2), we(o, o, [a, s]), (r = r.clone()).applyTransform(o) } var l = y(r), u = y(n.getBoundingRect()), h = y(i.getBoundingRect()), c = [n.x, n.y], p = [i.x, i.y]; p[0] = c[0] = l[0][0]; var d, f = t.labelPosOpt; null == f || U(f) ? (v(c, u, l, 1, d = "+" === f ? 0 : 1), v(p, h, l, 1, 1 - d)) : (v(c, u, l, 1, d = f >= 0 ? 0 : 1), p[1] = c[1] + f); function g(t) { t.originX = l[0][0] - t.x, t.originY = l[1][0] - t.y } function y(t) { return [[t.x, t.x + t.width], [t.y, t.y + t.height]] } function v(t, e, n, i, r) { t[i] += n[i][r] - e[i][r] } n.setPosition(c), i.setPosition(p), n.rotation = i.rotation = t.rotation, g(n), g(i) }, e.prototype._createAxis = function (t, e) { var n = e.getData(), i = e.get("axisType"), r = function (t, e) { if (e = e || t.get("type"), e) switch (e) { case "category": return new Lx({ ordinalMeta: t.getCategories(), extent: [1 / 0, -1 / 0] }); case "time": return new Zx({ locale: t.ecModel.getLocaleModel(), useUTC: t.ecModel.get("useUTC") }); default: return new Ox } }(e, i); r.getTicks = function () { return n.mapArray(["value"], (function (t) { return { value: t } })) }; var o = n.getDataExtent("value"); r.setExtent(o[0], o[1]), r.calcNiceTicks(); var a = new XV("value", r, t.axisExtent, i); return a.model = e, a }, e.prototype._createGroup = function (t) { var e = this[t] = new zr; return this.group.add(e), e }, e.prototype._renderAxisLine = function (t, e, n, i) { var r = n.getExtent(); if (i.get(["lineStyle", "show"])) { var o = new Zu({ shape: { x1: r[0], y1: 0, x2: r[1], y2: 0 }, style: A({ lineCap: "round" }, i.getModel("lineStyle").getLineStyle()), silent: !0, z2: 1 }); e.add(o); var a = this._progressLine = new Zu({ shape: { x1: r[0], x2: this._currentPointer ? this._currentPointer.x : r[0], y1: 0, y2: 0 }, style: k({ lineCap: "round", lineWidth: o.style.lineWidth }, i.getModel(["progress", "lineStyle"]).getLineStyle()), silent: !0, z2: 1 }); e.add(a) } }, e.prototype._renderAxisTick = function (t, e, n, i) { var r = this, o = i.getData(), a = n.scale.getTicks(); this._tickSymbols = [], E(a, (function (t) { var a = n.dataToCoord(t.value), s = o.getItemModel(t.value), l = s.getModel("itemStyle"), u = s.getModel(["emphasis", "itemStyle"]), h = s.getModel(["progress", "itemStyle"]), c = { x: a, y: 0, onclick: W(r._changeTimeline, r, t.value) }, p = qV(s, l, e, c); p.ensureState("emphasis").style = u.getItemStyle(), p.ensureState("progress").style = h.getItemStyle(), Hl(p); var d = Qs(p); s.get("tooltip") ? (d.dataIndex = t.value, d.dataModel = i) : d.dataIndex = d.dataModel = null, r._tickSymbols.push(p) })) }, e.prototype._renderAxisLabel = function (t, e, n, i) { var r = this; if (n.getLabelModel().get("show")) { var o = i.getData(), a = n.getViewLabels(); this._tickLabels = [], E(a, (function (i) { var a = i.tickValue, s = o.getItemModel(a), l = s.getModel("label"), u = s.getModel(["emphasis", "label"]), h = s.getModel(["progress", "label"]), c = n.dataToCoord(i.tickValue), p = new Fs({ x: c, y: 0, rotation: t.labelRotation - t.rotation, onclick: W(r._changeTimeline, r, a), silent: !1, style: nc(l, { text: i.formattedLabel, align: t.labelAlign, verticalAlign: t.labelBaseline }) }); p.ensureState("emphasis").style = nc(u), p.ensureState("progress").style = nc(h), e.add(p), Hl(p), ZV(p).dataIndex = a, r._tickLabels.push(p) })) } }, e.prototype._renderControl = function (t, e, n, i) { var r = t.controlSize, o = t.rotation, a = i.getModel("controlStyle").getItemStyle(), s = i.getModel(["emphasis", "controlStyle"]).getItemStyle(), l = i.getPlayState(), u = i.get("inverse", !0); function h(t, n, l, u) { if (t) { var h = Ir(rt(i.get(["controlStyle", n + "BtnSize"]), r), r), c = function (t, e, n, i) { var r = i.style, o = Hh(t.get(["controlStyle", e]), i || {}, new ze(n[0], n[1], n[2], n[3])); r && o.setStyle(r); return o }(i, n + "Icon", [0, -h / 2, h, h], { x: t[0], y: t[1], originX: r / 2, originY: 0, rotation: u ? -o : 0, rectHover: !0, style: a, onclick: l }); c.ensureState("emphasis").style = s, e.add(c), Hl(c) } } h(t.nextBtnPosition, "next", W(this._changeTimeline, this, u ? "-" : "+")), h(t.prevBtnPosition, "prev", W(this._changeTimeline, this, u ? "+" : "-")), h(t.playPosition, l ? "stop" : "play", W(this._handlePlayClick, this, !l), !0) }, e.prototype._renderCurrentPointer = function (t, e, n, i) { var r = i.getData(), o = i.getCurrentIndex(), a = r.getItemModel(o).getModel("checkpointStyle"), s = this, l = { onCreate: function (t) { t.draggable = !0, t.drift = W(s._handlePointerDrag, s), t.ondragend = W(s._handlePointerDragend, s), KV(t, s._progressLine, o, n, i, !0) }, onUpdate: function (t) { KV(t, s._progressLine, o, n, i) } }; this._currentPointer = qV(a, a, this._mainGroup, {}, this._currentPointer, l) }, e.prototype._handlePlayClick = function (t) { this._clearTimer(), this.api.dispatchAction({ type: "timelinePlayChange", playState: t, from: this.uid }) }, e.prototype._handlePointerDrag = function (t, e, n) { this._clearTimer(), this._pointerChangeTimeline([n.offsetX, n.offsetY]) }, e.prototype._handlePointerDragend = function (t) { this._pointerChangeTimeline([t.offsetX, t.offsetY], !0) }, e.prototype._pointerChangeTimeline = function (t, e) { var n = this._toAxisCoord(t)[0], i = jr(this._axis.getExtent().slice()); n > i[1] && (n = i[1]), n < i[0] && (n = i[0]), this._currentPointer.x = n, this._currentPointer.markRedraw(); var r = this._progressLine; r && (r.shape.x2 = n, r.dirty()); var o = this._findNearestTick(n), a = this.model; (e || o !== a.getCurrentIndex() && a.get("realtime")) && this._changeTimeline(o) }, e.prototype._doPlayStop = function () { var t = this; this._clearTimer(), this.model.getPlayState() && (this._timer = setTimeout((function () { var e = t.model; t._changeTimeline(e.getCurrentIndex() + (e.get("rewind", !0) ? -1 : 1)) }), this.model.get("playInterval"))) }, e.prototype._toAxisCoord = function (t) { return zh(t, this._mainGroup.getLocalTransform(), !0) }, e.prototype._findNearestTick = function (t) { var e, n = this.model.getData(), i = 1 / 0, r = this._axis; return n.each(["value"], (function (n, o) { var a = r.dataToCoord(n), s = Math.abs(a - t); s < i && (i = s, e = o) })), e }, e.prototype._clearTimer = function () { this._timer && (clearTimeout(this._timer), this._timer = null) }, e.prototype._changeTimeline = function (t) { var e = this.model.getCurrentIndex(); "+" === t ? t = e + 1 : "-" === t && (t = e - 1), this.api.dispatchAction({ type: "timelineChange", currentIndex: t, from: this.uid }) }, e.prototype._updateTicksStatus = function () { var t = this.model.getCurrentIndex(), e = this._tickSymbols, n = this._tickLabels; if (e) for (var i = 0; i < e.length; i++)e && e[i] && e[i].toggleState("progress", i < t); if (n) for (i = 0; i < n.length; i++)n && n[i] && n[i].toggleState("progress", ZV(n[i]).dataIndex <= t) }, e.type = "timeline.slider", e }(YV); function qV(t, e, n, i, r, o) { var a = e.get("color"); r ? (r.setColor(a), n.add(r), o && o.onUpdate(r)) : ((r = Wy(t.get("symbol"), -1, -1, 2, 2, a)).setStyle("strokeNoScale", !0), n.add(r), o && o.onCreate(r)); var s = e.getItemStyle(["color"]); r.setStyle(s), i = C({ rectHover: !0, z2: 100 }, i, !0); var l = Hy(t.get("symbolSize")); i.scaleX = l[0] / 2, i.scaleY = l[1] / 2; var u = Yy(t.get("symbolOffset"), l); u && (i.x = (i.x || 0) + u[0], i.y = (i.y || 0) + u[1]); var h = t.get("symbolRotate"); return i.rotation = (h || 0) * Math.PI / 180 || 0, r.attr(i), r.updateTransform(), r } function KV(t, e, n, i, r, o) { if (!t.dragging) { var a = r.getModel("checkpointStyle"), s = i.dataToCoord(r.getData().get("value", n)); if (o || !a.get("animation", !0)) t.attr({ x: s, y: 0 }), e && e.attr({ shape: { x2: s } }); else { var l = { duration: a.get("animationDuration", !0), easing: a.get("animationEasing", !0) }; t.stopAnimation(null, !0), t.animateTo({ x: s, y: 0 }, l), e && e.animateTo({ shape: { x2: s } }, l) } } } function $V(t) { var e = t && t.timeline; Y(e) || (e = e ? [e] : []), E(e, (function (t) { t && function (t) { var e = t.type, n = { number: "value", time: "time" }; n[e] && (t.axisType = n[e], delete t.type); if (JV(t), QV(t, "controlPosition")) { var i = t.controlStyle || (t.controlStyle = {}); QV(i, "position") || (i.position = t.controlPosition), "none" !== i.position || QV(i, "show") || (i.show = !1, delete i.position), delete t.controlPosition } E(t.data || [], (function (t) { q(t) && !Y(t) && (!QV(t, "value") && QV(t, "name") && (t.value = t.name), JV(t)) })) }(t) })) } function JV(t) { var e = t.itemStyle || (t.itemStyle = {}), n = e.emphasis || (e.emphasis = {}), i = t.label || t.label || {}, r = i.normal || (i.normal = {}), o = { normal: 1, emphasis: 1 }; E(i, (function (t, e) { o[e] || QV(r, e) || (r[e] = t) })), n.label && !QV(i, "emphasis") && (i.emphasis = n.label, delete n.label) } function QV(t, e) { return t.hasOwnProperty(e) } function tB(t, e) { if (!t) return !1; for (var n = Y(t) ? t : [t], i = 0; i < n.length; i++)if (n[i] && n[i][e]) return !0; return !1 } function eB(t) { wo(t, "label", ["show"]) } var nB = Oo(), iB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.createdBySelf = !1, n } return n(e, t), e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n), this._mergeOption(t, n, !1, !0) }, e.prototype.isAnimationEnabled = function () { if (r.node) return !1; var t = this.__hostSeries; return this.getShallow("animation") && t && t.isAnimationEnabled() }, e.prototype.mergeOption = function (t, e) { this._mergeOption(t, e, !1, !1) }, e.prototype._mergeOption = function (t, e, n, i) { var r = this.mainType; n || e.eachSeries((function (t) { var n = t.get(this.mainType, !0), o = nB(t)[r]; n && n.data ? (o ? o._mergeOption(n, e, !0) : (i && eB(n), E(n.data, (function (t) { t instanceof Array ? (eB(t[0]), eB(t[1])) : eB(t) })), A(o = this.createMarkerModelFromSeries(n, this, e), { mainType: this.mainType, seriesIndex: t.seriesIndex, name: t.name, createdBySelf: !0 }), o.__hostSeries = t), nB(t)[r] = o) : nB(t)[r] = null }), this) }, e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(), r = this.getRawValue(t), o = i.getName(t); return ng("section", { header: this.name, blocks: [ng("nameValue", { name: o, value: r, noName: !o, noValue: null == r })] }) }, e.prototype.getData = function () { return this._data }, e.prototype.setData = function (t) { this._data = t }, e.getMarkerModelFromSeries = function (t, e) { return nB(t)[e] }, e.type = "marker", e.dependencies = ["series", "grid", "polar", "geo"], e }(Rp); R(iB, vf.prototype); var rB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.createMarkerModelFromSeries = function (t, n, i) { return new e(t, n, i) }, e.type = "markPoint", e.defaultOption = { z: 5, symbol: "pin", symbolSize: 50, tooltip: { trigger: "item" }, label: { show: !0, position: "inside" }, itemStyle: { borderWidth: 2 }, emphasis: { label: { show: !0 } } }, e }(iB); function oB(t) { return !(isNaN(parseFloat(t.x)) && isNaN(parseFloat(t.y))) } function aB(t, e, n, i, r, o) { var a = [], s = gx(e, i) ? e.getCalculationInfo("stackResultDimension") : i, l = pB(e, s, t), u = e.indicesOfNearest(s, l)[0]; a[r] = e.get(n, u), a[o] = e.get(s, u); var h = e.get(i, u), c = qr(e.get(i, u)); return (c = Math.min(c, 20)) >= 0 && (a[o] = +a[o].toFixed(c)), [a, h] } var sB = { min: H(aB, "min"), max: H(aB, "max"), average: H(aB, "average"), median: H(aB, "median") }; function lB(t, e) { if (e) { var n = t.getData(), i = t.coordinateSystem, r = i && i.dimensions; if (!function (t) { return !isNaN(parseFloat(t.x)) && !isNaN(parseFloat(t.y)) }(e) && !Y(e.coord) && Y(r)) { var o = uB(e, n, i, t); if ((e = T(e)).type && sB[e.type] && o.baseAxis && o.valueAxis) { var a = P(r, o.baseAxis.dim), s = P(r, o.valueAxis.dim), l = sB[e.type](n, o.baseDataDim, o.valueDataDim, a, s); e.coord = l[0], e.value = l[1] } else e.coord = [null != e.xAxis ? e.xAxis : e.radiusAxis, null != e.yAxis ? e.yAxis : e.angleAxis] } if (null != e.coord && Y(r)) for (var u = e.coord, h = 0; h < 2; h++)sB[u[h]] && (u[h] = pB(n, n.mapDimension(r[h]), u[h])); else e.coord = []; return e } } function uB(t, e, n, i) { var r = {}; return null != t.valueIndex || null != t.valueDim ? (r.valueDataDim = null != t.valueIndex ? e.getDimension(t.valueIndex) : t.valueDim, r.valueAxis = n.getAxis(function (t, e) { var n = t.getData().getDimensionInfo(e); return n && n.coordDim }(i, r.valueDataDim)), r.baseAxis = n.getOtherAxis(r.valueAxis), r.baseDataDim = e.mapDimension(r.baseAxis.dim)) : (r.baseAxis = i.getBaseAxis(), r.valueAxis = n.getOtherAxis(r.baseAxis), r.baseDataDim = e.mapDimension(r.baseAxis.dim), r.valueDataDim = e.mapDimension(r.valueAxis.dim)), r } function hB(t, e) { return !(t && t.containData && e.coord && !oB(e)) || t.containData(e.coord) } function cB(t, e) { return t ? function (t, n, i, r) { return wf(r < 2 ? t.coord && t.coord[r] : t.value, e[r]) } : function (t, n, i, r) { return wf(t.value, e[r]) } } function pB(t, e, n) { if ("average" === n) { var i = 0, r = 0; return t.each(e, (function (t, e) { isNaN(t) || (i += t, r++) })), i / r } return "median" === n ? t.getMedian(e) : t.getDataExtent(e)["max" === n ? 1 : 0] } var dB = Oo(), fB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.init = function () { this.markerGroupMap = yt() }, e.prototype.render = function (t, e, n) { var i = this, r = this.markerGroupMap; r.each((function (t) { dB(t).keep = !1 })), e.eachSeries((function (t) { var r = iB.getMarkerModelFromSeries(t, i.type); r && i.renderSeries(t, r, e, n) })), r.each((function (t) { !dB(t).keep && i.group.remove(t.group) })) }, e.prototype.markKeep = function (t) { dB(t).keep = !0 }, e.prototype.toggleBlurSeries = function (t, e) { var n = this; E(t, (function (t) { var i = iB.getMarkerModelFromSeries(t, n.type); i && i.getData().eachItemGraphicEl((function (t) { t && (e ? Pl(t) : Ol(t)) })) })) }, e.type = "marker", e }(Tg); function gB(t, e, n) { var i = e.coordinateSystem; t.each((function (r) { var o, a = t.getItemModel(r), s = Ur(a.get("x"), n.getWidth()), l = Ur(a.get("y"), n.getHeight()); if (isNaN(s) || isNaN(l)) { if (e.getMarkerPosition) o = e.getMarkerPosition(t.getValues(t.dimensions, r)); else if (i) { var u = t.get(i.dimensions[0], r), h = t.get(i.dimensions[1], r); o = i.dataToPoint([u, h]) } } else o = [s, l]; isNaN(s) || (o[0] = s), isNaN(l) || (o[1] = l), t.setItemLayout(r, o) })) } var yB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.updateTransform = function (t, e, n) { e.eachSeries((function (t) { var e = iB.getMarkerModelFromSeries(t, "markPoint"); e && (gB(e.getData(), t, n), this.markerGroupMap.get(t.id).updateLayout()) }), this) }, e.prototype.renderSeries = function (t, e, n, i) { var r = t.coordinateSystem, o = t.id, a = t.getData(), s = this.markerGroupMap, l = s.get(o) || s.set(o, new hS), u = function (t, e, n) { var i; i = t ? z(t && t.dimensions, (function (t) { return A(A({}, e.getData().getDimensionInfo(e.getData().mapDimension(t)) || {}), { name: t, ordinalMeta: null }) })) : [{ name: "value", type: "float" }]; var r = new lx(i, n), o = z(n.get("data"), H(lB, e)); t && (o = B(o, H(hB, t))); var a = cB(!!t, i); return r.initData(o, null, a), r }(r, t, e); e.setData(u), gB(e.getData(), t, i), u.each((function (t) { var n = u.getItemModel(t), i = n.getShallow("symbol"), r = n.getShallow("symbolSize"), o = n.getShallow("symbolRotate"), s = n.getShallow("symbolOffset"), l = n.getShallow("symbolKeepAspect"); if (X(i) || X(r) || X(o) || X(s)) { var h = e.getRawValue(t), c = e.getDataParams(t); X(i) && (i = i(h, c)), X(r) && (r = r(h, c)), X(o) && (o = o(h, c)), X(s) && (s = s(h, c)) } var p = n.getModel("itemStyle").getItemStyle(), d = Ty(a, "color"); p.fill || (p.fill = d), u.setItemVisual(t, { symbol: i, symbolSize: r, symbolRotate: o, symbolOffset: s, symbolKeepAspect: l, style: p }) })), l.updateData(u), this.group.add(l.group), u.eachItemGraphicEl((function (t) { t.traverse((function (t) { Qs(t).dataModel = e })) })), this.markKeep(l), l.group.silent = e.get("silent") || t.get("silent") }, e.type = "markPoint", e }(fB); var vB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.createMarkerModelFromSeries = function (t, n, i) { return new e(t, n, i) }, e.type = "markLine", e.defaultOption = { z: 5, symbol: ["circle", "arrow"], symbolSize: [8, 16], symbolOffset: 0, precision: 2, tooltip: { trigger: "item" }, label: { show: !0, position: "end", distance: 5 }, lineStyle: { type: "dashed" }, emphasis: { label: { show: !0 }, lineStyle: { width: 3 } }, animationEasing: "linear" }, e }(iB), mB = Oo(), xB = function (t, e, n, i) { var r, o = t.getData(); if (Y(i)) r = i; else { var a = i.type; if ("min" === a || "max" === a || "average" === a || "median" === a || null != i.xAxis || null != i.yAxis) { var s = void 0, l = void 0; if (null != i.yAxis || null != i.xAxis) s = e.getAxis(null != i.yAxis ? "y" : "x"), l = it(i.yAxis, i.xAxis); else { var u = uB(i, o, e, t); s = u.valueAxis, l = pB(o, yx(o, u.valueDataDim), a) } var h = "x" === s.dim ? 0 : 1, c = 1 - h, p = T(i), d = { coord: [] }; p.type = null, p.coord = [], p.coord[c] = -1 / 0, d.coord[c] = 1 / 0; var f = n.get("precision"); f >= 0 && j(l) && (l = +l.toFixed(Math.min(f, 20))), p.coord[h] = d.coord[h] = l, r = [p, d, { type: a, valueIndex: i.valueIndex, value: l }] } else r = [] } var g = [lB(t, r[0]), lB(t, r[1]), A({}, r[2])]; return g[2].type = g[2].type || null, C(g[2], g[0]), C(g[2], g[1]), g }; function _B(t) { return !isNaN(t) && !isFinite(t) } function bB(t, e, n, i) { var r = 1 - t, o = i.dimensions[t]; return _B(e[r]) && _B(n[r]) && e[t] === n[t] && i.getAxis(o).containData(e[t]) } function wB(t, e) { if ("cartesian2d" === t.type) { var n = e[0].coord, i = e[1].coord; if (n && i && (bB(1, n, i, t) || bB(0, n, i, t))) return !0 } return hB(t, e[0]) && hB(t, e[1]) } function SB(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = Ur(s.get("x"), r.getWidth()), u = Ur(s.get("y"), r.getHeight()); if (isNaN(l) || isNaN(u)) { if (i.getMarkerPosition) o = i.getMarkerPosition(t.getValues(t.dimensions, e)); else { var h = a.dimensions, c = t.get(h[0], e), p = t.get(h[1], e); o = a.dataToPoint([c, p]) } if (MS(a, "cartesian2d")) { var d = a.getAxis("x"), f = a.getAxis("y"); h = a.dimensions; _B(t.get(h[0], e)) ? o[0] = d.toGlobalCoord(d.getExtent()[n ? 0 : 1]) : _B(t.get(h[1], e)) && (o[1] = f.toGlobalCoord(f.getExtent()[n ? 0 : 1])) } isNaN(l) || (o[0] = l), isNaN(u) || (o[1] = u) } else o = [l, u]; t.setItemLayout(e, o) } var MB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.updateTransform = function (t, e, n) { e.eachSeries((function (t) { var e = iB.getMarkerModelFromSeries(t, "markLine"); if (e) { var i = e.getData(), r = mB(e).from, o = mB(e).to; r.each((function (e) { SB(r, e, !0, t, n), SB(o, e, !1, t, n) })), i.each((function (t) { i.setItemLayout(t, [r.getItemLayout(t), o.getItemLayout(t)]) })), this.markerGroupMap.get(t.id).updateLayout() } }), this) }, e.prototype.renderSeries = function (t, e, n, i) { var r = t.coordinateSystem, o = t.id, a = t.getData(), s = this.markerGroupMap, l = s.get(o) || s.set(o, new RA); this.group.add(l.group); var u = function (t, e, n) { var i; i = t ? z(t && t.dimensions, (function (t) { return A(A({}, e.getData().getDimensionInfo(e.getData().mapDimension(t)) || {}), { name: t, ordinalMeta: null }) })) : [{ name: "value", type: "float" }]; var r = new lx(i, n), o = new lx(i, n), a = new lx([], n), s = z(n.get("data"), H(xB, e, t, n)); t && (s = B(s, H(wB, t))); var l = cB(!!t, i); return r.initData(z(s, (function (t) { return t[0] })), null, l), o.initData(z(s, (function (t) { return t[1] })), null, l), a.initData(z(s, (function (t) { return t[2] }))), a.hasItemOption = !0, { from: r, to: o, line: a } }(r, t, e), h = u.from, c = u.to, p = u.line; mB(e).from = h, mB(e).to = c, e.setData(p); var d = e.get("symbol"), f = e.get("symbolSize"), g = e.get("symbolRotate"), y = e.get("symbolOffset"); function v(e, n, r) { var o = e.getItemModel(n); SB(e, n, r, t, i); var s = o.getModel("itemStyle").getItemStyle(); null == s.fill && (s.fill = Ty(a, "color")), e.setItemVisual(n, { symbolKeepAspect: o.get("symbolKeepAspect"), symbolOffset: rt(o.get("symbolOffset", !0), y[r ? 0 : 1]), symbolRotate: rt(o.get("symbolRotate", !0), g[r ? 0 : 1]), symbolSize: rt(o.get("symbolSize"), f[r ? 0 : 1]), symbol: rt(o.get("symbol", !0), d[r ? 0 : 1]), style: s }) } Y(d) || (d = [d, d]), Y(f) || (f = [f, f]), Y(g) || (g = [g, g]), Y(y) || (y = [y, y]), u.from.each((function (t) { v(h, t, !0), v(c, t, !1) })), p.each((function (t) { var e = p.getItemModel(t).getModel("lineStyle").getLineStyle(); p.setItemLayout(t, [h.getItemLayout(t), c.getItemLayout(t)]), null == e.stroke && (e.stroke = h.getItemVisual(t, "style").fill), p.setItemVisual(t, { fromSymbolKeepAspect: h.getItemVisual(t, "symbolKeepAspect"), fromSymbolOffset: h.getItemVisual(t, "symbolOffset"), fromSymbolRotate: h.getItemVisual(t, "symbolRotate"), fromSymbolSize: h.getItemVisual(t, "symbolSize"), fromSymbol: h.getItemVisual(t, "symbol"), toSymbolKeepAspect: c.getItemVisual(t, "symbolKeepAspect"), toSymbolOffset: c.getItemVisual(t, "symbolOffset"), toSymbolRotate: c.getItemVisual(t, "symbolRotate"), toSymbolSize: c.getItemVisual(t, "symbolSize"), toSymbol: c.getItemVisual(t, "symbol"), style: e }) })), l.updateData(p), u.line.eachItemGraphicEl((function (t) { Qs(t).dataModel = e, t.traverse((function (t) { Qs(t).dataModel = e })) })), this.markKeep(l), l.group.silent = e.get("silent") || t.get("silent") }, e.type = "markLine", e }(fB); var IB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.createMarkerModelFromSeries = function (t, n, i) { return new e(t, n, i) }, e.type = "markArea", e.defaultOption = { z: 1, tooltip: { trigger: "item" }, animation: !1, label: { show: !0, position: "top" }, itemStyle: { borderWidth: 0 }, emphasis: { label: { show: !0, position: "top" } } }, e }(iB), TB = Oo(), CB = function (t, e, n, i) { var r = i[0], o = i[1]; if (r && o) { var a = lB(t, r), s = lB(t, o), l = a.coord, u = s.coord; l[0] = it(l[0], -1 / 0), l[1] = it(l[1], -1 / 0), u[0] = it(u[0], 1 / 0), u[1] = it(u[1], 1 / 0); var h = D([{}, a, s]); return h.coord = [a.coord, s.coord], h.x0 = a.x, h.y0 = a.y, h.x1 = s.x, h.y1 = s.y, h } }; function DB(t) { return !isNaN(t) && !isFinite(t) } function AB(t, e, n, i) { var r = 1 - t; return DB(e[r]) && DB(n[r]) } function kB(t, e) { var n = e.coord[0], i = e.coord[1], r = { coord: n, x: e.x0, y: e.y0 }, o = { coord: i, x: e.x1, y: e.y1 }; return MS(t, "cartesian2d") ? !(!n || !i || !AB(1, n, i) && !AB(0, n, i)) || function (t, e, n) { return !(t && t.containZone && e.coord && n.coord && !oB(e) && !oB(n)) || t.containZone(e.coord, n.coord) }(t, r, o) : hB(t, r) || hB(t, o) } function LB(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = Ur(s.get(n[0]), r.getWidth()), u = Ur(s.get(n[1]), r.getHeight()); if (isNaN(l) || isNaN(u)) { if (i.getMarkerPosition) { var h = t.getValues(["x0", "y0"], e), c = t.getValues(["x1", "y1"], e), p = a.clampData(h), d = a.clampData(c), f = []; "x0" === n[0] ? f[0] = p[0] > d[0] ? c[0] : h[0] : f[0] = p[0] > d[0] ? h[0] : c[0], "y0" === n[1] ? f[1] = p[1] > d[1] ? c[1] : h[1] : f[1] = p[1] > d[1] ? h[1] : c[1], o = i.getMarkerPosition(f, n, !0) } else { var g = [m = t.get(n[0], e), x = t.get(n[1], e)]; a.clampData && a.clampData(g, g), o = a.dataToPoint(g, !0) } if (MS(a, "cartesian2d")) { var y = a.getAxis("x"), v = a.getAxis("y"), m = t.get(n[0], e), x = t.get(n[1], e); DB(m) ? o[0] = y.toGlobalCoord(y.getExtent()["x0" === n[0] ? 0 : 1]) : DB(x) && (o[1] = v.toGlobalCoord(v.getExtent()["y0" === n[1] ? 0 : 1])) } isNaN(l) || (o[0] = l), isNaN(u) || (o[1] = u) } else o = [l, u]; return o } var PB = [["x0", "y0"], ["x1", "y0"], ["x1", "y1"], ["x0", "y1"]], OB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.updateTransform = function (t, e, n) { e.eachSeries((function (t) { var e = iB.getMarkerModelFromSeries(t, "markArea"); if (e) { var i = e.getData(); i.each((function (e) { var r = z(PB, (function (r) { return LB(i, e, r, t, n) })); i.setItemLayout(e, r), i.getItemGraphicEl(e).setShape("points", r) })) } }), this) }, e.prototype.renderSeries = function (t, e, n, i) { var r = t.coordinateSystem, o = t.id, a = t.getData(), s = this.markerGroupMap, l = s.get(o) || s.set(o, { group: new zr }); this.group.add(l.group), this.markKeep(l); var u = function (t, e, n) { var i, r, o = ["x0", "y0", "x1", "y1"]; if (t) { var a = z(t && t.dimensions, (function (t) { var n = e.getData(); return A(A({}, n.getDimensionInfo(n.mapDimension(t)) || {}), { name: t, ordinalMeta: null }) })); r = z(o, (function (t, e) { return { name: t, type: a[e % 2].type } })), i = new lx(r, n) } else i = new lx(r = [{ name: "value", type: "float" }], n); var s = z(n.get("data"), H(CB, e, t, n)); t && (s = B(s, H(kB, t))); var l = t ? function (t, e, n, i) { return wf(t.coord[Math.floor(i / 2)][i % 2], r[i]) } : function (t, e, n, i) { return wf(t.value, r[i]) }; return i.initData(s, null, l), i.hasItemOption = !0, i }(r, t, e); e.setData(u), u.each((function (e) { var n = z(PB, (function (n) { return LB(u, e, n, t, i) })), o = r.getAxis("x").scale, s = r.getAxis("y").scale, l = o.getExtent(), h = s.getExtent(), c = [o.parse(u.get("x0", e)), o.parse(u.get("x1", e))], p = [s.parse(u.get("y0", e)), s.parse(u.get("y1", e))]; jr(c), jr(p); var d = !!(l[0] > c[1] || l[1] < c[0] || h[0] > p[1] || h[1] < p[0]); u.setItemLayout(e, { points: n, allClipped: d }); var f = u.getItemModel(e).getModel("itemStyle").getItemStyle(), g = Ty(a, "color"); f.fill || (f.fill = g, U(f.fill) && (f.fill = ii(f.fill, .4))), f.stroke || (f.stroke = g), u.setItemVisual(e, "style", f) })), u.diff(TB(l).data).add((function (t) { var e = u.getItemLayout(t); if (!e.allClipped) { var n = new Wu({ shape: { points: e.points } }); u.setItemGraphicEl(t, n), l.group.add(n) } })).update((function (t, n) { var i = TB(l).data.getItemGraphicEl(n), r = u.getItemLayout(t); r.allClipped ? i && l.group.remove(i) : (i ? fh(i, { shape: { points: r.points } }, e, t) : i = new Wu({ shape: { points: r.points } }), u.setItemGraphicEl(t, i), l.group.add(i)) })).remove((function (t) { var e = TB(l).data.getItemGraphicEl(t); l.group.remove(e) })).execute(), u.eachItemGraphicEl((function (t, n) { var i = u.getItemModel(n), r = u.getItemVisual(n, "style"); t.useStyle(u.getItemVisual(n, "style")), tc(t, ec(i), { labelFetcher: e, labelDataIndex: n, defaultText: u.getName(n) || "", inheritColor: U(r.fill) ? ii(r.fill, 1) : "#000" }), jl(t, i), Yl(t, null, null, i.get(["emphasis", "disabled"])), Qs(t).dataModel = e })), TB(l).data = u, l.group.silent = e.get("silent") || t.get("silent") }, e.type = "markArea", e }(fB); var RB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.layoutMode = { type: "box", ignoreSize: !0 }, n } return n(e, t), e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n), t.selected = t.selected || {}, this._updateSelector(t) }, e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), this._updateSelector(e) }, e.prototype._updateSelector = function (t) { var e = t.selector, n = this.ecModel; !0 === e && (e = t.selector = ["all", "inverse"]), Y(e) && E(e, (function (t, i) { U(t) && (t = { type: t }), e[i] = C(t, function (t, e) { return "all" === e ? { type: "all", title: t.getLocaleModel().get(["legend", "selector", "all"]) } : "inverse" === e ? { type: "inverse", title: t.getLocaleModel().get(["legend", "selector", "inverse"]) } : void 0 }(n, t.type)) })) }, e.prototype.optionUpdated = function () { this._updateData(this.ecModel); var t = this._data; if (t[0] && "single" === this.get("selectedMode")) { for (var e = !1, n = 0; n < t.length; n++) { var i = t[n].get("name"); if (this.isSelected(i)) { this.select(i), e = !0; break } } !e && this.select(t[0].get("name")) } }, e.prototype._updateData = function (t) { var e = [], n = []; t.eachRawSeries((function (i) { var r, o = i.name; if (n.push(o), i.legendVisualProvider) { var a = i.legendVisualProvider.getAllNames(); t.isSeriesFiltered(i) || (n = n.concat(a)), a.length ? e = e.concat(a) : r = !0 } else r = !0; r && ko(i) && e.push(i.name) })), this._availableNames = n; var i = this.get("data") || e, r = yt(), o = z(i, (function (t) { return (U(t) || j(t)) && (t = { name: t }), r.get(t.name) ? null : (r.set(t.name, !0), new Mc(t, this, this.ecModel)) }), this); this._data = B(o, (function (t) { return !!t })) }, e.prototype.getData = function () { return this._data }, e.prototype.select = function (t) { var e = this.option.selected; "single" === this.get("selectedMode") && E(this._data, (function (t) { e[t.get("name")] = !1 })); e[t] = !0 }, e.prototype.unSelect = function (t) { "single" !== this.get("selectedMode") && (this.option.selected[t] = !1) }, e.prototype.toggleSelected = function (t) { var e = this.option.selected; e.hasOwnProperty(t) || (e[t] = !0), this[e[t] ? "unSelect" : "select"](t) }, e.prototype.allSelect = function () { var t = this._data, e = this.option.selected; E(t, (function (t) { e[t.get("name", !0)] = !0 })) }, e.prototype.inverseSelect = function () { var t = this._data, e = this.option.selected; E(t, (function (t) { var n = t.get("name", !0); e.hasOwnProperty(n) || (e[n] = !0), e[n] = !e[n] })) }, e.prototype.isSelected = function (t) { var e = this.option.selected; return !(e.hasOwnProperty(t) && !e[t]) && P(this._availableNames, t) >= 0 }, e.prototype.getOrient = function () { return "vertical" === this.get("orient") ? { index: 1, name: "vertical" } : { index: 0, name: "horizontal" } }, e.type = "legend.plain", e.dependencies = ["series"], e.defaultOption = { z: 4, show: !0, orient: "horizontal", left: "center", top: 0, align: "auto", backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderRadius: 0, borderWidth: 0, padding: 5, itemGap: 10, itemWidth: 25, itemHeight: 14, symbolRotate: "inherit", symbolKeepAspect: !0, inactiveColor: "#ccc", inactiveBorderColor: "#ccc", inactiveBorderWidth: "auto", itemStyle: { color: "inherit", opacity: "inherit", borderColor: "inherit", borderWidth: "auto", borderCap: "inherit", borderJoin: "inherit", borderDashOffset: "inherit", borderMiterLimit: "inherit" }, lineStyle: { width: "auto", color: "inherit", inactiveColor: "#ccc", inactiveWidth: 2, opacity: "inherit", type: "inherit", cap: "inherit", join: "inherit", dashOffset: "inherit", miterLimit: "inherit" }, textStyle: { color: "#333" }, selectedMode: !0, selector: !1, selectorLabel: { show: !0, borderRadius: 10, padding: [3, 5, 3, 5], fontSize: 12, fontFamily: "sans-serif", color: "#666", borderWidth: 1, borderColor: "#666" }, emphasis: { selectorLabel: { show: !0, color: "#eee", backgroundColor: "#666" } }, selectorPosition: "auto", selectorItemGap: 7, selectorButtonGap: 10, tooltip: { show: !1 } }, e }(Rp), NB = H, EB = E, zB = zr, VB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.newlineDisabled = !1, n } return n(e, t), e.prototype.init = function () { this.group.add(this._contentGroup = new zB), this.group.add(this._selectorGroup = new zB), this._isFirstRender = !0 }, e.prototype.getContentGroup = function () { return this._contentGroup }, e.prototype.getSelectorGroup = function () { return this._selectorGroup }, e.prototype.render = function (t, e, n) { var i = this._isFirstRender; if (this._isFirstRender = !1, this.resetInner(), t.get("show", !0)) { var r = t.get("align"), o = t.get("orient"); r && "auto" !== r || (r = "right" === t.get("left") && "vertical" === o ? "right" : "left"); var a = t.get("selector", !0), s = t.get("selectorPosition", !0); !a || s && "auto" !== s || (s = "horizontal" === o ? "end" : "start"), this.renderInner(r, t, e, n, a, o, s); var l = t.getBoxLayoutParams(), u = { width: n.getWidth(), height: n.getHeight() }, h = t.get("padding"), c = Cp(l, u, h), p = this.layoutInner(t, r, c, i, a, s), d = Cp(k({ width: p.width, height: p.height }, l), u, h); this.group.x = d.x - p.x, this.group.y = d.y - p.y, this.group.markRedraw(), this.group.add(this._backgroundEl = dz(p, t)) } }, e.prototype.resetInner = function () { this.getContentGroup().removeAll(), this._backgroundEl && this.group.remove(this._backgroundEl), this.getSelectorGroup().removeAll() }, e.prototype.renderInner = function (t, e, n, i, r, o, a) { var s = this.getContentGroup(), l = yt(), u = e.get("selectedMode"), h = []; n.eachRawSeries((function (t) { !t.get("legendHoverLink") && h.push(t.id) })), EB(e.getData(), (function (r, o) { var a = r.get("name"); if (!this.newlineDisabled && ("" === a || "\n" === a)) { var c = new zB; return c.newline = !0, void s.add(c) } var p = n.getSeriesByName(a)[0]; if (!l.get(a)) { if (p) { var d = p.getData(), f = d.getVisual("legendLineStyle") || {}, g = d.getVisual("legendIcon"), y = d.getVisual("style"); this._createItem(p, a, o, r, e, t, f, y, g, u, i).on("click", NB(BB, a, null, i, h)).on("mouseover", NB(GB, p.name, null, i, h)).on("mouseout", NB(WB, p.name, null, i, h)), l.set(a, !0) } else n.eachRawSeries((function (n) { if (!l.get(a) && n.legendVisualProvider) { var s = n.legendVisualProvider; if (!s.containName(a)) return; var c = s.indexOfName(a), p = s.getItemVisual(c, "style"), d = s.getItemVisual(c, "legendIcon"), f = qn(p.fill); f && 0 === f[3] && (f[3] = .2, p = A(A({}, p), { fill: ri(f, "rgba") })), this._createItem(n, a, o, r, e, t, {}, p, d, u, i).on("click", NB(BB, null, a, i, h)).on("mouseover", NB(GB, null, a, i, h)).on("mouseout", NB(WB, null, a, i, h)), l.set(a, !0) } }), this); 0 } }), this), r && this._createSelector(r, e, i, o, a) }, e.prototype._createSelector = function (t, e, n, i, r) { var o = this.getSelectorGroup(); EB(t, (function (t) { var i = t.type, r = new Fs({ style: { x: 0, y: 0, align: "center", verticalAlign: "middle" }, onclick: function () { n.dispatchAction({ type: "all" === i ? "legendAllSelect" : "legendInverseSelect" }) } }); o.add(r), tc(r, { normal: e.getModel("selectorLabel"), emphasis: e.getModel(["emphasis", "selectorLabel"]) }, { defaultText: t.title }), Hl(r) })) }, e.prototype._createItem = function (t, e, n, i, r, o, a, s, l, u, h) { var c = t.visualDrawType, p = r.get("itemWidth"), d = r.get("itemHeight"), f = r.isSelected(e), g = i.get("symbolRotate"), y = i.get("symbolKeepAspect"), v = i.get("icon"), m = function (t, e, n, i, r, o, a) { function s(t, e) { "auto" === t.lineWidth && (t.lineWidth = e.lineWidth > 0 ? 2 : 0), EB(t, (function (n, i) { "inherit" === t[i] && (t[i] = e[i]) })) } var l = e.getModel("itemStyle"), u = l.getItemStyle(), h = 0 === t.lastIndexOf("empty", 0) ? "fill" : "stroke", c = l.getShallow("decal"); u.decal = c && "inherit" !== c ? gv(c, a) : i.decal, "inherit" === u.fill && (u.fill = i[r]); "inherit" === u.stroke && (u.stroke = i[h]); "inherit" === u.opacity && (u.opacity = ("fill" === r ? i : n).opacity); s(u, i); var p = e.getModel("lineStyle"), d = p.getLineStyle(); if (s(d, n), "auto" === u.fill && (u.fill = i.fill), "auto" === u.stroke && (u.stroke = i.fill), "auto" === d.stroke && (d.stroke = i.fill), !o) { var f = e.get("inactiveBorderWidth"), g = u[h]; u.lineWidth = "auto" === f ? i.lineWidth > 0 && g ? 2 : 0 : u.lineWidth, u.fill = e.get("inactiveColor"), u.stroke = e.get("inactiveBorderColor"), d.stroke = p.get("inactiveColor"), d.lineWidth = p.get("inactiveWidth") } return { itemStyle: u, lineStyle: d } }(l = v || l || "roundRect", i, a, s, c, f, h), x = new zB, _ = i.getModel("textStyle"); if (!X(t.getLegendIcon) || v && "inherit" !== v) { var b = "inherit" === v && t.getData().getVisual("symbol") ? "inherit" === g ? t.getData().getVisual("symbolRotate") : g : 0; x.add(function (t) { var e = t.icon || "roundRect", n = Wy(e, 0, 0, t.itemWidth, t.itemHeight, t.itemStyle.fill, t.symbolKeepAspect); n.setStyle(t.itemStyle), n.rotation = (t.iconRotate || 0) * Math.PI / 180, n.setOrigin([t.itemWidth / 2, t.itemHeight / 2]), e.indexOf("empty") > -1 && (n.style.stroke = n.style.fill, n.style.fill = "#fff", n.style.lineWidth = 2); return n }({ itemWidth: p, itemHeight: d, icon: l, iconRotate: b, itemStyle: m.itemStyle, lineStyle: m.lineStyle, symbolKeepAspect: y })) } else x.add(t.getLegendIcon({ itemWidth: p, itemHeight: d, icon: l, iconRotate: g, itemStyle: m.itemStyle, lineStyle: m.lineStyle, symbolKeepAspect: y })); var w = "left" === o ? p + 5 : -5, S = o, M = r.get("formatter"), I = e; U(M) && M ? I = M.replace("{name}", null != e ? e : "") : X(M) && (I = M(e)); var T = f ? _.getTextColor() : i.get("inactiveColor"); x.add(new Fs({ style: nc(_, { text: I, x: w, y: d / 2, fill: T, align: S, verticalAlign: "middle" }, { inheritColor: T }) })); var C = new zs({ shape: x.getBoundingRect(), invisible: !0 }), D = i.getModel("tooltip"); return D.get("show") && Zh({ el: C, componentModel: r, itemName: e, itemTooltipOption: D.option }), x.add(C), x.eachChild((function (t) { t.silent = !0 })), C.silent = !u, this.getContentGroup().add(x), Hl(x), x.__legendDataIndex = n, x }, e.prototype.layoutInner = function (t, e, n, i, r, o) { var a = this.getContentGroup(), s = this.getSelectorGroup(); Tp(t.get("orient"), a, t.get("itemGap"), n.width, n.height); var l = a.getBoundingRect(), u = [-l.x, -l.y]; if (s.markRedraw(), a.markRedraw(), r) { Tp("horizontal", s, t.get("selectorItemGap", !0)); var h = s.getBoundingRect(), c = [-h.x, -h.y], p = t.get("selectorButtonGap", !0), d = t.getOrient().index, f = 0 === d ? "width" : "height", g = 0 === d ? "height" : "width", y = 0 === d ? "y" : "x"; "end" === o ? c[d] += l[f] + p : u[d] += h[f] + p, c[1 - d] += l[g] / 2 - h[g] / 2, s.x = c[0], s.y = c[1], a.x = u[0], a.y = u[1]; var v = { x: 0, y: 0 }; return v[f] = l[f] + p + h[f], v[g] = Math.max(l[g], h[g]), v[y] = Math.min(0, h[y] + c[1 - d]), v } return a.x = u[0], a.y = u[1], this.group.getBoundingRect() }, e.prototype.remove = function () { this.getContentGroup().removeAll(), this._isFirstRender = !0 }, e.type = "legend.plain", e }(Tg); function BB(t, e, n, i) { WB(t, e, n, i), n.dispatchAction({ type: "legendToggleSelect", name: null != t ? t : e }), GB(t, e, n, i) } function FB(t) { for (var e, n = t.getZr().storage.getDisplayList(), i = 0, r = n.length; i < r && !(e = n[i].states.emphasis);)i++; return e && e.hoverLayer } function GB(t, e, n, i) { FB(n) || n.dispatchAction({ type: "highlight", seriesName: t, name: e, excludeSeriesId: i }) } function WB(t, e, n, i) { FB(n) || n.dispatchAction({ type: "downplay", seriesName: t, name: e, excludeSeriesId: i }) } function HB(t) { var e = t.findComponents({ mainType: "legend" }); e && e.length && t.filterSeries((function (t) { for (var n = 0; n < e.length; n++)if (!e[n].isSelected(t.name)) return !1; return !0 })) } function YB(t, e, n) { var i, r = {}, o = "toggleSelected" === t; return n.eachComponent("legend", (function (n) { o && null != i ? n[i ? "select" : "unSelect"](e.name) : "allSelect" === t || "inverseSelect" === t ? n[t]() : (n[t](e.name), i = n.isSelected(e.name)), E(n.getData(), (function (t) { var e = t.get("name"); if ("\n" !== e && "" !== e) { var i = n.isSelected(e); r.hasOwnProperty(e) ? r[e] = r[e] && i : r[e] = i } })) })), "allSelect" === t || "inverseSelect" === t ? { selected: r } : { name: e.name, selected: r } } function XB(t) { t.registerComponentModel(RB), t.registerComponentView(VB), t.registerProcessor(t.PRIORITY.PROCESSOR.SERIES_FILTER, HB), t.registerSubTypeDefaulter("legend", (function () { return "plain" })), function (t) { t.registerAction("legendToggleSelect", "legendselectchanged", H(YB, "toggleSelected")), t.registerAction("legendAllSelect", "legendselectall", H(YB, "allSelect")), t.registerAction("legendInverseSelect", "legendinverseselect", H(YB, "inverseSelect")), t.registerAction("legendSelect", "legendselected", H(YB, "select")), t.registerAction("legendUnSelect", "legendunselected", H(YB, "unSelect")) }(t) } var UB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.setScrollDataIndex = function (t) { this.option.scrollDataIndex = t }, e.prototype.init = function (e, n, i) { var r = Lp(e); t.prototype.init.call(this, e, n, i), ZB(this, e, r) }, e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), ZB(this, this.option, e) }, e.type = "legend.scroll", e.defaultOption = Cc(RB.defaultOption, { scrollDataIndex: 0, pageButtonItemGap: 5, pageButtonGap: null, pageButtonPosition: "end", pageFormatter: "{current}/{total}", pageIcons: { horizontal: ["M0,0L12,-10L12,10z", "M0,0L-12,-10L-12,10z"], vertical: ["M0,0L20,0L10,-20z", "M0,0L20,0L10,20z"] }, pageIconColor: "#2f4554", pageIconInactiveColor: "#aaa", pageIconSize: 15, pageTextStyle: { color: "#333" }, animationDurationUpdate: 800 }), e }(RB); function ZB(t, e, n) { var i = [1, 1]; i[t.getOrient().index] = 0, kp(e, n, { type: "box", ignoreSize: !!i }) } var jB = zr, qB = ["width", "height"], KB = ["x", "y"], $B = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.newlineDisabled = !0, n._currentIndex = 0, n } return n(e, t), e.prototype.init = function () { t.prototype.init.call(this), this.group.add(this._containerGroup = new jB), this._containerGroup.add(this.getContentGroup()), this.group.add(this._controllerGroup = new jB) }, e.prototype.resetInner = function () { t.prototype.resetInner.call(this), this._controllerGroup.removeAll(), this._containerGroup.removeClipPath(), this._containerGroup.__rectSize = null }, e.prototype.renderInner = function (e, n, i, r, o, a, s) { var l = this; t.prototype.renderInner.call(this, e, n, i, r, o, a, s); var u = this._controllerGroup, h = n.get("pageIconSize", !0), c = Y(h) ? h : [h, h]; d("pagePrev", 0); var p = n.getModel("pageTextStyle"); function d(t, e) { var i = t + "DataIndex", o = Hh(n.get("pageIcons", !0)[n.getOrient().name][e], { onclick: W(l._pageGo, l, i, n, r) }, { x: -c[0] / 2, y: -c[1] / 2, width: c[0], height: c[1] }); o.name = t, u.add(o) } u.add(new Fs({ name: "pageText", style: { text: "xx/xx", fill: p.getTextColor(), font: p.getFont(), verticalAlign: "middle", align: "center" }, silent: !0 })), d("pageNext", 1) }, e.prototype.layoutInner = function (t, e, n, i, r, o) { var a = this.getSelectorGroup(), s = t.getOrient().index, l = qB[s], u = KB[s], h = qB[1 - s], c = KB[1 - s]; r && Tp("horizontal", a, t.get("selectorItemGap", !0)); var p = t.get("selectorButtonGap", !0), d = a.getBoundingRect(), f = [-d.x, -d.y], g = T(n); r && (g[l] = n[l] - d[l] - p); var y = this._layoutContentAndController(t, i, g, s, l, h, c, u); if (r) { if ("end" === o) f[s] += y[l] + p; else { var v = d[l] + p; f[s] -= v, y[u] -= v } y[l] += d[l] + p, f[1 - s] += y[c] + y[h] / 2 - d[h] / 2, y[h] = Math.max(y[h], d[h]), y[c] = Math.min(y[c], d[c] + f[1 - s]), a.x = f[0], a.y = f[1], a.markRedraw() } return y }, e.prototype._layoutContentAndController = function (t, e, n, i, r, o, a, s) { var l = this.getContentGroup(), u = this._containerGroup, h = this._controllerGroup; Tp(t.get("orient"), l, t.get("itemGap"), i ? n.width : null, i ? null : n.height), Tp("horizontal", h, t.get("pageButtonItemGap", !0)); var c = l.getBoundingRect(), p = h.getBoundingRect(), d = this._showController = c[r] > n[r], f = [-c.x, -c.y]; e || (f[i] = l[s]); var g = [0, 0], y = [-p.x, -p.y], v = rt(t.get("pageButtonGap", !0), t.get("itemGap", !0)); d && ("end" === t.get("pageButtonPosition", !0) ? y[i] += n[r] - p[r] : g[i] += p[r] + v); y[1 - i] += c[o] / 2 - p[o] / 2, l.setPosition(f), u.setPosition(g), h.setPosition(y); var m = { x: 0, y: 0 }; if (m[r] = d ? n[r] : c[r], m[o] = Math.max(c[o], p[o]), m[a] = Math.min(0, p[a] + y[1 - i]), u.__rectSize = n[r], d) { var x = { x: 0, y: 0 }; x[r] = Math.max(n[r] - p[r] - v, 0), x[o] = m[o], u.setClipPath(new zs({ shape: x })), u.__rectSize = x[r] } else h.eachChild((function (t) { t.attr({ invisible: !0, silent: !0 }) })); var _ = this._getPageInfo(t); return null != _.pageIndex && fh(l, { x: _.contentPosition[0], y: _.contentPosition[1] }, d ? t : null), this._updatePageInfoView(t, _), m }, e.prototype._pageGo = function (t, e, n) { var i = this._getPageInfo(e)[t]; null != i && n.dispatchAction({ type: "legendScroll", scrollDataIndex: i, legendId: e.id }) }, e.prototype._updatePageInfoView = function (t, e) { var n = this._controllerGroup; E(["pagePrev", "pageNext"], (function (i) { var r = null != e[i + "DataIndex"], o = n.childOfName(i); o && (o.setStyle("fill", r ? t.get("pageIconColor", !0) : t.get("pageIconInactiveColor", !0)), o.cursor = r ? "pointer" : "default") })); var i = n.childOfName("pageText"), r = t.get("pageFormatter"), o = e.pageIndex, a = null != o ? o + 1 : 0, s = e.pageCount; i && r && i.setStyle("text", U(r) ? r.replace("{current}", null == a ? "" : a + "").replace("{total}", null == s ? "" : s + "") : r({ current: a, total: s })) }, e.prototype._getPageInfo = function (t) { var e = t.get("scrollDataIndex", !0), n = this.getContentGroup(), i = this._containerGroup.__rectSize, r = t.getOrient().index, o = qB[r], a = KB[r], s = this._findTargetItemIndex(e), l = n.children(), u = l[s], h = l.length, c = h ? 1 : 0, p = { contentPosition: [n.x, n.y], pageCount: c, pageIndex: c - 1, pagePrevDataIndex: null, pageNextDataIndex: null }; if (!u) return p; var d = m(u); p.contentPosition[r] = -d.s; for (var f = s + 1, g = d, y = d, v = null; f <= h; ++f)(!(v = m(l[f])) && y.e > g.s + i || v && !x(v, g.s)) && (g = y.i > g.i ? y : v) && (null == p.pageNextDataIndex && (p.pageNextDataIndex = g.i), ++p.pageCount), y = v; for (f = s - 1, g = d, y = d, v = null; f >= -1; --f)(v = m(l[f])) && x(y, v.s) || !(g.i < y.i) || (y = g, null == p.pagePrevDataIndex && (p.pagePrevDataIndex = g.i), ++p.pageCount, ++p.pageIndex), g = v; return p; function m(t) { if (t) { var e = t.getBoundingRect(), n = e[a] + t[a]; return { s: n, e: n + e[o], i: t.__legendDataIndex } } } function x(t, e) { return t.e >= e && t.s <= e + i } }, e.prototype._findTargetItemIndex = function (t) { return this._showController ? (this.getContentGroup().eachChild((function (i, r) { var o = i.__legendDataIndex; null == n && null != o && (n = r), o === t && (e = r) })), null != e ? e : n) : 0; var e, n }, e.type = "legend.scroll", e }(VB); function JB(t) { Nm(XB), t.registerComponentModel(UB), t.registerComponentView($B), function (t) { t.registerAction("legendScroll", "legendscroll", (function (t, e) { var n = t.scrollDataIndex; null != n && e.eachComponent({ mainType: "legend", subType: "scroll", query: t }, (function (t) { t.setScrollDataIndex(n) })) })) }(t) } var QB = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "dataZoom.inside", e.defaultOption = Cc(KE.defaultOption, { disabled: !1, zoomLock: !1, zoomOnMouseWheel: !0, moveOnMouseMove: !0, moveOnMouseWheel: !1, preventDefaultMouseMove: !0 }), e }(KE), tF = Oo(); function eF(t, e, n) { tF(t).coordSysRecordMap.each((function (t) { var i = t.dataZoomInfoMap.get(e.uid); i && (i.getRange = n) })) } function nF(t, e) { if (e) { t.removeKey(e.model.uid); var n = e.controller; n && n.dispose() } } function iF(t, e) { t.isDisposed() || t.dispatchAction({ type: "dataZoom", animation: { easing: "cubicOut", duration: 100 }, batch: e }) } function rF(t, e, n, i) { return t.coordinateSystem.containPoint([n, i]) } function oF(t) { t.registerProcessor(t.PRIORITY.PROCESSOR.FILTER, (function (t, e) { var n = tF(e), i = n.coordSysRecordMap || (n.coordSysRecordMap = yt()); i.each((function (t) { t.dataZoomInfoMap = null })), t.eachComponent({ mainType: "dataZoom", subType: "inside" }, (function (t) { E(jE(t).infoList, (function (n) { var r = n.model.uid, o = i.get(r) || i.set(r, function (t, e) { var n = { model: e, containsPoint: H(rF, e), dispatchAction: H(iF, t), dataZoomInfoMap: null, controller: null }, i = n.controller = new UI(t.getZr()); return E(["pan", "zoom", "scrollMove"], (function (t) { i.on(t, (function (e) { var i = []; n.dataZoomInfoMap.each((function (r) { if (e.isAvailableBehavior(r.model.option)) { var o = (r.getRange || {})[t], a = o && o(r.dzReferCoordSysInfo, n.model.mainType, n.controller, e); !r.model.get("disabled", !0) && a && i.push({ dataZoomId: r.model.id, start: a[0], end: a[1] }) } })), i.length && n.dispatchAction(i) })) })), n }(e, n.model)); (o.dataZoomInfoMap || (o.dataZoomInfoMap = yt())).set(t.uid, { dzReferCoordSysInfo: n, model: t, getRange: null }) })) })), i.each((function (t) { var e, n = t.controller, r = t.dataZoomInfoMap; if (r) { var o = r.keys()[0]; null != o && (e = r.get(o)) } if (e) { var a = function (t) { var e, n = "type_", i = { type_true: 2, type_move: 1, type_false: 0, type_undefined: -1 }, r = !0; return t.each((function (t) { var o = t.model, a = !o.get("disabled", !0) && (!o.get("zoomLock", !0) || "move"); i[n + a] > i[n + e] && (e = a), r = r && o.get("preventDefaultMouseMove", !0) })), { controlType: e, opt: { zoomOnMouseWheel: !0, moveOnMouseMove: !0, moveOnMouseWheel: !0, preventDefaultMouseMove: !!r } } }(r); n.enable(a.controlType, a.opt), n.setPointerChecker(t.containsPoint), Fg(t, "dispatchAction", e.model.get("throttle", !0), "fixRate") } else nF(i, t) })) })) } var aF = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "dataZoom.inside", e } return n(e, t), e.prototype.render = function (e, n, i) { t.prototype.render.apply(this, arguments), e.noTarget() ? this._clear() : (this.range = e.getPercentRange(), eF(i, e, { pan: W(sF.pan, this), zoom: W(sF.zoom, this), scrollMove: W(sF.scrollMove, this) })) }, e.prototype.dispose = function () { this._clear(), t.prototype.dispose.apply(this, arguments) }, e.prototype._clear = function () { !function (t, e) { for (var n = tF(t).coordSysRecordMap, i = n.keys(), r = 0; r < i.length; r++) { var o = i[r], a = n.get(o), s = a.dataZoomInfoMap; if (s) { var l = e.uid; s.get(l) && (s.removeKey(l), s.keys().length || nF(n, a)) } } }(this.api, this.dataZoomModel), this.range = null }, e.type = "dataZoom.inside", e }(QE), sF = { zoom: function (t, e, n, i) { var r = this.range, o = r.slice(), a = t.axisModels[0]; if (a) { var s = uF[e](null, [i.originX, i.originY], a, n, t), l = (s.signal > 0 ? s.pixelStart + s.pixelLength - s.pixel : s.pixel - s.pixelStart) / s.pixelLength * (o[1] - o[0]) + o[0], u = Math.max(1 / i.scale, 0); o[0] = (o[0] - l) * u + l, o[1] = (o[1] - l) * u + l; var h = this.dataZoomModel.findRepresentativeAxisProxy().getMinMaxSpan(); return Ck(0, o, [0, 100], 0, h.minSpan, h.maxSpan), this.range = o, r[0] !== o[0] || r[1] !== o[1] ? o : void 0 } }, pan: lF((function (t, e, n, i, r, o) { var a = uF[i]([o.oldX, o.oldY], [o.newX, o.newY], e, r, n); return a.signal * (t[1] - t[0]) * a.pixel / a.pixelLength })), scrollMove: lF((function (t, e, n, i, r, o) { return uF[i]([0, 0], [o.scrollDelta, o.scrollDelta], e, r, n).signal * (t[1] - t[0]) * o.scrollDelta })) }; function lF(t) { return function (e, n, i, r) { var o = this.range, a = o.slice(), s = e.axisModels[0]; if (s) return Ck(t(a, s, e, n, i, r), a, [0, 100], "all"), this.range = a, o[0] !== a[0] || o[1] !== a[1] ? a : void 0 } } var uF = { grid: function (t, e, n, i, r) { var o = n.axis, a = {}, s = r.model.coordinateSystem.getRect(); return t = t || [0, 0], "x" === o.dim ? (a.pixel = e[0] - t[0], a.pixelLength = s.width, a.pixelStart = s.x, a.signal = o.inverse ? 1 : -1) : (a.pixel = e[1] - t[1], a.pixelLength = s.height, a.pixelStart = s.y, a.signal = o.inverse ? -1 : 1), a }, polar: function (t, e, n, i, r) { var o = n.axis, a = {}, s = r.model.coordinateSystem, l = s.getRadiusAxis().getExtent(), u = s.getAngleAxis().getExtent(); return t = t ? s.pointToCoord(t) : [0, 0], e = s.pointToCoord(e), "radiusAxis" === n.mainType ? (a.pixel = e[0] - t[0], a.pixelLength = l[1] - l[0], a.pixelStart = l[0], a.signal = o.inverse ? 1 : -1) : (a.pixel = e[1] - t[1], a.pixelLength = u[1] - u[0], a.pixelStart = u[0], a.signal = o.inverse ? -1 : 1), a }, singleAxis: function (t, e, n, i, r) { var o = n.axis, a = r.model.coordinateSystem.getRect(), s = {}; return t = t || [0, 0], "horizontal" === o.orient ? (s.pixel = e[0] - t[0], s.pixelLength = a.width, s.pixelStart = a.x, s.signal = o.inverse ? 1 : -1) : (s.pixel = e[1] - t[1], s.pixelLength = a.height, s.pixelStart = a.y, s.signal = o.inverse ? -1 : 1), s } }; function hF(t) { az(t), t.registerComponentModel(QB), t.registerComponentView(aF), oF(t) } var cF = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.type = "dataZoom.slider", e.layoutMode = "box", e.defaultOption = Cc(KE.defaultOption, { show: !0, right: "ph", top: "ph", width: "ph", height: "ph", left: null, bottom: null, borderColor: "#d2dbee", borderRadius: 3, backgroundColor: "rgba(47,69,84,0)", dataBackground: { lineStyle: { color: "#d2dbee", width: .5 }, areaStyle: { color: "#d2dbee", opacity: .2 } }, selectedDataBackground: { lineStyle: { color: "#8fb0f7", width: .5 }, areaStyle: { color: "#8fb0f7", opacity: .2 } }, fillerColor: "rgba(135,175,274,0.2)", handleIcon: "path://M-9.35,34.56V42m0-40V9.5m-2,0h4a2,2,0,0,1,2,2v21a2,2,0,0,1-2,2h-4a2,2,0,0,1-2-2v-21A2,2,0,0,1-11.35,9.5Z", handleSize: "100%", handleStyle: { color: "#fff", borderColor: "#ACB8D1" }, moveHandleSize: 7, moveHandleIcon: "path://M-320.9-50L-320.9-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-348-41-339-50-320.9-50z M-212.3-50L-212.3-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-239.4-41-230.4-50-212.3-50z M-103.7-50L-103.7-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-130.9-41-121.8-50-103.7-50z", moveHandleStyle: { color: "#D2DBEE", opacity: .7 }, showDetail: !0, showDataShadow: "auto", realtime: !0, zoomLock: !1, textStyle: { color: "#6E7079" }, brushSelect: !0, brushStyle: { color: "rgba(135,175,274,0.15)" }, emphasis: { handleStyle: { borderColor: "#8FB0F7" }, moveHandleStyle: { color: "#8FB0F7" } } }), e }(KE), pF = zs, dF = "horizontal", fF = "vertical", gF = ["line", "bar", "candlestick", "scatter"], yF = { easing: "cubicOut", duration: 100, delay: 0 }, vF = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._displayables = {}, n } return n(e, t), e.prototype.init = function (t, e) { this.api = e, this._onBrush = W(this._onBrush, this), this._onBrushEnd = W(this._onBrushEnd, this) }, e.prototype.render = function (e, n, i, r) { if (t.prototype.render.apply(this, arguments), Fg(this, "_dispatchZoomAction", e.get("throttle"), "fixRate"), this._orient = e.getOrient(), !1 !== e.get("show")) { if (e.noTarget()) return this._clear(), void this.group.removeAll(); r && "dataZoom" === r.type && r.from === this.uid || this._buildView(), this._updateView() } else this.group.removeAll() }, e.prototype.dispose = function () { this._clear(), t.prototype.dispose.apply(this, arguments) }, e.prototype._clear = function () { Gg(this, "_dispatchZoomAction"); var t = this.api.getZr(); t.off("mousemove", this._onBrush), t.off("mouseup", this._onBrushEnd) }, e.prototype._buildView = function () { var t = this.group; t.removeAll(), this._brushing = !1, this._displayables.brushRect = null, this._resetLocation(), this._resetInterval(); var e = this._displayables.sliderGroup = new zr; this._renderBackground(), this._renderHandle(), this._renderDataShadow(), t.add(e), this._positionGroup() }, e.prototype._resetLocation = function () { var t = this.dataZoomModel, e = this.api, n = t.get("brushSelect") ? 7 : 0, i = this._findCoordRect(), r = { width: e.getWidth(), height: e.getHeight() }, o = this._orient === dF ? { right: r.width - i.x - i.width, top: r.height - 30 - 7 - n, width: i.width, height: 30 } : { right: 7, top: i.y, width: 30, height: i.height }, a = Lp(t.option); E(["right", "top", "width", "height"], (function (t) { "ph" === a[t] && (a[t] = o[t]) })); var s = Cp(a, r); this._location = { x: s.x, y: s.y }, this._size = [s.width, s.height], this._orient === fF && this._size.reverse() }, e.prototype._positionGroup = function () { var t = this.group, e = this._location, n = this._orient, i = this.dataZoomModel.getFirstTargetAxisModel(), r = i && i.get("inverse"), o = this._displayables.sliderGroup, a = (this._dataShadowInfo || {}).otherAxisInverse; o.attr(n !== dF || r ? n === dF && r ? { scaleY: a ? 1 : -1, scaleX: -1 } : n !== fF || r ? { scaleY: a ? -1 : 1, scaleX: -1, rotation: Math.PI / 2 } : { scaleY: a ? -1 : 1, scaleX: 1, rotation: Math.PI / 2 } : { scaleY: a ? 1 : -1, scaleX: 1 }); var s = t.getBoundingRect([o]); t.x = e.x - s.x, t.y = e.y - s.y, t.markRedraw() }, e.prototype._getViewExtent = function () { return [0, this._size[0]] }, e.prototype._renderBackground = function () { var t = this.dataZoomModel, e = this._size, n = this._displayables.sliderGroup, i = t.get("brushSelect"); n.add(new pF({ silent: !0, shape: { x: 0, y: 0, width: e[0], height: e[1] }, style: { fill: t.get("backgroundColor") }, z2: -40 })); var r = new pF({ shape: { x: 0, y: 0, width: e[0], height: e[1] }, style: { fill: "transparent" }, z2: 0, onclick: W(this._onClickPanel, this) }), o = this.api.getZr(); i ? (r.on("mousedown", this._onBrushStart, this), r.cursor = "crosshair", o.on("mousemove", this._onBrush), o.on("mouseup", this._onBrushEnd)) : (o.off("mousemove", this._onBrush), o.off("mouseup", this._onBrushEnd)), n.add(r) }, e.prototype._renderDataShadow = function () { var t = this._dataShadowInfo = this._prepareDataShadowInfo(); if (this._displayables.dataShadowSegs = [], t) { var e = this._size, n = this._shadowSize || [], i = t.series, r = i.getRawData(), o = i.getShadowDim && i.getShadowDim(), a = o && r.getDimensionInfo(o) ? i.getShadowDim() : t.otherDim; if (null != a) { var s = this._shadowPolygonPts, l = this._shadowPolylinePts; if (r !== this._shadowData || a !== this._shadowDim || e[0] !== n[0] || e[1] !== n[1]) { var u = r.getDataExtent(a), h = .3 * (u[1] - u[0]); u = [u[0] - h, u[1] + h]; var c, p = [0, e[1]], d = [0, e[0]], f = [[e[0], 0], [0, 0]], g = [], y = d[1] / (r.count() - 1), v = 0, m = Math.round(r.count() / e[0]); r.each([a], (function (t, e) { if (m > 0 && e % m) v += y; else { var n = null == t || isNaN(t) || "" === t, i = n ? 0 : Xr(t, u, p, !0); n && !c && e ? (f.push([f[f.length - 1][0], 0]), g.push([g[g.length - 1][0], 0])) : !n && c && (f.push([v, 0]), g.push([v, 0])), f.push([v, i]), g.push([v, i]), v += y, c = n } })), s = this._shadowPolygonPts = f, l = this._shadowPolylinePts = g } this._shadowData = r, this._shadowDim = a, this._shadowSize = [e[0], e[1]]; for (var x = this.dataZoomModel, _ = 0; _ < 3; _++) { var b = w(1 === _); this._displayables.sliderGroup.add(b), this._displayables.dataShadowSegs.push(b) } } } function w(t) { var e = x.getModel(t ? "selectedDataBackground" : "dataBackground"), n = new zr, i = new Wu({ shape: { points: s }, segmentIgnoreThreshold: 1, style: e.getModel("areaStyle").getAreaStyle(), silent: !0, z2: -20 }), r = new Yu({ shape: { points: l }, segmentIgnoreThreshold: 1, style: e.getModel("lineStyle").getLineStyle(), silent: !0, z2: -19 }); return n.add(i), n.add(r), n } }, e.prototype._prepareDataShadowInfo = function () { var t = this.dataZoomModel, e = t.get("showDataShadow"); if (!1 !== e) { var n, i = this.ecModel; return t.eachTargetAxis((function (r, o) { E(t.getAxisProxy(r, o).getTargetSeriesModels(), (function (t) { if (!(n || !0 !== e && P(gF, t.get("type")) < 0)) { var a, s = i.getComponent(UE(r), o).axis, l = function (t) { var e = { x: "y", y: "x", radius: "angle", angle: "radius" }; return e[t] }(r), u = t.coordinateSystem; null != l && u.getOtherAxis && (a = u.getOtherAxis(s).inverse), l = t.getData().mapDimension(l), n = { thisAxis: s, series: t, thisDim: r, otherDim: l, otherAxisInverse: a } } }), this) }), this), n } }, e.prototype._renderHandle = function () { var t = this.group, e = this._displayables, n = e.handles = [null, null], i = e.handleLabels = [null, null], r = this._displayables.sliderGroup, o = this._size, a = this.dataZoomModel, s = this.api, l = a.get("borderRadius") || 0, u = a.get("brushSelect"), h = e.filler = new pF({ silent: u, style: { fill: a.get("fillerColor") }, textConfig: { position: "inside" } }); r.add(h), r.add(new pF({ silent: !0, subPixelOptimize: !0, shape: { x: 0, y: 0, width: o[0], height: o[1], r: l }, style: { stroke: a.get("dataBackgroundColor") || a.get("borderColor"), lineWidth: 1, fill: "rgba(0,0,0,0)" } })), E([0, 1], (function (e) { var o = a.get("handleIcon"); !By[o] && o.indexOf("path://") < 0 && o.indexOf("image://") < 0 && (o = "path://" + o); var s = Wy(o, -1, 0, 2, 2, null, !0); s.attr({ cursor: mF(this._orient), draggable: !0, drift: W(this._onDragMove, this, e), ondragend: W(this._onDragEnd, this), onmouseover: W(this._showDataInfo, this, !0), onmouseout: W(this._showDataInfo, this, !1), z2: 5 }); var l = s.getBoundingRect(), u = a.get("handleSize"); this._handleHeight = Ur(u, this._size[1]), this._handleWidth = l.width / l.height * this._handleHeight, s.setStyle(a.getModel("handleStyle").getItemStyle()), s.style.strokeNoScale = !0, s.rectHover = !0, s.ensureState("emphasis").style = a.getModel(["emphasis", "handleStyle"]).getItemStyle(), Hl(s); var h = a.get("handleColor"); null != h && (s.style.fill = h), r.add(n[e] = s); var c = a.getModel("textStyle"); t.add(i[e] = new Fs({ silent: !0, invisible: !0, style: nc(c, { x: 0, y: 0, text: "", verticalAlign: "middle", align: "center", fill: c.getTextColor(), font: c.getFont() }), z2: 10 })) }), this); var c = h; if (u) { var p = Ur(a.get("moveHandleSize"), o[1]), d = e.moveHandle = new zs({ style: a.getModel("moveHandleStyle").getItemStyle(), silent: !0, shape: { r: [0, 0, 2, 2], y: o[1] - .5, height: p } }), f = .8 * p, g = e.moveHandleIcon = Wy(a.get("moveHandleIcon"), -f / 2, -f / 2, f, f, "#fff", !0); g.silent = !0, g.y = o[1] + p / 2 - .5, d.ensureState("emphasis").style = a.getModel(["emphasis", "moveHandleStyle"]).getItemStyle(); var y = Math.min(o[1] / 2, Math.max(p, 10)); (c = e.moveZone = new zs({ invisible: !0, shape: { y: o[1] - y, height: p + y } })).on("mouseover", (function () { s.enterEmphasis(d) })).on("mouseout", (function () { s.leaveEmphasis(d) })), r.add(d), r.add(g), r.add(c) } c.attr({ draggable: !0, cursor: mF(this._orient), drift: W(this._onDragMove, this, "all"), ondragstart: W(this._showDataInfo, this, !0), ondragend: W(this._onDragEnd, this), onmouseover: W(this._showDataInfo, this, !0), onmouseout: W(this._showDataInfo, this, !1) }) }, e.prototype._resetInterval = function () { var t = this._range = this.dataZoomModel.getPercentRange(), e = this._getViewExtent(); this._handleEnds = [Xr(t[0], [0, 100], e, !0), Xr(t[1], [0, 100], e, !0)] }, e.prototype._updateInterval = function (t, e) { var n = this.dataZoomModel, i = this._handleEnds, r = this._getViewExtent(), o = n.findRepresentativeAxisProxy().getMinMaxSpan(), a = [0, 100]; Ck(e, i, r, n.get("zoomLock") ? "all" : t, null != o.minSpan ? Xr(o.minSpan, a, r, !0) : null, null != o.maxSpan ? Xr(o.maxSpan, a, r, !0) : null); var s = this._range, l = this._range = jr([Xr(i[0], r, a, !0), Xr(i[1], r, a, !0)]); return !s || s[0] !== l[0] || s[1] !== l[1] }, e.prototype._updateView = function (t) { var e = this._displayables, n = this._handleEnds, i = jr(n.slice()), r = this._size; E([0, 1], (function (t) { var i = e.handles[t], o = this._handleHeight; i.attr({ scaleX: o / 2, scaleY: o / 2, x: n[t] + (t ? -1 : 1), y: r[1] / 2 - o / 2 }) }), this), e.filler.setShape({ x: i[0], y: 0, width: i[1] - i[0], height: r[1] }); var o = { x: i[0], width: i[1] - i[0] }; e.moveHandle && (e.moveHandle.setShape(o), e.moveZone.setShape(o), e.moveZone.getBoundingRect(), e.moveHandleIcon && e.moveHandleIcon.attr("x", o.x + o.width / 2)); for (var a = e.dataShadowSegs, s = [0, i[0], i[1], r[0]], l = 0; l < a.length; l++) { var u = a[l], h = u.getClipPath(); h || (h = new zs, u.setClipPath(h)), h.setShape({ x: s[l], y: 0, width: s[l + 1] - s[l], height: r[1] }) } this._updateDataInfo(t) }, e.prototype._updateDataInfo = function (t) { var e = this.dataZoomModel, n = this._displayables, i = n.handleLabels, r = this._orient, o = ["", ""]; if (e.get("showDetail")) { var a = e.findRepresentativeAxisProxy(); if (a) { var s = a.getAxisModel().axis, l = this._range, u = t ? a.calculateDataWindow({ start: l[0], end: l[1] }).valueWindow : a.getDataValueWindow(); o = [this._formatLabel(u[0], s), this._formatLabel(u[1], s)] } } var h = jr(this._handleEnds.slice()); function c(t) { var e = Eh(n.handles[t].parent, this.group), a = Vh(0 === t ? "right" : "left", e), s = this._handleWidth / 2 + 5, l = zh([h[t] + (0 === t ? -s : s), this._size[1] / 2], e); i[t].setStyle({ x: l[0], y: l[1], verticalAlign: r === dF ? "middle" : a, align: r === dF ? a : "center", text: o[t] }) } c.call(this, 0), c.call(this, 1) }, e.prototype._formatLabel = function (t, e) { var n = this.dataZoomModel, i = n.get("labelFormatter"), r = n.get("labelPrecision"); null != r && "auto" !== r || (r = e.getPixelPrecision()); var o = null == t || isNaN(t) ? "" : "category" === e.type || "time" === e.type ? e.scale.getLabel({ value: Math.round(t) }) : t.toFixed(Math.min(r, 20)); return X(i) ? i(t, o) : U(i) ? i.replace("{value}", o) : o }, e.prototype._showDataInfo = function (t) { t = this._dragging || t; var e = this._displayables, n = e.handleLabels; n[0].attr("invisible", !t), n[1].attr("invisible", !t), e.moveHandle && this.api[t ? "enterEmphasis" : "leaveEmphasis"](e.moveHandle, 1) }, e.prototype._onDragMove = function (t, e, n, i) { this._dragging = !0, de(i.event); var r = zh([e, n], this._displayables.sliderGroup.getLocalTransform(), !0), o = this._updateInterval(t, r[0]), a = this.dataZoomModel.get("realtime"); this._updateView(!a), o && a && this._dispatchZoomAction(!0) }, e.prototype._onDragEnd = function () { this._dragging = !1, this._showDataInfo(!1), !this.dataZoomModel.get("realtime") && this._dispatchZoomAction(!1) }, e.prototype._onClickPanel = function (t) { var e = this._size, n = this._displayables.sliderGroup.transformCoordToLocal(t.offsetX, t.offsetY); if (!(n[0] < 0 || n[0] > e[0] || n[1] < 0 || n[1] > e[1])) { var i = this._handleEnds, r = (i[0] + i[1]) / 2, o = this._updateInterval("all", n[0] - r); this._updateView(), o && this._dispatchZoomAction(!1) } }, e.prototype._onBrushStart = function (t) { var e = t.offsetX, n = t.offsetY; this._brushStart = new De(e, n), this._brushing = !0, this._brushStartTime = +new Date }, e.prototype._onBrushEnd = function (t) { if (this._brushing) { var e = this._displayables.brushRect; if (this._brushing = !1, e) { e.attr("ignore", !0); var n = e.shape; if (!(+new Date - this._brushStartTime < 200 && Math.abs(n.width) < 5)) { var i = this._getViewExtent(), r = [0, 100]; this._range = jr([Xr(n.x, i, r, !0), Xr(n.x + n.width, i, r, !0)]), this._handleEnds = [n.x, n.x + n.width], this._updateView(), this._dispatchZoomAction(!1) } } } }, e.prototype._onBrush = function (t) { this._brushing && (de(t.event), this._updateBrushRect(t.offsetX, t.offsetY)) }, e.prototype._updateBrushRect = function (t, e) { var n = this._displayables, i = this.dataZoomModel, r = n.brushRect; r || (r = n.brushRect = new pF({ silent: !0, style: i.getModel("brushStyle").getItemStyle() }), n.sliderGroup.add(r)), r.attr("ignore", !1); var o = this._brushStart, a = this._displayables.sliderGroup, s = a.transformCoordToLocal(t, e), l = a.transformCoordToLocal(o.x, o.y), u = this._size; s[0] = Math.max(Math.min(u[0], s[0]), 0), r.setShape({ x: l[0], y: 0, width: s[0] - l[0], height: u[1] }) }, e.prototype._dispatchZoomAction = function (t) { var e = this._range; this.api.dispatchAction({ type: "dataZoom", from: this.uid, dataZoomId: this.dataZoomModel.id, animation: t ? yF : null, start: e[0], end: e[1] }) }, e.prototype._findCoordRect = function () { var t, e = jE(this.dataZoomModel).infoList; if (!t && e.length) { var n = e[0].model.coordinateSystem; t = n.getRect && n.getRect() } if (!t) { var i = this.api.getWidth(), r = this.api.getHeight(); t = { x: .2 * i, y: .2 * r, width: .6 * i, height: .6 * r } } return t }, e.type = "dataZoom.slider", e }(QE); function mF(t) { return "vertical" === t ? "ns-resize" : "ew-resize" } function xF(t) { t.registerComponentModel(cF), t.registerComponentView(vF), az(t) } var _F = function (t, e, n) { var i = T((bF[t] || {})[e]); return n && Y(i) ? i[i.length - 1] : i }, bF = { color: { active: ["#006edd", "#e0ffff"], inactive: ["rgba(0,0,0,0)"] }, colorHue: { active: [0, 360], inactive: [0, 0] }, colorSaturation: { active: [.3, 1], inactive: [0, 0] }, colorLightness: { active: [.9, .5], inactive: [0, 0] }, colorAlpha: { active: [.3, 1], inactive: [0, 0] }, opacity: { active: [.3, 1], inactive: [0, 0] }, symbol: { active: ["circle", "roundRect", "diamond"], inactive: ["none"] }, symbolSize: { active: [10, 50], inactive: [0, 0] } }, wF = _D.mapVisual, SF = _D.eachVisual, MF = Y, IF = E, TF = jr, CF = Xr, DF = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.stateList = ["inRange", "outOfRange"], n.replacableOptionKeys = ["inRange", "outOfRange", "target", "controller", "color"], n.layoutMode = { type: "box", ignoreSize: !0 }, n.dataBound = [-1 / 0, 1 / 0], n.targetVisuals = {}, n.controllerVisuals = {}, n } return n(e, t), e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n) }, e.prototype.optionUpdated = function (t, e) { var n = this.option; !e && wV(n, t, this.replacableOptionKeys), this.textStyleModel = this.getModel("textStyle"), this.resetItemSize(), this.completeVisualOption() }, e.prototype.resetVisual = function (t) { var e = this.stateList; t = W(t, this), this.controllerVisuals = bV(this.option.controller, e, t), this.targetVisuals = bV(this.option.target, e, t) }, e.prototype.getItemSymbol = function () { return null }, e.prototype.getTargetSeriesIndices = function () { var t = this.option.seriesIndex, e = []; return null == t || "all" === t ? this.ecModel.eachSeries((function (t, n) { e.push(n) })) : e = bo(t), e }, e.prototype.eachTargetSeries = function (t, e) { E(this.getTargetSeriesIndices(), (function (n) { var i = this.ecModel.getSeriesByIndex(n); i && t.call(e, i) }), this) }, e.prototype.isTargetSeries = function (t) { var e = !1; return this.eachTargetSeries((function (n) { n === t && (e = !0) })), e }, e.prototype.formatValueText = function (t, e, n) { var i, r = this.option, o = r.precision, a = this.dataBound, s = r.formatter; n = n || ["<", ">"], Y(t) && (t = t.slice(), i = !0); var l = e ? t : i ? [u(t[0]), u(t[1])] : u(t); return U(s) ? s.replace("{value}", i ? l[0] : l).replace("{value2}", i ? l[1] : l) : X(s) ? i ? s(t[0], t[1]) : s(t) : i ? t[0] === a[0] ? n[0] + " " + l[1] : t[1] === a[1] ? n[1] + " " + l[0] : l[0] + " - " + l[1] : l; function u(t) { return t === a[0] ? "min" : t === a[1] ? "max" : (+t).toFixed(Math.min(o, 20)) } }, e.prototype.resetExtent = function () { var t = this.option, e = TF([t.min, t.max]); this._dataExtent = e }, e.prototype.getDataDimensionIndex = function (t) { var e = this.option.dimension; if (null != e) return t.getDimensionIndex(e); for (var n = t.dimensions, i = n.length - 1; i >= 0; i--) { var r = n[i], o = t.getDimensionInfo(r); if (!o.isCalculationCoord) return o.storeDimIndex } }, e.prototype.getExtent = function () { return this._dataExtent.slice() }, e.prototype.completeVisualOption = function () { var t = this.ecModel, e = this.option, n = { inRange: e.inRange, outOfRange: e.outOfRange }, i = e.target || (e.target = {}), r = e.controller || (e.controller = {}); C(i, n), C(r, n); var o = this.isCategory(); function a(n) { MF(e.color) && !n.inRange && (n.inRange = { color: e.color.slice().reverse() }), n.inRange = n.inRange || { color: t.get("gradientColor") } } a.call(this, i), a.call(this, r), function (t, e, n) { var i = t[e], r = t[n]; i && !r && (r = t[n] = {}, IF(i, (function (t, e) { if (_D.isValidType(e)) { var n = _F(e, "inactive", o); null != n && (r[e] = n, "color" !== e || r.hasOwnProperty("opacity") || r.hasOwnProperty("colorAlpha") || (r.opacity = [0, 0])) } }))) }.call(this, i, "inRange", "outOfRange"), function (t) { var e = (t.inRange || {}).symbol || (t.outOfRange || {}).symbol, n = (t.inRange || {}).symbolSize || (t.outOfRange || {}).symbolSize, i = this.get("inactiveColor"), r = this.getItemSymbol() || "roundRect"; IF(this.stateList, (function (a) { var s = this.itemSize, l = t[a]; l || (l = t[a] = { color: o ? i : [i] }), null == l.symbol && (l.symbol = e && T(e) || (o ? r : [r])), null == l.symbolSize && (l.symbolSize = n && T(n) || (o ? s[0] : [s[0], s[0]])), l.symbol = wF(l.symbol, (function (t) { return "none" === t ? r : t })); var u = l.symbolSize; if (null != u) { var h = -1 / 0; SF(u, (function (t) { t > h && (h = t) })), l.symbolSize = wF(u, (function (t) { return CF(t, [0, h], [0, s[0]], !0) })) } }), this) }.call(this, r) }, e.prototype.resetItemSize = function () { this.itemSize = [parseFloat(this.get("itemWidth")), parseFloat(this.get("itemHeight"))] }, e.prototype.isCategory = function () { return !!this.option.categories }, e.prototype.setSelected = function (t) { }, e.prototype.getSelected = function () { return null }, e.prototype.getValueState = function (t) { return null }, e.prototype.getVisualMeta = function (t) { return null }, e.type = "visualMap", e.dependencies = ["series"], e.defaultOption = { show: !0, z: 4, seriesIndex: "all", min: 0, max: 200, left: 0, right: null, top: null, bottom: 0, itemWidth: null, itemHeight: null, inverse: !1, orient: "vertical", backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", contentColor: "#5793f3", inactiveColor: "#aaa", borderWidth: 0, padding: 5, textGap: 10, precision: 0, textStyle: { color: "#333" } }, e }(Rp), AF = [20, 140], kF = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.optionUpdated = function (e, n) { t.prototype.optionUpdated.apply(this, arguments), this.resetExtent(), this.resetVisual((function (t) { t.mappingMethod = "linear", t.dataExtent = this.getExtent() })), this._resetRange() }, e.prototype.resetItemSize = function () { t.prototype.resetItemSize.apply(this, arguments); var e = this.itemSize; (null == e[0] || isNaN(e[0])) && (e[0] = AF[0]), (null == e[1] || isNaN(e[1])) && (e[1] = AF[1]) }, e.prototype._resetRange = function () { var t = this.getExtent(), e = this.option.range; !e || e.auto ? (t.auto = 1, this.option.range = t) : Y(e) && (e[0] > e[1] && e.reverse(), e[0] = Math.max(e[0], t[0]), e[1] = Math.min(e[1], t[1])) }, e.prototype.completeVisualOption = function () { t.prototype.completeVisualOption.apply(this, arguments), E(this.stateList, (function (t) { var e = this.option.controller[t].symbolSize; e && e[0] !== e[1] && (e[0] = e[1] / 3) }), this) }, e.prototype.setSelected = function (t) { this.option.range = t.slice(), this._resetRange() }, e.prototype.getSelected = function () { var t = this.getExtent(), e = jr((this.get("range") || []).slice()); return e[0] > t[1] && (e[0] = t[1]), e[1] > t[1] && (e[1] = t[1]), e[0] < t[0] && (e[0] = t[0]), e[1] < t[0] && (e[1] = t[0]), e }, e.prototype.getValueState = function (t) { var e = this.option.range, n = this.getExtent(); return (e[0] <= n[0] || e[0] <= t) && (e[1] >= n[1] || t <= e[1]) ? "inRange" : "outOfRange" }, e.prototype.findTargetDataIndices = function (t) { var e = []; return this.eachTargetSeries((function (n) { var i = [], r = n.getData(); r.each(this.getDataDimensionIndex(r), (function (e, n) { t[0] <= e && e <= t[1] && i.push(n) }), this), e.push({ seriesId: n.id, dataIndex: i }) }), this), e }, e.prototype.getVisualMeta = function (t) { var e = LF(this, "outOfRange", this.getExtent()), n = LF(this, "inRange", this.option.range.slice()), i = []; function r(e, n) { i.push({ value: e, color: t(e, n) }) } for (var o = 0, a = 0, s = n.length, l = e.length; a < l && (!n.length || e[a] <= n[0]); a++)e[a] < n[o] && r(e[a], "outOfRange"); for (var u = 1; o < s; o++, u = 0)u && i.length && r(n[o], "outOfRange"), r(n[o], "inRange"); for (u = 1; a < l; a++)(!n.length || n[n.length - 1] < e[a]) && (u && (i.length && r(i[i.length - 1].value, "outOfRange"), u = 0), r(e[a], "outOfRange")); var h = i.length; return { stops: i, outerColors: [h ? i[0].color : "transparent", h ? i[h - 1].color : "transparent"] } }, e.type = "visualMap.continuous", e.defaultOption = Cc(DF.defaultOption, { align: "auto", calculable: !1, hoverLink: !0, realtime: !0, handleIcon: "path://M-11.39,9.77h0a3.5,3.5,0,0,1-3.5,3.5h-22a3.5,3.5,0,0,1-3.5-3.5h0a3.5,3.5,0,0,1,3.5-3.5h22A3.5,3.5,0,0,1-11.39,9.77Z", handleSize: "120%", handleStyle: { borderColor: "#fff", borderWidth: 1 }, indicatorIcon: "circle", indicatorSize: "50%", indicatorStyle: { borderColor: "#fff", borderWidth: 2, shadowBlur: 2, shadowOffsetX: 1, shadowOffsetY: 1, shadowColor: "rgba(0,0,0,0.2)" } }), e }(DF); function LF(t, e, n) { if (n[0] === n[1]) return n.slice(); for (var i = (n[1] - n[0]) / 200, r = n[0], o = [], a = 0; a <= 200 && r < n[1]; a++)o.push(r), r += i; return o.push(n[1]), o } var PF = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n.autoPositionValues = { left: 1, right: 1, top: 1, bottom: 1 }, n } return n(e, t), e.prototype.init = function (t, e) { this.ecModel = t, this.api = e }, e.prototype.render = function (t, e, n, i) { this.visualMapModel = t, !1 !== t.get("show") ? this.doRender(t, e, n, i) : this.group.removeAll() }, e.prototype.renderBackground = function (t) { var e = this.visualMapModel, n = fp(e.get("padding") || 0), i = t.getBoundingRect(); t.add(new zs({ z2: -1, silent: !0, shape: { x: i.x - n[3], y: i.y - n[0], width: i.width + n[3] + n[1], height: i.height + n[0] + n[2] }, style: { fill: e.get("backgroundColor"), stroke: e.get("borderColor"), lineWidth: e.get("borderWidth") } })) }, e.prototype.getControllerVisual = function (t, e, n) { var i = (n = n || {}).forceState, r = this.visualMapModel, o = {}; if ("color" === e) { var a = r.get("contentColor"); o.color = a } function s(t) { return o[t] } function l(t, e) { o[t] = e } var u = r.controllerVisuals[i || r.getValueState(t)]; return E(_D.prepareVisualTypes(u), (function (i) { var r = u[i]; n.convertOpacityToAlpha && "opacity" === i && (i = "colorAlpha", r = u.__alphaForOpacity), _D.dependsOn(i, e) && r && r.applyVisual(t, s, l) })), o[e] }, e.prototype.positionGroup = function (t) { var e = this.visualMapModel, n = this.api; Dp(t, e.getBoxLayoutParams(), { width: n.getWidth(), height: n.getHeight() }) }, e.prototype.doRender = function (t, e, n, i) { }, e.type = "visualMap", e }(Tg), OF = [["left", "right", "width"], ["top", "bottom", "height"]]; function RF(t, e, n) { var i = t.option, r = i.align; if (null != r && "auto" !== r) return r; for (var o = { width: e.getWidth(), height: e.getHeight() }, a = "horizontal" === i.orient ? 1 : 0, s = OF[a], l = [0, null, 10], u = {}, h = 0; h < 3; h++)u[OF[1 - a][h]] = l[h], u[s[h]] = 2 === h ? n[0] : i[s[h]]; var c = [["x", "width", 3], ["y", "height", 0]][a], p = Cp(u, o, i.padding); return s[(p.margin[c[2]] || 0) + p[c[0]] + .5 * p[c[1]] < .5 * o[c[1]] ? 0 : 1] } function NF(t, e) { return E(t || [], (function (t) { null != t.dataIndex && (t.dataIndexInside = t.dataIndex, t.dataIndex = null), t.highlightKey = "visualMap" + (e ? e.componentIndex : "") })), t } var EF = Xr, zF = E, VF = Math.min, BF = Math.max, FF = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._shapes = {}, n._dataInterval = [], n._handleEnds = [], n._hoverLinkDataIndices = [], n } return n(e, t), e.prototype.doRender = function (t, e, n, i) { this._api = n, i && "selectDataRange" === i.type && i.from === this.uid || this._buildView() }, e.prototype._buildView = function () { this.group.removeAll(); var t = this.visualMapModel, e = this.group; this._orient = t.get("orient"), this._useHandle = t.get("calculable"), this._resetInterval(), this._renderBar(e); var n = t.get("text"); this._renderEndsText(e, n, 0), this._renderEndsText(e, n, 1), this._updateView(!0), this.renderBackground(e), this._updateView(), this._enableHoverLinkToSeries(), this._enableHoverLinkFromSeries(), this.positionGroup(e) }, e.prototype._renderEndsText = function (t, e, n) { if (e) { var i = e[1 - n]; i = null != i ? i + "" : ""; var r = this.visualMapModel, o = r.get("textGap"), a = r.itemSize, s = this._shapes.mainGroup, l = this._applyTransform([a[0] / 2, 0 === n ? -o : a[1] + o], s), u = this._applyTransform(0 === n ? "bottom" : "top", s), h = this._orient, c = this.visualMapModel.textStyleModel; this.group.add(new Fs({ style: nc(c, { x: l[0], y: l[1], verticalAlign: "horizontal" === h ? "middle" : u, align: "horizontal" === h ? u : "center", text: i }) })) } }, e.prototype._renderBar = function (t) { var e = this.visualMapModel, n = this._shapes, i = e.itemSize, r = this._orient, o = this._useHandle, a = RF(e, this.api, i), s = n.mainGroup = this._createBarGroup(a), l = new zr; s.add(l), l.add(n.outOfRange = GF()), l.add(n.inRange = GF(null, o ? HF(this._orient) : null, W(this._dragHandle, this, "all", !1), W(this._dragHandle, this, "all", !0))), l.setClipPath(new zs({ shape: { x: 0, y: 0, width: i[0], height: i[1], r: 3 } })); var u = e.textStyleModel.getTextRect("国"), h = BF(u.width, u.height); o && (n.handleThumbs = [], n.handleLabels = [], n.handleLabelPoints = [], this._createHandle(e, s, 0, i, h, r), this._createHandle(e, s, 1, i, h, r)), this._createIndicator(e, s, i, h, r), t.add(s) }, e.prototype._createHandle = function (t, e, n, i, r, o) { var a = W(this._dragHandle, this, n, !1), s = W(this._dragHandle, this, n, !0), l = Ir(t.get("handleSize"), i[0]), u = Wy(t.get("handleIcon"), -l / 2, -l / 2, l, l, null, !0), h = HF(this._orient); u.attr({ cursor: h, draggable: !0, drift: a, ondragend: s, onmousemove: function (t) { de(t.event) } }), u.x = i[0] / 2, u.useStyle(t.getModel("handleStyle").getItemStyle()), u.setStyle({ strokeNoScale: !0, strokeFirst: !0 }), u.style.lineWidth *= 2, u.ensureState("emphasis").style = t.getModel(["emphasis", "handleStyle"]).getItemStyle(), ql(u, !0), e.add(u); var c = this.visualMapModel.textStyleModel, p = new Fs({ cursor: h, draggable: !0, drift: a, onmousemove: function (t) { de(t.event) }, ondragend: s, style: nc(c, { x: 0, y: 0, text: "" }) }); p.ensureState("blur").style = { opacity: .1 }, p.stateTransition = { duration: 200 }, this.group.add(p); var d = [l, 0], f = this._shapes; f.handleThumbs[n] = u, f.handleLabelPoints[n] = d, f.handleLabels[n] = p }, e.prototype._createIndicator = function (t, e, n, i, r) { var o = Ir(t.get("indicatorSize"), n[0]), a = Wy(t.get("indicatorIcon"), -o / 2, -o / 2, o, o, null, !0); a.attr({ cursor: "move", invisible: !0, silent: !0, x: n[0] / 2 }); var s = t.getModel("indicatorStyle").getItemStyle(); if (a instanceof ks) { var l = a.style; a.useStyle(A({ image: l.image, x: l.x, y: l.y, width: l.width, height: l.height }, s)) } else a.useStyle(s); e.add(a); var u = this.visualMapModel.textStyleModel, h = new Fs({ silent: !0, invisible: !0, style: nc(u, { x: 0, y: 0, text: "" }) }); this.group.add(h); var c = [("horizontal" === r ? i / 2 : 6) + n[0] / 2, 0], p = this._shapes; p.indicator = a, p.indicatorLabel = h, p.indicatorLabelPoint = c, this._firstShowIndicator = !0 }, e.prototype._dragHandle = function (t, e, n, i) { if (this._useHandle) { if (this._dragging = !e, !e) { var r = this._applyTransform([n, i], this._shapes.mainGroup, !0); this._updateInterval(t, r[1]), this._hideIndicator(), this._updateView() } e === !this.visualMapModel.get("realtime") && this.api.dispatchAction({ type: "selectDataRange", from: this.uid, visualMapId: this.visualMapModel.id, selected: this._dataInterval.slice() }), e ? !this._hovering && this._clearHoverLinkToSeries() : WF(this.visualMapModel) && this._doHoverLinkToSeries(this._handleEnds[t], !1) } }, e.prototype._resetInterval = function () { var t = this.visualMapModel, e = this._dataInterval = t.getSelected(), n = t.getExtent(), i = [0, t.itemSize[1]]; this._handleEnds = [EF(e[0], n, i, !0), EF(e[1], n, i, !0)] }, e.prototype._updateInterval = function (t, e) { e = e || 0; var n = this.visualMapModel, i = this._handleEnds, r = [0, n.itemSize[1]]; Ck(e, i, r, t, 0); var o = n.getExtent(); this._dataInterval = [EF(i[0], r, o, !0), EF(i[1], r, o, !0)] }, e.prototype._updateView = function (t) { var e = this.visualMapModel, n = e.getExtent(), i = this._shapes, r = [0, e.itemSize[1]], o = t ? r : this._handleEnds, a = this._createBarVisual(this._dataInterval, n, o, "inRange"), s = this._createBarVisual(n, n, r, "outOfRange"); i.inRange.setStyle({ fill: a.barColor }).setShape("points", a.barPoints), i.outOfRange.setStyle({ fill: s.barColor }).setShape("points", s.barPoints), this._updateHandle(o, a) }, e.prototype._createBarVisual = function (t, e, n, i) { var r = { forceState: i, convertOpacityToAlpha: !0 }, o = this._makeColorGradient(t, r), a = [this.getControllerVisual(t[0], "symbolSize", r), this.getControllerVisual(t[1], "symbolSize", r)], s = this._createBarPoints(n, a); return { barColor: new nh(0, 0, 0, 1, o), barPoints: s, handlesColor: [o[0].color, o[o.length - 1].color] } }, e.prototype._makeColorGradient = function (t, e) { var n = [], i = (t[1] - t[0]) / 100; n.push({ color: this.getControllerVisual(t[0], "color", e), offset: 0 }); for (var r = 1; r < 100; r++) { var o = t[0] + i * r; if (o > t[1]) break; n.push({ color: this.getControllerVisual(o, "color", e), offset: r / 100 }) } return n.push({ color: this.getControllerVisual(t[1], "color", e), offset: 1 }), n }, e.prototype._createBarPoints = function (t, e) { var n = this.visualMapModel.itemSize; return [[n[0] - e[0], t[0]], [n[0], t[0]], [n[0], t[1]], [n[0] - e[1], t[1]]] }, e.prototype._createBarGroup = function (t) { var e = this._orient, n = this.visualMapModel.get("inverse"); return new zr("horizontal" !== e || n ? "horizontal" === e && n ? { scaleX: "bottom" === t ? -1 : 1, rotation: -Math.PI / 2 } : "vertical" !== e || n ? { scaleX: "left" === t ? 1 : -1 } : { scaleX: "left" === t ? 1 : -1, scaleY: -1 } : { scaleX: "bottom" === t ? 1 : -1, rotation: Math.PI / 2 }) }, e.prototype._updateHandle = function (t, e) { if (this._useHandle) { var n = this._shapes, i = this.visualMapModel, r = n.handleThumbs, o = n.handleLabels, a = i.itemSize, s = i.getExtent(); zF([0, 1], (function (l) { var u = r[l]; u.setStyle("fill", e.handlesColor[l]), u.y = t[l]; var h = EF(t[l], [0, a[1]], s, !0), c = this.getControllerVisual(h, "symbolSize"); u.scaleX = u.scaleY = c / a[0], u.x = a[0] - c / 2; var p = zh(n.handleLabelPoints[l], Eh(u, this.group)); o[l].setStyle({ x: p[0], y: p[1], text: i.formatValueText(this._dataInterval[l]), verticalAlign: "middle", align: "vertical" === this._orient ? this._applyTransform("left", n.mainGroup) : "center" }) }), this) } }, e.prototype._showIndicator = function (t, e, n, i) { var r = this.visualMapModel, o = r.getExtent(), a = r.itemSize, s = [0, a[1]], l = this._shapes, u = l.indicator; if (u) { u.attr("invisible", !1); var h = this.getControllerVisual(t, "color", { convertOpacityToAlpha: !0 }), c = this.getControllerVisual(t, "symbolSize"), p = EF(t, o, s, !0), d = a[0] - c / 2, f = { x: u.x, y: u.y }; u.y = p, u.x = d; var g = zh(l.indicatorLabelPoint, Eh(u, this.group)), y = l.indicatorLabel; y.attr("invisible", !1); var v = this._applyTransform("left", l.mainGroup), m = "horizontal" === this._orient; y.setStyle({ text: (n || "") + r.formatValueText(e), verticalAlign: m ? v : "middle", align: m ? "center" : v }); var x = { x: d, y: p, style: { fill: h } }, _ = { style: { x: g[0], y: g[1] } }; if (r.ecModel.isAnimationEnabled() && !this._firstShowIndicator) { var b = { duration: 100, easing: "cubicInOut", additive: !0 }; u.x = f.x, u.y = f.y, u.animateTo(x, b), y.animateTo(_, b) } else u.attr(x), y.attr(_); this._firstShowIndicator = !1; var w = this._shapes.handleLabels; if (w) for (var S = 0; S < w.length; S++)this._api.enterBlur(w[S]) } }, e.prototype._enableHoverLinkToSeries = function () { var t = this; this._shapes.mainGroup.on("mousemove", (function (e) { if (t._hovering = !0, !t._dragging) { var n = t.visualMapModel.itemSize, i = t._applyTransform([e.offsetX, e.offsetY], t._shapes.mainGroup, !0, !0); i[1] = VF(BF(0, i[1]), n[1]), t._doHoverLinkToSeries(i[1], 0 <= i[0] && i[0] <= n[0]) } })).on("mouseout", (function () { t._hovering = !1, !t._dragging && t._clearHoverLinkToSeries() })) }, e.prototype._enableHoverLinkFromSeries = function () { var t = this.api.getZr(); this.visualMapModel.option.hoverLink ? (t.on("mouseover", this._hoverLinkFromSeriesMouseOver, this), t.on("mouseout", this._hideIndicator, this)) : this._clearHoverLinkFromSeries() }, e.prototype._doHoverLinkToSeries = function (t, e) { var n = this.visualMapModel, i = n.itemSize; if (n.option.hoverLink) { var r = [0, i[1]], o = n.getExtent(); t = VF(BF(r[0], t), r[1]); var a = function (t, e, n) { var i = 6, r = t.get("hoverLinkDataSize"); r && (i = EF(r, e, n, !0) / 2); return i }(n, o, r), s = [t - a, t + a], l = EF(t, r, o, !0), u = [EF(s[0], r, o, !0), EF(s[1], r, o, !0)]; s[0] < r[0] && (u[0] = -1 / 0), s[1] > r[1] && (u[1] = 1 / 0), e && (u[0] === -1 / 0 ? this._showIndicator(l, u[1], "< ", a) : u[1] === 1 / 0 ? this._showIndicator(l, u[0], "> ", a) : this._showIndicator(l, l, "≈ ", a)); var h = this._hoverLinkDataIndices, c = []; (e || WF(n)) && (c = this._hoverLinkDataIndices = n.findTargetDataIndices(u)); var p = function (t, e) { var n = {}, i = {}; return r(t || [], n), r(e || [], i, n), [o(n), o(i)]; function r(t, e, n) { for (var i = 0, r = t.length; i < r; i++) { var o = Ao(t[i].seriesId, null); if (null == o) return; for (var a = bo(t[i].dataIndex), s = n && n[o], l = 0, u = a.length; l < u; l++) { var h = a[l]; s && s[h] ? s[h] = null : (e[o] || (e[o] = {}))[h] = 1 } } } function o(t, e) { var n = []; for (var i in t) if (t.hasOwnProperty(i) && null != t[i]) if (e) n.push(+i); else { var r = o(t[i], !0); r.length && n.push({ seriesId: i, dataIndex: r }) } return n } }(h, c); this._dispatchHighDown("downplay", NF(p[0], n)), this._dispatchHighDown("highlight", NF(p[1], n)) } }, e.prototype._hoverLinkFromSeriesMouseOver = function (t) { var e; if (ky(t.target, (function (t) { var n = Qs(t); if (null != n.dataIndex) return e = n, !0 }), !0), e) { var n = this.ecModel.getSeriesByIndex(e.seriesIndex), i = this.visualMapModel; if (i.isTargetSeries(n)) { var r = n.getData(e.dataType), o = r.getStore().get(i.getDataDimensionIndex(r), e.dataIndex); isNaN(o) || this._showIndicator(o, o) } } }, e.prototype._hideIndicator = function () { var t = this._shapes; t.indicator && t.indicator.attr("invisible", !0), t.indicatorLabel && t.indicatorLabel.attr("invisible", !0); var e = this._shapes.handleLabels; if (e) for (var n = 0; n < e.length; n++)this._api.leaveBlur(e[n]) }, e.prototype._clearHoverLinkToSeries = function () { this._hideIndicator(); var t = this._hoverLinkDataIndices; this._dispatchHighDown("downplay", NF(t, this.visualMapModel)), t.length = 0 }, e.prototype._clearHoverLinkFromSeries = function () { this._hideIndicator(); var t = this.api.getZr(); t.off("mouseover", this._hoverLinkFromSeriesMouseOver), t.off("mouseout", this._hideIndicator) }, e.prototype._applyTransform = function (t, e, n, i) { var r = Eh(e, i ? null : this.group); return Y(t) ? zh(t, r, n) : Vh(t, r, n) }, e.prototype._dispatchHighDown = function (t, e) { e && e.length && this.api.dispatchAction({ type: t, batch: e }) }, e.prototype.dispose = function () { this._clearHoverLinkFromSeries(), this._clearHoverLinkToSeries() }, e.prototype.remove = function () { this._clearHoverLinkFromSeries(), this._clearHoverLinkToSeries() }, e.type = "visualMap.continuous", e }(PF); function GF(t, e, n, i) { return new Wu({ shape: { points: t }, draggable: !!n, cursor: e, drift: n, onmousemove: function (t) { de(t.event) }, ondragend: i }) } function WF(t) { var e = t.get("hoverLinkOnHandle"); return !!(null == e ? t.get("realtime") : e) } function HF(t) { return "vertical" === t ? "ns-resize" : "ew-resize" } var YF = { type: "selectDataRange", event: "dataRangeSelected", update: "update" }, XF = function (t, e) { e.eachComponent({ mainType: "visualMap", query: t }, (function (e) { e.setSelected(t.selected) })) }, UF = [{ createOnAllSeries: !0, reset: function (t, e) { var n = []; return e.eachComponent("visualMap", (function (e) { var i, r, o, a, s, l = t.pipelineContext; !e.isTargetSeries(t) || l && l.large || n.push((i = e.stateList, r = e.targetVisuals, o = W(e.getValueState, e), a = e.getDataDimensionIndex(t.getData()), s = {}, E(i, (function (t) { var e = _D.prepareVisualTypes(r[t]); s[t] = e })), { progress: function (t, e) { var n, i; function l(t) { return Iy(e, i, t) } function u(t, n) { Cy(e, i, t, n) } null != a && (n = e.getDimensionIndex(a)); for (var h = e.getStore(); null != (i = t.next());) { var c = e.getRawDataItem(i); if (!c || !1 !== c.visualMap) for (var p = null != a ? h.get(n, i) : i, d = o(p), f = r[d], g = s[d], y = 0, v = g.length; y < v; y++) { var m = g[y]; f[m] && f[m].applyVisual(p, l, u) } } } })) })), n } }, { createOnAllSeries: !0, reset: function (t, e) { var n = t.getData(), i = []; e.eachComponent("visualMap", (function (e) { if (e.isTargetSeries(t)) { var r = e.getVisualMeta(W(ZF, null, t, e)) || { stops: [], outerColors: [] }, o = e.getDataDimensionIndex(n); o >= 0 && (r.dimension = o, i.push(r)) } })), t.getData().setVisual("visualMeta", i) } }]; function ZF(t, e, n, i) { for (var r = e.targetVisuals[i], o = _D.prepareVisualTypes(r), a = { color: Ty(t.getData(), "color") }, s = 0, l = o.length; s < l; s++) { var u = o[s], h = r["opacity" === u ? "__alphaForOpacity" : u]; h && h.applyVisual(n, c, p) } return a.color; function c(t) { return a[t] } function p(t, e) { a[t] = e } } var jF = E; function qF(t) { var e = t && t.visualMap; Y(e) || (e = e ? [e] : []), jF(e, (function (t) { if (t) { KF(t, "splitList") && !KF(t, "pieces") && (t.pieces = t.splitList, delete t.splitList); var e = t.pieces; e && Y(e) && jF(e, (function (t) { q(t) && (KF(t, "start") && !KF(t, "min") && (t.min = t.start), KF(t, "end") && !KF(t, "max") && (t.max = t.end)) })) } })) } function KF(t, e) { return t && t.hasOwnProperty && t.hasOwnProperty(e) } var $F = !1; function JF(t) { $F || ($F = !0, t.registerSubTypeDefaulter("visualMap", (function (t) { return t.categories || (t.pieces ? t.pieces.length > 0 : t.splitNumber > 0) && !t.calculable ? "piecewise" : "continuous" })), t.registerAction(YF, XF), E(UF, (function (e) { t.registerVisual(t.PRIORITY.VISUAL.COMPONENT, e) })), t.registerPreprocessor(qF)) } function QF(t) { t.registerComponentModel(kF), t.registerComponentView(FF), JF(t) } var tG = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._pieceList = [], n } return n(e, t), e.prototype.optionUpdated = function (e, n) { t.prototype.optionUpdated.apply(this, arguments), this.resetExtent(); var i = this._mode = this._determineMode(); this._pieceList = [], eG[this._mode].call(this, this._pieceList), this._resetSelected(e, n); var r = this.option.categories; this.resetVisual((function (t, e) { "categories" === i ? (t.mappingMethod = "category", t.categories = T(r)) : (t.dataExtent = this.getExtent(), t.mappingMethod = "piecewise", t.pieceList = z(this._pieceList, (function (t) { return t = T(t), "inRange" !== e && (t.visual = null), t }))) })) }, e.prototype.completeVisualOption = function () { var e = this.option, n = {}, i = _D.listVisualTypes(), r = this.isCategory(); function o(t, e, n) { return t && t[e] && t[e].hasOwnProperty(n) } E(e.pieces, (function (t) { E(i, (function (e) { t.hasOwnProperty(e) && (n[e] = 1) })) })), E(n, (function (t, n) { var i = !1; E(this.stateList, (function (t) { i = i || o(e, t, n) || o(e.target, t, n) }), this), !i && E(this.stateList, (function (t) { (e[t] || (e[t] = {}))[n] = _F(n, "inRange" === t ? "active" : "inactive", r) })) }), this), t.prototype.completeVisualOption.apply(this, arguments) }, e.prototype._resetSelected = function (t, e) { var n = this.option, i = this._pieceList, r = (e ? n : t).selected || {}; if (n.selected = r, E(i, (function (t, e) { var n = this.getSelectedMapKey(t); r.hasOwnProperty(n) || (r[n] = !0) }), this), "single" === n.selectedMode) { var o = !1; E(i, (function (t, e) { var n = this.getSelectedMapKey(t); r[n] && (o ? r[n] = !1 : o = !0) }), this) } }, e.prototype.getItemSymbol = function () { return this.get("itemSymbol") }, e.prototype.getSelectedMapKey = function (t) { return "categories" === this._mode ? t.value + "" : t.index + "" }, e.prototype.getPieceList = function () { return this._pieceList }, e.prototype._determineMode = function () { var t = this.option; return t.pieces && t.pieces.length > 0 ? "pieces" : this.option.categories ? "categories" : "splitNumber" }, e.prototype.setSelected = function (t) { this.option.selected = T(t) }, e.prototype.getValueState = function (t) { var e = _D.findPieceIndex(t, this._pieceList); return null != e && this.option.selected[this.getSelectedMapKey(this._pieceList[e])] ? "inRange" : "outOfRange" }, e.prototype.findTargetDataIndices = function (t) { var e = [], n = this._pieceList; return this.eachTargetSeries((function (i) { var r = [], o = i.getData(); o.each(this.getDataDimensionIndex(o), (function (e, i) { _D.findPieceIndex(e, n) === t && r.push(i) }), this), e.push({ seriesId: i.id, dataIndex: r }) }), this), e }, e.prototype.getRepresentValue = function (t) { var e; if (this.isCategory()) e = t.value; else if (null != t.value) e = t.value; else { var n = t.interval || []; e = n[0] === -1 / 0 && n[1] === 1 / 0 ? 0 : (n[0] + n[1]) / 2 } return e }, e.prototype.getVisualMeta = function (t) { if (!this.isCategory()) { var e = [], n = ["", ""], i = this, r = this._pieceList.slice(); if (r.length) { var o = r[0].interval[0]; o !== -1 / 0 && r.unshift({ interval: [-1 / 0, o] }), (o = r[r.length - 1].interval[1]) !== 1 / 0 && r.push({ interval: [o, 1 / 0] }) } else r.push({ interval: [-1 / 0, 1 / 0] }); var a = -1 / 0; return E(r, (function (t) { var e = t.interval; e && (e[0] > a && s([a, e[0]], "outOfRange"), s(e.slice()), a = e[1]) }), this), { stops: e, outerColors: n } } function s(r, o) { var a = i.getRepresentValue({ interval: r }); o || (o = i.getValueState(a)); var s = t(a, o); r[0] === -1 / 0 ? n[0] = s : r[1] === 1 / 0 ? n[1] = s : e.push({ value: r[0], color: s }, { value: r[1], color: s }) } }, e.type = "visualMap.piecewise", e.defaultOption = Cc(DF.defaultOption, { selected: null, minOpen: !1, maxOpen: !1, align: "auto", itemWidth: 20, itemHeight: 14, itemSymbol: "roundRect", pieces: null, categories: null, splitNumber: 5, selectedMode: "multiple", itemGap: 10, hoverLink: !0 }), e }(DF), eG = { splitNumber: function (t) { var e = this.option, n = Math.min(e.precision, 20), i = this.getExtent(), r = e.splitNumber; r = Math.max(parseInt(r, 10), 1), e.splitNumber = r; for (var o = (i[1] - i[0]) / r; +o.toFixed(n) !== o && n < 5;)n++; e.precision = n, o = +o.toFixed(n), e.minOpen && t.push({ interval: [-1 / 0, i[0]], close: [0, 0] }); for (var a = 0, s = i[0]; a < r; s += o, a++) { var l = a === r - 1 ? i[1] : s + o; t.push({ interval: [s, l], close: [1, 1] }) } e.maxOpen && t.push({ interval: [i[1], 1 / 0], close: [0, 0] }), uo(t), E(t, (function (t, e) { t.index = e, t.text = this.formatValueText(t.interval) }), this) }, categories: function (t) { var e = this.option; E(e.categories, (function (e) { t.push({ text: this.formatValueText(e, !0), value: e }) }), this), nG(e, t) }, pieces: function (t) { var e = this.option; E(e.pieces, (function (e, n) { q(e) || (e = { value: e }); var i = { text: "", index: n }; if (null != e.label && (i.text = e.label), e.hasOwnProperty("value")) { var r = i.value = e.value; i.interval = [r, r], i.close = [1, 1] } else { for (var o = i.interval = [], a = i.close = [0, 0], s = [1, 0, 1], l = [-1 / 0, 1 / 0], u = [], h = 0; h < 2; h++) { for (var c = [["gte", "gt", "min"], ["lte", "lt", "max"]][h], p = 0; p < 3 && null == o[h]; p++)o[h] = e[c[p]], a[h] = s[p], u[h] = 2 === p; null == o[h] && (o[h] = l[h]) } u[0] && o[1] === 1 / 0 && (a[0] = 0), u[1] && o[0] === -1 / 0 && (a[1] = 0), o[0] === o[1] && a[0] && a[1] && (i.value = o[0]) } i.visual = _D.retrieveVisuals(e), t.push(i) }), this), nG(e, t), uo(t), E(t, (function (t) { var e = t.close, n = [["<", "≤"][e[1]], [">", "≥"][e[0]]]; t.text = t.text || this.formatValueText(null != t.value ? t.value : t.interval, !1, n) }), this) } }; function nG(t, e) { var n = t.inverse; ("vertical" === t.orient ? !n : n) && e.reverse() } var iG = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n } return n(e, t), e.prototype.doRender = function () { var t = this.group; t.removeAll(); var e = this.visualMapModel, n = e.get("textGap"), i = e.textStyleModel, r = i.getFont(), o = i.getTextColor(), a = this._getItemAlign(), s = e.itemSize, l = this._getViewData(), u = l.endsText, h = it(e.get("showLabel", !0), !u); u && this._renderEndsText(t, u[0], s, h, a), E(l.viewPieceList, (function (i) { var l = i.piece, u = new zr; u.onclick = W(this._onItemClick, this, l), this._enableHoverLink(u, i.indexInModelPieceList); var c = e.getRepresentValue(l); if (this._createItemSymbol(u, c, [0, 0, s[0], s[1]]), h) { var p = this.visualMapModel.getValueState(c); u.add(new Fs({ style: { x: "right" === a ? -n : s[0] + n, y: s[1] / 2, text: l.text, verticalAlign: "middle", align: a, font: r, fill: o, opacity: "outOfRange" === p ? .5 : 1 } })) } t.add(u) }), this), u && this._renderEndsText(t, u[1], s, h, a), Tp(e.get("orient"), t, e.get("itemGap")), this.renderBackground(t), this.positionGroup(t) }, e.prototype._enableHoverLink = function (t, e) { var n = this; t.on("mouseover", (function () { return i("highlight") })).on("mouseout", (function () { return i("downplay") })); var i = function (t) { var i = n.visualMapModel; i.option.hoverLink && n.api.dispatchAction({ type: t, batch: NF(i.findTargetDataIndices(e), i) }) } }, e.prototype._getItemAlign = function () { var t = this.visualMapModel, e = t.option; if ("vertical" === e.orient) return RF(t, this.api, t.itemSize); var n = e.align; return n && "auto" !== n || (n = "left"), n }, e.prototype._renderEndsText = function (t, e, n, i, r) { if (e) { var o = new zr, a = this.visualMapModel.textStyleModel; o.add(new Fs({ style: nc(a, { x: i ? "right" === r ? n[0] : 0 : n[0] / 2, y: n[1] / 2, verticalAlign: "middle", align: i ? r : "center", text: e }) })), t.add(o) } }, e.prototype._getViewData = function () { var t = this.visualMapModel, e = z(t.getPieceList(), (function (t, e) { return { piece: t, indexInModelPieceList: e } })), n = t.get("text"), i = t.get("orient"), r = t.get("inverse"); return ("horizontal" === i ? r : !r) ? e.reverse() : n && (n = n.slice().reverse()), { viewPieceList: e, endsText: n } }, e.prototype._createItemSymbol = function (t, e, n) { t.add(Wy(this.getControllerVisual(e, "symbol"), n[0], n[1], n[2], n[3], this.getControllerVisual(e, "color"))) }, e.prototype._onItemClick = function (t) { var e = this.visualMapModel, n = e.option, i = n.selectedMode; if (i) { var r = T(n.selected), o = e.getSelectedMapKey(t); "single" === i || !0 === i ? (r[o] = !0, E(r, (function (t, e) { r[e] = e === o }))) : r[o] = !r[o], this.api.dispatchAction({ type: "selectDataRange", from: this.uid, visualMapId: this.visualMapModel.id, selected: r }) } }, e.type = "visualMap.piecewise", e }(PF); function rG(t) { t.registerComponentModel(tG), t.registerComponentView(iG), JF(t) } var oG = { label: { enabled: !0 }, decal: { show: !1 } }, aG = Oo(), sG = {}; function lG(t, e) { var n = t.getModel("aria"); if (n.get("enabled")) { var i = T(oG); C(i.label, t.getLocaleModel().get("aria"), !1), C(n.option, i, !1), function () { if (n.getModel("decal").get("show")) { var e = yt(); t.eachSeries((function (t) { if (!t.isColorBySeries()) { var n = e.get(t.type); n || (n = {}, e.set(t.type, n)), aG(t).scope = n } })), t.eachRawSeries((function (e) { if (!t.isSeriesFiltered(e)) if (X(e.enableAriaDecal)) e.enableAriaDecal(); else { var n = e.getData(); if (e.isColorBySeries()) { var i = ud(e.ecModel, e.name, sG, t.getSeriesCount()), r = n.getVisual("decal"); n.setVisual("decal", u(r, i)) } else { var o = e.getRawData(), a = {}, s = aG(e).scope; n.each((function (t) { var e = n.getRawIndex(t); a[e] = t })); var l = o.count(); o.each((function (t) { var i = a[t], r = o.getName(t) || t + "", h = ud(e.ecModel, r, s, l), c = n.getItemVisual(i, "decal"); n.setItemVisual(i, "decal", u(c, h)) })) } } function u(t, e) { var n = t ? A(A({}, e), t) : e; return n.dirty = !0, n } })) } }(), function () { var i = t.getLocaleModel().get("aria"), o = n.getModel("label"); if (o.option = k(o.option, i), !o.get("enabled")) return; var a = e.getZr().dom; if (o.get("description")) return void a.setAttribute("aria-label", o.get("description")); var s, l = t.getSeriesCount(), u = o.get(["data", "maxCount"]) || 10, h = o.get(["series", "maxCount"]) || 10, c = Math.min(l, h); if (l < 1) return; var p = function () { var e = t.get("title"); e && e.length && (e = e[0]); return e && e.text }(); s = p ? r(o.get(["general", "withTitle"]), { title: p }) : o.get(["general", "withoutTitle"]); var d = []; s += r(l > 1 ? o.get(["series", "multiple", "prefix"]) : o.get(["series", "single", "prefix"]), { seriesCount: l }), t.eachSeries((function (e, n) { if (n < c) { var i = void 0, a = e.get("name") ? "withName" : "withoutName"; i = r(i = l > 1 ? o.get(["series", "multiple", a]) : o.get(["series", "single", a]), { seriesId: e.seriesIndex, seriesName: e.get("name"), seriesType: (x = e.subType, t.getLocaleModel().get(["series", "typeNames"])[x] || "自定义图") }); var s = e.getData(); if (s.count() > u) i += r(o.get(["data", "partialData"]), { displayCnt: u }); else i += o.get(["data", "allData"]); for (var h = o.get(["data", "separator", "middle"]), p = o.get(["data", "separator", "end"]), f = [], g = 0; g < s.count(); g++)if (g < u) { var y = s.getName(g), v = s.getValues(g), m = o.get(["data", y ? "withName" : "withoutName"]); f.push(r(m, { name: y, value: v.join(h) })) } i += f.join(h) + p, d.push(i) } var x })); var f = o.getModel(["series", "multiple", "separator"]), g = f.get("middle"), y = f.get("end"); s += d.join(g) + y, a.setAttribute("aria-label", s) }() } function r(t, e) { if (!U(t)) return t; var n = t; return E(e, (function (t, e) { n = n.replace(new RegExp("\\{\\s*" + e + "\\s*\\}", "g"), t) })), n } } function uG(t) { if (t && t.aria) { var e = t.aria; null != e.show && (e.enabled = e.show), e.label = e.label || {}, E(["description", "general", "series", "data"], (function (t) { null != e[t] && (e.label[t] = e[t]) })) } } var hG = { value: "eq", "<": "lt", "<=": "lte", ">": "gt", ">=": "gte", "=": "eq", "!=": "ne", "<>": "ne" }, cG = function () { function t(t) { if (null == (this._condVal = U(t) ? new RegExp(t) : et(t) ? t : null)) { var e = ""; 0, vo(e) } } return t.prototype.evaluate = function (t) { var e = typeof t; return U(e) ? this._condVal.test(t) : !!j(e) && this._condVal.test(t + "") }, t }(), pG = function () { function t() { } return t.prototype.evaluate = function () { return this.value }, t }(), dG = function () { function t() { } return t.prototype.evaluate = function () { for (var t = this.children, e = 0; e < t.length; e++)if (!t[e].evaluate()) return !1; return !0 }, t }(), fG = function () { function t() { } return t.prototype.evaluate = function () { for (var t = this.children, e = 0; e < t.length; e++)if (t[e].evaluate()) return !0; return !1 }, t }(), gG = function () { function t() { } return t.prototype.evaluate = function () { return !this.child.evaluate() }, t }(), yG = function () { function t() { } return t.prototype.evaluate = function () { for (var t = !!this.valueParser, e = (0, this.getValue)(this.valueGetterParam), n = t ? this.valueParser(e) : null, i = 0; i < this.subCondList.length; i++)if (!this.subCondList[i].evaluate(t ? n : e)) return !1; return !0 }, t }(); function vG(t, e) { if (!0 === t || !1 === t) { var n = new pG; return n.value = t, n } var i = ""; return xG(t) || vo(i), t.and ? mG("and", t, e) : t.or ? mG("or", t, e) : t.not ? function (t, e) { var n = t.not, i = ""; 0; xG(n) || vo(i); var r = new gG; r.child = vG(n, e), r.child || vo(i); return r }(t, e) : function (t, e) { for (var n = "", i = e.prepareGetValue(t), r = [], o = G(t), a = t.parser, s = a ? Mf(a) : null, l = 0; l < o.length; l++) { var u = o[l]; if ("parser" !== u && !e.valueGetterAttrMap.get(u)) { var h = _t(hG, u) ? hG[u] : u, c = t[u], p = s ? s(c) : c, d = Af(h, p) || "reg" === h && new cG(p); d || vo(n), r.push(d) } } r.length || vo(n); var f = new yG; return f.valueGetterParam = i, f.valueParser = s, f.getValue = e.getValue, f.subCondList = r, f }(t, e) } function mG(t, e, n) { var i = e[t], r = ""; Y(i) || vo(r), i.length || vo(r); var o = "and" === t ? new dG : new fG; return o.children = z(i, (function (t) { return vG(t, n) })), o.children.length || vo(r), o } function xG(t) { return q(t) && !N(t) } var _G = function () { function t(t, e) { this._cond = vG(t, e) } return t.prototype.evaluate = function () { return this._cond.evaluate() }, t }(); var bG = { type: "echarts:filter", transform: function (t) { for (var e, n, i, r = t.upstream, o = (n = t.config, i = { valueGetterAttrMap: yt({ dimension: !0 }), prepareGetValue: function (t) { var e = "", n = t.dimension; _t(t, "dimension") || vo(e); var i = r.getDimensionInfo(n); return i || vo(e), { dimIdx: i.index } }, getValue: function (t) { return r.retrieveValueFromItem(e, t.dimIdx) } }, new _G(n, i)), a = [], s = 0, l = r.count(); s < l; s++)e = r.getRawDataItem(s), o.evaluate() && a.push(e); return { data: a } } }; var wG = { type: "echarts:sort", transform: function (t) { var e = t.upstream, n = t.config, i = "", r = bo(n); r.length || vo(i); var o = []; E(r, (function (t) { var n = t.dimension, r = t.order, a = t.parser, s = t.incomparable; if (null == n && vo(i), "asc" !== r && "desc" !== r && vo(i), s && "min" !== s && "max" !== s) { var l = ""; 0, vo(l) } if ("asc" !== r && "desc" !== r) { var u = ""; 0, vo(u) } var h = e.getDimensionInfo(n); h || vo(i); var c = a ? Mf(a) : null; a && !c && vo(i), o.push({ dimIdx: h.index, parser: c, comparator: new Cf(r, s) }) })); var a = e.sourceFormat; a !== Fp && a !== Gp && vo(i); for (var s = [], l = 0, u = e.count(); l < u; l++)s.push(e.getRawDataItem(l)); return s.sort((function (t, n) { for (var i = 0; i < o.length; i++) { var r = o[i], a = e.retrieveValueFromItem(t, r.dimIdx), s = e.retrieveValueFromItem(n, r.dimIdx); r.parser && (a = r.parser(a), s = r.parser(s)); var l = r.comparator.evaluate(a, s); if (0 !== l) return l } return 0 })), { data: s } } }; var SG = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "dataset", e } return n(e, t), e.prototype.init = function (e, n, i) { t.prototype.init.call(this, e, n, i), this._sourceManager = new jf(this), qf(this) }, e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), qf(this) }, e.prototype.optionUpdated = function () { this._sourceManager.dirty() }, e.prototype.getSourceManager = function () { return this._sourceManager }, e.type = "dataset", e.defaultOption = { seriesLayoutBy: Xp }, e }(Rp), MG = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "dataset", e } return n(e, t), e.type = "dataset", e }(Tg); var IG = os.CMD; function TG(t, e) { return Math.abs(t - e) < 1e-5 } function CG(t) { var e, n, i, r, o, a = t.data, s = t.len(), l = [], u = 0, h = 0, c = 0, p = 0; function d(t, n) { e && e.length > 2 && l.push(e), e = [t, n] } function f(t, n, i, r) { TG(t, i) && TG(n, r) || e.push(t, n, i, r, i, r) } function g(t, n, i, r, o, a) { var s = Math.abs(n - t), l = 4 * Math.tan(s / 4) / 3, u = n < t ? -1 : 1, h = Math.cos(t), c = Math.sin(t), p = Math.cos(n), d = Math.sin(n), f = h * o + i, g = c * a + r, y = p * o + i, v = d * a + r, m = o * l * u, x = a * l * u; e.push(f - m * c, g + x * h, y + m * d, v - x * p, y, v) } for (var y = 0; y < s;) { var v = a[y++], m = 1 === y; switch (m && (c = u = a[y], p = h = a[y + 1], v !== IG.L && v !== IG.C && v !== IG.Q || (e = [c, p])), v) { case IG.M: u = c = a[y++], h = p = a[y++], d(c, p); break; case IG.L: f(u, h, n = a[y++], i = a[y++]), u = n, h = i; break; case IG.C: e.push(a[y++], a[y++], a[y++], a[y++], u = a[y++], h = a[y++]); break; case IG.Q: n = a[y++], i = a[y++], r = a[y++], o = a[y++], e.push(u + 2 / 3 * (n - u), h + 2 / 3 * (i - h), r + 2 / 3 * (n - r), o + 2 / 3 * (i - o), r, o), u = r, h = o; break; case IG.A: var x = a[y++], _ = a[y++], b = a[y++], w = a[y++], S = a[y++], M = a[y++] + S; y += 1; var I = !a[y++]; n = Math.cos(S) * b + x, i = Math.sin(S) * w + _, m ? d(c = n, p = i) : f(u, h, n, i), u = Math.cos(M) * b + x, h = Math.sin(M) * w + _; for (var T = (I ? -1 : 1) * Math.PI / 2, C = S; I ? C > M : C < M; C += T) { g(C, I ? Math.max(C + T, M) : Math.min(C + T, M), x, _, b, w) } break; case IG.R: c = u = a[y++], p = h = a[y++], n = c + a[y++], i = p + a[y++], d(n, p), f(n, p, n, i), f(n, i, c, i), f(c, i, c, p), f(c, p, n, p); break; case IG.Z: e && f(u, h, c, p), u = c, h = p } } return e && e.length > 2 && l.push(e), l } function DG(t, e, n, i, r, o, a, s, l, u) { if (TG(t, n) && TG(e, i) && TG(r, a) && TG(o, s)) l.push(a, s); else { var h = 2 / u, c = h * h, p = a - t, d = s - e, f = Math.sqrt(p * p + d * d); p /= f, d /= f; var g = n - t, y = i - e, v = r - a, m = o - s, x = g * g + y * y, _ = v * v + m * m; if (x < c && _ < c) l.push(a, s); else { var b = p * g + d * y, w = -p * v - d * m; if (x - b * b < c && b >= 0 && _ - w * w < c && w >= 0) l.push(a, s); else { var S = [], M = []; wn(t, n, r, a, .5, S), wn(e, i, o, s, .5, M), DG(S[0], M[0], S[1], M[1], S[2], M[2], S[3], M[3], l, u), DG(S[4], M[4], S[5], M[5], S[6], M[6], S[7], M[7], l, u) } } } } function AG(t, e, n) { var i = t[e], r = t[1 - e], o = Math.abs(i / r), a = Math.ceil(Math.sqrt(o * n)), s = Math.floor(n / a); 0 === s && (s = 1, a = n); for (var l = [], u = 0; u < a; u++)l.push(s); var h = n - a * s; if (h > 0) for (u = 0; u < h; u++)l[u % a] += 1; return l } function kG(t, e, n) { for (var i = t.r0, r = t.r, o = t.startAngle, a = t.endAngle, s = Math.abs(a - o), l = s * r, u = r - i, h = l > Math.abs(u), c = AG([l, u], h ? 0 : 1, e), p = (h ? s : u) / c.length, d = 0; d < c.length; d++)for (var f = (h ? u : s) / c[d], g = 0; g < c[d]; g++) { var y = {}; h ? (y.startAngle = o + p * d, y.endAngle = o + p * (d + 1), y.r0 = i + f * g, y.r = i + f * (g + 1)) : (y.startAngle = o + f * g, y.endAngle = o + f * (g + 1), y.r0 = i + p * d, y.r = i + p * (d + 1)), y.clockwise = t.clockwise, y.cx = t.cx, y.cy = t.cy, n.push(y) } } function LG(t, e, n, i) { return t * i - n * e } function PG(t, e, n, i, r, o, a, s) { var l = n - t, u = i - e, h = a - r, c = s - o, p = LG(h, c, l, u); if (Math.abs(p) < 1e-6) return null; var d = LG(t - r, e - o, h, c) / p; return d < 0 || d > 1 ? null : new De(d * l + t, d * u + e) } function OG(t, e, n) { var i = new De; De.sub(i, n, e), i.normalize(); var r = new De; return De.sub(r, t, e), r.dot(i) } function RG(t, e) { var n = t[t.length - 1]; n && n[0] === e[0] && n[1] === e[1] || t.push(e) } function NG(t) { var e = t.points, n = [], i = []; Ra(e, n, i); var r = new ze(n[0], n[1], i[0] - n[0], i[1] - n[1]), o = r.width, a = r.height, s = r.x, l = r.y, u = new De, h = new De; return o > a ? (u.x = h.x = s + o / 2, u.y = l, h.y = l + a) : (u.y = h.y = l + a / 2, u.x = s, h.x = s + o), function (t, e, n) { for (var i = t.length, r = [], o = 0; o < i; o++) { var a = t[o], s = t[(o + 1) % i], l = PG(a[0], a[1], s[0], s[1], e.x, e.y, n.x, n.y); l && r.push({ projPt: OG(l, e, n), pt: l, idx: o }) } if (r.length < 2) return [{ points: t }, { points: t }]; r.sort((function (t, e) { return t.projPt - e.projPt })); var u = r[0], h = r[r.length - 1]; if (h.idx < u.idx) { var c = u; u = h, h = c } var p = [u.pt.x, u.pt.y], d = [h.pt.x, h.pt.y], f = [p], g = [d]; for (o = u.idx + 1; o <= h.idx; o++)RG(f, t[o].slice()); for (RG(f, d), RG(f, p), o = h.idx + 1; o <= u.idx + i; o++)RG(g, t[o % i].slice()); return RG(g, p), RG(g, d), [{ points: f }, { points: g }] }(e, u, h) } function EG(t, e, n, i) { if (1 === n) i.push(e); else { var r = Math.floor(n / 2), o = t(e); EG(t, o[0], r, i), EG(t, o[1], n - r, i) } return i } function zG(t, e) { e.setStyle(t.style), e.z = t.z, e.z2 = t.z2, e.zlevel = t.zlevel } function VG(t, e) { var n, i = [], r = t.shape; switch (t.type) { case "rect": !function (t, e, n) { for (var i = t.width, r = t.height, o = i > r, a = AG([i, r], o ? 0 : 1, e), s = o ? "width" : "height", l = o ? "height" : "width", u = o ? "x" : "y", h = o ? "y" : "x", c = t[s] / a.length, p = 0; p < a.length; p++)for (var d = t[l] / a[p], f = 0; f < a[p]; f++) { var g = {}; g[u] = p * c, g[h] = f * d, g[s] = c, g[l] = d, g.x += t.x, g.y += t.y, n.push(g) } }(r, e, i), n = zs; break; case "sector": kG(r, e, i), n = zu; break; case "circle": kG({ r0: 0, r: r.r, startAngle: 0, endAngle: 2 * Math.PI, cx: r.cx, cy: r.cy }, e, i), n = zu; break; default: var o = t.getComputedTransform(), a = o ? Math.sqrt(Math.max(o[0] * o[0] + o[1] * o[1], o[2] * o[2] + o[3] * o[3])) : 1, s = z(function (t, e) { var n = CG(t), i = []; e = e || 1; for (var r = 0; r < n.length; r++) { var o = n[r], a = [], s = o[0], l = o[1]; a.push(s, l); for (var u = 2; u < o.length;) { var h = o[u++], c = o[u++], p = o[u++], d = o[u++], f = o[u++], g = o[u++]; DG(s, l, h, c, p, d, f, g, a, e), s = f, l = g } i.push(a) } return i }(t.getUpdatedPathProxy(), a), (function (t) { return function (t) { for (var e = [], n = 0; n < t.length;)e.push([t[n++], t[n++]]); return e }(t) })), l = s.length; if (0 === l) EG(NG, { points: s[0] }, e, i); else if (l === e) for (var u = 0; u < l; u++)i.push({ points: s[u] }); else { var h = 0, c = z(s, (function (t) { var e = [], n = []; Ra(t, e, n); var i = (n[1] - e[1]) * (n[0] - e[0]); return h += i, { poly: t, area: i } })); c.sort((function (t, e) { return e.area - t.area })); var p = e; for (u = 0; u < l; u++) { var d = c[u]; if (p <= 0) break; var f = u === l - 1 ? p : Math.ceil(d.area / h * e); f < 0 || (EG(NG, { points: d.poly }, f, i), p -= f) } } n = Wu }if (!n) return function (t, e) { for (var n = [], i = 0; i < e; i++)n.push(mu(t)); return n }(t, e); var g = []; for (u = 0; u < i.length; u++) { var y = new n; y.setShape(i[u]), zG(t, y), g.push(y) } return g } function BG(t, e) { var n = t.length, i = e.length; if (n === i) return [t, e]; for (var r = [], o = [], a = n < i ? t : e, s = Math.min(n, i), l = Math.abs(i - n) / 6, u = (s - 2) / 6, h = Math.ceil(l / u) + 1, c = [a[0], a[1]], p = l, d = 2; d < s;) { var f = a[d - 2], g = a[d - 1], y = a[d++], v = a[d++], m = a[d++], x = a[d++], _ = a[d++], b = a[d++]; if (p <= 0) c.push(y, v, m, x, _, b); else { for (var w = Math.min(p, h - 1) + 1, S = 1; S <= w; S++) { var M = S / w; wn(f, y, m, _, M, r), wn(g, v, x, b, M, o), f = r[3], g = o[3], c.push(r[1], o[1], r[2], o[2], f, g), y = r[5], v = o[5], m = r[6], x = o[6] } p -= w - 1 } } return a === t ? [c, e] : [t, c] } function FG(t, e) { for (var n = t.length, i = t[n - 2], r = t[n - 1], o = [], a = 0; a < e.length;)o[a++] = i, o[a++] = r; return o } function GG(t) { for (var e = 0, n = 0, i = 0, r = t.length, o = 0, a = r - 2; o < r; a = o, o += 2) { var s = t[a], l = t[a + 1], u = t[o], h = t[o + 1], c = s * h - u * l; e += c, n += (s + u) * c, i += (l + h) * c } return 0 === e ? [t[0] || 0, t[1] || 0] : [n / e / 3, i / e / 3, e] } function WG(t, e, n, i) { for (var r = (t.length - 2) / 6, o = 1 / 0, a = 0, s = t.length, l = s - 2, u = 0; u < r; u++) { for (var h = 6 * u, c = 0, p = 0; p < s; p += 2) { var d = 0 === p ? h : (h + p - 2) % l + 2, f = t[d] - n[0], g = t[d + 1] - n[1], y = e[p] - i[0] - f, v = e[p + 1] - i[1] - g; c += y * y + v * v } c < o && (o = c, a = u) } return a } function HG(t) { for (var e = [], n = t.length, i = 0; i < n; i += 2)e[i] = t[n - i - 2], e[i + 1] = t[n - i - 1]; return e } function YG(t) { return t.__isCombineMorphing } var XG = "__mOriginal_"; function UG(t, e, n) { var i = XG + e, r = t[i] || t[e]; t[i] || (t[i] = t[e]); var o = n.replace, a = n.after, s = n.before; t[e] = function () { var t, e = arguments; return s && s.apply(this, e), t = o ? o.apply(this, e) : r.apply(this, e), a && a.apply(this, e), t } } function ZG(t, e) { var n = XG + e; t[n] && (t[e] = t[n], t[n] = null) } function jG(t, e) { for (var n = 0; n < t.length; n++)for (var i = t[n], r = 0; r < i.length;) { var o = i[r], a = i[r + 1]; i[r++] = e[0] * o + e[2] * a + e[4], i[r++] = e[1] * o + e[3] * a + e[5] } } function qG(t, e) { var n = t.getUpdatedPathProxy(), i = e.getUpdatedPathProxy(), r = function (t, e) { for (var n, i, r, o = [], a = [], s = 0; s < Math.max(t.length, e.length); s++) { var l = t[s], u = e[s], h = void 0, c = void 0; l ? u ? (i = h = (n = BG(l, u))[0], r = c = n[1]) : (c = FG(r || l, l), h = l) : (h = FG(i || u, u), c = u), o.push(h), a.push(c) } return [o, a] }(CG(n), CG(i)), o = r[0], a = r[1], s = t.getComputedTransform(), l = e.getComputedTransform(); s && jG(o, s), l && jG(a, l), UG(e, "updateTransform", { replace: function () { this.transform = null } }), e.transform = null; var u = function (t, e, n, i) { for (var r, o = [], a = 0; a < t.length; a++) { var s = t[a], l = e[a], u = GG(s), h = GG(l); null == r && (r = u[2] < 0 != h[2] < 0); var c = [], p = [], d = 0, f = 1 / 0, g = [], y = s.length; r && (s = HG(s)); for (var v = 6 * WG(s, l, u, h), m = y - 2, x = 0; x < m; x += 2) { var _ = (v + x) % m + 2; c[x + 2] = s[_] - u[0], c[x + 3] = s[_ + 1] - u[1] } if (c[0] = s[v] - u[0], c[1] = s[v + 1] - u[1], n > 0) for (var b = i / n, w = -i / 2; w <= i / 2; w += b) { var S = Math.sin(w), M = Math.cos(w), I = 0; for (x = 0; x < s.length; x += 2) { var T = c[x], C = c[x + 1], D = l[x] - h[0], A = l[x + 1] - h[1], k = D * M - A * S, L = D * S + A * M; g[x] = k, g[x + 1] = L; var P = k - T, O = L - C; I += P * P + O * O } if (I < f) { f = I, d = w; for (var R = 0; R < g.length; R++)p[R] = g[R] } } else for (var N = 0; N < y; N += 2)p[N] = l[N] - h[0], p[N + 1] = l[N + 1] - h[1]; o.push({ from: c, to: p, fromCp: u, toCp: h, rotation: -d }) } return o }(o, a, 10, Math.PI), h = []; UG(e, "buildPath", { replace: function (t) { for (var n = e.__morphT, i = 1 - n, r = [], o = 0; o < u.length; o++) { var a = u[o], s = a.from, l = a.to, c = a.rotation * n, p = a.fromCp, d = a.toCp, f = Math.sin(c), g = Math.cos(c); Gt(r, p, d, n); for (var y = 0; y < s.length; y += 2) { var v = s[y], m = s[y + 1], x = v * i + (S = l[y]) * n, _ = m * i + (M = l[y + 1]) * n; h[y] = x * g - _ * f + r[0], h[y + 1] = x * f + _ * g + r[1] } var b = h[0], w = h[1]; t.moveTo(b, w); for (y = 2; y < s.length;) { var S = h[y++], M = h[y++], I = h[y++], T = h[y++], C = h[y++], D = h[y++]; b === S && w === M && I === C && T === D ? t.lineTo(C, D) : t.bezierCurveTo(S, M, I, T, C, D), b = C, w = D } } } }) } function KG(t, e, n) { if (!t || !e) return e; var i = n.done, r = n.during; return qG(t, e), e.__morphT = 0, e.animateTo({ __morphT: 1 }, k({ during: function (t) { e.dirtyShape(), r && r(t) }, done: function () { ZG(e, "buildPath"), ZG(e, "updateTransform"), e.__morphT = -1, e.createPathProxy(), e.dirtyShape(), i && i() } }, n)), e } function $G(t, e, n, i, r, o) { t = r === n ? 0 : Math.round(32767 * (t - n) / (r - n)), e = o === i ? 0 : Math.round(32767 * (e - i) / (o - i)); for (var a, s = 0, l = 32768; l > 0; l /= 2) { var u = 0, h = 0; (t & l) > 0 && (u = 1), (e & l) > 0 && (h = 1), s += l * l * (3 * u ^ h), 0 === h && (1 === u && (t = l - 1 - t, e = l - 1 - e), a = t, t = e, e = a) } return s } function JG(t) { var e = 1 / 0, n = 1 / 0, i = -1 / 0, r = -1 / 0, o = z(t, (function (t) { var o = t.getBoundingRect(), a = t.getComputedTransform(), s = o.x + o.width / 2 + (a ? a[4] : 0), l = o.y + o.height / 2 + (a ? a[5] : 0); return e = Math.min(s, e), n = Math.min(l, n), i = Math.max(s, i), r = Math.max(l, r), [s, l] })); return z(o, (function (o, a) { return { cp: o, z: $G(o[0], o[1], e, n, i, r), path: t[a] } })).sort((function (t, e) { return t.z - e.z })).map((function (t) { return t.path })) } function QG(t) { return VG(t.path, t.count) } function tW(t) { return Y(t[0]) } function eW(t, e) { for (var n = [], i = t.length, r = 0; r < i; r++)n.push({ one: t[r], many: [] }); for (r = 0; r < e.length; r++) { var o = e[r].length, a = void 0; for (a = 0; a < o; a++)n[a % i].many.push(e[r][a]) } var s = 0; for (r = i - 1; r >= 0; r--)if (!n[r].many.length) { var l = n[s].many; if (l.length <= 1) { if (!s) return n; s = 0 } o = l.length; var u = Math.ceil(o / 2); n[r].many = l.slice(u, o), n[s].many = l.slice(0, u), s++ } return n } var nW = { clone: function (t) { for (var e = [], n = 1 - Math.pow(1 - t.path.style.opacity, 1 / t.count), i = 0; i < t.count; i++) { var r = mu(t.path); r.setStyle("opacity", n), e.push(r) } return e }, split: null }; function iW(t, e, n, i, r, o) { if (t.length && e.length) { var a = ph("update", i, r); if (a && a.duration > 0) { var s, l, u = i.getModel("universalTransition").get("delay"), h = Object.assign({ setToFinal: !0 }, a); tW(t) && (s = t, l = e), tW(e) && (s = e, l = t); for (var c = s ? s === t : t.length > e.length, p = s ? eW(l, s) : eW(c ? e : t, [c ? t : e]), d = 0, f = 0; f < p.length; f++)d += p[f].many.length; var g = 0; for (f = 0; f < p.length; f++)y(p[f], c, g, d), g += p[f].many.length } } function y(t, e, i, r, a) { var s = t.many, l = t.one; if (1 !== s.length || a) for (var c = k({ dividePath: nW[n], individualDelay: u && function (t, e, n, o) { return u(t + i, r) } }, h), p = e ? function (t, e, n) { var i = []; !function t(e) { for (var n = 0; n < e.length; n++) { var r = e[n]; YG(r) ? t(r.childrenRef()) : r instanceof Is && i.push(r) } }(t); var r = i.length; if (!r) return { fromIndividuals: [], toIndividuals: [], count: 0 }; var o = (n.dividePath || QG)({ path: e, count: r }); if (o.length !== r) return console.error("Invalid morphing: unmatched splitted path"), { fromIndividuals: [], toIndividuals: [], count: 0 }; i = JG(i), o = JG(o); for (var a = n.done, s = n.during, l = n.individualDelay, u = new gr, h = 0; h < r; h++) { var c = i[h], p = o[h]; p.parent = e, p.copyTransform(u), l || qG(c, p) } function d(t) { for (var e = 0; e < o.length; e++)o[e].addSelfToZr(t) } function f() { e.__isCombineMorphing = !1, e.__morphT = -1, e.childrenRef = null, ZG(e, "addSelfToZr"), ZG(e, "removeSelfFromZr") } e.__isCombineMorphing = !0, e.childrenRef = function () { return o }, UG(e, "addSelfToZr", { after: function (t) { d(t) } }), UG(e, "removeSelfFromZr", { after: function (t) { for (var e = 0; e < o.length; e++)o[e].removeSelfFromZr(t) } }); var g = o.length; if (l) { var y = g, v = function () { 0 == --y && (f(), a && a()) }; for (h = 0; h < g; h++) { var m = l ? k({ delay: (n.delay || 0) + l(h, g, i[h], o[h]), done: v }, n) : n; KG(i[h], o[h], m) } } else e.__morphT = 0, e.animateTo({ __morphT: 1 }, k({ during: function (t) { for (var n = 0; n < g; n++) { var i = o[n]; i.__morphT = e.__morphT, i.dirtyShape() } s && s(t) }, done: function () { f(); for (var e = 0; e < t.length; e++)ZG(t[e], "updateTransform"); a && a() } }, n)); return e.__zr && d(e.__zr), { fromIndividuals: i, toIndividuals: o, count: g } }(s, l, c) : function (t, e, n) { var i = e.length, r = [], o = n.dividePath || QG; if (YG(t)) { !function t(e) { for (var n = 0; n < e.length; n++) { var i = e[n]; YG(i) ? t(i.childrenRef()) : i instanceof Is && r.push(i) } }(t.childrenRef()); var a = r.length; if (a < i) for (var s = 0, l = a; l < i; l++)r.push(mu(r[s++ % a])); r.length = i } else { r = o({ path: t, count: i }); var u = t.getComputedTransform(); for (l = 0; l < r.length; l++)r[l].setLocalTransform(u); if (r.length !== i) return console.error("Invalid morphing: unmatched splitted path"), { fromIndividuals: [], toIndividuals: [], count: 0 } } r = JG(r), e = JG(e); var h = n.individualDelay; for (l = 0; l < i; l++) { var c = h ? k({ delay: (n.delay || 0) + h(l, i, r[l], e[l]) }, n) : n; KG(r[l], e[l], c) } return { fromIndividuals: r, toIndividuals: e, count: e.length } }(l, s, c), d = p.fromIndividuals, f = p.toIndividuals, g = d.length, v = 0; v < g; v++) { m = u ? k({ delay: u(v, g) }, h) : h; o(d[v], f[v], e ? s[v] : t.one, e ? t.one : s[v], m) } else { var m, x = e ? s[0] : l, _ = e ? l : s[0]; if (YG(x)) y({ many: [x], one: _ }, !0, i, r, !0); else KG(x, _, m = u ? k({ delay: u(i, r) }, h) : h), o(x, _, x, _, m) } } } function rW(t) { if (!t) return []; if (Y(t)) { for (var e = [], n = 0; n < t.length; n++)e.push(rW(t[n])); return e } var i = []; return t.traverse((function (t) { t instanceof Is && !t.disableMorphing && !t.invisible && !t.ignore && i.push(t) })), i } var oW = Oo(); function aW(t) { var e = []; return E(t, (function (t) { var n = t.data; if (!(n.count() > 1e4)) for (var i = n.getIndices(), r = function (t) { for (var e = t.dimensions, n = 0; n < e.length; n++) { var i = t.getDimensionInfo(e[n]); if (i && 0 === i.otherDims.itemGroupId) return e[n] } }(n), o = 0; o < i.length; o++)e.push({ dataGroupId: t.dataGroupId, data: n, dim: t.dim || r, divide: t.divide, dataIndex: o }) })), e } function sW(t, e, n) { t.traverse((function (t) { t instanceof Is && gh(t, { style: { opacity: 0 } }, e, { dataIndex: n, isFrom: !0 }) })) } function lW(t) { if (t.parent) { var e = t.getComputedTransform(); t.setLocalTransform(e), t.parent.remove(t) } } function uW(t) { t.stopAnimation(), t.isGroup && t.traverse((function (t) { t.stopAnimation() })) } function hW(t, e, n) { var i = ph("update", n, e); i && t.traverse((function (t) { if (t instanceof Sa) { var e = function (t) { return ch(t).oldStyle }(t); e && t.animateFrom({ style: e }, i) } })) } function cW(t, e, n) { var i = aW(t), r = aW(e); function o(t, e, n, i, r) { (n || t) && e.animateFrom({ style: n && n !== t ? A(A({}, n.style), t.style) : t.style }, r) } function a(t) { for (var e = 0; e < t.length; e++)if (t[e].dim) return t[e].dim } var s = a(i), l = a(r), u = !1; function h(t, e) { return function (n) { var i = n.data, r = n.dataIndex; if (e) return i.getId(r); var o = n.dataGroupId, a = t ? s || l : l || s, u = a && i.getDimensionInfo(a), h = u && u.ordinalMeta; if (u) { var c = i.get(u.name, r); return h && h.categories[c] || c + "" } var p = i.getRawDataItem(r); return p && p.groupId ? p.groupId + "" : o || i.getId(r) } } var c = function (t, e) { var n = t.length; if (n !== e.length) return !1; for (var i = 0; i < n; i++) { var r = t[i], o = e[i]; if (r.data.getId(r.dataIndex) !== o.data.getId(o.dataIndex)) return !1 } return !0 }(i, r), p = {}; if (!c) for (var d = 0; d < r.length; d++) { var f = r[d], g = f.data.getItemGraphicEl(f.dataIndex); g && (p[g.id] = !0) } function y(t, e) { var n = i[e], a = r[t], s = a.data.hostModel, l = n.data.getItemGraphicEl(n.dataIndex), h = a.data.getItemGraphicEl(a.dataIndex); l !== h ? l && p[l.id] || h && (uW(h), l ? (uW(l), lW(l), u = !0, iW(rW(l), rW(h), a.divide, s, t, o)) : sW(h, s, t)) : h && hW(h, a.dataIndex, s) } new Vm(i, r, h(!0, c), h(!1, c), null, "multiple").update(y).updateManyToOne((function (t, e) { var n = r[t], a = n.data, s = a.hostModel, l = a.getItemGraphicEl(n.dataIndex), h = B(z(e, (function (t) { return i[t].data.getItemGraphicEl(i[t].dataIndex) })), (function (t) { return t && t !== l && !p[t.id] })); l && (uW(l), h.length ? (E(h, (function (t) { uW(t), lW(t) })), u = !0, iW(rW(h), rW(l), n.divide, s, t, o)) : sW(l, s, n.dataIndex)) })).updateOneToMany((function (t, e) { var n = i[e], a = n.data.getItemGraphicEl(n.dataIndex); if (!a || !p[a.id]) { var s = B(z(t, (function (t) { return r[t].data.getItemGraphicEl(r[t].dataIndex) })), (function (t) { return t && t !== a })), l = r[t[0]].data.hostModel; s.length && (E(s, (function (t) { return uW(t) })), a ? (uW(a), lW(a), u = !0, iW(rW(a), rW(s), n.divide, l, t[0], o)) : E(s, (function (e) { return sW(e, l, t[0]) }))) } })).updateManyToMany((function (t, e) { new Vm(e, t, (function (t) { return i[t].data.getId(i[t].dataIndex) }), (function (t) { return r[t].data.getId(r[t].dataIndex) })).update((function (n, i) { y(t[n], e[i]) })).execute() })).execute(), u && E(e, (function (t) { var e = t.data.hostModel, i = e && n.getViewOfSeriesModel(e), r = ph("update", e, 0); i && e.isAnimationEnabled() && r && r.duration > 0 && i.group.traverse((function (t) { t instanceof Is && !t.animators.length && t.animateFrom({ style: { opacity: 0 } }, r) })) })) } function pW(t) { var e = t.getModel("universalTransition").get("seriesKey"); return e || t.id } function dW(t) { return Y(t) ? t.sort().join(",") : t } function fW(t) { if (t.hostModel) return t.hostModel.getModel("universalTransition").get("divideShape") } function gW(t, e) { for (var n = 0; n < t.length; n++) { if (null != e.seriesIndex && e.seriesIndex === t[n].seriesIndex || null != e.seriesId && e.seriesId === t[n].id) return n } } Nm([function (t) { t.registerPainter("canvas", eS) }]), Nm([function (t) { t.registerPainter("svg", jw) }]), Nm([function (t) { t.registerChartView(NS), t.registerSeriesModel(nS), t.registerLayout(ES("line", !0)), t.registerVisual({ seriesType: "line", reset: function (t) { var e = t.getData(), n = t.getModel("lineStyle").getLineStyle(); n && !n.stroke && (n.stroke = e.getVisual("style").fill), e.setVisual("legendLineStyle", n) } }), t.registerProcessor(t.PRIORITY.PROCESSOR.STATISTIC, BS("line")) }, function (t) { t.registerChartView(qS), t.registerSeriesModel(GS), t.registerLayout(t.PRIORITY.VISUAL.LAYOUT, H(Hx, "bar")), t.registerLayout(t.PRIORITY.VISUAL.PROGRESSIVE_LAYOUT, Yx("bar")), t.registerProcessor(t.PRIORITY.PROCESSOR.STATISTIC, BS("bar")), t.registerAction({ type: "changeAxisOrder", event: "changeAxisOrder", update: "update" }, (function (t, e) { var n = t.componentType || "series"; e.eachComponent({ mainType: n, query: t }, (function (e) { t.sortInfo && e.axis.setCategorySortInfo(t.sortInfo) })) })) }, function (t) { t.registerChartView(SM), t.registerSeriesModel(CM), Dy("pie", t.registerAction), t.registerLayout(H(gM, "pie")), t.registerProcessor(yM("pie")), t.registerProcessor(function (t) { return { seriesType: t, reset: function (t, e) { var n = t.getData(); n.filterSelf((function (t) { var e = n.mapDimension("value"), i = n.get(e, t); return !(j(i) && !isNaN(i) && i < 0) })) } } }("pie")) }, function (t) { Nm(DI), t.registerSeriesModel(DM), t.registerChartView(PM), t.registerLayout(ES("scatter")) }, function (t) { Nm(WI), t.registerChartView(OI), t.registerSeriesModel(RI), t.registerLayout(AI), t.registerProcessor(yM("radar")), t.registerPreprocessor(PI) }, function (t) { Nm(vC), t.registerChartView(JT), t.registerSeriesModel(QT), t.registerLayout(eC), t.registerProcessor(t.PRIORITY.PROCESSOR.STATISTIC, tC), Dy("map", t.registerAction) }, function (t) { t.registerChartView(AC), t.registerSeriesModel($C), t.registerLayout(QC), t.registerVisual(tD), function (t) { t.registerAction({ type: "treeExpandAndCollapse", event: "treeExpandAndCollapse", update: "update" }, (function (t, e) { e.eachComponent({ mainType: "series", subType: "tree", query: t }, (function (e) { var n = t.dataIndex, i = e.getData().tree.getNodeByDataIndex(n); i.isExpand = !i.isExpand })) })), t.registerAction({ type: "treeRoam", event: "treeRoam", update: "none" }, (function (t, e, n) { e.eachComponent({ mainType: "series", subType: "tree", query: t }, (function (e) { var i = fC(e.coordinateSystem, t, void 0, n); e.setCenter && e.setCenter(i.center), e.setZoom && e.setZoom(i.zoom) })) })) }(t) }, function (t) { t.registerSeriesModel(iD), t.registerChartView(yD), t.registerVisual(OD), t.registerLayout(UD), function (t) { for (var e = 0; e < eD.length; e++)t.registerAction({ type: eD[e], update: "updateView" }, bt); t.registerAction({ type: "treemapRootToNode", update: "updateView" }, (function (t, e) { e.eachComponent({ mainType: "series", subType: "treemap", query: t }, (function (e, n) { var i = ZC(t, ["treemapZoomToNode", "treemapRootToNode"], e); if (i) { var r = e.getViewRoot(); r && (t.direction = qC(r, i.node) ? "rollUp" : "drillDown"), e.resetViewRoot(i.node) } })) })) }(t) }, function (t) { t.registerChartView(ZA), t.registerSeriesModel(tk), t.registerProcessor(JD), t.registerVisual(QD), t.registerVisual(eA), t.registerLayout(cA), t.registerLayout(t.PRIORITY.VISUAL.POST_CHART_LAYOUT, xA), t.registerLayout(bA), t.registerCoordinateSystem("graphView", { dimensions: iC.dimensions, create: wA }), t.registerAction({ type: "focusNodeAdjacency", event: "focusNodeAdjacency", update: "series:focusNodeAdjacency" }, bt), t.registerAction({ type: "unfocusNodeAdjacency", event: "unfocusNodeAdjacency", update: "series:unfocusNodeAdjacency" }, bt), t.registerAction(ek, (function (t, e, n) { e.eachComponent({ mainType: "series", query: t }, (function (e) { var i = fC(e.coordinateSystem, t, void 0, n); e.setCenter && e.setCenter(i.center), e.setZoom && e.setZoom(i.zoom) })) })) }, function (t) { t.registerChartView(ok), t.registerSeriesModel(ak) }, function (t) { t.registerChartView(uk), t.registerSeriesModel(hk), t.registerLayout(ck), t.registerProcessor(yM("funnel")) }, function (t) { Nm(zL), t.registerChartView(pk), t.registerSeriesModel(vk), t.registerVisual(t.PRIORITY.VISUAL.BRUSH, _k) }, function (t) { t.registerChartView(FL), t.registerSeriesModel(WL), t.registerLayout(HL), t.registerVisual(eP), t.registerAction({ type: "dragNode", event: "dragnode", update: "update" }, (function (t, e) { e.eachComponent({ mainType: "series", subType: "sankey", query: t }, (function (e) { e.setNodePosition(t.dataIndex, [t.localX, t.localY]) })) })) }, function (t) { t.registerSeriesModel(iP), t.registerChartView(rP), t.registerLayout(cP), t.registerTransform(pP) }, function (t) { t.registerChartView(fP), t.registerSeriesModel(IP), t.registerPreprocessor(TP), t.registerVisual(PP), t.registerLayout(OP) }, function (t) { t.registerChartView(zP), t.registerSeriesModel(VP), t.registerLayout(ES("effectScatter")) }, function (t) { t.registerChartView(UP), t.registerSeriesModel(KP), t.registerLayout(XP), t.registerVisual(JP) }, function (t) { t.registerChartView(eO), t.registerSeriesModel(nO) }, function (t) { t.registerChartView(aO), t.registerSeriesModel(MO), t.registerLayout(t.PRIORITY.VISUAL.LAYOUT, H(Hx, "pictorialBar")), t.registerLayout(t.PRIORITY.VISUAL.PROGRESSIVE_LAYOUT, Yx("pictorialBar")) }, function (t) { t.registerChartView(IO), t.registerSeriesModel(TO), t.registerLayout(CO), t.registerProcessor(yM("themeRiver")) }, function (t) { t.registerChartView(PO), t.registerSeriesModel(OO), t.registerLayout(H(EO, "sunburst")), t.registerProcessor(H(yM, "sunburst")), t.registerVisual(VO), function (t) { t.registerAction({ type: kO, update: "updateView" }, (function (t, e) { e.eachComponent({ mainType: "series", subType: "sunburst", query: t }, (function (e, n) { var i = ZC(t, [kO], e); if (i) { var r = e.getViewRoot(); r && (t.direction = qC(r, i.node) ? "rollUp" : "drillDown"), e.resetViewRoot(i.node) } })) })), t.registerAction({ type: LO, update: "none" }, (function (t, e, n) { t = A({}, t), e.eachComponent({ mainType: "series", subType: "sunburst", query: t }, (function (e) { var n = ZC(t, [LO], e); n && (t.dataIndex = n.node.dataIndex) })), n.dispatchAction(A(t, { type: "highlight" })) })), t.registerAction({ type: "sunburstUnhighlight", update: "updateView" }, (function (t, e, n) { t = A({}, t), n.dispatchAction(A(t, { type: "downplay" })) })) }(t) }, function (t) { t.registerChartView(AR), t.registerSeriesModel(WO) }]), Nm((function (t) { Nm(DI), Nm(kN) })), Nm((function (t) { Nm(kN), yI.registerAxisPointerClass("PolarAxisPointer", LN), t.registerCoordinateSystem("polar", XN), t.registerComponentModel(ON), t.registerComponentView(sE), FM(t, "angle", NN, oE), FM(t, "radius", EN, aE), t.registerComponentView(KN), t.registerComponentView(tE), t.registerLayout(H(rE, "bar")) })), Nm(vC), Nm((function (t) { Nm(kN), yI.registerAxisPointerClass("SingleAxisPointer", bE), t.registerComponentView(IE), t.registerComponentView(cE), t.registerComponentModel(dE), FM(t, "single", dE, dE.defaultOption), t.registerCoordinateSystem("single", mE) })), Nm(zL), Nm((function (t) { t.registerComponentModel(TE), t.registerComponentView(DE), t.registerCoordinateSystem("calendar", kE) })), Nm((function (t) { t.registerComponentModel(EE), t.registerComponentView(BE), t.registerPreprocessor((function (t) { var e = t.graphic; Y(e) ? e[0] && e[0].elements ? t.graphic = [t.graphic[0]] : t.graphic = [{ elements: e }] : e && !e.elements && (t.graphic = [{ elements: [e] }]) })) })), Nm((function (t) { t.registerComponentModel(pz), t.registerComponentView(fz), hz("saveAsImage", gz), hz("magicType", mz), hz("dataView", Iz), hz("dataZoom", Zz), hz("restore", kz), Nm(sz) })), Nm((function (t) { Nm(kN), t.registerComponentModel(Kz), t.registerComponentView(dV), t.registerAction({ type: "showTip", event: "showTip", update: "tooltip:manuallyShowTip" }, bt), t.registerAction({ type: "hideTip", event: "hideTip", update: "tooltip:manuallyHideTip" }, bt) })), Nm(kN), Nm((function (t) { t.registerComponentView(NV), t.registerComponentModel(EV), t.registerPreprocessor(mV), t.registerVisual(t.PRIORITY.VISUAL.BRUSH, kV), t.registerAction({ type: "brush", event: "brush", update: "updateVisual" }, (function (t, e) { e.eachComponent({ mainType: "brush", query: t }, (function (e) { e.setAreas(t.areas) })) })), t.registerAction({ type: "brushSelect", event: "brushSelected", update: "none" }, bt), t.registerAction({ type: "brushEnd", event: "brushEnd", update: "none" }, bt), hz("brush", BV) })), Nm((function (t) { t.registerComponentModel(FV), t.registerComponentView(GV) })), Nm((function (t) { t.registerComponentModel(HV), t.registerComponentView(jV), t.registerSubTypeDefaulter("timeline", (function () { return "slider" })), function (t) { t.registerAction({ type: "timelineChange", event: "timelineChanged", update: "prepareAndUpdate" }, (function (t, e, n) { var i = e.getComponent("timeline"); return i && null != t.currentIndex && (i.setCurrentIndex(t.currentIndex), !i.get("loop", !0) && i.isIndexMax() && i.getPlayState() && (i.setPlayState(!1), n.dispatchAction({ type: "timelinePlayChange", playState: !1, from: t.from }))), e.resetOption("timeline", { replaceMerge: i.get("replaceMerge", !0) }), k({ currentIndex: i.option.currentIndex }, t) })), t.registerAction({ type: "timelinePlayChange", event: "timelinePlayChanged", update: "update" }, (function (t, e) { var n = e.getComponent("timeline"); n && null != t.playState && n.setPlayState(t.playState) })) }(t), t.registerPreprocessor($V) })), Nm((function (t) { t.registerComponentModel(rB), t.registerComponentView(yB), t.registerPreprocessor((function (t) { tB(t.series, "markPoint") && (t.markPoint = t.markPoint || {}) })) })), Nm((function (t) { t.registerComponentModel(vB), t.registerComponentView(MB), t.registerPreprocessor((function (t) { tB(t.series, "markLine") && (t.markLine = t.markLine || {}) })) })), Nm((function (t) { t.registerComponentModel(IB), t.registerComponentView(OB), t.registerPreprocessor((function (t) { tB(t.series, "markArea") && (t.markArea = t.markArea || {}) })) })), Nm((function (t) { Nm(XB), Nm(JB) })), Nm((function (t) { Nm(hF), Nm(xF) })), Nm(hF), Nm(xF), Nm((function (t) { Nm(QF), Nm(rG) })), Nm(QF), Nm(rG), Nm((function (t) { t.registerPreprocessor(uG), t.registerVisual(t.PRIORITY.VISUAL.ARIA, lG) })), Nm((function (t) { t.registerTransform(bG), t.registerTransform(wG) })), Nm((function (t) { t.registerComponentModel(SG), t.registerComponentView(MG) })), Nm((function (t) { t.registerUpdateLifecycle("series:beforeupdate", (function (t, e, n) { E(bo(n.seriesTransition), (function (t) { E(bo(t.to), (function (t) { for (var e = n.updatedSeries, i = 0; i < e.length; i++)(null != t.seriesIndex && t.seriesIndex === e[i].seriesIndex || null != t.seriesId && t.seriesId === e[i].id) && (e[i][vg] = !0) })) })) })), t.registerUpdateLifecycle("series:transition", (function (t, e, n) { var i = oW(e); if (i.oldSeries && n.updatedSeries && n.optionChanged) { var r = n.seriesTransition; if (r) E(bo(r), (function (t) { !function (t, e, n, i) { var r = [], o = []; E(bo(t.from), (function (t) { var n = gW(e.oldSeries, t); n >= 0 && r.push({ dataGroupId: e.oldDataGroupIds[n], data: e.oldData[n], divide: fW(e.oldData[n]), dim: t.dimension }) })), E(bo(t.to), (function (t) { var i = gW(n.updatedSeries, t); if (i >= 0) { var r = n.updatedSeries[i].getData(); o.push({ dataGroupId: e.oldDataGroupIds[i], data: r, divide: fW(r), dim: t.dimension }) } })), r.length > 0 && o.length > 0 && cW(r, o, i) }(t, i, n, e) })); else { var o = function (t, e) { var n = yt(), i = yt(), r = yt(); return E(t.oldSeries, (function (e, n) { var o = t.oldDataGroupIds[n], a = t.oldData[n], s = pW(e), l = dW(s); i.set(l, { dataGroupId: o, data: a }), Y(s) && E(s, (function (t) { r.set(t, { key: l, dataGroupId: o, data: a }) })) })), E(e.updatedSeries, (function (t) { if (t.isUniversalTransitionEnabled() && t.isAnimationEnabled()) { var e = t.get("dataGroupId"), o = t.getData(), a = pW(t), s = dW(a), l = i.get(s); if (l) n.set(s, { oldSeries: [{ dataGroupId: l.dataGroupId, divide: fW(l.data), data: l.data }], newSeries: [{ dataGroupId: e, divide: fW(o), data: o }] }); else if (Y(a)) { var u = []; E(a, (function (t) { var e = i.get(t); e.data && u.push({ dataGroupId: e.dataGroupId, divide: fW(e.data), data: e.data }) })), u.length && n.set(s, { oldSeries: u, newSeries: [{ dataGroupId: e, data: o, divide: fW(o) }] }) } else { var h = r.get(a); if (h) { var c = n.get(h.key); c || (c = { oldSeries: [{ dataGroupId: h.dataGroupId, data: h.data, divide: fW(h.data) }], newSeries: [] }, n.set(h.key, c)), c.newSeries.push({ dataGroupId: e, data: o, divide: fW(o) }) } } } })), n }(i, n); E(o.keys(), (function (t) { var n = o.get(t); cW(n.oldSeries, n.newSeries, e) })) } E(n.updatedSeries, (function (t) { t[vg] && (t[vg] = !1) })) } for (var a = t.getSeries(), s = i.oldSeries = [], l = i.oldDataGroupIds = [], u = i.oldData = [], h = 0; h < a.length; h++) { var c = a[h].getData(); c.count() < 1e4 && (s.push(a[h]), l.push(a[h].get("dataGroupId")), u.push(c)) } })) })), Nm((function (t) { t.registerUpdateLifecycle("series:beforeupdate", (function (t, e, n) { var i = Gb(e).labelManager; i || (i = Gb(e).labelManager = new Fb), i.clearLabels() })), t.registerUpdateLifecycle("series:layoutlabels", (function (t, e, n) { var i = Gb(e).labelManager; n.updatedSeries.forEach((function (t) { i.addLabelsOfSeries(e.getViewOfSeriesModel(t)) })), i.updateLayoutConfig(e), i.layout(e), i.processLabelsOverall() })) })), t.Axis = nb, t.ChartView = kg, t.ComponentModel = Rp, t.ComponentView = Tg, t.List = lx, t.Model = Mc, t.PRIORITY = Mv, t.SeriesModel = mg, t.color = ai, t.connect = function (t) { if (Y(t)) { var e = t; t = null, E(e, (function (e) { null != e.group && (t = e.group) })), t = t || "g_" + dm++, E(e, (function (e) { e.group = t })) } return cm[t] = !0, t }, t.dataTool = {}, t.dependencies = { zrender: "5.4.4" }, t.disConnect = ym, t.disconnect = gm, t.dispose = function (t) { U(t) ? t = hm[t] : t instanceof Qv || (t = vm(t)), t instanceof Qv && !t.isDisposed() && t.dispose() }, t.env = r, t.extendChartView = function (t) { var e = kg.extend(t); return kg.registerClass(e), e }, t.extendComponentModel = function (t) { var e = Rp.extend(t); return Rp.registerClass(e), e }, t.extendComponentView = function (t) { var e = Tg.extend(t); return Tg.registerClass(e), e }, t.extendSeriesModel = function (t) { var e = mg.extend(t); return mg.registerClass(e), e }, t.format = Y_, t.getCoordinateSystemDimensions = function (t) { var e = xd.get(t); if (e) return e.getDimensionsInfo ? e.getDimensionsInfo() : e.dimensions.slice() }, t.getInstanceByDom = vm, t.getInstanceById = function (t) { return hm[t] }, t.getMap = function (t) { var e = bv("getMap"); return e && e(t) }, t.graphic = H_, t.helper = C_, t.init = function (t, e, n) { var i = !(n && n.ssr); if (i) { 0; var r = vm(t); if (r) return r; 0 } var o = new Qv(t, e, n); return o.id = "ec_" + pm++, hm[o.id] = o, i && Fo(t, fm, o.id), jv(o), xv.trigger("afterinit", o), o }, t.innerDrawElementOnCanvas = hv, t.matrix = Ce, t.number = G_, t.parseGeoJSON = F_, t.parseGeoJson = F_, t.registerAction = Mm, t.registerCoordinateSystem = Im, t.registerLayout = Tm, t.registerLoading = km, t.registerLocale = Rc, t.registerMap = Lm, t.registerPostInit = bm, t.registerPostUpdate = wm, t.registerPreprocessor = xm, t.registerProcessor = _m, t.registerTheme = mm, t.registerTransform = Pm, t.registerUpdateLifecycle = Sm, t.registerVisual = Cm, t.setCanvasCreator = function (t) { c({ createCanvas: t }) }, t.setPlatformAPI = c, t.throttle = Bg, t.time = W_, t.use = Nm, t.util = X_, t.vector = Xt, t.version = "5.4.3", t.zrUtil = St, t.zrender = Hr, Object.defineProperty(t, "__esModule", { value: !0 })
}));;
