2013-11-14 12:17:30 +00:00
/ *
2015-05-13 00:48:44 +00:00
Highcharts JS v4 . 1.5 ( 2015 - 04 - 13 )
2013-11-14 12:17:30 +00:00
2015-05-13 00:48:44 +00:00
( c ) 2009 - 2014 Torstein Honsi
2013-11-14 12:17:30 +00:00
License : www . highcharts . com / license
* /
2015-05-13 00:48:44 +00:00
( function ( ) { function z ( ) { var a , b = arguments , c , d = { } , e = function ( a , b ) { var c , d ; typeof a !== "object" && ( a = { } ) ; for ( d in b ) b . hasOwnProperty ( d ) && ( c = b [ d ] , a [ d ] = c && typeof c === "object" && Object . prototype . toString . call ( c ) !== "[object Array]" && d !== "renderTo" && typeof c . nodeType !== "number" ? e ( a [ d ] || { } , c ) : b [ d ] ) ; return a } ; b [ 0 ] === ! 0 && ( d = b [ 1 ] , b = Array . prototype . slice . call ( b , 2 ) ) ; c = b . length ; for ( a = 0 ; a < c ; a ++ ) d = e ( d , b [ a ] ) ; return d } function B ( a , b ) { return parseInt ( a , b || 10 ) } function Da ( a ) { return typeof a === "string" } function ca ( a ) { return a &&
typeof a === "object" } function Ha ( a ) { return Object . prototype . toString . call ( a ) === "[object Array]" } function qa ( a ) { return typeof a === "number" } function Ea ( a ) { return V . log ( a ) / V . LN10 } function ha ( a ) { return V . pow ( 10 , a ) } function ia ( a , b ) { for ( var c = a . length ; c -- ; ) if ( a [ c ] === b ) { a . splice ( c , 1 ) ; break } } function s ( a ) { return a !== u && a !== null } function L ( a , b , c ) { var d , e ; if ( Da ( b ) ) s ( c ) ? a . setAttribute ( b , c ) : a && a . getAttribute && ( e = a . getAttribute ( b ) ) ; else if ( s ( b ) && ca ( b ) ) for ( d in b ) a . setAttribute ( d , b [ d ] ) ; return e } function ra ( a ) { return Ha ( a ) ?
a : [ a ] } function F ( a , b ) { if ( ya && ! ba && b && b . opacity !== u ) b . filter = "alpha(opacity=" + b . opacity * 100 + ")" ; r ( a . style , b ) } function Z ( a , b , c , d , e ) { a = A . createElement ( a ) ; b && r ( a , b ) ; e && F ( a , { padding : 0 , border : R , margin : 0 } ) ; c && F ( a , c ) ; d && d . appendChild ( a ) ; return a } function ja ( a , b ) { var c = function ( ) { return u } ; c . prototype = new a ; r ( c . prototype , b ) ; return c } function Ia ( a , b ) { return Array ( ( b || 2 ) + 1 - String ( a ) . length ) . join ( 0 ) + a } function Wa ( a ) { return ( eb && eb ( a ) || nb || 0 ) * 6E4 } function Ja ( a , b ) { for ( var c = "{" , d = ! 1 , e , f , g , h , i , j = [ ] ; ( c = a . indexOf ( c ) ) !==
- 1 ; ) { e = a . slice ( 0 , c ) ; if ( d ) { f = e . split ( ":" ) ; g = f . shift ( ) . split ( "." ) ; i = g . length ; e = b ; for ( h = 0 ; h < i ; h ++ ) e = e [ g [ h ] ] ; if ( f . length ) f = f . join ( ":" ) , g = /\.([0-9])/ , h = P . lang , i = void 0 , /f$/ . test ( f ) ? ( i = ( i = f . match ( g ) ) ? i [ 1 ] : - 1 , e !== null && ( e = w . numberFormat ( e , i , h . decimalPoint , f . indexOf ( "," ) > - 1 ? h . thousandsSep : "" ) ) ) : e = Oa ( f , e ) } j . push ( e ) ; a = a . slice ( c + 1 ) ; c = ( d = ! d ) ? "}" : "{" } j . push ( a ) ; return j . join ( "" ) } function ob ( a ) { return V . pow ( 10 , U ( V . log ( a ) / V . LN10 ) ) } function pb ( a , b , c , d , e ) { var f , g = a , c = p ( c , 1 ) ; f = a / c ; b || ( b = [ 1 , 2 , 2.5 , 5 , 10 ] , d === ! 1 && ( c ===
1 ? b = [ 1 , 2 , 5 , 10 ] : c <= 0.1 && ( b = [ 1 / c ] ) ) ) ; for ( d = 0 ; d < b . length ; d ++ ) if ( g = b [ d ] , e && g * c >= a || ! e && f <= ( b [ d ] + ( b [ d + 1 ] || b [ d ] ) ) / 2 ) break ; g *= c ; return g } function qb ( a , b ) { var c = a . length , d , e ; for ( e = 0 ; e < c ; e ++ ) a [ e ] . ss _i = e ; a . sort ( function ( a , c ) { d = b ( a , c ) ; return d === 0 ? a . ss _i - c . ss _i : d } ) ; for ( e = 0 ; e < c ; e ++ ) delete a [ e ] . ss _i } function Pa ( a ) { for ( var b = a . length , c = a [ 0 ] ; b -- ; ) a [ b ] < c && ( c = a [ b ] ) ; return c } function Fa ( a ) { for ( var b = a . length , c = a [ 0 ] ; b -- ; ) a [ b ] > c && ( c = a [ b ] ) ; return c } function Qa ( a , b ) { for ( var c in a ) a [ c ] && a [ c ] !== b && a [ c ] . destroy && a [ c ] . destroy ( ) ,
delete a [ c ] } function Ra ( a ) { fb || ( fb = Z ( Ka ) ) ; a && fb . appendChild ( a ) ; fb . innerHTML = "" } function ka ( a , b ) { var c = "Highcharts error #" + a + ": www.highcharts.com/errors/" + a ; if ( b ) throw c ; H . console && console . log ( c ) } function da ( a ) { return parseFloat ( a . toPrecision ( 14 ) ) } function Sa ( a , b ) { za = p ( a , b . animation ) } function Cb ( ) { var a = P . global , b = a . useUTC , c = b ? "getUTC" : "get" , d = b ? "setUTC" : "set" ; Aa = a . Date || window . Date ; nb = b && a . timezoneOffset ; eb = b && a . getTimezoneOffset ; gb = function ( a , c , d , h , i , j ) { var k ; b ? ( k = Aa . UTC . apply ( 0 , arguments ) , k +=
Wa ( k ) ) : k = ( new Aa ( a , c , p ( d , 1 ) , p ( h , 0 ) , p ( i , 0 ) , p ( j , 0 ) ) ) . getTime ( ) ; return k } ; rb = c + "Minutes" ; sb = c + "Hours" ; tb = c + "Day" ; Xa = c + "Date" ; Ya = c + "Month" ; Za = c + "FullYear" ; Db = d + "Milliseconds" ; Eb = d + "Seconds" ; Fb = d + "Minutes" ; Gb = d + "Hours" ; ub = d + "Date" ; vb = d + "Month" ; wb = d + "FullYear" } function K ( ) { } function Ta ( a , b , c , d ) { this . axis = a ; this . pos = b ; this . type = c || "" ; this . isNew = ! 0 ; ! c && ! d && this . addLabel ( ) } function Hb ( a , b , c , d , e ) { var f = a . chart . inverted ; this . axis = a ; this . isNegative = c ; this . options = b ; this . x = d ; this . total = null ; this . points = { } ; this . stack =
e ; this . alignOptions = { align : b . align || ( f ? c ? "left" : "right" : "center" ) , verticalAlign : b . verticalAlign || ( f ? "middle" : c ? "bottom" : "top" ) , y : p ( b . y , f ? 4 : c ? 14 : - 6 ) , x : p ( b . x , f ? c ? - 6 : 6 : 0 ) } ; this . textAlign = b . textAlign || ( f ? c ? "right" : "left" : "center" ) } var u , A = document , H = window , V = Math , x = V . round , U = V . floor , sa = V . ceil , t = V . max , I = V . min , O = V . abs , W = V . cos , $ = V . sin , la = V . PI , ga = la * 2 / 360 , Ba = navigator . userAgent , Ib = H . opera , ya = /(msie|trident)/i . test ( Ba ) && ! Ib , hb = A . documentMode === 8 , xb = /AppleWebKit/ . test ( Ba ) , La = /Firefox/ . test ( Ba ) , Jb = /(Mobile|Android|Windows Phone)/ . test ( Ba ) ,
Ca = "http://www.w3.org/2000/svg" , ba = ! ! A . createElementNS && ! ! A . createElementNS ( Ca , "svg" ) . createSVGRect , Nb = La && parseInt ( Ba . split ( "Firefox/" ) [ 1 ] , 10 ) < 4 , ea = ! ba && ! ya && ! ! A . createElement ( "canvas" ) . getContext , $a , ab , Kb = { } , yb = 0 , fb , P , Oa , za , zb , G , ma = function ( ) { return u } , X = [ ] , bb = 0 , Ka = "div" , R = "none" , Ob = /^[0-9]+$/ , ib = [ "plotTop" , "marginRight" , "marginBottom" , "plotLeft" ] , Pb = "stroke-width" , Aa , gb , nb , eb , rb , sb , tb , Xa , Ya , Za , Db , Eb , Fb , Gb , ub , vb , wb , J = { } , w ; w = H . Highcharts = H . Highcharts ? ka ( 16 , ! 0 ) : { } ; w . seriesTypes = J ; var r = w . extend = function ( a ,
b ) { var c ; a || ( a = { } ) ; for ( c in b ) a [ c ] = b [ c ] ; return a } , p = w . pick = function ( ) { var a = arguments , b , c , d = a . length ; for ( b = 0 ; b < d ; b ++ ) if ( c = a [ b ] , c !== u && c !== null ) return c } , cb = w . wrap = function ( a , b , c ) { var d = a [ b ] ; a [ b ] = function ( ) { var a = Array . prototype . slice . call ( arguments ) ; a . unshift ( d ) ; return c . apply ( this , a ) } } ; Oa = function ( a , b , c ) { if ( ! s ( b ) || isNaN ( b ) ) return "Invalid date" ; var a = p ( a , "%Y-%m-%d %H:%M:%S" ) , d = new Aa ( b - Wa ( b ) ) , e , f = d [ sb ] ( ) , g = d [ tb ] ( ) , h = d [ Xa ] ( ) , i = d [ Ya ] ( ) , j = d [ Za ] ( ) , k = P . lang , l = k . weekdays , d = r ( { a : l [ g ] . substr ( 0 , 3 ) , A : l [ g ] ,
d : Ia ( h ) , e : h , w : g , b : k . shortMonths [ i ] , B : k . months [ i ] , m : Ia ( i + 1 ) , y : j . toString ( ) . substr ( 2 , 2 ) , Y : j , H : Ia ( f ) , I : Ia ( f % 12 || 12 ) , l : f % 12 || 12 , M : Ia ( d [ rb ] ( ) ) , p : f < 12 ? "AM" : "PM" , P : f < 12 ? "am" : "pm" , S : Ia ( d . getSeconds ( ) ) , L : Ia ( x ( b % 1E3 ) , 3 ) } , w . dateFormats ) ; for ( e in d ) for ( ; a . indexOf ( "%" + e ) !== - 1 ; ) a = a . replace ( "%" + e , typeof d [ e ] === "function" ? d [ e ] ( b ) : d [ e ] ) ; return c ? a . substr ( 0 , 1 ) . toUpperCase ( ) + a . substr ( 1 ) : a } ; G = { millisecond : 1 , second : 1E3 , minute : 6E4 , hour : 36E5 , day : 864E5 , week : 6048E5 , month : 24192E5 , year : 314496E5 } ; w . numberFormat = function ( a , b ,
c , d ) { var e = P . lang , a = + a || 0 , f = b === - 1 ? I ( ( a . toString ( ) . split ( "." ) [ 1 ] || "" ) . length , 20 ) : isNaN ( b = O ( b ) ) ? 2 : b , b = c === void 0 ? e . decimalPoint : c , d = d === void 0 ? e . thousandsSep : d , e = a < 0 ? "-" : "" , c = String ( B ( a = O ( a ) . toFixed ( f ) ) ) , g = c . length > 3 ? c . length % 3 : 0 ; return e + ( g ? c . substr ( 0 , g ) + d : "" ) + c . substr ( g ) . replace ( /(\d{3})(?=\d)/g , "$1" + d ) + ( f ? b + O ( a - c ) . toFixed ( f ) . slice ( 2 ) : "" ) } ; zb = { init : function ( a , b , c ) { var b = b || "" , d = a . shift , e = b . indexOf ( "C" ) > - 1 , f = e ? 7 : 3 , g , b = b . split ( " " ) , c = [ ] . concat ( c ) , h , i , j = function ( a ) { for ( g = a . length ; g -- ; ) a [ g ] === "M" && a . splice ( g +
1 , 0 , a [ g + 1 ] , a [ g + 2 ] , a [ g + 1 ] , a [ g + 2 ] ) } ; e && ( j ( b ) , j ( c ) ) ; a . isArea && ( h = b . splice ( b . length - 6 , 6 ) , i = c . splice ( c . length - 6 , 6 ) ) ; if ( d <= c . length / f && b . length === c . length ) for ( ; d -- ; ) c = [ ] . concat ( c ) . splice ( 0 , f ) . concat ( c ) ; a . shift = 0 ; if ( b . length ) for ( a = c . length ; b . length < a ; ) d = [ ] . concat ( b ) . splice ( b . length - f , f ) , e && ( d [ f - 6 ] = d [ f - 2 ] , d [ f - 5 ] = d [ f - 1 ] ) , b = b . concat ( d ) ; h && ( b = b . concat ( h ) , c = c . concat ( i ) ) ; return [ b , c ] } , step : function ( a , b , c , d ) { var e = [ ] , f = a . length ; if ( c === 1 ) e = d ; else if ( f === b . length && c < 1 ) for ( ; f -- ; ) d = parseFloat ( a [ f ] ) , e [ f ] = isNaN ( d ) ? a [ f ] :
c * parseFloat ( b [ f ] - d ) + d ; else e = b ; return e } } ; ( function ( a ) { H . HighchartsAdapter = H . HighchartsAdapter || a && { init : function ( b ) { var c = a . fx ; a . extend ( a . easing , { easeOutQuad : function ( a , b , c , g , h ) { return - g * ( b /= h ) * ( b - 2 ) + c } } ) ; a . each ( [ "cur" , "_default" , "width" , "height" , "opacity" ] , function ( b , e ) { var f = c . step , g ; e === "cur" ? f = c . prototype : e === "_default" && a . Tween && ( f = a . Tween . propHooks [ e ] , e = "set" ) ; ( g = f [ e ] ) && ( f [ e ] = function ( a ) { var c , a = b ? a : this ; if ( a . prop !== "align" ) return c = a . elem , c . attr ? c . attr ( a . prop , e === "cur" ? u : a . now ) : g . apply ( this ,
arguments ) } ) } ) ; cb ( a . cssHooks . opacity , "get" , function ( a , b , c ) { return b . attr ? b . opacity || 0 : a . call ( this , b , c ) } ) ; this . addAnimSetter ( "d" , function ( a ) { var c = a . elem , f ; if ( ! a . started ) f = b . init ( c , c . d , c . toD ) , a . start = f [ 0 ] , a . end = f [ 1 ] , a . started = ! 0 ; c . attr ( "d" , b . step ( a . start , a . end , a . pos , c . toD ) ) } ) ; this . each = Array . prototype . forEach ? function ( a , b ) { return Array . prototype . forEach . call ( a , b ) } : function ( a , b ) { var c , g = a . length ; for ( c = 0 ; c < g ; c ++ ) if ( b . call ( a [ c ] , a [ c ] , c , a ) === ! 1 ) return c } ; a . fn . highcharts = function ( ) { var a = "Chart" , b = arguments ,
c , g ; if ( this [ 0 ] ) { Da ( b [ 0 ] ) && ( a = b [ 0 ] , b = Array . prototype . slice . call ( b , 1 ) ) ; c = b [ 0 ] ; if ( c !== u ) c . chart = c . chart || { } , c . chart . renderTo = this [ 0 ] , new w [ a ] ( c , b [ 1 ] ) , g = this ; c === u && ( g = X [ L ( this [ 0 ] , "data-highcharts-chart" ) ] ) } return g } } , addAnimSetter : function ( b , c ) { a . Tween ? a . Tween . propHooks [ b ] = { set : c } : a . fx . step [ b ] = c } , getScript : a . getScript , inArray : a . inArray , adapterRun : function ( b , c ) { return a ( b ) [ c ] ( ) } , grep : a . grep , map : function ( a , c ) { for ( var d = [ ] , e = 0 , f = a . length ; e < f ; e ++ ) d [ e ] = c . call ( a [ e ] , a [ e ] , e , a ) ; return d } , offset : function ( b ) { return a ( b ) . offset ( ) } ,
addEvent : function ( b , c , d ) { a ( b ) . bind ( c , d ) } , removeEvent : function ( b , c , d ) { var e = A . removeEventListener ? "removeEventListener" : "detachEvent" ; A [ e ] && b && ! b [ e ] && ( b [ e ] = function ( ) { } ) ; a ( b ) . unbind ( c , d ) } , fireEvent : function ( b , c , d , e ) { var f = a . Event ( c ) , g = "detached" + c , h ; ! ya && d && ( delete d . layerX , delete d . layerY , delete d . returnValue ) ; r ( f , d ) ; b [ c ] && ( b [ g ] = b [ c ] , b [ c ] = null ) ; a . each ( [ "preventDefault" , "stopPropagation" ] , function ( a , b ) { var c = f [ b ] ; f [ b ] = function ( ) { try { c . call ( f ) } catch ( a ) { b === "preventDefault" && ( h = ! 0 ) } } } ) ; a ( b ) . trigger ( f ) ;
b [ g ] && ( b [ c ] = b [ g ] , b [ g ] = null ) ; e && ! f . isDefaultPrevented ( ) && ! h && e ( f ) } , washMouseEvent : function ( a ) { var c = a . originalEvent || a ; if ( c . pageX === u ) c . pageX = a . pageX , c . pageY = a . pageY ; return c } , animate : function ( b , c , d ) { var e = a ( b ) ; if ( ! b . style ) b . style = { } ; if ( c . d ) b . toD = c . d , c . d = 1 ; e . stop ( ) ; c . opacity !== u && b . attr && ( c . opacity += "px" ) ; b . hasAnim = 1 ; e . animate ( c , d ) } , stop : function ( b ) { b . hasAnim && a ( b ) . stop ( ) } } } ) ( H . jQuery ) ; var T = H . HighchartsAdapter , D = T || { } ; T && T . init . call ( T , zb ) ; var jb = D . adapterRun , Qb = D . getScript , Ma = D . inArray , m = w . each = D . each ,
kb = D . grep , Rb = D . offset , Ua = D . map , N = D . addEvent , Y = D . removeEvent , M = D . fireEvent , Sb = D . washMouseEvent , lb = D . animate , db = D . stop ; P = { colors : "#7cb5ec,#434348,#90ed7d,#f7a35c,#8085e9,#f15c80,#e4d354,#2b908f,#f45b5b,#91e8e1" . split ( "," ) , symbols : [ "circle" , "diamond" , "square" , "triangle" , "triangle-down" ] , lang : { loading : "Loading..." , months : "January,February,March,April,May,June,July,August,September,October,November,December" . split ( "," ) , shortMonths : "Jan,Feb,Mar,Apr,May,Jun,Jul,Aug,Sep,Oct,Nov,Dec" . split ( "," ) , weekdays : "Sunday,Monday,Tuesday,Wednesday,Thursday,Friday,Saturday" . split ( "," ) ,
decimalPoint : "." , numericSymbols : "k,M,G,T,P,E" . split ( "," ) , resetZoom : "Reset zoom" , resetZoomTitle : "Reset zoom level 1:1" , thousandsSep : " " } , global : { useUTC : ! 0 , canvasToolsURL : "http://code.highcharts.com/4.1.5/modules/canvas-tools.js" , VMLRadialGradientURL : "http://code.highcharts.com/4.1.5/gfx/vml-radial-gradient.png" } , chart : { borderColor : "#4572A7" , borderRadius : 0 , defaultSeriesType : "line" , ignoreHiddenSeries : ! 0 , spacing : [ 10 , 10 , 15 , 10 ] , backgroundColor : "#FFFFFF" , plotBorderColor : "#C0C0C0" , resetZoomButton : { theme : { zIndex : 20 } ,
position : { align : "right" , x : - 10 , y : 10 } } } , title : { text : "Chart title" , align : "center" , margin : 15 , style : { color : "#333333" , fontSize : "18px" } } , subtitle : { text : "" , align : "center" , style : { color : "#555555" } } , plotOptions : { line : { allowPointSelect : ! 1 , showCheckbox : ! 1 , animation : { duration : 1E3 } , events : { } , lineWidth : 2 , marker : { lineWidth : 0 , radius : 4 , lineColor : "#FFFFFF" , states : { hover : { enabled : ! 0 , lineWidthPlus : 1 , radiusPlus : 2 } , select : { fillColor : "#FFFFFF" , lineColor : "#000000" , lineWidth : 2 } } } , point : { events : { } } , dataLabels : { align : "center" ,
formatter : function ( ) { return this . y === null ? "" : w . numberFormat ( this . y , - 1 ) } , style : { color : "contrast" , fontSize : "11px" , fontWeight : "bold" , textShadow : "0 0 6px contrast, 0 0 3px contrast" } , verticalAlign : "bottom" , x : 0 , y : 0 , padding : 5 } , cropThreshold : 300 , pointRange : 0 , states : { hover : { lineWidthPlus : 1 , marker : { } , halo : { size : 10 , opacity : 0.25 } } , select : { marker : { } } } , stickyTracking : ! 0 , turboThreshold : 1E3 } } , labels : { style : { position : "absolute" , color : "#3E576F" } } , legend : { enabled : ! 0 , align : "center" , layout : "horizontal" , labelFormatter : function ( ) { return this . name } ,
borderColor : "#909090" , borderRadius : 0 , navigation : { activeColor : "#274b6d" , inactiveColor : "#CCC" } , shadow : ! 1 , itemStyle : { color : "#333333" , fontSize : "12px" , fontWeight : "bold" } , itemHoverStyle : { color : "#000" } , itemHiddenStyle : { color : "#CCC" } , itemCheckboxStyle : { position : "absolute" , width : "13px" , height : "13px" } , symbolPadding : 5 , verticalAlign : "bottom" , x : 0 , y : 0 , title : { style : { fontWeight : "bold" } } } , loading : { labelStyle : { fontWeight : "bold" , position : "relative" , top : "45%" } , style : { position : "absolute" , backgroundColor : "white" , opacity : 0.5 ,
textAlign : "center" } } , tooltip : { enabled : ! 0 , animation : ba , backgroundColor : "rgba(249, 249, 249, .85)" , borderWidth : 1 , borderRadius : 3 , dateTimeLabelFormats : { millisecond : "%A, %b %e, %H:%M:%S.%L" , second : "%A, %b %e, %H:%M:%S" , minute : "%A, %b %e, %H:%M" , hour : "%A, %b %e, %H:%M" , day : "%A, %b %e, %Y" , week : "Week from %A, %b %e, %Y" , month : "%B %Y" , year : "%Y" } , footerFormat : "" , headerFormat : '<span style="font-size: 10px">{point.key}</span><br/>' , pointFormat : '<span style="color:{point.color}">\u25CF</span> {series.name}: <b>{point.y}</b><br/>' ,
shadow : ! 0 , snap : Jb ? 25 : 10 , style : { color : "#333333" , cursor : "default" , fontSize : "12px" , padding : "8px" , whiteSpace : "nowrap" } } , credits : { enabled : ! 0 , text : "Highcharts.com" , href : "http://www.highcharts.com" , position : { align : "right" , x : - 10 , verticalAlign : "bottom" , y : - 5 } , style : { cursor : "pointer" , color : "#909090" , fontSize : "9px" } } } ; var aa = P . plotOptions , T = aa . line ; Cb ( ) ; var Tb = /rgba\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]?(?:\.[0-9]+)?)\s*\)/ , Ub = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/ ,
Vb = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/ , na = function ( a ) { var b = [ ] , c , d ; ( function ( a ) { a && a . stops ? d = Ua ( a . stops , function ( a ) { return na ( a [ 1 ] ) } ) : ( c = Tb . exec ( a ) ) ? b = [ B ( c [ 1 ] ) , B ( c [ 2 ] ) , B ( c [ 3 ] ) , parseFloat ( c [ 4 ] , 10 ) ] : ( c = Ub . exec ( a ) ) ? b = [ B ( c [ 1 ] , 16 ) , B ( c [ 2 ] , 16 ) , B ( c [ 3 ] , 16 ) , 1 ] : ( c = Vb . exec ( a ) ) && ( b = [ B ( c [ 1 ] ) , B ( c [ 2 ] ) , B ( c [ 3 ] ) , 1 ] ) } ) ( a ) ; return { get : function ( c ) { var f ; d ? ( f = z ( a ) , f . stops = [ ] . concat ( f . stops ) , m ( d , function ( a , b ) { f . stops [ b ] = [ f . stops [ b ] [ 0 ] , a . get ( c ) ] } ) ) : f = b && ! isNaN ( b [ 0 ] ) ? c === "rgb" ? "rgb(" + b [ 0 ] + "," +
b [ 1 ] + "," + b [ 2 ] + ")" : c === "a" ? b [ 3 ] : "rgba(" + b . join ( "," ) + ")" : a ; return f } , brighten : function ( a ) { if ( d ) m ( d , function ( b ) { b . brighten ( a ) } ) ; else if ( qa ( a ) && a !== 0 ) { var c ; for ( c = 0 ; c < 3 ; c ++ ) b [ c ] += B ( a * 255 ) , b [ c ] < 0 && ( b [ c ] = 0 ) , b [ c ] > 255 && ( b [ c ] = 255 ) } return this } , rgba : b , setOpacity : function ( a ) { b [ 3 ] = a ; return this } , raw : a } } ; K . prototype = { opacity : 1 , textProps : "fontSize,fontWeight,fontFamily,fontStyle,color,lineHeight,width,textDecoration,textShadow" . split ( "," ) , init : function ( a , b ) { this . element = b === "span" ? Z ( b ) : A . createElementNS ( Ca , b ) ;
this . renderer = a } , animate : function ( a , b , c ) { b = p ( b , za , ! 0 ) ; db ( this ) ; if ( b ) { b = z ( b , { } ) ; if ( c ) b . complete = c ; lb ( this , a , b ) } else this . attr ( a ) , c && c ( ) ; return this } , colorGradient : function ( a , b , c ) { var d = this . renderer , e , f , g , h , i , j , k , l , n , o , q = [ ] ; a . linearGradient ? f = "linearGradient" : a . radialGradient && ( f = "radialGradient" ) ; if ( f ) { g = a [ f ] ; h = d . gradients ; j = a . stops ; n = c . radialReference ; Ha ( g ) && ( a [ f ] = g = { x1 : g [ 0 ] , y1 : g [ 1 ] , x2 : g [ 2 ] , y2 : g [ 3 ] , gradientUnits : "userSpaceOnUse" } ) ; f === "radialGradient" && n && ! s ( g . gradientUnits ) && ( g = z ( g , { cx : n [ 0 ] - n [ 2 ] /
2 + g . cx * n [ 2 ] , cy : n [ 1 ] - n [ 2 ] / 2 + g . cy * n [ 2 ] , r : g . r * n [ 2 ] , gradientUnits : "userSpaceOnUse" } ) ) ; for ( o in g ) o !== "id" && q . push ( o , g [ o ] ) ; for ( o in j ) q . push ( j [ o ] ) ; q = q . join ( "," ) ; h [ q ] ? a = h [ q ] . attr ( "id" ) : ( g . id = a = "highcharts-" + yb ++ , h [ q ] = i = d . createElement ( f ) . attr ( g ) . add ( d . defs ) , i . stops = [ ] , m ( j , function ( a ) { a [ 1 ] . indexOf ( "rgba" ) === 0 ? ( e = na ( a [ 1 ] ) , k = e . get ( "rgb" ) , l = e . get ( "a" ) ) : ( k = a [ 1 ] , l = 1 ) ; a = d . createElement ( "stop" ) . attr ( { offset : a [ 0 ] , "stop-color" : k , "stop-opacity" : l } ) . add ( i ) ; i . stops . push ( a ) } ) ) ; c . setAttribute ( b , "url(" + d . url + "#" + a + ")" ) } } ,
applyTextShadow : function ( a ) { var b = this . element , c , d = a . indexOf ( "contrast" ) !== - 1 , e = this . renderer . forExport || b . style . textShadow !== u && ! ya ; d && ( a = a . replace ( /contrast/g , this . renderer . getContrast ( b . style . fill ) ) ) ; e ? d && F ( b , { textShadow : a } ) : ( this . fakeTS = ! 0 , this . ySetter = this . xSetter , c = [ ] . slice . call ( b . getElementsByTagName ( "tspan" ) ) , m ( a . split ( /\s?,\s?/g ) , function ( a ) { var d = b . firstChild , e , i , a = a . split ( " " ) ; e = a [ a . length - 1 ] ; ( i = a [ a . length - 2 ] ) && m ( c , function ( a , c ) { var f ; c === 0 && ( a . setAttribute ( "x" , b . getAttribute ( "x" ) ) , c = b . getAttribute ( "y" ) ,
a . setAttribute ( "y" , c || 0 ) , c === null && b . setAttribute ( "y" , 0 ) ) ; f = a . cloneNode ( 1 ) ; L ( f , { "class" : "highcharts-text-shadow" , fill : e , stroke : e , "stroke-opacity" : 1 / t ( B ( i ) , 3 ) , "stroke-width" : i , "stroke-linejoin" : "round" } ) ; b . insertBefore ( f , d ) } ) } ) ) } , attr : function ( a , b ) { var c , d , e = this . element , f , g = this , h ; typeof a === "string" && b !== u && ( c = a , a = { } , a [ c ] = b ) ; if ( typeof a === "string" ) g = ( this [ a + "Getter" ] || this . _defaultGetter ) . call ( this , a , e ) ; else { for ( c in a ) { d = a [ c ] ; h = ! 1 ; this . symbolName && /^(x|y|width|height|r|start|end|innerR|anchorX|anchorY)/ . test ( c ) &&
( f || ( this . symbolAttr ( a ) , f = ! 0 ) , h = ! 0 ) ; if ( this . rotation && ( c === "x" || c === "y" ) ) this . doTransform = ! 0 ; h || ( this [ c + "Setter" ] || this . _defaultSetter ) . call ( this , d , c , e ) ; this . shadows && /^(width|height|visibility|x|y|d|transform|cx|cy|r)$/ . test ( c ) && this . updateShadows ( c , d ) } if ( this . doTransform ) this . updateTransform ( ) , this . doTransform = ! 1 } return g } , updateShadows : function ( a , b ) { for ( var c = this . shadows , d = c . length ; d -- ; ) c [ d ] . setAttribute ( a , a === "height" ? t ( b - ( c [ d ] . cutHeight || 0 ) , 0 ) : a === "d" ? this . d : b ) } , addClass : function ( a ) { var b = this . element ,
c = L ( b , "class" ) || "" ; c . indexOf ( a ) === - 1 && L ( b , "class" , c + " " + a ) ; return this } , symbolAttr : function ( a ) { var b = this ; m ( "x,y,r,start,end,width,height,innerR,anchorX,anchorY" . split ( "," ) , function ( c ) { b [ c ] = p ( a [ c ] , b [ c ] ) } ) ; b . attr ( { d : b . renderer . symbols [ b . symbolName ] ( b . x , b . y , b . width , b . height , b ) } ) } , clip : function ( a ) { return this . attr ( "clip-path" , a ? "url(" + this . renderer . url + "#" + a . id + ")" : R ) } , crisp : function ( a ) { var b , c = { } , d , e = a . strokeWidth || this . strokeWidth || 0 ; d = x ( e ) % 2 / 2 ; a . x = U ( a . x || this . x || 0 ) + d ; a . y = U ( a . y || this . y || 0 ) + d ; a . width =
U ( ( a . width || this . width || 0 ) - 2 * d ) ; a . height = U ( ( a . height || this . height || 0 ) - 2 * d ) ; a . strokeWidth = e ; for ( b in a ) this [ b ] !== a [ b ] && ( this [ b ] = c [ b ] = a [ b ] ) ; return c } , css : function ( a ) { var b = this . styles , c = { } , d = this . element , e , f , g = "" ; e = ! b ; if ( a && a . color ) a . fill = a . color ; if ( b ) for ( f in a ) a [ f ] !== b [ f ] && ( c [ f ] = a [ f ] , e = ! 0 ) ; if ( e ) { e = this . textWidth = a && a . width && d . nodeName . toLowerCase ( ) === "text" && B ( a . width ) || this . textWidth ; b && ( a = r ( b , c ) ) ; this . styles = a ; e && ( ea || ! ba && this . renderer . forExport ) && delete a . width ; if ( ya && ! ba ) F ( this . element , a ) ; else { b =
function ( a , b ) { return "-" + b . toLowerCase ( ) } ; for ( f in a ) g += f . replace ( /([A-Z])/g , b ) + ":" + a [ f ] + ";" ; L ( d , "style" , g ) } e && this . added && this . renderer . buildText ( this ) } return this } , on : function ( a , b ) { var c = this , d = c . element ; ab && a === "click" ? ( d . ontouchstart = function ( a ) { c . touchEventFired = Aa . now ( ) ; a . preventDefault ( ) ; b . call ( d , a ) } , d . onclick = function ( a ) { ( Ba . indexOf ( "Android" ) === - 1 || Aa . now ( ) - ( c . touchEventFired || 0 ) > 1100 ) && b . call ( d , a ) } ) : d [ "on" + a ] = b ; return this } , setRadialReference : function ( a ) { this . element . radialReference = a ; return this } ,
translate : function ( a , b ) { return this . attr ( { translateX : a , translateY : b } ) } , invert : function ( ) { this . inverted = ! 0 ; this . updateTransform ( ) ; return this } , updateTransform : function ( ) { var a = this . translateX || 0 , b = this . translateY || 0 , c = this . scaleX , d = this . scaleY , e = this . inverted , f = this . rotation , g = this . element ; e && ( a += this . attr ( "width" ) , b += this . attr ( "height" ) ) ; a = [ "translate(" + a + "," + b + ")" ] ; e ? a . push ( "rotate(90) scale(-1,1)" ) : f && a . push ( "rotate(" + f + " " + ( g . getAttribute ( "x" ) || 0 ) + " " + ( g . getAttribute ( "y" ) || 0 ) + ")" ) ; ( s ( c ) || s ( d ) ) &&
a . push ( "scale(" + p ( c , 1 ) + " " + p ( d , 1 ) + ")" ) ; a . length && g . setAttribute ( "transform" , a . join ( " " ) ) } , toFront : function ( ) { var a = this . element ; a . parentNode . appendChild ( a ) ; return this } , align : function ( a , b , c ) { var d , e , f , g , h = { } ; e = this . renderer ; f = e . alignedObjects ; if ( a ) { if ( this . alignOptions = a , this . alignByTranslate = b , ! c || Da ( c ) ) this . alignTo = d = c || "renderer" , ia ( f , this ) , f . push ( this ) , c = null } else a = this . alignOptions , b = this . alignByTranslate , d = this . alignTo ; c = p ( c , e [ d ] , e ) ; d = a . align ; e = a . verticalAlign ; f = ( c . x || 0 ) + ( a . x || 0 ) ; g = ( c . y || 0 ) +
( a . y || 0 ) ; if ( d === "right" || d === "center" ) f += ( c . width - ( a . width || 0 ) ) / { right : 1 , center : 2 } [ d ] ; h [ b ? "translateX" : "x" ] = x ( f ) ; if ( e === "bottom" || e === "middle" ) g += ( c . height - ( a . height || 0 ) ) / ( { bottom : 1 , middle : 2 } [ e ] || 1 ) ; h [ b ? "translateY" : "y" ] = x ( g ) ; this [ this . placed ? "animate" : "attr" ] ( h ) ; this . placed = ! 0 ; this . alignAttr = h ; return this } , getBBox : function ( a ) { var b , c = this . renderer , d , e = this . rotation , f = this . element , g = this . styles , h = e * ga ; d = this . textStr ; var i , j = f . style , k , l ; d !== u && ( l = [ "" , e || 0 , g && g . fontSize , f . style . width ] . join ( "," ) , l = d ===
"" || Ob . test ( d ) ? "num:" + d . toString ( ) . length + l : d + l ) ; l && ! a && ( b = c . cache [ l ] ) ; if ( ! b ) { if ( f . namespaceURI === Ca || c . forExport ) { try { k = this . fakeTS && function ( a ) { m ( f . querySelectorAll ( ".highcharts-text-shadow" ) , function ( b ) { b . style . display = a } ) } , La && j . textShadow ? ( i = j . textShadow , j . textShadow = "" ) : k && k ( R ) , b = f . getBBox ? r ( { } , f . getBBox ( ) ) : { width : f . offsetWidth , height : f . offsetHeight } , i ? j . textShadow = i : k && k ( "" ) } catch ( n ) { } if ( ! b || b . width < 0 ) b = { width : 0 , height : 0 } } else b = this . htmlGetBBox ( ) ; if ( c . isSVG ) { a = b . width ; d = b . height ; if ( ya && g &&
g . fontSize === "11px" && d . toPrecision ( 3 ) === "16.9" ) b . height = d = 14 ; if ( e ) b . width = O ( d * $ ( h ) ) + O ( a * W ( h ) ) , b . height = O ( d * W ( h ) ) + O ( a * $ ( h ) ) } c . cache [ l ] = b } return b } , show : function ( a ) { a && this . element . namespaceURI === Ca ? this . element . removeAttribute ( "visibility" ) : this . attr ( { visibility : a ? "inherit" : "visible" } ) ; return this } , hide : function ( ) { return this . attr ( { visibility : "hidden" } ) } , fadeOut : function ( a ) { var b = this ; b . animate ( { opacity : 0 } , { duration : a || 150 , complete : function ( ) { b . attr ( { y : - 9999 } ) } } ) } , add : function ( a ) { var b = this . renderer ,
c = this . element , d ; if ( a ) this . parentGroup = a ; this . parentInverted = a && a . inverted ; this . textStr !== void 0 && b . buildText ( this ) ; this . added = ! 0 ; if ( ! a || a . handleZ || this . zIndex ) d = this . zIndexSetter ( ) ; d || ( a ? a . element : b . box ) . appendChild ( c ) ; if ( this . onAdd ) this . onAdd ( ) ; return this } , safeRemoveChild : function ( a ) { var b = a . parentNode ; b && b . removeChild ( a ) } , destroy : function ( ) { var a = this , b = a . element || { } , c = a . shadows , d = a . renderer . isSVG && b . nodeName === "SPAN" && a . parentGroup , e , f ; b . onclick = b . onmouseout = b . onmouseover = b . onmousemove = b . point =
null ; db ( a ) ; if ( a . clipPath ) a . clipPath = a . clipPath . destroy ( ) ; if ( a . stops ) { for ( f = 0 ; f < a . stops . length ; f ++ ) a . stops [ f ] = a . stops [ f ] . destroy ( ) ; a . stops = null } a . safeRemoveChild ( b ) ; for ( c && m ( c , function ( b ) { a . safeRemoveChild ( b ) } ) ; d && d . div && d . div . childNodes . length === 0 ; ) b = d . parentGroup , a . safeRemoveChild ( d . div ) , delete d . div , d = b ; a . alignTo && ia ( a . renderer . alignedObjects , a ) ; for ( e in a ) delete a [ e ] ; return null } , shadow : function ( a , b , c ) { var d = [ ] , e , f , g = this . element , h , i , j , k ; if ( a ) { i = p ( a . width , 3 ) ; j = ( a . opacity || 0.15 ) / i ; k = this . parentInverted ?
"(-1,-1)" : "(" + p ( a . offsetX , 1 ) + ", " + p ( a . offsetY , 1 ) + ")" ; for ( e = 1 ; e <= i ; e ++ ) { f = g . cloneNode ( 0 ) ; h = i * 2 + 1 - 2 * e ; L ( f , { isShadow : "true" , stroke : a . color || "black" , "stroke-opacity" : j * e , "stroke-width" : h , transform : "translate" + k , fill : R } ) ; if ( c ) L ( f , "height" , t ( L ( f , "height" ) - h , 0 ) ) , f . cutHeight = h ; b ? b . element . appendChild ( f ) : g . parentNode . insertBefore ( f , g ) ; d . push ( f ) } this . shadows = d } return this } , xGetter : function ( a ) { this . element . nodeName === "circle" && ( a = { x : "cx" , y : "cy" } [ a ] || a ) ; return this . _defaultGetter ( a ) } , _defaultGetter : function ( a ) { a =
p ( this [ a ] , this . element ? this . element . getAttribute ( a ) : null , 0 ) ; /^[\-0-9\.]+$/ . test ( a ) && ( a = parseFloat ( a ) ) ; return a } , dSetter : function ( a , b , c ) { a && a . join && ( a = a . join ( " " ) ) ; /(NaN| {2}|^$)/ . test ( a ) && ( a = "M 0 0" ) ; c . setAttribute ( b , a ) ; this [ b ] = a } , dashstyleSetter : function ( a ) { var b ; if ( a = a && a . toLowerCase ( ) ) { a = a . replace ( "shortdashdotdot" , "3,1,1,1,1,1," ) . replace ( "shortdashdot" , "3,1,1,1" ) . replace ( "shortdot" , "1,1," ) . replace ( "shortdash" , "3,1," ) . replace ( "longdash" , "8,3," ) . replace ( /dot/g , "1,3," ) . replace ( "dash" , "4,3," ) . replace ( /,$/ ,
"" ) . split ( "," ) ; for ( b = a . length ; b -- ; ) a [ b ] = B ( a [ b ] ) * this [ "stroke-width" ] ; a = a . join ( "," ) . replace ( "NaN" , "none" ) ; this . element . setAttribute ( "stroke-dasharray" , a ) } } , alignSetter : function ( a ) { this . element . setAttribute ( "text-anchor" , { left : "start" , center : "middle" , right : "end" } [ a ] ) } , opacitySetter : function ( a , b , c ) { this [ b ] = a ; c . setAttribute ( b , a ) } , titleSetter : function ( a ) { var b = this . element . getElementsByTagName ( "title" ) [ 0 ] ; b || ( b = A . createElementNS ( Ca , "title" ) , this . element . appendChild ( b ) ) ; b . textContent = String ( p ( a ) , "" ) . replace ( /<[^>]*>/g ,
"" ) } , textSetter : function ( a ) { if ( a !== this . textStr ) delete this . bBox , this . textStr = a , this . added && this . renderer . buildText ( this ) } , fillSetter : function ( a , b , c ) { typeof a === "string" ? c . setAttribute ( b , a ) : a && this . colorGradient ( a , b , c ) } , zIndexSetter : function ( a , b ) { var c = this . renderer , d = this . parentGroup , c = ( d || c ) . element || c . box , e , f , g = this . element , h ; e = this . added ; var i ; s ( a ) && ( g . setAttribute ( b , a ) , a = + a , this [ b ] === a && ( e = ! 1 ) , this [ b ] = a ) ; if ( e ) { if ( ( a = this . zIndex ) && d ) d . handleZ = ! 0 ; d = c . childNodes ; for ( i = 0 ; i < d . length && ! h ; i ++ ) if ( e =
d [ i ] , f = L ( e , "zIndex" ) , e !== g && ( B ( f ) > a || ! s ( a ) && s ( f ) ) ) c . insertBefore ( g , e ) , h = ! 0 ; h || c . appendChild ( g ) } return h } , _defaultSetter : function ( a , b , c ) { c . setAttribute ( b , a ) } } ; K . prototype . yGetter = K . prototype . xGetter ; K . prototype . translateXSetter = K . prototype . translateYSetter = K . prototype . rotationSetter = K . prototype . verticalAlignSetter = K . prototype . scaleXSetter = K . prototype . scaleYSetter = function ( a , b ) { this [ b ] = a ; this . doTransform = ! 0 } ; K . prototype [ "stroke-widthSetter" ] = K . prototype . strokeSetter = function ( a , b , c ) { this [ b ] = a ; if ( this . stroke &&
this [ "stroke-width" ] ) this . strokeWidth = this [ "stroke-width" ] , K . prototype . fillSetter . call ( this , this . stroke , "stroke" , c ) , c . setAttribute ( "stroke-width" , this [ "stroke-width" ] ) , this . hasStroke = ! 0 ; else if ( b === "stroke-width" && a === 0 && this . hasStroke ) c . removeAttribute ( "stroke" ) , this . hasStroke = ! 1 } ; var ta = function ( ) { this . init . apply ( this , arguments ) } ; ta . prototype = { Element : K , init : function ( a , b , c , d , e ) { var f = location , g , d = this . createElement ( "svg" ) . attr ( { version : "1.1" } ) . css ( this . getStyle ( d ) ) ; g = d . element ; a . appendChild ( g ) ;
a . innerHTML . indexOf ( "xmlns" ) === - 1 && L ( g , "xmlns" , Ca ) ; this . isSVG = ! 0 ; this . box = g ; this . boxWrapper = d ; this . alignedObjects = [ ] ; this . url = ( La || xb ) && A . getElementsByTagName ( "base" ) . length ? f . href . replace ( /#.*?$/ , "" ) . replace ( /([\('\)])/g , "\\$1" ) . replace ( / /g , "%20" ) : "" ; this . createElement ( "desc" ) . add ( ) . element . appendChild ( A . createTextNode ( "Created with Highcharts 4.1.5" ) ) ; this . defs = this . createElement ( "defs" ) . add ( ) ; this . forExport = e ; this . gradients = { } ; this . cache = { } ; this . setSize ( b , c , ! 1 ) ; var h ; if ( La && a . getBoundingClientRect ) this . subPixelFix =
b = function ( ) { F ( a , { left : 0 , top : 0 } ) ; h = a . getBoundingClientRect ( ) ; F ( a , { left : sa ( h . left ) - h . left + "px" , top : sa ( h . top ) - h . top + "px" } ) } , b ( ) , N ( H , "resize" , b ) } , getStyle : function ( a ) { return this . style = r ( { fontFamily : '"Lucida Grande", "Lucida Sans Unicode", Arial, Helvetica, sans-serif' , fontSize : "12px" } , a ) } , isHidden : function ( ) { return ! this . boxWrapper . getBBox ( ) . width } , destroy : function ( ) { var a = this . defs ; this . box = null ; this . boxWrapper = this . boxWrapper . destroy ( ) ; Qa ( this . gradients || { } ) ; this . gradients = null ; if ( a ) this . defs = a . destroy ( ) ;
this . subPixelFix && Y ( H , "resize" , this . subPixelFix ) ; return this . alignedObjects = null } , createElement : function ( a ) { var b = new this . Element ; b . init ( this , a ) ; return b } , draw : function ( ) { } , buildText : function ( a ) { for ( var b = a . element , c = this , d = c . forExport , e = p ( a . textStr , "" ) . toString ( ) , f = e . indexOf ( "<" ) !== - 1 , g = b . childNodes , h , i , j = L ( b , "x" ) , k = a . styles , l = a . textWidth , n = k && k . lineHeight , o = k && k . textShadow , q = k && k . textOverflow === "ellipsis" , y = g . length , S = l && ! a . added && this . box , C = function ( a ) { return n ? B ( n ) : c . fontMetrics ( /(px|em)$/ . test ( a &&
a . style . fontSize ) ? a . style . fontSize : k && k . fontSize || c . style . fontSize || 12 , a ) . h } , v = function ( a ) { return a . replace ( /</g , "<" ) . replace ( />/g , ">" ) } ; y -- ; ) b . removeChild ( g [ y ] ) ; ! f && ! o && ! q && e . indexOf ( " " ) === - 1 ? b . appendChild ( A . createTextNode ( v ( e ) ) ) : ( h = /<.*style="([^"]+)".*>/ , i = /<.*href="(http[^"]+)".*>/ , S && S . appendChild ( b ) , e = f ? e . replace ( /<(b|strong)>/g , '<span style="font-weight:bold">' ) . replace ( /<(i|em)>/g , '<span style="font-style:italic">' ) . replace ( /<a/g , "<span" ) . replace ( /<\/(b|strong|i|em|a)>/g , "</span>" ) . split ( /<br.*?>/g ) :
[ e ] , e [ e . length - 1 ] === "" && e . pop ( ) , m ( e , function ( e , f ) { var g , n = 0 , e = e . replace ( /<span/g , "|||<span" ) . replace ( /<\/span>/g , "</span>|||" ) ; g = e . split ( "|||" ) ; m ( g , function ( e ) { if ( e !== "" || g . length === 1 ) { var o = { } , y = A . createElementNS ( Ca , "tspan" ) , p ; h . test ( e ) && ( p = e . match ( h ) [ 1 ] . replace ( /(;| |^)color([ :])/ , "$1fill$2" ) , L ( y , "style" , p ) ) ; i . test ( e ) && ! d && ( L ( y , "onclick" , 'location.href="' + e . match ( i ) [ 1 ] + '"' ) , F ( y , { cursor : "pointer" } ) ) ; e = v ( e . replace ( /<(.|\n)*?>/g , "" ) || " " ) ; if ( e !== " " ) { y . appendChild ( A . createTextNode ( e ) ) ; if ( n ) o . dx = 0 ;
else if ( f && j !== null ) o . x = j ; L ( y , o ) ; b . appendChild ( y ) ; ! n && f && ( ! ba && d && F ( y , { display : "block" } ) , L ( y , "dy" , C ( y ) ) ) ; if ( l ) { for ( var o = e . replace ( /([^\^])-/g , "$1- " ) . split ( " " ) , m = g . length > 1 || f || o . length > 1 && k . whiteSpace !== "nowrap" , S , s , ua , u = [ ] , t = C ( y ) , x = 1 , r = a . rotation , z = e , w = z . length ; ( m || q ) && ( o . length || u . length ) ; ) a . rotation = 0 , S = a . getBBox ( ! 0 ) , ua = S . width , ! ba && c . forExport && ( ua = c . measureSpanWidth ( y . firstChild . data , a . styles ) ) , S = ua > l , s === void 0 && ( s = S ) , q && s ? ( w /= 2 , z === "" || ! S && w < 0.5 ? o = [ ] : ( S && ( s = ! 0 ) , z = e . substring ( 0 , z . length +
( S ? - 1 : 1 ) * sa ( w ) ) , o = [ z + "…" ] , y . removeChild ( y . firstChild ) ) ) : ! S || o . length === 1 ? ( o = u , u = [ ] , o . length && ( x ++ , y = A . createElementNS ( Ca , "tspan" ) , L ( y , { dy : t , x : j } ) , p && L ( y , "style" , p ) , b . appendChild ( y ) ) , ua > l && ( l = ua ) ) : ( y . removeChild ( y . firstChild ) , u . unshift ( o . pop ( ) ) ) , o . length && y . appendChild ( A . createTextNode ( o . join ( " " ) . replace ( /- /g , "-" ) ) ) ; s && a . attr ( "title" , a . textStr ) ; a . rotation = r } n ++ } } } ) } ) , S && S . removeChild ( b ) , o && a . applyTextShadow && a . applyTextShadow ( o ) ) } , getContrast : function ( a ) { a = na ( a ) . rgba ; return a [ 0 ] + a [ 1 ] + a [ 2 ] > 384 ? "#000" :
"#FFF" } , button : function ( a , b , c , d , e , f , g , h , i ) { var j = this . label ( a , b , c , i , null , null , null , null , "button" ) , k = 0 , l , n , o , q , y , p , a = { x1 : 0 , y1 : 0 , x2 : 0 , y2 : 1 } , e = z ( { "stroke-width" : 1 , stroke : "#CCCCCC" , fill : { linearGradient : a , stops : [ [ 0 , "#FEFEFE" ] , [ 1 , "#F6F6F6" ] ] } , r : 2 , padding : 5 , style : { color : "black" } } , e ) ; o = e . style ; delete e . style ; f = z ( e , { stroke : "#68A" , fill : { linearGradient : a , stops : [ [ 0 , "#FFF" ] , [ 1 , "#ACF" ] ] } } , f ) ; q = f . style ; delete f . style ; g = z ( e , { stroke : "#68A" , fill : { linearGradient : a , stops : [ [ 0 , "#9BD" ] , [ 1 , "#CDF" ] ] } } , g ) ; y = g . style ; delete g . style ;
h = z ( e , { style : { color : "#CCC" } } , h ) ; p = h . style ; delete h . style ; N ( j . element , ya ? "mouseover" : "mouseenter" , function ( ) { k !== 3 && j . attr ( f ) . css ( q ) } ) ; N ( j . element , ya ? "mouseout" : "mouseleave" , function ( ) { k !== 3 && ( l = [ e , f , g ] [ k ] , n = [ o , q , y ] [ k ] , j . attr ( l ) . css ( n ) ) } ) ; j . setState = function ( a ) { ( j . state = k = a ) ? a === 2 ? j . attr ( g ) . css ( y ) : a === 3 && j . attr ( h ) . css ( p ) : j . attr ( e ) . css ( o ) } ; return j . on ( "click" , function ( ) { k !== 3 && d . call ( j ) } ) . attr ( e ) . css ( r ( { cursor : "default" } , o ) ) } , crispLine : function ( a , b ) { a [ 1 ] === a [ 4 ] && ( a [ 1 ] = a [ 4 ] = x ( a [ 1 ] ) - b % 2 / 2 ) ; a [ 2 ] === a [ 5 ] &&
( a [ 2 ] = a [ 5 ] = x ( a [ 2 ] ) + b % 2 / 2 ) ; return a } , path : function ( a ) { var b = { fill : R } ; Ha ( a ) ? b . d = a : ca ( a ) && r ( b , a ) ; return this . createElement ( "path" ) . attr ( b ) } , circle : function ( a , b , c ) { a = ca ( a ) ? a : { x : a , y : b , r : c } ; b = this . createElement ( "circle" ) ; b . xSetter = function ( a ) { this . element . setAttribute ( "cx" , a ) } ; b . ySetter = function ( a ) { this . element . setAttribute ( "cy" , a ) } ; return b . attr ( a ) } , arc : function ( a , b , c , d , e , f ) { if ( ca ( a ) ) b = a . y , c = a . r , d = a . innerR , e = a . start , f = a . end , a = a . x ; a = this . symbol ( "arc" , a || 0 , b || 0 , c || 0 , c || 0 , { innerR : d || 0 , start : e || 0 , end : f || 0 } ) ;
a . r = c ; return a } , rect : function ( a , b , c , d , e , f ) { var e = ca ( a ) ? a . r : e , g = this . createElement ( "rect" ) , a = ca ( a ) ? a : a === u ? { } : { x : a , y : b , width : t ( c , 0 ) , height : t ( d , 0 ) } ; if ( f !== u ) a . strokeWidth = f , a = g . crisp ( a ) ; if ( e ) a . r = e ; g . rSetter = function ( a ) { L ( this . element , { rx : a , ry : a } ) } ; return g . attr ( a ) } , setSize : function ( a , b , c ) { var d = this . alignedObjects , e = d . length ; this . width = a ; this . height = b ; for ( this . boxWrapper [ p ( c , ! 0 ) ? "animate" : "attr" ] ( { width : a , height : b } ) ; e -- ; ) d [ e ] . align ( ) } , g : function ( a ) { var b = this . createElement ( "g" ) ; return s ( a ) ? b . attr ( { "class" : "highcharts-" +
a } ) : b } , image : function ( a , b , c , d , e ) { var f = { preserveAspectRatio : R } ; arguments . length > 1 && r ( f , { x : b , y : c , width : d , height : e } ) ; f = this . createElement ( "image" ) . attr ( f ) ; f . element . setAttributeNS ? f . element . setAttributeNS ( "http://www.w3.org/1999/xlink" , "href" , a ) : f . element . setAttribute ( "hc-svg-href" , a ) ; return f } , symbol : function ( a , b , c , d , e , f ) { var g , h = this . symbols [ a ] , h = h && h ( x ( b ) , x ( c ) , d , e , f ) , i = /^url\((.*?)\)$/ , j , k ; if ( h ) g = this . path ( h ) , r ( g , { symbolName : a , x : b , y : c , width : d , height : e } ) , f && r ( g , f ) ; else if ( i . test ( a ) ) k = function ( a , b ) { a . element &&
( a . attr ( { width : b [ 0 ] , height : b [ 1 ] } ) , a . alignByTranslate || a . translate ( x ( ( d - b [ 0 ] ) / 2 ) , x ( ( e - b [ 1 ] ) / 2 ) ) ) } , j = a . match ( i ) [ 1 ] , a = Kb [ j ] || f && f . width && f . height && [ f . width , f . height ] , g = this . image ( j ) . attr ( { x : b , y : c } ) , g . isImg = ! 0 , a ? k ( g , a ) : ( g . attr ( { width : 0 , height : 0 } ) , Z ( "img" , { onload : function ( ) { k ( g , Kb [ j ] = [ this . width , this . height ] ) } , src : j } ) ) ; return g } , symbols : { circle : function ( a , b , c , d ) { var e = 0.166 * c ; return [ "M" , a + c / 2 , b , "C" , a + c + e , b , a + c + e , b + d , a + c / 2 , b + d , "C" , a - e , b + d , a - e , b , a + c / 2 , b , "Z" ] } , square : function ( a , b , c , d ) { return [ "M" , a , b , "L" ,
a + c , b , a + c , b + d , a , b + d , "Z" ] } , triangle : function ( a , b , c , d ) { return [ "M" , a + c / 2 , b , "L" , a + c , b + d , a , b + d , "Z" ] } , "triangle-down" : function ( a , b , c , d ) { return [ "M" , a , b , "L" , a + c , b , a + c / 2 , b + d , "Z" ] } , diamond : function ( a , b , c , d ) { return [ "M" , a + c / 2 , b , "L" , a + c , b + d / 2 , a + c / 2 , b + d , a , b + d / 2 , "Z" ] } , arc : function ( a , b , c , d , e ) { var f = e . start , c = e . r || c || d , g = e . end - 0.001 , d = e . innerR , h = e . open , i = W ( f ) , j = $ ( f ) , k = W ( g ) , g = $ ( g ) , e = e . end - f < la ? 0 : 1 ; return [ "M" , a + c * i , b + c * j , "A" , c , c , 0 , e , 1 , a + c * k , b + c * g , h ? "M" : "L" , a + d * k , b + d * g , "A" , d , d , 0 , e , 0 , a + d * i , b + d * j , h ? "" : "Z" ] } , callout : function ( a ,
b , c , d , e ) { var f = I ( e && e . r || 0 , c , d ) , g = f + 6 , h = e && e . anchorX , i = e && e . anchorY , e = x ( e . strokeWidth || 0 ) % 2 / 2 ; a += e ; b += e ; e = [ "M" , a + f , b , "L" , a + c - f , b , "C" , a + c , b , a + c , b , a + c , b + f , "L" , a + c , b + d - f , "C" , a + c , b + d , a + c , b + d , a + c - f , b + d , "L" , a + f , b + d , "C" , a , b + d , a , b + d , a , b + d - f , "L" , a , b + f , "C" , a , b , a , b , a + f , b ] ; h && h > c && i > b + g && i < b + d - g ? e . splice ( 13 , 3 , "L" , a + c , i - 6 , a + c + 6 , i , a + c , i + 6 , a + c , b + d - f ) : h && h < 0 && i > b + g && i < b + d - g ? e . splice ( 33 , 3 , "L" , a , i + 6 , a - 6 , i , a , i - 6 , a , b + f ) : i && i > d && h > a + g && h < a + c - g ? e . splice ( 23 , 3 , "L" , h + 6 , b + d , h , b + d + 6 , h - 6 , b + d , a + f , b + d ) : i && i < 0 && h > a + g && h < a + c - g &&
e . splice ( 3 , 3 , "L" , h - 6 , b , h , b - 6 , h + 6 , b , c - f , b ) ; return e } } , clipRect : function ( a , b , c , d ) { var e = "highcharts-" + yb ++ , f = this . createElement ( "clipPath" ) . attr ( { id : e } ) . add ( this . defs ) , a = this . rect ( a , b , c , d , 0 ) . add ( f ) ; a . id = e ; a . clipPath = f ; a . count = 0 ; return a } , text : function ( a , b , c , d ) { var e = ea || ! ba && this . forExport , f = { } ; if ( d && ! this . forExport ) return this . html ( a , b , c ) ; f . x = Math . round ( b || 0 ) ; if ( c ) f . y = Math . round ( c ) ; if ( a || a === 0 ) f . text = a ; a = this . createElement ( "text" ) . attr ( f ) ; e && a . css ( { position : "absolute" } ) ; if ( ! d ) a . xSetter = function ( a ,
b , c ) { var d = c . getElementsByTagName ( "tspan" ) , e , f = c . getAttribute ( b ) , n ; for ( n = 0 ; n < d . length ; n ++ ) e = d [ n ] , e . getAttribute ( b ) === f && e . setAttribute ( b , a ) ; c . setAttribute ( b , a ) } ; return a } , fontMetrics : function ( a , b ) { a = a || this . style . fontSize ; if ( b && H . getComputedStyle ) b = b . element || b , a = H . getComputedStyle ( b , "" ) . fontSize ; var a = /px/ . test ( a ) ? B ( a ) : /em/ . test ( a ) ? parseFloat ( a ) * 12 : 12 , c = a < 24 ? a + 3 : x ( a * 1.2 ) , d = x ( c * 0.8 ) ; return { h : c , b : d , f : a } } , rotCorr : function ( a , b , c ) { var d = a ; b && c && ( d = t ( d * W ( b * ga ) , 4 ) ) ; return { x : - a / 3 * $ ( b * ga ) , y : d } } , label : function ( a ,
b , c , d , e , f , g , h , i ) { function j ( ) { var a , b ; a = q . element . style ; p = ( fa === void 0 || t === void 0 || o . styles . textAlign ) && s ( q . textStr ) && q . getBBox ( ) ; o . width = ( fa || p . width || 0 ) + 2 * v + ua ; o . height = ( t || p . height || 0 ) + 2 * v ; I = v + n . fontMetrics ( a && a . fontSize , q ) . b ; if ( D ) { if ( ! y ) a = x ( - C * v ) , b = h ? - I : 0 , o . box = y = d ? n . symbol ( d , a , b , o . width , o . height , E ) : n . rect ( a , b , o . width , o . height , 0 , E [ Pb ] ) , y . attr ( "fill" , R ) . add ( o ) ; y . isImg || y . attr ( r ( { width : x ( o . width ) , height : x ( o . height ) } , E ) ) ; E = null } } function k ( ) { var a = o . styles , a = a && a . textAlign , b = ua + v * ( 1 - C ) , c ; c = h ? 0 :
I ; if ( s ( fa ) && p && ( a === "center" || a === "right" ) ) b += { center : 0.5 , right : 1 } [ a ] * ( fa - p . width ) ; if ( b !== q . x || c !== q . y ) q . attr ( "x" , b ) , c !== u && q . attr ( q . element . nodeName === "SPAN" ? "y" : "translateY" , c ) ; q . x = b ; q . y = c } function l ( a , b ) { y ? y . attr ( a , b ) : E [ a ] = b } var n = this , o = n . g ( i ) , q = n . text ( "" , 0 , 0 , g ) . attr ( { zIndex : 1 } ) , y , p , C = 0 , v = 3 , ua = 0 , fa , t , w , A , B = 0 , E = { } , I , D ; o . onAdd = function ( ) { q . add ( o ) ; o . attr ( { text : a || a === 0 ? a : "" , x : b , y : c } ) ; y && s ( e ) && o . attr ( { anchorX : e , anchorY : f } ) } ; o . widthSetter = function ( a ) { fa = a } ; o . heightSetter = function ( a ) { t = a } ; o . paddingSetter =
function ( a ) { if ( s ( a ) && a !== v ) v = o . padding = a , k ( ) } ; o . paddingLeftSetter = function ( a ) { s ( a ) && a !== ua && ( ua = a , k ( ) ) } ; o . alignSetter = function ( a ) { C = { left : 0 , center : 0.5 , right : 1 } [ a ] } ; o . textSetter = function ( a ) { a !== u && q . textSetter ( a ) ; j ( ) ; k ( ) } ; o [ "stroke-widthSetter" ] = function ( a , b ) { a && ( D = ! 0 ) ; B = a % 2 / 2 ; l ( b , a ) } ; o . strokeSetter = o . fillSetter = o . rSetter = function ( a , b ) { b === "fill" && a && ( D = ! 0 ) ; l ( b , a ) } ; o . anchorXSetter = function ( a , b ) { e = a ; l ( b , a + B - w ) } ; o . anchorYSetter = function ( a , b ) { f = a ; l ( b , a - A ) } ; o . xSetter = function ( a ) { o . x = a ; C && ( a -= C * ( ( fa || p . width ) +
v ) ) ; w = x ( a ) ; o . attr ( "translateX" , w ) } ; o . ySetter = function ( a ) { A = o . y = x ( a ) ; o . attr ( "translateY" , A ) } ; var G = o . css ; return r ( o , { css : function ( a ) { if ( a ) { var b = { } , a = z ( a ) ; m ( o . textProps , function ( c ) { a [ c ] !== u && ( b [ c ] = a [ c ] , delete a [ c ] ) } ) ; q . css ( b ) } return G . call ( o , a ) } , getBBox : function ( ) { return { width : p . width + 2 * v , height : p . height + 2 * v , x : p . x - v , y : p . y - v } } , shadow : function ( a ) { y && y . shadow ( a ) ; return o } , destroy : function ( ) { Y ( o . element , "mouseenter" ) ; Y ( o . element , "mouseleave" ) ; q && ( q = q . destroy ( ) ) ; y && ( y = y . destroy ( ) ) ; K . prototype . destroy . call ( o ) ;
o = n = j = k = l = null } } ) } } ; $a = ta ; r ( K . prototype , { htmlCss : function ( a ) { var b = this . element ; if ( b = a && b . tagName === "SPAN" && a . width ) delete a . width , this . textWidth = b , this . updateTransform ( ) ; if ( a && a . textOverflow === "ellipsis" ) a . whiteSpace = "nowrap" , a . overflow = "hidden" ; this . styles = r ( this . styles , a ) ; F ( this . element , a ) ; return this } , htmlGetBBox : function ( ) { var a = this . element ; if ( a . nodeName === "text" ) a . style . position = "absolute" ; return { x : a . offsetLeft , y : a . offsetTop , width : a . offsetWidth , height : a . offsetHeight } } , htmlUpdateTransform : function ( ) { if ( this . added ) { var a =
this . renderer , b = this . element , c = this . translateX || 0 , d = this . translateY || 0 , e = this . x || 0 , f = this . y || 0 , g = this . textAlign || "left" , h = { left : 0 , center : 0.5 , right : 1 } [ g ] , i = this . shadows , j = this . styles ; F ( b , { marginLeft : c , marginTop : d } ) ; i && m ( i , function ( a ) { F ( a , { marginLeft : c + 1 , marginTop : d + 1 } ) } ) ; this . inverted && m ( b . childNodes , function ( c ) { a . invertChild ( c , b ) } ) ; if ( b . tagName === "SPAN" ) { var k = this . rotation , l , n = B ( this . textWidth ) , o = [ k , g , b . innerHTML , this . textWidth ] . join ( "," ) ; if ( o !== this . cTT ) { l = a . fontMetrics ( b . style . fontSize ) . b ; s ( k ) &&
this . setSpanRotation ( k , h , l ) ; i = p ( this . elemWidth , b . offsetWidth ) ; if ( i > n && /[ \-]/ . test ( b . textContent || b . innerText ) ) F ( b , { width : n + "px" , display : "block" , whiteSpace : j && j . whiteSpace || "normal" } ) , i = n ; this . getSpanCorrection ( i , l , h , k , g ) } F ( b , { left : e + ( this . xCorr || 0 ) + "px" , top : f + ( this . yCorr || 0 ) + "px" } ) ; if ( xb ) l = b . offsetHeight ; this . cTT = o } } else this . alignOnAdd = ! 0 } , setSpanRotation : function ( a , b , c ) { var d = { } , e = ya ? "-ms-transform" : xb ? "-webkit-transform" : La ? "MozTransform" : Ib ? "-o-transform" : "" ; d [ e ] = d . transform = "rotate(" + a + "deg)" ;
d [ e + ( La ? "Origin" : "-origin" ) ] = d . transformOrigin = b * 100 + "% " + c + "px" ; F ( this . element , d ) } , getSpanCorrection : function ( a , b , c ) { this . xCorr = - a * c ; this . yCorr = - b } } ) ; r ( ta . prototype , { html : function ( a , b , c ) { var d = this . createElement ( "span" ) , e = d . element , f = d . renderer ; d . textSetter = function ( a ) { a !== e . innerHTML && delete this . bBox ; e . innerHTML = this . textStr = a } ; d . xSetter = d . ySetter = d . alignSetter = d . rotationSetter = function ( a , b ) { b === "align" && ( b = "textAlign" ) ; d [ b ] = a ; d . htmlUpdateTransform ( ) } ; d . attr ( { text : a , x : x ( b ) , y : x ( c ) } ) . css ( { position : "absolute" ,
fontFamily : this . style . fontFamily , fontSize : this . style . fontSize } ) ; e . style . whiteSpace = "nowrap" ; d . css = d . htmlCss ; if ( f . isSVG ) d . add = function ( a ) { var b , c = f . box . parentNode , j = [ ] ; if ( this . parentGroup = a ) { if ( b = a . div , ! b ) { for ( ; a ; ) j . push ( a ) , a = a . parentGroup ; m ( j . reverse ( ) , function ( a ) { var d ; b = a . div = a . div || Z ( Ka , { className : L ( a . element , "class" ) } , { position : "absolute" , left : ( a . translateX || 0 ) + "px" , top : ( a . translateY || 0 ) + "px" } , b || c ) ; d = b . style ; r ( a , { translateXSetter : function ( b , c ) { d . left = b + "px" ; a [ c ] = b ; a . doTransform = ! 0 } , translateYSetter : function ( b ,
c ) { d . top = b + "px" ; a [ c ] = b ; a . doTransform = ! 0 } , visibilitySetter : function ( a , b ) { d [ b ] = a } } ) } ) } } else b = c ; b . appendChild ( e ) ; d . added = ! 0 ; d . alignOnAdd && d . htmlUpdateTransform ( ) ; return d } ; return d } } ) ; if ( ! ba && ! ea ) { D = { init : function ( a , b ) { var c = [ "<" , b , ' filled="f" stroked="f"' ] , d = [ "position: " , "absolute" , ";" ] , e = b === Ka ; ( b === "shape" || e ) && d . push ( "left:0;top:0;width:1px;height:1px;" ) ; d . push ( "visibility: " , e ? "hidden" : "visible" ) ; c . push ( ' style="' , d . join ( "" ) , '"/>' ) ; if ( b ) c = e || b === "span" || b === "img" ? c . join ( "" ) : a . prepVML ( c ) , this . element =
Z ( c ) ; this . renderer = a } , add : function ( a ) { var b = this . renderer , c = this . element , d = b . box , d = a ? a . element || a : d ; a && a . inverted && b . invertChild ( c , d ) ; d . appendChild ( c ) ; this . added = ! 0 ; this . alignOnAdd && ! this . deferUpdateTransform && this . updateTransform ( ) ; if ( this . onAdd ) this . onAdd ( ) ; return this } , updateTransform : K . prototype . htmlUpdateTransform , setSpanRotation : function ( ) { var a = this . rotation , b = W ( a * ga ) , c = $ ( a * ga ) ; F ( this . element , { filter : a ? [ "progid:DXImageTransform.Microsoft.Matrix(M11=" , b , ", M12=" , - c , ", M21=" , c , ", M22=" , b , ", sizingMethod='auto expand')" ] . join ( "" ) :
R } ) } , getSpanCorrection : function ( a , b , c , d , e ) { var f = d ? W ( d * ga ) : 1 , g = d ? $ ( d * ga ) : 0 , h = p ( this . elemHeight , this . element . offsetHeight ) , i ; this . xCorr = f < 0 && - a ; this . yCorr = g < 0 && - h ; i = f * g < 0 ; this . xCorr += g * b * ( i ? 1 - c : c ) ; this . yCorr -= f * b * ( d ? i ? c : 1 - c : 1 ) ; e && e !== "left" && ( this . xCorr -= a * c * ( f < 0 ? - 1 : 1 ) , d && ( this . yCorr -= h * c * ( g < 0 ? - 1 : 1 ) ) , F ( this . element , { textAlign : e } ) ) } , pathToVML : function ( a ) { for ( var b = a . length , c = [ ] ; b -- ; ) if ( qa ( a [ b ] ) ) c [ b ] = x ( a [ b ] * 10 ) - 5 ; else if ( a [ b ] === "Z" ) c [ b ] = "x" ; else if ( c [ b ] = a [ b ] , a . isArc && ( a [ b ] === "wa" || a [ b ] === "at" ) ) c [ b + 5 ] ===
c [ b + 7 ] && ( c [ b + 7 ] += a [ b + 7 ] > a [ b + 5 ] ? 1 : - 1 ) , c [ b + 6 ] === c [ b + 8 ] && ( c [ b + 8 ] += a [ b + 8 ] > a [ b + 6 ] ? 1 : - 1 ) ; return c . join ( " " ) || "x" } , clip : function ( a ) { var b = this , c ; a ? ( c = a . members , ia ( c , b ) , c . push ( b ) , b . destroyClip = function ( ) { ia ( c , b ) } , a = a . getCSS ( b ) ) : ( b . destroyClip && b . destroyClip ( ) , a = { clip : hb ? "inherit" : "rect(auto)" } ) ; return b . css ( a ) } , css : K . prototype . htmlCss , safeRemoveChild : function ( a ) { a . parentNode && Ra ( a ) } , destroy : function ( ) { this . destroyClip && this . destroyClip ( ) ; return K . prototype . destroy . apply ( this ) } , on : function ( a , b ) { this . element [ "on" +
a ] = function ( ) { var a = H . event ; a . target = a . srcElement ; b ( a ) } ; return this } , cutOffPath : function ( a , b ) { var c , a = a . split ( /[ ,]/ ) ; c = a . length ; if ( c === 9 || c === 11 ) a [ c - 4 ] = a [ c - 2 ] = B ( a [ c - 2 ] ) - 10 * b ; return a . join ( " " ) } , shadow : function ( a , b , c ) { var d = [ ] , e , f = this . element , g = this . renderer , h , i = f . style , j , k = f . path , l , n , o , q ; k && typeof k . value !== "string" && ( k = "x" ) ; n = k ; if ( a ) { o = p ( a . width , 3 ) ; q = ( a . opacity || 0.15 ) / o ; for ( e = 1 ; e <= 3 ; e ++ ) { l = o * 2 + 1 - 2 * e ; c && ( n = this . cutOffPath ( k . value , l + 0.5 ) ) ; j = [ '<shape isShadow="true" strokeweight="' , l , '" filled="false" path="' ,
n , '" coordsize="10 10" style="' , f . style . cssText , '" />' ] ; h = Z ( g . prepVML ( j ) , null , { left : B ( i . left ) + p ( a . offsetX , 1 ) , top : B ( i . top ) + p ( a . offsetY , 1 ) } ) ; if ( c ) h . cutOff = l + 1 ; j = [ '<stroke color="' , a . color || "black" , '" opacity="' , q * e , '"/>' ] ; Z ( g . prepVML ( j ) , null , null , h ) ; b ? b . element . appendChild ( h ) : f . parentNode . insertBefore ( h , f ) ; d . push ( h ) } this . shadows = d } return this } , updateShadows : ma , setAttr : function ( a , b ) { hb ? this . element [ a ] = b : this . element . setAttribute ( a , b ) } , classSetter : function ( a ) { this . element . className = a } , dashstyleSetter : function ( a ,
b , c ) { ( c . getElementsByTagName ( "stroke" ) [ 0 ] || Z ( this . renderer . prepVML ( [ "<stroke/>" ] ) , null , null , c ) ) [ b ] = a || "solid" ; this [ b ] = a } , dSetter : function ( a , b , c ) { var d = this . shadows , a = a || [ ] ; this . d = a . join && a . join ( " " ) ; c . path = a = this . pathToVML ( a ) ; if ( d ) for ( c = d . length ; c -- ; ) d [ c ] . path = d [ c ] . cutOff ? this . cutOffPath ( a , d [ c ] . cutOff ) : a ; this . setAttr ( b , a ) } , fillSetter : function ( a , b , c ) { var d = c . nodeName ; if ( d === "SPAN" ) c . style . color = a ; else if ( d !== "IMG" ) c . filled = a !== R , this . setAttr ( "fillcolor" , this . renderer . color ( a , c , b , this ) ) } , opacitySetter : ma ,
rotationSetter : function ( a , b , c ) { c = c . style ; this [ b ] = c [ b ] = a ; c . left = - x ( $ ( a * ga ) + 1 ) + "px" ; c . top = x ( W ( a * ga ) ) + "px" } , strokeSetter : function ( a , b , c ) { this . setAttr ( "strokecolor" , this . renderer . color ( a , c , b ) ) } , "stroke-widthSetter" : function ( a , b , c ) { c . stroked = ! ! a ; this [ b ] = a ; qa ( a ) && ( a += "px" ) ; this . setAttr ( "strokeweight" , a ) } , titleSetter : function ( a , b ) { this . setAttr ( b , a ) } , visibilitySetter : function ( a , b , c ) { a === "inherit" && ( a = "visible" ) ; this . shadows && m ( this . shadows , function ( c ) { c . style [ b ] = a } ) ; c . nodeName === "DIV" && ( a = a === "hidden" ? "-999em" :
0 , hb || ( c . style [ b ] = a ? "visible" : "hidden" ) , b = "top" ) ; c . style [ b ] = a } , xSetter : function ( a , b , c ) { this [ b ] = a ; b === "x" ? b = "left" : b === "y" && ( b = "top" ) ; this . updateClipping ? ( this [ b ] = a , this . updateClipping ( ) ) : c . style [ b ] = a } , zIndexSetter : function ( a , b , c ) { c . style [ b ] = a } } ; w . VMLElement = D = ja ( K , D ) ; D . prototype . ySetter = D . prototype . widthSetter = D . prototype . heightSetter = D . prototype . xSetter ; var Na = { Element : D , isIE8 : Ba . indexOf ( "MSIE 8.0" ) > - 1 , init : function ( a , b , c , d ) { var e ; this . alignedObjects = [ ] ; d = this . createElement ( Ka ) . css ( r ( this . getStyle ( d ) ,
{ position : "relative" } ) ) ; e = d . element ; a . appendChild ( d . element ) ; this . isVML = ! 0 ; this . box = e ; this . boxWrapper = d ; this . cache = { } ; this . setSize ( b , c , ! 1 ) ; if ( ! A . namespaces . hcv ) { A . namespaces . add ( "hcv" , "urn:schemas-microsoft-com:vml" ) ; try { A . createStyleSheet ( ) . cssText = "hcv\\:fill, hcv\\:path, hcv\\:shape, hcv\\:stroke{ behavior:url(#default#VML); display: inline-block; } " } catch ( f ) { A . styleSheets [ 0 ] . cssText += "hcv\\:fill, hcv\\:path, hcv\\:shape, hcv\\:stroke{ behavior:url(#default#VML); display: inline-block; } " } } } ,
isHidden : function ( ) { return ! this . box . offsetWidth } , clipRect : function ( a , b , c , d ) { var e = this . createElement ( ) , f = ca ( a ) ; return r ( e , { members : [ ] , count : 0 , left : ( f ? a . x : a ) + 1 , top : ( f ? a . y : b ) + 1 , width : ( f ? a . width : c ) - 1 , height : ( f ? a . height : d ) - 1 , getCSS : function ( a ) { var b = a . element , c = b . nodeName , a = a . inverted , d = this . top - ( c === "shape" ? b . offsetTop : 0 ) , e = this . left , b = e + this . width , f = d + this . height , d = { clip : "rect(" + x ( a ? e : d ) + "px," + x ( a ? f : b ) + "px," + x ( a ? b : f ) + "px," + x ( a ? d : e ) + "px)" } ; ! a && hb && c === "DIV" && r ( d , { width : b + "px" , height : f + "px" } ) ; return d } ,
updateClipping : function ( ) { m ( e . members , function ( a ) { a . element && a . css ( e . getCSS ( a ) ) } ) } } ) } , color : function ( a , b , c , d ) { var e = this , f , g = /^rgba/ , h , i , j = R ; a && a . linearGradient ? i = "gradient" : a && a . radialGradient && ( i = "pattern" ) ; if ( i ) { var k , l , n = a . linearGradient || a . radialGradient , o , q , y , p , C , v = "" , a = a . stops , s , fa = [ ] , t = function ( ) { h = [ '<fill colors="' + fa . join ( "," ) + '" opacity="' , y , '" o:opacity2="' , q , '" type="' , i , '" ' , v , 'focus="100%" method="any" />' ] ; Z ( e . prepVML ( h ) , null , null , b ) } ; o = a [ 0 ] ; s = a [ a . length - 1 ] ; o [ 0 ] > 0 && a . unshift ( [ 0 , o [ 1 ] ] ) ;
s [ 0 ] < 1 && a . push ( [ 1 , s [ 1 ] ] ) ; m ( a , function ( a , b ) { g . test ( a [ 1 ] ) ? ( f = na ( a [ 1 ] ) , k = f . get ( "rgb" ) , l = f . get ( "a" ) ) : ( k = a [ 1 ] , l = 1 ) ; fa . push ( a [ 0 ] * 100 + "% " + k ) ; b ? ( y = l , p = k ) : ( q = l , C = k ) } ) ; if ( c === "fill" ) if ( i === "gradient" ) c = n . x1 || n [ 0 ] || 0 , a = n . y1 || n [ 1 ] || 0 , o = n . x2 || n [ 2 ] || 0 , n = n . y2 || n [ 3 ] || 0 , v = 'angle="' + ( 90 - V . atan ( ( n - a ) / ( o - c ) ) * 180 / la ) + '"' , t ( ) ; else { var j = n . r , u = j * 2 , x = j * 2 , r = n . cx , E = n . cy , z = b . radialReference , w , j = function ( ) { z && ( w = d . getBBox ( ) , r += ( z [ 0 ] - w . x ) / w . width - 0.5 , E += ( z [ 1 ] - w . y ) / w . height - 0.5 , u *= z [ 2 ] / w . width , x *= z [ 2 ] / w . height ) ; v = 'src="' + P . global . VMLRadialGradientURL +
'" size="' + u + "," + x + '" origin="0.5,0.5" position="' + r + "," + E + '" color2="' + C + '" ' ; t ( ) } ; d . added ? j ( ) : d . onAdd = j ; j = p } else j = k } else if ( g . test ( a ) && b . tagName !== "IMG" ) f = na ( a ) , h = [ "<" , c , ' opacity="' , f . get ( "a" ) , '"/>' ] , Z ( this . prepVML ( h ) , null , null , b ) , j = f . get ( "rgb" ) ; else { j = b . getElementsByTagName ( c ) ; if ( j . length ) j [ 0 ] . opacity = 1 , j [ 0 ] . type = "solid" ; j = a } return j } , prepVML : function ( a ) { var b = this . isIE8 , a = a . join ( "" ) ; b ? ( a = a . replace ( "/>" , ' xmlns="urn:schemas-microsoft-com:vml" />' ) , a = a . indexOf ( 'style="' ) === - 1 ? a . replace ( "/>" , ' style="display:inline-block;behavior:url(#default#VML);" />' ) :
a . replace ( 'style="' , 'style="display:inline-block;behavior:url(#default#VML);' ) ) : a = a . replace ( "<" , "<hcv:" ) ; return a } , text : ta . prototype . html , path : function ( a ) { var b = { coordsize : "10 10" } ; Ha ( a ) ? b . d = a : ca ( a ) && r ( b , a ) ; return this . createElement ( "shape" ) . attr ( b ) } , circle : function ( a , b , c ) { var d = this . symbol ( "circle" ) ; if ( ca ( a ) ) c = a . r , b = a . y , a = a . x ; d . isCircle = ! 0 ; d . r = c ; return d . attr ( { x : a , y : b } ) } , g : function ( a ) { var b ; a && ( b = { className : "highcharts-" + a , "class" : "highcharts-" + a } ) ; return this . createElement ( Ka ) . attr ( b ) } , image : function ( a ,
b , c , d , e ) { var f = this . createElement ( "img" ) . attr ( { src : a } ) ; arguments . length > 1 && f . attr ( { x : b , y : c , width : d , height : e } ) ; return f } , createElement : function ( a ) { return a === "rect" ? this . symbol ( a ) : ta . prototype . createElement . call ( this , a ) } , invertChild : function ( a , b ) { var c = this , d = b . style , e = a . tagName === "IMG" && a . style ; F ( a , { flip : "x" , left : B ( d . width ) - ( e ? B ( e . top ) : 1 ) , top : B ( d . height ) - ( e ? B ( e . left ) : 1 ) , rotation : - 90 } ) ; m ( a . childNodes , function ( b ) { c . invertChild ( b , a ) } ) } , symbols : { arc : function ( a , b , c , d , e ) { var f = e . start , g = e . end , h = e . r || c ||
d , c = e . innerR , d = W ( f ) , i = $ ( f ) , j = W ( g ) , k = $ ( g ) ; if ( g - f === 0 ) return [ "x" ] ; f = [ "wa" , a - h , b - h , a + h , b + h , a + h * d , b + h * i , a + h * j , b + h * k ] ; e . open && ! c && f . push ( "e" , "M" , a , b ) ; f . push ( "at" , a - c , b - c , a + c , b + c , a + c * j , b + c * k , a + c * d , b + c * i , "x" , "e" ) ; f . isArc = ! 0 ; return f } , circle : function ( a , b , c , d , e ) { e && ( c = d = 2 * e . r ) ; e && e . isCircle && ( a -= c / 2 , b -= d / 2 ) ; return [ "wa" , a , b , a + c , b + d , a + c , b + d / 2 , a + c , b + d / 2 , "e" ] } , rect : function ( a , b , c , d , e ) { return ta . prototype . symbols [ ! s ( e ) || ! e . r ? "square" : "callout" ] . call ( 0 , a , b , c , d , e ) } } } ; w . VMLRenderer = D = function ( ) { this . init . apply ( this ,
arguments ) } ; D . prototype = z ( ta . prototype , Na ) ; $a = D } ta . prototype . measureSpanWidth = function ( a , b ) { var c = A . createElement ( "span" ) , d ; d = A . createTextNode ( a ) ; c . appendChild ( d ) ; F ( c , b ) ; this . box . appendChild ( c ) ; d = c . offsetWidth ; Ra ( c ) ; return d } ; var Lb ; if ( ea ) w . CanVGRenderer = D = function ( ) { Ca = "http://www.w3.org/1999/xhtml" } , D . prototype . symbols = { } , Lb = function ( ) { function a ( ) { var a = b . length , d ; for ( d = 0 ; d < a ; d ++ ) b [ d ] ( ) ; b = [ ] } var b = [ ] ; return { push : function ( c , d ) { b . length === 0 && Qb ( d , a ) ; b . push ( c ) } } } ( ) , $a = D ; Ta . prototype = { addLabel : function ( ) { var a =
this . axis , b = a . options , c = a . chart , d = a . categories , e = a . names , f = this . pos , g = b . labels , h = a . tickPositions , i = f === h [ 0 ] , j = f === h [ h . length - 1 ] , e = d ? p ( d [ f ] , e [ f ] , f ) : f , d = this . label , h = h . info , k ; a . isDatetimeAxis && h && ( k = b . dateTimeLabelFormats [ h . higherRanks [ f ] || h . unitName ] ) ; this . isFirst = i ; this . isLast = j ; b = a . labelFormatter . call ( { axis : a , chart : c , isFirst : i , isLast : j , dateTimeLabelFormat : k , value : a . isLog ? da ( ha ( e ) ) : e } ) ; s ( d ) ? d && d . attr ( { text : b } ) : ( this . labelLength = ( this . label = d = s ( b ) && g . enabled ? c . renderer . text ( b , 0 , 0 , g . useHTML ) . css ( z ( g . style ) ) . add ( a . labelGroup ) :
null ) && d . getBBox ( ) . width , this . rotation = 0 ) } , getLabelSize : function ( ) { return this . label ? this . label . getBBox ( ) [ this . axis . horiz ? "height" : "width" ] : 0 } , handleOverflow : function ( a ) { var b = this . axis , c = a . x , d = b . chart . chartWidth , e = b . chart . spacing , f = p ( b . labelLeft , e [ 3 ] ) , e = p ( b . labelRight , d - e [ 1 ] ) , g = this . label , h = this . rotation , i = { left : 0 , center : 0.5 , right : 1 } [ b . labelAlign ] , j = g . getBBox ( ) . width , k = b . slotWidth , l ; if ( h ) h < 0 && c - i * j < f ? l = x ( c / W ( h * ga ) - f ) : h > 0 && c + i * j > e && ( l = x ( ( d - c ) / W ( h * ga ) ) ) ; else { d = c - i * j ; c += i * j ; if ( d < f ) k -= f - d , a . x = f , g . attr ( { align : "left" } ) ;
else if ( c > e ) k -= c - e , a . x = e , g . attr ( { align : "right" } ) ; if ( j > k || b . autoRotation && g . styles . width ) l = k } l && g . css ( { width : l , textOverflow : "ellipsis" } ) } , getPosition : function ( a , b , c , d ) { var e = this . axis , f = e . chart , g = d && f . oldChartHeight || f . chartHeight ; return { x : a ? e . translate ( b + c , null , null , d ) + e . transB : e . left + e . offset + ( e . opposite ? ( d && f . oldChartWidth || f . chartWidth ) - e . right - e . left : 0 ) , y : a ? g - e . bottom + e . offset - ( e . opposite ? e . height : 0 ) : g - e . translate ( b + c , null , null , d ) - e . transB } } , getLabelPosition : function ( a , b , c , d , e , f , g , h ) { var i = this . axis ,
j = i . transA , k = i . reversed , l = i . staggerLines , n = i . tickRotCorr || { x : 0 , y : 0 } , c = p ( e . y , n . y + ( i . side === 2 ? 8 : - ( c . getBBox ( ) . height / 2 ) ) ) , a = a + e . x + n . x - ( f && d ? f * j * ( k ? - 1 : 1 ) : 0 ) , b = b + c - ( f && ! d ? f * j * ( k ? 1 : - 1 ) : 0 ) ; l && ( b += g / ( h || 1 ) % l * ( i . labelOffset / l ) ) ; return { x : a , y : x ( b ) } } , getMarkPath : function ( a , b , c , d , e , f ) { return f . crispLine ( [ "M" , a , b , "L" , a + ( e ? 0 : - c ) , b + ( e ? c : 0 ) ] , d ) } , render : function ( a , b , c ) { var d = this . axis , e = d . options , f = d . chart . renderer , g = d . horiz , h = this . type , i = this . label , j = this . pos , k = e . labels , l = this . gridLine , n = h ? h + "Grid" : "grid" , o = h ? h +
"Tick" : "tick" , q = e [ n + "LineWidth" ] , y = e [ n + "LineColor" ] , m = e [ n + "LineDashStyle" ] , C = e [ o + "Length" ] , n = e [ o + "Width" ] || 0 , v = e [ o + "Color" ] , s = e [ o + "Position" ] , o = this . mark , fa = k . step , t = ! 0 , x = d . tickmarkOffset , r = this . getPosition ( g , j , x , b ) , w = r . x , r = r . y , z = g && w === d . pos + d . len || ! g && r === d . pos ? - 1 : 1 , c = p ( c , 1 ) ; this . isActive = ! 0 ; if ( q ) { j = d . getPlotLinePath ( j + x , q * z , b , ! 0 ) ; if ( l === u ) { l = { stroke : y , "stroke-width" : q } ; if ( m ) l . dashstyle = m ; if ( ! h ) l . zIndex = 1 ; if ( b ) l . opacity = 0 ; this . gridLine = l = q ? f . path ( j ) . attr ( l ) . add ( d . gridGroup ) : null } if ( ! b && l && j ) l [ this . isNew ?
"attr" : "animate" ] ( { d : j , opacity : c } ) } if ( n && C ) s === "inside" && ( C = - C ) , d . opposite && ( C = - C ) , h = this . getMarkPath ( w , r , C , n * z , g , f ) , o ? o . animate ( { d : h , opacity : c } ) : this . mark = f . path ( h ) . attr ( { stroke : v , "stroke-width" : n , opacity : c } ) . add ( d . axisGroup ) ; if ( i && ! isNaN ( w ) ) i . xy = r = this . getLabelPosition ( w , r , i , g , k , x , a , fa ) , this . isFirst && ! this . isLast && ! p ( e . showFirstLabel , 1 ) || this . isLast && ! this . isFirst && ! p ( e . showLastLabel , 1 ) ? t = ! 1 : g && ! d . isRadial && ! k . step && ! k . rotation && ! b && c !== 0 && this . handleOverflow ( r ) , fa && a % fa && ( t = ! 1 ) , t && ! isNaN ( r . y ) ?
( r . opacity = c , i [ this . isNew ? "attr" : "animate" ] ( r ) , this . isNew = ! 1 ) : i . attr ( "y" , - 9999 ) } , destroy : function ( ) { Qa ( this , this . axis ) } } ; w . PlotLineOrBand = function ( a , b ) { this . axis = a ; if ( b ) this . options = b , this . id = b . id } ; w . PlotLineOrBand . prototype = { render : function ( ) { var a = this , b = a . axis , c = b . horiz , d = a . options , e = d . label , f = a . label , g = d . width , h = d . to , i = d . from , j = s ( i ) && s ( h ) , k = d . value , l = d . dashStyle , n = a . svgElem , o = [ ] , q , y = d . color , p = d . zIndex , m = d . events , v = { } , t = b . chart . renderer ; b . isLog && ( i = Ea ( i ) , h = Ea ( h ) , k = Ea ( k ) ) ; if ( g ) { if ( o = b . getPlotLinePath ( k ,
g ) , v = { stroke : y , "stroke-width" : g } , l ) v . dashstyle = l } else if ( j ) { o = b . getPlotBandPath ( i , h , d ) ; if ( y ) v . fill = y ; if ( d . borderWidth ) v . stroke = d . borderColor , v [ "stroke-width" ] = d . borderWidth } else return ; if ( s ( p ) ) v . zIndex = p ; if ( n ) if ( o ) n . animate ( { d : o } , null , n . onGetPath ) ; else { if ( n . hide ( ) , n . onGetPath = function ( ) { n . show ( ) } , f ) a . label = f = f . destroy ( ) } else if ( o && o . length && ( a . svgElem = n = t . path ( o ) . attr ( v ) . add ( ) , m ) ) for ( q in d = function ( b ) { n . on ( b , function ( c ) { m [ b ] . apply ( a , [ c ] ) } ) } , m ) d ( q ) ; if ( e && s ( e . text ) && o && o . length && b . width > 0 && b . height >
0 ) { e = z ( { align : c && j && "center" , x : c ? ! j && 4 : 10 , verticalAlign : ! c && j && "middle" , y : c ? j ? 16 : 10 : j ? 6 : - 4 , rotation : c && ! j && 90 } , e ) ; if ( ! f ) { v = { align : e . textAlign || e . align , rotation : e . rotation } ; if ( s ( p ) ) v . zIndex = p ; a . label = f = t . text ( e . text , 0 , 0 , e . useHTML ) . attr ( v ) . css ( e . style ) . add ( ) } b = [ o [ 1 ] , o [ 4 ] , j ? o [ 6 ] : o [ 1 ] ] ; j = [ o [ 2 ] , o [ 5 ] , j ? o [ 7 ] : o [ 2 ] ] ; o = Pa ( b ) ; c = Pa ( j ) ; f . align ( e , ! 1 , { x : o , y : c , width : Fa ( b ) - o , height : Fa ( j ) - c } ) ; f . show ( ) } else f && f . hide ( ) ; return a } , destroy : function ( ) { ia ( this . axis . plotLinesAndBands , this ) ; delete this . axis ; Qa ( this ) } } ; var va =
w . Axis = function ( ) { this . init . apply ( this , arguments ) } ; va . prototype = { defaultOptions : { dateTimeLabelFormats : { millisecond : "%H:%M:%S.%L" , second : "%H:%M:%S" , minute : "%H:%M" , hour : "%H:%M" , day : "%e. %b" , week : "%e. %b" , month : "%b '%y" , year : "%Y" } , endOnTick : ! 1 , gridLineColor : "#D8D8D8" , labels : { enabled : ! 0 , style : { color : "#606060" , cursor : "default" , fontSize : "11px" } , x : 0 , y : 15 } , lineColor : "#C0D0E0" , lineWidth : 1 , minPadding : 0.01 , maxPadding : 0.01 , minorGridLineColor : "#E0E0E0" , minorGridLineWidth : 1 , minorTickColor : "#A0A0A0" , minorTickLength : 2 ,
minorTickPosition : "outside" , startOfWeek : 1 , startOnTick : ! 1 , tickColor : "#C0D0E0" , tickLength : 10 , tickmarkPlacement : "between" , tickPixelInterval : 100 , tickPosition : "outside" , tickWidth : 1 , title : { align : "middle" , style : { color : "#707070" } } , type : "linear" } , defaultYAxisOptions : { endOnTick : ! 0 , gridLineWidth : 1 , tickPixelInterval : 72 , showLastLabel : ! 0 , labels : { x : - 8 , y : 3 } , lineWidth : 0 , maxPadding : 0.05 , minPadding : 0.05 , startOnTick : ! 0 , tickWidth : 0 , title : { rotation : 270 , text : "Values" } , stackLabels : { enabled : ! 1 , formatter : function ( ) { return w . numberFormat ( this . total ,
- 1 ) } , style : z ( aa . line . dataLabels . style , { color : "#000000" } ) } } , defaultLeftAxisOptions : { labels : { x : - 15 , y : null } , title : { rotation : 270 } } , defaultRightAxisOptions : { labels : { x : 15 , y : null } , title : { rotation : 90 } } , defaultBottomAxisOptions : { labels : { autoRotation : [ - 45 ] , x : 0 , y : null } , title : { rotation : 0 } } , defaultTopAxisOptions : { labels : { autoRotation : [ - 45 ] , x : 0 , y : - 15 } , title : { rotation : 0 } } , init : function ( a , b ) { var c = b . isX ; this . horiz = a . inverted ? ! c : c ; this . coll = ( this . isXAxis = c ) ? "xAxis" : "yAxis" ; this . opposite = b . opposite ; this . side = b . side ||
( this . horiz ? this . opposite ? 0 : 2 : this . opposite ? 1 : 3 ) ; this . setOptions ( b ) ; var d = this . options , e = d . type ; this . labelFormatter = d . labels . formatter || this . defaultLabelFormatter ; this . userOptions = b ; this . minPixelPadding = 0 ; this . chart = a ; this . reversed = d . reversed ; this . zoomEnabled = d . zoomEnabled !== ! 1 ; this . categories = d . categories || e === "category" ; this . names = this . names || [ ] ; this . isLog = e === "logarithmic" ; this . isDatetimeAxis = e === "datetime" ; this . isLinked = s ( d . linkedTo ) ; this . ticks = { } ; this . labelEdge = [ ] ; this . minorTicks = { } ; this . plotLinesAndBands =
[ ] ; this . alternateBands = { } ; this . len = 0 ; this . minRange = this . userMinRange = d . minRange || d . maxZoom ; this . range = d . range ; this . offset = d . offset || 0 ; this . stacks = { } ; this . oldStacks = { } ; this . min = this . max = null ; this . crosshair = p ( d . crosshair , ra ( a . options . tooltip . crosshairs ) [ c ? 0 : 1 ] , ! 1 ) ; var f , d = this . options . events ; Ma ( this , a . axes ) === - 1 && ( c && ! this . isColorAxis ? a . axes . splice ( a . xAxis . length , 0 , this ) : a . axes . push ( this ) , a [ this . coll ] . push ( this ) ) ; this . series = this . series || [ ] ; if ( a . inverted && c && this . reversed === u ) this . reversed = ! 0 ; this . removePlotLine =
this . removePlotBand = this . removePlotBandOrLine ; for ( f in d ) N ( this , f , d [ f ] ) ; if ( this . isLog ) this . val2lin = Ea , this . lin2val = ha } , setOptions : function ( a ) { this . options = z ( this . defaultOptions , this . isXAxis ? { } : this . defaultYAxisOptions , [ this . defaultTopAxisOptions , this . defaultRightAxisOptions , this . defaultBottomAxisOptions , this . defaultLeftAxisOptions ] [ this . side ] , z ( P [ this . coll ] , a ) ) } , defaultLabelFormatter : function ( ) { var a = this . axis , b = this . value , c = a . categories , d = this . dateTimeLabelFormat , e = P . lang . numericSymbols , f = e && e . length ,
g , h = a . options . labels . format , a = a . isLog ? b : a . tickInterval ; if ( h ) g = Ja ( h , this ) ; else if ( c ) g = b ; else if ( d ) g = Oa ( d , b ) ; else if ( f && a >= 1E3 ) for ( ; f -- && g === u ; ) c = Math . pow ( 1E3 , f + 1 ) , a >= c && e [ f ] !== null && ( g = w . numberFormat ( b / c , - 1 ) + e [ f ] ) ; g === u && ( g = O ( b ) >= 1E4 ? w . numberFormat ( b , 0 ) : w . numberFormat ( b , - 1 , u , "" ) ) ; return g } , getSeriesExtremes : function ( ) { var a = this , b = a . chart ; a . hasVisibleSeries = ! 1 ; a . dataMin = a . dataMax = a . ignoreMinPadding = a . ignoreMaxPadding = null ; a . buildStacks && a . buildStacks ( ) ; m ( a . series , function ( c ) { if ( c . visible || ! b . options . chart . ignoreHiddenSeries ) { var d ;
d = c . options . threshold ; var e ; a . hasVisibleSeries = ! 0 ; a . isLog && d <= 0 && ( d = null ) ; if ( a . isXAxis ) { if ( d = c . xData , d . length ) a . dataMin = I ( p ( a . dataMin , d [ 0 ] ) , Pa ( d ) ) , a . dataMax = t ( p ( a . dataMax , d [ 0 ] ) , Fa ( d ) ) } else { c . getExtremes ( ) ; e = c . dataMax ; c = c . dataMin ; if ( s ( c ) && s ( e ) ) a . dataMin = I ( p ( a . dataMin , c ) , c ) , a . dataMax = t ( p ( a . dataMax , e ) , e ) ; if ( s ( d ) ) if ( a . dataMin >= d ) a . dataMin = d , a . ignoreMinPadding = ! 0 ; else if ( a . dataMax < d ) a . dataMax = d , a . ignoreMaxPadding = ! 0 } } } ) } , translate : function ( a , b , c , d , e , f ) { var g = 1 , h = 0 , i = d ? this . oldTransA : this . transA , d = d ? this . oldMin :
this . min , j = this . minPixelPadding , e = ( this . doPostTranslate || this . isLog && e ) && this . lin2val ; if ( ! i ) i = this . transA ; if ( c ) g *= - 1 , h = this . len ; this . reversed && ( g *= - 1 , h -= g * ( this . sector || this . len ) ) ; b ? ( a = a * g + h , a -= j , a = a / i + d , e && ( a = this . lin2val ( a ) ) ) : ( e && ( a = this . val2lin ( a ) ) , f === "between" && ( f = 0.5 ) , a = g * ( a - d ) * i + h + g * j + ( qa ( f ) ? i * f * this . pointRange : 0 ) ) ; return a } , toPixels : function ( a , b ) { return this . translate ( a , ! 1 , ! this . horiz , null , ! 0 ) + ( b ? 0 : this . pos ) } , toValue : function ( a , b ) { return this . translate ( a - ( b ? 0 : this . pos ) , ! 0 , ! this . horiz , null ,
! 0 ) } , getPlotLinePath : function ( a , b , c , d , e ) { var f = this . chart , g = this . left , h = this . top , i , j , k = c && f . oldChartHeight || f . chartHeight , l = c && f . oldChartWidth || f . chartWidth , n ; i = this . transB ; var o = function ( a , b , c ) { if ( a < b || a > c ) d ? a = I ( t ( b , a ) , c ) : n = ! 0 ; return a } , e = p ( e , this . translate ( a , null , null , c ) ) , a = c = x ( e + i ) ; i = j = x ( k - e - i ) ; isNaN ( e ) ? n = ! 0 : this . horiz ? ( i = h , j = k - this . bottom , a = c = o ( a , g , g + this . width ) ) : ( a = g , c = l - this . right , i = j = o ( i , h , h + this . height ) ) ; return n && ! d ? null : f . renderer . crispLine ( [ "M" , a , i , "L" , c , j ] , b || 1 ) } , getLinearTickPositions : function ( a ,
b , c ) { var d , e = da ( U ( b / a ) * a ) , f = da ( sa ( c / a ) * a ) , g = [ ] ; if ( b === c && qa ( b ) ) return [ b ] ; for ( b = e ; b <= f ; ) { g . push ( b ) ; b = da ( b + a ) ; if ( b === d ) break ; d = b } return g } , getMinorTickPositions : function ( ) { var a = this . options , b = this . tickPositions , c = this . minorTickInterval , d = [ ] , e , f = this . min ; e = this . max ; var g = e - f ; if ( g && g / c < this . len / 3 ) if ( this . isLog ) { a = b . length ; for ( e = 1 ; e < a ; e ++ ) d = d . concat ( this . getLogTickPositions ( c , b [ e - 1 ] , b [ e ] , ! 0 ) ) } else if ( this . isDatetimeAxis && a . minorTickInterval === "auto" ) d = d . concat ( this . getTimeTicks ( this . normalizeTimeTickInterval ( c ) ,
f , e , a . startOfWeek ) ) ; else for ( b = f + ( b [ 0 ] - f ) % c ; b <= e ; b += c ) d . push ( b ) ; this . trimTicks ( d ) ; return d } , adjustForMinRange : function ( ) { var a = this . options , b = this . min , c = this . max , d , e = this . dataMax - this . dataMin >= this . minRange , f , g , h , i , j ; if ( this . isXAxis && this . minRange === u && ! this . isLog ) s ( a . min ) || s ( a . max ) ? this . minRange = null : ( m ( this . series , function ( a ) { i = a . xData ; for ( g = j = a . xIncrement ? 1 : i . length - 1 ; g > 0 ; g -- ) if ( h = i [ g ] - i [ g - 1 ] , f === u || h < f ) f = h } ) , this . minRange = I ( f * 5 , this . dataMax - this . dataMin ) ) ; if ( c - b < this . minRange ) { var k = this . minRange ;
d = ( k - c + b ) / 2 ; d = [ b - d , p ( a . min , b - d ) ] ; if ( e ) d [ 2 ] = this . dataMin ; b = Fa ( d ) ; c = [ b + k , p ( a . max , b + k ) ] ; if ( e ) c [ 2 ] = this . dataMax ; c = Pa ( c ) ; c - b < k && ( d [ 0 ] = c - k , d [ 1 ] = p ( a . min , c - k ) , b = Fa ( d ) ) } this . min = b ; this . max = c } , setAxisTranslation : function ( a ) { var b = this , c = b . max - b . min , d = b . axisPointRange || 0 , e , f = 0 , g = 0 , h = b . linkedParent , i = ! ! b . categories , j = b . transA , k = b . isXAxis ; if ( k || i || d ) if ( h ? ( f = h . minPointOffset , g = h . pointRangePadding ) : m ( b . series , function ( a ) { var h = i ? 1 : k ? a . pointRange : b . axisPointRange || 0 , j = a . options . pointPlacement , q = a . closestPointRange ;
h > c && ( h = 0 ) ; d = t ( d , h ) ; b . single || ( f = t ( f , Da ( j ) ? 0 : h / 2 ) , g = t ( g , j === "on" ? 0 : h ) ) ; ! a . noSharedTooltip && s ( q ) && ( e = s ( e ) ? I ( e , q ) : q ) } ) , h = b . ordinalSlope && e ? b . ordinalSlope / e : 1 , b . minPointOffset = f *= h , b . pointRangePadding = g *= h , b . pointRange = I ( d , c ) , k ) b . closestPointRange = e ; if ( a ) b . oldTransA = j ; b . translationSlope = b . transA = j = b . len / ( c + g || 1 ) ; b . transB = b . horiz ? b . left : b . bottom ; b . minPixelPadding = j * f } , setTickInterval : function ( a ) { var b = this , c = b . chart , d = b . options , e = b . isLog , f = b . isDatetimeAxis , g = b . isXAxis , h = b . isLinked , i = d . maxPadding , j = d . minPadding ,
k = d . tickInterval , l = d . tickPixelInterval , n = b . categories ; ! f && ! n && ! h && this . getTickAmount ( ) ; h ? ( b . linkedParent = c [ b . coll ] [ d . linkedTo ] , c = b . linkedParent . getExtremes ( ) , b . min = p ( c . min , c . dataMin ) , b . max = p ( c . max , c . dataMax ) , d . type !== b . linkedParent . options . type && ka ( 11 , 1 ) ) : ( b . min = p ( b . userMin , d . min , b . dataMin ) , b . max = p ( b . userMax , d . max , b . dataMax ) ) ; if ( e ) ! a && I ( b . min , p ( b . dataMin , b . min ) ) <= 0 && ka ( 10 , 1 ) , b . min = da ( Ea ( b . min ) ) , b . max = da ( Ea ( b . max ) ) ; if ( b . range && s ( b . max ) ) b . userMin = b . min = t ( b . min , b . max - b . range ) , b . userMax = b . max , b . range =
null ; b . beforePadding && b . beforePadding ( ) ; b . adjustForMinRange ( ) ; if ( ! n && ! b . axisPointRange && ! b . usePercentage && ! h && s ( b . min ) && s ( b . max ) && ( c = b . max - b . min ) ) { if ( ! s ( d . min ) && ! s ( b . userMin ) && j && ( b . dataMin < 0 || ! b . ignoreMinPadding ) ) b . min -= c * j ; if ( ! s ( d . max ) && ! s ( b . userMax ) && i && ( b . dataMax > 0 || ! b . ignoreMaxPadding ) ) b . max += c * i } if ( qa ( d . floor ) ) b . min = t ( b . min , d . floor ) ; if ( qa ( d . ceiling ) ) b . max = I ( b . max , d . ceiling ) ; b . tickInterval = b . min === b . max || b . min === void 0 || b . max === void 0 ? 1 : h && ! k && l === b . linkedParent . options . tickPixelInterval ? b . linkedParent . tickInterval :
p ( k , this . tickAmount ? ( b . max - b . min ) / t ( this . tickAmount - 1 , 1 ) : void 0 , n ? 1 : ( b . max - b . min ) * l / t ( b . len , l ) ) ; g && ! a && m ( b . series , function ( a ) { a . processData ( b . min !== b . oldMin || b . max !== b . oldMax ) } ) ; b . setAxisTranslation ( ! 0 ) ; b . beforeSetTickPositions && b . beforeSetTickPositions ( ) ; if ( b . postProcessTickInterval ) b . tickInterval = b . postProcessTickInterval ( b . tickInterval ) ; if ( b . pointRange ) b . tickInterval = t ( b . pointRange , b . tickInterval ) ; a = p ( d . minTickInterval , b . isDatetimeAxis && b . closestPointRange ) ; if ( ! k && b . tickInterval < a ) b . tickInterval =
a ; if ( ! f && ! e && ! k ) b . tickInterval = pb ( b . tickInterval , null , ob ( b . tickInterval ) , p ( d . allowDecimals , ! ( b . tickInterval > 0.5 && b . tickInterval < 5 && b . max > 1E3 && b . max < 9999 ) ) , ! ! this . tickAmount ) ; if ( ! this . tickAmount && this . len ) b . tickInterval = b . unsquish ( ) ; this . setTickPositions ( ) } , setTickPositions : function ( ) { var a = this . options , b , c = a . tickPositions , d = a . tickPositioner , e = a . startOnTick , f = a . endOnTick , g ; this . tickmarkOffset = this . categories && a . tickmarkPlacement === "between" && this . tickInterval === 1 ? 0.5 : 0 ; this . minorTickInterval = a . minorTickInterval ===
"auto" && this . tickInterval ? this . tickInterval / 5 : a . minorTickInterval ; this . tickPositions = b = a . tickPositions && a . tickPositions . slice ( ) ; if ( ! b && ( this . tickPositions = b = this . isDatetimeAxis ? this . getTimeTicks ( this . normalizeTimeTickInterval ( this . tickInterval , a . units ) , this . min , this . max , a . startOfWeek , this . ordinalPositions , this . closestPointRange , ! 0 ) : this . isLog ? this . getLogTickPositions ( this . tickInterval , this . min , this . max ) : this . getLinearTickPositions ( this . tickInterval , this . min , this . max ) , d && ( d = d . apply ( this , [ this . min ,
this . max ] ) ) ) ) this . tickPositions = b = d ; if ( ! this . isLinked ) this . trimTicks ( b , e , f ) , this . min === this . max && s ( this . min ) && ! this . tickAmount && ( g = ! 0 , this . min -= 0.5 , this . max += 0.5 ) , this . single = g , ! c && ! d && this . adjustTickAmount ( ) } , trimTicks : function ( a , b , c ) { var d = a [ 0 ] , e = a [ a . length - 1 ] , f = this . minPointOffset || 0 ; b ? this . min = d : this . min - f > d && a . shift ( ) ; c ? this . max = e : this . max + f < e && a . pop ( ) ; a . length === 0 && s ( d ) && a . push ( ( e + d ) / 2 ) } , getTickAmount : function ( ) { var a = { } , b , c = this . options , d = c . tickAmount , e = c . tickPixelInterval ; ! s ( c . tickInterval ) &&
this . len < e && ! this . isRadial && ! this . isLog && c . startOnTick && c . endOnTick && ( d = 2 ) ; ! d && this . chart . options . chart . alignTicks !== ! 1 && c . alignTicks !== ! 1 && ( m ( this . chart [ this . coll ] , function ( c ) { var d = c . options , c = c . horiz , d = [ c ? d . left : d . top , c ? d . width : d . height , d . pane ] . join ( "," ) ; a [ d ] ? b = ! 0 : a [ d ] = 1 } ) , b && ( d = sa ( this . len / e ) + 1 ) ) ; if ( d < 4 ) this . finalTickAmt = d , d = 5 ; this . tickAmount = d } , adjustTickAmount : function ( ) { var a = this . tickInterval , b = this . tickPositions , c = this . tickAmount , d = this . finalTickAmt , e = b && b . length ; if ( e < c ) { for ( ; b . length < c ; ) b . push ( da ( b [ b . length -
1 ] + a ) ) ; this . transA *= ( e - 1 ) / ( c - 1 ) ; this . max = b [ b . length - 1 ] } else e > c && ( this . tickInterval *= 2 , this . setTickPositions ( ) ) ; if ( s ( d ) ) { for ( a = c = b . length ; a -- ; ) ( d === 3 && a % 2 === 1 || d <= 2 && a > 0 && a < c - 1 ) && b . splice ( a , 1 ) ; this . finalTickAmt = u } } , setScale : function ( ) { var a = this . stacks , b , c , d , e ; this . oldMin = this . min ; this . oldMax = this . max ; this . oldAxisLength = this . len ; this . setAxisSize ( ) ; e = this . len !== this . oldAxisLength ; m ( this . series , function ( a ) { if ( a . isDirtyData || a . isDirty || a . xAxis . isDirty ) d = ! 0 } ) ; if ( e || d || this . isLinked || this . forceRedraw ||
this . userMin !== this . oldUserMin || this . userMax !== this . oldUserMax ) { if ( ! this . isXAxis ) for ( b in a ) for ( c in a [ b ] ) a [ b ] [ c ] . total = null , a [ b ] [ c ] . cum = 0 ; this . forceRedraw = ! 1 ; this . getSeriesExtremes ( ) ; this . setTickInterval ( ) ; this . oldUserMin = this . userMin ; this . oldUserMax = this . userMax ; if ( ! this . isDirty ) this . isDirty = e || this . min !== this . oldMin || this . max !== this . oldMax } else if ( ! this . isXAxis ) { if ( this . oldStacks ) a = this . stacks = this . oldStacks ; for ( b in a ) for ( c in a [ b ] ) a [ b ] [ c ] . cum = a [ b ] [ c ] . total } } , setExtremes : function ( a , b , c , d , e ) { var f =
this , g = f . chart , c = p ( c , ! 0 ) ; m ( f . series , function ( a ) { delete a . kdTree } ) ; e = r ( e , { min : a , max : b } ) ; M ( f , "setExtremes" , e , function ( ) { f . userMin = a ; f . userMax = b ; f . eventArgs = e ; f . isDirtyExtremes = ! 0 ; c && g . redraw ( d ) } ) } , zoom : function ( a , b ) { var c = this . dataMin , d = this . dataMax , e = this . options ; this . allowZoomOutside || ( s ( c ) && a <= I ( c , p ( e . min , c ) ) && ( a = u ) , s ( d ) && b >= t ( d , p ( e . max , d ) ) && ( b = u ) ) ; this . displayBtn = a !== u || b !== u ; this . setExtremes ( a , b , ! 1 , u , { trigger : "zoom" } ) ; return ! 0 } , setAxisSize : function ( ) { var a = this . chart , b = this . options , c = b . offsetLeft ||
0 , d = this . horiz , e = p ( b . width , a . plotWidth - c + ( b . offsetRight || 0 ) ) , f = p ( b . height , a . plotHeight ) , g = p ( b . top , a . plotTop ) , b = p ( b . left , a . plotLeft + c ) , c = /%$/ ; c . test ( f ) && ( f = parseFloat ( f ) / 100 * a . plotHeight ) ; c . test ( g ) && ( g = parseFloat ( g ) / 100 * a . plotHeight + a . plotTop ) ; this . left = b ; this . top = g ; this . width = e ; this . height = f ; this . bottom = a . chartHeight - f - g ; this . right = a . chartWidth - e - b ; this . len = t ( d ? e : f , 0 ) ; this . pos = d ? b : g } , getExtremes : function ( ) { var a = this . isLog ; return { min : a ? da ( ha ( this . min ) ) : this . min , max : a ? da ( ha ( this . max ) ) : this . max , dataMin : this . dataMin ,
dataMax : this . dataMax , userMin : this . userMin , userMax : this . userMax } } , getThreshold : function ( a ) { var b = this . isLog , c = b ? ha ( this . min ) : this . min , b = b ? ha ( this . max ) : this . max ; c > a || a === null ? a = c : b < a && ( a = b ) ; return this . translate ( a , 0 , 1 , 0 , 1 ) } , autoLabelAlign : function ( a ) { a = ( p ( a , 0 ) - this . side * 90 + 720 ) % 360 ; return a > 15 && a < 165 ? "right" : a > 195 && a < 345 ? "left" : "center" } , unsquish : function ( ) { var a = this . ticks , b = this . options . labels , c = this . horiz , d = this . tickInterval , e = d , f = this . len / ( ( ( this . categories ? 1 : 0 ) + this . max - this . min ) / d ) , g , h = b . rotation ,
i = this . chart . renderer . fontMetrics ( b . style . fontSize , a [ 0 ] && a [ 0 ] . label ) , j , k = Number . MAX _VALUE , l , n = function ( a ) { a /= f || 1 ; a = a > 1 ? sa ( a ) : 1 ; return a * d } ; c ? ( l = s ( h ) ? [ h ] : f < p ( b . autoRotationLimit , 80 ) && ! b . staggerLines && ! b . step && b . autoRotation ) && m ( l , function ( a ) { var b ; if ( a === h || a && a >= - 90 && a <= 90 ) j = n ( O ( i . h / $ ( ga * a ) ) ) , b = j + O ( a / 360 ) , b < k && ( k = b , g = a , e = j ) } ) : e = n ( i . h ) ; this . autoRotation = l ; this . labelRotation = g ; return e } , renderUnsquish : function ( ) { var a = this . chart , b = a . renderer , c = this . tickPositions , d = this . ticks , e = this . options . labels ,
f = this . horiz , g = a . margin , h = this . slotWidth = f && ! e . step && ! e . rotation && ( this . staggerLines || 1 ) * a . plotWidth / c . length || ! f && ( g [ 3 ] && g [ 3 ] - a . spacing [ 3 ] || a . chartWidth * 0.33 ) , i = t ( 1 , x ( h - 2 * ( e . padding || 5 ) ) ) , j = { } , g = b . fontMetrics ( e . style . fontSize , d [ 0 ] && d [ 0 ] . label ) , k , l = 0 ; if ( ! Da ( e . rotation ) ) j . rotation = e . rotation ; if ( this . autoRotation ) m ( c , function ( a ) { if ( ( a = d [ a ] ) && a . labelLength > l ) l = a . labelLength } ) , l > i && l > g . h ? j . rotation = this . labelRotation : this . labelRotation = 0 ; else if ( h ) { k = { width : i + "px" , textOverflow : "clip" } ; for ( h = c . length ; ! f &&
h -- ; ) if ( i = c [ h ] , i = d [ i ] . label ) if ( i . styles . textOverflow === "ellipsis" && i . css ( { textOverflow : "clip" } ) , i . getBBox ( ) . height > this . len / c . length - ( g . h - g . f ) ) i . specCss = { textOverflow : "ellipsis" } } j . rotation && ( k = { width : ( l > a . chartHeight * 0.5 ? a . chartHeight * 0.33 : a . chartHeight ) + "px" , textOverflow : "ellipsis" } ) ; this . labelAlign = j . align = e . align || this . autoLabelAlign ( this . labelRotation ) ; m ( c , function ( a ) { var b = ( a = d [ a ] ) && a . label ; if ( b ) k && b . css ( z ( k , b . specCss ) ) , delete b . specCss , b . attr ( j ) , a . rotation = j . rotation } ) ; this . tickRotCorr = b . rotCorr ( g . b ,
this . labelRotation || 0 , this . side === 2 ) } , getOffset : function ( ) { var a = this , b = a . chart , c = b . renderer , d = a . options , e = a . tickPositions , f = a . ticks , g = a . horiz , h = a . side , i = b . inverted ? [ 1 , 0 , 3 , 2 ] [ h ] : h , j , k , l = 0 , n , o = 0 , q = d . title , y = d . labels , S = 0 , C = b . axisOffset , b = b . clipOffset , v = [ - 1 , 1 , 1 , - 1 ] [ h ] , r ; a . hasData = j = a . hasVisibleSeries || s ( a . min ) && s ( a . max ) && ! ! e ; a . showAxis = k = j || p ( d . showEmpty , ! 0 ) ; a . staggerLines = a . horiz && y . staggerLines ; if ( ! a . axisGroup ) a . gridGroup = c . g ( "grid" ) . attr ( { zIndex : d . gridZIndex || 1 } ) . add ( ) , a . axisGroup = c . g ( "axis" ) . attr ( { zIndex : d . zIndex ||
2 } ) . add ( ) , a . labelGroup = c . g ( "axis-labels" ) . attr ( { zIndex : y . zIndex || 7 } ) . addClass ( "highcharts-" + a . coll . toLowerCase ( ) + "-labels" ) . add ( ) ; if ( j || a . isLinked ) { if ( m ( e , function ( b ) { f [ b ] ? f [ b ] . addLabel ( ) : f [ b ] = new Ta ( a , b ) } ) , a . renderUnsquish ( ) , m ( e , function ( b ) { if ( h === 0 || h === 2 || { 1 : "left" , 3 : "right" } [ h ] === a . labelAlign ) S = t ( f [ b ] . getLabelSize ( ) , S ) } ) , a . staggerLines ) S *= a . staggerLines , a . labelOffset = S } else for ( r in f ) f [ r ] . destroy ( ) , delete f [ r ] ; if ( q && q . text && q . enabled !== ! 1 ) { if ( ! a . axisTitle ) a . axisTitle = c . text ( q . text , 0 , 0 , q . useHTML ) . attr ( { zIndex : 7 ,
rotation : q . rotation || 0 , align : q . textAlign || { low : "left" , middle : "center" , high : "right" } [ q . align ] } ) . addClass ( "highcharts-" + this . coll . toLowerCase ( ) + "-title" ) . css ( q . style ) . add ( a . axisGroup ) , a . axisTitle . isNew = ! 0 ; if ( k ) l = a . axisTitle . getBBox ( ) [ g ? "height" : "width" ] , n = q . offset , o = s ( n ) ? 0 : p ( q . margin , g ? 5 : 10 ) ; a . axisTitle [ k ? "show" : "hide" ] ( ) } a . offset = v * p ( d . offset , C [ h ] ) ; a . tickRotCorr = a . tickRotCorr || { x : 0 , y : 0 } ; c = h === 2 ? a . tickRotCorr . y : 0 ; g = S + o + ( S && v * ( g ? p ( y . y , a . tickRotCorr . y + 8 ) : y . x ) - c ) ; a . axisTitleMargin = p ( n , g ) ; C [ h ] = t ( C [ h ] , a . axisTitleMargin +
l + v * a . offset , g ) ; b [ i ] = t ( b [ i ] , U ( d . lineWidth / 2 ) * 2 ) } , getLinePath : function ( a ) { var b = this . chart , c = this . opposite , d = this . offset , e = this . horiz , f = this . left + ( c ? this . width : 0 ) + d , d = b . chartHeight - this . bottom - ( c ? this . height : 0 ) + d ; c && ( a *= - 1 ) ; return b . renderer . crispLine ( [ "M" , e ? this . left : f , e ? d : this . top , "L" , e ? b . chartWidth - this . right : f , e ? d : b . chartHeight - this . bottom ] , a ) } , getTitlePosition : function ( ) { var a = this . horiz , b = this . left , c = this . top , d = this . len , e = this . options . title , f = a ? b : c , g = this . opposite , h = this . offset , i = B ( e . style . fontSize ||
12 ) , d = { low : f + ( a ? 0 : d ) , middle : f + d / 2 , high : f + ( a ? d : 0 ) } [ e . align ] , b = ( a ? c + this . height : b ) + ( a ? 1 : - 1 ) * ( g ? - 1 : 1 ) * this . axisTitleMargin + ( this . side === 2 ? i : 0 ) ; return { x : a ? d : b + ( g ? this . width : 0 ) + h + ( e . x || 0 ) , y : a ? b - ( g ? this . height : 0 ) + h : d + ( e . y || 0 ) } } , render : function ( ) { var a = this , b = a . chart , c = b . renderer , d = a . options , e = a . isLog , f = a . isLinked , g = a . tickPositions , h = a . axisTitle , i = a . ticks , j = a . minorTicks , k = a . alternateBands , l = d . stackLabels , n = d . alternateGridColor , o = a . tickmarkOffset , q = d . lineWidth , y , p = b . hasRendered && s ( a . oldMin ) && ! isNaN ( a . oldMin ) ;
y = a . hasData ; var C = a . showAxis , v , r ; a . labelEdge . length = 0 ; a . overlap = ! 1 ; m ( [ i , j , k ] , function ( a ) { for ( var b in a ) a [ b ] . isActive = ! 1 } ) ; if ( y || f ) { a . minorTickInterval && ! a . categories && m ( a . getMinorTickPositions ( ) , function ( b ) { j [ b ] || ( j [ b ] = new Ta ( a , b , "minor" ) ) ; p && j [ b ] . isNew && j [ b ] . render ( null , ! 0 ) ; j [ b ] . render ( null , ! 1 , 1 ) } ) ; if ( g . length && ( m ( g , function ( b , c ) { if ( ! f || b >= a . min && b <= a . max ) i [ b ] || ( i [ b ] = new Ta ( a , b ) ) , p && i [ b ] . isNew && i [ b ] . render ( c , ! 0 , 0.1 ) , i [ b ] . render ( c ) } ) , o && ( a . min === 0 || a . single ) ) ) i [ - 1 ] || ( i [ - 1 ] = new Ta ( a , - 1 , null , ! 0 ) ) ,
i [ - 1 ] . render ( - 1 ) ; n && m ( g , function ( b , c ) { if ( c % 2 === 0 && b < a . max ) k [ b ] || ( k [ b ] = new w . PlotLineOrBand ( a ) ) , v = b + o , r = g [ c + 1 ] !== u ? g [ c + 1 ] + o : a . max , k [ b ] . options = { from : e ? ha ( v ) : v , to : e ? ha ( r ) : r , color : n } , k [ b ] . render ( ) , k [ b ] . isActive = ! 0 } ) ; if ( ! a . _addedPlotLB ) m ( ( d . plotLines || [ ] ) . concat ( d . plotBands || [ ] ) , function ( b ) { a . addPlotBandOrLine ( b ) } ) , a . _addedPlotLB = ! 0 } m ( [ i , j , k ] , function ( a ) { var c , d , e = [ ] , f = za ? za . duration || 500 : 0 , g = function ( ) { for ( d = e . length ; d -- ; ) a [ e [ d ] ] && ! a [ e [ d ] ] . isActive && ( a [ e [ d ] ] . destroy ( ) , delete a [ e [ d ] ] ) } ; for ( c in a ) if ( ! a [ c ] . isActive ) a [ c ] . render ( c ,
! 1 , 0 ) , a [ c ] . isActive = ! 1 , e . push ( c ) ; a === k || ! b . hasRendered || ! f ? g ( ) : f && setTimeout ( g , f ) } ) ; if ( q ) y = a . getLinePath ( q ) , a . axisLine ? a . axisLine . animate ( { d : y } ) : a . axisLine = c . path ( y ) . attr ( { stroke : d . lineColor , "stroke-width" : q , zIndex : 7 } ) . add ( a . axisGroup ) , a . axisLine [ C ? "show" : "hide" ] ( ) ; if ( h && C ) h [ h . isNew ? "attr" : "animate" ] ( a . getTitlePosition ( ) ) , h . isNew = ! 1 ; l && l . enabled && a . renderStackTotals ( ) ; a . isDirty = ! 1 } , redraw : function ( ) { this . render ( ) ; m ( this . plotLinesAndBands , function ( a ) { a . render ( ) } ) ; m ( this . series , function ( a ) { a . isDirty =
! 0 } ) } , destroy : function ( a ) { var b = this , c = b . stacks , d , e = b . plotLinesAndBands ; a || Y ( b ) ; for ( d in c ) Qa ( c [ d ] ) , c [ d ] = null ; m ( [ b . ticks , b . minorTicks , b . alternateBands ] , function ( a ) { Qa ( a ) } ) ; for ( a = e . length ; a -- ; ) e [ a ] . destroy ( ) ; m ( "stackTotalGroup,axisLine,axisTitle,axisGroup,cross,gridGroup,labelGroup" . split ( "," ) , function ( a ) { b [ a ] && ( b [ a ] = b [ a ] . destroy ( ) ) } ) ; this . cross && this . cross . destroy ( ) } , drawCrosshair : function ( a , b ) { var c , d = this . crosshair , e = d . animation ; if ( ! this . crosshair || ( s ( b ) || ! p ( this . crosshair . snap , ! 0 ) ) === ! 1 ) this . hideCrosshair ( ) ;
else if ( p ( d . snap , ! 0 ) ? s ( b ) && ( c = this . isXAxis ? b . plotX : this . len - b . plotY ) : c = this . horiz ? a . chartX - this . pos : this . len - a . chartY + this . pos , c = this . isRadial ? this . getPlotLinePath ( this . isXAxis ? b . x : p ( b . stackY , b . y ) ) || null : this . getPlotLinePath ( null , null , null , null , c ) || null , c === null ) this . hideCrosshair ( ) ; else if ( this . cross ) this . cross . attr ( { visibility : "visible" } ) [ e ? "animate" : "attr" ] ( { d : c } , e ) ; else { e = this . categories && ! this . isRadial ; e = { "stroke-width" : d . width || ( e ? this . transA : 1 ) , stroke : d . color || ( e ? "rgba(155,200,255,0.2)" : "#C0C0C0" ) ,
zIndex : d . zIndex || 2 } ; if ( d . dashStyle ) e . dashstyle = d . dashStyle ; this . cross = this . chart . renderer . path ( c ) . attr ( e ) . add ( ) } } , hideCrosshair : function ( ) { this . cross && this . cross . hide ( ) } } ; r ( va . prototype , { getPlotBandPath : function ( a , b ) { var c = this . getPlotLinePath ( b , null , null , ! 0 ) , d = this . getPlotLinePath ( a , null , null , ! 0 ) ; d && c && d . toString ( ) !== c . toString ( ) ? d . push ( c [ 4 ] , c [ 5 ] , c [ 1 ] , c [ 2 ] ) : d = null ; return d } , addPlotBand : function ( a ) { return this . addPlotBandOrLine ( a , "plotBands" ) } , addPlotLine : function ( a ) { return this . addPlotBandOrLine ( a ,
"plotLines" ) } , addPlotBandOrLine : function ( a , b ) { var c = ( new w . PlotLineOrBand ( this , a ) ) . render ( ) , d = this . userOptions ; c && ( b && ( d [ b ] = d [ b ] || [ ] , d [ b ] . push ( a ) ) , this . plotLinesAndBands . push ( c ) ) ; return c } , removePlotBandOrLine : function ( a ) { for ( var b = this . plotLinesAndBands , c = this . options , d = this . userOptions , e = b . length ; e -- ; ) b [ e ] . id === a && b [ e ] . destroy ( ) ; m ( [ c . plotLines || [ ] , d . plotLines || [ ] , c . plotBands || [ ] , d . plotBands || [ ] ] , function ( b ) { for ( e = b . length ; e -- ; ) b [ e ] . id === a && ia ( b , b [ e ] ) } ) } } ) ; va . prototype . getTimeTicks = function ( a , b ,
c , d ) { var e = [ ] , f = { } , g = P . global . useUTC , h , i = new Aa ( b - Wa ( b ) ) , j = a . unitRange , k = a . count ; if ( s ( b ) ) { i [ Db ] ( j >= G . second ? 0 : k * U ( i . getMilliseconds ( ) / k ) ) ; if ( j >= G . second ) i [ Eb ] ( j >= G . minute ? 0 : k * U ( i . getSeconds ( ) / k ) ) ; if ( j >= G . minute ) i [ Fb ] ( j >= G . hour ? 0 : k * U ( i [ rb ] ( ) / k ) ) ; if ( j >= G . hour ) i [ Gb ] ( j >= G . day ? 0 : k * U ( i [ sb ] ( ) / k ) ) ; if ( j >= G . day ) i [ ub ] ( j >= G . month ? 1 : k * U ( i [ Xa ] ( ) / k ) ) ; j >= G . month && ( i [ vb ] ( j >= G . year ? 0 : k * U ( i [ Ya ] ( ) / k ) ) , h = i [ Za ] ( ) ) ; j >= G . year && ( h -= h % k , i [ wb ] ( h ) ) ; if ( j === G . week ) i [ ub ] ( i [ Xa ] ( ) - i [ tb ] ( ) + p ( d , 1 ) ) ; b = 1 ; if ( nb || eb ) i = i . getTime ( ) , i = new Aa ( i +
Wa ( i ) ) ; h = i [ Za ] ( ) ; for ( var d = i . getTime ( ) , l = i [ Ya ] ( ) , n = i [ Xa ] ( ) , o = ( G . day + ( g ? Wa ( i ) : i . getTimezoneOffset ( ) * 6E4 ) ) % G . day ; d < c ; ) e . push ( d ) , j === G . year ? d = gb ( h + b * k , 0 ) : j === G . month ? d = gb ( h , l + b * k ) : ! g && ( j === G . day || j === G . week ) ? d = gb ( h , l , n + b * k * ( j === G . day ? 1 : 7 ) ) : d += j * k , b ++ ; e . push ( d ) ; m ( kb ( e , function ( a ) { return j <= G . hour && a % G . day === o } ) , function ( a ) { f [ a ] = "day" } ) } e . info = r ( a , { higherRanks : f , totalRange : j * k } ) ; return e } ; va . prototype . normalizeTimeTickInterval = function ( a , b ) { var c = b || [ [ "millisecond" , [ 1 , 2 , 5 , 10 , 20 , 25 , 50 , 100 , 200 , 500 ] ] , [ "second" ,
[ 1 , 2 , 5 , 10 , 15 , 30 ] ] , [ "minute" , [ 1 , 2 , 5 , 10 , 15 , 30 ] ] , [ "hour" , [ 1 , 2 , 3 , 4 , 6 , 8 , 12 ] ] , [ "day" , [ 1 , 2 ] ] , [ "week" , [ 1 , 2 ] ] , [ "month" , [ 1 , 2 , 3 , 4 , 6 ] ] , [ "year" , null ] ] , d = c [ c . length - 1 ] , e = G [ d [ 0 ] ] , f = d [ 1 ] , g ; for ( g = 0 ; g < c . length ; g ++ ) if ( d = c [ g ] , e = G [ d [ 0 ] ] , f = d [ 1 ] , c [ g + 1 ] && a <= ( e * f [ f . length - 1 ] + G [ c [ g + 1 ] [ 0 ] ] ) / 2 ) break ; e === G . year && a < 5 * e && ( f = [ 1 , 2 , 5 ] ) ; c = pb ( a / e , f , d [ 0 ] === "year" ? t ( ob ( a / e ) , 1 ) : 1 ) ; return { unitRange : e , count : c , unitName : d [ 0 ] } } ; va . prototype . getLogTickPositions = function ( a , b , c , d ) { var e = this . options , f = this . len , g = [ ] ; if ( ! d ) this . _minorAutoInterval =
null ; if ( a >= 0.5 ) a = x ( a ) , g = this . getLinearTickPositions ( a , b , c ) ; else if ( a >= 0.08 ) for ( var f = U ( b ) , h , i , j , k , l , e = a > 0.3 ? [ 1 , 2 , 4 ] : a > 0.15 ? [ 1 , 2 , 4 , 6 , 8 ] : [ 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 ] ; f < c + 1 && ! l ; f ++ ) { i = e . length ; for ( h = 0 ; h < i && ! l ; h ++ ) j = Ea ( ha ( f ) * e [ h ] ) , j > b && ( ! d || k <= c ) && k !== u && g . push ( k ) , k > c && ( l = ! 0 ) , k = j } else if ( b = ha ( b ) , c = ha ( c ) , a = e [ d ? "minorTickInterval" : "tickInterval" ] , a = p ( a === "auto" ? null : a , this . _minorAutoInterval , ( c - b ) * ( e . tickPixelInterval / ( d ? 5 : 1 ) ) / ( ( d ? f / this . tickPositions . length : f ) || 1 ) ) , a = pb ( a , null , ob ( a ) ) , g = Ua ( this . getLinearTickPositions ( a ,
b , c ) , Ea ) , ! d ) this . _minorAutoInterval = a / 5 ; if ( ! d ) this . tickInterval = a ; return g } ; var Mb = w . Tooltip = function ( ) { this . init . apply ( this , arguments ) } ; Mb . prototype = { init : function ( a , b ) { var c = b . borderWidth , d = b . style , e = B ( d . padding ) ; this . chart = a ; this . options = b ; this . crosshairs = [ ] ; this . now = { x : 0 , y : 0 } ; this . isHidden = ! 0 ; this . label = a . renderer . label ( "" , 0 , 0 , b . shape || "callout" , null , null , b . useHTML , null , "tooltip" ) . attr ( { padding : e , fill : b . backgroundColor , "stroke-width" : c , r : b . borderRadius , zIndex : 8 } ) . css ( d ) . css ( { padding : 0 } ) . add ( ) . attr ( { y : - 9999 } ) ;
ea || this . label . shadow ( b . shadow ) ; this . shared = b . shared } , destroy : function ( ) { if ( this . label ) this . label = this . label . destroy ( ) ; clearTimeout ( this . hideTimer ) ; clearTimeout ( this . tooltipTimeout ) } , move : function ( a , b , c , d ) { var e = this , f = e . now , g = e . options . animation !== ! 1 && ! e . isHidden && ( O ( a - f . x ) > 1 || O ( b - f . y ) > 1 ) , h = e . followPointer || e . len > 1 ; r ( f , { x : g ? ( 2 * f . x + a ) / 3 : a , y : g ? ( f . y + b ) / 2 : b , anchorX : h ? u : g ? ( 2 * f . anchorX + c ) / 3 : c , anchorY : h ? u : g ? ( f . anchorY + d ) / 2 : d } ) ; e . label . attr ( f ) ; if ( g ) clearTimeout ( this . tooltipTimeout ) , this . tooltipTimeout = setTimeout ( function ( ) { e &&
e . move ( a , b , c , d ) } , 32 ) } , hide : function ( a ) { var b = this , c ; clearTimeout ( this . hideTimer ) ; if ( ! this . isHidden ) c = this . chart . hoverPoints , this . hideTimer = setTimeout ( function ( ) { b . label . fadeOut ( ) ; b . isHidden = ! 0 } , p ( a , this . options . hideDelay , 500 ) ) , c && m ( c , function ( a ) { a . setState ( ) } ) , this . chart . hoverPoints = null , this . chart . hoverSeries = null } , getAnchor : function ( a , b ) { var c , d = this . chart , e = d . inverted , f = d . plotTop , g = d . plotLeft , h = 0 , i = 0 , j , k , a = ra ( a ) ; c = a [ 0 ] . tooltipPos ; this . followPointer && b && ( b . chartX === u && ( b = d . pointer . normalize ( b ) ) ,
c = [ b . chartX - d . plotLeft , b . chartY - f ] ) ; c || ( m ( a , function ( a ) { j = a . series . yAxis ; k = a . series . xAxis ; h += a . plotX + ( ! e && k ? k . left - g : 0 ) ; i += ( a . plotLow ? ( a . plotLow + a . plotHigh ) / 2 : a . plotY ) + ( ! e && j ? j . top - f : 0 ) } ) , h /= a . length , i /= a . length , c = [ e ? d . plotWidth - i : h , this . shared && ! e && a . length > 1 && b ? b . chartY - f : e ? d . plotHeight - h : i ] ) ; return Ua ( c , x ) } , getPosition : function ( a , b , c ) { var d = this . chart , e = this . distance , f = { } , g = c . h , h , i = [ "y" , d . chartHeight , b , c . plotY + d . plotTop ] , j = [ "x" , d . chartWidth , a , c . plotX + d . plotLeft ] , k = p ( c . ttBelow , d . inverted && ! c . negative ||
! d . inverted && c . negative ) , l = function ( a , b , c , d ) { var h = c < d - e , i = d + e + c < b , j = d - e - c ; d += e ; if ( k && i ) f [ a ] = d ; else if ( ! k && h ) f [ a ] = j ; else if ( h ) f [ a ] = j - g < 0 ? j : j - g ; else if ( i ) f [ a ] = d + g + c > b ? d : d + g ; else return ! 1 } , n = function ( a , b , c , d ) { if ( d < e || d > b - e ) return ! 1 ; else f [ a ] = d < c / 2 ? 1 : d > b - c / 2 ? b - c - 2 : d - c / 2 } , o = function ( a ) { var b = i ; i = j ; j = b ; h = a } , q = function ( ) { l . apply ( 0 , i ) !== ! 1 ? n . apply ( 0 , j ) === ! 1 && ! h && ( o ( ! 0 ) , q ( ) ) : h ? f . x = f . y = 0 : ( o ( ! 0 ) , q ( ) ) } ; ( d . inverted || this . len > 1 ) && o ( ) ; q ( ) ; return f } , defaultFormatter : function ( a ) { var b = this . points || ra ( this ) , c ; c = [ a . tooltipFooterHeaderFormatter ( b [ 0 ] ) ] ;
c = c . concat ( a . bodyFormatter ( b ) ) ; c . push ( a . tooltipFooterHeaderFormatter ( b [ 0 ] , ! 0 ) ) ; return c . join ( "" ) } , refresh : function ( a , b ) { var c = this . chart , d = this . label , e = this . options , f , g , h = { } , i , j = [ ] ; i = e . formatter || this . defaultFormatter ; var h = c . hoverPoints , k , l = this . shared ; clearTimeout ( this . hideTimer ) ; this . followPointer = ra ( a ) [ 0 ] . series . tooltipOptions . followPointer ; g = this . getAnchor ( a , b ) ; f = g [ 0 ] ; g = g [ 1 ] ; l && ( ! a . series || ! a . series . noSharedTooltip ) ? ( c . hoverPoints = a , h && m ( h , function ( a ) { a . setState ( ) } ) , m ( a , function ( a ) { a . setState ( "hover" ) ;
j . push ( a . getLabelConfig ( ) ) } ) , h = { x : a [ 0 ] . category , y : a [ 0 ] . y } , h . points = j , this . len = j . length , a = a [ 0 ] ) : h = a . getLabelConfig ( ) ; i = i . call ( h , this ) ; h = a . series ; this . distance = p ( h . tooltipOptions . distance , 16 ) ; i === ! 1 ? this . hide ( ) : ( this . isHidden && ( db ( d ) , d . attr ( "opacity" , 1 ) . show ( ) ) , d . attr ( { text : i } ) , k = e . borderColor || a . color || h . color || "#606060" , d . attr ( { stroke : k } ) , this . updatePosition ( { plotX : f , plotY : g , negative : a . negative , ttBelow : a . ttBelow , h : a . shapeArgs && a . shapeArgs . height || 0 } ) , this . isHidden = ! 1 ) ; M ( c , "tooltipRefresh" , { text : i ,
x : f + c . plotLeft , y : g + c . plotTop , borderColor : k } ) } , updatePosition : function ( a ) { var b = this . chart , c = this . label , c = ( this . options . positioner || this . getPosition ) . call ( this , c . width , c . height , a ) ; this . move ( x ( c . x ) , x ( c . y ) , a . plotX + b . plotLeft , a . plotY + b . plotTop ) } , getXDateFormat : function ( a , b , c ) { var d , b = b . dateTimeLabelFormats , e = c && c . closestPointRange , f , g = { millisecond : 15 , second : 12 , minute : 9 , hour : 6 , day : 3 } , h , i ; if ( e ) { h = Oa ( "%m-%d %H:%M:%S.%L" , a . x ) ; for ( f in G ) { if ( e === G . week && + Oa ( "%w" , a . x ) === c . options . startOfWeek && h . substr ( 6 ) ===
"00:00:00.000" ) { f = "week" ; break } else if ( G [ f ] > e ) { f = i ; break } else if ( g [ f ] && h . substr ( g [ f ] ) !== "01-01 00:00:00.000" . substr ( g [ f ] ) ) break ; f !== "week" && ( i = f ) } f && ( d = b [ f ] ) } else d = b . day ; return d || b . year } , tooltipFooterHeaderFormatter : function ( a , b ) { var c = b ? "footer" : "header" , d = a . series , e = d . tooltipOptions , f = e . xDateFormat , g = d . xAxis , h = g && g . options . type === "datetime" && qa ( a . key ) , c = e [ c + "Format" ] ; h && ! f && ( f = this . getXDateFormat ( a , e , g ) ) ; h && f && ( c = c . replace ( "{point.key}" , "{point.key:" + f + "}" ) ) ; return Ja ( c , { point : a , series : d } ) } , bodyFormatter : function ( a ) { return Ua ( a ,
function ( a ) { var c = a . series . tooltipOptions ; return ( c . pointFormatter || a . point . tooltipFormatter ) . call ( a . point , c . pointFormat ) } ) } } ; var oa ; ab = A . documentElement . ontouchstart !== u ; var Va = w . Pointer = function ( a , b ) { this . init ( a , b ) } ; Va . prototype = { init : function ( a , b ) { var c = b . chart , d = c . events , e = ea ? "" : c . zoomType , c = a . inverted , f ; this . options = b ; this . chart = a ; this . zoomX = f = /x/ . test ( e ) ; this . zoomY = e = /y/ . test ( e ) ; this . zoomHor = f && ! c || e && c ; this . zoomVert = e && ! c || f && c ; this . hasZoom = f || e ; this . runChartClick = d && ! ! d . click ; this . pinchDown =
[ ] ; this . lastValidTouch = { } ; if ( w . Tooltip && b . tooltip . enabled ) a . tooltip = new Mb ( a , b . tooltip ) , this . followTouchMove = p ( b . tooltip . followTouchMove , ! 0 ) ; this . setDOMEvents ( ) } , normalize : function ( a , b ) { var c , d , a = a || window . event , a = Sb ( a ) ; if ( ! a . target ) a . target = a . srcElement ; d = a . touches ? a . touches . length ? a . touches . item ( 0 ) : a . changedTouches [ 0 ] : a ; if ( ! b ) this . chartPosition = b = Rb ( this . chart . container ) ; d . pageX === u ? ( c = t ( a . x , a . clientX - b . left ) , d = a . y ) : ( c = d . pageX - b . left , d = d . pageY - b . top ) ; return r ( a , { chartX : x ( c ) , chartY : x ( d ) } ) } , getCoordinates : function ( a ) { var b =
{ xAxis : [ ] , yAxis : [ ] } ; m ( this . chart . axes , function ( c ) { b [ c . isXAxis ? "xAxis" : "yAxis" ] . push ( { axis : c , value : c . toValue ( a [ c . horiz ? "chartX" : "chartY" ] ) } ) } ) ; return b } , runPointActions : function ( a ) { var b = this . chart , c = b . series , d = b . tooltip , e = d ? d . shared : ! 1 , f = b . hoverPoint , g = b . hoverSeries , h , i = b . chartWidth , j = b . chartWidth , k , l = [ ] , n , o ; if ( ! e && ! g ) for ( h = 0 ; h < c . length ; h ++ ) if ( c [ h ] . directTouch || ! c [ h ] . options . stickyTracking ) c = [ ] ; ! e && g && g . directTouch && f ? n = f : ( m ( c , function ( b ) { k = b . noSharedTooltip && e ; b . visible && ! k && p ( b . options . enableMouseTracking ,
! 0 ) && ( o = b . searchPoint ( a ) ) && l . push ( o ) } ) , m ( l , function ( a ) { if ( a && s ( a . plotX ) && s ( a . plotY ) && ( a . dist . distX < i || ( a . dist . distX === i || a . series . kdDimensions > 1 ) && a . dist . distR < j ) ) i = a . dist . distX , j = a . dist . distR , n = a } ) ) ; if ( n && ( n !== f || d && d . isHidden ) ) if ( e && ! n . series . noSharedTooltip ) { for ( h = l . length ; h -- ; ) ( l [ h ] . clientX !== n . clientX || l [ h ] . series . noSharedTooltip ) && l . splice ( h , 1 ) ; l . length && d && d . refresh ( l , a ) ; m ( l , function ( b ) { if ( b !== n ) b . onMouseOver ( a ) } ) ; ( g && g . directTouch && f || n ) . onMouseOver ( a ) } else d && d . refresh ( n , a ) , n . onMouseOver ( a ) ;
else c = g && g . tooltipOptions . followPointer , d && c && ! d . isHidden && ( c = d . getAnchor ( [ { } ] , a ) , d . updatePosition ( { plotX : c [ 0 ] , plotY : c [ 1 ] } ) ) ; if ( d && ! this . _onDocumentMouseMove ) this . _onDocumentMouseMove = function ( a ) { if ( X [ oa ] ) X [ oa ] . pointer . onDocumentMouseMove ( a ) } , N ( A , "mousemove" , this . _onDocumentMouseMove ) ; m ( b . axes , function ( b ) { b . drawCrosshair ( a , p ( n , f ) ) } ) } , reset : function ( a , b ) { var c = this . chart , d = c . hoverSeries , e = c . hoverPoint , f = c . tooltip , g = f && f . shared ? c . hoverPoints : e ; ( a = a && f && g ) && ra ( g ) [ 0 ] . plotX === u && ( a = ! 1 ) ; if ( a ) f . refresh ( g ) ,
e && ( e . setState ( e . state , ! 0 ) , m ( c . axes , function ( b ) { p ( b . options . crosshair && b . options . crosshair . snap , ! 0 ) ? b . drawCrosshair ( null , a ) : b . hideCrosshair ( ) } ) ) ; else { if ( e ) e . onMouseOut ( ) ; if ( d ) d . onMouseOut ( ) ; f && f . hide ( b ) ; if ( this . _onDocumentMouseMove ) Y ( A , "mousemove" , this . _onDocumentMouseMove ) , this . _onDocumentMouseMove = null ; m ( c . axes , function ( a ) { a . hideCrosshair ( ) } ) ; this . hoverX = null } } , scaleGroups : function ( a , b ) { var c = this . chart , d ; m ( c . series , function ( e ) { d = a || e . getPlotBox ( ) ; e . xAxis && e . xAxis . zoomEnabled && ( e . group . attr ( d ) ,
e . markerGroup && ( e . markerGroup . attr ( d ) , e . markerGroup . clip ( b ? c . clipRect : null ) ) , e . dataLabelsGroup && e . dataLabelsGroup . attr ( d ) ) } ) ; c . clipRect . attr ( b || c . clipBox ) } , dragStart : function ( a ) { var b = this . chart ; b . mouseIsDown = a . type ; b . cancelClick = ! 1 ; b . mouseDownX = this . mouseDownX = a . chartX ; b . mouseDownY = this . mouseDownY = a . chartY } , drag : function ( a ) { var b = this . chart , c = b . options . chart , d = a . chartX , e = a . chartY , f = this . zoomHor , g = this . zoomVert , h = b . plotLeft , i = b . plotTop , j = b . plotWidth , k = b . plotHeight , l , n = this . mouseDownX , o = this . mouseDownY ,
q = c . panKey && a [ c . panKey + "Key" ] ; d < h ? d = h : d > h + j && ( d = h + j ) ; e < i ? e = i : e > i + k && ( e = i + k ) ; this . hasDragged = Math . sqrt ( Math . pow ( n - d , 2 ) + Math . pow ( o - e , 2 ) ) ; if ( this . hasDragged > 10 ) { l = b . isInsidePlot ( n - h , o - i ) ; if ( b . hasCartesianSeries && ( this . zoomX || this . zoomY ) && l && ! q && ! this . selectionMarker ) this . selectionMarker = b . renderer . rect ( h , i , f ? 1 : j , g ? 1 : k , 0 ) . attr ( { fill : c . selectionMarkerFill || "rgba(69,114,167,0.25)" , zIndex : 7 } ) . add ( ) ; this . selectionMarker && f && ( d -= n , this . selectionMarker . attr ( { width : O ( d ) , x : ( d > 0 ? 0 : d ) + n } ) ) ; this . selectionMarker &&
g && ( d = e - o , this . selectionMarker . attr ( { height : O ( d ) , y : ( d > 0 ? 0 : d ) + o } ) ) ; l && ! this . selectionMarker && c . panning && b . pan ( a , c . panning ) } } , drop : function ( a ) { var b = this , c = this . chart , d = this . hasPinched ; if ( this . selectionMarker ) { var e = { xAxis : [ ] , yAxis : [ ] , originalEvent : a . originalEvent || a } , f = this . selectionMarker , g = f . attr ? f . attr ( "x" ) : f . x , h = f . attr ? f . attr ( "y" ) : f . y , i = f . attr ? f . attr ( "width" ) : f . width , j = f . attr ? f . attr ( "height" ) : f . height , k ; if ( this . hasDragged || d ) m ( c . axes , function ( c ) { if ( c . zoomEnabled && s ( c . min ) && ( d || b [ { xAxis : "zoomX" ,
yAxis : "zoomY" } [ c . coll ] ] ) ) { var f = c . horiz , o = a . type === "touchend" ? c . minPixelPadding : 0 , q = c . toValue ( ( f ? g : h ) + o ) , f = c . toValue ( ( f ? g + i : h + j ) - o ) ; e [ c . coll ] . push ( { axis : c , min : I ( q , f ) , max : t ( q , f ) } ) ; k = ! 0 } } ) , k && M ( c , "selection" , e , function ( a ) { c . zoom ( r ( a , d ? { animation : ! 1 } : null ) ) } ) ; this . selectionMarker = this . selectionMarker . destroy ( ) ; d && this . scaleGroups ( ) } if ( c ) F ( c . container , { cursor : c . _cursor } ) , c . cancelClick = this . hasDragged > 10 , c . mouseIsDown = this . hasDragged = this . hasPinched = ! 1 , this . pinchDown = [ ] } , onContainerMouseDown : function ( a ) { a =
this . normalize ( a ) ; a . preventDefault && a . preventDefault ( ) ; this . dragStart ( a ) } , onDocumentMouseUp : function ( a ) { X [ oa ] && X [ oa ] . pointer . drop ( a ) } , onDocumentMouseMove : function ( a ) { var b = this . chart , c = this . chartPosition , a = this . normalize ( a , c ) ; c && ! this . inClass ( a . target , "highcharts-tracker" ) && ! b . isInsidePlot ( a . chartX - b . plotLeft , a . chartY - b . plotTop ) && this . reset ( ) } , onContainerMouseLeave : function ( ) { var a = X [ oa ] ; if ( a ) a . pointer . reset ( ) , a . pointer . chartPosition = null } , onContainerMouseMove : function ( a ) { var b = this . chart ; oa = b . index ;
a = this . normalize ( a ) ; a . returnValue = ! 1 ; b . mouseIsDown === "mousedown" && this . drag ( a ) ; ( this . inClass ( a . target , "highcharts-tracker" ) || b . isInsidePlot ( a . chartX - b . plotLeft , a . chartY - b . plotTop ) ) && ! b . openMenu && this . runPointActions ( a ) } , inClass : function ( a , b ) { for ( var c ; a ; ) { if ( c = L ( a , "class" ) ) if ( c . indexOf ( b ) !== - 1 ) return ! 0 ; else if ( c . indexOf ( "highcharts-container" ) !== - 1 ) return ! 1 ; a = a . parentNode } } , onTrackerMouseOut : function ( a ) { var b = this . chart . hoverSeries , c = ( a = a . relatedTarget || a . toElement ) && a . point && a . point . series ; if ( b &&
! b . options . stickyTracking && ! this . inClass ( a , "highcharts-tooltip" ) && c !== b ) b . onMouseOut ( ) } , onContainerClick : function ( a ) { var b = this . chart , c = b . hoverPoint , d = b . plotLeft , e = b . plotTop , a = this . normalize ( a ) ; a . originalEvent = a ; a . cancelBubble = ! 0 ; b . cancelClick || ( c && this . inClass ( a . target , "highcharts-tracker" ) ? ( M ( c . series , "click" , r ( a , { point : c } ) ) , b . hoverPoint && c . firePointEvent ( "click" , a ) ) : ( r ( a , this . getCoordinates ( a ) ) , b . isInsidePlot ( a . chartX - d , a . chartY - e ) && M ( b , "click" , a ) ) ) } , setDOMEvents : function ( ) { var a = this , b = a . chart . container ;
b . onmousedown = function ( b ) { a . onContainerMouseDown ( b ) } ; b . onmousemove = function ( b ) { a . onContainerMouseMove ( b ) } ; b . onclick = function ( b ) { a . onContainerClick ( b ) } ; N ( b , "mouseleave" , a . onContainerMouseLeave ) ; bb === 1 && N ( A , "mouseup" , a . onDocumentMouseUp ) ; if ( ab ) b . ontouchstart = function ( b ) { a . onContainerTouchStart ( b ) } , b . ontouchmove = function ( b ) { a . onContainerTouchMove ( b ) } , bb === 1 && N ( A , "touchend" , a . onDocumentTouchEnd ) } , destroy : function ( ) { var a ; Y ( this . chart . container , "mouseleave" , this . onContainerMouseLeave ) ; bb || ( Y ( A , "mouseup" ,
this . onDocumentMouseUp ) , Y ( A , "touchend" , this . onDocumentTouchEnd ) ) ; clearInterval ( this . tooltipTimeout ) ; for ( a in this ) this [ a ] = null } } ; r ( w . Pointer . prototype , { pinchTranslate : function ( a , b , c , d , e , f ) { ( this . zoomHor || this . pinchHor ) && this . pinchTranslateDirection ( ! 0 , a , b , c , d , e , f ) ; ( this . zoomVert || this . pinchVert ) && this . pinchTranslateDirection ( ! 1 , a , b , c , d , e , f ) } , pinchTranslateDirection : function ( a , b , c , d , e , f , g , h ) { var i = this . chart , j = a ? "x" : "y" , k = a ? "X" : "Y" , l = "chart" + k , n = a ? "width" : "height" , o = i [ "plot" + ( a ? "Left" : "Top" ) ] , q , p ,
m = h || 1 , C = i . inverted , v = i . bounds [ a ? "h" : "v" ] , s = b . length === 1 , r = b [ 0 ] [ l ] , t = c [ 0 ] [ l ] , u = ! s && b [ 1 ] [ l ] , x = ! s && c [ 1 ] [ l ] , w , c = function ( ) { ! s && O ( r - u ) > 20 && ( m = h || O ( t - x ) / O ( r - u ) ) ; p = ( o - t ) / m + r ; q = i [ "plot" + ( a ? "Width" : "Height" ) ] / m } ; c ( ) ; b = p ; b < v . min ? ( b = v . min , w = ! 0 ) : b + q > v . max && ( b = v . max - q , w = ! 0 ) ; w ? ( t -= 0.8 * ( t - g [ j ] [ 0 ] ) , s || ( x -= 0.8 * ( x - g [ j ] [ 1 ] ) ) , c ( ) ) : g [ j ] = [ t , x ] ; C || ( f [ j ] = p - o , f [ n ] = q ) ; f = C ? 1 / m : m ; e [ n ] = q ; e [ j ] = b ; d [ C ? a ? "scaleY" : "scaleX" : "scale" + k ] = m ; d [ "translate" + k ] = f * o + ( t - f * r ) } , pinch : function ( a ) { var b = this , c = b . chart , d = b . pinchDown , e = a . touches ,
f = e . length , g = b . lastValidTouch , h = b . hasZoom , i = b . selectionMarker , j = { } , k = f === 1 && ( b . inClass ( a . target , "highcharts-tracker" ) && c . runTrackerClick || b . runChartClick ) , l = { } ; h && ! k && a . preventDefault ( ) ; Ua ( e , function ( a ) { return b . normalize ( a ) } ) ; if ( a . type === "touchstart" ) m ( e , function ( a , b ) { d [ b ] = { chartX : a . chartX , chartY : a . chartY } } ) , g . x = [ d [ 0 ] . chartX , d [ 1 ] && d [ 1 ] . chartX ] , g . y = [ d [ 0 ] . chartY , d [ 1 ] && d [ 1 ] . chartY ] , m ( c . axes , function ( a ) { if ( a . zoomEnabled ) { var b = c . bounds [ a . horiz ? "h" : "v" ] , d = a . minPixelPadding , e = a . toPixels ( p ( a . options . min ,
a . dataMin ) ) , f = a . toPixels ( p ( a . options . max , a . dataMax ) ) , g = I ( e , f ) , e = t ( e , f ) ; b . min = I ( a . pos , g - d ) ; b . max = t ( a . pos + a . len , e + d ) } } ) , b . res = ! 0 ; else if ( d . length ) { if ( ! i ) b . selectionMarker = i = r ( { destroy : ma } , c . plotBox ) ; b . pinchTranslate ( d , e , j , i , l , g ) ; b . hasPinched = h ; b . scaleGroups ( j , l ) ; if ( ! h && b . followTouchMove && f === 1 ) this . runPointActions ( b . normalize ( a ) ) ; else if ( b . res ) b . res = ! 1 , this . reset ( ! 1 , 0 ) } } , onContainerTouchStart : function ( a ) { var b = this . chart ; oa = b . index ; a . touches . length === 1 ? ( a = this . normalize ( a ) , b . isInsidePlot ( a . chartX - b . plotLeft ,
a . chartY - b . plotTop ) && ! b . openMenu ? ( this . runPointActions ( a ) , this . pinch ( a ) ) : this . reset ( ) ) : a . touches . length === 2 && this . pinch ( a ) } , onContainerTouchMove : function ( a ) { ( a . touches . length === 1 || a . touches . length === 2 ) && this . pinch ( a ) } , onDocumentTouchEnd : function ( a ) { X [ oa ] && X [ oa ] . pointer . drop ( a ) } } ) ; if ( H . PointerEvent || H . MSPointerEvent ) { var wa = { } , Ab = ! ! H . PointerEvent , Wb = function ( ) { var a , b = [ ] ; b . item = function ( a ) { return this [ a ] } ; for ( a in wa ) wa . hasOwnProperty ( a ) && b . push ( { pageX : wa [ a ] . pageX , pageY : wa [ a ] . pageY , target : wa [ a ] . target } ) ;
return b } , Bb = function ( a , b , c , d ) { a = a . originalEvent || a ; if ( ( a . pointerType === "touch" || a . pointerType === a . MSPOINTER _TYPE _TOUCH ) && X [ oa ] ) d ( a ) , d = X [ oa ] . pointer , d [ b ] ( { type : c , target : a . currentTarget , preventDefault : ma , touches : Wb ( ) } ) } ; r ( Va . prototype , { onContainerPointerDown : function ( a ) { Bb ( a , "onContainerTouchStart" , "touchstart" , function ( a ) { wa [ a . pointerId ] = { pageX : a . pageX , pageY : a . pageY , target : a . currentTarget } } ) } , onContainerPointerMove : function ( a ) { Bb ( a , "onContainerTouchMove" , "touchmove" , function ( a ) { wa [ a . pointerId ] = { pageX : a . pageX ,
pageY : a . pageY } ; if ( ! wa [ a . pointerId ] . target ) wa [ a . pointerId ] . target = a . currentTarget } ) } , onDocumentPointerUp : function ( a ) { Bb ( a , "onDocumentTouchEnd" , "touchend" , function ( a ) { delete wa [ a . pointerId ] } ) } , batchMSEvents : function ( a ) { a ( this . chart . container , Ab ? "pointerdown" : "MSPointerDown" , this . onContainerPointerDown ) ; a ( this . chart . container , Ab ? "pointermove" : "MSPointerMove" , this . onContainerPointerMove ) ; a ( A , Ab ? "pointerup" : "MSPointerUp" , this . onDocumentPointerUp ) } } ) ; cb ( Va . prototype , "init" , function ( a , b , c ) { a . call ( this , b ,
c ) ; this . hasZoom && F ( b . container , { "-ms-touch-action" : R , "touch-action" : R } ) } ) ; cb ( Va . prototype , "setDOMEvents" , function ( a ) { a . apply ( this ) ; ( this . hasZoom || this . followTouchMove ) && this . batchMSEvents ( N ) } ) ; cb ( Va . prototype , "destroy" , function ( a ) { this . batchMSEvents ( Y ) ; a . call ( this ) } ) } var mb = w . Legend = function ( a , b ) { this . init ( a , b ) } ; mb . prototype = { init : function ( a , b ) { var c = this , d = b . itemStyle , e = b . itemMarginTop || 0 ; this . options = b ; if ( b . enabled ) c . itemStyle = d , c . itemHiddenStyle = z ( d , b . itemHiddenStyle ) , c . itemMarginTop = e , c . padding =
d = p ( b . padding , 8 ) , c . initialItemX = d , c . initialItemY = d - 5 , c . maxItemWidth = 0 , c . chart = a , c . itemHeight = 0 , c . symbolWidth = p ( b . symbolWidth , 16 ) , c . pages = [ ] , c . render ( ) , N ( c . chart , "endResize" , function ( ) { c . positionCheckboxes ( ) } ) } , colorizeItem : function ( a , b ) { var c = this . options , d = a . legendItem , e = a . legendLine , f = a . legendSymbol , g = this . itemHiddenStyle . color , c = b ? c . itemStyle . color : g , h = b ? a . legendColor || a . color || "#CCC" : g , g = a . options && a . options . marker , i = { fill : h } , j ; d && d . css ( { fill : c , color : c } ) ; e && e . attr ( { stroke : h } ) ; if ( f ) { if ( g && f . isMarker ) for ( j in i . stroke =
h , g = a . convertAttribs ( g ) , g ) d = g [ j ] , d !== u && ( i [ j ] = d ) ; f . attr ( i ) } } , positionItem : function ( a ) { var b = this . options , c = b . symbolPadding , b = ! b . rtl , d = a . _legendItemPos , e = d [ 0 ] , d = d [ 1 ] , f = a . checkbox ; a . legendGroup && a . legendGroup . translate ( b ? e : this . legendWidth - e - 2 * c - 4 , d ) ; if ( f ) f . x = e , f . y = d } , destroyItem : function ( a ) { var b = a . checkbox ; m ( [ "legendItem" , "legendLine" , "legendSymbol" , "legendGroup" ] , function ( b ) { a [ b ] && ( a [ b ] = a [ b ] . destroy ( ) ) } ) ; b && Ra ( a . checkbox ) } , clearItems : function ( ) { var a = this ; m ( a . getAllItems ( ) , function ( b ) { a . destroyItem ( b ) } ) } ,
destroy : function ( ) { var a = this . group , b = this . box ; if ( b ) this . box = b . destroy ( ) ; if ( a ) this . group = a . destroy ( ) } , positionCheckboxes : function ( a ) { var b = this . group . alignAttr , c , d = this . clipHeight || this . legendHeight ; if ( b ) c = b . translateY , m ( this . allItems , function ( e ) { var f = e . checkbox , g ; f && ( g = c + f . y + ( a || 0 ) + 3 , F ( f , { left : b . translateX + e . checkboxOffset + f . x - 20 + "px" , top : g + "px" , display : g > c - 6 && g < c + d - 6 ? "" : R } ) ) } ) } , renderTitle : function ( ) { var a = this . padding , b = this . options . title , c = 0 ; if ( b . text ) { if ( ! this . title ) this . title = this . chart . renderer . label ( b . text ,
a - 3 , a - 4 , null , null , null , null , null , "legend-title" ) . attr ( { zIndex : 1 } ) . css ( b . style ) . add ( this . group ) ; a = this . title . getBBox ( ) ; c = a . height ; this . offsetWidth = a . width ; this . contentGroup . attr ( { translateY : c } ) } this . titleHeight = c } , renderItem : function ( a ) { var b = this . chart , c = b . renderer , d = this . options , e = d . layout === "horizontal" , f = this . symbolWidth , g = d . symbolPadding , h = this . itemStyle , i = this . itemHiddenStyle , j = this . padding , k = e ? p ( d . itemDistance , 20 ) : 0 , l = ! d . rtl , n = d . width , o = d . itemMarginBottom || 0 , q = this . itemMarginTop , y = this . initialItemX ,
m = a . legendItem , s = a . series && a . series . drawLegendSymbol ? a . series : a , v = s . options , v = this . createCheckboxForItem && v && v . showCheckbox , r = d . useHTML ; if ( ! m ) { a . legendGroup = c . g ( "legend-item" ) . attr ( { zIndex : 1 } ) . add ( this . scrollGroup ) ; a . legendItem = m = c . text ( d . labelFormat ? Ja ( d . labelFormat , a ) : d . labelFormatter . call ( a ) , l ? f + g : - g , this . baseline || 0 , r ) . css ( z ( a . visible ? h : i ) ) . attr ( { align : l ? "left" : "right" , zIndex : 2 } ) . add ( a . legendGroup ) ; if ( ! this . baseline ) this . fontMetrics = c . fontMetrics ( h . fontSize , m ) , this . baseline = this . fontMetrics . f +
3 + q , m . attr ( "y" , this . baseline ) ; s . drawLegendSymbol ( this , a ) ; this . setItemEvents && this . setItemEvents ( a , m , r , h , i ) ; this . colorizeItem ( a , a . visible ) ; v && this . createCheckboxForItem ( a ) } c = m . getBBox ( ) ; f = a . checkboxOffset = d . itemWidth || a . legendItemWidth || f + g + c . width + k + ( v ? 20 : 0 ) ; this . itemHeight = g = x ( a . legendItemHeight || c . height ) ; if ( e && this . itemX - y + f > ( n || b . chartWidth - 2 * j - y - d . x ) ) this . itemX = y , this . itemY += q + this . lastLineHeight + o , this . lastLineHeight = 0 ; this . maxItemWidth = t ( this . maxItemWidth , f ) ; this . lastItemY = q + this . itemY + o ; this . lastLineHeight =
t ( g , this . lastLineHeight ) ; a . _legendItemPos = [ this . itemX , this . itemY ] ; e ? this . itemX += f : ( this . itemY += q + g + o , this . lastLineHeight = g ) ; this . offsetWidth = n || t ( ( e ? this . itemX - y - k : f ) + j , this . offsetWidth ) } , getAllItems : function ( ) { var a = [ ] ; m ( this . chart . series , function ( b ) { var c = b . options ; if ( p ( c . showInLegend , ! s ( c . linkedTo ) ? u : ! 1 , ! 0 ) ) a = a . concat ( b . legendItems || ( c . legendType === "point" ? b . data : b ) ) } ) ; return a } , adjustMargins : function ( a , b ) { var c = this . chart , d = this . options , e = d . align [ 0 ] + d . verticalAlign [ 0 ] + d . layout [ 0 ] ; this . display &&
! d . floating && m ( [ /(lth|ct|rth)/ , /(rtv|rm|rbv)/ , /(rbh|cb|lbh)/ , /(lbv|lm|ltv)/ ] , function ( f , g ) { f . test ( e ) && ! s ( a [ g ] ) && ( c [ ib [ g ] ] = t ( c [ ib [ g ] ] , c . legend [ ( g + 1 ) % 2 ? "legendHeight" : "legendWidth" ] + [ 1 , - 1 , - 1 , 1 ] [ g ] * d [ g % 2 ? "x" : "y" ] + p ( d . margin , 12 ) + b [ g ] ) ) } ) } , render : function ( ) { var a = this , b = a . chart , c = b . renderer , d = a . group , e , f , g , h , i = a . box , j = a . options , k = a . padding , l = j . borderWidth , n = j . backgroundColor ; a . itemX = a . initialItemX ; a . itemY = a . initialItemY ; a . offsetWidth = 0 ; a . lastItemY = 0 ; if ( ! d ) a . group = d = c . g ( "legend" ) . attr ( { zIndex : 7 } ) . add ( ) ,
a . contentGroup = c . g ( ) . attr ( { zIndex : 1 } ) . add ( d ) , a . scrollGroup = c . g ( ) . add ( a . contentGroup ) ; a . renderTitle ( ) ; e = a . getAllItems ( ) ; qb ( e , function ( a , b ) { return ( a . options && a . options . legendIndex || 0 ) - ( b . options && b . options . legendIndex || 0 ) } ) ; j . reversed && e . reverse ( ) ; a . allItems = e ; a . display = f = ! ! e . length ; a . lastLineHeight = 0 ; m ( e , function ( b ) { a . renderItem ( b ) } ) ; g = ( j . width || a . offsetWidth ) + k ; h = a . lastItemY + a . lastLineHeight + a . titleHeight ; h = a . handleOverflow ( h ) ; h += k ; if ( l || n ) { if ( i ) { if ( g > 0 && h > 0 ) i [ i . isNew ? "attr" : "animate" ] ( i . crisp ( { width : g ,
height : h } ) ) , i . isNew = ! 1 } else a . box = i = c . rect ( 0 , 0 , g , h , j . borderRadius , l || 0 ) . attr ( { stroke : j . borderColor , "stroke-width" : l || 0 , fill : n || R } ) . add ( d ) . shadow ( j . shadow ) , i . isNew = ! 0 ; i [ f ? "show" : "hide" ] ( ) } a . legendWidth = g ; a . legendHeight = h ; m ( e , function ( b ) { a . positionItem ( b ) } ) ; f && d . align ( r ( { width : g , height : h } , j ) , ! 0 , "spacingBox" ) ; b . isResizing || this . positionCheckboxes ( ) } , handleOverflow : function ( a ) { var b = this , c = this . chart , d = c . renderer , e = this . options , f = e . y , f = c . spacingBox . height + ( e . verticalAlign === "top" ? - f : f ) - this . padding , g =
e . maxHeight , h , i = this . clipRect , j = e . navigation , k = p ( j . animation , ! 0 ) , l = j . arrowSize || 12 , n = this . nav , o = this . pages , q , y = this . allItems ; e . layout === "horizontal" && ( f /= 2 ) ; g && ( f = I ( f , g ) ) ; o . length = 0 ; if ( a > f && ! e . useHTML ) { this . clipHeight = h = t ( f - 20 - this . titleHeight - this . padding , 0 ) ; this . currentPage = p ( this . currentPage , 1 ) ; this . fullHeight = a ; m ( y , function ( a , b ) { var c = a . _legendItemPos [ 1 ] , d = x ( a . legendItem . getBBox ( ) . height ) , e = o . length ; if ( ! e || c - o [ e - 1 ] > h && ( q || c ) !== o [ e - 1 ] ) o . push ( q || c ) , e ++ ; b === y . length - 1 && c + d - o [ e - 1 ] > h && o . push ( c ) ; c !==
q && ( q = c ) } ) ; if ( ! i ) i = b . clipRect = d . clipRect ( 0 , this . padding , 9999 , 0 ) , b . contentGroup . clip ( i ) ; i . attr ( { height : h } ) ; if ( ! n ) this . nav = n = d . g ( ) . attr ( { zIndex : 1 } ) . add ( this . group ) , this . up = d . symbol ( "triangle" , 0 , 0 , l , l ) . on ( "click" , function ( ) { b . scroll ( - 1 , k ) } ) . add ( n ) , this . pager = d . text ( "" , 15 , 10 ) . css ( j . style ) . add ( n ) , this . down = d . symbol ( "triangle-down" , 0 , 0 , l , l ) . on ( "click" , function ( ) { b . scroll ( 1 , k ) } ) . add ( n ) ; b . scroll ( 0 ) ; a = f } else if ( n ) i . attr ( { height : c . chartHeight } ) , n . hide ( ) , this . scrollGroup . attr ( { translateY : 1 } ) , this . clipHeight =
0 ; return a } , scroll : function ( a , b ) { var c = this . pages , d = c . length , e = this . currentPage + a , f = this . clipHeight , g = this . options . navigation , h = g . activeColor , g = g . inactiveColor , i = this . pager , j = this . padding ; e > d && ( e = d ) ; if ( e > 0 ) b !== u && Sa ( b , this . chart ) , this . nav . attr ( { translateX : j , translateY : f + this . padding + 7 + this . titleHeight , visibility : "visible" } ) , this . up . attr ( { fill : e === 1 ? g : h } ) . css ( { cursor : e === 1 ? "default" : "pointer" } ) , i . attr ( { text : e + "/" + d } ) , this . down . attr ( { x : 18 + this . pager . getBBox ( ) . width , fill : e === d ? g : h } ) . css ( { cursor : e ===
d ? "default" : "pointer" } ) , c = - c [ e - 1 ] + this . initialItemY , this . scrollGroup . animate ( { translateY : c } ) , this . currentPage = e , this . positionCheckboxes ( c ) } } ; Na = w . LegendSymbolMixin = { drawRectangle : function ( a , b ) { var c = a . options . symbolHeight || a . fontMetrics . f ; b . legendSymbol = this . chart . renderer . rect ( 0 , a . baseline - c + 1 , a . symbolWidth , c , a . options . symbolRadius || 0 ) . attr ( { zIndex : 3 } ) . add ( b . legendGroup ) } , drawLineMarker : function ( a ) { var b = this . options , c = b . marker , d ; d = a . symbolWidth ; var e = this . chart . renderer , f = this . legendGroup , a = a . baseline -
x ( a . fontMetrics . b * 0.3 ) , g ; if ( b . lineWidth ) { g = { "stroke-width" : b . lineWidth } ; if ( b . dashStyle ) g . dashstyle = b . dashStyle ; this . legendLine = e . path ( [ "M" , 0 , a , "L" , d , a ] ) . attr ( g ) . add ( f ) } if ( c && c . enabled !== ! 1 ) b = c . radius , this . legendSymbol = d = e . symbol ( this . symbol , d / 2 - b , a - b , 2 * b , 2 * b ) . add ( f ) , d . isMarker = ! 0 } } ; ( /Trident\/7\.0/ . test ( Ba ) || La ) && cb ( mb . prototype , "positionItem" , function ( a , b ) { var c = this , d = function ( ) { b . _legendItemPos && a . call ( c , b ) } ; d ( ) ; setTimeout ( d ) } ) ; D = w . Chart = function ( ) { this . init . apply ( this , arguments ) } ; D . prototype =
{ callbacks : [ ] , init : function ( a , b ) { var c , d = a . series ; a . series = null ; c = z ( P , a ) ; c . series = a . series = d ; this . userOptions = a ; d = c . chart ; this . margin = this . splashArray ( "margin" , d ) ; this . spacing = this . splashArray ( "spacing" , d ) ; var e = d . events ; this . bounds = { h : { } , v : { } } ; this . callback = b ; this . isResizing = 0 ; this . options = c ; this . axes = [ ] ; this . series = [ ] ; this . hasCartesianSeries = d . showAxes ; var f = this , g ; f . index = X . length ; X . push ( f ) ; bb ++ ; d . reflow !== ! 1 && N ( f , "load" , function ( ) { f . initReflow ( ) } ) ; if ( e ) for ( g in e ) N ( f , g , e [ g ] ) ; f . xAxis = [ ] ; f . yAxis =
[ ] ; f . animation = ea ? ! 1 : p ( d . animation , ! 0 ) ; f . pointCount = f . colorCounter = f . symbolCounter = 0 ; f . firstRender ( ) } , initSeries : function ( a ) { var b = this . options . chart ; ( b = J [ a . type || b . type || b . defaultSeriesType ] ) || ka ( 17 , ! 0 ) ; b = new b ; b . init ( this , a ) ; return b } , isInsidePlot : function ( a , b , c ) { var d = c ? b : a , a = c ? a : b ; return d >= 0 && d <= this . plotWidth && a >= 0 && a <= this . plotHeight } , redraw : function ( a ) { var b = this . axes , c = this . series , d = this . pointer , e = this . legend , f = this . isDirtyLegend , g , h , i = this . hasCartesianSeries , j = this . isDirtyBox , k = c . length ,
l = k , n = this . renderer , o = n . isHidden ( ) , q = [ ] ; Sa ( a , this ) ; o && this . cloneRenderTo ( ) ; for ( this . layOutTitles ( ) ; l -- ; ) if ( a = c [ l ] , a . options . stacking && ( g = ! 0 , a . isDirty ) ) { h = ! 0 ; break } if ( h ) for ( l = k ; l -- ; ) if ( a = c [ l ] , a . options . stacking ) a . isDirty = ! 0 ; m ( c , function ( a ) { a . isDirty && a . options . legendType === "point" && ( f = ! 0 ) } ) ; if ( f && e . options . enabled ) e . render ( ) , this . isDirtyLegend = ! 1 ; g && this . getStacks ( ) ; if ( i && ! this . isResizing ) this . maxTicks = null , m ( b , function ( a ) { a . setScale ( ) } ) ; this . getMargins ( ) ; i && ( m ( b , function ( a ) { a . isDirty && ( j = ! 0 ) } ) , m ( b ,
function ( a ) { if ( a . isDirtyExtremes ) a . isDirtyExtremes = ! 1 , q . push ( function ( ) { M ( a , "afterSetExtremes" , r ( a . eventArgs , a . getExtremes ( ) ) ) ; delete a . eventArgs } ) ; ( j || g ) && a . redraw ( ) } ) ) ; j && this . drawChartBox ( ) ; m ( c , function ( a ) { a . isDirty && a . visible && ( ! a . isCartesian || a . xAxis ) && a . redraw ( ) } ) ; d && d . reset ( ! 0 ) ; n . draw ( ) ; M ( this , "redraw" ) ; o && this . cloneRenderTo ( ! 0 ) ; m ( q , function ( a ) { a . call ( ) } ) } , get : function ( a ) { var b = this . axes , c = this . series , d , e ; for ( d = 0 ; d < b . length ; d ++ ) if ( b [ d ] . options . id === a ) return b [ d ] ; for ( d = 0 ; d < c . length ; d ++ ) if ( c [ d ] . options . id ===
a ) return c [ d ] ; for ( d = 0 ; d < c . length ; d ++ ) { e = c [ d ] . points || [ ] ; for ( b = 0 ; b < e . length ; b ++ ) if ( e [ b ] . id === a ) return e [ b ] } return null } , getAxes : function ( ) { var a = this , b = this . options , c = b . xAxis = ra ( b . xAxis || { } ) , b = b . yAxis = ra ( b . yAxis || { } ) ; m ( c , function ( a , b ) { a . index = b ; a . isX = ! 0 } ) ; m ( b , function ( a , b ) { a . index = b } ) ; c = c . concat ( b ) ; m ( c , function ( b ) { new va ( a , b ) } ) } , getSelectedPoints : function ( ) { var a = [ ] ; m ( this . series , function ( b ) { a = a . concat ( kb ( b . points || [ ] , function ( a ) { return a . selected } ) ) } ) ; return a } , getSelectedSeries : function ( ) { return kb ( this . series ,
function ( a ) { return a . selected } ) } , getStacks : function ( ) { var a = this ; m ( a . yAxis , function ( a ) { if ( a . stacks && a . hasVisibleSeries ) a . oldStacks = a . stacks } ) ; m ( a . series , function ( b ) { if ( b . options . stacking && ( b . visible === ! 0 || a . options . chart . ignoreHiddenSeries === ! 1 ) ) b . stackKey = b . type + p ( b . options . stack , "" ) } ) } , setTitle : function ( a , b , c ) { var g ; var d = this , e = d . options , f ; f = e . title = z ( e . title , a ) ; g = e . subtitle = z ( e . subtitle , b ) , e = g ; m ( [ [ "title" , a , f ] , [ "subtitle" , b , e ] ] , function ( a ) { var b = a [ 0 ] , c = d [ b ] , e = a [ 1 ] , a = a [ 2 ] ; c && e && ( d [ b ] = c = c . destroy ( ) ) ;
a && a . text && ! c && ( d [ b ] = d . renderer . text ( a . text , 0 , 0 , a . useHTML ) . attr ( { align : a . align , "class" : "highcharts-" + b , zIndex : a . zIndex || 4 } ) . css ( a . style ) . add ( ) ) } ) ; d . layOutTitles ( c ) } , layOutTitles : function ( a ) { var b = 0 , c = this . title , d = this . subtitle , e = this . options , f = e . title , e = e . subtitle , g = this . renderer , h = this . spacingBox . width - 44 ; if ( c && ( c . css ( { width : ( f . width || h ) + "px" } ) . align ( r ( { y : g . fontMetrics ( f . style . fontSize , c ) . b - 3 } , f ) , ! 1 , "spacingBox" ) , ! f . floating && ! f . verticalAlign ) ) b = c . getBBox ( ) . height ; d && ( d . css ( { width : ( e . width || h ) + "px" } ) . align ( r ( { y : b +
( f . margin - 13 ) + g . fontMetrics ( f . style . fontSize , d ) . b } , e ) , ! 1 , "spacingBox" ) , ! e . floating && ! e . verticalAlign && ( b = sa ( b + d . getBBox ( ) . height ) ) ) ; c = this . titleOffset !== b ; this . titleOffset = b ; if ( ! this . isDirtyBox && c ) this . isDirtyBox = c , this . hasRendered && p ( a , ! 0 ) && this . isDirtyBox && this . redraw ( ) } , getChartSize : function ( ) { var a = this . options . chart , b = a . width , a = a . height , c = this . renderToClone || this . renderTo ; if ( ! s ( b ) ) this . containerWidth = jb ( c , "width" ) ; if ( ! s ( a ) ) this . containerHeight = jb ( c , "height" ) ; this . chartWidth = t ( 0 , b || this . containerWidth ||
600 ) ; this . chartHeight = t ( 0 , p ( a , this . containerHeight > 19 ? this . containerHeight : 400 ) ) } , cloneRenderTo : function ( a ) { var b = this . renderToClone , c = this . container ; a ? b && ( this . renderTo . appendChild ( c ) , Ra ( b ) , delete this . renderToClone ) : ( c && c . parentNode === this . renderTo && this . renderTo . removeChild ( c ) , this . renderToClone = b = this . renderTo . cloneNode ( 0 ) , F ( b , { position : "absolute" , top : "-9999px" , display : "block" } ) , b . style . setProperty && b . style . setProperty ( "display" , "block" , "important" ) , A . body . appendChild ( b ) , c && b . appendChild ( c ) ) } ,
getContainer : function ( ) { var a , b = this . options . chart , c , d , e ; this . renderTo = a = b . renderTo ; e = "highcharts-" + yb ++ ; if ( Da ( a ) ) this . renderTo = a = A . getElementById ( a ) ; a || ka ( 13 , ! 0 ) ; c = B ( L ( a , "data-highcharts-chart" ) ) ; ! isNaN ( c ) && X [ c ] && X [ c ] . hasRendered && X [ c ] . destroy ( ) ; L ( a , "data-highcharts-chart" , this . index ) ; a . innerHTML = "" ; ! b . skipClone && ! a . offsetWidth && this . cloneRenderTo ( ) ; this . getChartSize ( ) ; c = this . chartWidth ; d = this . chartHeight ; this . container = a = Z ( Ka , { className : "highcharts-container" + ( b . className ? " " + b . className : "" ) , id : e } ,
r ( { position : "relative" , overflow : "hidden" , width : c + "px" , height : d + "px" , textAlign : "left" , lineHeight : "normal" , zIndex : 0 , "-webkit-tap-highlight-color" : "rgba(0,0,0,0)" } , b . style ) , this . renderToClone || a ) ; this . _cursor = a . style . cursor ; this . renderer = b . forExport ? new ta ( a , c , d , b . style , ! 0 ) : new $a ( a , c , d , b . style ) ; ea && this . renderer . create ( this , a , c , d ) ; this . renderer . chartIndex = this . index } , getMargins : function ( a ) { var b = this . spacing , c = this . margin , d = this . titleOffset ; this . resetMargins ( ) ; if ( d && ! s ( c [ 0 ] ) ) this . plotTop = t ( this . plotTop ,
d + this . options . title . margin + b [ 0 ] ) ; this . legend . adjustMargins ( c , b ) ; this . extraBottomMargin && ( this . marginBottom += this . extraBottomMargin ) ; this . extraTopMargin && ( this . plotTop += this . extraTopMargin ) ; a || this . getAxisMargins ( ) } , getAxisMargins : function ( ) { var a = this , b = a . axisOffset = [ 0 , 0 , 0 , 0 ] , c = a . margin ; a . hasCartesianSeries && m ( a . axes , function ( a ) { a . getOffset ( ) } ) ; m ( ib , function ( d , e ) { s ( c [ e ] ) || ( a [ d ] += b [ e ] ) } ) ; a . setChartSize ( ) } , reflow : function ( a ) { var b = this , c = b . options . chart , d = b . renderTo , e = c . width || jb ( d , "width" ) , f = c . height ||
jb ( d , "height" ) , c = a ? a . target : H , d = function ( ) { if ( b . container ) b . setSize ( e , f , ! 1 ) , b . hasUserSize = null } ; if ( ! b . hasUserSize && ! b . isPrinting && e && f && ( c === H || c === A ) ) { if ( e !== b . containerWidth || f !== b . containerHeight ) clearTimeout ( b . reflowTimeout ) , a ? b . reflowTimeout = setTimeout ( d , 100 ) : d ( ) ; b . containerWidth = e ; b . containerHeight = f } } , initReflow : function ( ) { var a = this , b = function ( b ) { a . reflow ( b ) } ; N ( H , "resize" , b ) ; N ( a , "destroy" , function ( ) { Y ( H , "resize" , b ) } ) } , setSize : function ( a , b , c ) { var d = this , e , f , g ; d . isResizing += 1 ; g = function ( ) { d &&
M ( d , "endResize" , null , function ( ) { d . isResizing -= 1 } ) } ; Sa ( c , d ) ; d . oldChartHeight = d . chartHeight ; d . oldChartWidth = d . chartWidth ; if ( s ( a ) ) d . chartWidth = e = t ( 0 , x ( a ) ) , d . hasUserSize = ! ! e ; if ( s ( b ) ) d . chartHeight = f = t ( 0 , x ( b ) ) ; ( za ? lb : F ) ( d . container , { width : e + "px" , height : f + "px" } , za ) ; d . setChartSize ( ! 0 ) ; d . renderer . setSize ( e , f , c ) ; d . maxTicks = null ; m ( d . axes , function ( a ) { a . isDirty = ! 0 ; a . setScale ( ) } ) ; m ( d . series , function ( a ) { a . isDirty = ! 0 } ) ; d . isDirtyLegend = ! 0 ; d . isDirtyBox = ! 0 ; d . layOutTitles ( ) ; d . getMargins ( ) ; d . redraw ( c ) ; d . oldChartHeight =
null ; M ( d , "resize" ) ; za === ! 1 ? g ( ) : setTimeout ( g , za && za . duration || 500 ) } , setChartSize : function ( a ) { var b = this . inverted , c = this . renderer , d = this . chartWidth , e = this . chartHeight , f = this . options . chart , g = this . spacing , h = this . clipOffset , i , j , k , l ; this . plotLeft = i = x ( this . plotLeft ) ; this . plotTop = j = x ( this . plotTop ) ; this . plotWidth = k = t ( 0 , x ( d - i - this . marginRight ) ) ; this . plotHeight = l = t ( 0 , x ( e - j - this . marginBottom ) ) ; this . plotSizeX = b ? l : k ; this . plotSizeY = b ? k : l ; this . plotBorderWidth = f . plotBorderWidth || 0 ; this . spacingBox = c . spacingBox = { x : g [ 3 ] ,
y : g [ 0 ] , width : d - g [ 3 ] - g [ 1 ] , height : e - g [ 0 ] - g [ 2 ] } ; this . plotBox = c . plotBox = { x : i , y : j , width : k , height : l } ; d = 2 * U ( this . plotBorderWidth / 2 ) ; b = sa ( t ( d , h [ 3 ] ) / 2 ) ; c = sa ( t ( d , h [ 0 ] ) / 2 ) ; this . clipBox = { x : b , y : c , width : U ( this . plotSizeX - t ( d , h [ 1 ] ) / 2 - b ) , height : t ( 0 , U ( this . plotSizeY - t ( d , h [ 2 ] ) / 2 - c ) ) } ; a || m ( this . axes , function ( a ) { a . setAxisSize ( ) ; a . setAxisTranslation ( ) } ) } , resetMargins : function ( ) { var a = this ; m ( ib , function ( b , c ) { a [ b ] = p ( a . margin [ c ] , a . spacing [ c ] ) } ) ; a . axisOffset = [ 0 , 0 , 0 , 0 ] ; a . clipOffset = [ 0 , 0 , 0 , 0 ] } , drawChartBox : function ( ) { var a =
this . options . chart , b = this . renderer , c = this . chartWidth , d = this . chartHeight , e = this . chartBackground , f = this . plotBackground , g = this . plotBorder , h = this . plotBGImage , i = a . borderWidth || 0 , j = a . backgroundColor , k = a . plotBackgroundColor , l = a . plotBackgroundImage , n = a . plotBorderWidth || 0 , o , q = this . plotLeft , p = this . plotTop , m = this . plotWidth , s = this . plotHeight , v = this . plotBox , r = this . clipRect , t = this . clipBox ; o = i + ( a . shadow ? 8 : 0 ) ; if ( i || j ) if ( e ) e . animate ( e . crisp ( { width : c - o , height : d - o } ) ) ; else { e = { fill : j || R } ; if ( i ) e . stroke = a . borderColor , e [ "stroke-width" ] =
i ; this . chartBackground = b . rect ( o / 2 , o / 2 , c - o , d - o , a . borderRadius , i ) . attr ( e ) . addClass ( "highcharts-background" ) . add ( ) . shadow ( a . shadow ) } if ( k ) f ? f . animate ( v ) : this . plotBackground = b . rect ( q , p , m , s , 0 ) . attr ( { fill : k } ) . add ( ) . shadow ( a . plotShadow ) ; if ( l ) h ? h . animate ( v ) : this . plotBGImage = b . image ( l , q , p , m , s ) . add ( ) ; r ? r . animate ( { width : t . width , height : t . height } ) : this . clipRect = b . clipRect ( t ) ; if ( n ) g ? g . animate ( g . crisp ( { x : q , y : p , width : m , height : s , strokeWidth : - n } ) ) : this . plotBorder = b . rect ( q , p , m , s , 0 , - n ) . attr ( { stroke : a . plotBorderColor ,
"stroke-width" : n , fill : R , zIndex : 1 } ) . add ( ) ; this . isDirtyBox = ! 1 } , propFromSeries : function ( ) { var a = this , b = a . options . chart , c , d = a . options . series , e , f ; m ( [ "inverted" , "angular" , "polar" ] , function ( g ) { c = J [ b . type || b . defaultSeriesType ] ; f = a [ g ] || b [ g ] || c && c . prototype [ g ] ; for ( e = d && d . length ; ! f && e -- ; ) ( c = J [ d [ e ] . type ] ) && c . prototype [ g ] && ( f = ! 0 ) ; a [ g ] = f } ) } , linkSeries : function ( ) { var a = this , b = a . series ; m ( b , function ( a ) { a . linkedSeries . length = 0 } ) ; m ( b , function ( b ) { var d = b . options . linkedTo ; if ( Da ( d ) && ( d = d === ":previous" ? a . series [ b . index -
1 ] : a . get ( d ) ) ) d . linkedSeries . push ( b ) , b . linkedParent = d } ) } , renderSeries : function ( ) { m ( this . series , function ( a ) { a . translate ( ) ; a . render ( ) } ) } , renderLabels : function ( ) { var a = this , b = a . options . labels ; b . items && m ( b . items , function ( c ) { var d = r ( b . style , c . style ) , e = B ( d . left ) + a . plotLeft , f = B ( d . top ) + a . plotTop + 12 ; delete d . left ; delete d . top ; a . renderer . text ( c . html , e , f ) . attr ( { zIndex : 2 } ) . css ( d ) . add ( ) } ) } , render : function ( ) { var a = this . axes , b = this . renderer , c = this . options , d , e , f , g ; this . setTitle ( ) ; this . legend = new mb ( this , c . legend ) ;
this . getStacks ( ) ; this . getMargins ( ! 0 ) ; this . setChartSize ( ) ; d = this . plotWidth ; e = this . plotHeight -= 13 ; m ( a , function ( a ) { a . setScale ( ) } ) ; this . getAxisMargins ( ) ; f = d / this . plotWidth > 1.1 ; g = e / this . plotHeight > 1.1 ; if ( f || g ) this . maxTicks = null , m ( a , function ( a ) { ( a . horiz && f || ! a . horiz && g ) && a . setTickInterval ( ! 0 ) } ) , this . getMargins ( ) ; this . drawChartBox ( ) ; this . hasCartesianSeries && m ( a , function ( a ) { a . render ( ) } ) ; if ( ! this . seriesGroup ) this . seriesGroup = b . g ( "series-group" ) . attr ( { zIndex : 3 } ) . add ( ) ; this . renderSeries ( ) ; this . renderLabels ( ) ;
this . showCredits ( c . credits ) ; this . hasRendered = ! 0 } , showCredits : function ( a ) { if ( a . enabled && ! this . credits ) this . credits = this . renderer . text ( a . text , 0 , 0 ) . on ( "click" , function ( ) { if ( a . href ) location . href = a . href } ) . attr ( { align : a . position . align , zIndex : 8 } ) . css ( a . style ) . add ( ) . align ( a . position ) } , destroy : function ( ) { var a = this , b = a . axes , c = a . series , d = a . container , e , f = d && d . parentNode ; M ( a , "destroy" ) ; X [ a . index ] = u ; bb -- ; a . renderTo . removeAttribute ( "data-highcharts-chart" ) ; Y ( a ) ; for ( e = b . length ; e -- ; ) b [ e ] = b [ e ] . destroy ( ) ; for ( e = c . length ; e -- ; ) c [ e ] =
c [ e ] . destroy ( ) ; m ( "title,subtitle,chartBackground,plotBackground,plotBGImage,plotBorder,seriesGroup,clipRect,credits,pointer,scroller,rangeSelector,legend,resetZoomButton,tooltip,renderer" . split ( "," ) , function ( b ) { var c = a [ b ] ; c && c . destroy && ( a [ b ] = c . destroy ( ) ) } ) ; if ( d ) d . innerHTML = "" , Y ( d ) , f && Ra ( d ) ; for ( e in a ) delete a [ e ] } , isReadyToRender : function ( ) { var a = this ; return ! ba && H == H . top && A . readyState !== "complete" || ea && ! H . canvg ? ( ea ? Lb . push ( function ( ) { a . firstRender ( ) } , a . options . global . canvasToolsURL ) : A . attachEvent ( "onreadystatechange" ,
function ( ) { A . detachEvent ( "onreadystatechange" , a . firstRender ) ; A . readyState === "complete" && a . firstRender ( ) } ) , ! 1 ) : ! 0 } , firstRender : function ( ) { var a = this , b = a . options , c = a . callback ; if ( a . isReadyToRender ( ) ) { a . getContainer ( ) ; M ( a , "init" ) ; a . resetMargins ( ) ; a . setChartSize ( ) ; a . propFromSeries ( ) ; a . getAxes ( ) ; m ( b . series || [ ] , function ( b ) { a . initSeries ( b ) } ) ; a . linkSeries ( ) ; M ( a , "beforeRender" ) ; if ( w . Pointer ) a . pointer = new Va ( a , b ) ; a . render ( ) ; a . renderer . draw ( ) ; c && c . apply ( a , [ a ] ) ; m ( a . callbacks , function ( b ) { a . index !== u && b . apply ( a ,
[ a ] ) } ) ; M ( a , "load" ) ; a . cloneRenderTo ( ! 0 ) } } , splashArray : function ( a , b ) { var c = b [ a ] , c = ca ( c ) ? c : [ c , c , c , c ] ; return [ p ( b [ a + "Top" ] , c [ 0 ] ) , p ( b [ a + "Right" ] , c [ 1 ] ) , p ( b [ a + "Bottom" ] , c [ 2 ] ) , p ( b [ a + "Left" ] , c [ 3 ] ) ] } } ; var Xb = w . CenteredSeriesMixin = { getCenter : function ( ) { var a = this . options , b = this . chart , c = 2 * ( a . slicedOffset || 0 ) , d = b . plotWidth - 2 * c , b = b . plotHeight - 2 * c , e = a . center , e = [ p ( e [ 0 ] , "50%" ) , p ( e [ 1 ] , "50%" ) , a . size || "100%" , a . innerSize || 0 ] , f = I ( d , b ) , g , h , i ; for ( h = 0 ; h < 4 ; ++ h ) i = e [ h ] , g = /%$/ . test ( i ) , a = h < 2 || h === 2 && g , e [ h ] = ( g ? [ d , b , f , e [ 2 ] ] [ h ] * B ( i ) /
100 : B ( i ) ) + ( a ? c : 0 ) ; return e } } , Ga = function ( ) { } ; Ga . prototype = { init : function ( a , b , c ) { this . series = a ; this . color = a . color ; this . applyOptions ( b , c ) ; this . pointAttr = { } ; if ( a . options . colorByPoint && ( b = a . options . colors || a . chart . options . colors , this . color = this . color || b [ a . colorCounter ++ ] , a . colorCounter === b . length ) ) a . colorCounter = 0 ; a . chart . pointCount ++ ; return this } , applyOptions : function ( a , b ) { var c = this . series , d = c . options . pointValKey || c . pointValKey , a = Ga . prototype . optionsToObject . call ( this , a ) ; r ( this , a ) ; this . options = this . options ?
r ( this . options , a ) : a ; if ( d ) this . y = this [ d ] ; if ( this . x === u && c ) this . x = b === u ? c . autoIncrement ( ) : b ; return this } , optionsToObject : function ( a ) { var b = { } , c = this . series , d = c . options . keys , e = d || c . pointArrayMap || [ "y" ] , f = e . length , g = 0 , h = 0 ; if ( typeof a === "number" || a === null ) b [ e [ 0 ] ] = a ; else if ( Ha ( a ) ) { if ( ! d && a . length > f ) { c = typeof a [ 0 ] ; if ( c === "string" ) b . name = a [ 0 ] ; else if ( c === "number" ) b . x = a [ 0 ] ; g ++ } for ( ; h < f ; ) b [ e [ h ++ ] ] = a [ g ++ ] } else if ( typeof a === "object" ) { b = a ; if ( a . dataLabels ) c . _hasPointLabels = ! 0 ; if ( a . marker ) c . _hasPointMarkers = ! 0 } return b } ,
destroy : function ( ) { var a = this . series . chart , b = a . hoverPoints , c ; a . pointCount -- ; if ( b && ( this . setState ( ) , ia ( b , this ) , ! b . length ) ) a . hoverPoints = null ; if ( this === a . hoverPoint ) this . onMouseOut ( ) ; if ( this . graphic || this . dataLabel ) Y ( this ) , this . destroyElements ( ) ; this . legendItem && a . legend . destroyItem ( this ) ; for ( c in this ) this [ c ] = null } , destroyElements : function ( ) { for ( var a = "graphic,dataLabel,dataLabelUpper,group,connector,shadowGroup" . split ( "," ) , b , c = 6 ; c -- ; ) b = a [ c ] , this [ b ] && ( this [ b ] = this [ b ] . destroy ( ) ) } , getLabelConfig : function ( ) { return { x : this . category ,
y : this . y , key : this . name || this . category , series : this . series , point : this , percentage : this . percentage , total : this . total || this . stackTotal } } , tooltipFormatter : function ( a ) { var b = this . series , c = b . tooltipOptions , d = p ( c . valueDecimals , "" ) , e = c . valuePrefix || "" , f = c . valueSuffix || "" ; m ( b . pointArrayMap || [ "y" ] , function ( b ) { b = "{point." + b ; if ( e || f ) a = a . replace ( b + "}" , e + b + "}" + f ) ; a = a . replace ( b + "}" , b + ":,." + d + "f}" ) } ) ; return Ja ( a , { point : this , series : this . series } ) } , firePointEvent : function ( a , b , c ) { var d = this , e = this . series . options ; ( e . point . events [ a ] ||
d . options && d . options . events && d . options . events [ a ] ) && this . importEvents ( ) ; a === "click" && e . allowPointSelect && ( c = function ( a ) { d . select ( null , a . ctrlKey || a . metaKey || a . shiftKey ) } ) ; M ( this , a , b , c ) } } ; var Q = w . Series = function ( ) { } ; Q . prototype = { isCartesian : ! 0 , type : "line" , pointClass : Ga , sorted : ! 0 , requireSorting : ! 0 , pointAttrToOptions : { stroke : "lineColor" , "stroke-width" : "lineWidth" , fill : "fillColor" , r : "radius" } , axisTypes : [ "xAxis" , "yAxis" ] , colorCounter : 0 , parallelArrays : [ "x" , "y" ] , init : function ( a , b ) { var c = this , d , e , f = a . series ,
g = function ( a , b ) { return p ( a . options . index , a . _i ) - p ( b . options . index , b . _i ) } ; c . chart = a ; c . options = b = c . setOptions ( b ) ; c . linkedSeries = [ ] ; c . bindAxes ( ) ; r ( c , { name : b . name , state : "" , pointAttr : { } , visible : b . visible !== ! 1 , selected : b . selected === ! 0 } ) ; if ( ea ) b . animation = ! 1 ; e = b . events ; for ( d in e ) N ( c , d , e [ d ] ) ; if ( e && e . click || b . point && b . point . events && b . point . events . click || b . allowPointSelect ) a . runTrackerClick = ! 0 ; c . getColor ( ) ; c . getSymbol ( ) ; m ( c . parallelArrays , function ( a ) { c [ a + "Data" ] = [ ] } ) ; c . setData ( b . data , ! 1 ) ; if ( c . isCartesian ) a . hasCartesianSeries =
! 0 ; f . push ( c ) ; c . _i = f . length - 1 ; qb ( f , g ) ; this . yAxis && qb ( this . yAxis . series , g ) ; m ( f , function ( a , b ) { a . index = b ; a . name = a . name || "Series " + ( b + 1 ) } ) } , bindAxes : function ( ) { var a = this , b = a . options , c = a . chart , d ; m ( a . axisTypes || [ ] , function ( e ) { m ( c [ e ] , function ( c ) { d = c . options ; if ( b [ e ] === d . index || b [ e ] !== u && b [ e ] === d . id || b [ e ] === u && d . index === 0 ) c . series . push ( a ) , a [ e ] = c , c . isDirty = ! 0 } ) ; ! a [ e ] && a . optionalAxis !== e && ka ( 18 , ! 0 ) } ) } , updateParallelArrays : function ( a , b ) { var c = a . series , d = arguments ; m ( c . parallelArrays , typeof b === "number" ? function ( d ) { var f =
d === "y" && c . toYData ? c . toYData ( a ) : a [ d ] ; c [ d + "Data" ] [ b ] = f } : function ( a ) { Array . prototype [ b ] . apply ( c [ a + "Data" ] , Array . prototype . slice . call ( d , 2 ) ) } ) } , autoIncrement : function ( ) { var a = this . options , b = this . xIncrement , c , d = a . pointIntervalUnit , b = p ( b , a . pointStart , 0 ) ; this . pointInterval = c = p ( this . pointInterval , a . pointInterval , 1 ) ; if ( d === "month" || d === "year" ) a = new Aa ( b ) , a = d === "month" ? + a [ vb ] ( a [ Ya ] ( ) + c ) : + a [ wb ] ( a [ Za ] ( ) + c ) , c = a - b ; this . xIncrement = b + c ; return b } , getSegments : function ( ) { var a = - 1 , b = [ ] , c , d = this . points , e = d . length ; if ( e ) if ( this . options . connectNulls ) { for ( c =
e ; c -- ; ) d [ c ] . y === null && d . splice ( c , 1 ) ; d . length && ( b = [ d ] ) } else m ( d , function ( c , g ) { c . y === null ? ( g > a + 1 && b . push ( d . slice ( a + 1 , g ) ) , a = g ) : g === e - 1 && b . push ( d . slice ( a + 1 , g + 1 ) ) } ) ; this . segments = b } , setOptions : function ( a ) { var b = this . chart , c = b . options . plotOptions , b = b . userOptions || { } , d = b . plotOptions || { } , e = c [ this . type ] ; this . userOptions = a ; c = z ( e , c . series , a ) ; this . tooltipOptions = z ( P . tooltip , P . plotOptions [ this . type ] . tooltip , b . tooltip , d . series && d . series . tooltip , d [ this . type ] && d [ this . type ] . tooltip , a . tooltip ) ; e . marker === null && delete c . marker ;
this . zoneAxis = c . zoneAxis ; a = this . zones = ( c . zones || [ ] ) . slice ( ) ; if ( ( c . negativeColor || c . negativeFillColor ) && ! c . zones ) a . push ( { value : c [ this . zoneAxis + "Threshold" ] || c . threshold || 0 , color : c . negativeColor , fillColor : c . negativeFillColor } ) ; a . length && s ( a [ a . length - 1 ] . value ) && a . push ( { color : this . color , fillColor : this . fillColor } ) ; return c } , getCyclic : function ( a , b , c ) { var d = this . userOptions , e = "_" + a + "Index" , f = a + "Counter" ; b || ( s ( d [ e ] ) ? b = d [ e ] : ( d [ e ] = b = this . chart [ f ] % c . length , this . chart [ f ] += 1 ) , b = c [ b ] ) ; this [ a ] = b } , getColor : function ( ) { this . options . colorByPoint ||
this . getCyclic ( "color" , this . options . color || aa [ this . type ] . color , this . chart . options . colors ) } , getSymbol : function ( ) { var a = this . options . marker ; this . getCyclic ( "symbol" , a . symbol , this . chart . options . symbols ) ; if ( /^url/ . test ( this . symbol ) ) a . radius = 0 } , drawLegendSymbol : Na . drawLineMarker , setData : function ( a , b , c , d ) { var e = this , f = e . points , g = f && f . length || 0 , h , i = e . options , j = e . chart , k = null , l = e . xAxis , n = l && ! ! l . categories , o = i . turboThreshold , q = this . xData , y = this . yData , s = ( h = e . pointArrayMap ) && h . length , a = a || [ ] ; h = a . length ; b = p ( b ,
! 0 ) ; if ( d !== ! 1 && h && g === h && ! e . cropped && ! e . hasGroupedData && e . visible ) m ( a , function ( a , b ) { f [ b ] . update ( a , ! 1 , null , ! 1 ) } ) ; else { e . xIncrement = null ; e . pointRange = n ? 1 : i . pointRange ; e . colorCounter = 0 ; m ( this . parallelArrays , function ( a ) { e [ a + "Data" ] . length = 0 } ) ; if ( o && h > o ) { for ( c = 0 ; k === null && c < h ; ) k = a [ c ] , c ++ ; if ( qa ( k ) ) { n = p ( i . pointStart , 0 ) ; i = p ( i . pointInterval , 1 ) ; for ( c = 0 ; c < h ; c ++ ) q [ c ] = n , y [ c ] = a [ c ] , n += i ; e . xIncrement = n } else if ( Ha ( k ) ) if ( s ) for ( c = 0 ; c < h ; c ++ ) i = a [ c ] , q [ c ] = i [ 0 ] , y [ c ] = i . slice ( 1 , s + 1 ) ; else for ( c = 0 ; c < h ; c ++ ) i = a [ c ] , q [ c ] = i [ 0 ] , y [ c ] =
i [ 1 ] ; else ka ( 12 ) } else for ( c = 0 ; c < h ; c ++ ) if ( a [ c ] !== u && ( i = { series : e } , e . pointClass . prototype . applyOptions . apply ( i , [ a [ c ] ] ) , e . updateParallelArrays ( i , c ) , n && i . name ) ) l . names [ i . x ] = i . name ; Da ( y [ 0 ] ) && ka ( 14 , ! 0 ) ; e . data = [ ] ; e . options . data = a ; for ( c = g ; c -- ; ) f [ c ] && f [ c ] . destroy && f [ c ] . destroy ( ) ; if ( l ) l . minRange = l . userMinRange ; e . isDirty = e . isDirtyData = j . isDirtyBox = ! 0 ; c = ! 1 } b && j . redraw ( c ) } , processData : function ( a ) { var b = this . xData , c = this . yData , d = b . length , e ; e = 0 ; var f , g , h = this . xAxis , i , j = this . options ; i = j . cropThreshold ; var k = this . isCartesian ,
l , n ; if ( k && ! this . isDirty && ! h . isDirty && ! this . yAxis . isDirty && ! a ) return ! 1 ; if ( h ) a = h . getExtremes ( ) , l = a . min , n = a . max ; if ( k && this . sorted && ( ! i || d > i || this . forceCrop ) ) if ( b [ d - 1 ] < l || b [ 0 ] > n ) b = [ ] , c = [ ] ; else if ( b [ 0 ] < l || b [ d - 1 ] > n ) e = this . cropData ( this . xData , this . yData , l , n ) , b = e . xData , c = e . yData , e = e . start , f = ! 0 ; for ( i = b . length - 1 ; i >= 0 ; i -- ) d = b [ i ] - b [ i - 1 ] , d > 0 && ( g === u || d < g ) ? g = d : d < 0 && this . requireSorting && ka ( 15 ) ; this . cropped = f ; this . cropStart = e ; this . processedXData = b ; this . processedYData = c ; if ( j . pointRange === null ) this . pointRange = g || 1 ;
this . closestPointRange = g } , cropData : function ( a , b , c , d ) { var e = a . length , f = 0 , g = e , h = p ( this . cropShoulder , 1 ) , i ; for ( i = 0 ; i < e ; i ++ ) if ( a [ i ] >= c ) { f = t ( 0 , i - h ) ; break } for ( ; i < e ; i ++ ) if ( a [ i ] > d ) { g = i + h ; break } return { xData : a . slice ( f , g ) , yData : b . slice ( f , g ) , start : f , end : g } } , generatePoints : function ( ) { var a = this . options . data , b = this . data , c , d = this . processedXData , e = this . processedYData , f = this . pointClass , g = d . length , h = this . cropStart || 0 , i , j = this . hasGroupedData , k , l = [ ] , n ; if ( ! b && ! j ) b = [ ] , b . length = a . length , b = this . data = b ; for ( n = 0 ; n < g ; n ++ ) i = h +
n , j ? l [ n ] = ( new f ) . init ( this , [ d [ n ] ] . concat ( ra ( e [ n ] ) ) ) : ( b [ i ] ? k = b [ i ] : a [ i ] !== u && ( b [ i ] = k = ( new f ) . init ( this , a [ i ] , d [ n ] ) ) , l [ n ] = k ) , l [ n ] . index = i ; if ( b && ( g !== ( c = b . length ) || j ) ) for ( n = 0 ; n < c ; n ++ ) if ( n === h && ! j && ( n += g ) , b [ n ] ) b [ n ] . destroyElements ( ) , b [ n ] . plotX = u ; this . data = b ; this . points = l } , getExtremes : function ( a ) { var b = this . yAxis , c = this . processedXData , d , e = [ ] , f = 0 ; d = this . xAxis . getExtremes ( ) ; var g = d . min , h = d . max , i , j , k , l , a = a || this . stackedYData || this . processedYData ; d = a . length ; for ( l = 0 ; l < d ; l ++ ) if ( j = c [ l ] , k = a [ l ] , i = k !== null && k !== u &&
( ! b . isLog || k . length || k > 0 ) , j = this . getExtremesFromAll || this . cropped || ( c [ l + 1 ] || j ) >= g && ( c [ l - 1 ] || j ) <= h , i && j ) if ( i = k . length ) for ( ; i -- ; ) k [ i ] !== null && ( e [ f ++ ] = k [ i ] ) ; else e [ f ++ ] = k ; this . dataMin = Pa ( e ) ; this . dataMax = Fa ( e ) } , translate : function ( ) { this . processedXData || this . processData ( ) ; this . generatePoints ( ) ; for ( var a = this . options , b = a . stacking , c = this . xAxis , d = c . categories , e = this . yAxis , f = this . points , g = f . length , h = ! ! this . modifyValue , i = a . pointPlacement , j = i === "between" || qa ( i ) , k = a . threshold , l , n , o , q = Number . MAX _VALUE , a = 0 ; a < g ; a ++ ) { var m =
f [ a ] , r = m . x , C = m . y ; n = m . low ; var v = b && e . stacks [ ( this . negStacks && C < k ? "-" : "" ) + this . stackKey ] ; if ( e . isLog && C !== null && C <= 0 ) m . y = C = null , ka ( 10 ) ; m . plotX = l = c . translate ( r , 0 , 0 , 0 , 1 , i , this . type === "flags" ) ; if ( b && this . visible && v && v [ r ] ) v = v [ r ] , C = v . points [ this . index + "," + a ] , n = C [ 0 ] , C = C [ 1 ] , n === 0 && ( n = p ( k , e . min ) ) , e . isLog && n <= 0 && ( n = null ) , m . total = m . stackTotal = v . total , m . percentage = v . total && m . y / v . total * 100 , m . stackY = C , v . setOffset ( this . pointXOffset || 0 , this . barW || 0 ) ; m . yBottom = s ( n ) ? e . translate ( n , 0 , 1 , 0 , 1 ) : null ; h && ( C = this . modifyValue ( C ,
m ) ) ; m . plotY = n = typeof C === "number" && C !== Infinity ? I ( t ( - 1E5 , e . translate ( C , 0 , 1 , 0 , 1 ) ) , 1E5 ) : u ; m . isInside = n !== u && n >= 0 && n <= e . len && l >= 0 && l <= c . len ; m . clientX = j ? c . translate ( r , 0 , 0 , 0 , 1 ) : l ; m . negative = m . y < ( k || 0 ) ; m . category = d && d [ m . x ] !== u ? d [ m . x ] : m . x ; a && ( q = I ( q , O ( l - o ) ) ) ; o = l } this . closestPointRangePx = q ; this . getSegments ( ) } , setClip : function ( a ) { var b = this . chart , c = b . renderer , d = b . inverted , e = this . clipBox , f = e || b . clipBox , g = this . sharedClipKey || [ "_sharedClip" , a && a . duration , a && a . easing , f . height ] . join ( "," ) , h = b [ g ] , i = b [ g + "m" ] ; if ( ! h ) { if ( a ) f . width =
0 , b [ g + "m" ] = i = c . clipRect ( - 99 , d ? - b . plotLeft : - b . plotTop , 99 , d ? b . chartWidth : b . chartHeight ) ; b [ g ] = h = c . clipRect ( f ) } a && ( h . count += 1 ) ; if ( this . options . clip !== ! 1 ) this . group . clip ( a || e ? h : b . clipRect ) , this . markerGroup . clip ( i ) , this . sharedClipKey = g ; a || ( h . count -= 1 , h . count <= 0 && g && b [ g ] && ( e || ( b [ g ] = b [ g ] . destroy ( ) ) , b [ g + "m" ] && ( b [ g + "m" ] = b [ g + "m" ] . destroy ( ) ) ) ) } , animate : function ( a ) { var b = this . chart , c = this . options . animation , d ; if ( c && ! ca ( c ) ) c = aa [ this . type ] . animation ; a ? this . setClip ( c ) : ( d = this . sharedClipKey , ( a = b [ d ] ) && a . animate ( { width : b . plotSizeX } ,
c ) , b [ d + "m" ] && b [ d + "m" ] . animate ( { width : b . plotSizeX + 99 } , c ) , this . animate = null ) } , afterAnimate : function ( ) { this . setClip ( ) ; M ( this , "afterAnimate" ) } , drawPoints : function ( ) { var a , b = this . points , c = this . chart , d , e , f , g , h , i , j , k , l = this . options . marker , n = this . pointAttr [ "" ] , o , q , m , s = this . markerGroup , t = p ( l . enabled , this . xAxis . isRadial , this . closestPointRangePx > 2 * l . radius ) ; if ( l . enabled !== ! 1 || this . _hasPointMarkers ) for ( f = b . length ; f -- ; ) if ( g = b [ f ] , d = U ( g . plotX ) , e = g . plotY , k = g . graphic , o = g . marker || { } , q = ! ! g . marker , a = t && o . enabled === u ||
o . enabled , m = g . isInside , a && e !== u && ! isNaN ( e ) && g . y !== null ) if ( a = g . pointAttr [ g . selected ? "select" : "" ] || n , h = a . r , i = p ( o . symbol , this . symbol ) , j = i . indexOf ( "url" ) === 0 , k ) k [ m ? "show" : "hide" ] ( ! 0 ) . animate ( r ( { x : d - h , y : e - h } , k . symbolName ? { width : 2 * h , height : 2 * h } : { } ) ) ; else { if ( m && ( h > 0 || j ) ) g . graphic = c . renderer . symbol ( i , d - h , e - h , 2 * h , 2 * h , q ? o : l ) . attr ( a ) . add ( s ) } else if ( k ) g . graphic = k . destroy ( ) } , convertAttribs : function ( a , b , c , d ) { var e = this . pointAttrToOptions , f , g , h = { } , a = a || { } , b = b || { } , c = c || { } , d = d || { } ; for ( f in e ) g = e [ f ] , h [ f ] = p ( a [ g ] , b [ f ] ,
c [ f ] , d [ f ] ) ; return h } , getAttribs : function ( ) { var a = this , b = a . options , c = aa [ a . type ] . marker ? b . marker : b , d = c . states , e = d . hover , f , g = a . color , h = a . options . negativeColor ; f = { stroke : g , fill : g } ; var i = a . points || [ ] , j , k = [ ] , l , n = a . pointAttrToOptions ; l = a . hasPointSpecificOptions ; var o = c . lineColor , q = c . fillColor ; j = b . turboThreshold ; var p = a . zones , t = a . zoneAxis || "y" , C ; b . marker ? ( e . radius = e . radius || c . radius + e . radiusPlus , e . lineWidth = e . lineWidth || c . lineWidth + e . lineWidthPlus ) : ( e . color = e . color || na ( e . color || g ) . brighten ( e . brightness ) . get ( ) ,
e . negativeColor = e . negativeColor || na ( e . negativeColor || h ) . brighten ( e . brightness ) . get ( ) ) ; k [ "" ] = a . convertAttribs ( c , f ) ; m ( [ "hover" , "select" ] , function ( b ) { k [ b ] = a . convertAttribs ( d [ b ] , k [ "" ] ) } ) ; a . pointAttr = k ; g = i . length ; if ( ! j || g < j || l ) for ( ; g -- ; ) { j = i [ g ] ; if ( ( c = j . options && j . options . marker || j . options ) && c . enabled === ! 1 ) c . radius = 0 ; if ( p . length ) { l = 0 ; for ( f = p [ l ] ; j [ t ] >= f . value ; ) f = p [ ++ l ] ; j . color = j . fillColor = f . color } l = b . colorByPoint || j . color ; if ( j . options ) for ( C in n ) s ( c [ n [ C ] ] ) && ( l = ! 0 ) ; if ( l ) { c = c || { } ; l = [ ] ; d = c . states || { } ; f = d . hover =
d . hover || { } ; if ( ! b . marker ) f . color = f . color || ! j . options . color && e [ j . negative && h ? "negativeColor" : "color" ] || na ( j . color ) . brighten ( f . brightness || e . brightness ) . get ( ) ; f = { color : j . color } ; if ( ! q ) f . fillColor = j . color ; if ( ! o ) f . lineColor = j . color ; c . hasOwnProperty ( "color" ) && ! c . color && delete c . color ; l [ "" ] = a . convertAttribs ( r ( f , c ) , k [ "" ] ) ; l . hover = a . convertAttribs ( d . hover , k . hover , l [ "" ] ) ; l . select = a . convertAttribs ( d . select , k . select , l [ "" ] ) } else l = k ; j . pointAttr = l } } , destroy : function ( ) { var a = this , b = a . chart , c = /AppleWebKit\/533/ . test ( Ba ) ,
d , e = a . data || [ ] , f , g , h ; M ( a , "destroy" ) ; Y ( a ) ; m ( a . axisTypes || [ ] , function ( b ) { if ( h = a [ b ] ) ia ( h . series , a ) , h . isDirty = h . forceRedraw = ! 0 } ) ; a . legendItem && a . chart . legend . destroyItem ( a ) ; for ( d = e . length ; d -- ; ) ( f = e [ d ] ) && f . destroy && f . destroy ( ) ; a . points = null ; clearTimeout ( a . animationTimeout ) ; for ( g in a ) a [ g ] instanceof K && ! a [ g ] . survive && ( d = c && g === "group" ? "hide" : "destroy" , a [ g ] [ d ] ( ) ) ; if ( b . hoverSeries === a ) b . hoverSeries = null ; ia ( b . series , a ) ; for ( g in a ) delete a [ g ] } , getSegmentPath : function ( a ) { var b = this , c = [ ] , d = b . options . step ; m ( a ,
function ( e , f ) { var g = e . plotX , h = e . plotY , i ; b . getPointSpline ? c . push . apply ( c , b . getPointSpline ( a , e , f ) ) : ( c . push ( f ? "L" : "M" ) , d && f && ( i = a [ f - 1 ] , d === "right" ? c . push ( i . plotX , h ) : d === "center" ? c . push ( ( i . plotX + g ) / 2 , i . plotY , ( i . plotX + g ) / 2 , h ) : c . push ( g , i . plotY ) ) , c . push ( e . plotX , e . plotY ) ) } ) ; return c } , getGraphPath : function ( ) { var a = this , b = [ ] , c , d = [ ] ; m ( a . segments , function ( e ) { c = a . getSegmentPath ( e ) ; e . length > 1 ? b = b . concat ( c ) : d . push ( e [ 0 ] ) } ) ; a . singlePoints = d ; return a . graphPath = b } , drawGraph : function ( ) { var a = this , b = this . options , c = [ [ "graph" ,
b . lineColor || this . color , b . dashStyle ] ] , d = b . lineWidth , e = b . linecap !== "square" , f = this . getGraphPath ( ) , g = this . fillGraph && this . color || R ; m ( this . zones , function ( d , e ) { c . push ( [ "zoneGraph" + e , d . color || a . color , d . dashStyle || b . dashStyle ] ) } ) ; m ( c , function ( c , i ) { var j = c [ 0 ] , k = a [ j ] ; if ( k ) db ( k ) , k . animate ( { d : f } ) ; else if ( ( d || g ) && f . length ) k = { stroke : c [ 1 ] , "stroke-width" : d , fill : g , zIndex : 1 } , c [ 2 ] ? k . dashstyle = c [ 2 ] : e && ( k [ "stroke-linecap" ] = k [ "stroke-linejoin" ] = "round" ) , a [ j ] = a . chart . renderer . path ( f ) . attr ( k ) . add ( a . group ) . shadow ( i < 2 &&
b . shadow ) } ) } , applyZones : function ( ) { var a = this , b = this . chart , c = b . renderer , d = this . zones , e , f , g = this . clips || [ ] , h , i = this . graph , j = this . area , k = t ( b . chartWidth , b . chartHeight ) , l = this [ ( this . zoneAxis || "y" ) + "Axis" ] , n = l . reversed , o = l . horiz , q = ! 1 ; if ( d . length && ( i || j ) ) i && i . hide ( ) , j && j . hide ( ) , m ( d , function ( d , m ) { e = p ( f , n ? o ? b . plotWidth : 0 : o ? 0 : l . toPixels ( l . min ) ) ; f = x ( l . toPixels ( p ( d . value , l . max ) , ! 0 ) ) ; e = l . isXAxis ? e > f ? f : e : e < f ? f : e ; q && ( e = f = l . toPixels ( l . max ) ) ; if ( l . isXAxis ) { if ( h = { x : n ? f : e , y : 0 , width : Math . abs ( e - f ) , height : k } , ! o ) h . x = b . plotHeight -
h . x } else if ( h = { x : 0 , y : n ? e : f , width : k , height : Math . abs ( e - f ) } , o ) h . y = b . plotWidth - h . y ; b . inverted && c . isVML && ( h = l . isXAxis ? { x : 0 , y : n ? e : f , height : h . width , width : b . chartWidth } : { x : h . y - b . plotLeft - b . spacingBox . x , y : 0 , width : h . height , height : b . chartHeight } ) ; g [ m ] ? g [ m ] . animate ( h ) : ( g [ m ] = c . clipRect ( h ) , i && a [ "zoneGraph" + m ] . clip ( g [ m ] ) , j && a [ "zoneArea" + m ] . clip ( g [ m ] ) ) ; q = d . value > l . max } ) , this . clips = g } , invertGroups : function ( ) { function a ( ) { var a = { width : b . yAxis . len , height : b . xAxis . len } ; m ( [ "group" , "markerGroup" ] , function ( c ) { b [ c ] && b [ c ] . attr ( a ) . invert ( ) } ) }
var b = this , c = b . chart ; if ( b . xAxis ) N ( c , "resize" , a ) , N ( b , "destroy" , function ( ) { Y ( c , "resize" , a ) } ) , a ( ) , b . invertGroups = a } , plotGroup : function ( a , b , c , d , e ) { var f = this [ a ] , g = ! f ; g && ( this [ a ] = f = this . chart . renderer . g ( b ) . attr ( { visibility : c , zIndex : d || 0.1 } ) . add ( e ) ) ; f [ g ? "attr" : "animate" ] ( this . getPlotBox ( ) ) ; return f } , getPlotBox : function ( ) { var a = this . chart , b = this . xAxis , c = this . yAxis ; if ( a . inverted ) b = c , c = this . xAxis ; return { translateX : b ? b . left : a . plotLeft , translateY : c ? c . top : a . plotTop , scaleX : 1 , scaleY : 1 } } , render : function ( ) { var a =
this , b = a . chart , c , d = a . options , e = ( c = d . animation ) && ! ! a . animate && b . renderer . isSVG && p ( c . duration , 500 ) || 0 , f = a . visible ? "visible" : "hidden" , g = d . zIndex , h = a . hasRendered , i = b . seriesGroup ; c = a . plotGroup ( "group" , "series" , f , g , i ) ; a . markerGroup = a . plotGroup ( "markerGroup" , "markers" , f , g , i ) ; e && a . animate ( ! 0 ) ; a . getAttribs ( ) ; c . inverted = a . isCartesian ? b . inverted : ! 1 ; a . drawGraph && ( a . drawGraph ( ) , a . applyZones ( ) ) ; m ( a . points , function ( a ) { a . redraw && a . redraw ( ) } ) ; a . drawDataLabels && a . drawDataLabels ( ) ; a . visible && a . drawPoints ( ) ; a . drawTracker &&
a . options . enableMouseTracking !== ! 1 && a . drawTracker ( ) ; b . inverted && a . invertGroups ( ) ; d . clip !== ! 1 && ! a . sharedClipKey && ! h && c . clip ( b . clipRect ) ; e && a . animate ( ) ; if ( ! h ) e ? a . animationTimeout = setTimeout ( function ( ) { a . afterAnimate ( ) } , e ) : a . afterAnimate ( ) ; a . isDirty = a . isDirtyData = ! 1 ; a . hasRendered = ! 0 } , redraw : function ( ) { var a = this . chart , b = this . isDirtyData , c = this . isDirty , d = this . group , e = this . xAxis , f = this . yAxis ; d && ( a . inverted && d . attr ( { width : a . plotWidth , height : a . plotHeight } ) , d . animate ( { translateX : p ( e && e . left , a . plotLeft ) , translateY : p ( f &&
f . top , a . plotTop ) } ) ) ; this . translate ( ) ; this . render ( ) ; b && M ( this , "updatedData" ) ; ( c || b ) && delete this . kdTree } , kdDimensions : 1 , kdTree : null , kdAxisArray : [ "clientX" , "plotY" ] , kdComparer : "distX" , searchPoint : function ( a ) { var b = this . xAxis , c = this . yAxis , d = this . chart . inverted ; return this . searchKDTree ( { clientX : d ? b . len - a . chartY + b . pos : a . chartX - b . pos , plotY : d ? c . len - a . chartX + c . pos : a . chartY - c . pos } ) } , buildKDTree : function ( ) { function a ( b , d , g ) { var h , i ; if ( i = b && b . length ) return h = c . kdAxisArray [ d % g ] , b . sort ( function ( a , b ) { return a [ h ] -
b [ h ] } ) , i = Math . floor ( i / 2 ) , { point : b [ i ] , left : a ( b . slice ( 0 , i ) , d + 1 , g ) , right : a ( b . slice ( i + 1 ) , d + 1 , g ) } } function b ( ) { var b = kb ( c . points , function ( a ) { return a . y !== null } ) ; c . kdTree = a ( b , d , d ) } var c = this , d = c . kdDimensions ; delete c . kdTree ; c . options . kdSync ? b ( ) : setTimeout ( b ) } , searchKDTree : function ( a ) { function b ( a , h , i , j ) { var k = h . point , l = c . kdAxisArray [ i % j ] , n , o = k ; n = s ( a [ e ] ) && s ( k [ e ] ) ? Math . pow ( a [ e ] - k [ e ] , 2 ) : null ; var m = s ( a [ f ] ) && s ( k [ f ] ) ? Math . pow ( a [ f ] - k [ f ] , 2 ) : null , p = ( n || 0 ) + ( m || 0 ) ; n = { distX : s ( n ) ? Math . sqrt ( n ) : Number . MAX _VALUE , distY : s ( m ) ?
Math . sqrt ( m ) : Number . MAX _VALUE , distR : s ( p ) ? Math . sqrt ( p ) : Number . MAX _VALUE } ; k . dist = n ; l = a [ l ] - k [ l ] ; n = l < 0 ? "left" : "right" ; h [ n ] && ( n = b ( a , h [ n ] , i + 1 , j ) , o = n . dist [ d ] < o . dist [ d ] ? n : k , k = l < 0 ? "right" : "left" , h [ k ] && Math . sqrt ( l * l ) < o . dist [ d ] && ( a = b ( a , h [ k ] , i + 1 , j ) , o = a . dist [ d ] < o . dist [ d ] ? a : o ) ) ; return o } var c = this , d = this . kdComparer , e = this . kdAxisArray [ 0 ] , f = this . kdAxisArray [ 1 ] ; this . kdTree || this . buildKDTree ( ) ; if ( this . kdTree ) return b ( a , this . kdTree , this . kdDimensions , this . kdDimensions ) } } ; Hb . prototype = { destroy : function ( ) { Qa ( this , this . axis ) } ,
render : function ( a ) { var b = this . options , c = b . format , c = c ? Ja ( c , this ) : b . formatter . call ( this ) ; this . label ? this . label . attr ( { text : c , visibility : "hidden" } ) : this . label = this . axis . chart . renderer . text ( c , null , null , b . useHTML ) . css ( b . style ) . attr ( { align : this . textAlign , rotation : b . rotation , visibility : "hidden" } ) . add ( a ) } , setOffset : function ( a , b ) { var c = this . axis , d = c . chart , e = d . inverted , f = c . reversed , f = this . isNegative && ! f || ! this . isNegative && f , g = c . translate ( c . usePercentage ? 100 : this . total , 0 , 0 , 0 , 1 ) , c = c . translate ( 0 ) , c = O ( g - c ) , h = d . xAxis [ 0 ] . translate ( this . x ) +
a , i = d . plotHeight , f = { x : e ? f ? g : g - c : h , y : e ? i - h - b : f ? i - g - c : i - g , width : e ? c : b , height : e ? b : c } ; if ( e = this . label ) e . align ( this . alignOptions , null , f ) , f = e . alignAttr , e [ this . options . crop === ! 1 || d . isInsidePlot ( f . x , f . y ) ? "show" : "hide" ] ( ! 0 ) } } ; va . prototype . buildStacks = function ( ) { var a = this . series , b = p ( this . options . reversedStacks , ! 0 ) , c = a . length ; if ( ! this . isXAxis ) { for ( this . usePercentage = ! 1 ; c -- ; ) a [ b ? c : a . length - c - 1 ] . setStackedPoints ( ) ; if ( this . usePercentage ) for ( c = 0 ; c < a . length ; c ++ ) a [ c ] . setPercentStacks ( ) } } ; va . prototype . renderStackTotals =
function ( ) { var a = this . chart , b = a . renderer , c = this . stacks , d , e , f = this . stackTotalGroup ; if ( ! f ) this . stackTotalGroup = f = b . g ( "stack-labels" ) . attr ( { visibility : "visible" , zIndex : 6 } ) . add ( ) ; f . translate ( a . plotLeft , a . plotTop ) ; for ( d in c ) for ( e in a = c [ d ] , a ) a [ e ] . render ( f ) } ; Q . prototype . setStackedPoints = function ( ) { if ( this . options . stacking && ! ( this . visible !== ! 0 && this . chart . options . chart . ignoreHiddenSeries !== ! 1 ) ) { var a = this . processedXData , b = this . processedYData , c = [ ] , d = b . length , e = this . options , f = e . threshold , g = e . stack , e = e . stacking ,
h = this . stackKey , i = "-" + h , j = this . negStacks , k = this . yAxis , l = k . stacks , n = k . oldStacks , o , m , p , s , r , v ; for ( s = 0 ; s < d ; s ++ ) { r = a [ s ] ; v = b [ s ] ; p = this . index + "," + s ; m = ( o = j && v < f ) ? i : h ; l [ m ] || ( l [ m ] = { } ) ; if ( ! l [ m ] [ r ] ) n [ m ] && n [ m ] [ r ] ? ( l [ m ] [ r ] = n [ m ] [ r ] , l [ m ] [ r ] . total = null ) : l [ m ] [ r ] = new Hb ( k , k . options . stackLabels , o , r , g ) ; m = l [ m ] [ r ] ; m . points [ p ] = [ m . cum || 0 ] ; e === "percent" ? ( o = o ? h : i , j && l [ o ] && l [ o ] [ r ] ? ( o = l [ o ] [ r ] , m . total = o . total = t ( o . total , m . total ) + O ( v ) || 0 ) : m . total = da ( m . total + ( O ( v ) || 0 ) ) ) : m . total = da ( m . total + ( v || 0 ) ) ; m . cum = ( m . cum || 0 ) + ( v || 0 ) ; m . points [ p ] . push ( m . cum ) ;
c [ s ] = m . cum } if ( e === "percent" ) k . usePercentage = ! 0 ; this . stackedYData = c ; k . oldStacks = { } } } ; Q . prototype . setPercentStacks = function ( ) { var a = this , b = a . stackKey , c = a . yAxis . stacks , d = a . processedXData ; m ( [ b , "-" + b ] , function ( b ) { var e ; for ( var f = d . length , g , h ; f -- ; ) if ( g = d [ f ] , e = ( h = c [ b ] && c [ b ] [ g ] ) && h . points [ a . index + "," + f ] , g = e ) h = h . total ? 100 / h . total : 0 , g [ 0 ] = da ( g [ 0 ] * h ) , g [ 1 ] = da ( g [ 1 ] * h ) , a . stackedYData [ f ] = g [ 1 ] } ) } ; r ( D . prototype , { addSeries : function ( a , b , c ) { var d , e = this ; a && ( b = p ( b , ! 0 ) , M ( e , "addSeries" , { options : a } , function ( ) { d = e . initSeries ( a ) ;
e . isDirtyLegend = ! 0 ; e . linkSeries ( ) ; b && e . redraw ( c ) } ) ) ; return d } , addAxis : function ( a , b , c , d ) { var e = b ? "xAxis" : "yAxis" , f = this . options ; new va ( this , z ( a , { index : this [ e ] . length , isX : b } ) ) ; f [ e ] = ra ( f [ e ] || { } ) ; f [ e ] . push ( a ) ; p ( c , ! 0 ) && this . redraw ( d ) } , showLoading : function ( a ) { var b = this , c = b . options , d = b . loadingDiv , e = c . loading , f = function ( ) { d && F ( d , { left : b . plotLeft + "px" , top : b . plotTop + "px" , width : b . plotWidth + "px" , height : b . plotHeight + "px" } ) } ; if ( ! d ) b . loadingDiv = d = Z ( Ka , { className : "highcharts-loading" } , r ( e . style , { zIndex : 10 , display : R } ) ,
b . container ) , b . loadingSpan = Z ( "span" , null , e . labelStyle , d ) , N ( b , "redraw" , f ) ; b . loadingSpan . innerHTML = a || c . lang . loading ; if ( ! b . loadingShown ) F ( d , { opacity : 0 , display : "" } ) , lb ( d , { opacity : e . style . opacity } , { duration : e . showDuration || 0 } ) , b . loadingShown = ! 0 ; f ( ) } , hideLoading : function ( ) { var a = this . options , b = this . loadingDiv ; b && lb ( b , { opacity : 0 } , { duration : a . loading . hideDuration || 100 , complete : function ( ) { F ( b , { display : R } ) } } ) ; this . loadingShown = ! 1 } } ) ; r ( Ga . prototype , { update : function ( a , b , c , d ) { function e ( ) { f . applyOptions ( a ) ; if ( ca ( a ) &&
! Ha ( a ) ) f . redraw = function ( ) { if ( h ) a && a . marker && a . marker . symbol ? f . graphic = h . destroy ( ) : h . attr ( f . pointAttr [ f . state || "" ] ) ; if ( a && a . dataLabels && f . dataLabel ) f . dataLabel = f . dataLabel . destroy ( ) ; f . redraw = null } ; i = f . index ; g . updateParallelArrays ( f , i ) ; if ( l && f . name ) l [ f . x ] = f . name ; k . data [ i ] = f . options ; g . isDirty = g . isDirtyData = ! 0 ; if ( ! g . fixedBox && g . hasCartesianSeries ) j . isDirtyBox = ! 0 ; j . legend . display && k . legendType === "point" && ( g . updateTotals ( ) , j . legend . clearItems ( ) ) ; b && j . redraw ( c ) } var f = this , g = f . series , h = f . graphic , i , j = g . chart ,
k = g . options , l = g . xAxis && g . xAxis . names , b = p ( b , ! 0 ) ; d === ! 1 ? e ( ) : f . firePointEvent ( "update" , { options : a } , e ) } , remove : function ( a , b ) { this . series . removePoint ( Ma ( this , this . series . data ) , a , b ) } } ) ; r ( Q . prototype , { addPoint : function ( a , b , c , d ) { var e = this , f = e . options , g = e . data , h = e . graph , i = e . area , j = e . chart , k = e . xAxis && e . xAxis . names , l = h && h . shift || 0 , n = [ "graph" , "area" ] , h = f . data , o , q = e . xData ; Sa ( d , j ) ; if ( c ) { for ( d = e . zones . length ; d -- ; ) n . push ( "zoneGraph" + d , "zoneArea" + d ) ; m ( n , function ( a ) { if ( e [ a ] ) e [ a ] . shift = l + 1 } ) } if ( i ) i . isArea = ! 0 ; b = p ( b ,
! 0 ) ; i = { series : e } ; e . pointClass . prototype . applyOptions . apply ( i , [ a ] ) ; n = i . x ; d = q . length ; if ( e . requireSorting && n < q [ d - 1 ] ) for ( o = ! 0 ; d && q [ d - 1 ] > n ; ) d -- ; e . updateParallelArrays ( i , "splice" , d , 0 , 0 ) ; e . updateParallelArrays ( i , d ) ; if ( k && i . name ) k [ n ] = i . name ; h . splice ( d , 0 , a ) ; o && ( e . data . splice ( d , 0 , null ) , e . processData ( ) ) ; f . legendType === "point" && e . generatePoints ( ) ; c && ( g [ 0 ] && g [ 0 ] . remove ? g [ 0 ] . remove ( ! 1 ) : ( g . shift ( ) , e . updateParallelArrays ( i , "shift" ) , h . shift ( ) ) ) ; e . isDirty = ! 0 ; e . isDirtyData = ! 0 ; b && ( e . getAttribs ( ) , j . redraw ( ) ) } , removePoint : function ( a ,
b , c ) { var d = this , e = d . data , f = e [ a ] , g = d . points , h = d . chart , i = function ( ) { e . length === g . length && g . splice ( a , 1 ) ; e . splice ( a , 1 ) ; d . options . data . splice ( a , 1 ) ; d . updateParallelArrays ( f || { series : d } , "splice" , a , 1 ) ; f && f . destroy ( ) ; d . isDirty = ! 0 ; d . isDirtyData = ! 0 ; b && h . redraw ( ) } ; Sa ( c , h ) ; b = p ( b , ! 0 ) ; f ? f . firePointEvent ( "remove" , null , i ) : i ( ) } , remove : function ( a , b ) { var c = this , d = c . chart , a = p ( a , ! 0 ) ; if ( ! c . isRemoving ) c . isRemoving = ! 0 , M ( c , "remove" , null , function ( ) { c . destroy ( ) ; d . isDirtyLegend = d . isDirtyBox = ! 0 ; d . linkSeries ( ) ; a && d . redraw ( b ) } ) ;
c . isRemoving = ! 1 } , update : function ( a , b ) { var c = this , d = this . chart , e = this . userOptions , f = this . type , g = J [ f ] . prototype , h = [ "group" , "markerGroup" , "dataLabelsGroup" ] , i ; if ( a . type && a . type !== f || a . zIndex !== void 0 ) h . length = 0 ; m ( h , function ( a ) { h [ a ] = c [ a ] ; delete c [ a ] } ) ; a = z ( e , { animation : ! 1 , index : this . index , pointStart : this . xData [ 0 ] } , { data : this . options . data } , a ) ; this . remove ( ! 1 ) ; for ( i in g ) this [ i ] = u ; r ( this , J [ a . type || f ] . prototype ) ; m ( h , function ( a ) { c [ a ] = h [ a ] } ) ; this . init ( d , a ) ; d . linkSeries ( ) ; p ( b , ! 0 ) && d . redraw ( ! 1 ) } } ) ; r ( va . prototype ,
{ update : function ( a , b ) { var c = this . chart , a = c . options [ this . coll ] [ this . options . index ] = z ( this . userOptions , a ) ; this . destroy ( ! 0 ) ; this . _addedPlotLB = u ; this . init ( c , r ( a , { events : u } ) ) ; c . isDirtyBox = ! 0 ; p ( b , ! 0 ) && c . redraw ( ) } , remove : function ( a ) { for ( var b = this . chart , c = this . coll , d = this . series , e = d . length ; e -- ; ) d [ e ] && d [ e ] . remove ( ! 1 ) ; ia ( b . axes , this ) ; ia ( b [ c ] , this ) ; b . options [ c ] . splice ( this . options . index , 1 ) ; m ( b [ c ] , function ( a , b ) { a . options . index = b } ) ; this . destroy ( ) ; b . isDirtyBox = ! 0 ; p ( a , ! 0 ) && b . redraw ( ) } , setTitle : function ( a , b ) { this . update ( { title : a } ,
b ) } , setCategories : function ( a , b ) { this . update ( { categories : a } , b ) } } ) ; var xa = ja ( Q ) ; J . line = xa ; aa . area = z ( T , { threshold : 0 } ) ; var pa = ja ( Q , { type : "area" , getSegments : function ( ) { var a = this , b = [ ] , c = [ ] , d = [ ] , e = this . xAxis , f = this . yAxis , g = f . stacks [ this . stackKey ] , h = { } , i , j , k = this . points , l = this . options . connectNulls , n , o ; if ( this . options . stacking && ! this . cropped ) { for ( n = 0 ; n < k . length ; n ++ ) h [ k [ n ] . x ] = k [ n ] ; for ( o in g ) g [ o ] . total !== null && d . push ( + o ) ; d . sort ( function ( a , b ) { return a - b } ) ; m ( d , function ( b ) { var d = 0 , k ; if ( ! l || h [ b ] && h [ b ] . y !== null ) if ( h [ b ] ) c . push ( h [ b ] ) ;
else { for ( n = a . index ; n <= f . series . length ; n ++ ) if ( k = g [ b ] . points [ n + "," + b ] ) { d = k [ 1 ] ; break } i = e . translate ( b ) ; j = f . toPixels ( d , ! 0 ) ; c . push ( { y : null , plotX : i , clientX : i , plotY : j , yBottom : j , onMouseOver : ma } ) } } ) ; c . length && b . push ( c ) } else Q . prototype . getSegments . call ( this ) , b = this . segments ; this . segments = b } , getSegmentPath : function ( a ) { var b = Q . prototype . getSegmentPath . call ( this , a ) , c = [ ] . concat ( b ) , d , e = this . options ; d = b . length ; var f = this . yAxis . getThreshold ( e . threshold ) , g ; d === 3 && c . push ( "L" , b [ 1 ] , b [ 2 ] ) ; if ( e . stacking && ! this . closedStacks ) for ( d =
a . length - 1 ; d >= 0 ; d -- ) g = p ( a [ d ] . yBottom , f ) , d < a . length - 1 && e . step && c . push ( a [ d + 1 ] . plotX , g ) , c . push ( a [ d ] . plotX , g ) ; else this . closeSegment ( c , a , f ) ; this . areaPath = this . areaPath . concat ( c ) ; return b } , closeSegment : function ( a , b , c ) { a . push ( "L" , b [ b . length - 1 ] . plotX , c , "L" , b [ 0 ] . plotX , c ) } , drawGraph : function ( ) { this . areaPath = [ ] ; Q . prototype . drawGraph . apply ( this ) ; var a = this , b = this . areaPath , c = this . options , d = [ [ "area" , this . color , c . fillColor ] ] ; m ( this . zones , function ( b , f ) { d . push ( [ "zoneArea" + f , b . color || a . color , b . fillColor || c . fillColor ] ) } ) ;
m ( d , function ( d ) { var f = d [ 0 ] , g = a [ f ] ; g ? g . animate ( { d : b } ) : a [ f ] = a . chart . renderer . path ( b ) . attr ( { fill : p ( d [ 2 ] , na ( d [ 1 ] ) . setOpacity ( p ( c . fillOpacity , 0.75 ) ) . get ( ) ) , zIndex : 0 } ) . add ( a . group ) } ) } , drawLegendSymbol : Na . drawRectangle } ) ; J . area = pa ; aa . spline = z ( T ) ; xa = ja ( Q , { type : "spline" , getPointSpline : function ( a , b , c ) { var d = b . plotX , e = b . plotY , f = a [ c - 1 ] , g = a [ c + 1 ] , h , i , j , k ; if ( f && g ) { a = f . plotY ; j = g . plotX ; var g = g . plotY , l ; h = ( 1.5 * d + f . plotX ) / 2.5 ; i = ( 1.5 * e + a ) / 2.5 ; j = ( 1.5 * d + j ) / 2.5 ; k = ( 1.5 * e + g ) / 2.5 ; l = ( k - i ) * ( j - d ) / ( j - h ) + e - k ; i += l ; k += l ; i > a && i > e ?
( i = t ( a , e ) , k = 2 * e - i ) : i < a && i < e && ( i = I ( a , e ) , k = 2 * e - i ) ; k > g && k > e ? ( k = t ( g , e ) , i = 2 * e - k ) : k < g && k < e && ( k = I ( g , e ) , i = 2 * e - k ) ; b . rightContX = j ; b . rightContY = k } c ? ( b = [ "C" , f . rightContX || f . plotX , f . rightContY || f . plotY , h || d , i || e , d , e ] , f . rightContX = f . rightContY = null ) : b = [ "M" , d , e ] ; return b } } ) ; J . spline = xa ; aa . areaspline = z ( aa . area ) ; pa = pa . prototype ; xa = ja ( xa , { type : "areaspline" , closedStacks : ! 0 , getSegmentPath : pa . getSegmentPath , closeSegment : pa . closeSegment , drawGraph : pa . drawGraph , drawLegendSymbol : Na . drawRectangle } ) ; J . areaspline = xa ; aa . column =
z ( T , { borderColor : "#FFFFFF" , borderRadius : 0 , groupPadding : 0.2 , marker : null , pointPadding : 0.1 , minPointLength : 0 , cropThreshold : 50 , pointRange : null , states : { hover : { brightness : 0.1 , shadow : ! 1 , halo : ! 1 } , select : { color : "#C0C0C0" , borderColor : "#000000" , shadow : ! 1 } } , dataLabels : { align : null , verticalAlign : null , y : null } , stickyTracking : ! 1 , tooltip : { distance : 6 } , threshold : 0 } ) ; xa = ja ( Q , { type : "column" , pointAttrToOptions : { stroke : "borderColor" , fill : "color" , r : "borderRadius" } , cropShoulder : 0 , directTouch : ! 0 , trackerGroups : [ "group" , "dataLabelsGroup" ] ,
negStacks : ! 0 , init : function ( ) { Q . prototype . init . apply ( this , arguments ) ; var a = this , b = a . chart ; b . hasRendered && m ( b . series , function ( b ) { if ( b . type === a . type ) b . isDirty = ! 0 } ) } , getColumnMetrics : function ( ) { var a = this , b = a . options , c = a . xAxis , d = a . yAxis , e = c . reversed , f , g = { } , h , i = 0 ; b . grouping === ! 1 ? i = 1 : m ( a . chart . series , function ( b ) { var c = b . options , e = b . yAxis ; if ( b . type === a . type && b . visible && d . len === e . len && d . pos === e . pos ) c . stacking ? ( f = b . stackKey , g [ f ] === u && ( g [ f ] = i ++ ) , h = g [ f ] ) : c . grouping !== ! 1 && ( h = i ++ ) , b . columnIndex = h } ) ; var c = I ( O ( c . transA ) *
( c . ordinalSlope || b . pointRange || c . closestPointRange || c . tickInterval || 1 ) , c . len ) , j = c * b . groupPadding , k = ( c - 2 * j ) / i , l = b . pointWidth , b = s ( l ) ? ( k - l ) / 2 : k * b . pointPadding , l = p ( l , k - 2 * b ) ; return a . columnMetrics = { width : l , offset : b + ( j + ( ( e ? i - ( a . columnIndex || 0 ) : a . columnIndex ) || 0 ) * k - c / 2 ) * ( e ? - 1 : 1 ) } } , translate : function ( ) { var a = this , b = a . chart , c = a . options , d = a . borderWidth = p ( c . borderWidth , a . closestPointRange * a . xAxis . transA < 2 ? 0 : 1 ) , e = a . yAxis , f = a . translatedThreshold = e . getThreshold ( c . threshold ) , g = p ( c . minPointLength , 5 ) , h = a . getColumnMetrics ( ) ,
i = h . width , j = a . barW = t ( i , 1 + 2 * d ) , k = a . pointXOffset = h . offset , l = - ( d % 2 ? 0.5 : 0 ) , n = d % 2 ? 0.5 : 1 ; b . inverted && ( f -= 0.5 , b . renderer . isVML && ( n += 1 ) ) ; c . pointPadding && ( j = sa ( j ) ) ; Q . prototype . translate . apply ( a ) ; m ( a . points , function ( c ) { var d = p ( c . yBottom , f ) , h = I ( t ( - 999 - d , c . plotY ) , e . len + 999 + d ) , m = c . plotX + k , s = j , r = I ( h , d ) , u , w ; u = t ( h , d ) - r ; O ( u ) < g && g && ( u = g , w = ! e . reversed && ! c . negative || e . reversed && c . negative , r = x ( O ( r - f ) > g ? d - g : f - ( w ? g : 0 ) ) ) ; c . barX = m ; c . pointWidth = i ; c . tooltipPos = b . inverted ? [ e . len + e . pos - b . plotLeft - h , a . xAxis . len - m - s / 2 ] : [ m + s / 2 ,
h + e . pos - b . plotTop ] ; s = x ( m + s ) + l ; m = x ( m ) + l ; s -= m ; d = O ( r ) < 0.5 ; u = I ( x ( r + u ) + n , 9E4 ) ; r = x ( r ) + n ; u -= r ; d && ( r -= 1 , u += 1 ) ; c . shapeType = "rect" ; c . shapeArgs = { x : m , y : r , width : s , height : u } } ) } , getSymbol : ma , drawLegendSymbol : Na . drawRectangle , drawGraph : ma , drawPoints : function ( ) { var a = this , b = this . chart , c = a . options , d = b . renderer , e = c . animationLimit || 250 , f , g ; m ( a . points , function ( h ) { var i = h . plotY , j = h . graphic ; if ( i !== u && ! isNaN ( i ) && h . y !== null ) f = h . shapeArgs , i = s ( a . borderWidth ) ? { "stroke-width" : a . borderWidth } : { } , g = h . pointAttr [ h . selected ? "select" :
"" ] || a . pointAttr [ "" ] , j ? ( db ( j ) , j . attr ( i ) [ b . pointCount < e ? "animate" : "attr" ] ( z ( f ) ) ) : h . graphic = d [ h . shapeType ] ( f ) . attr ( i ) . attr ( g ) . add ( a . group ) . shadow ( c . shadow , null , c . stacking && ! c . borderRadius ) ; else if ( j ) h . graphic = j . destroy ( ) } ) } , animate : function ( a ) { var b = this . yAxis , c = this . options , d = this . chart . inverted , e = { } ; if ( ba ) a ? ( e . scaleY = 0.001 , a = I ( b . pos + b . len , t ( b . pos , b . toPixels ( c . threshold ) ) ) , d ? e . translateX = a - b . len : e . translateY = a , this . group . attr ( e ) ) : ( e . scaleY = 1 , e [ d ? "translateX" : "translateY" ] = b . pos , this . group . animate ( e ,
this . options . animation ) , this . animate = null ) } , remove : function ( ) { var a = this , b = a . chart ; b . hasRendered && m ( b . series , function ( b ) { if ( b . type === a . type ) b . isDirty = ! 0 } ) ; Q . prototype . remove . apply ( a , arguments ) } } ) ; J . column = xa ; aa . bar = z ( aa . column ) ; pa = ja ( xa , { type : "bar" , inverted : ! 0 } ) ; J . bar = pa ; aa . scatter = z ( T , { lineWidth : 0 , marker : { enabled : ! 0 } , tooltip : { headerFormat : '<span style="color:{series.color}">\u25CF</span> <span style="font-size: 10px;"> {series.name}</span><br/>' , pointFormat : "x: <b>{point.x}</b><br/>y: <b>{point.y}</b><br/>" } } ) ;
pa = ja ( Q , { type : "scatter" , sorted : ! 1 , requireSorting : ! 1 , noSharedTooltip : ! 0 , trackerGroups : [ "group" , "markerGroup" , "dataLabelsGroup" ] , takeOrdinalPosition : ! 1 , kdDimensions : 2 , kdComparer : "distR" , drawGraph : function ( ) { this . options . lineWidth && Q . prototype . drawGraph . call ( this ) } } ) ; J . scatter = pa ; aa . pie = z ( T , { borderColor : "#FFFFFF" , borderWidth : 1 , center : [ null , null ] , clip : ! 1 , colorByPoint : ! 0 , dataLabels : { distance : 30 , enabled : ! 0 , formatter : function ( ) { return this . point . name } , x : 0 } , ignoreHiddenPoint : ! 0 , legendType : "point" , marker : null ,
size : null , showInLegend : ! 1 , slicedOffset : 10 , states : { hover : { brightness : 0.1 , shadow : ! 1 } } , stickyTracking : ! 1 , tooltip : { followPointer : ! 0 } } ) ; T = { type : "pie" , isCartesian : ! 1 , pointClass : ja ( Ga , { init : function ( ) { Ga . prototype . init . apply ( this , arguments ) ; var a = this , b ; r ( a , { visible : a . visible !== ! 1 , name : p ( a . name , "Slice" ) } ) ; b = function ( b ) { a . slice ( b . type === "select" ) } ; N ( a , "select" , b ) ; N ( a , "unselect" , b ) ; return a } , setVisible : function ( a , b ) { var c = this , d = c . series , e = d . chart , f = ! d . isDirty && d . options . ignoreHiddenPoint ; if ( a !== c . visible ||
b ) if ( c . visible = c . options . visible = a = a === u ? ! c . visible : a , d . options . data [ Ma ( c , d . data ) ] = c . options , m ( [ "graphic" , "dataLabel" , "connector" , "shadowGroup" ] , function ( b ) { if ( c [ b ] ) c [ b ] [ a ? "show" : "hide" ] ( ! 0 ) } ) , c . legendItem && ( e . hasRendered && ( d . updateTotals ( ) , e . legend . clearItems ( ) , f || e . legend . render ( ) ) , e . legend . colorizeItem ( c , a ) ) , f ) d . isDirty = ! 0 , e . redraw ( ) } , slice : function ( a , b , c ) { var d = this . series ; Sa ( c , d . chart ) ; p ( b , ! 0 ) ; this . sliced = this . options . sliced = a = s ( a ) ? a : ! this . sliced ; d . options . data [ Ma ( this , d . data ) ] = this . options ;
a = a ? this . slicedTranslation : { translateX : 0 , translateY : 0 } ; this . graphic . animate ( a ) ; this . shadowGroup && this . shadowGroup . animate ( a ) } , haloPath : function ( a ) { var b = this . shapeArgs , c = this . series . chart ; return this . sliced || ! this . visible ? [ ] : this . series . chart . renderer . symbols . arc ( c . plotLeft + b . x , c . plotTop + b . y , b . r + a , b . r + a , { innerR : this . shapeArgs . r , start : b . start , end : b . end } ) } } ) , requireSorting : ! 1 , noSharedTooltip : ! 0 , trackerGroups : [ "group" , "dataLabelsGroup" ] , axisTypes : [ ] , pointAttrToOptions : { stroke : "borderColor" , "stroke-width" : "borderWidth" ,
fill : "color" } , getColor : ma , animate : function ( a ) { var b = this , c = b . points , d = b . startAngleRad ; if ( ! a ) m ( c , function ( a ) { var c = a . graphic , g = a . shapeArgs ; c && ( c . attr ( { r : a . startR || b . center [ 3 ] / 2 , start : d , end : d } ) , c . animate ( { r : g . r , start : g . start , end : g . end } , b . options . animation ) ) } ) , b . animate = null } , setData : function ( a , b , c , d ) { Q . prototype . setData . call ( this , a , ! 1 , c , d ) ; this . processData ( ) ; this . generatePoints ( ) ; p ( b , ! 0 ) && this . chart . redraw ( c ) } , updateTotals : function ( ) { var a , b = 0 , c , d , e , f = this . options . ignoreHiddenPoint ; c = this . points ; d =
c . length ; for ( a = 0 ; a < d ; a ++ ) { e = c [ a ] ; if ( e . y < 0 ) e . y = null ; b += f && ! e . visible ? 0 : e . y } this . total = b ; for ( a = 0 ; a < d ; a ++ ) e = c [ a ] , e . percentage = b > 0 && ( e . visible || ! f ) ? e . y / b * 100 : 0 , e . total = b } , generatePoints : function ( ) { Q . prototype . generatePoints . call ( this ) ; this . updateTotals ( ) } , translate : function ( a ) { this . generatePoints ( ) ; var b = 0 , c = this . options , d = c . slicedOffset , e = d + c . borderWidth , f , g , h , i = c . startAngle || 0 , j = this . startAngleRad = la / 180 * ( i - 90 ) , i = ( this . endAngleRad = la / 180 * ( p ( c . endAngle , i + 360 ) - 90 ) ) - j , k = this . points , l = c . dataLabels . distance ,
c = c . ignoreHiddenPoint , n , m = k . length , q ; if ( ! a ) this . center = a = this . getCenter ( ) ; this . getX = function ( b , c ) { h = V . asin ( I ( ( b - a [ 1 ] ) / ( a [ 2 ] / 2 + l ) , 1 ) ) ; return a [ 0 ] + ( c ? - 1 : 1 ) * W ( h ) * ( a [ 2 ] / 2 + l ) } ; for ( n = 0 ; n < m ; n ++ ) { q = k [ n ] ; f = j + b * i ; if ( ! c || q . visible ) b += q . percentage / 100 ; g = j + b * i ; q . shapeType = "arc" ; q . shapeArgs = { x : a [ 0 ] , y : a [ 1 ] , r : a [ 2 ] / 2 , innerR : a [ 3 ] / 2 , start : x ( f * 1E3 ) / 1E3 , end : x ( g * 1E3 ) / 1E3 } ; h = ( g + f ) / 2 ; h > 1.5 * la ? h -= 2 * la : h < - la / 2 && ( h += 2 * la ) ; q . slicedTranslation = { translateX : x ( W ( h ) * d ) , translateY : x ( $ ( h ) * d ) } ; f = W ( h ) * a [ 2 ] / 2 ; g = $ ( h ) * a [ 2 ] / 2 ; q . tooltipPos =
[ a [ 0 ] + f * 0.7 , a [ 1 ] + g * 0.7 ] ; q . half = h < - la / 2 || h > la / 2 ? 1 : 0 ; q . angle = h ; e = I ( e , l / 2 ) ; q . labelPos = [ a [ 0 ] + f + W ( h ) * l , a [ 1 ] + g + $ ( h ) * l , a [ 0 ] + f + W ( h ) * e , a [ 1 ] + g + $ ( h ) * e , a [ 0 ] + f , a [ 1 ] + g , l < 0 ? "center" : q . half ? "right" : "left" , h ] } } , drawGraph : null , drawPoints : function ( ) { var a = this , b = a . chart . renderer , c , d , e = a . options . shadow , f , g ; if ( e && ! a . shadowGroup ) a . shadowGroup = b . g ( "shadow" ) . add ( a . group ) ; m ( a . points , function ( h ) { var i = h . options . visible ; d = h . graphic ; g = h . shapeArgs ; f = h . shadowGroup ; if ( e && ! f ) f = h . shadowGroup = b . g ( "shadow" ) . add ( a . shadowGroup ) ; c = h . sliced ?
h . slicedTranslation : { translateX : 0 , translateY : 0 } ; f && f . attr ( c ) ; d ? d . animate ( r ( g , c ) ) : h . graphic = d = b [ h . shapeType ] ( g ) . setRadialReference ( a . center ) . attr ( h . pointAttr [ h . selected ? "select" : "" ] ) . attr ( { "stroke-linejoin" : "round" } ) . attr ( c ) . add ( a . group ) . shadow ( e , f ) ; i !== void 0 && h . setVisible ( i , ! 0 ) } ) } , searchPoint : ma , sortByAngle : function ( a , b ) { a . sort ( function ( a , d ) { return a . angle !== void 0 && ( d . angle - a . angle ) * b } ) } , drawLegendSymbol : Na . drawRectangle , getCenter : Xb . getCenter , getSymbol : ma } ; T = ja ( Q , T ) ; J . pie = T ; Q . prototype . drawDataLabels =
function ( ) { var a = this , b = a . options , c = b . cursor , d = b . dataLabels , e = a . points , f , g , h = a . hasRendered || 0 , i , j , k = a . chart . renderer ; if ( d . enabled || a . _hasPointLabels ) a . dlProcessOptions && a . dlProcessOptions ( d ) , j = a . plotGroup ( "dataLabelsGroup" , "data-labels" , d . defer ? "hidden" : "visible" , d . zIndex || 6 ) , p ( d . defer , ! 0 ) && ( j . attr ( { opacity : + h } ) , h || N ( a , "afterAnimate" , function ( ) { a . visible && j . show ( ) ; j [ b . animation ? "animate" : "attr" ] ( { opacity : 1 } , { duration : 200 } ) } ) ) , g = d , m ( e , function ( e ) { var h , m = e . dataLabel , q , t , x = e . connector , w = ! 0 , v , A = { } ; f =
e . dlOptions || e . options && e . options . dataLabels ; h = p ( f && f . enabled , g . enabled ) ; if ( m && ! h ) e . dataLabel = m . destroy ( ) ; else if ( h ) { d = z ( g , f ) ; v = d . style ; h = d . rotation ; q = e . getLabelConfig ( ) ; i = d . format ? Ja ( d . format , q ) : d . formatter . call ( q , d ) ; v . color = p ( d . color , v . color , a . color , "black" ) ; if ( m ) if ( s ( i ) ) m . attr ( { text : i } ) , w = ! 1 ; else { if ( e . dataLabel = m = m . destroy ( ) , x ) e . connector = x . destroy ( ) } else if ( s ( i ) ) { m = { fill : d . backgroundColor , stroke : d . borderColor , "stroke-width" : d . borderWidth , r : d . borderRadius || 0 , rotation : h , padding : d . padding , zIndex : 1 } ;
if ( v . color === "contrast" ) A . color = d . inside || d . distance < 0 || b . stacking ? k . getContrast ( e . color || a . color ) : "#000000" ; if ( c ) A . cursor = c ; for ( t in m ) m [ t ] === u && delete m [ t ] ; m = e . dataLabel = k [ h ? "text" : "label" ] ( i , 0 , - 999 , d . shape , null , null , d . useHTML ) . attr ( m ) . css ( r ( v , A ) ) . add ( j ) . shadow ( d . shadow ) } m && a . alignDataLabel ( e , m , d , null , w ) } } ) } ; Q . prototype . alignDataLabel = function ( a , b , c , d , e ) { var f = this . chart , g = f . inverted , h = p ( a . plotX , - 999 ) , i = p ( a . plotY , - 999 ) , j = b . getBBox ( ) , k = f . renderer . fontMetrics ( c . style . fontSize ) . b , l = this . visible && ( a . series . forceDL ||
f . isInsidePlot ( h , x ( i ) , g ) || d && f . isInsidePlot ( h , g ? d . x + 1 : d . y + d . height - 1 , g ) ) ; if ( l ) d = r ( { x : g ? f . plotWidth - i : h , y : x ( g ? f . plotHeight - h : i ) , width : 0 , height : 0 } , d ) , r ( c , { width : j . width , height : j . height } ) , c . rotation ? ( a = f . renderer . rotCorr ( k , c . rotation ) , b [ e ? "attr" : "animate" ] ( { x : d . x + c . x + d . width / 2 + a . x , y : d . y + c . y + d . height / 2 } ) . attr ( { align : c . align } ) ) : ( b . align ( c , null , d ) , g = b . alignAttr , p ( c . overflow , "justify" ) === "justify" ? this . justifyDataLabel ( b , c , g , j , d , e ) : p ( c . crop , ! 0 ) && ( l = f . isInsidePlot ( g . x , g . y ) && f . isInsidePlot ( g . x + j . width , g . y +
j . height ) ) , c . shape && b . attr ( { anchorX : a . plotX , anchorY : a . plotY } ) ) ; if ( ! l ) b . attr ( { y : - 999 } ) , b . placed = ! 1 } ; Q . prototype . justifyDataLabel = function ( a , b , c , d , e , f ) { var g = this . chart , h = b . align , i = b . verticalAlign , j , k , l = a . box ? 0 : a . padding || 0 ; j = c . x + l ; if ( j < 0 ) h === "right" ? b . align = "left" : b . x = - j , k = ! 0 ; j = c . x + d . width - l ; if ( j > g . plotWidth ) h === "left" ? b . align = "right" : b . x = g . plotWidth - j , k = ! 0 ; j = c . y + l ; if ( j < 0 ) i === "bottom" ? b . verticalAlign = "top" : b . y = - j , k = ! 0 ; j = c . y + d . height - l ; if ( j > g . plotHeight ) i === "top" ? b . verticalAlign = "bottom" : b . y = g . plotHeight -
j , k = ! 0 ; if ( k ) a . placed = ! f , a . align ( b , null , e ) } ; if ( J . pie ) J . pie . prototype . drawDataLabels = function ( ) { var a = this , b = a . data , c , d = a . chart , e = a . options . dataLabels , f = p ( e . connectorPadding , 10 ) , g = p ( e . connectorWidth , 1 ) , h = d . plotWidth , i = d . plotHeight , j , k , l = p ( e . softConnector , ! 0 ) , n = e . distance , o = a . center , q = o [ 2 ] / 2 , r = o [ 1 ] , s = n > 0 , u , v , w , z = [ [ ] , [ ] ] , A , B , D , G , E , F = [ 0 , 0 , 0 , 0 ] , M = function ( a , b ) { return b . y - a . y } ; if ( a . visible && ( e . enabled || a . _hasPointLabels ) ) { Q . prototype . drawDataLabels . apply ( a ) ; m ( b , function ( a ) { a . dataLabel && a . visible && z [ a . half ] . push ( a ) } ) ;
for ( G = 2 ; G -- ; ) { var J = [ ] , N = [ ] , H = z [ G ] , L = H . length , K ; if ( L ) { a . sortByAngle ( H , G - 0.5 ) ; for ( E = b = 0 ; ! b && H [ E ] ; ) b = H [ E ] && H [ E ] . dataLabel && ( H [ E ] . dataLabel . getBBox ( ) . height || 21 ) , E ++ ; if ( n > 0 ) { v = I ( r + q + n , d . plotHeight ) ; for ( E = t ( 0 , r - q - n ) ; E <= v ; E += b ) J . push ( E ) ; v = J . length ; if ( L > v ) { c = [ ] . concat ( H ) ; c . sort ( M ) ; for ( E = L ; E -- ; ) c [ E ] . rank = E ; for ( E = L ; E -- ; ) H [ E ] . rank >= v && H . splice ( E , 1 ) ; L = H . length } for ( E = 0 ; E < L ; E ++ ) { c = H [ E ] ; w = c . labelPos ; c = 9999 ; var R , P ; for ( P = 0 ; P < v ; P ++ ) R = O ( J [ P ] - w [ 1 ] ) , R < c && ( c = R , K = P ) ; if ( K < E && J [ E ] !== null ) K = E ; else for ( v < L - E + K && J [ E ] !== null &&
( K = v - L + E ) ; J [ K ] === null ; ) K ++ ; N . push ( { i : K , y : J [ K ] } ) ; J [ K ] = null } N . sort ( M ) } for ( E = 0 ; E < L ; E ++ ) { c = H [ E ] ; w = c . labelPos ; u = c . dataLabel ; D = c . visible === ! 1 ? "hidden" : "inherit" ; c = w [ 1 ] ; if ( n > 0 ) { if ( v = N . pop ( ) , K = v . i , B = v . y , c > B && J [ K + 1 ] !== null || c < B && J [ K - 1 ] !== null ) B = I ( t ( 0 , c ) , d . plotHeight ) } else B = c ; A = e . justify ? o [ 0 ] + ( G ? - 1 : 1 ) * ( q + n ) : a . getX ( B === r - q - n || B === r + q + n ? c : B , G ) ; u . _attr = { visibility : D , align : w [ 6 ] } ; u . _pos = { x : A + e . x + ( { left : f , right : - f } [ w [ 6 ] ] || 0 ) , y : B + e . y - 10 } ; u . connX = A ; u . connY = B ; if ( this . options . size === null ) v = u . width , A - v < f ? F [ 3 ] = t ( x ( v -
A + f ) , F [ 3 ] ) : A + v > h - f && ( F [ 1 ] = t ( x ( A + v - h + f ) , F [ 1 ] ) ) , B - b / 2 < 0 ? F [ 0 ] = t ( x ( - B + b / 2 ) , F [ 0 ] ) : B + b / 2 > i && ( F [ 2 ] = t ( x ( B + b / 2 - i ) , F [ 2 ] ) ) } } } if ( Fa ( F ) === 0 || this . verifyDataLabelOverflow ( F ) ) this . placeDataLabels ( ) , s && g && m ( this . points , function ( b ) { j = b . connector ; w = b . labelPos ; if ( ( u = b . dataLabel ) && u . _pos ) D = u . _attr . visibility , A = u . connX , B = u . connY , k = l ? [ "M" , A + ( w [ 6 ] === "left" ? 5 : - 5 ) , B , "C" , A , B , 2 * w [ 2 ] - w [ 4 ] , 2 * w [ 3 ] - w [ 5 ] , w [ 2 ] , w [ 3 ] , "L" , w [ 4 ] , w [ 5 ] ] : [ "M" , A + ( w [ 6 ] === "left" ? 5 : - 5 ) , B , "L" , w [ 2 ] , w [ 3 ] , "L" , w [ 4 ] , w [ 5 ] ] , j ? ( j . animate ( { d : k } ) , j . attr ( "visibility" , D ) ) :
b . connector = j = a . chart . renderer . path ( k ) . attr ( { "stroke-width" : g , stroke : e . connectorColor || b . color || "#606060" , visibility : D } ) . add ( a . dataLabelsGroup ) ; else if ( j ) b . connector = j . destroy ( ) } ) } } , J . pie . prototype . placeDataLabels = function ( ) { m ( this . points , function ( a ) { var a = a . dataLabel , b ; if ( a ) ( b = a . _pos ) ? ( a . attr ( a . _attr ) , a [ a . moved ? "animate" : "attr" ] ( b ) , a . moved = ! 0 ) : a && a . attr ( { y : - 999 } ) } ) } , J . pie . prototype . alignDataLabel = ma , J . pie . prototype . verifyDataLabelOverflow = function ( a ) { var b = this . center , c = this . options , d = c . center , e =
c = c . minSize || 80 , f ; d [ 0 ] !== null ? e = t ( b [ 2 ] - t ( a [ 1 ] , a [ 3 ] ) , c ) : ( e = t ( b [ 2 ] - a [ 1 ] - a [ 3 ] , c ) , b [ 0 ] += ( a [ 3 ] - a [ 1 ] ) / 2 ) ; d [ 1 ] !== null ? e = t ( I ( e , b [ 2 ] - t ( a [ 0 ] , a [ 2 ] ) ) , c ) : ( e = t ( I ( e , b [ 2 ] - a [ 0 ] - a [ 2 ] ) , c ) , b [ 1 ] += ( a [ 0 ] - a [ 2 ] ) / 2 ) ; e < b [ 2 ] ? ( b [ 2 ] = e , this . translate ( b ) , m ( this . points , function ( a ) { if ( a . dataLabel ) a . dataLabel . _pos = null } ) , this . drawDataLabels && this . drawDataLabels ( ) ) : f = ! 0 ; return f } ; if ( J . column ) J . column . prototype . alignDataLabel = function ( a , b , c , d , e ) { var f = this . chart . inverted , g = a . series , h = a . dlBox || a . shapeArgs , i = a . below || a . plotY > p ( this . translatedThreshold ,
g . yAxis . len ) , j = p ( c . inside , ! ! this . options . stacking ) ; if ( h && ( d = z ( h ) , f && ( d = { x : g . yAxis . len - d . y - d . height , y : g . xAxis . len - d . x - d . width , width : d . height , height : d . width } ) , ! j ) ) f ? ( d . x += i ? 0 : d . width , d . width = 0 ) : ( d . y += i ? d . height : 0 , d . height = 0 ) ; c . align = p ( c . align , ! f || j ? "center" : i ? "right" : "left" ) ; c . verticalAlign = p ( c . verticalAlign , f || j ? "middle" : i ? "top" : "bottom" ) ; Q . prototype . alignDataLabel . call ( this , a , b , c , d , e ) } ; ( function ( a ) { var b = a . Chart , c = a . each , d = HighchartsAdapter . addEvent ; b . prototype . callbacks . push ( function ( a ) { function b ( ) { var d =
[ ] ; c ( a . series , function ( a ) { var b = a . options . dataLabels ; ( b . enabled || a . _hasPointLabels ) && ! b . allowOverlap && a . visible && c ( a . points , function ( a ) { if ( a . dataLabel ) a . dataLabel . labelrank = a . labelrank , d . push ( a . dataLabel ) } ) } ) ; a . hideOverlappingLabels ( d ) } b ( ) ; d ( a , "redraw" , b ) } ) ; b . prototype . hideOverlappingLabels = function ( a ) { var b = a . length , c , d , i , j ; for ( d = 0 ; d < b ; d ++ ) if ( c = a [ d ] ) c . oldOpacity = c . opacity , c . newOpacity = 1 ; for ( d = 0 ; d < b ; d ++ ) { i = a [ d ] ; for ( c = d + 1 ; c < b ; ++ c ) if ( j = a [ c ] , i && j && i . placed && j . placed && i . newOpacity !== 0 && j . newOpacity !==
0 && ! ( j . alignAttr . x > i . alignAttr . x + i . width || j . alignAttr . x + j . width < i . alignAttr . x || j . alignAttr . y > i . alignAttr . y + i . height || j . alignAttr . y + j . height < i . alignAttr . y ) ) ( i . labelrank < j . labelrank ? i : j ) . newOpacity = 0 } for ( d = 0 ; d < b ; d ++ ) if ( c = a [ d ] ) { if ( c . oldOpacity !== c . newOpacity && c . placed ) c . alignAttr . opacity = c . newOpacity , c [ c . isOld && c . newOpacity ? "animate" : "attr" ] ( c . alignAttr ) ; c . isOld = ! 0 } } } ) ( w ) ; T = w . TrackerMixin = { drawTrackerPoint : function ( ) { var a = this , b = a . chart , c = b . pointer , d = a . options . cursor , e = d && { cursor : d } , f = function ( a ) { for ( var c =
a . target , d ; c && ! d ; ) d = c . point , c = c . parentNode ; if ( d !== u && d !== b . hoverPoint ) d . onMouseOver ( a ) } ; m ( a . points , function ( a ) { if ( a . graphic ) a . graphic . element . point = a ; if ( a . dataLabel ) a . dataLabel . element . point = a } ) ; if ( ! a . _hasTracking ) m ( a . trackerGroups , function ( b ) { if ( a [ b ] && ( a [ b ] . addClass ( "highcharts-tracker" ) . on ( "mouseover" , f ) . on ( "mouseout" , function ( a ) { c . onTrackerMouseOut ( a ) } ) . css ( e ) , ab ) ) a [ b ] . on ( "touchstart" , f ) } ) , a . _hasTracking = ! 0 } , drawTrackerGraph : function ( ) { var a = this , b = a . options , c = b . trackByArea , d = [ ] . concat ( c ? a . areaPath :
a . graphPath ) , e = d . length , f = a . chart , g = f . pointer , h = f . renderer , i = f . options . tooltip . snap , j = a . tracker , k = b . cursor , l = k && { cursor : k } , k = a . singlePoints , n , o = function ( ) { if ( f . hoverSeries !== a ) a . onMouseOver ( ) } , p = "rgba(192,192,192," + ( ba ? 1.0 E - 4 : 0.002 ) + ")" ; if ( e && ! c ) for ( n = e + 1 ; n -- ; ) d [ n ] === "M" && d . splice ( n + 1 , 0 , d [ n + 1 ] - i , d [ n + 2 ] , "L" ) , ( n && d [ n ] === "M" || n === e ) && d . splice ( n , 0 , "L" , d [ n - 2 ] + i , d [ n - 1 ] ) ; for ( n = 0 ; n < k . length ; n ++ ) e = k [ n ] , d . push ( "M" , e . plotX - i , e . plotY , "L" , e . plotX + i , e . plotY ) ; j ? j . attr ( { d : d } ) : ( a . tracker = h . path ( d ) . attr ( { "stroke-linejoin" : "round" ,
visibility : a . visible ? "visible" : "hidden" , stroke : p , fill : c ? p : R , "stroke-width" : b . lineWidth + ( c ? 0 : 2 * i ) , zIndex : 2 } ) . add ( a . group ) , m ( [ a . tracker , a . markerGroup ] , function ( a ) { a . addClass ( "highcharts-tracker" ) . on ( "mouseover" , o ) . on ( "mouseout" , function ( a ) { g . onTrackerMouseOut ( a ) } ) . css ( l ) ; if ( ab ) a . on ( "touchstart" , o ) } ) ) } } ; if ( J . column ) xa . prototype . drawTracker = T . drawTrackerPoint ; if ( J . pie ) J . pie . prototype . drawTracker = T . drawTrackerPoint ; if ( J . scatter ) pa . prototype . drawTracker = T . drawTrackerPoint ; r ( mb . prototype , { setItemEvents : function ( a ,
b , c , d , e ) { var f = this ; ( c ? b : a . legendGroup ) . on ( "mouseover" , function ( ) { a . setState ( "hover" ) ; b . css ( f . options . itemHoverStyle ) } ) . on ( "mouseout" , function ( ) { b . css ( a . visible ? d : e ) ; a . setState ( ) } ) . on ( "click" , function ( b ) { var c = function ( ) { a . setVisible ( ) } , b = { browserEvent : b } ; a . firePointEvent ? a . firePointEvent ( "legendItemClick" , b , c ) : M ( a , "legendItemClick" , b , c ) } ) } , createCheckboxForItem : function ( a ) { a . checkbox = Z ( "input" , { type : "checkbox" , checked : a . selected , defaultChecked : a . selected } , this . options . itemCheckboxStyle , this . chart . container ) ;
N ( a . checkbox , "click" , function ( b ) { M ( a . series || a , "checkboxClick" , { checked : b . target . checked , item : a } , function ( ) { a . select ( ) } ) } ) } } ) ; P . legend . itemStyle . cursor = "pointer" ; r ( D . prototype , { showResetZoom : function ( ) { var a = this , b = P . lang , c = a . options . chart . resetZoomButton , d = c . theme , e = d . states , f = c . relativeTo === "chart" ? null : "plotBox" ; this . resetZoomButton = a . renderer . button ( b . resetZoom , null , null , function ( ) { a . zoomOut ( ) } , d , e && e . hover ) . attr ( { align : c . position . align , title : b . resetZoomTitle } ) . add ( ) . align ( c . position , ! 1 , f ) } , zoomOut : function ( ) { var a =
this ; M ( a , "selection" , { resetSelection : ! 0 } , function ( ) { a . zoom ( ) } ) } , zoom : function ( a ) { var b , c = this . pointer , d = ! 1 , e ; ! a || a . resetSelection ? m ( this . axes , function ( a ) { b = a . zoom ( ) } ) : m ( a . xAxis . concat ( a . yAxis ) , function ( a ) { var e = a . axis , h = e . isXAxis ; if ( c [ h ? "zoomX" : "zoomY" ] || c [ h ? "pinchX" : "pinchY" ] ) b = e . zoom ( a . min , a . max ) , e . displayBtn && ( d = ! 0 ) } ) ; e = this . resetZoomButton ; if ( d && ! e ) this . showResetZoom ( ) ; else if ( ! d && ca ( e ) ) this . resetZoomButton = e . destroy ( ) ; b && this . redraw ( p ( this . options . chart . animation , a && a . animation , this . pointCount <
100 ) ) } , pan : function ( a , b ) { var c = this , d = c . hoverPoints , e ; d && m ( d , function ( a ) { a . setState ( ) } ) ; m ( b === "xy" ? [ 1 , 0 ] : [ 1 ] , function ( b ) { var d = a [ b ? "chartX" : "chartY" ] , h = c [ b ? "xAxis" : "yAxis" ] [ 0 ] , i = c [ b ? "mouseDownX" : "mouseDownY" ] , j = ( h . pointRange || 0 ) / 2 , k = h . getExtremes ( ) , l = h . toValue ( i - d , ! 0 ) + j , j = h . toValue ( i + c [ b ? "plotWidth" : "plotHeight" ] - d , ! 0 ) - j , i = i > d ; if ( h . series . length && ( i || l > I ( k . dataMin , k . min ) ) && ( ! i || j < t ( k . dataMax , k . max ) ) ) h . setExtremes ( l , j , ! 1 , ! 1 , { trigger : "pan" } ) , e = ! 0 ; c [ b ? "mouseDownX" : "mouseDownY" ] = d } ) ; e && c . redraw ( ! 1 ) ; F ( c . container ,
{ cursor : "move" } ) } } ) ; r ( Ga . prototype , { select : function ( a , b ) { var c = this , d = c . series , e = d . chart , a = p ( a , ! c . selected ) ; c . firePointEvent ( a ? "select" : "unselect" , { accumulate : b } , function ( ) { c . selected = c . options . selected = a ; d . options . data [ Ma ( c , d . data ) ] = c . options ; c . setState ( a && "select" ) ; b || m ( e . getSelectedPoints ( ) , function ( a ) { if ( a . selected && a !== c ) a . selected = a . options . selected = ! 1 , d . options . data [ Ma ( a , d . data ) ] = a . options , a . setState ( "" ) , a . firePointEvent ( "unselect" ) } ) } ) } , onMouseOver : function ( a ) { var b = this . series , c = b . chart ,
d = c . tooltip , e = c . hoverPoint ; if ( c . hoverSeries !== b ) b . onMouseOver ( ) ; if ( e && e !== this ) e . onMouseOut ( ) ; this . firePointEvent ( "mouseOver" ) ; d && ( ! d . shared || b . noSharedTooltip ) && d . refresh ( this , a ) ; this . setState ( "hover" ) ; c . hoverPoint = this } , onMouseOut : function ( ) { var a = this . series . chart , b = a . hoverPoints ; this . firePointEvent ( "mouseOut" ) ; if ( ! b || Ma ( this , b ) === - 1 ) this . setState ( ) , a . hoverPoint = null } , importEvents : function ( ) { if ( ! this . hasImportedEvents ) { var a = z ( this . series . options . point , this . options ) . events , b ; this . events = a ; for ( b in a ) N ( this ,
b , a [ b ] ) ; this . hasImportedEvents = ! 0 } } , setState : function ( a , b ) { var c = this . plotX , d = this . plotY , e = this . series , f = e . options . states , g = aa [ e . type ] . marker && e . options . marker , h = g && ! g . enabled , i = g && g . states [ a ] , j = i && i . enabled === ! 1 , k = e . stateMarkerGraphic , l = this . marker || { } , n = e . chart , m = e . halo , p , a = a || "" ; p = this . pointAttr [ a ] || e . pointAttr [ a ] ; if ( ! ( a === this . state && ! b || this . selected && a !== "select" || f [ a ] && f [ a ] . enabled === ! 1 || a && ( j || h && i . enabled === ! 1 ) || a && l . states && l . states [ a ] && l . states [ a ] . enabled === ! 1 ) ) { if ( this . graphic ) g = g && this . graphic . symbolName &&
p . r , this . graphic . attr ( z ( p , g ? { x : c - g , y : d - g , width : 2 * g , height : 2 * g } : { } ) ) , k && k . hide ( ) ; else { if ( a && i ) if ( g = i . radius , l = l . symbol || e . symbol , k && k . currentSymbol !== l && ( k = k . destroy ( ) ) , k ) k [ b ? "animate" : "attr" ] ( { x : c - g , y : d - g } ) ; else if ( l ) e . stateMarkerGraphic = k = n . renderer . symbol ( l , c - g , d - g , 2 * g , 2 * g ) . attr ( p ) . add ( e . markerGroup ) , k . currentSymbol = l ; if ( k ) k [ a && n . isInsidePlot ( c , d , n . inverted ) ? "show" : "hide" ] ( ) } if ( ( c = f [ a ] && f [ a ] . halo ) && c . size ) { if ( ! m ) e . halo = m = n . renderer . path ( ) . add ( n . seriesGroup ) ; m . attr ( r ( { fill : na ( this . color || e . color ) . setOpacity ( c . opacity ) . get ( ) } ,
c . attributes ) ) [ b ? "animate" : "attr" ] ( { d : this . haloPath ( c . size ) } ) } else m && m . attr ( { d : [ ] } ) ; this . state = a } } , haloPath : function ( a ) { var b = this . series , c = b . chart , d = b . getPlotBox ( ) , e = c . inverted ; return c . renderer . symbols . circle ( d . translateX + ( e ? b . yAxis . len - this . plotY : this . plotX ) - a , d . translateY + ( e ? b . xAxis . len - this . plotX : this . plotY ) - a , a * 2 , a * 2 ) } } ) ; r ( Q . prototype , { onMouseOver : function ( ) { var a = this . chart , b = a . hoverSeries ; if ( b && b !== this ) b . onMouseOut ( ) ; this . options . events . mouseOver && M ( this , "mouseOver" ) ; this . setState ( "hover" ) ;
a . hoverSeries = this } , onMouseOut : function ( ) { var a = this . options , b = this . chart , c = b . tooltip , d = b . hoverPoint ; if ( d ) d . onMouseOut ( ) ; this && a . events . mouseOut && M ( this , "mouseOut" ) ; c && ! a . stickyTracking && ( ! c . shared || this . noSharedTooltip ) && c . hide ( ) ; this . setState ( ) ; b . hoverSeries = null } , setState : function ( a ) { var b = this . options , c = this . graph , d = b . states , e = b . lineWidth , b = 0 , a = a || "" ; if ( this . state !== a && ( this . state = a , ! ( d [ a ] && d [ a ] . enabled === ! 1 ) && ( a && ( e = d [ a ] . lineWidth || e + ( d [ a ] . lineWidthPlus || 0 ) ) , c && ! c . dashstyle ) ) ) { a = { "stroke-width" : e } ;
for ( c . attr ( a ) ; this [ "zoneGraph" + b ] ; ) this [ "zoneGraph" + b ] . attr ( a ) , b += 1 } } , setVisible : function ( a , b ) { var c = this , d = c . chart , e = c . legendItem , f , g = d . options . chart . ignoreHiddenSeries , h = c . visible ; f = ( c . visible = a = c . userOptions . visible = a === u ? ! h : a ) ? "show" : "hide" ; m ( [ "group" , "dataLabelsGroup" , "markerGroup" , "tracker" ] , function ( a ) { if ( c [ a ] ) c [ a ] [ f ] ( ) } ) ; if ( d . hoverSeries === c || ( d . hoverPoint && d . hoverPoint . series ) === c ) c . onMouseOut ( ) ; e && d . legend . colorizeItem ( c , a ) ; c . isDirty = ! 0 ; c . options . stacking && m ( d . series , function ( a ) { if ( a . options . stacking &&
a . visible ) a . isDirty = ! 0 } ) ; m ( c . linkedSeries , function ( b ) { b . setVisible ( a , ! 1 ) } ) ; if ( g ) d . isDirtyBox = ! 0 ; b !== ! 1 && d . redraw ( ) ; M ( c , f ) } , show : function ( ) { this . setVisible ( ! 0 ) } , hide : function ( ) { this . setVisible ( ! 1 ) } , select : function ( a ) { this . selected = a = a === u ? ! this . selected : a ; if ( this . checkbox ) this . checkbox . checked = a ; M ( this , a ? "select" : "unselect" ) } , drawTracker : T . drawTrackerGraph } ) ; r ( w , { Color : na , Point : Ga , Tick : Ta , Renderer : $a , SVGElement : K , SVGRenderer : ta , arrayMin : Pa , arrayMax : Fa , charts : X , dateFormat : Oa , error : ka , format : Ja , pathAnim : zb ,
getOptions : function ( ) { return P } , hasBidiBug : Nb , isTouchDevice : Jb , setOptions : function ( a ) { P = z ( ! 0 , P , a ) ; Cb ( ) ; return P } , addEvent : N , removeEvent : Y , createElement : Z , discardElement : Ra , css : F , each : m , map : Ua , merge : z , splat : ra , extendClass : ja , pInt : B , svg : ba , canvas : ea , vml : ! ba && ! ea , product : "Highcharts" , version : "4.1.5" } ) } ) ( ) ;