dealposbooks 1.0.7 → 1.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/3rdpartylicenses.txt +88 -88
- package/assets/scss/fonts/montserrat/Montserrat-Bold.woff2 +0 -0
- package/assets/scss/fonts/montserrat/Montserrat-Italic.woff2 +0 -0
- package/assets/scss/fonts/montserrat/Montserrat-Regular.woff2 +0 -0
- package/assets/scss/fonts/montserrat/Montserrat-SemiBold.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-Black.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-Bold.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-ExtraBold.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-ExtraLight.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-Light.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-Medium.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-Regular.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-SemiBold.woff2 +0 -0
- package/assets/scss/fonts/roboto-slab/RobotoSlab-Thin.woff2 +0 -0
- package/assets/scss/layouts/_layout.scss +6 -6
- package/assets/scss/layouts/_sidebar.scss +8 -6
- package/assets/scss/style.scss +20 -8
- package/assets/scss/variables/_variables.scss +11 -35
- package/{chunk-OM3AWD5C.js → chunk-25PFXJAK.js} +1 -1
- package/chunk-2ODJIB2A.js +2 -0
- package/{chunk-D7G3TZFD.js → chunk-2RWUYFYR.js} +1 -1
- package/chunk-3GWDCNXX.js +397 -0
- package/chunk-4ANSU2AT.js +137 -0
- package/{chunk-FRUVZQE2.js → chunk-52HZNWBM.js} +4 -2
- package/{chunk-C6OIY3SK.js → chunk-63UNI6LK.js} +3 -3
- package/chunk-7LG2CFYI.js +1 -0
- package/{chunk-4WX4CTCF.js → chunk-AH4LZWJY.js} +1 -1
- package/chunk-AKBPKNCH.js +1 -0
- package/chunk-AOB6BRGQ.js +1 -0
- package/chunk-ATVC2UCR.js +47 -0
- package/chunk-AWY6AD76.js +1 -0
- package/chunk-B4JAAGJX.js +1 -0
- package/chunk-BGKS3L73.js +246 -0
- package/{chunk-T4BLJS6I.js → chunk-C66O26ZI.js} +2 -2
- package/chunk-C6Q5SG76.js +1 -0
- package/chunk-DOKYUX3G.js +1 -0
- package/{chunk-HTIWSCTK.js → chunk-E6EWXQXJ.js} +1 -1
- package/{chunk-AVVIJQVC.js → chunk-E6QGADC5.js} +6 -2
- package/chunk-EN5MVYJQ.js +180 -0
- package/chunk-EP22HTZC.js +300 -0
- package/chunk-FJ7O4K2Y.js +1 -0
- package/chunk-FVXLQNAC.js +193 -0
- package/chunk-G52TDPSD.js +297 -0
- package/chunk-GCTIPWTU.js +1 -0
- package/chunk-GMTXOQ6X.js +1 -0
- package/chunk-GRTIJ77T.js +1 -0
- package/chunk-HG23WDL5.js +1660 -0
- package/chunk-I4HDCL3W.js +1 -0
- package/{chunk-SKH7LGD3.js → chunk-I7MT7OUB.js} +1 -1
- package/chunk-ISXV3FIH.js +1 -0
- package/{chunk-NHEOQJVG.js → chunk-JFAO2CIB.js} +1 -1
- package/chunk-JQNCWTZN.js +1 -0
- package/{chunk-CUPI27LK.js → chunk-JT2WCR5Q.js} +1 -1
- package/chunk-JXNLXEJT.js +1 -0
- package/chunk-K36WQVFR.js +1 -0
- package/{chunk-XVXUJ33X.js → chunk-KFHCGO62.js} +1 -1
- package/chunk-LCATVZKP.js +141 -0
- package/chunk-LJMMN36O.js +1 -0
- package/{chunk-BFBSEK4H.js → chunk-MNPBLC23.js} +2 -2
- package/{chunk-36254LID.js → chunk-NQ24E7JY.js} +1 -1
- package/{chunk-7HQ6WSSU.js → chunk-NTDTN5DF.js} +1 -1
- package/{chunk-6VATP7AD.js → chunk-O7OAT4UO.js} +1 -1
- package/chunk-OHVHLILJ.js +1 -0
- package/chunk-OJWZH7AB.js +301 -0
- package/{chunk-ZZCZU47E.js → chunk-PG4QL7N2.js} +1 -1
- package/chunk-PNAWRNGD.js +197 -0
- package/chunk-QJ2XA575.js +1 -0
- package/chunk-RJYIKNTI.js +1 -0
- package/chunk-RR5AUWZO.js +1 -0
- package/chunk-RSHFIZV3.js +7 -0
- package/chunk-SQKLMC5H.js +231 -0
- package/{chunk-P7OQDOZ5.js → chunk-T3ZCO6EC.js} +1 -1
- package/chunk-T7R7C3RX.js +1 -0
- package/chunk-TJSPXPO6.js +59 -0
- package/chunk-TNXHYK2R.js +7 -0
- package/chunk-TTG6XQNP.js +1 -0
- package/chunk-UC2RR4WT.js +210 -0
- package/chunk-UOFRXQI7.js +1 -0
- package/{chunk-CGUMLMMW.js → chunk-UVBFYB2X.js} +2 -2
- package/{chunk-ECOKK22J.js → chunk-WCQQSWYQ.js} +21 -67
- package/{chunk-ZNSZA7QK.js → chunk-WTRMIJHX.js} +1 -1
- package/chunk-Z4SGDPGH.js +821 -0
- package/chunk-ZNN2E36Y.js +1 -0
- package/index.html +3 -3
- package/main-F2OQVLJM.js +1 -0
- package/package.json +1 -1
- package/styles-GUJHQHWA.css +1 -0
- package/assets/scss/fonts/Montserrat-Black.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-BlackItalic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-Bold.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-BoldItalic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-ExtraBold.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-ExtraBoldItalic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-ExtraLight.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-ExtraLightItalic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-Italic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-Light.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-LightItalic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-Medium.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-MediumItalic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-Regular.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-SemiBold.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-SemiBoldItalic.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-Thin.woff2 +0 -0
- package/assets/scss/fonts/Montserrat-ThinItalic.woff2 +0 -0
- package/assets/scss/fonts/Roboto-Italic-VariableFont_wdth,wght.woff2 +0 -0
- package/assets/scss/fonts/Roboto-VariableFont_wdth,wght.woff2 +0 -0
- package/assets/scss/fonts/RobotoSlab-VariableFont_wght.woff2 +0 -0
- package/chunk-2TIQLYOU.js +0 -1
- package/chunk-3RX6VPXR.js +0 -2
- package/chunk-4KSABCT6.js +0 -1
- package/chunk-5U24N52S.js +0 -1
- package/chunk-6SHWLH3C.js +0 -141
- package/chunk-7BUIG2V4.js +0 -2
- package/chunk-A63HKFUG.js +0 -7
- package/chunk-BMZ2A6GT.js +0 -1
- package/chunk-DFW6MEY3.js +0 -1
- package/chunk-EQDQRRRY.js +0 -1
- package/chunk-FJNTF5KS.js +0 -1
- package/chunk-FT6T65H6.js +0 -191
- package/chunk-G7QGHGLM.js +0 -1767
- package/chunk-KSOH6FOP.js +0 -160
- package/chunk-L3OWH62Z.js +0 -1
- package/chunk-LVEM3QDX.js +0 -180
- package/chunk-MYWX5CJP.js +0 -1
- package/chunk-NAZKZSVO.js +0 -1
- package/chunk-NFJLN5KP.js +0 -1
- package/chunk-OB4H7LE4.js +0 -1
- package/chunk-PFEDDKVG.js +0 -235
- package/chunk-PJF5SBZS.js +0 -2
- package/chunk-QHTRP332.js +0 -1
- package/chunk-QSMNYWAY.js +0 -1
- package/chunk-RYKEISKQ.js +0 -1
- package/chunk-SMINY2HR.js +0 -428
- package/chunk-T6W6HJCE.js +0 -1
- package/chunk-UJUUMHOE.js +0 -284
- package/chunk-ULH6XT2Q.js +0 -931
- package/chunk-WB6KUPUB.js +0 -393
- package/chunk-WKMCCUUK.js +0 -1
- package/chunk-WQNK5ZUV.js +0 -1
- package/chunk-XTTFTDKZ.js +0 -1
- package/chunk-ZQDTA2BC.js +0 -189
- package/main-ZQK6GRTL.js +0 -1
- package/styles-PZKETPHN.css +0 -1
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{f as Nn}from"./chunk-ZNN2E36Y.js";import{a as Xn}from"./chunk-AKBPKNCH.js";import{a as Wn,b as Hn}from"./chunk-MNPBLC23.js";import{g as Rn}from"./chunk-EN5MVYJQ.js";import"./chunk-Z4SGDPGH.js";import"./chunk-FJ7O4K2Y.js";import{c as Bn}from"./chunk-PNAWRNGD.js";import"./chunk-FVXLQNAC.js";import{d as zn}from"./chunk-T3ZCO6EC.js";import"./chunk-S35HUXPS.js";import"./chunk-25PFXJAK.js";import{n as En,s as In,t as Dn}from"./chunk-GRTIJ77T.js";import{Aa as Mn,Bb as Ho,Ea as Sn,Fc as oi,Gc as ri,Ha as Cn,Ic as On,Kb as ii,Ub as ut,Vb as ft,Vc as Ln,Wb as ge,Xb as An,Yb as Pn,Z as bn,ca as vn,da as kn,ec as Xo,gb as te,hb as Wo,ia as ts,mc as Xt,nc as si,pa as wn,ub as es,vb as Tn,za as Ro}from"./chunk-RSHFIZV3.js";import{a as vt,b as Ht,d as lg,e as dg}from"./chunk-C6Q5SG76.js";var jn=lg((ai,Fo)=>{(function(F,Ot){typeof ai=="object"&&typeof Fo=="object"?(F._Highcharts=Ot(),Fo.exports=F._Highcharts):typeof define=="function"&&define.amd?define("highcharts/highcharts",[],Ot):typeof ai=="object"?(F._Highcharts=Ot(),ai.highcharts=F._Highcharts):(F.Highcharts&&F.Highcharts.error(16,!0),F.Highcharts=Ot())})(typeof window>"u"?ai:window,()=>(()=>{"use strict";let F,Ot;var V,Q,ue,is,ss,os,rs,as,ns,hs,ls,ds,cs,ps,gs,us,fs,ms,Ee={};Ee.d=(h,t)=>{for(var e in t)Ee.o(t,e)&&!Ee.o(h,e)&&Object.defineProperty(h,e,{enumerable:!0,get:t[e]})},Ee.o=(h,t)=>Object.prototype.hasOwnProperty.call(h,t);var Go={};Ee.d(Go,{default:()=>hg}),function(h){h.SVG_NS="http://www.w3.org/2000/svg",h.product="Highcharts",h.version="12.2.0",h.win=typeof window<"u"?window:{},h.doc=h.win.document,h.svg=!!h.doc?.createElementNS?.(h.SVG_NS,"svg")?.createSVGRect,h.pageLang=h.doc?.documentElement?.closest("[lang]")?.lang,h.userAgent=h.win.navigator?.userAgent||"",h.isChrome=h.win.chrome,h.isFirefox=h.userAgent.indexOf("Firefox")!==-1,h.isMS=/(edge|msie|trident)/i.test(h.userAgent)&&!h.win.opera,h.isSafari=!h.isChrome&&h.userAgent.indexOf("Safari")!==-1,h.isTouchDevice=/(Mobile|Android|Windows Phone)/.test(h.userAgent),h.isWebKit=h.userAgent.indexOf("AppleWebKit")!==-1,h.deg2rad=2*Math.PI/360,h.marginNames=["plotTop","marginRight","marginBottom","plotLeft"],h.noop=function(){},h.supportsPassiveEvents=function(){let t=!1;if(!h.isMS){let e=Object.defineProperty({},"passive",{get:function(){t=!0}});h.win.addEventListener&&h.win.removeEventListener&&(h.win.addEventListener("testPassive",h.noop,e),h.win.removeEventListener("testPassive",h.noop,e))}return t}(),h.charts=[],h.composed=[],h.dateFormats={},h.seriesTypes={},h.symbolSizes={},h.chartCount=0}(V||(V={}));let P=V,{charts:Vn,doc:ni,win:ee}=P;function Ie(h,t,e,i){let s=t?"Highcharts error":"Highcharts warning";h===32&&(h=`${s}: Deprecated member`);let o=ys(h),r=o?`${s} #${h}: www.highcharts.com/errors/${h}/`:h.toString();if(i!==void 0){let a="";o&&(r+="?"),ie(i,function(n,l){a+=`
|
|
2
|
+
- ${l}: ${n}`,o&&(r+=encodeURI(l)+"="+encodeURI(n))}),r+=a}Ko(P,"displayError",{chart:e,code:h,message:r,params:i},function(){if(t)throw Error(r);ee.console&&Ie.messages.indexOf(r)===-1&&console.warn(r)}),Ie.messages.push(r)}function Yo(h,t){return parseInt(h,t||10)}function De(h){return typeof h=="string"}function hi(h){let t=Object.prototype.toString.call(h);return t==="[object Array]"||t==="[object Array Iterator]"}function fe(h,t){return!!h&&typeof h=="object"&&(!t||!hi(h))}function xs(h){return fe(h)&&typeof h.nodeType=="number"}function jo(h){let t=h?.constructor;return!!(fe(h,!0)&&!xs(h)&&t?.name&&t.name!=="Object")}function ys(h){return typeof h=="number"&&!isNaN(h)&&h<1/0&&h>-1/0}function me(h){return h!=null}function Uo(h,t,e){let i,s=De(t)&&!me(e),o=(r,a)=>{me(r)?h.setAttribute(a,r):s?(i=h.getAttribute(a))||a!=="class"||(i=h.getAttribute(a+"Name")):h.removeAttribute(a)};return De(t)?o(e,t):ie(t,o),i}function Vo(h){return hi(h)?h:[h]}function xe(h,t){let e;for(e in h||(h={}),t)h[e]=t[e];return h}function Be(){let h=arguments,t=h.length;for(let e=0;e<t;e++){let i=h[e];if(i!=null)return i}}function bs(h,t){xe(h.style,t)}function $o(h){return Math.pow(10,Math.floor(Math.log(h)/Math.LN10))}function Zo(h,t){return h>1e14?h:parseFloat(h.toPrecision(t||14))}(Ie||(Ie={})).messages=[],Math.easeInOutSine=function(h){return-.5*(Math.cos(Math.PI*h)-1)};let $n=Array.prototype.find?function(h,t){return h.find(t)}:function(h,t){let e,i=h.length;for(e=0;e<i;e++)if(t(h[e],e))return h[e]};function ie(h,t,e){for(let i in h)Object.hasOwnProperty.call(h,i)&&t.call(e||h[i],h[i],i,h)}function qo(h,t,e){function i(r,a){let n=h.removeEventListener;n&&n.call(h,r,a,!1)}function s(r){let a,n;h.nodeName&&(t?(a={})[t]=!0:a=r,ie(a,function(l,c){if(r[c])for(n=r[c].length;n--;)i(c,r[c][n].fn)}))}let o=typeof h=="function"&&h.prototype||h;if(Object.hasOwnProperty.call(o,"hcEvents")){let r=o.hcEvents;if(t){let a=r[t]||[];e?(r[t]=a.filter(function(n){return e!==n.fn}),i(t,e)):(s(r),r[t]=[])}else s(r),delete o.hcEvents}}function Ko(h,t,e,i){if(e=e||{},ni?.createEvent&&(h.dispatchEvent||h.fireEvent&&h!==P)){let s=ni.createEvent("Events");s.initEvent(t,!0,!0),e=xe(s,e),h.dispatchEvent?h.dispatchEvent(e):h.fireEvent(t,e)}else if(h.hcEvents){e.target||xe(e,{preventDefault:function(){e.defaultPrevented=!0},target:h,type:t});let s=[],o=h,r=!1;for(;o.hcEvents;)Object.hasOwnProperty.call(o,"hcEvents")&&o.hcEvents[t]&&(s.length&&(r=!0),s.unshift.apply(s,o.hcEvents[t])),o=Object.getPrototypeOf(o);r&&s.sort((a,n)=>a.order-n.order),s.forEach(a=>{a.fn.call(h,e)===!1&&e.preventDefault()})}i&&!e.defaultPrevented&&i.call(h,e)}let Zn=function(){let h=Math.random().toString(36).substring(2,9)+"-",t=0;return function(){return"highcharts-"+(F?"":h)+t++}}();ee.jQuery&&(ee.jQuery.fn.highcharts=function(){let h=[].slice.call(arguments);if(this[0])return h[0]?(new P[De(h[0])?h.shift():"Chart"](this[0],h[0],h[1]),this):Vn[Uo(this[0],"data-highcharts-chart")]});let N={addEvent:function(h,t,e,i={}){let s=typeof h=="function"&&h.prototype||h;Object.hasOwnProperty.call(s,"hcEvents")||(s.hcEvents={});let o=s.hcEvents;P.Point&&h instanceof P.Point&&h.series&&h.series.chart&&(h.series.chart.runTrackerClick=!0);let r=h.addEventListener;r&&r.call(h,t,e,!!P.supportsPassiveEvents&&{passive:i.passive===void 0?t.indexOf("touch")!==-1:i.passive,capture:!1}),o[t]||(o[t]=[]);let a={fn:e,order:typeof i.order=="number"?i.order:1/0};return o[t].push(a),o[t].sort((n,l)=>n.order-l.order),function(){qo(h,t,e)}},arrayMax:function(h){let t=h.length,e=h[0];for(;t--;)h[t]>e&&(e=h[t]);return e},arrayMin:function(h){let t=h.length,e=h[0];for(;t--;)h[t]<e&&(e=h[t]);return e},attr:Uo,clamp:function(h,t,e){return h>t?h<e?h:e:t},clearTimeout:function(h){me(h)&&clearTimeout(h)},correctFloat:Zo,createElement:function(h,t,e,i,s){let o=ni.createElement(h);return t&&xe(o,t),s&&bs(o,{padding:"0",border:"none",margin:"0"}),e&&bs(o,e),i&&i.appendChild(o),o},crisp:function(h,t=0,e){let i=t%2/2,s=e?-1:1;return(Math.round(h*s-i)+i)*s},css:bs,defined:me,destroyObjectProperties:function(h,t,e){ie(h,function(i,s){i!==t&&i?.destroy&&i.destroy(),(i?.destroy||!e)&&delete h[s]})},diffObjects:function(h,t,e,i){let s={};return function o(r,a,n,l){let c=e?a:r;ie(r,function(d,p){if(!l&&i&&i.indexOf(p)>-1&&a[p]){d=Vo(d),n[p]=[];for(let g=0;g<Math.max(d.length,a[p].length);g++)a[p][g]&&(d[g]===void 0?n[p][g]=a[p][g]:(n[p][g]={},o(d[g],a[p][g],n[p][g],l+1)))}else fe(d,!0)&&!d.nodeType?(n[p]=hi(d)?[]:{},o(d,a[p]||{},n[p],l+1),Object.keys(n[p]).length===0&&(p!=="colorAxis"||l!==0)&&delete n[p]):(r[p]!==a[p]||p in r&&!(p in a))&&p!=="__proto__"&&p!=="constructor"&&(n[p]=c[p])})}(h,t,s,0),s},discardElement:function(h){h?.parentElement?.removeChild(h)},erase:function(h,t){let e=h.length;for(;e--;)if(h[e]===t){h.splice(e,1);break}},error:Ie,extend:xe,extendClass:function(h,t){let e=function(){};return e.prototype=new h,xe(e.prototype,t),e},find:$n,fireEvent:Ko,getAlignFactor:(h="")=>({center:.5,right:1,middle:.5,bottom:1})[h]||0,getClosestDistance:function(h,t){let e,i,s,o,r=!t;return h.forEach(a=>{if(a.length>1)for(o=i=a.length-1;o>0;o--)(s=a[o]-a[o-1])<0&&!r?(t?.(),t=void 0):s&&(e===void 0||s<e)&&(e=s)}),e},getMagnitude:$o,getNestedProperty:function(h,t){let e=h.split(".");for(;e.length&&me(t);){let i=e.shift();if(i===void 0||i==="__proto__")return;if(i==="this"){let o;return fe(t)&&(o=t["@this"]),o??t}let s=t[i.replace(/[\\'"]/g,"")];if(!me(s)||typeof s=="function"||typeof s.nodeType=="number"||s===ee)return;t=s}return t},getStyle:function h(t,e,i){let s;if(e==="width"){let r=Math.min(t.offsetWidth,t.scrollWidth),a=t.getBoundingClientRect?.().width;return a<r&&a>=r-1&&(r=Math.floor(a)),Math.max(0,r-(h(t,"padding-left",!0)||0)-(h(t,"padding-right",!0)||0))}if(e==="height")return Math.max(0,Math.min(t.offsetHeight,t.scrollHeight)-(h(t,"padding-top",!0)||0)-(h(t,"padding-bottom",!0)||0));let o=ee.getComputedStyle(t,void 0);return o&&(s=o.getPropertyValue(e),Be(i,e!=="opacity")&&(s=Yo(s))),s},insertItem:function(h,t){let e,i=h.options.index,s=t.length;for(e=h.options.isInternal?s:0;e<s+1;e++)if(!t[e]||ys(i)&&i<Be(t[e].options.index,t[e]._i)||t[e].options.isInternal){t.splice(e,0,h);break}return e},isArray:hi,isClass:jo,isDOMElement:xs,isFunction:function(h){return typeof h=="function"},isNumber:ys,isObject:fe,isString:De,merge:function(h,...t){let e,i=[h,...t],s={},o=function(a,n){return typeof a!="object"&&(a={}),ie(n,function(l,c){c!=="__proto__"&&c!=="constructor"&&(!fe(l,!0)||jo(l)||xs(l)?a[c]=n[c]:a[c]=o(a[c]||{},l))}),a};h===!0&&(s=i[1],i=Array.prototype.slice.call(i,2));let r=i.length;for(e=0;e<r;e++)s=o(s,i[e]);return s},normalizeTickInterval:function(h,t,e,i,s){let o,r=h;e=Be(e,$o(h));let a=h/e;for(!t&&(t=s?[1,1.2,1.5,2,2.5,3,4,5,6,8,10]:[1,2,2.5,5,10],i===!1&&(e===1?t=t.filter(function(n){return n%1==0}):e<=.1&&(t=[1/e]))),o=0;o<t.length&&(r=t[o],(!s||!(r*e>=h))&&(s||!(a<=(t[o]+(t[o+1]||t[o]))/2)));o++);return Zo(r*e,-Math.round(Math.log(.001)/Math.LN10))},objectEach:ie,offset:function(h){let t=ni.documentElement,e=h.parentElement||h.parentNode?h.getBoundingClientRect():{top:0,left:0,width:0,height:0};return{top:e.top+(ee.pageYOffset||t.scrollTop)-(t.clientTop||0),left:e.left+(ee.pageXOffset||t.scrollLeft)-(t.clientLeft||0),width:e.width,height:e.height}},pad:function(h,t,e){return Array((t||2)+1-String(h).replace("-","").length).join(e||"0")+h},pick:Be,pInt:Yo,pushUnique:function(h,t){return 0>h.indexOf(t)&&!!h.push(t)},relativeLength:function(h,t,e){return/%$/.test(h)?t*parseFloat(h)/100+(e||0):parseFloat(h)},removeEvent:qo,replaceNested:function(h,...t){let e,i;do for(i of(e=h,t))h=h.replace(i[0],i[1]);while(h!==e);return h},splat:Vo,stableSort:function(h,t){let e,i,s=h.length;for(i=0;i<s;i++)h[i].safeI=i;for(h.sort(function(o,r){return(e=t(o,r))===0?o.safeI-r.safeI:e}),i=0;i<s;i++)delete h[i].safeI},syncTimeout:function(h,t,e){return t>0?setTimeout(h,t,e):(h.call(0,e),-1)},timeUnits:{millisecond:1,second:1e3,minute:6e4,hour:36e5,day:864e5,week:6048e5,month:24192e5,year:314496e5},ucfirst:function(h){return De(h)?h.substring(0,1).toUpperCase()+h.substring(1):String(h)},uniqueKey:Zn,useSerialIds:function(h){return F=Be(h,F)},wrap:function(h,t,e){let i=h[t];h[t]=function(){let s=arguments,o=this;return e.apply(this,[function(){return i.apply(o,arguments.length?arguments:s)}].concat([].slice.call(arguments)))}}},{pageLang:qn,win:li}=P,{defined:_o,error:Jo,extend:vs,isNumber:Qo,isObject:ks,isString:Ne,merge:Kn,objectEach:_n,pad:Ft,splat:Jn,timeUnits:ws,ucfirst:Qn}=N,th=P.isSafari&&li.Intl&&!li.Intl.DateTimeFormat.prototype.formatRange,eh=h=>h.main===void 0,ih=class{constructor(h,t){this.options={timezone:"UTC"},this.variableTimezone=!1,this.Date=li.Date,this.update(h),this.lang=t}update(h={}){this.dTLCache={},this.options=h=Kn(!0,this.options,h);let{timezoneOffset:t,useUTC:e}=h;this.Date=h.Date||li.Date||Date;let i=h.timezone;_o(e)&&(i=e?"UTC":void 0),t&&t%60==0&&(i="Etc/GMT"+(t>0?"+":"")+t/60),this.variableTimezone=i!=="UTC"&&i?.indexOf("Etc/GMT")!==0,this.timezone=i,["months","shortMonths","weekdays","shortWeekdays"].forEach(s=>{let o=/months/i.test(s),r=/short/.test(s),a={timeZone:"UTC"};a[o?"month":"weekday"]=r?"short":"long",this[s]=(o?[0,1,2,3,4,5,6,7,8,9,10,11]:[3,4,5,6,7,8,9]).map(n=>this.dateFormat(a,(o?31:1)*24*36e5*n))})}toParts(h){let[t,e,i,s,o,r,a]=this.dateTimeFormat({weekday:"narrow",day:"numeric",month:"numeric",year:"numeric",hour:"numeric",minute:"numeric",second:"numeric"},h,"es").split(/(?:, | |\/|:)/g);return[s,+i-1,e,o,r,a,Math.floor(Number(h)||0)%1e3,"DLMXJVS".indexOf(t)].map(Number)}dateTimeFormat(h,t,e=this.options.locale||qn){let i=JSON.stringify(h)+e;Ne(h)&&(h=this.str2dtf(h));let s=this.dTLCache[i];if(!s){h.timeZone??(h.timeZone=this.timezone);try{s=new Intl.DateTimeFormat(e,h)}catch(o){/Invalid time zone/i.test(o.message)?(Jo(34),h.timeZone="UTC",s=new Intl.DateTimeFormat(e,h)):Jo(o.message,!1)}}return this.dTLCache[i]=s,s?.format(t)||""}str2dtf(h,t={}){let e={L:{fractionalSecondDigits:3},S:{second:"2-digit"},M:{minute:"numeric"},H:{hour:"2-digit"},k:{hour:"numeric"},E:{weekday:"narrow"},a:{weekday:"short"},A:{weekday:"long"},d:{day:"2-digit"},e:{day:"numeric"},b:{month:"short"},B:{month:"long"},m:{month:"2-digit"},o:{month:"numeric"},y:{year:"2-digit"},Y:{year:"numeric"}};return Object.keys(e).forEach(i=>{h.indexOf(i)!==-1&&vs(t,e[i])}),t}makeTime(h,t,e=1,i=0,s,o,r){let a=this.Date.UTC(h,t,e,i,s||0,o||0,r||0);if(this.timezone!=="UTC"){let n=this.getTimezoneOffset(a);if(a+=n,[2,3,8,9,10,11].indexOf(t)!==-1&&(i<5||i>20)){let l=this.getTimezoneOffset(a);n!==l?a+=l-n:n-36e5!==this.getTimezoneOffset(a-36e5)||th||(a-=36e5)}}return a}parse(h){if(!Ne(h))return h??void 0;let t=(h=h.replace(/\//g,"-").replace(/(GMT|UTC)/,"")).indexOf("Z")>-1||/([+-][0-9]{2}):?[0-9]{2}$/.test(h),e=/^[0-9]{4}-[0-9]{2}(-[0-9]{2}|)$/.test(h);t||e||(h+="Z");let i=Date.parse(h);if(Qo(i))return i+(!t||e?this.getTimezoneOffset(i):0)}getTimezoneOffset(h){if(this.timezone!=="UTC"){let[t,e,i,s,o=0]=this.dateTimeFormat({timeZoneName:"shortOffset"},h,"en").split(/(GMT|:)/).map(Number),r=-(36e5*(i+o/60));if(Qo(r))return r}return 0}dateFormat(h,t,e){let i=this.lang;if(!_o(t)||isNaN(t))return i?.invalidDate||"";if(Ne(h=h??"%Y-%m-%d %H:%M:%S")){let s,o=/%\[([a-zA-Z]+)\]/g;for(;s=o.exec(h);)h=h.replace(s[0],this.dateTimeFormat(s[1],t,i?.locale))}if(Ne(h)&&h.indexOf("%")!==-1){let s=this,[o,r,a,n,l,c,d,p]=this.toParts(t),g=i?.weekdays||this.weekdays,u=i?.shortWeekdays||this.shortWeekdays,f=i?.months||this.months,x=i?.shortMonths||this.shortMonths;_n(vs({a:u?u[p]:g[p].substr(0,3),A:g[p],d:Ft(a),e:Ft(a,2," "),w:p,v:i?.weekFrom??"",b:x[r],B:f[r],m:Ft(r+1),o:r+1,y:o.toString().substr(2,2),Y:o,H:Ft(n),k:n,I:Ft(n%12||12),l:n%12||12,M:Ft(l),p:n<12?"AM":"PM",P:n<12?"am":"pm",S:Ft(c),L:Ft(d,3)},P.dateFormats),function(m,y){if(Ne(h))for(;h.indexOf("%"+y)!==-1;)h=h.replace("%"+y,typeof m=="function"?m.call(s,t):m)})}else if(ks(h)){let s=(this.getTimezoneOffset(t)||0)/36e5,o=this.timezone||"Etc/GMT"+(s>=0?"+":"")+s,{prefix:r="",suffix:a=""}=h;h=r+this.dateTimeFormat(vs({timeZone:o},h),t)+a}return e?Qn(h):h}resolveDTLFormat(h){return ks(h,!0)?ks(h,!0)&&eh(h)?{main:h}:h:{main:(h=Jn(h))[0],from:h[1],to:h[2]}}getDateFormat(h,t,e,i){let s=this.dateFormat("%m-%d %H:%M:%S.%L",t),o="01-01 00:00:00.000",r={millisecond:15,second:12,minute:9,hour:6,day:3},a="millisecond",n=a;for(a in ws){if(h&&h===ws.week&&+this.dateFormat("%w",t)===e&&s.substr(6)===o.substr(6)){a="week";break}if(h&&ws[a]>h){a=n;break}if(r[a]&&s.substr(r[a])!==o.substr(r[a]))break;a!=="week"&&(n=a)}return this.resolveDTLFormat(i[a]).main}},{defined:tr,extend:sh,timeUnits:rt}=N,Ms=class extends ih{getTimeTicks(h,t,e,i){let s=this,o=[],r={},{count:a=1,unitRange:n}=h,[l,c,d,p,g,u]=s.toParts(t),f=(t||0)%1e3,x;if(i??(i=1),tr(t)){if(f=n>=rt.second?0:a*Math.floor(f/a),n>=rt.second&&(u=n>=rt.minute?0:a*Math.floor(u/a)),n>=rt.minute&&(g=n>=rt.hour?0:a*Math.floor(g/a)),n>=rt.hour&&(p=n>=rt.day?0:a*Math.floor(p/a)),n>=rt.day&&(d=n>=rt.month?1:Math.max(1,a*Math.floor(d/a))),n>=rt.month&&(c=n>=rt.year?0:a*Math.floor(c/a)),n>=rt.year&&(l-=l%a),n===rt.week){a&&(t=s.makeTime(l,c,d,p,g,u,f));let b=this.dateTimeFormat({timeZone:this.timezone,weekday:"narrow"},t,"es"),v="DLMXJVS".indexOf(b);d+=-v+i+(v<i?-7:0)}t=s.makeTime(l,c,d,p,g,u,f),s.variableTimezone&&tr(e)&&(x=e-t>4*rt.month||s.getTimezoneOffset(t)!==s.getTimezoneOffset(e));let m=t,y=1;for(;m<e;)o.push(m),n===rt.year?m=s.makeTime(l+y*a,0):n===rt.month?m=s.makeTime(l,c+y*a):x&&(n===rt.day||n===rt.week)?m=s.makeTime(l,c,d+y*a*(n===rt.day?1:7)):x&&n===rt.hour&&a>1?m=s.makeTime(l,c,d,p+y*a):m+=n*a,y++;o.push(m),n<=rt.hour&&o.length<1e4&&o.forEach(b=>{b%18e5==0&&s.dateFormat("%H%M%S%L",b)==="000000000"&&(r[b]="day")})}return o.info=sh(h,{higherRanks:r,totalRange:n*a}),o}},{isTouchDevice:oh}=P,{fireEvent:rh,merge:ah}=N,zt={colors:["#2caffe","#544fc5","#00e272","#fe6a35","#6b8abc","#d568fb","#2ee0ca","#fa4b42","#feb56a","#91e8e1"],symbols:["circle","diamond","square","triangle","triangle-down"],lang:{weekFrom:"week from",chartTitle:"Chart title",locale:void 0,loading:"Loading...",months:void 0,seriesName:"Series {add index 1}",shortMonths:void 0,weekdays:void 0,numericSymbols:["k","M","G","T","P","E"],pieSliceName:"Slice",resetZoom:"Reset zoom",yAxisTitle:"Values",resetZoomTitle:"Reset zoom level 1:1"},global:{buttonTheme:{fill:"#f7f7f7",padding:8,r:2,stroke:"#cccccc","stroke-width":1,style:{color:"#333333",cursor:"pointer",fontSize:"0.8em",fontWeight:"normal"},states:{hover:{fill:"#e6e6e6"},select:{fill:"#e6e9ff",style:{color:"#000000",fontWeight:"bold"}},disabled:{style:{color:"#cccccc"}}}}},time:{Date:void 0,timezone:"UTC",timezoneOffset:0,useUTC:void 0},chart:{alignThresholds:!1,panning:{enabled:!1,type:"x"},styledMode:!1,borderRadius:0,colorCount:10,allowMutatingData:!0,ignoreHiddenSeries:!0,spacing:[10,10,15,10],resetZoomButton:{theme:{},position:{}},reflow:!0,type:"line",zooming:{singleTouch:!1,resetButton:{theme:{zIndex:6},position:{align:"right",x:-10,y:10}}},width:null,height:null,borderColor:"#334eff",backgroundColor:"#ffffff",plotBorderColor:"#cccccc"},title:{style:{color:"#333333",fontWeight:"bold"},text:"Chart title",margin:15,minScale:.67},subtitle:{style:{color:"#666666",fontSize:"0.8em"},text:""},caption:{margin:15,style:{color:"#666666",fontSize:"0.8em"},text:"",align:"left",verticalAlign:"bottom"},plotOptions:{},legend:{enabled:!0,align:"center",alignColumns:!0,className:"highcharts-no-tooltip",events:{},layout:"horizontal",itemMarginBottom:2,itemMarginTop:2,labelFormatter:function(){return this.name},borderColor:"#999999",borderRadius:0,navigation:{style:{fontSize:"0.8em"},activeColor:"#0022ff",inactiveColor:"#cccccc"},itemStyle:{color:"#333333",cursor:"pointer",fontSize:"0.8em",textDecoration:"none",textOverflow:"ellipsis"},itemHoverStyle:{color:"#000000"},itemHiddenStyle:{color:"#666666",textDecoration:"line-through"},shadow:!1,itemCheckboxStyle:{position:"absolute",width:"13px",height:"13px"},squareSymbol:!0,symbolPadding:5,verticalAlign:"bottom",x:0,y:0,title:{style:{fontSize:"0.8em",fontWeight:"bold"}}},loading:{labelStyle:{fontWeight:"bold",position:"relative",top:"45%"},style:{position:"absolute",backgroundColor:"#ffffff",opacity:.5,textAlign:"center"}},tooltip:{enabled:!0,animation:{duration:300,easing:h=>Math.sqrt(1-Math.pow(h-1,2))},borderRadius:3,dateTimeLabelFormats:{millisecond:"%[AebHMSL]",second:"%[AebHMS]",minute:"%[AebHM]",hour:"%[AebHM]",day:"%[AebY]",week:"%v %[AebY]",month:"%[BY]",year:"%Y"},footerFormat:"",headerShape:"callout",hideDelay:500,padding:8,position:{x:0,y:3},shared:!1,snap:oh?25:10,headerFormat:'<span style="font-size: 0.8em">{ucfirst point.key}</span><br/>',pointFormat:'<span style="color:{point.color}">\u25CF</span> {series.name}: <b>{point.y}</b><br/>',backgroundColor:"#ffffff",borderWidth:void 0,stickOnContact:!1,style:{color:"#333333",cursor:"default",fontSize:"0.8em"},useHTML:!1},credits:{enabled:!0,href:"https://www.highcharts.com?credits",position:{align:"right",x:-10,verticalAlign:"bottom",y:-5},style:{cursor:"pointer",color:"#999999",fontSize:"0.6em"},text:"Highcharts.com"}},Ss=new Ms(zt.time,zt.lang),kt={defaultOptions:zt,defaultTime:Ss,getOptions:function(){return zt},setOptions:function(h){return rh(P,"setOptions",{options:h}),ah(!0,zt,h),h.time&&Ss.update(zt.time),h.lang&&"locale"in h.lang&&Ss.update({locale:h.lang.locale}),h.lang?.chartTitle&&(zt.title=Ht(vt({},zt.title),{text:h.lang.chartTitle})),zt}},{win:nh}=P,{isNumber:ze,isString:hh,merge:lh,pInt:mt,defined:er}=N,ir=(h,t,e)=>`color-mix(in srgb,${h},${t} ${100*e}%)`,Cs=h=>hh(h)&&!!h&&h!=="none";class tt{static parse(t){return t?new tt(t):tt.None}constructor(t){let e,i,s,o;this.rgba=[NaN,NaN,NaN,NaN],this.input=t;let r=P.Color;if(r&&r!==tt)return new r(t);if(typeof t=="object"&&t.stops!==void 0)this.stops=t.stops.map(a=>new tt(a[1]));else if(typeof t=="string")for(this.input=t=tt.names[t.toLowerCase()]||t,s=tt.parsers.length;s--&&!i;)(e=(o=tt.parsers[s]).regex.exec(t))&&(i=o.parse(e));i&&(this.rgba=i)}get(t){let e=this.input,i=this.rgba;if(this.output)return this.output;if(typeof e=="object"&&this.stops!==void 0){let s=lh(e);return s.stops=[].slice.call(s.stops),this.stops.forEach((o,r)=>{s.stops[r]=[s.stops[r][0],o.get(t)]}),s}return i&&ze(i[0])?t!=="rgb"&&(t||i[3]!==1)?t==="a"?`${i[3]}`:"rgba("+i.join(",")+")":"rgb("+i[0]+","+i[1]+","+i[2]+")":e}brighten(t){let e=this.rgba;if(this.stops)this.stops.forEach(function(i){i.brighten(t)});else if(ze(t)&&t!==0)if(ze(e[0]))for(let i=0;i<3;i++)e[i]+=mt(255*t),e[i]<0&&(e[i]=0),e[i]>255&&(e[i]=255);else tt.useColorMix&&Cs(this.input)&&(this.output=ir(this.input,t>0?"white":"black",Math.abs(t)));return this}setOpacity(t){return this.rgba[3]=t,this}tweenTo(t,e){let i=this.rgba,s=t.rgba;if(!ze(i[0])||!ze(s[0]))return tt.useColorMix&&Cs(this.input)&&Cs(t.input)&&e<.99?ir(this.input,t.input,e):t.input||"none";let o=s[3]!==1||i[3]!==1,r=(n,l)=>n+(i[l]-n)*(1-e),a=s.slice(0,3).map(r).map(Math.round);return o&&a.push(r(s[3],3)),(o?"rgba(":"rgb(")+a.join(",")+")"}}tt.names={white:"#ffffff",black:"#000000"},tt.parsers=[{regex:/rgba\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d?(?:\.\d+)?)\s*\)/,parse:function(h){return[mt(h[1]),mt(h[2]),mt(h[3]),parseFloat(h[4],10)]}},{regex:/rgb\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*\)/,parse:function(h){return[mt(h[1]),mt(h[2]),mt(h[3]),1]}},{regex:/^#([a-f0-9])([a-f0-9])([a-f0-9])([a-f0-9])?$/i,parse:function(h){return[mt(h[1]+h[1],16),mt(h[2]+h[2],16),mt(h[3]+h[3],16),er(h[4])?mt(h[4]+h[4],16)/255:1]}},{regex:/^#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})?$/i,parse:function(h){return[mt(h[1],16),mt(h[2],16),mt(h[3],16),er(h[4])?mt(h[4],16)/255:1]}}],tt.useColorMix=nh.CSS?.supports("color","color-mix(in srgb,red,blue 9%)"),tt.None=new tt("");let{parse:sr}=tt,{win:dh}=P,{isNumber:Ts,objectEach:ch}=N,se=(()=>{class h{constructor(e,i,s){this.pos=NaN,this.options=i,this.elem=e,this.prop=s}dSetter(){let e=this.paths,i=e?.[0],s=e?.[1],o=this.now||0,r=[];if(o!==1&&i&&s)if(i.length===s.length&&o<1)for(let a=0;a<s.length;a++){let n=i[a],l=s[a],c=[];for(let d=0;d<l.length;d++){let p=n[d],g=l[d];Ts(p)&&Ts(g)&&(l[0]!=="A"||d!==4&&d!==5)?c[d]=p+o*(g-p):c[d]=g}r.push(c)}else r=s;else r=this.toD||[];this.elem.attr("d",r,void 0,!0)}update(){let e=this.elem,i=this.prop,s=this.now,o=this.options.step;this[i+"Setter"]?this[i+"Setter"]():e.attr?e.element&&e.attr(i,s,null,!0):e.style[i]=s+this.unit,o&&o.call(e,s,this)}run(e,i,s){let o=this,r=o.options,a=function(c){return!a.stopped&&o.step(c)},n=dh.requestAnimationFrame||function(c){setTimeout(c,13)},l=function(){for(let c=0;c<h.timers.length;c++)h.timers[c]()||h.timers.splice(c--,1);h.timers.length&&n(l)};e!==i||this.elem["forceAnimate:"+this.prop]?(this.startTime=+new Date,this.start=e,this.end=i,this.unit=s,this.now=this.start,this.pos=0,a.elem=this.elem,a.prop=this.prop,a()&&h.timers.push(a)===1&&n(l)):(delete r.curAnim[this.prop],r.complete&&Object.keys(r.curAnim).length===0&&r.complete.call(this.elem))}step(e){let i,s,o=+new Date,r=this.options,a=this.elem,n=r.complete,l=r.duration,c=r.curAnim;return a.attr&&!a.element?i=!1:e||o>=l+this.startTime?(this.now=this.end,this.pos=1,this.update(),c[this.prop]=!0,s=!0,ch(c,function(d){d!==!0&&(s=!1)}),s&&n&&n.call(a),i=!1):(this.pos=r.easing((o-this.startTime)/l),this.now=this.start+(this.end-this.start)*this.pos,this.update(),i=!0),i}initPath(e,i,s){let o=e.startX,r=e.endX,a=s.slice(),n=e.isArea,l=n?2:1,c=i&&s.length>i.length&&s.hasStackedCliffs,d,p,g,u,f=i?.slice();if(!f||c)return[a,a];function x(y,b){for(;y.length<p;){let v=y[0],S=b[p-y.length];if(S&&v[0]==="M"&&(S[0]==="C"?y[0]=["C",v[1],v[2],v[1],v[2],v[1],v[2]]:y[0]=["L",v[1],v[2]]),y.unshift(v),n){let w=y.pop();y.push(y[y.length-1],w)}}}function m(y){for(;y.length<p;){let b=y[Math.floor(y.length/l)-1].slice();if(b[0]==="C"&&(b[1]=b[5],b[2]=b[6]),n){let v=y[Math.floor(y.length/l)].slice();y.splice(y.length/2,0,b,v)}else y.push(b)}}if(o&&r&&r.length){for(g=0;g<o.length;g++){if(o[g]===r[0]){d=g;break}if(o[0]===r[r.length-o.length+g]){d=g,u=!0;break}if(o[o.length-1]===r[r.length-o.length+g]){d=o.length-g;break}}d===void 0&&(f=[])}return f.length&&Ts(d)&&(p=a.length+d*l,u?(x(f,a),m(a)):(x(a,f),m(f))),[f,a]}fillSetter(){h.prototype.strokeSetter.apply(this,arguments)}strokeSetter(){this.elem.attr(this.prop,sr(this.start).tweenTo(sr(this.end),this.pos),void 0,!0)}}return h.timers=[],h})(),{defined:ph,getStyle:gh,isArray:uh,isNumber:fh,isObject:As,merge:or,objectEach:mh,pick:xh}=N;function Ps(h){return As(h)?or({duration:500,defer:0},h):{duration:500*!!h,defer:0}}function rr(h,t){let e=se.timers.length;for(;e--;)se.timers[e].elem!==h||t&&t!==se.timers[e].prop||(se.timers[e].stopped=!0)}let dt={animate:function(h,t,e){let i,s="",o,r,a;As(e)||(a=arguments,e={duration:a[2],easing:a[3],complete:a[4]}),fh(e.duration)||(e.duration=400),e.easing=typeof e.easing=="function"?e.easing:Math[e.easing]||Math.easeInOutSine,e.curAnim=or(t),mh(t,function(n,l){rr(h,l),r=new se(h,e,l),o=void 0,l==="d"&&uh(t.d)?(r.paths=r.initPath(h,h.pathArray,t.d),r.toD=t.d,i=0,o=1):h.attr?i=h.attr(l):(i=parseFloat(gh(h,l))||0,l!=="opacity"&&(s="px")),o||(o=n),typeof o=="string"&&o.match("px")&&(o=o.replace(/px/g,"")),r.run(i,o,s)})},animObject:Ps,getDeferredAnimation:function(h,t,e){let i=Ps(t),s=e?[e]:h.series,o=0,r=0;return s.forEach(a=>{let n=Ps(a.options.animation);o=As(t)&&ph(t.defer)?i.defer:Math.max(o,n.duration+n.defer),r=Math.min(i.duration,n.duration)}),h.renderer.forExport&&(o=0),{defer:Math.max(0,o-r),duration:Math.min(o,r)}},setAnimation:function(h,t){t.renderer.globalAnimation=xh(h,t.options.chart.animation,!0)},stop:rr},{SVG_NS:ar,win:yh}=P,{attr:bh,createElement:vh,css:kh,error:nr,isFunction:wh,isString:hr,objectEach:lr,splat:Mh}=N,{trustedTypes:Os}=yh,di=Os&&wh(Os.createPolicy)&&Os.createPolicy("highcharts",{createHTML:h=>h}),Sh=di?di.createHTML(""):"";class _{static filterUserAttributes(t){return lr(t,(e,i)=>{let s=!0;_.allowedAttributes.indexOf(i)===-1&&(s=!1),["background","dynsrc","href","lowsrc","src"].indexOf(i)!==-1&&(s=hr(e)&&_.allowedReferences.some(o=>e.indexOf(o)===0)),s||(nr(33,!1,void 0,{"Invalid attribute in config":`${i}`}),delete t[i]),hr(e)&&t[i]&&(t[i]=e.replace(/</g,"<"))}),t}static parseStyle(t){return t.split(";").reduce((e,i)=>{let s=i.split(":").map(r=>r.trim()),o=s.shift();return o&&s.length&&(e[o.replace(/-([a-z])/g,r=>r[1].toUpperCase())]=s.join(":")),e},{})}static setElementHTML(t,e){t.innerHTML=_.emptyHTML,e&&new _(e).addToDOM(t)}constructor(t){this.nodes=typeof t=="string"?this.parseMarkup(t):t}addToDOM(t){return function e(i,s){let o;return Mh(i).forEach(function(r){let a,n=r.tagName,l=r.textContent?P.doc.createTextNode(r.textContent):void 0,c=_.bypassHTMLFiltering;if(n)if(n==="#text")a=l;else if(_.allowedTags.indexOf(n)!==-1||c){let d=n==="svg"?ar:s.namespaceURI||ar,p=P.doc.createElementNS(d,n),g=r.attributes||{};lr(r,function(u,f){f!=="tagName"&&f!=="attributes"&&f!=="children"&&f!=="style"&&f!=="textContent"&&(g[f]=u)}),bh(p,c?g:_.filterUserAttributes(g)),r.style&&kh(p,r.style),l&&p.appendChild(l),e(r.children||[],p),a=p}else nr(33,!1,void 0,{"Invalid tagName in config":n});a&&s.appendChild(a),o=a}),o}(this.nodes,t)}parseMarkup(t){let e,i=[];t=t.trim().replace(/ style=(["'])/g," data-style=$1");try{e=new DOMParser().parseFromString(di?di.createHTML(t):t,"text/html")}catch{}if(!e){let o=vh("div");o.innerHTML=t,e={body:o}}let s=(o,r)=>{let a=o.nodeName.toLowerCase(),n={tagName:a};a==="#text"&&(n.textContent=o.textContent||"");let l=o.attributes;if(l){let c={};[].forEach.call(l,d=>{d.name==="data-style"?n.style=_.parseStyle(d.value):c[d.name]=d.value}),n.attributes=c}if(o.childNodes.length){let c=[];[].forEach.call(o.childNodes,d=>{s(d,c)}),c.length&&(n.children=c)}r.push(n)};return[].forEach.call(e.body.childNodes,o=>s(o,i)),i}}_.allowedAttributes=["alt","aria-controls","aria-describedby","aria-expanded","aria-haspopup","aria-hidden","aria-label","aria-labelledby","aria-live","aria-pressed","aria-readonly","aria-roledescription","aria-selected","class","clip-path","color","colspan","cx","cy","d","dx","dy","disabled","fill","filterUnits","flood-color","flood-opacity","height","href","id","in","in2","markerHeight","markerWidth","offset","opacity","operator","orient","padding","paddingLeft","paddingRight","patternUnits","r","radius","refX","refY","role","scope","slope","src","startOffset","stdDeviation","stroke","stroke-linecap","stroke-width","style","tableValues","result","rowspan","summary","target","tabindex","text-align","text-anchor","textAnchor","textLength","title","type","valign","width","x","x1","x2","xlink:href","y","y1","y2","zIndex"],_.allowedReferences=["https://","http://","mailto:","/","../","./","#"],_.allowedTags=["a","abbr","b","br","button","caption","circle","clipPath","code","dd","defs","div","dl","dt","em","feComponentTransfer","feComposite","feDropShadow","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feMorphology","feOffset","feMerge","feMergeNode","filter","h1","h2","h3","h4","h5","h6","hr","i","img","li","linearGradient","marker","ol","p","path","pattern","pre","rect","small","span","stop","strong","style","sub","sup","svg","table","text","textPath","thead","title","tbody","tspan","td","th","tr","u","ul","#text"],_.emptyHTML=Sh,_.bypassHTMLFiltering=!1;let{defaultOptions:dr,defaultTime:cr}=kt,{pageLang:Ch}=P,{extend:Th,getNestedProperty:Ah,isArray:Ph,isNumber:pr,isObject:Oh,isString:Lh,pick:Eh,ucfirst:Ih}=N,ci={add:(h,t)=>h+t,divide:(h,t)=>t!==0?h/t:"",eq:(h,t)=>h==t,each:function(h){let t=arguments[arguments.length-1];return!!Ph(h)&&h.map((e,i)=>pi(t.body,Th(Oh(e)?e:{"@this":e},{"@index":i,"@first":i===0,"@last":i===h.length-1}))).join("")},ge:(h,t)=>h>=t,gt:(h,t)=>h>t,if:h=>!!h,le:(h,t)=>h<=t,lt:(h,t)=>h<t,multiply:(h,t)=>h*t,ne:(h,t)=>h!=t,subtract:(h,t)=>h-t,ucfirst:Ih,unless:h=>!h},gr={},ur=h=>/^["'].+["']$/.test(h);function pi(h="",t,e){let i=/\{([a-zA-Z\u00C0-\u017F\d:\.,;\-\/<>\[\]%_@+"'’= #\(\)]+)\}/g,s=/\(([a-zA-Z\u00C0-\u017F\d:\.,;\-\/<>\[\]%_@+"'= ]+)\)/g,o=[],r=/f$/,a=/\.(\d)/,n=e?.options?.lang||dr.lang,l=e?.time||cr,c=e?.numberFormatter||fr,d=(x="")=>{let m;return x==="true"||x!=="false"&&((m=Number(x)).toString()===x?m:ur(x)?x.slice(1,-1):Ah(x,t))},p,g,u=0,f;for(;(p=i.exec(h))!==null;){let x=p,m=s.exec(p[1]);m&&(p=m,f=!0),g?.isBlock||(g={ctx:t,expression:p[1],find:p[0],isBlock:p[1].charAt(0)==="#",start:p.index,startInner:p.index+p[0].length,length:p[0].length});let y=(g.isBlock?x:p)[1].split(" ")[0].replace("#","");ci[y]&&(g.isBlock&&y===g.fn&&u++,g.fn||(g.fn=y));let b=p[1]==="else";if(g.isBlock&&g.fn&&(p[1]===`/${g.fn}`||b))if(u)!b&&u--;else{let v=g.startInner,S=h.substr(v,p.index-v);g.body===void 0?(g.body=S,g.startInner=p.index+p[0].length):g.elseBody=S,g.find+=S+p[0],b||(o.push(g),g=void 0)}else g.isBlock||o.push(g);if(m&&!g?.isBlock)break}return o.forEach(x=>{let m,y,{body:b,elseBody:v,expression:S,fn:w}=x;if(w){let k=[x],M=[],C=S.length,T=0,A;for(y=0;y<=C;y++){let O=S.charAt(y);A||O!=='"'&&O!=="'"?A===O&&(A=""):A=O,A||O!==" "&&y!==C||(M.push(S.substr(T,y-T)),T=y+1)}for(y=ci[w].length;y--;)k.unshift(d(M[y+1]));m=ci[w].apply(t,k),x.isBlock&&typeof m=="boolean"&&(m=pi(m?b:v,t,e))}else{let k=ur(S)?[S]:S.split(":");if(m=d(k.shift()||""),k.length&&typeof m=="number"){let M=k.join(":");if(r.test(M)){let C=parseInt((M.match(a)||["","-1"])[1],10);m!==null&&(m=c(m,C,n.decimalPoint,M.indexOf(",")>-1?n.thousandsSep:""))}else m=l.dateFormat(M,m)}s.lastIndex=0,s.test(x.find)&&Lh(m)&&(m=`"${m}"`)}h=h.replace(x.find,Eh(m,""))}),f?pi(h,t,e):h}function fr(h,t,e,i){t*=1;let s,o,[r,a]=(h=+h||0).toString().split("e").map(Number),n=this?.options?.lang||dr.lang,l=(h.toString().split(".")[1]||"").split("e")[0].length,c=t,d={};e??(e=n.decimalPoint),i??(i=n.thousandsSep),t===-1?t=Math.min(l,20):pr(t)?t&&a<0&&((o=t+a)>=0?(r=+r.toExponential(o).split("e")[0],t=o):(r=Math.floor(r),h=t<20?+(r*Math.pow(10,a)).toFixed(t):0,a=0)):t=2,a&&(t??(t=2),h=r),pr(t)&&t>=0&&(d.minimumFractionDigits=t,d.maximumFractionDigits=t),i===""&&(d.useGrouping=!1);let p=i||e,g=p?"en":this?.locale||n.locale||Ch,u=JSON.stringify(d)+g;return s=(gr[u]??(gr[u]=new Intl.NumberFormat(g,d))).format(h),p&&(s=s.replace(/([,\.])/g,"_$1").replace(/_\,/g,i??",").replace("_.",e??".")),(t||+s!=0)&&(!(a<0)||c)||(s="0"),a&&+s!=0&&(s+="e"+(a<0?"":"+")+a),s}let wt={dateFormat:function(h,t,e){return cr.dateFormat(h,t,e)},format:pi,helpers:ci,numberFormat:fr};(function(h){let t;h.rendererTypes={},h.getRendererType=function(e=t){return h.rendererTypes[e]||h.rendererTypes[t]},h.registerRendererType=function(e,i,s){h.rendererTypes[e]=i,(!t||s)&&(t=e,P.Renderer=i)}})(Q||(Q={}));let Re=Q,{clamp:Dh,pick:Bh,pushUnique:Nh,stableSort:Ls}=N;(ue||(ue={})).distribute=function h(t,e,i){let s=t,o=s.reducedLen||e,r=(b,v)=>b.target-v.target,a=[],n=t.length,l=[],c=a.push,d,p,g,u=!0,f,x,m=0,y;for(d=n;d--;)m+=t[d].size;if(m>o){for(Ls(t,(b,v)=>(v.rank||0)-(b.rank||0)),g=(y=t[0].rank===t[t.length-1].rank)?n/2:-1,p=y?g:n-1;g&&m>o;)f=t[d=Math.floor(p)],Nh(l,d)&&(m-=f.size),p+=g,y&&p>=t.length&&(g/=2,p=g);l.sort((b,v)=>v-b).forEach(b=>c.apply(a,t.splice(b,1)))}for(Ls(t,r),t=t.map(b=>({size:b.size,targets:[b.target],align:Bh(b.align,.5)}));u;){for(d=t.length;d--;)f=t[d],x=(Math.min.apply(0,f.targets)+Math.max.apply(0,f.targets))/2,f.pos=Dh(x-f.size*f.align,0,e-f.size);for(d=t.length,u=!1;d--;)d>0&&t[d-1].pos+t[d-1].size>t[d].pos&&(t[d-1].size+=t[d].size,t[d-1].targets=t[d-1].targets.concat(t[d].targets),t[d-1].align=.5,t[d-1].pos+t[d-1].size>e&&(t[d-1].pos=e-t[d-1].size),t.splice(d,1),u=!0)}return c.apply(s,a),d=0,t.some(b=>{let v=0;return(b.targets||[]).some(()=>(s[d].pos=b.pos+v,i!==void 0&&Math.abs(s[d].pos-s[d].target)>i?(s.slice(0,d+1).forEach(S=>delete S.pos),s.reducedLen=(s.reducedLen||e)-.1*e,s.reducedLen>.1*e&&h(s,e,i),!0):(v+=s[d].size,d++,!1)))}),Ls(s,r),s};let gi=ue,{animate:zh,animObject:Rh,stop:mr}=dt,{deg2rad:xr,doc:ye,svg:Wh,SVG_NS:ui,win:Hh,isFirefox:Xh}=P,{addEvent:Fh,attr:Es,createElement:Gh,crisp:fi,css:yr,defined:Lt,erase:Yh,extend:We,fireEvent:Is,getAlignFactor:Ds,isArray:br,isFunction:vr,isNumber:jh,isObject:Uh,isString:kr,merge:Bs,objectEach:be,pick:Rt,pInt:mi,pushUnique:Vh,replaceNested:$h,syncTimeout:Zh,uniqueKey:wr}=N;class nt{_defaultGetter(t){let e=Rt(this[t+"Value"],this[t],this.element?this.element.getAttribute(t):null,0);return/^-?[\d\.]+$/.test(e)&&(e=parseFloat(e)),e}_defaultSetter(t,e,i){i.setAttribute(e,t)}add(t){let e,i=this.renderer,s=this.element;return t&&(this.parentGroup=t),this.textStr!==void 0&&this.element.nodeName==="text"&&i.buildText(this),this.added=!0,(!t||t.handleZ||this.zIndex)&&(e=this.zIndexSetter()),e||(t?t.element:i.box).appendChild(s),this.onAdd&&this.onAdd(),this}addClass(t,e){let i=e?"":this.attr("class")||"";return(t=(t||"").split(/ /g).reduce(function(s,o){return i.indexOf(o)===-1&&s.push(o),s},i?[i]:[]).join(" "))!==i&&this.attr("class",t),this}afterSetters(){this.doTransform&&(this.updateTransform(),this.doTransform=!1)}align(t,e,i,s=!0){let o=this.renderer,r=o.alignedObjects,a=!!t;t?(this.alignOptions=t,this.alignByTranslate=e,this.alignTo=i):(t=this.alignOptions||{},e=this.alignByTranslate,i=this.alignTo);let n=!i||kr(i)?i||"renderer":void 0;n&&(a&&Vh(r,this),i=void 0);let l=Rt(i,o[n],o),c=(l.x||0)+(t.x||0)+((l.width||0)-(t.width||0))*Ds(t.align),d=(l.y||0)+(t.y||0)+((l.height||0)-(t.height||0))*Ds(t.verticalAlign),p={"text-align":t?.align};return p[e?"translateX":"x"]=Math.round(c),p[e?"translateY":"y"]=Math.round(d),s&&(this[this.placed?"animate":"attr"](p),this.placed=!0),this.alignAttr=p,this}alignSetter(t){let e={left:"start",center:"middle",right:"end"};e[t]&&(this.alignValue=t,this.element.setAttribute("text-anchor",e[t]))}animate(t,e,i){let s=Rh(Rt(e,this.renderer.globalAnimation,!0)),o=s.defer;return ye.hidden&&(s.duration=0),s.duration!==0?(i&&(s.complete=i),Zh(()=>{this.element&&zh(this,t,s)},o)):(this.attr(t,void 0,i||s.complete),be(t,function(r,a){s.step&&s.step.call(this,r,{prop:a,pos:1,elem:this})},this)),this}applyTextOutline(t){let e=this.element;t.indexOf("contrast")!==-1&&(t=t.replace(/contrast/g,this.renderer.getContrast(e.style.fill)));let i=t.indexOf(" "),s=t.substring(i+1),o=t.substring(0,i);if(o&&o!=="none"&&P.svg){this.fakeTS=!0,o=o.replace(/(^[\d\.]+)(.*?)$/g,function(c,d,p){return 2*Number(d)+p}),this.removeTextOutline();let r=ye.createElementNS(ui,"tspan");Es(r,{class:"highcharts-text-outline",fill:s,stroke:s,"stroke-width":o,"stroke-linejoin":"round"});let a=e.querySelector("textPath")||e;[].forEach.call(a.childNodes,c=>{let d=c.cloneNode(!0);d.removeAttribute&&["fill","stroke","stroke-width","stroke"].forEach(p=>d.removeAttribute(p)),r.appendChild(d)});let n=0;[].forEach.call(a.querySelectorAll("text tspan"),c=>{n+=Number(c.getAttribute("dy"))});let l=ye.createElementNS(ui,"tspan");l.textContent="\u200B",Es(l,{x:Number(e.getAttribute("x")),dy:-n}),r.appendChild(l),a.insertBefore(r,a.firstChild)}}attr(t,e,i,s){let{element:o}=this,r=nt.symbolCustomAttribs,a,n,l=this,c;return typeof t=="string"&&e!==void 0&&(a=t,(t={})[a]=e),typeof t=="string"?l=(this[t+"Getter"]||this._defaultGetter).call(this,t,o):(be(t,function(d,p){c=!1,s||mr(this,p),this.symbolName&&r.indexOf(p)!==-1&&(n||(this.symbolAttr(t),n=!0),c=!0),this.rotation&&(p==="x"||p==="y")&&(this.doTransform=!0),c||(this[p+"Setter"]||this._defaultSetter).call(this,d,p,o)},this),this.afterSetters()),i&&i.call(this),l}clip(t){if(t&&!t.clipPath){let e=wr()+"-",i=this.renderer.createElement("clipPath").attr({id:e}).add(this.renderer.defs);We(t,{clipPath:i,id:e,count:0}),t.add(i)}return this.attr("clip-path",t?`url(${this.renderer.url}#${t.id})`:"none")}crisp(t,e){e=Math.round(e||t.strokeWidth||0);let i=t.x||this.x||0,s=t.y||this.y||0,o=(t.width||this.width||0)+i,r=(t.height||this.height||0)+s,a=fi(i,e),n=fi(s,e);return We(t,{x:a,y:n,width:fi(o,e)-a,height:fi(r,e)-n}),Lt(t.strokeWidth)&&(t.strokeWidth=e),t}complexColor(t,e,i){let s=this.renderer,o,r,a,n,l,c,d,p,g,u,f=[],x;Is(this.renderer,"complexColor",{args:arguments},function(){if(t.radialGradient?r="radialGradient":t.linearGradient&&(r="linearGradient"),r){if(a=t[r],l=s.gradients,c=t.stops,g=i.radialReference,br(a)&&(t[r]=a={x1:a[0],y1:a[1],x2:a[2],y2:a[3],gradientUnits:"userSpaceOnUse"}),r==="radialGradient"&&g&&!Lt(a.gradientUnits)&&(n=a,a=Bs(a,s.getRadialAttr(g,n),{gradientUnits:"userSpaceOnUse"})),be(a,function(m,y){y!=="id"&&f.push(y,m)}),be(c,function(m){f.push(m)}),l[f=f.join(",")])u=l[f].attr("id");else{a.id=u=wr();let m=l[f]=s.createElement(r).attr(a).add(s.defs);m.radAttr=n,m.stops=[],c.forEach(function(y){y[1].indexOf("rgba")===0?(d=(o=tt.parse(y[1])).get("rgb"),p=o.get("a")):(d=y[1],p=1);let b=s.createElement("stop").attr({offset:y[0],"stop-color":d,"stop-opacity":p}).add(m);m.stops.push(b)})}x="url("+s.url+"#"+u+")",i.setAttribute(e,x),i.gradient=f,t.toString=function(){return x}}})}css(t){let e=this.styles,i={},s=this.element,o,r=!e;if(e&&be(t,function(a,n){e&&e[n]!==a&&(i[n]=a,r=!0)}),r){e&&(t=We(e,i)),t.width===null||t.width==="auto"?delete this.textWidth:s.nodeName.toLowerCase()==="text"&&t.width&&(o=this.textWidth=mi(t.width)),We(this.styles,t),o&&!Wh&&this.renderer.forExport&&delete t.width;let a=Xh&&t.fontSize||null;a&&(jh(a)||/^\d+$/.test(a))&&(t.fontSize+="px");let n=Bs(t);s.namespaceURI===this.SVG_NS&&(["textOutline","textOverflow","whiteSpace","width"].forEach(l=>n&&delete n[l]),n.color&&(n.fill=n.color,delete n.color)),yr(s,n)}return this.added&&(this.element.nodeName==="text"&&this.renderer.buildText(this),t.textOutline&&this.applyTextOutline(t.textOutline)),this}dashstyleSetter(t){let e,i=this["stroke-width"];if(i==="inherit"&&(i=1),t){let s=(t=t.toLowerCase()).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(e=s.length;e--;)s[e]=""+mi(s[e])*Rt(i,NaN);t=s.join(",").replace(/NaN/g,"none"),this.element.setAttribute("stroke-dasharray",t)}}destroy(){let t=this,e=t.element||{},i=t.renderer,s=e.ownerSVGElement,o=e.nodeName==="SPAN"&&t.parentGroup||void 0,r,a;if(e.onclick=e.onmouseout=e.onmouseover=e.onmousemove=e.point=null,mr(t),t.clipPath&&s){let n=t.clipPath;[].forEach.call(s.querySelectorAll("[clip-path],[CLIP-PATH]"),function(l){l.getAttribute("clip-path").indexOf(n.element.id)>-1&&l.removeAttribute("clip-path")}),t.clipPath=n.destroy()}if(t.stops){for(a=0;a<t.stops.length;a++)t.stops[a].destroy();t.stops.length=0,t.stops=void 0}for(t.safeRemoveChild(e);o?.div&&o.div.childNodes.length===0;)r=o.parentGroup,t.safeRemoveChild(o.div),delete o.div,o=r;t.alignOptions&&Yh(i.alignedObjects,t),be(t,(n,l)=>{(t[l]?.parentGroup===t||["connector","foreignObject"].indexOf(l)!==-1)&&t[l]?.destroy?.(),delete t[l]})}dSetter(t,e,i){br(t)&&(typeof t[0]=="string"&&(t=this.renderer.pathToSegments(t)),this.pathArray=t,t=t.reduce((s,o,r)=>o?.join?(r?s+" ":"")+o.join(" "):(o||"").toString(),"")),/(NaN| {2}|^$)/.test(t)&&(t="M 0 0"),this[e]!==t&&(i.setAttribute(e,t),this[e]=t)}fillSetter(t,e,i){typeof t=="string"?i.setAttribute(e,t):t&&this.complexColor(t,e,i)}hrefSetter(t,e,i){i.setAttributeNS("http://www.w3.org/1999/xlink",e,t)}getBBox(t,e){let i,s,o,r,{alignValue:a,element:n,renderer:l,styles:c,textStr:d}=this,{cache:p,cacheKeys:g}=l,u=n.namespaceURI===this.SVG_NS,f=Rt(e,this.rotation,0),x=l.styledMode?n&&nt.prototype.getStyle.call(n,"font-size"):c.fontSize;if(Lt(d)&&((r=d.toString()).indexOf("<")===-1&&(r=r.replace(/\d/g,"0")),r+=["",l.rootFontSize,x,f,this.textWidth,a,c.lineClamp,c.textOverflow,c.fontWeight].join(",")),r&&!t&&(i=p[r]),!i||i.polygon){if(u||l.forExport){try{o=this.fakeTS&&function(y){let b=n.querySelector(".highcharts-text-outline");b&&yr(b,{display:y})},vr(o)&&o("none"),i=n.getBBox?We({},n.getBBox()):{width:n.offsetWidth,height:n.offsetHeight,x:0,y:0},vr(o)&&o("")}catch{}(!i||i.width<0)&&(i={x:0,y:0,width:0,height:0})}else i=this.htmlGetBBox();s=i.height,u&&(i.height=s={"11px,17":14,"13px,20":16}[`${x||""},${Math.round(s)}`]||s),f&&(i=this.getRotatedBox(i,f));let m={bBox:i};Is(this,"afterGetBBox",m),i=m.bBox}if(r&&(d===""||i.height>0)){for(;g.length>250;)delete p[g.shift()];p[r]||g.push(r),p[r]=i}return i}getRotatedBox(t,e){let{x:i,y:s,width:o,height:r}=t,{alignValue:a,translateY:n,rotationOriginX:l=0,rotationOriginY:c=0}=this,d=Ds(a),p=Number(this.element.getAttribute("y")||0)-(n?0:s),g=e*xr,u=(e-90)*xr,f=Math.cos(g),x=Math.sin(g),m=o*f,y=o*x,b=Math.cos(u),v=Math.sin(u),[[S,w],[k,M]]=[l,c].map(R=>[R-R*f,R*x]),C=i+d*(o-m)+S+M+p*b,T=C+m,A=T-r*b,O=A-m,L=s+p-d*y-w+k+p*v,I=L+y,D=I-r*v,E=D-y,B=Math.min(C,T,A,O),K=Math.min(L,I,D,E),Y=Math.max(C,T,A,O)-B,pt=Math.max(L,I,D,E)-K;return{x:B,y:K,width:Y,height:pt,polygon:[[C,L],[T,I],[A,D],[O,E]]}}getStyle(t){return Hh.getComputedStyle(this.element||this,"").getPropertyValue(t)}hasClass(t){return(""+this.attr("class")).split(" ").indexOf(t)!==-1}hide(){return this.attr({visibility:"hidden"})}htmlGetBBox(){return{height:0,width:0,x:0,y:0}}constructor(t,e){this.onEvents={},this.opacity=1,this.SVG_NS=ui,this.element=e==="span"||e==="body"?Gh(e):ye.createElementNS(this.SVG_NS,e),this.renderer=t,this.styles={},Is(this,"afterInit")}on(t,e){let{onEvents:i}=this;return i[t]&&i[t](),i[t]=Fh(this.element,t,e),this}opacitySetter(t,e,i){let s=Number(Number(t).toFixed(3));this.opacity=s,i.setAttribute(e,s)}reAlign(){this.alignOptions?.width&&this.alignOptions.align!=="left"&&(this.alignOptions.width=this.getBBox().width,this.placed=!1,this.align())}removeClass(t){return this.attr("class",(""+this.attr("class")).replace(kr(t)?RegExp(`(^| )${t}( |$)`):t," ").replace(/ +/g," ").trim())}removeTextOutline(){let t=this.element.querySelector("tspan.highcharts-text-outline");t&&this.safeRemoveChild(t)}safeRemoveChild(t){let e=t.parentNode;e&&e.removeChild(t)}setRadialReference(t){let e=this.element.gradient&&this.renderer.gradients[this.element.gradient]||void 0;return this.element.radialReference=t,e?.radAttr&&e.animate(this.renderer.getRadialAttr(t,e.radAttr)),this}shadow(t){let{renderer:e}=this,i=Bs(this.parentGroup?.rotation===90?{offsetX:-1,offsetY:-1}:{},Uh(t)?t:{}),s=e.shadowDefinition(i);return this.attr({filter:t?`url(${e.url}#${s})`:"none"})}show(t=!0){return this.attr({visibility:t?"inherit":"visible"})}"stroke-widthSetter"(t,e,i){this[e]=t,i.setAttribute(e,t)}strokeWidth(){if(!this.renderer.styledMode)return this["stroke-width"]||0;let t=this.getStyle("stroke-width"),e=0,i;return/px$/.test(t)?e=mi(t):t!==""&&(Es(i=ye.createElementNS(ui,"rect"),{width:t,"stroke-width":0}),this.element.parentNode.appendChild(i),e=i.getBBox().width,i.parentNode.removeChild(i)),e}symbolAttr(t){let e=this;nt.symbolCustomAttribs.forEach(function(i){e[i]=Rt(t[i],e[i])}),e.attr({d:e.renderer.symbols[e.symbolName](e.x,e.y,e.width,e.height,e)})}textSetter(t){t!==this.textStr&&(delete this.textPxLength,this.textStr=t,this.added&&this.renderer.buildText(this),this.reAlign())}titleSetter(t){let e=this.element,i=e.getElementsByTagName("title")[0]||ye.createElementNS(this.SVG_NS,"title");e.insertBefore?e.insertBefore(i,e.firstChild):e.appendChild(i),i.textContent=$h(Rt(t,""),[/<[^>]*>/g,""]).replace(/</g,"<").replace(/>/g,">")}toFront(){let t=this.element;return t.parentNode.appendChild(t),this}translate(t,e){return this.attr({translateX:t,translateY:e})}updateTransform(t="transform"){let{element:e,foreignObject:i,matrix:s,padding:o,rotation:r=0,rotationOriginX:a,rotationOriginY:n,scaleX:l,scaleY:c,text:d,translateX:p=0,translateY:g=0}=this,u=["translate("+p+","+g+")"];Lt(s)&&u.push("matrix("+s.join(",")+")"),r&&(u.push("rotate("+r+" "+(a??e.getAttribute("x")??this.x??0)+" "+(n??e.getAttribute("y")??this.y??0)+")"),d?.element.tagName!=="SPAN"||d?.foreignObject||d.attr({rotation:r,rotationOriginX:(a||0)-o,rotationOriginY:(n||0)-o})),(Lt(l)||Lt(c))&&u.push("scale("+Rt(l,1)+" "+Rt(c,1)+")"),u.length&&!(d||this).textPath&&(i?.element||e).setAttribute(t,u.join(" "))}visibilitySetter(t,e,i){t==="inherit"?i.removeAttribute(e):this[e]!==t&&i.setAttribute(e,t),this[e]=t}xGetter(t){return this.element.nodeName==="circle"&&(t==="x"?t="cx":t==="y"&&(t="cy")),this._defaultGetter(t)}zIndexSetter(t,e){let i=this.renderer,s=this.parentGroup,o=(s||i).element||i.box,r=this.element,a=o===i.box,n,l,c,d=!1,p,g=this.added,u;if(Lt(t)?(r.setAttribute("data-z-index",t),t*=1,this[e]===t&&(g=!1)):Lt(this[e])&&r.removeAttribute("data-z-index"),this[e]=t,g){for((t=this.zIndex)&&s&&(s.handleZ=!0),u=(n=o.childNodes).length-1;u>=0&&!d;u--)p=!Lt(c=(l=n[u]).getAttribute("data-z-index")),l!==r&&(t<0&&p&&!a&&!u?(o.insertBefore(r,n[u]),d=!0):(mi(c)<=t||p&&(!Lt(t)||t>=0))&&(o.insertBefore(r,n[u+1]),d=!0));d||(o.insertBefore(r,n[3*!!a]),d=!0)}return d}}nt.symbolCustomAttribs=["anchorX","anchorY","clockwise","end","height","innerR","r","start","width","x","y"],nt.prototype.strokeSetter=nt.prototype.fillSetter,nt.prototype.yGetter=nt.prototype.xGetter,nt.prototype.matrixSetter=nt.prototype.rotationOriginXSetter=nt.prototype.rotationOriginYSetter=nt.prototype.rotationSetter=nt.prototype.scaleXSetter=nt.prototype.scaleYSetter=nt.prototype.translateXSetter=nt.prototype.translateYSetter=nt.prototype.verticalAlignSetter=function(h,t){this[t]=h,this.doTransform=!0};let Et=nt,{defined:Mr,extend:qh,getAlignFactor:Sr,isNumber:He,merge:Kh,pick:xi,removeEvent:Cr}=N;class oe extends Et{constructor(t,e,i,s,o,r,a,n,l,c){let d;super(t,"g"),this.paddingLeftSetter=this.paddingSetter,this.paddingRightSetter=this.paddingSetter,this.doUpdate=!1,this.textStr=e,this.x=i,this.y=s,this.anchorX=r,this.anchorY=a,this.baseline=l,this.className=c,this.addClass(c==="button"?"highcharts-no-tooltip":"highcharts-label"),c&&this.addClass("highcharts-"+c),this.text=t.text(void 0,0,0,n).attr({zIndex:1}),typeof o=="string"&&((d=/^url\((.*?)\)$/.test(o))||this.renderer.symbols[o])&&(this.symbolKey=o),this.bBox=oe.emptyBBox,this.padding=3,this.baselineOffset=0,this.needsBox=t.styledMode||d,this.deferredAttr={},this.alignFactor=0}alignSetter(t){let e=Sr(t);this.textAlign=t,e!==this.alignFactor&&(this.alignFactor=e,this.bBox&&He(this.xSetting)&&this.attr({x:this.xSetting}))}anchorXSetter(t,e){this.anchorX=t,this.boxAttr(e,Math.round(t)-this.getCrispAdjust()-this.xSetting)}anchorYSetter(t,e){this.anchorY=t,this.boxAttr(e,t-this.ySetting)}boxAttr(t,e){this.box?this.box.attr(t,e):this.deferredAttr[t]=e}css(t){if(t){let e={};t=Kh(t),oe.textProps.forEach(i=>{t[i]!==void 0&&(e[i]=t[i],delete t[i])}),this.text.css(e),"fontSize"in e||"fontWeight"in e?this.updateTextPadding():("width"in e||"textOverflow"in e)&&this.updateBoxSize()}return Et.prototype.css.call(this,t)}destroy(){Cr(this.element,"mouseenter"),Cr(this.element,"mouseleave"),this.text&&this.text.destroy(),this.box&&(this.box=this.box.destroy()),Et.prototype.destroy.call(this)}fillSetter(t,e){t&&(this.needsBox=!0),this.fill=t,this.boxAttr(e,t)}getBBox(t,e){this.textStr&&this.bBox.width===0&&this.bBox.height===0&&this.updateBoxSize();let{padding:i,height:s=0,translateX:o=0,translateY:r=0,width:a=0}=this,n=xi(this.paddingLeft,i),l=e??(this.rotation||0),c={width:a,height:s,x:o+this.bBox.x-n,y:r+this.bBox.y-i+this.baselineOffset};return l&&(c=this.getRotatedBox(c,l)),c}getCrispAdjust(){return(this.renderer.styledMode&&this.box?this.box.strokeWidth():this["stroke-width"]?parseInt(this["stroke-width"],10):0)%2/2}heightSetter(t){this.heightSetting=t,this.doUpdate=!0}afterSetters(){super.afterSetters(),this.doUpdate&&(this.updateBoxSize(),this.doUpdate=!1)}onAdd(){this.text.add(this),this.attr({text:xi(this.textStr,""),x:this.x||0,y:this.y||0}),this.box&&Mr(this.anchorX)&&this.attr({anchorX:this.anchorX,anchorY:this.anchorY})}paddingSetter(t,e){He(t)?t!==this[e]&&(this[e]=t,this.updateTextPadding()):this[e]=void 0}rSetter(t,e){this.boxAttr(e,t)}strokeSetter(t,e){this.stroke=t,this.boxAttr(e,t)}"stroke-widthSetter"(t,e){t&&(this.needsBox=!0),this["stroke-width"]=t,this.boxAttr(e,t)}"text-alignSetter"(t){this.textAlign=this["text-align"]=t,this.updateTextPadding()}textSetter(t){t!==void 0&&this.text.attr({text:t}),this.updateTextPadding(),this.reAlign()}updateBoxSize(){let t,e=this.text,i={},s=this.padding,o=this.bBox=(!He(this.widthSetting)||!He(this.heightSetting)||this.textAlign)&&Mr(e.textStr)?e.getBBox(void 0,0):oe.emptyBBox;this.width=this.getPaddedWidth(),this.height=(this.heightSetting||o.height||0)+2*s;let r=this.renderer.fontMetrics(e);if(this.baselineOffset=s+Math.min((this.text.firstLineMetrics||r).b,o.height||1/0),this.heightSetting&&(this.baselineOffset+=(this.heightSetting-r.h)/2),this.needsBox&&!e.textPath){if(!this.box){let a=this.box=this.symbolKey?this.renderer.symbol(this.symbolKey):this.renderer.rect();a.addClass((this.className==="button"?"":"highcharts-label-box")+(this.className?" highcharts-"+this.className+"-box":"")),a.add(this)}i.x=t=this.getCrispAdjust(),i.y=(this.baseline?-this.baselineOffset:0)+t,i.width=Math.round(this.width),i.height=Math.round(this.height),this.box.attr(qh(i,this.deferredAttr)),this.deferredAttr={}}}updateTextPadding(){let t=this.text,e=t.styles.textAlign||this.textAlign;if(!t.textPath){this.updateBoxSize();let i=this.baseline?0:this.baselineOffset,s=(this.paddingLeft??this.padding)+Sr(e)*(this.widthSetting??this.bBox.width);(s!==t.x||i!==t.y)&&(t.attr({align:e,x:s}),i!==void 0&&t.attr("y",i)),t.x=s,t.y=i}}widthSetter(t){this.widthSetting=He(t)?t:void 0,this.doUpdate=!0}getPaddedWidth(){let t=this.padding,e=xi(this.paddingLeft,t),i=xi(this.paddingRight,t);return(this.widthSetting||this.bBox.width||0)+e+i}xSetter(t){this.x=t,this.alignFactor&&(t-=this.alignFactor*this.getPaddedWidth(),this["forceAnimate:x"]=!0),this.xSetting=Math.round(t),this.attr("translateX",this.xSetting)}ySetter(t){this.ySetting=this.y=Math.round(t),this.attr("translateY",this.ySetting)}}oe.emptyBBox={width:0,height:0,x:0,y:0},oe.textProps=["color","direction","fontFamily","fontSize","fontStyle","fontWeight","lineClamp","lineHeight","textAlign","textDecoration","textOutline","textOverflow","whiteSpace","width"];let{defined:Tr,isNumber:_h,pick:Xe}=N;function Ar(h,t,e,i,s){let o=[];if(s){let r=s.start||0,a=s.end||0,n=Xe(s.r,e),l=Xe(s.r,i||e),c=2e-4/(s.borderRadius?1:Math.max(n,1)),d=Math.abs(a-r-2*Math.PI)<c;d&&(r=Math.PI/2,a=2.5*Math.PI-c);let p=s.innerR,g=Xe(s.open,d),u=Math.cos(r),f=Math.sin(r),x=Math.cos(a),m=Math.sin(a),y=Xe(s.longArc,a-r-Math.PI<c?0:1),b=["A",n,l,0,y,Xe(s.clockwise,1),h+n*x,t+l*m];b.params={start:r,end:a,cx:h,cy:t},o.push(["M",h+n*u,t+l*f],b),Tr(p)&&((b=["A",p,p,0,y,Tr(s.clockwise)?1-s.clockwise:0,h+p*u,t+p*f]).params={start:a,end:r,cx:h,cy:t},o.push(g?["M",h+p*x,t+p*m]:["L",h+p*x,t+p*m],b)),g||o.push(["Z"])}return o}function Pr(h,t,e,i,s){return s?.r?Ns(h,t,e,i,s):[["M",h,t],["L",h+e,t],["L",h+e,t+i],["L",h,t+i],["Z"]]}function Ns(h,t,e,i,s){let o=s?.r||0;return[["M",h+o,t],["L",h+e-o,t],["A",o,o,0,0,1,h+e,t+o],["L",h+e,t+i-o],["A",o,o,0,0,1,h+e-o,t+i],["L",h+o,t+i],["A",o,o,0,0,1,h,t+i-o],["L",h,t+o],["A",o,o,0,0,1,h+o,t],["Z"]]}let Or={arc:Ar,callout:function(h,t,e,i,s){let o=Math.min(s?.r||0,e,i),r=o+6,a=s?.anchorX,n=s?.anchorY||0,l=Ns(h,t,e,i,{r:o});if(!_h(a)||a<e&&a>0&&n<i&&n>0)return l;if(h+a>e-r)if(n>t+r&&n<t+i-r)l.splice(3,1,["L",h+e,n-6],["L",h+e+6,n],["L",h+e,n+6],["L",h+e,t+i-o]);else if(a<e){let c=n<t+r,d=c?t:t+i;l.splice(c?2:5,0,["L",a,n],["L",h+e-o,d])}else l.splice(3,1,["L",h+e,i/2],["L",a,n],["L",h+e,i/2],["L",h+e,t+i-o]);else if(h+a<r)if(n>t+r&&n<t+i-r)l.splice(7,1,["L",h,n+6],["L",h-6,n],["L",h,n-6],["L",h,t+o]);else if(a>0){let c=n<t+r,d=c?t:t+i;l.splice(c?1:6,0,["L",a,n],["L",h+o,d])}else l.splice(7,1,["L",h,i/2],["L",a,n],["L",h,i/2],["L",h,t+o]);else n>i&&a<e-r?l.splice(5,1,["L",a+6,t+i],["L",a,t+i+6],["L",a-6,t+i],["L",h+o,t+i]):n<0&&a>r&&l.splice(1,1,["L",a-6,t],["L",a,t-6],["L",a+6,t],["L",e-o,t]);return l},circle:function(h,t,e,i){return Ar(h+e/2,t+i/2,e/2,i/2,{start:.5*Math.PI,end:2.5*Math.PI,open:!1})},diamond:function(h,t,e,i){return[["M",h+e/2,t],["L",h+e,t+i/2],["L",h+e/2,t+i],["L",h,t+i/2],["Z"]]},rect:Pr,roundedRect:Ns,square:Pr,triangle:function(h,t,e,i){return[["M",h+e/2,t],["L",h+e,t+i],["L",h,t+i],["Z"]]},"triangle-down":function(h,t,e,i){return[["M",h,t],["L",h+e,t],["L",h+e/2,t+i],["Z"]]}},{doc:zs,SVG_NS:Jh,win:Lr}=P,{attr:Rs,extend:Qh,fireEvent:tl,isString:el,objectEach:il,pick:sl}=N,Ws=(h,t)=>h.substring(0,t)+"\u2026",ol=class{constructor(h){let t=h.styles;this.renderer=h.renderer,this.svgElement=h,this.width=h.textWidth,this.textLineHeight=t?.lineHeight,this.textOutline=t?.textOutline,this.ellipsis=t?.textOverflow==="ellipsis",this.lineClamp=t?.lineClamp,this.noWrap=t?.whiteSpace==="nowrap"}buildSVG(){let h=this.svgElement,t=h.element,e=h.renderer,i=sl(h.textStr,"").toString(),s=i.indexOf("<")!==-1,o=t.childNodes,r=!h.added&&e.box,a=[i,this.ellipsis,this.noWrap,this.textLineHeight,this.textOutline,h.getStyle("font-size"),h.styles.lineClamp,this.width].join(",");if(a!==h.textCache){h.textCache=a,delete h.actualWidth;for(let n=o.length;n--;)t.removeChild(o[n]);if(s||this.ellipsis||this.width||h.textPath||i.indexOf(" ")!==-1&&(!this.noWrap||/<br.*?>/g.test(i))){if(i!==""){r&&r.appendChild(t);let n=new _(i);this.modifyTree(n.nodes),n.addToDOM(t),this.modifyDOM(),this.ellipsis&&(t.textContent||"").indexOf("\u2026")!==-1&&h.attr("title",this.unescapeEntities(h.textStr||"",["<",">"])),r&&r.removeChild(t)}}else t.appendChild(zs.createTextNode(this.unescapeEntities(i)));el(this.textOutline)&&h.applyTextOutline&&h.applyTextOutline(this.textOutline)}}modifyDOM(){let h,t=this.svgElement,e=Rs(t.element,"x");for(t.firstLineMetrics=void 0;(h=t.element.firstChild)&&/^[\s\u200B]*$/.test(h.textContent||" ");)t.element.removeChild(h);[].forEach.call(t.element.querySelectorAll("tspan.highcharts-br"),(r,a)=>{r.nextSibling&&r.previousSibling&&(a===0&&r.previousSibling.nodeType===1&&(t.firstLineMetrics=t.renderer.fontMetrics(r.previousSibling)),Rs(r,{dy:this.getLineHeight(r.nextSibling),x:e}))});let i=this.width||0;if(!i)return;let s=(r,a)=>{let n=r.textContent||"",l=n.replace(/([^\^])-/g,"$1- ").split(" "),c=!this.noWrap&&(l.length>1||t.element.childNodes.length>1),d=this.getLineHeight(a),p=Math.max(0,i-.8*d),g=0,u=t.actualWidth;if(c){let f=[],x=[];for(;a.firstChild&&a.firstChild!==r;)x.push(a.firstChild),a.removeChild(a.firstChild);for(;l.length;)if(l.length&&!this.noWrap&&g>0&&(f.push(r.textContent||""),r.textContent=l.join(" ").replace(/- /g,"-")),this.truncate(r,void 0,l,g===0&&u||0,i,p,(m,y)=>l.slice(0,y).join(" ").replace(/- /g,"-")),u=t.actualWidth,g++,this.lineClamp&&g>=this.lineClamp){l.length&&(this.truncate(r,r.textContent||"",void 0,0,i,p,Ws),r.textContent=r.textContent?.replace("\u2026","")+"\u2026");break}x.forEach(m=>{a.insertBefore(m,r)}),f.forEach(m=>{a.insertBefore(zs.createTextNode(m),r);let y=zs.createElementNS(Jh,"tspan");y.textContent="\u200B",Rs(y,{dy:d,x:e}),a.insertBefore(y,r)})}else this.ellipsis&&n&&this.truncate(r,n,void 0,0,i,p,Ws)},o=r=>{[].slice.call(r.childNodes).forEach(a=>{a.nodeType===Lr.Node.TEXT_NODE?s(a,r):(a.className.baseVal.indexOf("highcharts-br")!==-1&&(t.actualWidth=0),o(a))})};o(t.element)}getLineHeight(h){let t=h.nodeType===Lr.Node.TEXT_NODE?h.parentElement:h;return this.textLineHeight?parseInt(this.textLineHeight.toString(),10):this.renderer.fontMetrics(t||this.svgElement.element).h}modifyTree(h){let t=(e,i)=>{let{attributes:s={},children:o,style:r={},tagName:a}=e,n=this.renderer.styledMode;if(a==="b"||a==="strong"?n?s.class="highcharts-strong":r.fontWeight="bold":(a==="i"||a==="em")&&(n?s.class="highcharts-emphasized":r.fontStyle="italic"),r?.color&&(r.fill=r.color),a==="br"){s.class="highcharts-br",e.textContent="\u200B";let l=h[i+1];l?.textContent&&(l.textContent=l.textContent.replace(/^ +/gm,""))}else a==="a"&&o&&o.some(l=>l.tagName==="#text")&&(e.children=[{children:o,tagName:"tspan"}]);a!=="#text"&&a!=="a"&&(e.tagName="tspan"),Qh(e,{attributes:s,style:r}),o&&o.filter(l=>l.tagName!=="#text").forEach(t)};h.forEach(t),tl(this.svgElement,"afterModifyTree",{nodes:h})}truncate(h,t,e,i,s,o,r){let a,n,l=this.svgElement,{rotation:c}=l,d=[],p=e&&!i?1:0,g=(t||e||"").length,u=g;e||(s=o);let f=function(x,m){let y=m||x,b=h.parentNode;if(b&&d[y]===void 0&&b.getSubStringLength)try{d[y]=i+b.getSubStringLength(0,e?y+1:y)}catch{}return d[y]};if(l.rotation=0,i+(n=f(h.textContent.length))>s){for(;p<=g;)u=Math.ceil((p+g)/2),e&&(a=r(e,u)),n=f(u,a&&a.length-1),p===g?p=g+1:n>s?g=u-1:p=u;g===0?h.textContent="":t&&g===t.length-1||(h.textContent=a||r(t||e,u)),this.ellipsis&&n>s&&this.truncate(h,h.textContent||"",void 0,0,s,o,Ws)}e&&e.splice(0,u),l.actualWidth=n,l.rotation=c}unescapeEntities(h,t){return il(this.renderer.escapes,function(e,i){t&&t.indexOf(e)!==-1||(h=h.toString().replace(RegExp(e,"g"),i))}),h}},{defaultOptions:rl}=kt,{charts:al,deg2rad:Er,doc:ve,isFirefox:Ir,isMS:Dr,isWebKit:nl,noop:hl,SVG_NS:ll,symbolSizes:Hs,win:Xs}=P,{addEvent:yi,attr:bi,createElement:dl,crisp:Br,css:vi,defined:re,destroyObjectProperties:cl,extend:ae,isArray:pl,isNumber:ke,isObject:Fe,isString:gl,merge:Fs,pick:Gs,pInt:ul,replaceNested:fl,uniqueKey:ml}=N;class ki{constructor(t,e,i,s,o,r,a){let n,l;this.x=0,this.y=0;let c=this.createElement("svg").attr({version:"1.1",class:"highcharts-root"}),d=c.element;a||c.css(this.getStyle(s||{})),t.appendChild(d),bi(t,"dir","ltr"),t.innerHTML.indexOf("xmlns")===-1&&bi(d,"xmlns",this.SVG_NS),this.box=d,this.boxWrapper=c,this.alignedObjects=[],this.url=this.getReferenceURL(),this.createElement("desc").add().element.appendChild(ve.createTextNode("Created with Highcharts 12.2.0")),this.defs=this.createElement("defs").add(),this.allowHTML=r,this.forExport=o,this.styledMode=a,this.gradients={},this.cache={},this.cacheKeys=[],this.imgCount=0,this.rootFontSize=c.getStyle("font-size"),this.setSize(e,i,!1),Ir&&t.getBoundingClientRect&&((n=function(){vi(t,{left:0,top:0}),l=t.getBoundingClientRect(),vi(t,{left:Math.ceil(l.left)-l.left+"px",top:Math.ceil(l.top)-l.top+"px"})})(),this.unSubPixelFix=yi(Xs,"resize",n))}definition(t){return new _([t]).addToDOM(this.defs.element)}getReferenceURL(){if((Ir||nl)&&ve.getElementsByTagName("base").length){if(!re(Ot)){let t=ml(),e=new _([{tagName:"svg",attributes:{width:8,height:8},children:[{tagName:"defs",children:[{tagName:"clipPath",attributes:{id:t},children:[{tagName:"rect",attributes:{width:4,height:4}}]}]},{tagName:"rect",attributes:{id:"hitme",width:8,height:8,"clip-path":`url(#${t})`,fill:"rgba(0,0,0,0.001)"}}]}]).addToDOM(ve.body);vi(e,{position:"fixed",top:0,left:0,zIndex:9e5}),Ot=ve.elementFromPoint(6,6)?.id==="hitme",ve.body.removeChild(e)}if(Ot)return fl(Xs.location.href.split("#")[0],[/<[^>]*>/g,""],[/([\('\)])/g,"\\$1"],[/ /g,"%20"])}return""}getStyle(t){return this.style=ae({fontFamily:'-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif',fontSize:"1rem"},t),this.style}setStyle(t){this.boxWrapper.css(this.getStyle(t))}isHidden(){return!this.boxWrapper.getBBox().width}destroy(){let t=this.defs;return this.box=null,this.boxWrapper=this.boxWrapper.destroy(),cl(this.gradients||{}),this.gradients=null,this.defs=t.destroy(),this.unSubPixelFix&&this.unSubPixelFix(),this.alignedObjects=null,null}createElement(t){return new this.Element(this,t)}getRadialAttr(t,e){return{cx:t[0]-t[2]/2+(e.cx||0)*t[2],cy:t[1]-t[2]/2+(e.cy||0)*t[2],r:(e.r||0)*t[2]}}shadowDefinition(t){let e=[`highcharts-drop-shadow-${this.chartIndex}`,...Object.keys(t).map(s=>`${s}-${t[s]}`)].join("-").toLowerCase().replace(/[^a-z\d\-]/g,""),i=Fs({color:"#000000",offsetX:1,offsetY:1,opacity:.15,width:5},t);return this.defs.element.querySelector(`#${e}`)||this.definition({tagName:"filter",attributes:{id:e,filterUnits:i.filterUnits},children:this.getShadowFilterContent(i)}),e}getShadowFilterContent(t){return[{tagName:"feDropShadow",attributes:{dx:t.offsetX,dy:t.offsetY,"flood-color":t.color,"flood-opacity":Math.min(5*t.opacity,1),stdDeviation:t.width/2}}]}buildText(t){new ol(t).buildSVG()}getContrast(t){let e=tt.parse(t).rgba,i=" clamp(0,calc(9e9*(0.5 - (0.2126*r + 0.7152*g + 0.0722*b))),1)";if(ke(e[0])||!tt.useColorMix){let s=e.map(r=>{let a=r/255;return a<=.04?a/12.92:Math.pow((a+.055)/1.055,2.4)}),o=.2126*s[0]+.7152*s[1]+.0722*s[2];return 1.05/(o+.05)>(o+.05)/.05?"#FFFFFF":"#000000"}return"color(from "+t+" srgb"+i+i+i+")"}button(t,e,i,s,o={},r,a,n,l,c){let d=this.label(t,e,i,l,void 0,void 0,c,void 0,"button"),p=this.styledMode,g=arguments,u=0;o=Fs(rl.global.buttonTheme,o),p&&(delete o.fill,delete o.stroke,delete o["stroke-width"]);let f=o.states||{},x=o.style||{};delete o.states,delete o.style;let m=[_.filterUserAttributes(o)],y=[x];return p||["hover","select","disabled"].forEach((b,v)=>{m.push(Fs(m[0],_.filterUserAttributes(g[v+5]||f[b]||{}))),y.push(m[v+1].style),delete m[v+1].style}),yi(d.element,Dr?"mouseover":"mouseenter",function(){u!==3&&d.setState(1)}),yi(d.element,Dr?"mouseout":"mouseleave",function(){u!==3&&d.setState(u)}),d.setState=(b=0)=>{if(b!==1&&(d.state=u=b),d.removeClass(/highcharts-button-(normal|hover|pressed|disabled)/).addClass("highcharts-button-"+["normal","hover","pressed","disabled"][b]),!p){d.attr(m[b]);let v=y[b];Fe(v)&&d.css(v)}},d.attr(m[0]),!p&&(d.css(ae({cursor:"default"},x)),c&&d.text.css({pointerEvents:"none"})),d.on("touchstart",b=>b.stopPropagation()).on("click",function(b){u!==3&&s?.call(d,b)})}crispLine(t,e){let[i,s]=t;return re(i[1])&&i[1]===s[1]&&(i[1]=s[1]=Br(i[1],e)),re(i[2])&&i[2]===s[2]&&(i[2]=s[2]=Br(i[2],e)),t}path(t){let e=this.styledMode?{}:{fill:"none"};return pl(t)?e.d=t:Fe(t)&&ae(e,t),this.createElement("path").attr(e)}circle(t,e,i){let s=Fe(t)?t:t===void 0?{}:{x:t,y:e,r:i},o=this.createElement("circle");return o.xSetter=o.ySetter=function(r,a,n){n.setAttribute("c"+a,r)},o.attr(s)}arc(t,e,i,s,o,r){let a;Fe(t)?(e=(a=t).y,i=a.r,s=a.innerR,o=a.start,r=a.end,t=a.x):a={innerR:s,start:o,end:r};let n=this.symbol("arc",t,e,i,i,a);return n.r=i,n}rect(t,e,i,s,o,r){let a=Fe(t)?t:t===void 0?{}:{x:t,y:e,r:o,width:Math.max(i||0,0),height:Math.max(s||0,0)},n=this.createElement("rect");return this.styledMode||(r!==void 0&&(a["stroke-width"]=r,ae(a,n.crisp(a))),a.fill="none"),n.rSetter=function(l,c,d){n.r=l,bi(d,{rx:l,ry:l})},n.rGetter=function(){return n.r||0},n.attr(a)}roundedRect(t){return this.symbol("roundedRect").attr(t)}setSize(t,e,i){this.width=t,this.height=e,this.boxWrapper.animate({width:t,height:e},{step:function(){this.attr({viewBox:"0 0 "+this.attr("width")+" "+this.attr("height")})},duration:Gs(i,!0)?void 0:0}),this.alignElements()}g(t){let e=this.createElement("g");return t?e.attr({class:"highcharts-"+t}):e}image(t,e,i,s,o,r){let a={preserveAspectRatio:"none"};ke(e)&&(a.x=e),ke(i)&&(a.y=i),ke(s)&&(a.width=s),ke(o)&&(a.height=o);let n=this.createElement("image").attr(a),l=function(c){n.attr({href:t}),r.call(n,c)};if(r){n.attr({href:"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="});let c=new Xs.Image;yi(c,"load",l),c.src=t,c.complete&&l({})}else n.attr({href:t});return n}symbol(t,e,i,s,o,r){let a,n,l,c,d=this,p=/^url\((.*?)\)$/,g=p.test(t),u=!g&&(this.symbols[t]?t:"circle"),f=u&&this.symbols[u];if(f)typeof e=="number"&&(n=f.call(this.symbols,e||0,i||0,s||0,o||0,r)),a=this.path(n),d.styledMode||a.attr("fill","none"),ae(a,{symbolName:u||void 0,x:e,y:i,width:s,height:o}),r&&ae(a,r);else if(g){l=t.match(p)[1];let x=a=this.image(l);x.imgwidth=Gs(r?.width,Hs[l]?.width),x.imgheight=Gs(r?.height,Hs[l]?.height),c=m=>m.attr({width:m.width,height:m.height}),["width","height"].forEach(m=>{x[`${m}Setter`]=function(y,b){this[b]=y;let{alignByTranslate:v,element:S,width:w,height:k,imgwidth:M,imgheight:C}=this,T=b==="width"?M:C,A=1;r&&r.backgroundSize==="within"&&w&&k&&M&&C?(A=Math.min(w/M,k/C),bi(S,{width:Math.round(M*A),height:Math.round(C*A)})):S&&T&&S.setAttribute(b,T),!v&&M&&C&&this.translate(((w||0)-M*A)/2,((k||0)-C*A)/2)}}),re(e)&&x.attr({x:e,y:i}),x.isImg=!0,x.symbolUrl=t,re(x.imgwidth)&&re(x.imgheight)?c(x):(x.attr({width:0,height:0}),dl("img",{onload:function(){let m=al[d.chartIndex];this.width===0&&(vi(this,{position:"absolute",top:"-999em"}),ve.body.appendChild(this)),Hs[l]={width:this.width,height:this.height},x.imgwidth=this.width,x.imgheight=this.height,x.element&&c(x),this.parentNode&&this.parentNode.removeChild(this),d.imgCount--,d.imgCount||!m||m.hasLoaded||m.onload()},src:l}),this.imgCount++)}return a}clipRect(t,e,i,s){return this.rect(t,e,i,s,0)}text(t,e,i,s){let o={};if(s&&(this.allowHTML||!this.forExport))return this.html(t,e,i);o.x=Math.round(e||0),i&&(o.y=Math.round(i)),re(t)&&(o.text=t);let r=this.createElement("text").attr(o);return s&&(!this.forExport||this.allowHTML)||(r.xSetter=function(a,n,l){let c=l.getElementsByTagName("tspan"),d=l.getAttribute(n);for(let p=0,g;p<c.length;p++)(g=c[p]).getAttribute(n)===d&&g.setAttribute(n,a);l.setAttribute(n,a)}),r}fontMetrics(t){let e=ul(Et.prototype.getStyle.call(t,"font-size")||0),i=e<24?e+3:Math.round(1.2*e),s=Math.round(.8*i);return{h:i,b:s,f:e}}rotCorr(t,e,i){let s=t;return e&&i&&(s=Math.max(s*Math.cos(e*Er),4)),{x:-t/3*Math.sin(e*Er),y:s}}pathToSegments(t){let e=[],i=[],s={A:8,C:7,H:2,L:3,M:3,Q:5,S:5,T:3,V:2};for(let o=0;o<t.length;o++)gl(i[0])&&ke(t[o])&&i.length===s[i[0].toUpperCase()]&&t.splice(o,0,i[0].replace("M","L").replace("m","l")),typeof t[o]=="string"&&(i.length&&e.push(i.slice(0)),i.length=0),i.push(t[o]);return e.push(i.slice(0)),e}label(t,e,i,s,o,r,a,n,l){return new oe(this,t,e,i,s,o,r,a,n,l)}alignElements(){this.alignedObjects.forEach(t=>t.align())}}ae(ki.prototype,{Element:Et,SVG_NS:ll,escapes:{"&":"&","<":"<",">":">","'":"'",'"':"""},symbols:Or,draw:hl}),Re.registerRendererType("svg",ki,!0);let{composed:xl,isFirefox:yl}=P,{attr:bl,css:Gt,createElement:vl,defined:Nr,extend:kl,getAlignFactor:wl,isNumber:wi,pInt:Ml,pushUnique:Sl}=N;function zr(h,t,e){let i=this.div?.style||e.style;Et.prototype[`${t}Setter`].call(this,h,t,e),i&&(i[t]=h)}let Cl=(h,t)=>{if(!h.div){let e=bl(h.element,"class"),i=h.css,s=vl("div",e?{className:e}:void 0,Ht(vt({position:"absolute",left:`${h.translateX||0}px`,top:`${h.translateY||0}px`},h.styles),{display:h.display,opacity:h.opacity,visibility:h.visibility}),h.parentGroup?.div||t);h.classSetter=(o,r,a)=>{a.setAttribute("class",o),s.className=o},h.translateXSetter=h.translateYSetter=(o,r)=>{h[r]=o,s.style[r==="translateX"?"left":"top"]=`${o}px`,h.doTransform=!0},h.opacitySetter=h.visibilitySetter=zr,h.css=o=>(i.call(h,o),o.cursor&&(s.style.cursor=o.cursor),o.pointerEvents&&(s.style.pointerEvents=o.pointerEvents),h),h.on=function(){return Et.prototype.on.apply({element:s,onEvents:h.onEvents},arguments),h},h.div=s}return h.div};class we extends Et{static compose(t){Sl(xl,this.compose)&&(t.prototype.html=function(e,i,s){return new we(this,"span").attr({text:e,x:Math.round(i),y:Math.round(s)})})}constructor(t,e){super(t,e),we.useForeignObject?this.foreignObject=t.createElement("foreignObject").attr({zIndex:2}):this.css(vt({position:"absolute"},t.styledMode?{}:{fontFamily:t.style.fontFamily,fontSize:t.style.fontSize})),this.element.style.whiteSpace="nowrap"}getSpanCorrection(t,e,i){this.xCorr=-t*i,this.yCorr=-e}css(t){let e,{element:i}=this,s=i.tagName==="SPAN"&&t&&"width"in t,o=s&&t.width;return s&&(delete t.width,this.textWidth=Ml(o)||void 0,e=!0),t?.textOverflow==="ellipsis"&&(t.overflow="hidden",t.whiteSpace="nowrap"),t?.lineClamp&&(t.display="-webkit-box",t.WebkitLineClamp=t.lineClamp,t.WebkitBoxOrient="vertical",t.overflow="hidden"),wi(Number(t?.fontSize))&&(t.fontSize+="px"),kl(this.styles,t),Gt(i,t),e&&this.updateTransform(),this}htmlGetBBox(){let{element:t}=this;return{x:t.offsetLeft,y:t.offsetTop,width:t.offsetWidth,height:t.offsetHeight}}updateTransform(){if(!this.added){this.alignOnAdd=!0;return}let{element:t,foreignObject:e,oldTextWidth:i,renderer:s,rotation:o,rotationOriginX:r,rotationOriginY:a,scaleX:n,scaleY:l,styles:{display:c="inline-block",whiteSpace:d},textAlign:p="left",textWidth:g,translateX:u=0,translateY:f=0,x=0,y:m=0}=this;if(e||Gt(t,{marginLeft:`${u}px`,marginTop:`${f}px`}),t.tagName==="SPAN"){let y,b=[o,p,t.innerHTML,g,this.textAlign].join(","),v=-(this.parentGroup?.padding*1)||0;if(g!==i){let M=this.textPxLength?this.textPxLength:(Gt(t,{width:"",whiteSpace:d||"nowrap"}),t.offsetWidth),C=g||0,T=t.style.textOverflow===""&&t.style.webkitLineClamp;(C>i||M>C||T)&&(/[\-\s\u00AD]/.test(t.textContent||t.innerText)||t.style.textOverflow==="ellipsis")&&(Gt(t,{width:(o||n||M>C||T)&&wi(g)?g+"px":"auto",display:c,whiteSpace:d||"normal"}),this.oldTextWidth=g)}e&&(Gt(t,{display:"inline-block",verticalAlign:"top"}),e.attr({width:s.width,height:s.height})),b!==this.cTT&&(y=s.fontMetrics(t).b,Nr(o)&&!e&&(o!==(this.oldRotation||0)||p!==this.oldAlign)&&Gt(t,{transform:`rotate(${o}deg)`,transformOrigin:`${v}% ${v}px`}),this.getSpanCorrection(!Nr(o)&&!this.textWidth&&this.textPxLength||t.offsetWidth,y,wl(p)));let{xCorr:S=0,yCorr:w=0}=this,k={left:`${x+S}px`,top:`${m+w}px`,textAlign:p,transformOrigin:`${(r??x)-S-x-v}px ${(a??m)-w-m-v}px`};(n||l)&&(k.transform=`scale(${n??1},${l??1})`),e?(super.updateTransform(),wi(x)&&wi(m)?(e.attr({x:x+S,y:m+w,width:t.offsetWidth+3,height:t.offsetHeight,"transform-origin":t.getAttribute("transform-origin")||"0 0"}),Gt(t,{display:c,textAlign:p})):yl&&e.attr({width:0,height:0})):Gt(t,k),this.cTT=b,this.oldRotation=o,this.oldAlign=p}}add(t){let{foreignObject:e,renderer:i}=this,s=i.box.parentNode,o=[];if(e)e.add(t),super.add(i.createElement("body").attr({xmlns:"http://www.w3.org/1999/xhtml"}).css({background:"transparent",margin:"0 3px 0 0"}).add(e));else{let r;if(this.parentGroup=t,t&&!(r=t.div)){let a=t;for(;a;)o.push(a),a=a.parentGroup;for(let n of o.reverse())r=Cl(n,s)}(r||s).appendChild(this.element)}return this.added=!0,this.alignOnAdd&&this.updateTransform(),this}textSetter(t){t!==this.textStr&&(delete this.bBox,delete this.oldTextWidth,_.setElementHTML(this.element,t??""),this.textStr=t,this.doTransform=!0)}alignSetter(t){this.alignValue=this.textAlign=t,this.doTransform=!0}xSetter(t,e){this[e]=t,this.doTransform=!0}}let ne=we.prototype;ne.visibilitySetter=ne.opacitySetter=zr,ne.ySetter=ne.rotationSetter=ne.rotationOriginXSetter=ne.rotationOriginYSetter=ne.xSetter,function(h){h.xAxis={alignTicks:!0,allowDecimals:void 0,panningEnabled:!0,zIndex:2,zoomEnabled:!0,dateTimeLabelFormats:{millisecond:{main:"%[HMSL]",range:!1},second:{main:"%[HMS]",range:!1},minute:{main:"%[HM]",range:!1},hour:{main:"%[HM]",range:!1},day:{main:"%[eb]"},week:{main:"%[eb]"},month:{main:"%[bY]"},year:{main:"%Y"}},endOnTick:!1,gridLineDashStyle:"Solid",gridZIndex:1,labels:{autoRotationLimit:80,distance:15,enabled:!0,indentation:10,overflow:"justify",reserveSpace:void 0,rotation:void 0,staggerLines:0,step:0,useHTML:!1,zIndex:7,style:{color:"#333333",cursor:"default",fontSize:"0.8em",textOverflow:"ellipsis"}},maxPadding:.01,minorGridLineDashStyle:"Solid",minorTickLength:2,minorTickPosition:"outside",minorTicksPerMajor:5,minPadding:.01,offset:void 0,reversed:void 0,reversedStacks:!1,showEmpty:!0,showFirstLabel:!0,showLastLabel:!0,startOfWeek:1,startOnTick:!1,tickLength:10,tickPixelInterval:100,tickmarkPlacement:"between",tickPosition:"outside",title:{align:"middle",useHTML:!1,x:0,y:0,style:{color:"#666666",fontSize:"0.8em"}},visible:!0,minorGridLineColor:"#f2f2f2",minorGridLineWidth:1,minorTickColor:"#999999",lineColor:"#333333",lineWidth:1,gridLineColor:"#e6e6e6",gridLineWidth:void 0,tickColor:"#333333"},h.yAxis={reversedStacks:!0,endOnTick:!0,maxPadding:.05,minPadding:.05,tickPixelInterval:72,showLastLabel:!0,labels:{x:void 0},startOnTick:!0,title:{},stackLabels:{animation:{},allowOverlap:!1,enabled:!1,crop:!0,overflow:"justify",formatter:function(){let{numberFormatter:t}=this.axis.chart;return t(this.total||0,-1)},style:{color:"#000000",fontSize:"0.7em",fontWeight:"bold",textOutline:"1px contrast"}},gridLineWidth:1,lineWidth:0}}(is||(is={}));let Tl=is,{addEvent:Al,isFunction:Pl,objectEach:Ol,removeEvent:Ll}=N;(ss||(ss={})).registerEventOptions=function(h,t){h.eventOptions=h.eventOptions||{},Ol(t.events,function(e,i){h.eventOptions[i]!==e&&(h.eventOptions[i]&&(Ll(h,i,h.eventOptions[i]),delete h.eventOptions[i]),Pl(e)&&(h.eventOptions[i]=e,Al(h,i,e,{order:0})))})};let Mi=ss,{deg2rad:Ys}=P,{clamp:El,correctFloat:Si,defined:js,destroyObjectProperties:Il,extend:Rr,fireEvent:Ge,getAlignFactor:Dl,isNumber:Ci,merge:Bl,objectEach:Nl,pick:It}=N,Me=class{constructor(h,t,e,i,s){this.isNew=!0,this.isNewLabel=!0,this.axis=h,this.pos=t,this.type=e||"",this.parameters=s||{},this.tickmarkOffset=this.parameters.tickmarkOffset,this.options=this.parameters.options,Ge(this,"init"),e||i||this.addLabel()}addLabel(){let h=this,t=h.axis,e=t.options,i=t.chart,s=t.categories,o=t.logarithmic,r=t.names,a=h.pos,n=It(h.options?.labels,e.labels),l=t.tickPositions,c=a===l[0],d=a===l[l.length-1],p=(!n.step||n.step===1)&&t.tickInterval===1,g=l.info,u=h.label,f,x,m,y=this.parameters.category||(s?It(s[a],r[a],a):a);o&&Ci(y)&&(y=Si(o.lin2log(y))),t.dateTime&&(g?f=(x=i.time.resolveDTLFormat(e.dateTimeLabelFormats[!e.grid&&g.higherRanks[a]||g.unitName])).main:Ci(y)&&(f=t.dateTime.getXDateFormat(y,e.dateTimeLabelFormats||{}))),h.isFirst=c,h.isLast=d;let b={axis:t,chart:i,dateTimeLabelFormat:f,isFirst:c,isLast:d,pos:a,tick:h,tickPositionInfo:g,value:y};Ge(this,"labelFormat",b);let v=k=>n.formatter?n.formatter.call(k,k):n.format?(k.text=t.defaultLabelFormatter.call(k),wt.format(n.format,k,i)):t.defaultLabelFormatter.call(k),S=v.call(b,b),w=x?.list;w?h.shortenLabel=function(){for(m=0;m<w.length;m++)if(Rr(b,{dateTimeLabelFormat:w[m]}),u.attr({text:v.call(b,b)}),u.getBBox().width<t.getSlotWidth(h)-2*(n.padding||0))return;u.attr({text:""})}:h.shortenLabel=void 0,p&&t._addedPlotLB&&h.moveLabel(S,n),js(u)||h.movedLabel?u&&u.textStr!==S&&!p&&(!u.textWidth||n.style.width||u.styles.width||u.css({width:null}),u.attr({text:S}),u.textPxLength=u.getBBox().width):(h.label=u=h.createLabel(S,n),h.rotation=0)}createLabel(h,t,e){let i=this.axis,{renderer:s,styledMode:o}=i.chart,r=t.style.whiteSpace,a=js(h)&&t.enabled?s.text(h,e?.x,e?.y,t.useHTML).add(i.labelGroup):void 0;return a&&(o||a.css(Bl(t.style)),a.textPxLength=a.getBBox().width,!o&&r&&a.css({whiteSpace:r})),a}destroy(){Il(this,this.axis)}getPosition(h,t,e,i){let s=this.axis,o=s.chart,r=i&&o.oldChartHeight||o.chartHeight,a={x:h?Si(s.translate(t+e,void 0,void 0,i)+s.transB):s.left+s.offset+(s.opposite?(i&&o.oldChartWidth||o.chartWidth)-s.right-s.left:0),y:h?r-s.bottom+s.offset-(s.opposite?s.height:0):Si(r-s.translate(t+e,void 0,void 0,i)-s.transB)};return a.y=El(a.y,-1e9,1e9),Ge(this,"afterGetPosition",{pos:a}),a}getLabelPosition(h,t,e,i,s,o,r,a){let n,l,c=this.axis,d=c.transA,p=c.isLinked&&c.linkedParent?c.linkedParent.reversed:c.reversed,g=c.staggerLines,u=c.tickRotCorr||{x:0,y:0},f=i||c.reserveSpaceDefault?0:-c.labelOffset*(c.labelAlign==="center"?.5:1),x=s.distance,m={};return n=c.side===0?e.rotation?-x:-e.getBBox().height:c.side===2?u.y+x:Math.cos(e.rotation*Ys)*(u.y-e.getBBox(!1,0).height/2),js(s.y)&&(n=c.side===0&&c.horiz?s.y+n:s.y),h=h+It(s.x,[0,1,0,-1][c.side]*x)+f+u.x-(o&&i?o*d*(p?-1:1):0),t=t+n-(o&&!i?o*d*(p?1:-1):0),g&&(l=r/(a||1)%g,c.opposite&&(l=g-l-1),t+=l*(c.labelOffset/g)),m.x=h,m.y=Math.round(t),Ge(this,"afterGetLabelPosition",{pos:m,tickmarkOffset:o,index:r}),m}getLabelSize(){return this.label?this.label.getBBox()[this.axis.horiz?"height":"width"]:0}getMarkPath(h,t,e,i,s=!1,o){return o.crispLine([["M",h,t],["L",h+(s?0:-e),t+(s?e:0)]],i)}handleOverflow(h){let t=this.axis,e=t.options.labels,i=h.x,s=t.chart.chartWidth,o=t.chart.spacing,r=It(t.labelLeft,Math.min(t.pos,o[3])),a=It(t.labelRight,Math.max(t.isRadial?0:t.pos+t.len,s-o[1])),n=this.label,l=this.rotation,c=Dl(t.labelAlign||n.attr("align")),d=n.getBBox().width,p=t.getSlotWidth(this),g=p,u=1,f;l||e.overflow!=="justify"?l<0&&i-c*d<r?f=Math.round(i/Math.cos(l*Ys)-r):l>0&&i+c*d>a&&(f=Math.round((s-i)/Math.cos(l*Ys))):(i-c*d<r?g=h.x+g*(1-c)-r:i+(1-c)*d>a&&(g=a-h.x+g*c,u=-1),(g=Math.min(p,g))<p&&t.labelAlign==="center"&&(h.x+=u*(p-g-c*(p-Math.min(d,g)))),(d>g||t.autoRotation&&n?.styles?.width)&&(f=g)),f&&n&&(this.shortenLabel?this.shortenLabel():n.css(Rr({},{width:Math.floor(f)+"px",lineClamp:+!t.isRadial})))}moveLabel(h,t){let e=this,i=e.label,s=e.axis,o=!1,r;i&&i.textStr===h?(e.movedLabel=i,o=!0,delete e.label):Nl(s.ticks,function(a){o||a.isNew||a===e||!a.label||a.label.textStr!==h||(e.movedLabel=a.label,o=!0,a.labelPos=e.movedLabel.xy,delete a.label)}),!o&&(e.labelPos||i)&&(r=e.labelPos||i.xy,e.movedLabel=e.createLabel(h,t,r),e.movedLabel&&e.movedLabel.attr({opacity:0}))}render(h,t,e){let i=this.axis,s=i.horiz,o=this.pos,r=It(this.tickmarkOffset,i.tickmarkOffset),a=this.getPosition(s,o,r,t),n=a.x,l=a.y,c=i.pos,d=c+i.len,p=s?n:l,g=It(e,this.label?.newOpacity,1);!i.chart.polar&&(Si(p)<c||p>d)&&(e=0),e??(e=1),this.isActive=!0,this.renderGridLine(t,e),this.renderMark(a,e),this.renderLabel(a,t,g,h),this.isNew=!1,Ge(this,"afterRender")}renderGridLine(h,t){let e=this.axis,i=e.options,s={},o=this.pos,r=this.type,a=It(this.tickmarkOffset,e.tickmarkOffset),n=e.chart.renderer,l=this.gridLine,c,d=i.gridLineWidth,p=i.gridLineColor,g=i.gridLineDashStyle;this.type==="minor"&&(d=i.minorGridLineWidth,p=i.minorGridLineColor,g=i.minorGridLineDashStyle),l||(e.chart.styledMode||(s.stroke=p,s["stroke-width"]=d||0,s.dashstyle=g),r||(s.zIndex=1),h&&(t=0),this.gridLine=l=n.path().attr(s).addClass("highcharts-"+(r?r+"-":"")+"grid-line").add(e.gridGroup)),l&&(c=e.getPlotLinePath({value:o+a,lineWidth:l.strokeWidth(),force:"pass",old:h,acrossPanes:!1}))&&l[h||this.isNew?"attr":"animate"]({d:c,opacity:t})}renderMark(h,t){let e=this.axis,i=e.options,s=e.chart.renderer,o=this.type,r=e.tickSize(o?o+"Tick":"tick"),a=h.x,n=h.y,l=It(i[o!=="minor"?"tickWidth":"minorTickWidth"],!o&&e.isXAxis?1:0),c=i[o!=="minor"?"tickColor":"minorTickColor"],d=this.mark,p=!d;r&&(e.opposite&&(r[0]=-r[0]),d||(this.mark=d=s.path().addClass("highcharts-"+(o?o+"-":"")+"tick").add(e.axisGroup),e.chart.styledMode||d.attr({stroke:c,"stroke-width":l})),d[p?"attr":"animate"]({d:this.getMarkPath(a,n,r[0],d.strokeWidth(),e.horiz,s),opacity:t}))}renderLabel(h,t,e,i){let s=this.axis,o=s.horiz,r=s.options,a=this.label,n=r.labels,l=n.step,c=It(this.tickmarkOffset,s.tickmarkOffset),d=h.x,p=h.y,g=!0;a&&Ci(d)&&(a.xy=h=this.getLabelPosition(d,p,a,o,n,c,i,l),(!this.isFirst||this.isLast||r.showFirstLabel)&&(!this.isLast||this.isFirst||r.showLastLabel)?!o||n.step||n.rotation||t||e===0||this.handleOverflow(h):g=!1,l&&i%l&&(g=!1),g&&Ci(h.y)?(h.opacity=e,a[this.isNewLabel?"attr":"animate"](h).show(!0),this.isNewLabel=!1):(a.hide(),this.isNewLabel=!0))}replaceMovedLabel(){let h=this.label,t=this.axis;h&&!this.isNew&&(h.animate({opacity:0},void 0,h.destroy),delete this.label),t.isDirty=!0,this.label=this.movedLabel,delete this.movedLabel}},{animObject:zl}=dt,{xAxis:Wr,yAxis:Rl}=Tl,{defaultOptions:Us}=kt,{registerEventOptions:Wl}=Mi,{deg2rad:Hl}=P,{arrayMax:Hr,arrayMin:Xl,clamp:Vs,correctFloat:yt,defined:Z,destroyObjectProperties:Fl,erase:Xr,error:$s,extend:Ti,fireEvent:et,getClosestDistance:Fr,insertItem:Gl,isArray:Gr,isNumber:z,isString:Yr,merge:Ai,normalizeTickInterval:Yl,objectEach:Pi,pick:H,relativeLength:Oi,removeEvent:jl,splat:Ul,syncTimeout:Vl}=N,jr=(h,t)=>Yl(t,void 0,void 0,H(h.options.allowDecimals,t<.5||h.tickAmount!==void 0),!!h.tickAmount);Ti(Us,{xAxis:Wr,yAxis:Ai(Wr,Rl)});let Zs=(()=>{class h{constructor(e,i,s){this.init(e,i,s)}init(e,i,s=this.coll){let o=s==="xAxis",r=this.isZAxis||(e.inverted?!o:o);this.chart=e,this.horiz=r,this.isXAxis=o,this.coll=s,et(this,"init",{userOptions:i}),this.opposite=H(i.opposite,this.opposite),this.side=H(i.side,this.side,r?2*!this.opposite:this.opposite?1:3),this.setOptions(i);let a=this.options,n=a.labels;this.type??(this.type=a.type||"linear"),this.uniqueNames??(this.uniqueNames=a.uniqueNames??!0),et(this,"afterSetType"),this.userOptions=i,this.minPixelPadding=0,this.reversed=H(a.reversed,this.reversed),this.visible=a.visible,this.zoomEnabled=a.zoomEnabled,this.hasNames=this.type==="category"||a.categories===!0,this.categories=Gr(a.categories)&&a.categories||(this.hasNames?[]:void 0),this.names||(this.names=[],this.names.keys={}),this.plotLinesAndBandsGroups={},this.positiveValuesOnly=!!this.logarithmic,this.isLinked=Z(a.linkedTo),this.ticks={},this.labelEdge=[],this.minorTicks={},this.plotLinesAndBands=[],this.alternateBands={},this.len??(this.len=0),this.minRange=this.userMinRange=a.minRange||a.maxZoom,this.range=a.range,this.offset=a.offset||0,this.max=void 0,this.min=void 0;let l=H(a.crosshair,Ul(e.options.tooltip.crosshairs)[+!o]);this.crosshair=l===!0?{}:l,e.axes.indexOf(this)===-1&&(o?e.axes.splice(e.xAxis.length,0,this):e.axes.push(this),Gl(this,e[this.coll])),e.orderItems(this.coll),this.series=this.series||[],e.inverted&&!this.isZAxis&&o&&!Z(this.reversed)&&(this.reversed=!0),this.labelRotation=z(n.rotation)?n.rotation:void 0,Wl(this,a),et(this,"afterInit")}setOptions(e){let i=this.horiz?{labels:{autoRotation:[-45],padding:3},margin:15}:{labels:{padding:1},title:{rotation:90*this.side}};this.options=Ai(i,this.coll==="yAxis"?{title:{text:this.chart.options.lang.yAxisTitle}}:{},Us[this.coll],e),et(this,"afterSetOptions",{userOptions:e})}defaultLabelFormatter(){let e=this.axis,{numberFormatter:i}=this.chart,s=z(this.value)?this.value:NaN,o=e.chart.time,r=e.categories,a=this.dateTimeLabelFormat,n=Us.lang,l=n.numericSymbols,c=n.numericSymbolMagnitude||1e3,d=e.logarithmic?Math.abs(s):e.tickInterval,p=l?.length,g,u;if(r)u=`${this.value}`;else if(a)u=o.dateFormat(a,s,!0);else if(p&&l&&d>=1e3)for(;p--&&u===void 0;)d>=(g=Math.pow(c,p+1))&&10*s%g==0&&l[p]!==null&&s!==0&&(u=i(s/g,-1)+l[p]);return u===void 0&&(u=Math.abs(s)>=1e4?i(s,-1):i(s,-1,void 0,"")),u}getSeriesExtremes(){let e,i=this;et(this,"getSeriesExtremes",null,function(){i.hasVisibleSeries=!1,i.dataMin=i.dataMax=i.threshold=void 0,i.softThreshold=!i.isXAxis,i.series.forEach(s=>{if(s.reserveSpace()){let o=s.options,r,a=o.threshold,n,l;if(i.hasVisibleSeries=!0,i.positiveValuesOnly&&0>=(a||0)&&(a=void 0),i.isXAxis)(r=s.getColumn("x")).length&&(r=i.logarithmic?r.filter(c=>c>0):r,n=(e=s.getXExtremes(r)).min,l=e.max,z(n)||n instanceof Date||(r=r.filter(z),n=(e=s.getXExtremes(r)).min,l=e.max),r.length&&(i.dataMin=Math.min(H(i.dataMin,n),n),i.dataMax=Math.max(H(i.dataMax,l),l)));else{let c=s.applyExtremes();z(c.dataMin)&&(n=c.dataMin,i.dataMin=Math.min(H(i.dataMin,n),n)),z(c.dataMax)&&(l=c.dataMax,i.dataMax=Math.max(H(i.dataMax,l),l)),Z(a)&&(i.threshold=a),(!o.softThreshold||i.positiveValuesOnly)&&(i.softThreshold=!1)}}})}),et(this,"afterGetSeriesExtremes")}translate(e,i,s,o,r,a){let n=this.linkedParent||this,l=o&&n.old?n.old.min:n.min;if(!z(l))return NaN;let c=n.minPixelPadding,d=(n.isOrdinal||n.brokenAxis?.hasBreaks||n.logarithmic&&r)&&n.lin2val,p=1,g=0,u=o&&n.old?n.old.transA:n.transA,f=0;return u||(u=n.transA),s&&(p*=-1,g=n.len),n.reversed&&(p*=-1,g-=p*(n.sector||n.len)),i?(f=(e=e*p+g-c)/u+l,d&&(f=n.lin2val(f))):(d&&(e=n.val2lin(e)),f=p*(e-l)*u+g+p*c+(z(a)?u*a:0),n.isRadial||(f=yt(f))),f}toPixels(e,i){return this.translate(this.chart?.time.parse(e)??NaN,!1,!this.horiz,void 0,!0)+(i?0:this.pos)}toValue(e,i){return this.translate(e-(i?0:this.pos),!0,!this.horiz,void 0,!0)}getPlotLinePath(e){let i=this,s=i.chart,o=i.left,r=i.top,a=e.old,n=e.value,l=e.lineWidth,c=a&&s.oldChartHeight||s.chartHeight,d=a&&s.oldChartWidth||s.chartWidth,p=i.transB,g=e.translatedValue,u=e.force,f,x,m,y,b;function v(w,k,M){return u!=="pass"&&(w<k||w>M)&&(u?w=Vs(w,k,M):b=!0),w}let S={value:n,lineWidth:l,old:a,force:u,acrossPanes:e.acrossPanes,translatedValue:g};return et(this,"getPlotLinePath",S,function(w){f=m=(g=Vs(g=H(g,i.translate(n,void 0,void 0,a)),-1e9,1e9))+p,x=y=c-g-p,z(g)?i.horiz?(x=r,y=c-i.bottom+(i.options.isInternal?0:s.scrollablePixelsY||0),f=m=v(f,o,o+i.width)):(f=o,m=d-i.right+(s.scrollablePixelsX||0),x=y=v(x,r,r+i.height)):(b=!0,u=!1),w.path=b&&!u?void 0:s.renderer.crispLine([["M",f,x],["L",m,y]],l||1)}),S.path}getLinearTickPositions(e,i,s){let o,r,a,n=yt(Math.floor(i/e)*e),l=yt(Math.ceil(s/e)*e),c=[];if(yt(n+e)===n&&(a=20),this.single)return[i];for(o=n;o<=l&&(c.push(o),(o=yt(o+e,a))!==r);)r=o;return c}getMinorTickInterval(){let{minorTicks:e,minorTickInterval:i}=this.options;return e===!0?H(i,"auto"):e!==!1?i:void 0}getMinorTickPositions(){let e=this.options,i=this.tickPositions,s=this.minorTickInterval,o=this.pointRangePadding||0,r=(this.min||0)-o,a=(this.max||0)+o,n=this.brokenAxis?.hasBreaks?this.brokenAxis.unitLength:a-r,l=[],c;if(n&&n/s<this.len/3){let d=this.logarithmic;if(d)this.paddedTicks.forEach(function(p,g,u){g&&l.push.apply(l,d.getLogTickPositions(s,u[g-1],u[g],!0))});else if(this.dateTime&&this.getMinorTickInterval()==="auto")l=l.concat(this.getTimeTicks(this.dateTime.normalizeTimeTickInterval(s),r,a,e.startOfWeek));else for(c=r+(i[0]-r)%s;c<=a&&c!==l[0];c+=s)l.push(c)}return l.length!==0&&this.trimTicks(l),l}adjustForMinRange(){let e=this.options,i=this.logarithmic,s=this.chart.time,{max:o,min:r,minRange:a}=this,n,l,c,d;this.isXAxis&&a===void 0&&!i&&(a=Z(e.min)||Z(e.max)||Z(e.floor)||Z(e.ceiling)?null:Math.min(5*(Fr(this.series.map(p=>{let g=p.getColumn("x");return p.xIncrement?g.slice(0,2):g}))||0),this.dataMax-this.dataMin)),z(o)&&z(r)&&z(a)&&o-r<a&&(l=this.dataMax-this.dataMin>=a,n=(a-o+r)/2,c=[r-n,s.parse(e.min)??r-n],l&&(c[2]=i?i.log2lin(this.dataMin):this.dataMin),d=[(r=Hr(c))+a,s.parse(e.max)??r+a],l&&(d[2]=i?i.log2lin(this.dataMax):this.dataMax),(o=Xl(d))-r<a&&(c[0]=o-a,c[1]=s.parse(e.min)??o-a,r=Hr(c))),this.minRange=a,this.min=r,this.max=o}getClosest(){let e,i;if(this.categories)i=1;else{let s=[];this.series.forEach(function(o){let r=o.closestPointRange,a=o.getColumn("x");a.length===1?s.push(a[0]):o.sorted&&Z(r)&&o.reserveSpace()&&(i=Z(i)?Math.min(i,r):r)}),s.length&&(s.sort((o,r)=>o-r),e=Fr([s]))}return e&&i?Math.min(e,i):e||i}nameToX(e){let i=Gr(this.options.categories),s=i?this.categories:this.names,o=e.options.x,r;return e.series.requireSorting=!1,Z(o)||(o=this.uniqueNames&&s?i?s.indexOf(e.name):H(s.keys[e.name],-1):e.series.autoIncrement()),o===-1?!i&&s&&(r=s.length):z(o)&&(r=o),r!==void 0?(this.names[r]=e.name,this.names.keys[e.name]=r):e.x&&(r=e.x),r}updateNames(){let e=this,i=this.names;i.length>0&&(Object.keys(i.keys).forEach(function(s){delete i.keys[s]}),i.length=0,this.minRange=this.userMinRange,(this.series||[]).forEach(s=>{s.xIncrement=null,(!s.points||s.isDirtyData)&&(e.max=Math.max(e.max||0,s.dataTable.rowCount-1),s.processData(),s.generatePoints());let o=s.getColumn("x").slice();s.data.forEach((r,a)=>{let n=o[a];r?.options&&r.name!==void 0&&(n=e.nameToX(r))!==void 0&&n!==r.x&&(o[a]=r.x=n)}),s.dataTable.setColumn("x",o)}))}setAxisTranslation(){let e=this,i=e.max-e.min,s=e.linkedParent,o=!!e.categories,r=e.isXAxis,a=e.axisPointRange||0,n,l=0,c=0,d,p=e.transA;(r||o||a)&&(n=e.getClosest(),s?(l=s.minPointOffset,c=s.pointRangePadding):e.series.forEach(function(g){let u=o?1:r?H(g.options.pointRange,n,0):e.axisPointRange||0,f=g.options.pointPlacement;if(a=Math.max(a,u),!e.single||o){let x=g.is("xrange")?!r:r;l=Math.max(l,x&&Yr(f)?0:u/2),c=Math.max(c,x&&f==="on"?0:u)}}),d=e.ordinal?.slope&&n?e.ordinal.slope/n:1,e.minPointOffset=l*=d,e.pointRangePadding=c*=d,e.pointRange=Math.min(a,e.single&&o?1:i),r&&(e.closestPointRange=n)),e.translationSlope=e.transA=p=e.staticScale||e.len/(i+c||1),e.transB=e.horiz?e.left:e.bottom,e.minPixelPadding=p*l,et(this,"afterSetAxisTranslation")}minFromRange(){let{max:e,min:i}=this;return z(e)&&z(i)&&e-i||void 0}setTickInterval(e){let{categories:i,chart:s,dataMax:o,dataMin:r,dateTime:a,isXAxis:n,logarithmic:l,options:c,softThreshold:d}=this,p=s.time,g=z(this.threshold)?this.threshold:void 0,u=this.minRange||0,{ceiling:f,floor:x,linkedTo:m,softMax:y,softMin:b}=c,v=z(m)&&s[this.coll]?.[m],S=c.tickPixelInterval,w=c.maxPadding,k=c.minPadding,M=0,C,T=z(c.tickInterval)&&c.tickInterval>=0?c.tickInterval:void 0,A,O,L,I;if(a||i||v||this.getTickAmount(),L=H(this.userMin,p.parse(c.min)),I=H(this.userMax,p.parse(c.max)),v?(this.linkedParent=v,C=v.getExtremes(),this.min=H(C.min,C.dataMin),this.max=H(C.max,C.dataMax),this.type!==v.type&&$s(11,!0,s)):(d&&Z(g)&&z(o)&&z(r)&&(r>=g?(A=g,k=0):o<=g&&(O=g,w=0)),this.min=H(L,A,r),this.max=H(I,O,o)),z(this.max)&&z(this.min)&&(l&&(this.positiveValuesOnly&&!e&&0>=Math.min(this.min,H(r,this.min))&&$s(10,!0,s),this.min=yt(l.log2lin(this.min),16),this.max=yt(l.log2lin(this.max),16)),this.range&&z(r)&&(this.userMin=this.min=L=Math.max(r,this.minFromRange()||0),this.userMax=I=this.max,this.range=void 0)),et(this,"foundExtremes"),this.adjustForMinRange(),z(this.min)&&z(this.max)){if(!z(this.userMin)&&z(b)&&b<this.min&&(this.min=L=b),!z(this.userMax)&&z(y)&&y>this.max&&(this.max=I=y),i||this.axisPointRange||this.stacking?.usePercentage||v||!(M=this.max-this.min)||(!Z(L)&&k&&(this.min-=M*k),Z(I)||!w||(this.max+=M*w)),!z(this.userMin)&&z(x)&&(this.min=Math.max(this.min,x)),!z(this.userMax)&&z(f)&&(this.max=Math.min(this.max,f)),d&&z(r)&&z(o)){let E=g||0;!Z(L)&&this.min<E&&r>=E?this.min=c.minRange?Math.min(E,this.max-u):E:!Z(I)&&this.max>E&&o<=E&&(this.max=c.minRange?Math.max(E,this.min+u):E)}!s.polar&&this.min>this.max&&(Z(c.min)?this.max=this.min:Z(c.max)&&(this.min=this.max)),M=this.max-this.min}if(this.min!==this.max&&z(this.min)&&z(this.max)?v&&!T&&S===v.options.tickPixelInterval?this.tickInterval=T=v.tickInterval:this.tickInterval=H(T,this.tickAmount?M/Math.max(this.tickAmount-1,1):void 0,i?1:M*S/Math.max(this.len,S)):this.tickInterval=1,n&&!e){let E=this.min!==this.old?.min||this.max!==this.old?.max;this.series.forEach(function(B){B.forceCrop=B.forceCropping?.(),B.processData(E)}),et(this,"postProcessData",{hasExtremesChanged:E})}this.setAxisTranslation(),et(this,"initialAxisTranslation"),this.pointRange&&!T&&(this.tickInterval=Math.max(this.pointRange,this.tickInterval));let D=H(c.minTickInterval,a&&!this.series.some(E=>!E.sorted)?this.closestPointRange:0);!T&&D&&this.tickInterval<D&&(this.tickInterval=D),a||l||T||(this.tickInterval=jr(this,this.tickInterval)),this.tickAmount||(this.tickInterval=this.unsquish()),this.setTickPositions()}setTickPositions(){let e=this.options,i=e.tickPositions,s=e.tickPositioner,o=this.getMinorTickInterval(),r=!this.isPanning,a=r&&e.startOnTick,n=r&&e.endOnTick,l=[],c;if(this.tickmarkOffset=this.categories&&e.tickmarkPlacement==="between"&&this.tickInterval===1?.5:0,this.single=this.min===this.max&&Z(this.min)&&!this.tickAmount&&(this.min%1==0||e.allowDecimals!==!1),i)l=i.slice();else if(z(this.min)&&z(this.max)){if(!this.ordinal?.positions&&(this.max-this.min)/this.tickInterval>Math.max(2*this.len,200))l=[this.min,this.max],$s(19,!1,this.chart);else if(this.dateTime)l=this.getTimeTicks(this.dateTime.normalizeTimeTickInterval(this.tickInterval,e.units),this.min,this.max,e.startOfWeek,this.ordinal?.positions,this.closestPointRange,!0);else if(this.logarithmic)l=this.logarithmic.getLogTickPositions(this.tickInterval,this.min,this.max);else{let d=this.tickInterval,p=d;for(;p<=2*d&&(l=this.getLinearTickPositions(this.tickInterval,this.min,this.max),this.tickAmount&&l.length>this.tickAmount);)this.tickInterval=jr(this,p*=1.1)}l.length>this.len&&(l=[l[0],l[l.length-1]])[0]===l[1]&&(l.length=1),s&&(this.tickPositions=l,(c=s.apply(this,[this.min,this.max]))&&(l=c))}this.tickPositions=l,this.minorTickInterval=o==="auto"&&this.tickInterval?this.tickInterval/e.minorTicksPerMajor:o,this.paddedTicks=l.slice(0),this.trimTicks(l,a,n),!this.isLinked&&z(this.min)&&z(this.max)&&(this.single&&l.length<2&&!this.categories&&!this.series.some(d=>d.is("heatmap")&&d.options.pointPlacement==="between")&&(this.min-=.5,this.max+=.5),i||c||this.adjustTickAmount()),et(this,"afterSetTickPositions")}trimTicks(e,i,s){let o=e[0],r=e[e.length-1],a=!this.isOrdinal&&this.minPointOffset||0;if(et(this,"trimTicks"),!this.isLinked||!this.grid){if(i&&o!==-1/0)this.min=o;else for(;this.min-a>e[0];)e.shift();if(s)this.max=r;else for(;this.max+a<e[e.length-1];)e.pop();e.length===0&&Z(o)&&!this.options.tickPositions&&e.push((r+o)/2)}}alignToOthers(){let e,i=this,s=i.chart,o=[this],r=i.options,a=s.options.chart,n=this.coll==="yAxis"&&a.alignThresholds,l=[];if(i.thresholdAlignment=void 0,(a.alignTicks!==!1&&r.alignTicks||n)&&r.startOnTick!==!1&&r.endOnTick!==!1&&!i.logarithmic){let c=p=>{let{horiz:g,options:u}=p;return[g?u.left:u.top,u.width,u.height,u.pane].join(",")},d=c(this);s[this.coll].forEach(function(p){let{series:g}=p;g.length&&g.some(u=>u.visible)&&p!==i&&c(p)===d&&(e=!0,o.push(p))})}if(e&&n){o.forEach(d=>{let p=d.getThresholdAlignment(i);z(p)&&l.push(p)});let c=l.length>1?l.reduce((d,p)=>d+=p,0)/l.length:void 0;o.forEach(d=>{d.thresholdAlignment=c})}return e}getThresholdAlignment(e){if((!z(this.dataMin)||this!==e&&this.series.some(i=>i.isDirty||i.isDirtyData))&&this.getSeriesExtremes(),z(this.threshold)){let i=Vs((this.threshold-(this.dataMin||0))/((this.dataMax||0)-(this.dataMin||0)),0,1);return this.options.reversed&&(i=1-i),i}}getTickAmount(){let e=this.options,i=e.tickPixelInterval,s=e.tickAmount;Z(e.tickInterval)||s||!(this.len<i)||this.isRadial||this.logarithmic||!e.startOnTick||!e.endOnTick||(s=2),!s&&this.alignToOthers()&&(s=Math.ceil(this.len/i)+1),s<4&&(this.finalTickAmt=s,s=5),this.tickAmount=s}adjustTickAmount(){let e=this,{finalTickAmt:i,max:s,min:o,options:r,tickPositions:a,tickAmount:n,thresholdAlignment:l}=e,c=a?.length,d=H(e.threshold,e.softThreshold?0:null),p,g,u=e.tickInterval,f,x=()=>a.push(yt(a[a.length-1]+u)),m=()=>a.unshift(yt(a[0]-u));if(z(l)&&(f=l<.5?Math.ceil(l*(n-1)):Math.floor(l*(n-1)),r.reversed&&(f=n-1-f)),e.hasData()&&z(o)&&z(s)){let y=()=>{e.transA*=(c-1)/(n-1),e.min=r.startOnTick?a[0]:Math.min(o,a[0]),e.max=r.endOnTick?a[a.length-1]:Math.max(s,a[a.length-1])};if(z(f)&&z(e.threshold)){for(;a[f]!==d||a.length!==n||a[0]>o||a[a.length-1]<s;){for(a.length=0,a.push(e.threshold);a.length<n;)a[f]===void 0||a[f]>e.threshold?m():x();if(u>8*e.tickInterval)break;u*=2}y()}else if(c<n){for(;a.length<n;)a.length%2||o===d?x():m();y()}if(Z(i)){for(g=p=a.length;g--;)(i===3&&g%2==1||i<=2&&g>0&&g<p-1)&&a.splice(g,1);e.finalTickAmt=void 0}}}setScale(){let{coll:e,stacking:i}=this,s=!1,o=!1;this.series.forEach(a=>{s=s||a.isDirtyData||a.isDirty,o=o||a.xAxis?.isDirty||!1}),this.setAxisSize();let r=this.len!==this.old?.len;r||s||o||this.isLinked||this.forceRedraw||this.userMin!==this.old?.userMin||this.userMax!==this.old?.userMax||this.alignToOthers()?(i&&e==="yAxis"&&i.buildStacks(),this.forceRedraw=!1,this.userMinRange||(this.minRange=void 0),this.getSeriesExtremes(),this.setTickInterval(),i&&e==="xAxis"&&i.buildStacks(),this.isDirty||(this.isDirty=r||this.min!==this.old?.min||this.max!==this.old?.max)):i&&i.cleanStacks(),s&&delete this.allExtremes,et(this,"afterSetScale")}setExtremes(e,i,s=!0,o,r){let a=this.chart;this.series.forEach(n=>{delete n.kdTree}),e=a.time.parse(e),i=a.time.parse(i),et(this,"setExtremes",r=Ti(r,{min:e,max:i}),n=>{this.userMin=n.min,this.userMax=n.max,this.eventArgs=n,s&&a.redraw(o)})}setAxisSize(){let e=this.chart,i=this.options,s=i.offsets||[0,0,0,0],o=this.horiz,r=this.width=Math.round(Oi(H(i.width,e.plotWidth-s[3]+s[1]),e.plotWidth)),a=this.height=Math.round(Oi(H(i.height,e.plotHeight-s[0]+s[2]),e.plotHeight)),n=this.top=Math.round(Oi(H(i.top,e.plotTop+s[0]),e.plotHeight,e.plotTop)),l=this.left=Math.round(Oi(H(i.left,e.plotLeft+s[3]),e.plotWidth,e.plotLeft));this.bottom=e.chartHeight-a-n,this.right=e.chartWidth-r-l,this.len=Math.max(o?r:a,0),this.pos=o?l:n}getExtremes(){let e=this.logarithmic;return{min:e?yt(e.lin2log(this.min)):this.min,max:e?yt(e.lin2log(this.max)):this.max,dataMin:this.dataMin,dataMax:this.dataMax,userMin:this.userMin,userMax:this.userMax}}getThreshold(e){let i=this.logarithmic,s=i?i.lin2log(this.min):this.min,o=i?i.lin2log(this.max):this.max;return e===null||e===-1/0?e=s:e===1/0?e=o:s>e?e=s:o<e&&(e=o),this.translate(e,0,1,0,1)}autoLabelAlign(e){let i=(H(e,0)-90*this.side+720)%360,s={align:"center"};return et(this,"autoLabelAlign",s,function(o){i>15&&i<165?o.align="right":i>195&&i<345&&(o.align="left")}),s.align}tickSize(e){let i=this.options,s=H(i[e==="tick"?"tickWidth":"minorTickWidth"],e==="tick"&&this.isXAxis&&!this.categories?1:0),o=i[e==="tick"?"tickLength":"minorTickLength"],r;s&&o&&(i[e+"Position"]==="inside"&&(o=-o),r=[o,s]);let a={tickSize:r};return et(this,"afterTickSize",a),a.tickSize}labelMetrics(){let e=this.chart.renderer,i=this.ticks,s=i[Object.keys(i)[0]]||{};return this.chart.renderer.fontMetrics(s.label||s.movedLabel||e.box)}unsquish(){let e=this.options.labels,i=e.padding||0,s=this.horiz,o=this.tickInterval,r=this.len/((+!!this.categories+this.max-this.min)/o),a=e.rotation,n=yt(.8*this.labelMetrics().h),l=Math.max(this.max-this.min,0),c=function(f){let x=(f+2*i)/(r||1);return(x=x>1?Math.ceil(x):1)*o>l&&f!==1/0&&r!==1/0&&l&&(x=Math.ceil(l/o)),yt(x*o)},d=o,p,g=Number.MAX_VALUE,u;if(s){if(!e.staggerLines&&(z(a)?u=[a]:r<e.autoRotationLimit&&(u=e.autoRotation)),u){let f,x;for(let m of u)(m===a||m&&m>=-90&&m<=90)&&(x=(f=c(Math.abs(n/Math.sin(Hl*m))))+Math.abs(m/360))<g&&(g=x,p=m,d=f)}}else d=c(.75*n);return this.autoRotation=u,this.labelRotation=H(p,z(a)?a:0),e.step?o:d}getSlotWidth(e){let i=this.chart,s=this.horiz,o=this.options.labels,r=Math.max(this.tickPositions.length-+!this.categories,1),a=i.margin[3];if(e&&z(e.slotWidth))return e.slotWidth;if(s&&o.step<2&&!this.isRadial)return o.rotation?0:(this.staggerLines||1)*this.len/r;if(!s){let n=o.style.width;if(n!==void 0)return parseInt(String(n),10);if(a)return a-i.spacing[3]}return .33*i.chartWidth}renderUnsquish(){let e=this.chart,i=e.renderer,s=this.tickPositions,o=this.ticks,r=this.options.labels,a=r.style,n=this.horiz,l=this.getSlotWidth(),c=Math.max(1,Math.round(l-(n?2*(r.padding||0):r.distance||0))),d={},p=this.labelMetrics(),g=a.lineClamp,u,f=g??(Math.floor(this.len/(s.length*p.h))||1),x=0;Yr(r.rotation)||(d.rotation=r.rotation||0),s.forEach(function(m){let y=o[m];y.movedLabel&&y.replaceMovedLabel();let b=y.label?.textPxLength||0;b>x&&(x=b)}),this.maxLabelLength=x,this.autoRotation?x>c&&x>p.h?d.rotation=this.labelRotation:this.labelRotation=0:l&&(u=c),d.rotation&&(u=x>.5*e.chartHeight?.33*e.chartHeight:x,g||(f=1)),this.labelAlign=r.align||this.autoLabelAlign(this.labelRotation),this.labelAlign&&(d.align=this.labelAlign),s.forEach(function(m){let y=o[m],b=y?.label,v=a.width,S={};b&&(b.attr(d),y.shortenLabel?y.shortenLabel():u&&!v&&a.whiteSpace!=="nowrap"&&(u<(b.textPxLength||0)||b.element.tagName==="SPAN")?b.css(Ti(S,{width:`${u}px`,lineClamp:f})):!b.styles.width||S.width||v||b.css({width:"auto"}),y.rotation=d.rotation)},this),this.tickRotCorr=i.rotCorr(p.b,this.labelRotation||0,this.side!==0)}hasData(){return this.series.some(function(e){return e.hasData()})||this.options.showEmpty&&Z(this.min)&&Z(this.max)}addTitle(e){let i,s=this.chart.renderer,o=this.horiz,r=this.opposite,a=this.options.title,n=this.chart.styledMode;this.axisTitle||((i=a.textAlign)||(i=(o?{low:"left",middle:"center",high:"right"}:{low:r?"right":"left",middle:"center",high:r?"left":"right"})[a.align]),this.axisTitle=s.text(a.text||"",0,0,a.useHTML).attr({zIndex:7,rotation:a.rotation||0,align:i}).addClass("highcharts-axis-title"),n||this.axisTitle.css(Ai(a.style)),this.axisTitle.add(this.axisGroup),this.axisTitle.isNew=!0),n||a.style.width||this.isRadial||this.axisTitle.css({width:this.len+"px"}),this.axisTitle[e?"show":"hide"](e)}generateTick(e){let i=this.ticks;i[e]?i[e].addLabel():i[e]=new Me(this,e)}createGroups(){let{axisParent:e,chart:i,coll:s,options:o}=this,r=i.renderer,a=(n,l,c)=>r.g(n).attr({zIndex:c}).addClass(`highcharts-${s.toLowerCase()}${l} `+(this.isRadial?`highcharts-radial-axis${l} `:"")+(o.className||"")).add(e);this.axisGroup||(this.gridGroup=a("grid","-grid",o.gridZIndex),this.axisGroup=a("axis","",o.zIndex),this.labelGroup=a("axis-labels","-labels",o.labels.zIndex))}getOffset(){let e=this,{chart:i,horiz:s,options:o,side:r,ticks:a,tickPositions:n,coll:l}=e,c=i.inverted&&!e.isZAxis?[1,0,3,2][r]:r,d=e.hasData(),p=o.title,g=o.labels,u=z(o.crossing),f=i.axisOffset,x=i.clipOffset,m=[-1,1,1,-1][r],y,b=0,v,S=0,w=0,k,M;if(e.showAxis=y=d||o.showEmpty,e.staggerLines=e.horiz&&g.staggerLines||void 0,e.createGroups(),d||e.isLinked?(n.forEach(function(C){e.generateTick(C)}),e.renderUnsquish(),e.reserveSpaceDefault=r===0||r===2||{1:"left",3:"right"}[r]===e.labelAlign,H(g.reserveSpace,!u&&null,e.labelAlign==="center"||null,e.reserveSpaceDefault)&&n.forEach(function(C){w=Math.max(a[C].getLabelSize(),w)}),e.staggerLines&&(w*=e.staggerLines),e.labelOffset=w*(e.opposite?-1:1)):Pi(a,function(C,T){C.destroy(),delete a[T]}),p?.text&&p.enabled!==!1&&(e.addTitle(y),y&&!u&&p.reserveSpace!==!1&&(e.titleOffset=b=e.axisTitle.getBBox()[s?"height":"width"],S=Z(v=p.offset)?0:H(p.margin,s?5:10))),e.renderLine(),e.offset=m*H(o.offset,f[r]?f[r]+(o.margin||0):0),e.tickRotCorr=e.tickRotCorr||{x:0,y:0},M=r===0?-e.labelMetrics().h:r===2?e.tickRotCorr.y:0,k=Math.abs(w)+S,w&&(k-=M,k+=m*(s?H(g.y,e.tickRotCorr.y+m*g.distance):H(g.x,m*g.distance))),e.axisTitleMargin=H(v,k),e.getMaxLabelDimensions&&(e.maxLabelDimensions=e.getMaxLabelDimensions(a,n)),l!=="colorAxis"&&x){let C=this.tickSize("tick");f[r]=Math.max(f[r],(e.axisTitleMargin||0)+b+m*e.offset,k,n?.length&&C?C[0]+m*e.offset:0);let T=!e.axisLine||o.offset?0:e.axisLine.strokeWidth()/2;x[c]=Math.max(x[c],T)}et(this,"afterGetOffset")}getLinePath(e){let i=this.chart,s=this.opposite,o=this.offset,r=this.horiz,a=this.left+(s?this.width:0)+o,n=i.chartHeight-this.bottom-(s?this.height:0)+o;return s&&(e*=-1),i.renderer.crispLine([["M",r?this.left:a,r?n:this.top],["L",r?i.chartWidth-this.right:a,r?n:i.chartHeight-this.bottom]],e)}renderLine(){this.axisLine||(this.axisLine=this.chart.renderer.path().addClass("highcharts-axis-line").add(this.axisGroup),this.chart.styledMode||this.axisLine.attr({stroke:this.options.lineColor,"stroke-width":this.options.lineWidth,zIndex:7}))}getTitlePosition(e){let i=this.horiz,s=this.left,o=this.top,r=this.len,a=this.options.title,n=i?s:o,l=this.opposite,c=this.offset,d=a.x,p=a.y,g=this.chart.renderer.fontMetrics(e),u=e?Math.max(e.getBBox(!1,0).height-g.h-1,0):0,f={low:n+(i?0:r),middle:n+r/2,high:n+(i?r:0)}[a.align],x=(i?o+this.height:s)+(i?1:-1)*(l?-1:1)*(this.axisTitleMargin||0)+[-u,u,g.f,-u][this.side],m={x:i?f+d:x+(l?this.width:0)+c+d,y:i?x+p-(l?this.height:0)+c:f+p};return et(this,"afterGetTitlePosition",{titlePosition:m}),m}renderMinorTick(e,i){let s=this.minorTicks;s[e]||(s[e]=new Me(this,e,"minor")),i&&s[e].isNew&&s[e].render(null,!0),s[e].render(null,!1,1)}renderTick(e,i,s){let o=this.isLinked,r=this.ticks;(!o||e>=this.min&&e<=this.max||this.grid?.isColumn)&&(r[e]||(r[e]=new Me(this,e)),s&&r[e].isNew&&r[e].render(i,!0,-1),r[e].render(i))}render(){let e,i,s=this,o=s.chart,r=s.logarithmic,a=o.renderer,n=s.options,l=s.isLinked,c=s.tickPositions,d=s.axisTitle,p=s.ticks,g=s.minorTicks,u=s.alternateBands,f=n.stackLabels,x=n.alternateGridColor,m=n.crossing,y=s.tickmarkOffset,b=s.axisLine,v=s.showAxis,S=zl(a.globalAnimation);if(s.labelEdge.length=0,s.overlap=!1,[p,g,u].forEach(function(w){Pi(w,function(k){k.isActive=!1})}),z(m)){let w=this.isXAxis?o.yAxis[0]:o.xAxis[0],k=[1,-1,-1,1][this.side];if(w){let M=w.toPixels(m,!0);s.horiz&&(M=w.len-M),s.offset=k*M}}if(s.hasData()||l){let w=s.chart.hasRendered&&s.old&&z(s.old.min);s.minorTickInterval&&!s.categories&&s.getMinorTickPositions().forEach(function(k){s.renderMinorTick(k,w)}),c.length&&(c.forEach(function(k,M){s.renderTick(k,M,w)}),y&&(s.min===0||s.single)&&(p[-1]||(p[-1]=new Me(s,-1,null,!0)),p[-1].render(-1))),x&&c.forEach(function(k,M){i=c[M+1]!==void 0?c[M+1]+y:s.max-y,M%2==0&&k<s.max&&i<=s.max+(o.polar?-y:y)&&(u[k]||(u[k]=new P.PlotLineOrBand(s,{})),e=k+y,u[k].options={from:r?r.lin2log(e):e,to:r?r.lin2log(i):i,color:x,className:"highcharts-alternate-grid"},u[k].render(),u[k].isActive=!0)}),s._addedPlotLB||(s._addedPlotLB=!0,(n.plotLines||[]).concat(n.plotBands||[]).forEach(function(k){s.addPlotBandOrLine(k)}))}[p,g,u].forEach(function(w){let k=[],M=S.duration;Pi(w,function(C,T){C.isActive||(C.render(T,!1,0),C.isActive=!1,k.push(T))}),Vl(function(){let C=k.length;for(;C--;)w[k[C]]&&!w[k[C]].isActive&&(w[k[C]].destroy(),delete w[k[C]])},w!==u&&o.hasRendered&&M?M:0)}),b&&(b[b.isPlaced?"animate":"attr"]({d:this.getLinePath(b.strokeWidth())}),b.isPlaced=!0,b[v?"show":"hide"](v)),d&&v&&(d[d.isNew?"attr":"animate"](s.getTitlePosition(d)),d.isNew=!1),f?.enabled&&s.stacking&&s.stacking.renderStackTotals(),s.old={len:s.len,max:s.max,min:s.min,transA:s.transA,userMax:s.userMax,userMin:s.userMin},s.isDirty=!1,et(this,"afterRender")}redraw(){this.visible&&(this.render(),this.plotLinesAndBands.forEach(function(e){e.render()})),this.series.forEach(function(e){e.isDirty=!0})}getKeepProps(){return this.keepProps||h.keepProps}destroy(e){let i=this,s=i.plotLinesAndBands,o=this.eventOptions;if(et(this,"destroy",{keepEvents:e}),e||jl(i),[i.ticks,i.minorTicks,i.alternateBands].forEach(function(r){Fl(r)}),s){let r=s.length;for(;r--;)s[r].destroy()}for(let r in["axisLine","axisTitle","axisGroup","gridGroup","labelGroup","cross","scrollbar"].forEach(function(a){i[a]&&(i[a]=i[a].destroy())}),i.plotLinesAndBandsGroups)i.plotLinesAndBandsGroups[r]=i.plotLinesAndBandsGroups[r].destroy();Pi(i,function(r,a){i.getKeepProps().indexOf(a)===-1&&delete i[a]}),this.eventOptions=o}drawCrosshair(e,i){let s=this.crosshair,o=s?.snap??!0,r=this.chart,a,n,l,c=this.cross,d;if(et(this,"drawCrosshair",{e,point:i}),e||(e=this.cross?.e),s&&(Z(i)||!o)!==!1){if(o?Z(i)&&(n=H(this.coll!=="colorAxis"?i.crosshairPos:null,this.isXAxis?i.plotX:this.len-i.plotY)):n=e&&(this.horiz?e.chartX-this.pos:this.len-e.chartY+this.pos),Z(n)&&(d={value:i&&(this.isXAxis?i.x:H(i.stackY,i.y)),translatedValue:n},r.polar&&Ti(d,{isCrosshair:!0,chartX:e?.chartX,chartY:e?.chartY,point:i}),a=this.getPlotLinePath(d)||null),!Z(a)){this.hideCrosshair();return}l=this.categories&&!this.isRadial,c||(this.cross=c=r.renderer.path().addClass("highcharts-crosshair highcharts-crosshair-"+(l?"category ":"thin ")+(s.className||"")).attr({zIndex:H(s.zIndex,2)}).add(),!r.styledMode&&(c.attr({stroke:s.color||(l?tt.parse("#ccd3ff").setOpacity(.25).get():"#cccccc"),"stroke-width":H(s.width,1)}).css({"pointer-events":"none"}),s.dashStyle&&c.attr({dashstyle:s.dashStyle}))),c.show().attr({d:a}),l&&!s.width&&c.attr({"stroke-width":this.transA}),this.cross.e=e}else this.hideCrosshair();et(this,"afterDrawCrosshair",{e,point:i})}hideCrosshair(){this.cross&&this.cross.hide(),et(this,"afterHideCrosshair")}update(e,i){let s=this.chart;e=Ai(this.userOptions,e),this.destroy(!0),this.init(s,e),s.isDirtyBox=!0,H(i,!0)&&s.redraw()}remove(e){let i=this.chart,s=this.coll,o=this.series,r=o.length;for(;r--;)o[r]&&o[r].remove(!1);Xr(i.axes,this),Xr(i[s]||[],this),i.orderItems(s),this.destroy(),i.isDirtyBox=!0,H(e,!0)&&i.redraw()}setTitle(e,i){this.update({title:e},i)}setCategories(e,i){this.update({categories:e},i)}}return h.keepProps=["coll","extKey","hcEvents","len","names","series","userMax","userMin"],h})(),{addEvent:$l,getMagnitude:Zl,normalizeTickInterval:ql,timeUnits:Li}=N;(function(h){function t(){return this.chart.time.getTimeTicks.apply(this.chart.time,arguments)}function e(){if(this.type!=="datetime"){this.dateTime=void 0;return}this.dateTime||(this.dateTime=new i(this))}h.compose=function(s){return s.keepProps.includes("dateTime")||(s.keepProps.push("dateTime"),s.prototype.getTimeTicks=t,$l(s,"afterSetType",e)),s};class i{constructor(o){this.axis=o}normalizeTimeTickInterval(o,r){let a=r||[["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]],n=a[a.length-1],l=Li[n[0]],c=n[1],d;for(d=0;d<a.length&&(l=Li[(n=a[d])[0]],c=n[1],!a[d+1]||!(o<=(l*c[c.length-1]+Li[a[d+1][0]])/2));d++);l===Li.year&&o<5*l&&(c=[1,2,5]);let p=ql(o/l,c,n[0]==="year"?Math.max(Zl(o/l),1):1);return{unitRange:l,count:p,unitName:n[0]}}getXDateFormat(o,r){let{axis:a}=this,n=a.chart.time;return a.closestPointRange?n.getDateFormat(a.closestPointRange,o,a.options.startOfWeek,r)||n.resolveDTLFormat(r.year).main:n.resolveDTLFormat(r.day).main}}h.Additions=i})(os||(os={}));let Kl=os,{addEvent:Ur,normalizeTickInterval:_l,pick:Jl}=N;(function(h){function t(){this.type!=="logarithmic"?this.logarithmic=void 0:this.logarithmic??(this.logarithmic=new i(this))}function e(){let s=this.logarithmic;s&&(this.lin2val=function(o){return s.lin2log(o)},this.val2lin=function(o){return s.log2lin(o)})}h.compose=function(s){return s.keepProps.includes("logarithmic")||(s.keepProps.push("logarithmic"),Ur(s,"afterSetType",t),Ur(s,"afterInit",e)),s};class i{constructor(o){this.axis=o}getLogTickPositions(o,r,a,n){let l=this.axis,c=l.len,d=l.options,p=[];if(n||(this.minorAutoInterval=void 0),o>=.5)o=Math.round(o),p=l.getLinearTickPositions(o,r,a);else if(o>=.08){let g,u,f,x,m,y,b,v=Math.floor(r);for(g=o>.3?[1,2,4]:o>.15?[1,2,4,6,8]:[1,2,3,4,5,6,7,8,9],u=v;u<a+1&&!b;u++)for(f=0,x=g.length;f<x&&!b;f++)(m=this.log2lin(this.lin2log(u)*g[f]))>r&&(!n||y<=a)&&y!==void 0&&p.push(y),y>a&&(b=!0),y=m}else{let g=this.lin2log(r),u=this.lin2log(a),f=n?l.getMinorTickInterval():d.tickInterval,x=d.tickPixelInterval/(n?5:1),m=n?c/l.tickPositions.length:c;o=_l(o=Jl(f==="auto"?null:f,this.minorAutoInterval,(u-g)*x/(m||1))),p=l.getLinearTickPositions(o,g,u).map(this.log2lin),n||(this.minorAutoInterval=o/5)}return n||(l.tickInterval=o),p}lin2log(o){return Math.pow(10,o)}log2lin(o){return Math.log(o)/Math.LN10}}h.Additions=i})(rs||(rs={}));let Ql=rs,{erase:td,extend:ed,isNumber:Vr}=N;(function(h){let t;function e(l){return this.addPlotBandOrLine(l,"plotBands")}function i(l,c){let d=this.userOptions,p=new t(this,l);if(this.visible&&(p=p.render()),p){if(this._addedPlotLB||(this._addedPlotLB=!0,(d.plotLines||[]).concat(d.plotBands||[]).forEach(g=>{this.addPlotBandOrLine(g)})),c){let g=d[c]||[];g.push(l),d[c]=g}this.plotLinesAndBands.push(p)}return p}function s(l){return this.addPlotBandOrLine(l,"plotLines")}function o(l,c,d){d=d||this.options;let p=this.getPlotLinePath({value:c,force:!0,acrossPanes:d.acrossPanes}),g=[],u=this.horiz,f=!Vr(this.min)||!Vr(this.max)||l<this.min&&c<this.min||l>this.max&&c>this.max,x=this.getPlotLinePath({value:l,force:!0,acrossPanes:d.acrossPanes}),m,y=1,b;if(x&&p)for(f&&(b=x.toString()===p.toString(),y=0),m=0;m<x.length;m+=2){let v=x[m],S=x[m+1],w=p[m],k=p[m+1];(v[0]==="M"||v[0]==="L")&&(S[0]==="M"||S[0]==="L")&&(w[0]==="M"||w[0]==="L")&&(k[0]==="M"||k[0]==="L")&&(u&&w[1]===v[1]?(w[1]+=y,k[1]+=y):u||w[2]!==v[2]||(w[2]+=y,k[2]+=y),g.push(["M",v[1],v[2]],["L",S[1],S[2]],["L",k[1],k[2]],["L",w[1],w[2]],["Z"])),g.isFlat=b}return g}function r(l){this.removePlotBandOrLine(l)}function a(l){let c=this.plotLinesAndBands,d=this.options,p=this.userOptions;if(c){let g=c.length;for(;g--;)c[g].id===l&&c[g].destroy();[d.plotLines||[],p.plotLines||[],d.plotBands||[],p.plotBands||[]].forEach(function(u){for(g=u.length;g--;)u[g]?.id===l&&td(u,u[g])})}}function n(l){this.removePlotBandOrLine(l)}h.compose=function(l,c){let d=c.prototype;return d.addPlotBand||(t=l,ed(d,{addPlotBand:e,addPlotLine:s,addPlotBandOrLine:i,getPlotBandPath:o,removePlotBand:r,removePlotLine:n,removePlotBandOrLine:a})),c}})(as||(as={}));let id=as,{addEvent:sd,arrayMax:$r,arrayMin:Zr,defined:Dt,destroyObjectProperties:od,erase:rd,fireEvent:ad,merge:qr,objectEach:nd,pick:hd}=N;class Ei{static compose(t,e){return sd(t,"afterInit",function(){this.labelCollectors.push(()=>{let i=[];for(let s of this.axes)for(let{label:o,options:r}of s.plotLinesAndBands)o&&!r?.label?.allowOverlap&&i.push(o);return i})}),id.compose(Ei,e)}constructor(t,e){this.axis=t,this.options=e,this.id=e.id}render(){ad(this,"render");let{axis:t,options:e}=this,{horiz:i,logarithmic:s}=t,{color:o,events:r,zIndex:a=0}=e,{renderer:n,time:l}=t.chart,c={},d=l.parse(e.to),p=l.parse(e.from),g=l.parse(e.value),u=e.borderWidth,f=e.label,{label:x,svgElem:m}=this,y=[],b,v=Dt(p)&&Dt(d),S=Dt(g),w=!m,k={class:"highcharts-plot-"+(v?"band ":"line ")+(e.className||"")},M=v?"bands":"lines";if(!t.chart.styledMode&&(S?(k.stroke=o||"#999999",k["stroke-width"]=hd(e.width,1),e.dashStyle&&(k.dashstyle=e.dashStyle)):v&&(k.fill=o||"#e6e9ff",u&&(k.stroke=e.borderColor,k["stroke-width"]=u))),c.zIndex=a,M+="-"+a,(b=t.plotLinesAndBandsGroups[M])||(t.plotLinesAndBandsGroups[M]=b=n.g("plot-"+M).attr(c).add()),m||(this.svgElem=m=n.path().attr(k).add(b)),Dt(g))y=t.getPlotLinePath({value:s?.log2lin(g)??g,lineWidth:m.strokeWidth(),acrossPanes:e.acrossPanes});else{if(!(Dt(p)&&Dt(d)))return;y=t.getPlotBandPath(s?.log2lin(p)??p,s?.log2lin(d)??d,e)}return!this.eventsAdded&&r&&(nd(r,(C,T)=>{m?.on(T,A=>{r[T].apply(this,[A])})}),this.eventsAdded=!0),(w||!m.d)&&y?.length?m.attr({d:y}):m&&(y?(m.show(),m.animate({d:y})):m.d&&(m.hide(),x&&(this.label=x=x.destroy()))),f&&(Dt(f.text)||Dt(f.formatter))&&y?.length&&t.width>0&&t.height>0&&!y.isFlat?(f=qr(vt({align:i&&v?"center":void 0,x:i?!v&&4:10,verticalAlign:!i&&v?"middle":void 0,y:i?v?16:10:v?6:-4,rotation:i&&!v?90:0},v?{inside:!0}:{}),f),this.renderLabel(f,y,v,a)):x&&x.hide(),this}renderLabel(t,e,i,s){let o=this.axis,r=o.chart.renderer,a=t.inside,n=this.label;n||(this.label=n=r.text(this.getLabelText(t),0,0,t.useHTML).attr({align:t.textAlign||t.align,rotation:t.rotation,class:"highcharts-plot-"+(i?"band":"line")+"-label "+(t.className||""),zIndex:s}),o.chart.styledMode||n.css(qr({fontSize:"0.8em",textOverflow:i&&!a?"":"ellipsis"},t.style)),n.add());let l=e.xBounds||[e[0][1],e[1][1],i?e[2][1]:e[0][1]],c=e.yBounds||[e[0][2],e[1][2],i?e[2][2]:e[0][2]],d=Zr(l),p=Zr(c),g=$r(l)-d;n.align(t,!1,{x:d,y:p,width:g,height:$r(c)-p}),n.alignAttr.y-=r.fontMetrics(n).b,(!n.alignValue||n.alignValue==="left"||Dt(a))&&n.css({width:(t.style?.width||(i&&a?g:n.rotation===90?o.height-(n.alignAttr.y-o.top):(t.clip?o.width:o.chart.chartWidth)-(n.alignAttr.x-o.left)))+"px"}),n.show(!0)}getLabelText(t){return Dt(t.formatter)?t.formatter.call(this):t.text}destroy(){rd(this.axis.plotLinesAndBands,this),delete this.axis,od(this)}}let{animObject:ld}=dt,{format:Kr}=wt,{composed:dd,dateFormats:cd,doc:_r,isSafari:pd}=P,{distribute:gd}=gi,{addEvent:ud,clamp:Se,css:Jr,discardElement:fd,extend:md,fireEvent:Qr,getAlignFactor:ta,isArray:xd,isNumber:yd,isObject:bd,isString:qs,merge:vd,pick:Ce,pushUnique:kd,splat:Ks,syncTimeout:wd}=N;class _s{constructor(t,e,i){this.allowShared=!0,this.crosshairs=[],this.distance=0,this.isHidden=!0,this.isSticky=!1,this.options={},this.outside=!1,this.chart=t,this.init(t,e),this.pointer=i}bodyFormatter(t){return t.map(e=>{let i=e.series.tooltipOptions,s=e.formatPrefix||"point";return(i[s+"Formatter"]||e.tooltipFormatter).call(e,i[s+"Format"]||"")})}cleanSplit(t){this.chart.series.forEach(function(e){let i=e?.tt;i&&(!i.isActive||t?e.tt=i.destroy():i.isActive=!1)})}defaultFormatter(t){let e,i=this.points||Ks(this);return(e=(e=[t.headerFooterFormatter(i[0])]).concat(t.bodyFormatter(i))).push(t.headerFooterFormatter(i[0],!0)),e}destroy(){this.label&&(this.label=this.label.destroy()),this.split&&(this.cleanSplit(!0),this.tt&&(this.tt=this.tt.destroy())),this.renderer&&(this.renderer=this.renderer.destroy(),fd(this.container)),N.clearTimeout(this.hideTimer)}getAnchor(t,e){let i,{chart:s,pointer:o}=this,r=s.inverted,a=s.plotTop,n=s.plotLeft;if(t=Ks(t),t[0].series?.yAxis&&!t[0].series.yAxis.options.reversedStacks&&(t=t.slice().reverse()),this.followPointer&&e)e.chartX===void 0&&(e=o.normalize(e)),i=[e.chartX-n,e.chartY-a];else if(t[0].tooltipPos)i=t[0].tooltipPos;else{let l=0,c=0;t.forEach(function(d){let p=d.pos(!0);p&&(l+=p[0],c+=p[1])}),l/=t.length,c/=t.length,this.shared&&t.length>1&&e&&(r?l=e.chartX:c=e.chartY),i=[l-n,c-a]}return i.map(Math.round)}getClassName(t,e,i){let s=this.options,o=t.series,r=o.options;return[s.className,"highcharts-label",i&&"highcharts-tooltip-header",e?"highcharts-tooltip-box":"highcharts-tooltip",!i&&"highcharts-color-"+Ce(t.colorIndex,o.colorIndex),r?.className].filter(qs).join(" ")}getLabel({anchorX:t,anchorY:e}={anchorX:0,anchorY:0}){let i=this,s=this.chart.styledMode,o=this.options,r=this.split&&this.allowShared,a=this.container,n=this.chart.renderer;if(this.label){let l=!this.label.hasClass("highcharts-label");(!r&&l||r&&!l)&&this.destroy()}if(!this.label){if(this.outside){let l=this.chart,c=l.options.chart.style,d=Re.getRendererType();this.container=a=P.doc.createElement("div"),a.className="highcharts-tooltip-container "+(l.renderTo.className.match(/(highcharts[a-zA-Z0-9-]+)\s?/gm)||""),Jr(a,{position:"absolute",top:"1px",pointerEvents:"none",zIndex:Math.max(this.options.style.zIndex||0,(c?.zIndex||0)+3)}),this.renderer=n=new d(a,0,0,c,void 0,void 0,n.styledMode)}if(r?this.label=n.g("tooltip"):(this.label=n.label("",t,e,o.shape||"callout",void 0,void 0,o.useHTML,void 0,"tooltip").attr({padding:o.padding,r:o.borderRadius}),s||this.label.attr({fill:o.backgroundColor,"stroke-width":o.borderWidth||0}).css(o.style).css({pointerEvents:o.style.pointerEvents||(this.shouldStickOnContact()?"auto":"none")})),i.outside){let l=this.label;[l.xSetter,l.ySetter].forEach((c,d)=>{l[d?"ySetter":"xSetter"]=p=>{c.call(l,i.distance),l[d?"y":"x"]=p,a&&(a.style[d?"top":"left"]=`${p}px`)}})}this.label.attr({zIndex:8}).shadow(o.shadow??!o.fixed).add()}return a&&!a.parentElement&&P.doc.body.appendChild(a),this.label}getPlayingField(){let{body:t,documentElement:e}=_r,{chart:i,distance:s,outside:o}=this;return{width:o?Math.max(t.scrollWidth,e.scrollWidth,t.offsetWidth,e.offsetWidth,e.clientWidth)-2*s-2:i.chartWidth,height:o?Math.max(t.scrollHeight,e.scrollHeight,t.offsetHeight,e.offsetHeight,e.clientHeight):i.chartHeight}}getPosition(t,e,i){let{distance:s,chart:o,outside:r,pointer:a}=this,{inverted:n,plotLeft:l,plotTop:c,polar:d}=o,{plotX:p=0,plotY:g=0}=i,u={},f=n&&i.h||0,{height:x,width:m}=this.getPlayingField(),y=a.getChartPosition(),b=D=>D*y.scaleX,v=D=>D*y.scaleY,S=D=>{let E=D==="x";return[D,E?m:x,E?t:e].concat(r?[E?b(t):v(e),E?y.left-s+b(p+l):y.top-s+v(g+c),0,E?m:x]:[E?t:e,E?p+l:g+c,E?l:c,E?l+o.plotWidth:c+o.plotHeight])},w=S("y"),k=S("x"),M,C=!!i.negative;!d&&o.hoverSeries?.yAxis?.reversed&&(C=!C);let T=!this.followPointer&&Ce(i.ttBelow,!d&&!n===C),A=function(D,E,B,K,Y,pt,R){let W=r?D==="y"?v(s):b(s):s,j=(B-K)/2,X=K<Y-s,$=Y+s+K<E,q=Y-W-B+j,U=Y+W-j;if(T&&$)u[D]=U;else if(!T&&X)u[D]=q;else if(X)u[D]=Math.min(R-K,q-f<0?q:q-f);else{if(!$)return u[D]=0,!1;u[D]=Math.max(pt,U+f+B>E?U:U+f)}},O=function(D,E,B,K,Y){if(Y<s||Y>E-s)return!1;Y<B/2?u[D]=1:Y>E-K/2?u[D]=E-K-2:u[D]=Y-B/2},L=function(D){[w,k]=[k,w],M=D},I=()=>{A.apply(0,w)!==!1?O.apply(0,k)!==!1||M||(L(!0),I()):M?u.x=u.y=0:(L(!0),I())};return(n&&!d||this.len>1)&&L(),I(),u}getFixedPosition(t,e,i){let s=i.series,{chart:o,options:r,split:a}=this,n=r.position,l=n.relativeTo,c=r.shared||s?.yAxis?.isRadial&&(l==="pane"||!l)?"plotBox":l,d=c==="chart"?o.renderer:o[c]||o.getClipBox(s,!0);return{x:d.x+(d.width-t)*ta(n.align)+n.x,y:d.y+(d.height-e)*ta(n.verticalAlign)+(!a&&n.y||0)}}hide(t){let e=this;N.clearTimeout(this.hideTimer),t=Ce(t,this.options.hideDelay),this.isHidden||(this.hideTimer=wd(function(){let i=e.getLabel();e.getLabel().animate({opacity:0},{duration:t&&150,complete:()=>{i.hide(),e.container&&e.container.remove()}}),e.isHidden=!0},t))}init(t,e){this.chart=t,this.options=e,this.crosshairs=[],this.isHidden=!0,this.split=e.split&&!t.inverted&&!t.polar,this.shared=e.shared||this.split,this.outside=Ce(e.outside,!!(t.scrollablePixelsX||t.scrollablePixelsY))}shouldStickOnContact(t){return!!(!this.followPointer&&this.options.stickOnContact&&(!t||this.pointer.inClass(t.target,"highcharts-tooltip")))}move(t,e,i,s){let{followPointer:o,options:r}=this,a=ld(!o&&!this.isHidden&&!r.fixed&&r.animation),n=o||(this.len||0)>1,l={x:t,y:e};n?l.anchorX=l.anchorY=NaN:(l.anchorX=i,l.anchorY=s),a.step=()=>this.drawTracker(),this.getLabel().animate(l,a)}refresh(t,e){let{chart:i,options:s,pointer:o,shared:r}=this,a=Ks(t),n=a[0],l=s.format,c=s.formatter||this.defaultFormatter,d=i.styledMode,p=this.allowShared;if(!s.enabled||!n.series)return;N.clearTimeout(this.hideTimer),this.allowShared=!(!xd(t)&&t.series&&t.series.noSharedTooltip),p=p&&!this.allowShared,this.followPointer=!this.split&&n.series.tooltipOptions.followPointer;let g=this.getAnchor(t,e),u=g[0],f=g[1];r&&this.allowShared&&(o.applyInactiveState(a),a.forEach(y=>y.setState("hover")),n.points=a),this.len=a.length;let x=qs(l)?Kr(l,n,i):c.call(n,this);n.points=void 0;let m=n.series;if(this.distance=Ce(m.tooltipOptions.distance,16),x===!1)this.hide();else{if(this.split&&this.allowShared)this.renderSplit(x,a);else{let y=u,b=f;if(e&&o.isDirectTouch&&(y=e.chartX-i.plotLeft,b=e.chartY-i.plotTop),i.polar||m.options.clip===!1||a.some(v=>o.isDirectTouch||v.series.shouldShowTooltip(y,b))){let v=this.getLabel(p&&this.tt||{});(!s.style.width||d)&&v.css({width:(this.outside?this.getPlayingField():i.spacingBox).width+"px"}),v.attr({class:this.getClassName(n),text:x&&x.join?x.join(""):x}),this.outside&&v.attr({x:Se(v.x||0,0,this.getPlayingField().width-(v.width||0)-1)}),d||v.attr({stroke:s.borderColor||n.color||m.color||"#666666"}),this.updatePosition({plotX:u,plotY:f,negative:n.negative,ttBelow:n.ttBelow,series:m,h:g[2]||0})}else{this.hide();return}}this.isHidden&&this.label&&this.label.attr({opacity:1}).show(),this.isHidden=!1}Qr(this,"refresh")}renderSplit(t,e){let i=this,{chart:s,chart:{chartWidth:o,chartHeight:r,plotHeight:a,plotLeft:n,plotTop:l,scrollablePixelsY:c=0,scrollablePixelsX:d,styledMode:p},distance:g,options:u,options:{fixed:f,position:x,positioner:m},pointer:y}=i,{scrollLeft:b=0,scrollTop:v=0}=s.scrollablePlotArea?.scrollingContainer||{},S=i.outside&&typeof d!="number"?_r.documentElement.getBoundingClientRect():{left:b,right:b+o,top:v,bottom:v+r},w=i.getLabel(),k=this.renderer||s.renderer,M=!!s.xAxis[0]?.opposite,{left:C,top:T}=y.getChartPosition(),A=m||f,O=l+v,L=0,I=a-c,D=function(R,W,j,X=[0,0],$=!0){let q,U;if(j.isHeader)U=M?0:I,q=Se(X[0]-R/2,S.left,S.right-R-(i.outside?C:0));else if(f&&j){let J=i.getFixedPosition(R,W,j);q=J.x,U=J.y-O}else U=X[1]-O,q=Se(q=$?X[0]-R-g:X[0]+g,$?q:S.left,S.right);return{x:q,y:U}};qs(t)&&(t=[!1,t]);let E=t.slice(0,e.length+1).reduce(function(R,W,j){if(W!==!1&&W!==""){let X=e[j-1]||{isHeader:!0,plotX:e[0].plotX,plotY:a,series:{}},$=X.isHeader,q=$?i:X.series,U=q.tt=function(Oe,Ct,ti){let Qt=Oe,{isHeader:pe,series:ei}=Ct,Pt=ei.tooltipOptions||u;if(!Qt){let Le={padding:Pt.padding,r:Pt.borderRadius};p||(Le.fill=Pt.backgroundColor,Le["stroke-width"]=Pt.borderWidth??(f&&!pe?0:1)),Qt=k.label("",0,0,Pt[pe?"headerShape":"shape"]||(f&&!pe?"rect":"callout"),void 0,void 0,Pt.useHTML).addClass(i.getClassName(Ct,!0,pe)).attr(Le).add(w)}return Qt.isActive=!0,Qt.attr({text:ti}),p||Qt.css(Pt.style).attr({stroke:Pt.borderColor||Ct.color||ei.color||"#333333"}),Qt}(q.tt,X,W.toString()),J=U.getBBox(),gt=J.width+U.strokeWidth();$&&(L=J.height,I+=L,M&&(O-=L));let{anchorX:xt,anchorY:Jt}=function(Oe){let Ct,ti,{isHeader:Qt,plotX:pe=0,plotY:ei=0,series:Pt}=Oe;if(Qt)Ct=Math.max(n+pe,n),ti=l+a/2;else{let{xAxis:Le,yAxis:yn}=Pt;Ct=Le.pos+Se(pe,-g,Le.len+g),Pt.shouldShowTooltip(0,yn.pos-l+ei,{ignoreX:!0})&&(ti=yn.pos+ei)}return{anchorX:Ct=Se(Ct,S.left-g,S.right+g),anchorY:ti}}(X);if(typeof Jt=="number"){let Oe=J.height+1,Ct=(m||D).call(i,gt,Oe,X,[xt,Jt]);R.push({align:A?0:void 0,anchorX:xt,anchorY:Jt,boxWidth:gt,point:X,rank:Ce(Ct.rank,+!!$),size:Oe,target:Ct.y,tt:U,x:Ct.x})}else U.isActive=!1}return R},[]);!A&&E.some(R=>{let{outside:W}=i,j=(W?C:0)+R.anchorX;return j<S.left&&j+R.boxWidth<S.right||j<C-S.left+R.boxWidth&&S.right-j>j})&&(E=E.map(R=>{let{x:W,y:j}=D.call(this,R.boxWidth,R.size,R.point,[R.anchorX,R.anchorY],!1);return md(R,{target:j,x:W})})),i.cleanSplit(),gd(E,I);let B={left:C,right:C};E.forEach(function(R){let{x:W,boxWidth:j,isHeader:X}=R;!X&&(i.outside&&C+W<B.left&&(B.left=C+W),!X&&i.outside&&B.left+j>B.right&&(B.right=C+W))}),E.forEach(function(R){let{x:W,anchorX:j,anchorY:X,pos:$,point:{isHeader:q}}=R,U={visibility:$===void 0?"hidden":"inherit",x:W,y:($||0)+O+(f&&x.y||0),anchorX:j,anchorY:X};if(i.outside&&W<j){let J=C-B.left;J>0&&(q||(U.x=W+J,U.anchorX=j+J),q&&(U.x=(B.right-B.left)/2,U.anchorX=j+J))}R.tt.attr(U)});let{container:K,outside:Y,renderer:pt}=i;if(Y&&K&&pt){let{width:R,height:W,x:j,y:X}=w.getBBox();pt.setSize(R+j,W+X,!1),K.style.left=B.left+"px",K.style.top=T+"px"}pd&&w.attr({opacity:w.opacity===1?.999:1})}drawTracker(){if(!this.shouldStickOnContact()){this.tracker&&(this.tracker=this.tracker.destroy());return}let t=this.chart,e=this.label,i=this.shared?t.hoverPoints:t.hoverPoint;if(!e||!i)return;let s={x:0,y:0,width:0,height:0},o=this.getAnchor(i),r=e.getBBox();o[0]+=t.plotLeft-(e.translateX||0),o[1]+=t.plotTop-(e.translateY||0),s.x=Math.min(0,o[0]),s.y=Math.min(0,o[1]),s.width=o[0]<0?Math.max(Math.abs(o[0]),r.width-o[0]):Math.max(Math.abs(o[0]),r.width),s.height=o[1]<0?Math.max(Math.abs(o[1]),r.height-Math.abs(o[1])):Math.max(Math.abs(o[1]),r.height),this.tracker?this.tracker.attr(s):(this.tracker=e.renderer.rect(s).addClass("highcharts-tracker").add(e),t.styledMode||this.tracker.attr({fill:"rgba(0,0,0,0)"}))}styledModeFormat(t){return t.replace('style="font-size: 0.8em"','class="highcharts-header"').replace(/style="color:{(point|series)\.color}"/g,'class="highcharts-color-{$1.colorIndex} {series.options.className} {point.options.className}"')}headerFooterFormatter(t,e){let i=t.series,s=i.tooltipOptions,o=i.xAxis,r=o?.dateTime,a={isFooter:e,point:t},n=s.xDateFormat||"",l=s[e?"footerFormat":"headerFormat"];return Qr(this,"headerFormatter",a,function(c){if(r&&!n&&yd(t.key)&&(n=r.getXDateFormat(t.key,s.dateTimeLabelFormats)),r&&n){if(bd(n)){let d=n;cd[0]=p=>i.chart.time.dateFormat(d,p),n="%0"}(t.tooltipDateKeys||["key"]).forEach(d=>{l=l.replace(RegExp("point\\."+d+"([ \\)}])"),`(point.${d}:${n})$1`)})}i.chart.styledMode&&(l=this.styledModeFormat(l)),c.text=Kr(l,t,this.chart)}),a.text||""}update(t){this.destroy(),this.init(this.chart,vd(!0,this.options,t))}updatePosition(t){let{chart:e,container:i,distance:s,options:o,pointer:r,renderer:a}=this,{height:n=0,width:l=0}=this.getLabel(),{fixed:c,positioner:d}=o,{left:p,top:g,scaleX:u,scaleY:f}=r.getChartPosition(),x=(d||c&&this.getFixedPosition||this.getPosition).call(this,l,n,t),m=P.doc,y=(t.plotX||0)+e.plotLeft,b=(t.plotY||0)+e.plotTop,v;if(a&&i){if(d||c){let{scrollLeft:S=0,scrollTop:w=0}=e.scrollablePlotArea?.scrollingContainer||{};x.x+=S+p-s,x.y+=w+g-s}v=(o.borderWidth||0)+2*s+2,a.setSize(Se(l+v,0,m.documentElement.clientWidth)-1,n+v,!1),(u!==1||f!==1)&&(Jr(i,{transform:`scale(${u}, ${f})`}),y*=u,b*=f),y+=p-x.x,b+=g-x.y}this.move(Math.round(x.x),Math.round(x.y||0),y,b)}}(function(h){h.compose=function(t){kd(dd,"Core.Tooltip")&&ud(t,"afterInit",function(){let e=this.chart;e.options.tooltip&&(e.tooltip=new h(e,e.options.tooltip,this))})}})(_s||(_s={}));let ea=_s,{animObject:Md}=dt,{defaultOptions:Sd}=kt,{format:Cd}=wt,{addEvent:Td,crisp:Ad,erase:Pd,extend:Ii,fireEvent:Js,getNestedProperty:Od,isArray:Ld,isFunction:Ed,isNumber:Yt,isObject:Di,merge:ia,pick:jt,syncTimeout:Id,removeEvent:sa,uniqueKey:Dd}=N;class Ye{animateBeforeDestroy(){let t=this,e={x:t.startXPos,opacity:0},i=t.getGraphicalProps();i.singular.forEach(function(s){t[s]=t[s].animate(s==="dataLabel"?{x:t[s].startXPos,y:t[s].startYPos,opacity:0}:e)}),i.plural.forEach(function(s){t[s].forEach(function(o){o.element&&o.animate(Ii({x:t.startXPos},o.startYPos?{x:o.startXPos,y:o.startYPos}:{}))})})}applyOptions(t,e){let i=this.series,s=i.options.pointValKey||i.pointValKey;return Ii(this,t=Ye.prototype.optionsToObject.call(this,t)),this.options=this.options?Ii(this.options,t):t,t.group&&delete this.group,t.dataLabels&&delete this.dataLabels,s&&(this.y=Ye.prototype.getNestedProperty.call(this,s)),this.selected&&(this.state="select"),"name"in this&&e===void 0&&i.xAxis&&i.xAxis.hasNames&&(this.x=i.xAxis.nameToX(this)),this.x===void 0&&i?this.x=e??i.autoIncrement():Yt(t.x)&&i.options.relativeXValue?this.x=i.autoIncrement(t.x):typeof this.x=="string"&&(e??(e=i.chart.time.parse(this.x)),Yt(e)&&(this.x=e)),this.isNull=this.isValid&&!this.isValid(),this.formatPrefix=this.isNull?"null":"point",this}destroy(){if(!this.destroyed){let t=this,e=t.series,i=e.chart,s=e.options.dataSorting,o=i.hoverPoints,r=Md(t.series.chart.renderer.globalAnimation),a=()=>{for(let n in(t.graphic||t.graphics||t.dataLabel||t.dataLabels)&&(sa(t),t.destroyElements()),t)delete t[n]};t.legendItem&&i.legend.destroyItem(t),o&&(t.setState(),Pd(o,t),o.length||(i.hoverPoints=null)),t===i.hoverPoint&&t.onMouseOut(),s?.enabled?(this.animateBeforeDestroy(),Id(a,r.duration)):a(),i.pointCount--}this.destroyed=!0}destroyElements(t){let e=this,i=e.getGraphicalProps(t);i.singular.forEach(function(s){e[s]=e[s].destroy()}),i.plural.forEach(function(s){e[s].forEach(function(o){o?.element&&o.destroy()}),delete e[s]})}firePointEvent(t,e,i){let s=this,o=this.series.options;s.manageEvent(t),t==="click"&&o.allowPointSelect&&(i=function(r){!s.destroyed&&s.select&&s.select(null,r.ctrlKey||r.metaKey||r.shiftKey)}),Js(s,t,e,i)}getClassName(){return"highcharts-point"+(this.selected?" highcharts-point-select":"")+(this.negative?" highcharts-negative":"")+(this.isNull?" highcharts-null-point":"")+(this.colorIndex!==void 0?" highcharts-color-"+this.colorIndex:"")+(this.options.className?" "+this.options.className:"")+(this.zone?.className?" "+this.zone.className.replace("highcharts-negative",""):"")}getGraphicalProps(t){let e,i,s=this,o=[],r={singular:[],plural:[]};for((t=t||{graphic:1,dataLabel:1}).graphic&&o.push("graphic","connector"),t.dataLabel&&o.push("dataLabel","dataLabelPath","dataLabelUpper"),i=o.length;i--;)s[e=o[i]]&&r.singular.push(e);return["graphic","dataLabel"].forEach(function(a){let n=a+"s";t[a]&&s[n]&&r.plural.push(n)}),r}getNestedProperty(t){return t?t.indexOf("custom.")===0?Od(t,this.options):this[t]:void 0}getZone(){let t=this.series,e=t.zones,i=t.zoneAxis||"y",s,o=0;for(s=e[0];this[i]>=s.value;)s=e[++o];return this.nonZonedColor||(this.nonZonedColor=this.color),s?.color&&!this.options.color?this.color=s.color:this.color=this.nonZonedColor,s}hasNewShapeType(){return(this.graphic&&(this.graphic.symbolName||this.graphic.element.nodeName))!==this.shapeType}constructor(t,e,i){this.formatPrefix="point",this.visible=!0,this.point=this,this.series=t,this.applyOptions(e,i),this.id??(this.id=Dd()),this.resolveColor(),this.dataLabelOnNull??(this.dataLabelOnNull=t.options.nullInteraction),t.chart.pointCount++,Js(this,"afterInit")}isValid(){return(Yt(this.x)||this.x instanceof Date)&&Yt(this.y)}optionsToObject(t){let e=this.series,i=e.options.keys,s=i||e.pointArrayMap||["y"],o=s.length,r={},a,n=0,l=0;if(Yt(t)||t===null)r[s[0]]=t;else if(Ld(t))for(!i&&t.length>o&&((a=typeof t[0])=="string"?e.xAxis?.dateTime?r.x=e.chart.time.parse(t[0]):r.name=t[0]:a==="number"&&(r.x=t[0]),n++);l<o;)i&&t[n]===void 0||(s[l].indexOf(".")>0?Ye.prototype.setNestedProperty(r,t[n],s[l]):r[s[l]]=t[n]),n++,l++;else typeof t=="object"&&(r=t,t.dataLabels&&(e.hasDataLabels=()=>!0),t.marker&&(e._hasPointMarkers=!0));return r}pos(t,e=this.plotY){if(!this.destroyed){let{plotX:i,series:s}=this,{chart:o,xAxis:r,yAxis:a}=s,n=0,l=0;if(Yt(i)&&Yt(e))return t&&(n=r?r.pos:o.plotLeft,l=a?a.pos:o.plotTop),o.inverted&&r&&a?[a.len-e+l,r.len-i+n]:[i+n,e+l]}}resolveColor(){let t=this.series,e=t.chart.options.chart,i=t.chart.styledMode,s,o,r=e.colorCount,a;delete this.nonZonedColor,t.options.colorByPoint?(i||(s=(o=t.options.colors||t.chart.options.colors)[t.colorCounter],r=o.length),a=t.colorCounter,t.colorCounter++,t.colorCounter===r&&(t.colorCounter=0)):(i||(s=t.color),a=t.colorIndex),this.colorIndex=jt(this.options.colorIndex,a),this.color=jt(this.options.color,s)}setNestedProperty(t,e,i){return i.split(".").reduce(function(s,o,r,a){let n=a.length-1===r;return s[o]=n?e:Di(s[o],!0)?s[o]:{},s[o]},t),t}shouldDraw(){return!this.isNull}tooltipFormatter(t){let{chart:e,pointArrayMap:i=["y"],tooltipOptions:s}=this.series,{valueDecimals:o="",valuePrefix:r="",valueSuffix:a=""}=s;return e.styledMode&&(t=e.tooltip?.styledModeFormat(t)||t),i.forEach(n=>{n="{point."+n,(r||a)&&(t=t.replace(RegExp(n+"}","g"),r+n+"}"+a)),t=t.replace(RegExp(n+"}","g"),n+":,."+o+"f}")}),Cd(t,this,e)}update(t,e,i,s){let o,r=this,a=r.series,n=r.graphic,l=a.chart,c=a.options;function d(){r.applyOptions(t);let p=n&&r.hasMockGraphic,g=r.y===null?!p:p;n&&g&&(r.graphic=n.destroy(),delete r.hasMockGraphic),Di(t,!0)&&(n?.element&&t&&t.marker&&t.marker.symbol!==void 0&&(r.graphic=n.destroy()),t?.dataLabels&&r.dataLabel&&(r.dataLabel=r.dataLabel.destroy())),o=r.index;let u={};for(let f of a.dataColumnKeys())u[f]=r[f];a.dataTable.setRow(u,o),c.data[o]=Di(c.data[o],!0)||Di(t,!0)?r.options:jt(t,c.data[o]),a.isDirty=a.isDirtyData=!0,!a.fixedBox&&a.hasCartesianSeries&&(l.isDirtyBox=!0),c.legendType==="point"&&(l.isDirtyLegend=!0),e&&l.redraw(i)}e=jt(e,!0),s===!1?d():r.firePointEvent("update",{options:t},d)}remove(t,e){this.series.removePoint(this.series.data.indexOf(this),t,e)}select(t,e){let i=this,s=i.series,o=s.chart;t=jt(t,!i.selected),this.selectedStaging=t,i.firePointEvent(t?"select":"unselect",{accumulate:e},function(){i.selected=i.options.selected=t,s.options.data[s.data.indexOf(i)]=i.options,i.setState(t&&"select"),e||o.getSelectedPoints().forEach(function(r){let a=r.series;r.selected&&r!==i&&(r.selected=r.options.selected=!1,a.options.data[a.data.indexOf(r)]=r.options,r.setState(o.hoverPoints&&a.options.inactiveOtherPoints?"inactive":""),r.firePointEvent("unselect"))})}),delete this.selectedStaging}onMouseOver(t){let{inverted:e,pointer:i}=this.series.chart;i&&(t=t?i.normalize(t):i.getChartCoordinatesFromPoint(this,e),i.runPointActions(t,this))}onMouseOut(){let t=this.series.chart;this.firePointEvent("mouseOut"),this.series.options.inactiveOtherPoints||(t.hoverPoints||[]).forEach(function(e){e.setState()}),t.hoverPoints=t.hoverPoint=null}manageEvent(t){let e=ia(this.series.options.point,this.options),i=e.events?.[t];Ed(i)&&(!this.hcEvents?.[t]||this.hcEvents?.[t]?.map(s=>s.fn).indexOf(i)===-1)?(this.importedUserEvent?.(),this.importedUserEvent=Td(this,t,i),this.hcEvents&&(this.hcEvents[t].userEvent=!0)):this.importedUserEvent&&!i&&this.hcEvents?.[t]&&this.hcEvents?.[t].userEvent&&(sa(this,t),delete this.hcEvents[t],Object.keys(this.hcEvents)||delete this.importedUserEvent)}setState(t,e){let i=this.series,s=this.state,o=i.options.states[t||"normal"]||{},r=Sd.plotOptions[i.type].marker&&i.options.marker,a=r&&r.enabled===!1,n=r?.states?.[t||"normal"]||{},l=n.enabled===!1,c=this.marker||{},d=i.chart,p=r&&i.markerAttribs,g=i.halo,u,f,x,m=i.stateMarkerGraphic,y;if((t=t||"")===this.state&&!e||this.selected&&t!=="select"||o.enabled===!1||t&&(l||a&&n.enabled===!1)||t&&c.states&&c.states[t]&&c.states[t].enabled===!1)return;if(this.state=t,p&&(u=i.markerAttribs(this,t)),this.graphic&&!this.hasMockGraphic){if(s&&this.graphic.removeClass("highcharts-point-"+s),t&&this.graphic.addClass("highcharts-point-"+t),!d.styledMode){f=i.pointAttribs(this,t),x=jt(d.options.chart.animation,o.animation);let w=f.opacity;i.options.inactiveOtherPoints&&Yt(w)&&(this.dataLabels||[]).forEach(function(k){k&&!k.hasClass("highcharts-data-label-hidden")&&(k.animate({opacity:w},x),k.connector&&k.connector.animate({opacity:w},x))}),this.graphic.animate(f,x)}u&&this.graphic.animate(u,jt(d.options.chart.animation,n.animation,r.animation)),m&&m.hide()}else t&&n&&(y=c.symbol||i.symbol,m&&m.currentSymbol!==y&&(m=m.destroy()),u&&(m?m[e?"animate":"attr"]({x:u.x,y:u.y}):y&&(i.stateMarkerGraphic=m=d.renderer.symbol(y,u.x,u.y,u.width,u.height,ia(r,n)).add(i.markerGroup),m.currentSymbol=y)),!d.styledMode&&m&&this.state!=="inactive"&&m.attr(i.pointAttribs(this,t))),m&&(m[t&&this.isInside?"show":"hide"](),m.element.point=this,m.addClass(this.getClassName(),!0));let b=o.halo,v=this.graphic||m,S=v?.visibility||"inherit";b?.size&&v&&S!=="hidden"&&!this.isCluster?(g||(i.halo=g=d.renderer.path().add(v.parentGroup)),g.show()[e?"animate":"attr"]({d:this.haloPath(b.size)}),g.attr({class:"highcharts-halo highcharts-color-"+jt(this.colorIndex,i.colorIndex)+(this.className?" "+this.className:""),visibility:S,zIndex:-1}),g.point=this,d.styledMode||g.attr(Ii({fill:this.color||i.color,"fill-opacity":b.opacity},_.filterUserAttributes(b.attributes||{})))):g?.point?.haloPath&&!g.point.destroyed&&g.animate({d:g.point.haloPath(0)},null,g.hide),Js(this,"afterSetState",{state:t})}haloPath(t){let e=this.pos();return e?this.series.chart.renderer.symbols.circle(Ad(e[0],1)-t,e[1]-t,2*t,2*t):[]}}let Ut=Ye,{parse:Bd}=tt,{charts:Qs,composed:Nd,isTouchDevice:zd}=P,{addEvent:Mt,attr:Rd,css:to,extend:eo,find:oa,fireEvent:Vt,isNumber:Bi,isObject:Ni,objectEach:Wd,offset:Hd,pick:Bt,pushUnique:Xd,splat:ra}=N;class ht{applyInactiveState(t=[]){let e=[];t.forEach(i=>{let s=i.series;e.push(s),s.linkedParent&&e.push(s.linkedParent),s.linkedSeries&&e.push.apply(e,s.linkedSeries),s.navigatorSeries&&e.push(s.navigatorSeries),s.boosted&&s.markerGroup&&e.push.apply(e,this.chart.series.filter(o=>o.markerGroup===s.markerGroup))}),this.chart.series.forEach(i=>{e.indexOf(i)===-1?i.setState("inactive",!0):i.options.inactiveOtherPoints&&i.setAllPointsToState("inactive")})}destroy(){let t=this;this.eventsToUnbind.forEach(e=>e()),this.eventsToUnbind=[],!P.chartCount&&(ht.unbindDocumentMouseUp.forEach(e=>e.unbind()),ht.unbindDocumentMouseUp.length=0,ht.unbindDocumentTouchEnd&&(ht.unbindDocumentTouchEnd=ht.unbindDocumentTouchEnd())),clearInterval(t.tooltipTimeout),Wd(t,function(e,i){t[i]=void 0})}getSelectionMarkerAttrs(t,e){let i={args:{chartX:t,chartY:e},attrs:{},shapeType:"rect"};return Vt(this,"getSelectionMarkerAttrs",i,s=>{let o,{chart:r,zoomHor:a,zoomVert:n}=this,{mouseDownX:l=0,mouseDownY:c=0}=r,d=s.attrs;d.x=r.plotLeft,d.y=r.plotTop,d.width=a?1:r.plotWidth,d.height=n?1:r.plotHeight,a&&(d.width=Math.max(1,Math.abs(o=t-l)),d.x=(o>0?0:o)+l),n&&(d.height=Math.max(1,Math.abs(o=e-c)),d.y=(o>0?0:o)+c)}),i}drag(t){let{chart:e}=this,{mouseDownX:i=0,mouseDownY:s=0}=e,{panning:o,panKey:r,selectionMarkerFill:a}=e.options.chart,n=e.plotLeft,l=e.plotTop,c=e.plotWidth,d=e.plotHeight,p=Ni(o)?o.enabled:o,g=r&&t[`${r}Key`],u=t.chartX,f=t.chartY,x,m=this.selectionMarker;if((!m||!m.touch)&&(u<n?u=n:u>n+c&&(u=n+c),f<l?f=l:f>l+d&&(f=l+d),this.hasDragged=Math.sqrt(Math.pow(i-u,2)+Math.pow(s-f,2)),this.hasDragged>10)){x=e.isInsidePlot(i-n,s-l,{visiblePlotOnly:!0});let{shapeType:y,attrs:b}=this.getSelectionMarkerAttrs(u,f);(e.hasCartesianSeries||e.mapView)&&this.hasZoom&&x&&!g&&!m&&(this.selectionMarker=m=e.renderer[y](),m.attr({class:"highcharts-selection-marker",zIndex:7}).add(),e.styledMode||m.attr({fill:a||Bd("#334eff").setOpacity(.25).get()})),m&&m.attr(b),x&&!m&&p&&e.pan(t,o)}}dragStart(t){let e=this.chart;e.mouseIsDown=t.type,e.cancelClick=!1,e.mouseDownX=t.chartX,e.mouseDownY=t.chartY}getSelectionBox(t){let e={args:{marker:t},result:t.getBBox()};return Vt(this,"getSelectionBox",e),e.result}drop(t){let e,{chart:i,selectionMarker:s}=this;for(let o of i.axes)o.isPanning&&(o.isPanning=!1,(o.options.startOnTick||o.options.endOnTick||o.series.some(r=>r.boosted))&&(o.forceRedraw=!0,o.setExtremes(o.userMin,o.userMax,!1),e=!0));if(e&&i.redraw(),s&&t){if(this.hasDragged){let o=this.getSelectionBox(s);i.transform({axes:i.axes.filter(r=>r.zoomEnabled&&(r.coll==="xAxis"&&this.zoomX||r.coll==="yAxis"&&this.zoomY)),selection:vt({originalEvent:t,xAxis:[],yAxis:[]},o),from:o})}Bi(i.index)&&(this.selectionMarker=s.destroy())}i&&Bi(i.index)&&(to(i.container,{cursor:i._cursor}),i.cancelClick=this.hasDragged>10,i.mouseIsDown=!1,this.hasDragged=0,this.pinchDown=[])}findNearestKDPoint(t,e,i){let s;return t.forEach(function(o){let r=!(o.noSharedTooltip&&e)&&0>o.options.findNearestPointBy.indexOf("y"),a=o.searchPoint(i,r);Ni(a,!0)&&a.series&&(!Ni(s,!0)||function(n,l){let c,d=n.distX-l.distX,p=n.dist-l.dist,g=l.series.group?.zIndex-n.series.group?.zIndex;return d!==0&&e?d:p!==0?p:g!==0?g:n.series.index>l.series.index?-1:1}(s,a)>0)&&(s=a)}),s}getChartCoordinatesFromPoint(t,e){let{xAxis:i,yAxis:s}=t.series,o=t.shapeArgs;if(i&&s){let r=t.clientX??t.plotX??0,a=t.plotY||0;return t.isNode&&o&&Bi(o.x)&&Bi(o.y)&&(r=o.x,a=o.y),e?{chartX:s.len+s.pos-a,chartY:i.len+i.pos-r}:{chartX:r+i.pos,chartY:a+s.pos}}if(o?.x&&o.y)return{chartX:o.x,chartY:o.y}}getChartPosition(){if(this.chartPosition)return this.chartPosition;let{container:t}=this.chart,e=Hd(t);this.chartPosition={left:e.left,top:e.top,scaleX:1,scaleY:1};let{offsetHeight:i,offsetWidth:s}=t;return s>2&&i>2&&(this.chartPosition.scaleX=e.width/s,this.chartPosition.scaleY=e.height/i),this.chartPosition}getCoordinates(t){let e={xAxis:[],yAxis:[]};for(let i of this.chart.axes)e[i.isXAxis?"xAxis":"yAxis"].push({axis:i,value:i.toValue(t[i.horiz?"chartX":"chartY"])});return e}getHoverData(t,e,i,s,o,r){let a=[],n=function(g){return g.visible&&!(!o&&g.directTouch)&&Bt(g.options.enableMouseTracking,!0)},l=e,c,d={chartX:r?r.chartX:void 0,chartY:r?r.chartY:void 0,shared:o};Vt(this,"beforeGetHoverData",d),c=l&&!l.stickyTracking?[l]:i.filter(g=>g.stickyTracking&&(d.filter||n)(g));let p=s&&t||!r?t:this.findNearestKDPoint(c,o,r);return l=p?.series,p&&(o&&!l.noSharedTooltip?(c=i.filter(function(g){return d.filter?d.filter(g):n(g)&&!g.noSharedTooltip})).forEach(function(g){let u=g.options?.nullInteraction,f=oa(g.points,function(x){return x.x===p.x&&(!x.isNull||!!u)});Ni(f)&&(g.boosted&&g.boost&&(f=g.boost.getPoint(f)),a.push(f))}):a.push(p)),Vt(this,"afterGetHoverData",d={hoverPoint:p}),{hoverPoint:d.hoverPoint,hoverSeries:l,hoverPoints:a}}getPointFromEvent(t){let e=t.target,i;for(;e&&!i;)i=e.point,e=e.parentNode;return i}onTrackerMouseOut(t){let e=this.chart,i=t.relatedTarget,s=e.hoverSeries;this.isDirectTouch=!1,!s||!i||s.stickyTracking||this.inClass(i,"highcharts-tooltip")||this.inClass(i,"highcharts-series-"+s.index)&&this.inClass(i,"highcharts-tracker")||s.onMouseOut()}inClass(t,e){let i=t,s;for(;i;){if(s=Rd(i,"class")){if(s.indexOf(e)!==-1)return!0;if(s.indexOf("highcharts-container")!==-1)return!1}i=i.parentElement}}constructor(t,e){this.hasDragged=0,this.pointerCaptureEventsToUnbind=[],this.eventsToUnbind=[],this.options=e,this.chart=t,this.runChartClick=!!e.chart.events?.click,this.pinchDown=[],this.setDOMEvents(),Vt(this,"afterInit")}normalize(t,e){let i=t.touches,s=i?i.length?i.item(0):Bt(i.changedTouches,t.changedTouches)[0]:t;e||(e=this.getChartPosition());let o=s.pageX-e.left,r=s.pageY-e.top;return eo(t,{chartX:Math.round(o/=e.scaleX),chartY:Math.round(r/=e.scaleY)})}onContainerClick(t){let e=this.chart,i=e.hoverPoint,s=this.normalize(t),o=e.plotLeft,r=e.plotTop;!e.cancelClick&&(i&&this.inClass(s.target,"highcharts-tracker")?(Vt(i.series,"click",eo(s,{point:i})),e.hoverPoint&&i.firePointEvent("click",s)):(eo(s,this.getCoordinates(s)),e.isInsidePlot(s.chartX-o,s.chartY-r,{visiblePlotOnly:!0})&&Vt(e,"click",s)))}onContainerMouseDown(t){let e=(1&(t.buttons||t.button))==1;t=this.normalize(t),P.isFirefox&&t.button!==0&&this.onContainerMouseMove(t),(t.button===void 0||e)&&(this.zoomOption(t),e&&t.preventDefault?.(),this.dragStart(t))}onContainerMouseLeave(t){let{pointer:e}=Qs[Bt(ht.hoverChartIndex,-1)]||{};t=this.normalize(t),this.onContainerMouseMove(t),e&&!this.inClass(t.relatedTarget,"highcharts-tooltip")&&(e.reset(),e.chartPosition=void 0)}onContainerMouseEnter(){delete this.chartPosition}onContainerMouseMove(t){let e=this.chart,i=e.tooltip,s=this.normalize(t);this.setHoverChartIndex(t),(e.mouseIsDown==="mousedown"||this.touchSelect(s))&&this.drag(s),!e.openMenu&&(this.inClass(s.target,"highcharts-tracker")||e.isInsidePlot(s.chartX-e.plotLeft,s.chartY-e.plotTop,{visiblePlotOnly:!0}))&&!i?.shouldStickOnContact(s)&&(this.inClass(s.target,"highcharts-no-tooltip")?this.reset(!1,0):this.runPointActions(s))}onDocumentTouchEnd(t){this.onDocumentMouseUp(t)}onContainerTouchMove(t){this.touchSelect(t)?this.onContainerMouseMove(t):this.touch(t)}onContainerTouchStart(t){this.touchSelect(t)?this.onContainerMouseDown(t):(this.zoomOption(t),this.touch(t,!0))}onDocumentMouseMove(t){let e=this.chart,i=e.tooltip,s=this.chartPosition,o=this.normalize(t,s);!s||e.isInsidePlot(o.chartX-e.plotLeft,o.chartY-e.plotTop,{visiblePlotOnly:!0})||i?.shouldStickOnContact(o)||o.target!==e.container.ownerDocument&&this.inClass(o.target,"highcharts-tracker")||this.reset()}onDocumentMouseUp(t){Qs[Bt(ht.hoverChartIndex,-1)]?.pointer?.drop(t)}pinch(t){let e=this,{chart:i,hasZoom:s,lastTouches:o}=e,r=[].map.call(t.touches||[],d=>e.normalize(d)),a=r.length,n=a===1&&(e.inClass(t.target,"highcharts-tracker")&&i.runTrackerClick||e.runChartClick),l=i.tooltip,c=a===1&&Bt(l?.options.followTouchMove,!0);a>1?e.initiated=!0:c&&(e.initiated=!1),s&&e.initiated&&!n&&t.cancelable!==!1&&t.preventDefault(),t.type==="touchstart"?(e.pinchDown=r,e.res=!0,i.mouseDownX=t.chartX):c?this.runPointActions(e.normalize(t)):o&&(Vt(i,"touchpan",{originalEvent:t,touches:r},()=>{let d=p=>{let g=p[0],u=p[1]||g;return{x:g.chartX,y:g.chartY,width:u.chartX-g.chartX,height:u.chartY-g.chartY}};i.transform({axes:i.axes.filter(p=>p.zoomEnabled&&(this.zoomHor&&p.horiz||this.zoomVert&&!p.horiz)),to:d(r),from:d(o),trigger:t.type})}),e.res&&(e.res=!1,this.reset(!1,0))),e.lastTouches=r}reset(t,e){let i=this.chart,s=i.hoverSeries,o=i.hoverPoint,r=i.hoverPoints,a=i.tooltip,n=a?.shared?r:o;t&&n&&ra(n).forEach(function(l){l.series.isCartesian&&l.plotX===void 0&&(t=!1)}),t?a&&n&&ra(n).length&&(a.refresh(n),a.shared&&r?r.forEach(function(l){l.setState(l.state,!0),l.series.isCartesian&&(l.series.xAxis.crosshair&&l.series.xAxis.drawCrosshair(null,l),l.series.yAxis.crosshair&&l.series.yAxis.drawCrosshair(null,l))}):o&&(o.setState(o.state,!0),i.axes.forEach(function(l){l.crosshair&&o.series[l.coll]===l&&l.drawCrosshair(null,o)}))):(o&&o.onMouseOut(),r&&r.forEach(function(l){l.setState()}),s&&s.onMouseOut(),a&&a.hide(e),this.unDocMouseMove&&(this.unDocMouseMove=this.unDocMouseMove()),i.axes.forEach(function(l){l.hideCrosshair()}),i.hoverPoints=i.hoverPoint=void 0)}runPointActions(t,e,i){let s=this.chart,o=s.series,r=s.tooltip?.options.enabled?s.tooltip:void 0,a=!!r&&r.shared,n=e||s.hoverPoint,l=n?.series||s.hoverSeries,c=(!t||t.type!=="touchmove")&&(!!e||l?.directTouch&&this.isDirectTouch),d=this.getHoverData(n,l,o,c,a,t);n=d.hoverPoint,l=d.hoverSeries;let p=d.hoverPoints,g=l?.tooltipOptions.followPointer&&!l.tooltipOptions.split,u=a&&l&&!l.noSharedTooltip;if(n&&(i||n!==s.hoverPoint||r?.isHidden)){if((s.hoverPoints||[]).forEach(function(f){p.indexOf(f)===-1&&f.setState()}),s.hoverSeries!==l&&l.onMouseOver(),this.applyInactiveState(p),(p||[]).forEach(function(f){f.setState("hover")}),s.hoverPoint&&s.hoverPoint.firePointEvent("mouseOut"),!n.series)return;s.hoverPoints=p,s.hoverPoint=n,n.firePointEvent("mouseOver",void 0,()=>{r&&n&&r.refresh(u?p:n,t)})}else if(g&&r&&!r.isHidden){let f=r.getAnchor([{}],t);s.isInsidePlot(f[0],f[1],{visiblePlotOnly:!0})&&r.updatePosition({plotX:f[0],plotY:f[1]})}this.unDocMouseMove||(this.unDocMouseMove=Mt(s.container.ownerDocument,"mousemove",f=>Qs[ht.hoverChartIndex??-1]?.pointer?.onDocumentMouseMove(f)),this.eventsToUnbind.push(this.unDocMouseMove)),s.axes.forEach(function(f){let x,m=f.crosshair?.snap??!0;!m||(x=s.hoverPoint)&&x.series[f.coll]===f||(x=oa(p,y=>y.series?.[f.coll]===f)),x||!m?f.drawCrosshair(t,x):f.hideCrosshair()})}setDOMEvents(){let t=this.chart.container,e=t.ownerDocument;t.onmousedown=this.onContainerMouseDown.bind(this),t.onmousemove=this.onContainerMouseMove.bind(this),t.onclick=this.onContainerClick.bind(this),this.eventsToUnbind.push(Mt(t,"mouseenter",this.onContainerMouseEnter.bind(this)),Mt(t,"mouseleave",this.onContainerMouseLeave.bind(this))),ht.unbindDocumentMouseUp.some(s=>s.doc===e)||ht.unbindDocumentMouseUp.push({doc:e,unbind:Mt(e,"mouseup",this.onDocumentMouseUp.bind(this))});let i=this.chart.renderTo.parentElement;for(;i&&i.tagName!=="BODY";)this.eventsToUnbind.push(Mt(i,"scroll",()=>{delete this.chartPosition})),i=i.parentElement;this.eventsToUnbind.push(Mt(t,"touchstart",this.onContainerTouchStart.bind(this),{passive:!1}),Mt(t,"touchmove",this.onContainerTouchMove.bind(this),{passive:!1})),ht.unbindDocumentTouchEnd||(ht.unbindDocumentTouchEnd=Mt(e,"touchend",this.onDocumentTouchEnd.bind(this),{passive:!1})),this.setPointerCapture(),Mt(this.chart,"redraw",this.setPointerCapture.bind(this))}setPointerCapture(){if(!zd)return;let t=this.pointerCaptureEventsToUnbind,e=this.chart,i=e.container,s=Bt(e.options.tooltip?.followTouchMove,!0)&&e.series.some(o=>o.options.findNearestPointBy.indexOf("y")>-1);!this.hasPointerCapture&&s?(t.push(Mt(i,"pointerdown",o=>{o.target?.hasPointerCapture(o.pointerId)&&o.target?.releasePointerCapture(o.pointerId)}),Mt(i,"pointermove",o=>{e.pointer?.getPointFromEvent(o)?.onMouseOver(o)})),e.styledMode||to(i,{"touch-action":"none"}),i.className+=" highcharts-no-touch-action",this.hasPointerCapture=!0):this.hasPointerCapture&&!s&&(t.forEach(o=>o()),t.length=0,e.styledMode||to(i,{"touch-action":Bt(e.options.chart.style?.["touch-action"],"manipulation")}),i.className=i.className.replace(" highcharts-no-touch-action",""),this.hasPointerCapture=!1)}setHoverChartIndex(t){let e=this.chart,i=P.charts[Bt(ht.hoverChartIndex,-1)];if(i&&i!==e){let s={relatedTarget:e.container};t&&!t?.relatedTarget&&Object.assign({},t,s),i.pointer?.onContainerMouseLeave(t||s)}i?.mouseIsDown||(ht.hoverChartIndex=e.index)}touch(t,e){let i,{chart:s,pinchDown:o=[]}=this;this.setHoverChartIndex(),(t=this.normalize(t)).touches.length===1?s.isInsidePlot(t.chartX-s.plotLeft,t.chartY-s.plotTop,{visiblePlotOnly:!0})&&!s.openMenu?(e&&this.runPointActions(t),t.type==="touchmove"&&(i=!!o[0]&&Math.pow(o[0].chartX-t.chartX,2)+Math.pow(o[0].chartY-t.chartY,2)>=16),Bt(i,!0)&&this.pinch(t)):e&&this.reset():t.touches.length===2&&this.pinch(t)}touchSelect(t){return!!(this.chart.zooming.singleTouch&&t.touches&&t.touches.length===1)}zoomOption(t){let e=this.chart,i=e.inverted,s=e.zooming.type||"",o,r;/touch/.test(t.type)&&(s=Bt(e.zooming.pinchType,s)),this.zoomX=o=/x/.test(s),this.zoomY=r=/y/.test(s),this.zoomHor=o&&!i||r&&i,this.zoomVert=r&&!i||o&&i,this.hasZoom=o||r}}ht.unbindDocumentMouseUp=[],function(h){h.compose=function(t){Xd(Nd,"Core.Pointer")&&Mt(t,"beforeRender",function(){this.pointer=new h(this,this.options)})}}(ht||(ht={}));let aa=ht;(function(h){h.setLength=function(t,e,i){return Array.isArray(t)?(t.length=e,t):t[i?"subarray":"slice"](0,e)},h.splice=function(t,e,i,s,o=[]){if(Array.isArray(t))return Array.isArray(o)||(o=Array.from(o)),{removed:t.splice(e,i,...o),array:t};let r=Object.getPrototypeOf(t).constructor,a=t[s?"subarray":"slice"](e,e+i),n=new r(t.length-i+o.length);return n.set(t.subarray(0,e),0),n.set(o,e),n.set(t.subarray(e+i),e+o.length),{removed:a,array:n}}})(ns||(ns={}));let{setLength:Fd,splice:na}=ns,{fireEvent:io,objectEach:je,uniqueKey:Ue}=N,zi=class{constructor(h={}){this.autoId=!h.id,this.columns={},this.id=h.id||Ue(),this.modified=this,this.rowCount=0,this.versionTag=Ue();let t=0;je(h.columns||{},(e,i)=>{this.columns[i]=e.slice(),t=Math.max(t,e.length)}),this.applyRowCount(t)}applyRowCount(h){this.rowCount=h,je(this.columns,(t,e)=>{t.length!==h&&(this.columns[e]=Fd(t,h))})}deleteRows(h,t=1){if(t>0&&h<this.rowCount){let e=0;je(this.columns,(i,s)=>{this.columns[s]=na(i,h,t).array,e=i.length}),this.rowCount=e}io(this,"afterDeleteRows",{rowIndex:h,rowCount:t}),this.versionTag=Ue()}getColumn(h,t){return this.columns[h]}getColumns(h,t){return(h||Object.keys(this.columns)).reduce((e,i)=>(e[i]=this.columns[i],e),{})}getRow(h,t){return(t||Object.keys(this.columns)).map(e=>this.columns[e]?.[h])}setColumn(h,t=[],e=0,i){this.setColumns({[h]:t},e,i)}setColumns(h,t,e){let i=this.rowCount;je(h,(s,o)=>{this.columns[o]=s.slice(),i=s.length}),this.applyRowCount(i),e?.silent||(io(this,"afterSetColumns"),this.versionTag=Ue())}setRow(h,t=this.rowCount,e,i){let{columns:s}=this,o=e?this.rowCount+1:t+1;je(h,(r,a)=>{let n=s[a]||i?.addColumns!==!1&&Array(o);n&&(e?n=na(n,t,0,!0,[r]).array:n[t]=r,s[a]=n)}),o>this.rowCount&&this.applyRowCount(o),i?.silent||(io(this,"afterSetRows"),this.versionTag=Ue())}},{extend:Gd,merge:Yd,pick:ha}=N;(function(h){function t(e,i,s){let o=this.legendItem=this.legendItem||{},{chart:r,options:a}=this,{baseline:n=0,symbolWidth:l,symbolHeight:c}=e,d=this.symbol||"circle",p=c/2,g=r.renderer,u=o.group,f=n-Math.round((e.fontMetrics?.b||c)*(s?.4:.3)),x={},m,y=a.marker,b=0;if(r.styledMode||(x["stroke-width"]=Math.min(a.lineWidth||0,24),a.dashStyle?x.dashstyle=a.dashStyle:a.linecap==="square"||(x["stroke-linecap"]="round")),o.line=g.path().addClass("highcharts-graph").attr(x).add(u),s&&(o.area=g.path().addClass("highcharts-area").add(u)),x["stroke-linecap"]&&(b=Math.min(o.line.strokeWidth(),l)/2),l){let v=[["M",b,f],["L",l-b,f]];o.line.attr({d:v}),o.area?.attr({d:[...v,["L",l-b,n],["L",b,n]]})}if(y&&y.enabled!==!1&&l){let v=Math.min(ha(y.radius,p),p);d.indexOf("url")===0&&(y=Yd(y,{width:c,height:c}),v=0),o.symbol=m=g.symbol(d,l/2-v,f-v,2*v,2*v,Gd({context:"legend"},y)).addClass("highcharts-point").add(u),m.isMarker=!0}}h.areaMarker=function(e,i){t.call(this,e,i,!0)},h.lineMarker=t,h.rectangle=function(e,i){let s=i.legendItem||{},o=e.options,r=e.symbolHeight,a=o.squareSymbol,n=a?r:e.symbolWidth;s.symbol=this.chart.renderer.rect(a?(e.symbolWidth-r)/2:0,e.baseline-r+1,n,r,ha(e.options.symbolRadius,r/2)).addClass("highcharts-point").attr({zIndex:3}).add(s.group)}})(hs||(hs={}));let la=hs,{defaultOptions:da}=kt,{extend:jd,extendClass:Ud,merge:Vd}=N;(function(h){function t(e,i){let s=da.plotOptions||{},o=i.defaultOptions,r=i.prototype;return r.type=e,r.pointClass||(r.pointClass=Ut),!h.seriesTypes[e]&&(o&&(s[e]=o),h.seriesTypes[e]=i,!0)}h.seriesTypes=P.seriesTypes,h.registerSeriesType=t,h.seriesType=function(e,i,s,o,r){let a=da.plotOptions||{};if(i=i||"",a[e]=Vd(a[i],s),delete h.seriesTypes[e],t(e,Ud(h.seriesTypes[i]||function(){},o)),h.seriesTypes[e].prototype.type=e,r){class n extends Ut{}jd(n.prototype,r),h.seriesTypes[e].prototype.pointClass=n}return h.seriesTypes[e]}})(ls||(ls={}));let st=ls,{animObject:ca,setAnimation:$d}=dt,{defaultOptions:Ri}=kt,{registerEventOptions:Zd}=Mi,{svg:qd,win:Kd}=P,{seriesTypes:Te}=st,{format:_d}=wt,{arrayMax:so,arrayMin:pa,clamp:ga,correctFloat:ua,crisp:Jd,defined:at,destroyObjectProperties:Qd,diffObjects:tc,erase:fa,error:Wi,extend:Ae,find:ec,fireEvent:ot,getClosestDistance:ic,getNestedProperty:ma,insertItem:xa,isArray:ya,isNumber:lt,isString:sc,merge:Ve,objectEach:oo,pick:it,removeEvent:oc,syncTimeout:ba}=N;class Tt{constructor(){this.zoneAxis="y"}init(t,e){let i;ot(this,"init",{options:e}),this.dataTable??(this.dataTable=new zi);let s=t.series;this.eventsToUnbind=[],this.chart=t,this.options=this.setOptions(e);let o=this.options,r=o.visible!==!1;this.linkedSeries=[],this.bindAxes(),Ae(this,{name:o.name,state:"",visible:r,selected:o.selected===!0}),Zd(this,o),(o.events?.click||o.point?.events?.click||o.allowPointSelect)&&(t.runTrackerClick=!0),this.getColor(),this.getSymbol(),this.isCartesian&&(t.hasCartesianSeries=!0),s.length&&(i=s[s.length-1]),this._i=it(i?._i,-1)+1,this.opacity=this.options.opacity,t.orderItems("series",xa(this,s)),o.dataSorting?.enabled?this.setDataSortingOptions():this.points||this.data||this.setData(o.data,!1),ot(this,"afterInit")}is(t){return Te[t]&&this instanceof Te[t]}bindAxes(){let t,e=this,i=e.options,s=e.chart;ot(this,"bindAxes",null,function(){(e.axisTypes||[]).forEach(function(o){(s[o]||[]).forEach(function(r){t=r.options,(it(i[o],0)===r.index||i[o]!==void 0&&i[o]===t.id)&&(xa(e,r.series),e[o]=r,r.isDirty=!0)}),e[o]||e.optionalAxis===o||Wi(18,!0,s)})}),ot(this,"afterBindAxes")}hasData(){return this.visible&&this.dataMax!==void 0&&this.dataMin!==void 0||this.visible&&this.dataTable.rowCount>0}hasMarkerChanged(t,e){let i=t.marker,s=e.marker||{};return i&&(s.enabled&&!i.enabled||s.symbol!==i.symbol||s.height!==i.height||s.width!==i.width)}autoIncrement(t){let e,i=this.options,{pointIntervalUnit:s,relativeXValue:o}=this.options,r=this.chart.time,a=this.xIncrement??r.parse(i.pointStart)??0;if(this.pointInterval=e=it(this.pointInterval,i.pointInterval,1),o&<(t)&&(e*=t),s){let n=r.toParts(a);s==="day"?n[2]+=e:s==="month"?n[1]+=e:s==="year"&&(n[0]+=e),e=r.makeTime.apply(r,n)-a}return o&<(t)?a+e:(this.xIncrement=a+e,a)}setDataSortingOptions(){let t=this.options;Ae(this,{requireSorting:!1,sorted:!1,enabledDataSorting:!0,allowDG:!1}),at(t.pointRange)||(t.pointRange=1)}setOptions(t){let e,i=this.chart,s=i.options.plotOptions,o=i.userOptions||{},r=Ve(t),a=i.styledMode,n={plotOptions:s,userOptions:r};ot(this,"setOptions",n);let l=n.plotOptions[this.type],c=o.plotOptions||{},d=c.series||{},p=Ri.plotOptions[this.type]||{},g=c[this.type]||{};l.dataLabels=this.mergeArrays(p.dataLabels,l.dataLabels),this.userOptions=n.userOptions;let u=Ve(l,s.series,g,r);this.tooltipOptions=Ve(Ri.tooltip,Ri.plotOptions.series?.tooltip,p?.tooltip,i.userOptions.tooltip,c.series?.tooltip,g.tooltip,r.tooltip),this.stickyTracking=it(r.stickyTracking,g.stickyTracking,d.stickyTracking,!!this.tooltipOptions.shared&&!this.noSharedTooltip||u.stickyTracking),l.marker===null&&delete u.marker,this.zoneAxis=u.zoneAxis||"y";let f=this.zones=(u.zones||[]).map(x=>vt({},x));return(u.negativeColor||u.negativeFillColor)&&!u.zones&&(e={value:u[this.zoneAxis+"Threshold"]||u.threshold||0,className:"highcharts-negative"},a||(e.color=u.negativeColor,e.fillColor=u.negativeFillColor),f.push(e)),f.length&&at(f[f.length-1].value)&&f.push(a?{}:{color:this.color,fillColor:this.fillColor}),ot(this,"afterSetOptions",{options:u}),u}getName(){return this.options.name??_d(this.chart.options.lang.seriesName,this,this.chart)}getCyclic(t,e,i){let s,o,r=this.chart,a=`${t}Index`,n=`${t}Counter`,l=i?.length||r.options.chart.colorCount;!e&&(at(o=it(t==="color"?this.options.colorIndex:void 0,this[a]))?s=o:(r.series.length||(r[n]=0),s=r[n]%l,r[n]+=1),i&&(e=i[s])),s!==void 0&&(this[a]=s),this[t]=e}getColor(){this.chart.styledMode?this.getCyclic("color"):this.options.colorByPoint?this.color="#cccccc":this.getCyclic("color",this.options.color||Ri.plotOptions[this.type].color,this.chart.options.colors)}getPointsCollection(){return(this.hasGroupedData?this.points:this.data)||[]}getSymbol(){let t=this.options.marker;this.getCyclic("symbol",t.symbol,this.chart.options.symbols)}getColumn(t,e){return(e?this.dataTable.modified:this.dataTable).getColumn(t,!0)||[]}findPointIndex(t,e){let i,s,o,{id:r,x:a}=t,n=this.points,l=this.options.dataSorting,c=this.cropStart||0;if(r){let d=this.chart.get(r);d instanceof Ut&&(i=d)}else if(this.linkedParent||this.enabledDataSorting||this.options.relativeXValue){let d=p=>!p.touched&&p.index===t.index;if(l?.matchByName?d=p=>!p.touched&&p.name===t.name:this.options.relativeXValue&&(d=p=>!p.touched&&p.options.x===t.x),!(i=ec(n,d)))return}return i&&(o=i?.index)!==void 0&&(s=!0),o===void 0&<(a)&&(o=this.getColumn("x").indexOf(a,e)),o!==-1&&o!==void 0&&this.cropped&&(o=o>=c?o-c:o),!s&<(o)&&n[o]?.touched&&(o=void 0),o}updateData(t,e){let{options:i,requireSorting:s}=this,o=i.dataSorting,r=this.points,a=[],n=t.length===r.length,l,c,d,p,g=!0;if(this.xIncrement=null,t.forEach((f,x)=>{let m,y=at(f)&&this.pointClass.prototype.optionsToObject.call({series:this},f)||{},{id:b,x:v}=y;b||lt(v)?((m=this.findPointIndex(y,p))===-1||m===void 0?a.push(f):r[m]&&f!==i.data?.[m]?(r[m].update(f,!1,void 0,!1),r[m].touched=!0,s&&(p=m+1)):r[m]&&(r[m].touched=!0),(!n||x!==m||o?.enabled||this.hasDerivedData)&&(l=!0)):a.push(f)},this),l)for(c=r.length;c--;)(d=r[c])&&!d.touched&&d.remove?.(!1,e);else n&&!o?.enabled?(t.forEach((f,x)=>{f===r[x].y||r[x].destroyed||r[x].update(f,!1,void 0,!1)}),a.length=0):g=!1;if(r.forEach(f=>{f&&(f.touched=!1)}),!g)return!1;a.forEach(f=>{this.addPoint(f,!1,void 0,void 0,!1)},this);let u=this.getColumn("x");return this.xIncrement===null&&u.length&&(this.xIncrement=so(u),this.autoIncrement()),!0}dataColumnKeys(){return["x",...this.pointArrayMap||["y"]]}setData(t,e=!0,i,s){let o=this.points,r=o?.length||0,a=this.options,n=this.chart,l=a.dataSorting,c=this.xAxis,d=a.turboThreshold,p=this.dataTable,g=this.dataColumnKeys(),u=this.pointValKey||"y",f=(this.pointArrayMap||[]).length,x=a.keys,m,y,b=0,v=1,S;n.options.chart.allowMutatingData||(a.data&&delete this.options.data,this.userOptions.data&&delete this.userOptions.data,S=Ve(!0,t));let w=(t=S||t||[]).length;if(l?.enabled&&(t=this.sortData(t)),n.options.chart.allowMutatingData&&s!==!1&&w&&r&&!this.cropped&&!this.hasGroupedData&&this.visible&&!this.boosted&&(y=this.updateData(t,i)),!y){this.xIncrement=null,this.colorCounter=0;let k=d&&w>d;if(k){let M=this.getFirstValidPoint(t),C=this.getFirstValidPoint(t,w-1,-1),T=A=>!!(ya(A)&&(x||lt(A[0])));if(lt(M)&<(C)){let A=[],O=[];for(let L of t)A.push(this.autoIncrement()),O.push(L);p.setColumns({x:A,[u]:O})}else if(T(M)&&T(C))if(f){let A=+(M.length===f),O=Array(g.length).fill(0).map(()=>[]);for(let L of t){A&&O[0].push(this.autoIncrement());for(let I=A;I<=f;I++)O[I]?.push(L[I-A])}p.setColumns(g.reduce((L,I,D)=>(L[I]=O[D],L),{}))}else{x&&(b=x.indexOf("x"),v=x.indexOf("y"),b=b>=0?b:0,v=v>=0?v:1),M.length===1&&(v=0);let A=[],O=[];if(b===v)for(let L of t)A.push(this.autoIncrement()),O.push(L[v]);else for(let L of t)A.push(L[b]),O.push(L[v]);p.setColumns({x:A,[u]:O})}else k=!1}if(!k){let M=g.reduce((C,T)=>(C[T]=[],C),{});for(m=0;m<w;m++){let C=this.pointClass.prototype.applyOptions.apply({series:this},[t[m]]);for(let T of g)M[T][m]=C[T]}p.setColumns(M)}for(sc(this.getColumn("y")[0])&&Wi(14,!0,n),this.data=[],this.options.data=this.userOptions.data=t,m=r;m--;)o[m]?.destroy();c&&(c.minRange=c.userMinRange),this.isDirty=n.isDirtyBox=!0,this.isDirtyData=!!o,i=!1}a.legendType==="point"&&(this.processData(),this.generatePoints()),e&&n.redraw(i)}sortData(t){let e=this,i=e.options.dataSorting.sortKey||"y",s=function(o,r){return at(r)&&o.pointClass.prototype.optionsToObject.call({series:o},r)||{}};return t.forEach(function(o,r){t[r]=s(e,o),t[r].index=r},this),t.concat().sort((o,r)=>{let a=ma(i,o),n=ma(i,r);return n<a?-1:+(n>a)}).forEach(function(o,r){o.x=r},this),e.linkedSeries&&e.linkedSeries.forEach(function(o){let r=o.options,a=r.data;!r.dataSorting?.enabled&&a&&(a.forEach(function(n,l){a[l]=s(o,n),t[l]&&(a[l].x=t[l].x,a[l].index=l)}),o.setData(a,!1))}),t}getProcessedData(t){let e=this,{dataTable:i,isCartesian:s,options:o,xAxis:r}=e,a=o.cropThreshold,n=t||e.getExtremesFromAll,l=r?.logarithmic,c=i.rowCount,d,p,g=0,u,f,x,m=e.getColumn("x"),y=i,b=!1;return r&&(f=(u=r.getExtremes()).min,x=u.max,b=!!(r.categories&&!r.names.length),s&&e.sorted&&!n&&(!a||c>a||e.forceCrop)&&(m[c-1]<f||m[0]>x?y=new zi:e.getColumn(e.pointValKey||"y").length&&(m[0]<f||m[c-1]>x)&&(y=(d=this.cropData(i,f,x)).modified,g=d.start,p=!0))),m=y.getColumn("x")||[],{modified:y,cropped:p,cropStart:g,closestPointRange:ic([l?m.map(l.log2lin):m],()=>e.requireSorting&&!b&&Wi(15,!1,e.chart))}}processData(t){let e=this.xAxis,i=this.dataTable;if(this.isCartesian&&!this.isDirty&&!e.isDirty&&!this.yAxis.isDirty&&!t)return!1;let s=this.getProcessedData();i.modified=s.modified,this.cropped=s.cropped,this.cropStart=s.cropStart,this.closestPointRange=this.basePointRange=s.closestPointRange,ot(this,"afterProcessData")}cropData(t,e,i){let s=t.getColumn("x",!0)||[],o=s.length,r={},a,n,l=0,c=o;for(a=0;a<o;a++)if(s[a]>=e){l=Math.max(0,a-1);break}for(n=a;n<o;n++)if(s[n]>i){c=n+1;break}for(let d of this.dataColumnKeys()){let p=t.getColumn(d,!0);p&&(r[d]=p.slice(l,c))}return{modified:new zi({columns:r}),start:l,end:c}}generatePoints(){let t=this.options,e=this.processedData||t.data,i=this.dataTable.modified,s=this.getColumn("x",!0),o=this.pointClass,r=i.rowCount,a=this.cropStart||0,n=this.hasGroupedData,l=t.keys,c=[],d=t.dataGrouping?.groupAll?a:0,p=this.xAxis?.categories,g=this.pointArrayMap||["y"],u=this.dataColumnKeys(),f,x,m,y,b=this.data,v;if(!b&&!n){let S=[];S.length=e?.length||0,b=this.data=S}for(l&&n&&(this.options.keys=!1),y=0;y<r;y++)x=a+y,n?((m=new o(this,i.getRow(y,u)||[])).dataGroup=this.groupMap[d+y],m.dataGroup?.options&&(m.options=m.dataGroup.options,Ae(m,m.dataGroup.options),delete m.dataLabels)):(m=b[x],v=e?e[x]:i.getRow(y,g),m||v===void 0||(b[x]=m=new o(this,v,s[y]))),m&&(m.index=n?d+y:x,c[y]=m,m.category=p?.[m.x]??m.x,m.key=m.name??m.category);if(this.options.keys=l,b&&(r!==(f=b.length)||n))for(y=0;y<f;y++)y!==a||n||(y+=r),b[y]&&(b[y].destroyElements(),b[y].plotX=void 0);this.data=b,this.points=c,ot(this,"afterGeneratePoints")}getXExtremes(t){return{min:pa(t),max:so(t)}}getExtremes(t,e){let{xAxis:i,yAxis:s}=this,o=e||this.getExtremesFromAll||this.options.getExtremesFromAll,r=o&&this.cropped?this.dataTable:this.dataTable.modified,a=r.rowCount,n=t||this.stackedYData,l=n?[n]:(this.keysAffectYAxis||this.pointArrayMap||["y"])?.map(S=>r.getColumn(S,!0)||[])||[],c=this.getColumn("x",!0),d=[],p=this.requireSorting&&!this.is("column")?1:0,g=!!s&&s.positiveValuesOnly,u=o||this.cropped||!i,f,x,m,y=0,b=0;for(i&&(y=(f=i.getExtremes()).min,b=f.max),m=0;m<a;m++)if(x=c[m],u||(c[m+p]||x)>=y&&(c[m-p]||x)<=b)for(let S of l){let w=S[m];lt(w)&&(w>0||!g)&&d.push(w)}let v={activeYData:d,dataMin:pa(d),dataMax:so(d)};return ot(this,"afterGetExtremes",{dataExtremes:v}),v}applyExtremes(){let t=this.getExtremes();return this.dataMin=t.dataMin,this.dataMax=t.dataMax,t}getFirstValidPoint(t,e=0,i=1){let s=t.length,o=e;for(;o>=0&&o<s;){if(at(t[o]))return t[o];o+=i}}translate(){this.generatePoints();let t=this.options,e=t.stacking,i=this.xAxis,s=this.enabledDataSorting,o=this.yAxis,r=this.points,a=r.length,n=this.pointPlacementToXValue(),l=!!n,c=t.threshold,d=t.startFromThreshold?c:0,p=t?.nullInteraction&&o.len,g,u,f,x,m=Number.MAX_VALUE;function y(b){return ga(b,-1e9,1e9)}for(g=0;g<a;g++){let b,v=r[g],S=v.x,w,k,M=v.y,C=v.low,T=e&&o.stacking?.stacks[(this.negStacks&&M<(d?0:c)?"-":"")+this.stackKey];v.plotX=lt(u=i.translate(S,!1,!1,!1,!0,n))?ua(y(u)):void 0,e&&this.visible&&T&&T[S]&&(x=this.getStackIndicator(x,S,this.index),!v.isNull&&x.key&&(k=(w=T[S]).points[x.key]),w&&ya(k)&&(C=k[0],M=k[1],C===d&&x.key===T[S].base&&(C=it(lt(c)?c:o.min)),o.positiveValuesOnly&&at(C)&&C<=0&&(C=void 0),v.total=v.stackTotal=it(w.total),v.percentage=at(v.y)&&w.total?v.y/w.total*100:void 0,v.stackY=M,this.irregularWidths||w.setOffset(this.pointXOffset||0,this.barW||0,void 0,void 0,void 0,this.xAxis))),v.yBottom=at(C)?y(o.translate(C,!1,!0,!1,!0)):void 0,this.dataModify&&(M=this.dataModify.modifyValue(M,g)),lt(M)&&v.plotX!==void 0?b=lt(b=o.translate(M,!1,!0,!1,!0))?y(b):void 0:!lt(M)&&p&&(b=p),v.plotY=b,v.isInside=this.isPointInside(v),v.clientX=l?ua(i.translate(S,!1,!1,!1,!0,n)):u,v.negative=(v.y||0)<(c||0),v.isNull||v.visible===!1||(f!==void 0&&(m=Math.min(m,Math.abs(u-f))),f=u),v.zone=this.zones.length?v.getZone():void 0,!v.graphic&&this.group&&s&&(v.isNew=!0)}this.closestPointRangePx=m,ot(this,"afterTranslate")}getValidPoints(t,e,i){let s=this.chart;return(t||this.points||[]).filter(function(o){let{plotX:r,plotY:a}=o;return!!((i||!o.isNull&<(a))&&(!e||s.isInsidePlot(r,a,{inverted:s.inverted})))&&o.visible!==!1})}getSharedClipKey(){return this.sharedClipKey=(this.options.xAxis||0)+","+(this.options.yAxis||0),this.sharedClipKey}setClip(){let{chart:t,group:e,markerGroup:i}=this,s=t.sharedClips,o=t.renderer,r=t.getClipBox(this),a=this.getSharedClipKey(),n=s[a];n?n.animate(r):s[a]=n=o.clipRect(r),e&&e.clip(this.options.clip===!1?void 0:n),i&&i.clip()}animate(t){let{chart:e,group:i,markerGroup:s}=this,o=e.inverted,r=ca(this.options.animation),a=[this.getSharedClipKey(),r.duration,r.easing,r.defer].join(","),n=e.sharedClips[a],l=e.sharedClips[a+"m"];if(t&&i){let c=e.getClipBox(this);if(n)n.attr("height",c.height);else{c.width=0,o&&(c.x=e.plotHeight),n=e.renderer.clipRect(c),e.sharedClips[a]=n;let d={x:-99,y:-99,width:o?e.plotWidth+199:99,height:o?99:e.plotHeight+199};l=e.renderer.clipRect(d),e.sharedClips[a+"m"]=l}i.clip(n),s?.clip(l)}else if(n&&!n.hasClass("highcharts-animating")){let c=e.getClipBox(this),d=r.step;(s?.element.childNodes.length||e.series.length>1)&&(r.step=function(p,g){d&&d.apply(g,arguments),g.prop==="width"&&l?.element&&l.attr(o?"height":"width",p+99)}),n.addClass("highcharts-animating").animate(c,r)}}afterAnimate(){this.setClip(),oo(this.chart.sharedClips,(t,e,i)=>{t&&!this.chart.container.querySelector(`[clip-path="url(#${t.id})"]`)&&(t.destroy(),delete i[e])}),this.finishedAnimating=!0,ot(this,"afterAnimate")}drawPoints(t=this.points){let e,i,s,o,r,a,n,l=this.chart,c=l.styledMode,{colorAxis:d,options:p}=this,g=p.marker,u=p.nullInteraction,f=this[this.specialGroup||"markerGroup"],x=this.xAxis,m=it(g.enabled,!x||!!x.isRadial||null,this.closestPointRangePx>=g.enabledThreshold*g.radius);if(g.enabled!==!1||this._hasPointMarkers)for(e=0;e<t.length;e++){o=(s=(i=t[e]).graphic)?"animate":"attr",r=i.marker||{},a=!!i.marker;let y=i.isNull;if((m&&!at(r.enabled)||r.enabled)&&(!y||u)&&i.visible!==!1){let b=it(r.symbol,this.symbol,"rect");n=this.markerAttribs(i,i.selected&&"select"),this.enabledDataSorting&&(i.startXPos=x.reversed?-(n.width||0):x.width);let v=i.isInside!==!1;if(!s&&v&&((n.width||0)>0||i.hasImage)&&(i.graphic=s=l.renderer.symbol(b,n.x,n.y,n.width,n.height,a?r:g).add(f),this.enabledDataSorting&&l.hasRendered&&(s.attr({x:i.startXPos}),o="animate")),s&&o==="animate"&&s[v?"show":"hide"](v).animate(n),s){let S=this.pointAttribs(i,c||!i.selected?void 0:"select");c?d&&s.css({fill:S.fill}):s[o](S)}s&&s.addClass(i.getClassName(),!0)}else s&&(i.graphic=s.destroy())}}markerAttribs(t,e){let i=this.options,s=i.marker,o=t.marker||{},r=o.symbol||s.symbol,a={},n,l,c=it(o.radius,s?.radius);e&&(n=s.states[e],l=o.states&&o.states[e],c=it(l?.radius,n?.radius,c&&c+(n?.radiusPlus||0))),t.hasImage=r&&r.indexOf("url")===0,t.hasImage&&(c=0);let d=t.pos();return lt(c)&&d&&(i.crisp&&(d[0]=Jd(d[0],t.hasImage?0:r==="rect"?s?.lineWidth||0:1)),a.x=d[0]-c,a.y=d[1]-c),c&&(a.width=a.height=2*c),a}pointAttribs(t,e){let i=this.options,s=i.marker,o=t?.options,r=o?.marker||{},a=o?.color,n=t?.color,l=t?.zone?.color,c,d,p=this.color,g,u,f=it(r.lineWidth,s.lineWidth),x=t?.isNull&&i.nullInteraction?0:1;return p=a||l||n||p,g=r.fillColor||s.fillColor||p,u=r.lineColor||s.lineColor||p,e=e||"normal",c=s.states[e]||{},f=it((d=r.states&&r.states[e]||{}).lineWidth,c.lineWidth,f+it(d.lineWidthPlus,c.lineWidthPlus,0)),g=d.fillColor||c.fillColor||g,u=d.lineColor||c.lineColor||u,{stroke:u,"stroke-width":f,fill:g,opacity:x=it(d.opacity,c.opacity,x)}}destroy(t){let e,i,s=this,o=s.chart,r=/AppleWebKit\/533/.test(Kd.navigator.userAgent),a=s.data||[];for(ot(s,"destroy",{keepEventsForUpdate:t}),this.removeEvents(t),(s.axisTypes||[]).forEach(function(n){i=s[n],i?.series&&(fa(i.series,s),i.isDirty=i.forceRedraw=!0)}),s.legendItem&&s.chart.legend.destroyItem(s),e=a.length;e--;)a[e]?.destroy?.();for(let n of s.zones)Qd(n,void 0,!0);N.clearTimeout(s.animationTimeout),oo(s,function(n,l){n instanceof Et&&!n.survive&&n[r&&l==="group"?"hide":"destroy"]()}),o.hoverSeries===s&&(o.hoverSeries=void 0),fa(o.series,s),o.orderItems("series"),oo(s,function(n,l){t&&l==="hcEvents"||delete s[l]})}applyZones(){let{area:t,chart:e,graph:i,zones:s,points:o,xAxis:r,yAxis:a,zoneAxis:n}=this,{inverted:l,renderer:c}=e,d=this[`${n}Axis`],{isXAxis:p,len:g=0,minPointOffset:u=0}=d||{},f=(i?.strokeWidth()||0)/2+1,x=(m,y=0,b=0)=>{l&&(b=g-b);let{translated:v=0,lineClip:S}=m,w=b-v;S?.push(["L",y,Math.abs(w)<f?b-f*(w<=0?-1:1):v])};if(s.length&&(i||t)&&d&<(d.min)){let m=d.getExtremes().max+u,y=S=>{S.forEach((w,k)=>{(w[0]==="M"||w[0]==="L")&&(S[k]=[w[0],p?g-w[1]:w[1],p?w[2]:g-w[2]])})};if(s.forEach(S=>{S.lineClip=[],S.translated=ga(d.toPixels(it(S.value,m),!0)||0,0,g)}),i&&!this.showLine&&i.hide(),t&&t.hide(),n==="y"&&o.length<r.len)for(let S of o){let{plotX:w,plotY:k,zone:M}=S,C=M&&s[s.indexOf(M)-1];M&&x(M,w,k),C&&x(C,w,k)}let b=[],v=d.toPixels(d.getExtremes().min-u,!0);s.forEach(S=>{let w=S.lineClip||[],k=Math.round(S.translated||0);r.reversed&&w.reverse();let{clip:M,simpleClip:C}=S,T=0,A=0,O=r.len,L=a.len;p?(T=k,O=v):(A=k,L=v);let I=[["M",T,A],["L",O,A],["L",O,L],["L",T,L],["Z"]],D=[I[0],...w,I[1],I[2],...b,I[3],I[4]];b=w.reverse(),v=k,l&&(y(D),t&&y(I)),M?(M.animate({d:D}),C?.animate({d:I})):(M=S.clip=c.path(D),t&&(C=S.simpleClip=c.path(I))),i&&S.graph?.clip(M),t&&S.area?.clip(C)})}else this.visible&&(i&&i.show(),t&&t.show())}plotGroup(t,e,i,s,o){let r=this[t],a=!r,n={visibility:i,zIndex:s||.1};return at(this.opacity)&&!this.chart.styledMode&&this.state!=="inactive"&&(n.opacity=this.opacity),r||(this[t]=r=this.chart.renderer.g().add(o)),r.addClass("highcharts-"+e+" highcharts-series-"+this.index+" highcharts-"+this.type+"-series "+(at(this.colorIndex)?"highcharts-color-"+this.colorIndex+" ":"")+(this.options.className||"")+(r.hasClass("highcharts-tracker")?" highcharts-tracker":""),!0),r.attr(n)[a?"attr":"animate"](this.getPlotBox(e)),r}getPlotBox(t){let e=this.xAxis,i=this.yAxis,s=this.chart,o=s.inverted&&!s.polar&&e&&this.invertible&&t==="series";return s.inverted&&(e=i,i=this.xAxis),{translateX:e?e.left:s.plotLeft,translateY:i?i.top:s.plotTop,rotation:90*!!o,rotationOriginX:o?(e.len-i.len)/2:0,rotationOriginY:o?(e.len+i.len)/2:0,scaleX:o?-1:1,scaleY:1}}removeEvents(t){let{eventsToUnbind:e}=this;t||oc(this),e.length&&(e.forEach(i=>{i()}),e.length=0)}render(){let t=this,{chart:e,options:i,hasRendered:s}=t,o=ca(i.animation),r=t.visible?"inherit":"hidden",a=i.zIndex,n=e.seriesGroup,l=t.finishedAnimating?0:o.duration;ot(this,"render"),t.plotGroup("group","series",r,a,n),t.markerGroup=t.plotGroup("markerGroup","markers",r,a,n),i.clip!==!1&&t.setClip(),l&&t.animate?.(!0),t.drawGraph&&(t.drawGraph(),t.applyZones()),t.visible&&t.drawPoints(),t.drawDataLabels?.(),t.redrawPoints?.(),i.enableMouseTracking&&t.drawTracker?.(),l&&t.animate?.(),s||(l&&o.defer&&(l+=o.defer),t.animationTimeout=ba(()=>{t.afterAnimate()},l||0)),t.isDirty=!1,t.hasRendered=!0,ot(t,"afterRender")}redraw(){let t=this.isDirty||this.isDirtyData;this.translate(),this.render(),t&&delete this.kdTree}reserveSpace(){return this.visible||!this.chart.options.chart.ignoreHiddenSeries}searchPoint(t,e){let{xAxis:i,yAxis:s}=this,o=this.chart.inverted;return this.searchKDTree({clientX:o?i.len-t.chartY+i.pos:t.chartX-i.pos,plotY:o?s.len-t.chartX+s.pos:t.chartY-s.pos},e,t)}buildKDTree(t){this.buildingKdTree=!0;let e=this,i=e.options,s=i.findNearestPointBy.indexOf("y")>-1?2:1;delete e.kdTree,ba(function(){e.kdTree=function o(r,a,n){let l,c,d=r?.length;if(d)return l=e.kdAxisArray[a%n],r.sort((p,g)=>(p[l]||0)-(g[l]||0)),{point:r[c=Math.floor(d/2)],left:o(r.slice(0,c),a+1,n),right:o(r.slice(c+1),a+1,n)}}(e.getValidPoints(void 0,!e.directTouch,i?.nullInteraction),s,s),e.buildingKdTree=!1},i.kdNow||t?.type==="touchstart"?0:1)}searchKDTree(t,e,i,s,o){let r=this,[a,n]=this.kdAxisArray,l=e?"distX":"dist",c=(r.options.findNearestPointBy||"").indexOf("y")>-1?2:1,d=!!r.isBubble,p=s||((u,f,x)=>{let m=u[x]||0,y=f[x]||0;return[m===y&&u.index>f.index||m<y?u:f,!1]}),g=o||((u,f)=>u<f);if(this.kdTree||this.buildingKdTree||this.buildKDTree(i),this.kdTree)return function u(f,x,m,y){let b=x.point,v=r.kdAxisArray[m%y],S=b,w=!1;(function(T,A){let O=T[a],L=A[a],I=at(O)&&at(L)?O-L:null,D=T[n],E=A[n],B=at(D)&&at(E)?D-E:0,K=d&&A.marker?.radius||0;A.dist=Math.sqrt((I&&I*I||0)+B*B)-K,A.distX=at(I)?Math.abs(I)-K:Number.MAX_VALUE})(f,b);let k=(f[v]||0)-(b[v]||0)+(d&&b.marker?.radius||0),M=k<0?"left":"right",C=k<0?"right":"left";return x[M]&&([S,w]=p(b,u(f,x[M],m+1,y),l)),x[C]&&g(Math.sqrt(k*k),S[l],w)&&(S=p(S,u(f,x[C],m+1,y),l)[0]),S}(t,this.kdTree,c,c)}pointPlacementToXValue(){let{options:t,xAxis:e}=this,i=t.pointPlacement;return i==="between"&&(i=e.reversed?-.5:.5),lt(i)?i*(t.pointRange||e.pointRange):0}isPointInside(t){let{chart:e,xAxis:i,yAxis:s}=this,{plotX:o=-1,plotY:r=-1}=t;return r>=0&&r<=(s?s.len:e.plotHeight)&&o>=0&&o<=(i?i.len:e.plotWidth)}drawTracker(){let t=this,e=t.options,i=e.trackByArea,s=[].concat((i?t.areaPath:t.graphPath)||[]),o=t.chart,r=o.pointer,a=o.renderer,n=o.options.tooltip?.snap||0,l=()=>{e.enableMouseTracking&&o.hoverSeries!==t&&t.onMouseOver()},c="rgba(192,192,192,"+(qd?1e-4:.002)+")",d=t.tracker;d?d.attr({d:s}):t.graph&&(t.tracker=d=a.path(s).attr({visibility:t.visible?"inherit":"hidden",zIndex:2}).addClass(i?"highcharts-tracker-area":"highcharts-tracker-line").add(t.group),o.styledMode||d.attr({"stroke-linecap":"round","stroke-linejoin":"round",stroke:c,fill:i?c:"none","stroke-width":t.graph.strokeWidth()+(i?0:2*n)}),[t.tracker,t.markerGroup,t.dataLabelsGroup].forEach(p=>{p&&(p.addClass("highcharts-tracker").on("mouseover",l).on("mouseout",g=>{r?.onTrackerMouseOut(g)}),e.cursor&&!o.styledMode&&p.css({cursor:e.cursor}),p.on("touchstart",l))})),ot(this,"afterDrawTracker")}addPoint(t,e,i,s,o){let r,a,n=this.options,{chart:l,data:c,dataTable:d,xAxis:p}=this,g=p?.hasNames&&p.names,u=n.data,f=this.getColumn("x");e=it(e,!0);let x={series:this};this.pointClass.prototype.applyOptions.apply(x,[t]);let m=x.x;if(a=f.length,this.requireSorting&&m<f[a-1])for(r=!0;a&&f[a-1]>m;)a--;d.setRow(x,a,!0,{addColumns:!1}),g&&x.name&&(g[m]=x.name),u?.splice(a,0,t),(r||this.processedData)&&(this.data.splice(a,0,null),this.processData()),n.legendType==="point"&&this.generatePoints(),i&&(c[0]&&c[0].remove?c[0].remove(!1):([c,u].filter(at).forEach(y=>{y.shift()}),d.deleteRows(0))),o!==!1&&ot(this,"addPoint",{point:x}),this.isDirty=!0,this.isDirtyData=!0,e&&l.redraw(s)}removePoint(t,e,i){let s=this,{chart:o,data:r,points:a,dataTable:n}=s,l=r[t],c=function(){[a?.length===r.length?a:void 0,r,s.options.data].filter(at).forEach(d=>{d.splice(t,1)}),n.deleteRows(t),l?.destroy(),s.isDirty=!0,s.isDirtyData=!0,e&&o.redraw()};$d(i,o),e=it(e,!0),l?l.firePointEvent("remove",null,c):c()}remove(t,e,i,s){let o=this,r=o.chart;function a(){o.destroy(s),r.isDirtyLegend=r.isDirtyBox=!0,r.linkSeries(s),it(t,!0)&&r.redraw(e)}i!==!1?ot(o,"remove",null,a):a()}update(t,e){ot(this,"update",{options:t=tc(t,this.userOptions)});let i=this,s=i.chart,o=i.userOptions,r=i.initialType||i.type,a=s.options.plotOptions,n=Te[r].prototype,l=i.finishedAnimating&&{animation:!1},c={},d,p,g=Tt.keepProps.slice(),u=t.type||o.type||s.options.chart.type,f=!(this.hasDerivedData||u&&u!==this.type||t.keys!==void 0||t.pointStart!==void 0||t.pointInterval!==void 0||t.relativeXValue!==void 0||t.joinBy||t.mapData||["dataGrouping","pointStart","pointInterval","pointIntervalUnit","keys"].some(m=>i.hasOptionChanged(m)));u=u||r,f?(g.push.apply(g,Tt.keepPropsForPoints),t.visible!==!1&&g.push("area","graph"),i.parallelArrays.forEach(function(m){g.push(m+"Data")}),t.data&&(t.dataSorting&&Ae(i.options.dataSorting,t.dataSorting),this.setData(t.data,!1))):this.dataTable.modified=this.dataTable,t=Ve(o,{index:o.index===void 0?i.index:o.index,pointStart:a?.series?.pointStart??o.pointStart??i.getColumn("x")[0]},!f&&{data:i.options.data},t,l),f&&t.data&&(t.data=i.options.data),(g=["group","markerGroup","dataLabelsGroup","transformGroup"].concat(g)).forEach(function(m){g[m]=i[m],delete i[m]});let x=!1;if(Te[u]){if(x=u!==i.type,i.remove(!1,!1,!1,!0),x)if(s.propFromSeries(),Object.setPrototypeOf)Object.setPrototypeOf(i,Te[u].prototype);else{let m=Object.hasOwnProperty.call(i,"hcEvents")&&i.hcEvents;for(p in n)i[p]=void 0;Ae(i,Te[u].prototype),m?i.hcEvents=m:delete i.hcEvents}}else Wi(17,!0,s,{missingModuleFor:u});if(g.forEach(function(m){i[m]=g[m]}),i.init(s,t),f&&this.points)for(let m of((d=i.options).visible===!1?(c.graphic=1,c.dataLabel=1):(this.hasMarkerChanged(d,o)&&(c.graphic=1),i.hasDataLabels?.()||(c.dataLabel=1)),this.points))m?.series&&(m.resolveColor(),Object.keys(c).length&&m.destroyElements(c),d.showInLegend===!1&&m.legendItem&&s.legend.destroyItem(m));i.initialType=r,s.linkSeries(),s.setSortedData(),x&&i.linkedSeries.length&&(i.isDirtyData=!0),ot(this,"afterUpdate"),it(e,!0)&&s.redraw(!!f&&void 0)}setName(t){this.name=this.options.name=this.userOptions.name=t,this.chart.isDirtyLegend=!0}hasOptionChanged(t){let e=this.chart,i=this.options[t],s=e.options.plotOptions,o=this.userOptions[t],r=it(s?.[this.type]?.[t],s?.series?.[t]);return o&&!at(r)?i!==o:i!==it(r,i)}onMouseOver(){let t=this.chart,e=t.hoverSeries;t.pointer?.setHoverChartIndex(),e&&e!==this&&e.onMouseOut(),this.options.events.mouseOver&&ot(this,"mouseOver"),this.setState("hover"),t.hoverSeries=this}onMouseOut(){let t=this.options,e=this.chart,i=e.tooltip,s=e.hoverPoint;e.hoverSeries=null,s&&s.onMouseOut(),this&&t.events.mouseOut&&ot(this,"mouseOut"),i&&!this.stickyTracking&&(!i.shared||this.noSharedTooltip)&&i.hide(),e.series.forEach(function(o){o.setState("",!0)})}setState(t,e){let i=this,s=i.options,o=i.graph,r=s.inactiveOtherPoints,a=s.states,n=it(a[t||"normal"]&&a[t||"normal"].animation,i.chart.options.chart.animation),l=s.lineWidth,c=s.opacity;if(t=t||"",i.state!==t&&([i.group,i.markerGroup,i.dataLabelsGroup].forEach(function(d){d&&(i.state&&d.removeClass("highcharts-series-"+i.state),t&&d.addClass("highcharts-series-"+t))}),i.state=t,!i.chart.styledMode)){if(a[t]&&a[t].enabled===!1)return;if(t&&(l=a[t].lineWidth||l+(a[t].lineWidthPlus||0),c=it(a[t].opacity,c)),o&&!o.dashstyle&<(l))for(let d of[o,...this.zones.map(p=>p.graph)])d?.animate({"stroke-width":l},n);r||[i.group,i.markerGroup,i.dataLabelsGroup,i.labelBySeries].forEach(function(d){d&&d.animate({opacity:c},n)})}e&&r&&i.points&&i.setAllPointsToState(t||void 0)}setAllPointsToState(t){this.points.forEach(function(e){e.setState&&e.setState(t)})}setVisible(t,e){let i=this,s=i.chart,o=s.options.chart.ignoreHiddenSeries,r=i.visible;i.visible=t=i.options.visible=i.userOptions.visible=t===void 0?!r:t;let a=t?"show":"hide";["group","dataLabelsGroup","markerGroup","tracker","tt"].forEach(n=>{i[n]?.[a]()}),(s.hoverSeries===i||s.hoverPoint?.series===i)&&i.onMouseOut(),i.legendItem&&s.legend.colorizeItem(i,t),i.isDirty=!0,i.options.stacking&&s.series.forEach(n=>{n.options.stacking&&n.visible&&(n.isDirty=!0)}),i.linkedSeries.forEach(n=>{n.setVisible(t,!1)}),o&&(s.isDirtyBox=!0),ot(i,a),e!==!1&&s.redraw()}show(){this.setVisible(!0)}hide(){this.setVisible(!1)}select(t){this.selected=t=this.options.selected=t===void 0?!this.selected:t,this.checkbox&&(this.checkbox.checked=t),ot(this,t?"select":"unselect")}shouldShowTooltip(t,e,i={}){return i.series=this,i.visiblePlotOnly=!0,this.chart.isInsidePlot(t,e,i)}drawLegendSymbol(t,e){la[this.options.legendSymbol||"rectangle"]?.call(this,t,e)}}Tt.defaultOptions={lineWidth:2,allowPointSelect:!1,crisp:!0,showCheckbox:!1,animation:{duration:1e3},enableMouseTracking:!0,events:{},marker:{enabledThreshold:2,lineColor:"#ffffff",lineWidth:0,radius:4,states:{normal:{animation:!0},hover:{animation:{duration:150},enabled:!0,radiusPlus:2,lineWidthPlus:1},select:{fillColor:"#cccccc",lineColor:"#000000",lineWidth:2}}},point:{events:{}},dataLabels:{animation:{},align:"center",borderWidth:0,defer:!0,formatter:function(){let{numberFormatter:h}=this.series.chart;return typeof this.y!="number"?"":h(this.y,-1)},padding:5,style:{fontSize:"0.7em",fontWeight:"bold",color:"contrast",textOutline:"1px contrast"},verticalAlign:"bottom",x:0,y:0},cropThreshold:300,opacity:1,pointRange:0,softThreshold:!0,states:{normal:{animation:!0},hover:{animation:{duration:150},lineWidthPlus:1,marker:{},halo:{size:10,opacity:.25}},select:{animation:{duration:0}},inactive:{animation:{duration:150},opacity:.2}},stickyTracking:!0,turboThreshold:1e3,findNearestPointBy:"x"},Tt.types=st.seriesTypes,Tt.registerType=st.registerSeriesType,Tt.keepProps=["colorIndex","eventOptions","navigatorSeries","symbolIndex","baseSeries"],Tt.keepPropsForPoints=["data","isDirtyData","isDirtyCanvas","points","dataTable","processedData","xIncrement","cropped","_hasPointMarkers","hasDataLabels","nodes","layout","level","mapMap","mapData","minY","maxY","minX","maxX","transformGroups"],Ae(Tt.prototype,{axisTypes:["xAxis","yAxis"],coll:"series",colorCounter:0,directTouch:!1,invertible:!0,isCartesian:!0,kdAxisArray:["clientX","plotY"],parallelArrays:["x","y"],pointClass:Ut,requireSorting:!0,sorted:!0}),st.series=Tt;let bt=Tt,{animObject:rc,setAnimation:ac}=dt,{registerEventOptions:va}=Mi,{composed:nc,marginNames:ka}=P,{distribute:hc}=gi,{format:lc}=wt,{addEvent:Hi,createElement:dc,css:cc,defined:ro,discardElement:pc,find:gc,fireEvent:Wt,isNumber:wa,merge:he,pick:St,pushUnique:uc,relativeLength:fc,stableSort:mc,syncTimeout:xc}=N;class ao{constructor(t,e){this.allItems=[],this.initialItemY=0,this.itemHeight=0,this.itemMarginBottom=0,this.itemMarginTop=0,this.itemX=0,this.itemY=0,this.lastItemY=0,this.lastLineHeight=0,this.legendHeight=0,this.legendWidth=0,this.maxItemWidth=0,this.maxLegendWidth=0,this.offsetWidth=0,this.padding=0,this.pages=[],this.symbolHeight=0,this.symbolWidth=0,this.titleHeight=0,this.totalItemWidth=0,this.widthOption=0,this.chart=t,this.setOptions(e),e.enabled&&(this.render(),va(this,e),Hi(this.chart,"endResize",function(){this.legend.positionCheckboxes()})),Hi(this.chart,"render",()=>{this.options.enabled&&this.proximate&&(this.proximatePositions(),this.positionItems())})}setOptions(t){let e=St(t.padding,8);this.options=t,this.chart.styledMode||(this.itemStyle=t.itemStyle,this.itemHiddenStyle=he(this.itemStyle,t.itemHiddenStyle)),this.itemMarginTop=t.itemMarginTop,this.itemMarginBottom=t.itemMarginBottom,this.padding=e,this.initialItemY=e-5,this.symbolWidth=St(t.symbolWidth,16),this.pages=[],this.proximate=t.layout==="proximate"&&!this.chart.inverted,this.baseline=void 0}update(t,e){let i=this.chart;this.setOptions(he(!0,this.options,t)),"events"in this.options&&va(this,this.options),this.destroy(),i.isDirtyLegend=i.isDirtyBox=!0,St(e,!0)&&i.redraw(),Wt(this,"afterUpdate",{redraw:e})}colorizeItem(t,e){let i=t.color,{area:s,group:o,label:r,line:a,symbol:n}=t.legendItem||{};if((t instanceof bt||t instanceof Ut)&&(t.color=t.options?.legendSymbolColor||i),o?.[e?"removeClass":"addClass"]("highcharts-legend-item-hidden"),!this.chart.styledMode){let{itemHiddenStyle:l={}}=this,c=l.color,{fillColor:d,fillOpacity:p,lineColor:g,marker:u}=t.options,f=x=>(!e&&(x.fill&&(x.fill=c),x.stroke&&(x.stroke=c)),x);r?.css(he(e?this.itemStyle:l)),a?.attr(f({stroke:g||t.color})),n&&n.attr(f(u&&n.isMarker?t.pointAttribs():{fill:t.color})),s?.attr(f({fill:d||t.color,"fill-opacity":d?1:p??.75}))}t.color=i,Wt(this,"afterColorizeItem",{item:t,visible:e})}positionItems(){this.allItems.forEach(this.positionItem,this),this.chart.isResizing||this.positionCheckboxes()}positionItem(t){let{group:e,x:i=0,y:s=0}=t.legendItem||{},o=this.options,r=o.symbolPadding,a=!o.rtl,n=t.checkbox;if(e?.element){let l={translateX:a?i:this.legendWidth-i-2*r-4,translateY:s};e[ro(e.translateY)?"animate":"attr"](l,void 0,()=>{Wt(this,"afterPositionItem",{item:t})})}n&&(n.x=i,n.y=s)}destroyItem(t){let e=t.checkbox,i=t.legendItem||{};for(let s of["group","label","line","symbol"])i[s]&&(i[s]=i[s].destroy());e&&pc(e),t.legendItem=void 0}destroy(){for(let t of this.getAllItems())this.destroyItem(t);for(let t of["clipRect","up","down","pager","nav","box","title","group"])this[t]&&(this[t]=this[t].destroy());this.display=null}positionCheckboxes(){let t,e=this.group?.alignAttr,i=this.clipHeight||this.legendHeight,s=this.titleHeight;e&&(t=e.translateY,this.allItems.forEach(function(o){let r,a=o.checkbox;a&&(r=t+s+a.y+(this.scrollOffset||0)+3,cc(a,{left:e.translateX+o.checkboxOffset+a.x-20+"px",top:r+"px",display:this.proximate||r>t-6&&r<t+i-6?"":"none"}))},this))}renderTitle(){let t=this.options,e=this.padding,i=t.title,s,o=0;i.text&&(this.title||(this.title=this.chart.renderer.label(i.text,e-3,e-4,void 0,void 0,void 0,t.useHTML,void 0,"legend-title").attr({zIndex:1}),this.chart.styledMode||this.title.css(i.style),this.title.add(this.group)),i.width||this.title.css({width:this.maxLegendWidth+"px"}),o=(s=this.title.getBBox()).height,this.offsetWidth=s.width,this.contentGroup.attr({translateY:o})),this.titleHeight=o}setText(t){let e=this.options;t.legendItem.label.attr({text:e.labelFormat?lc(e.labelFormat,t,this.chart):e.labelFormatter.call(t)})}renderItem(t){let e=t.legendItem=t.legendItem||{},i=this.chart,s=i.renderer,o=this.options,r=o.layout==="horizontal",a=this.symbolWidth,n=o.symbolPadding||0,l=this.itemStyle,c=this.itemHiddenStyle,d=r?St(o.itemDistance,20):0,p=!o.rtl,g=!t.series,u=!g&&t.series.drawLegendSymbol?t.series:t,f=u.options,x=!!this.createCheckboxForItem&&f&&f.showCheckbox,m=o.useHTML,y=t.options.className,b=e.label,v=a+n+d+20*!!x;!b&&(e.group=s.g("legend-item").addClass("highcharts-"+u.type+"-series highcharts-color-"+t.colorIndex+(y?" "+y:"")+(g?" highcharts-series-"+t.index:"")).attr({zIndex:1}).add(this.scrollGroup),e.label=b=s.text("",p?a+n:-n,this.baseline||0,m),i.styledMode||b.css(he(t.visible?l:c)),b.attr({align:p?"left":"right",zIndex:2}).add(e.group),!this.baseline&&(this.fontMetrics=s.fontMetrics(b),this.baseline=this.fontMetrics.f+3+this.itemMarginTop,b.attr("y",this.baseline),this.symbolHeight=St(o.symbolHeight,this.fontMetrics.f),o.squareSymbol&&(this.symbolWidth=St(o.symbolWidth,Math.max(this.symbolHeight,16)),v=this.symbolWidth+n+d+20*!!x,p&&b.attr("x",this.symbolWidth+n))),u.drawLegendSymbol(this,t),this.setItemEvents&&this.setItemEvents(t,b,m)),x&&!t.checkbox&&this.createCheckboxForItem&&this.createCheckboxForItem(t),this.colorizeItem(t,t.visible),(i.styledMode||!l.width)&&b.css({width:(o.itemWidth||this.widthOption||i.spacingBox.width)-v+"px"}),this.setText(t);let S=b.getBBox(),w=this.fontMetrics?.h||0;t.itemWidth=t.checkboxOffset=o.itemWidth||e.labelWidth||S.width+v,this.maxItemWidth=Math.max(this.maxItemWidth,t.itemWidth),this.totalItemWidth+=t.itemWidth,this.itemHeight=t.itemHeight=Math.round(e.labelHeight||(S.height>1.5*w?S.height:w))}layoutItem(t){let e=this.options,i=this.padding,s=e.layout==="horizontal",o=t.itemHeight,r=this.itemMarginBottom,a=this.itemMarginTop,n=s?St(e.itemDistance,20):0,l=this.maxLegendWidth,c=e.alignColumns&&this.totalItemWidth>l?this.maxItemWidth:t.itemWidth,d=t.legendItem||{};s&&this.itemX-i+c>l&&(this.itemX=i,this.lastLineHeight&&(this.itemY+=a+this.lastLineHeight+r),this.lastLineHeight=0),this.lastItemY=a+this.itemY+r,this.lastLineHeight=Math.max(o,this.lastLineHeight),d.x=this.itemX,d.y=this.itemY,s?this.itemX+=c:(this.itemY+=a+o+r,this.lastLineHeight=o),this.offsetWidth=this.widthOption||Math.max((s?this.itemX-i-(t.checkbox?0:n):c)+i,this.offsetWidth)}getAllItems(){let t=[];return this.chart.series.forEach(function(e){let i=e?.options;e&&St(i.showInLegend,!ro(i.linkedTo)&&void 0,!0)&&(t=t.concat(e.legendItem?.labels||(i.legendType==="point"?e.data:e)))}),Wt(this,"afterGetAllItems",{allItems:t}),t}getAlignment(){let t=this.options;return this.proximate?t.align.charAt(0)+"tv":t.floating?"":t.align.charAt(0)+t.verticalAlign.charAt(0)+t.layout.charAt(0)}adjustMargins(t,e){let i=this.chart,s=this.options,o=this.getAlignment();o&&[/(lth|ct|rth)/,/(rtv|rm|rbv)/,/(rbh|cb|lbh)/,/(lbv|lm|ltv)/].forEach(function(r,a){r.test(o)&&!ro(t[a])&&(i[ka[a]]=Math.max(i[ka[a]],i.legend[(a+1)%2?"legendHeight":"legendWidth"]+[1,-1,-1,1][a]*s[a%2?"x":"y"]+St(s.margin,12)+e[a]+(i.titleOffset[a]||0)))})}proximatePositions(){let t,e=this.chart,i=[],s=this.options.align==="left";for(let o of(this.allItems.forEach(function(r){let a,n,l=s,c,d;r.yAxis&&(r.xAxis.options.reversed&&(l=!l),r.points&&(a=gc(l?r.points:r.points.slice(0).reverse(),function(p){return wa(p.plotY)})),n=this.itemMarginTop+r.legendItem.label.getBBox().height+this.itemMarginBottom,d=r.yAxis.top-e.plotTop,c=r.visible?(a?a.plotY:r.yAxis.height)+(d-.3*n):d+r.yAxis.height,i.push({target:c,size:n,item:r}))},this),hc(i,e.plotHeight)))t=o.item.legendItem||{},wa(o.pos)&&(t.y=e.plotTop-e.spacing[0]+o.pos)}render(){let t=this.chart,e=t.renderer,i=this.options,s=this.padding,o=this.getAllItems(),r,a,n,l=this.group,c,d=this.box;this.itemX=s,this.itemY=this.initialItemY,this.offsetWidth=0,this.lastItemY=0,this.widthOption=fc(i.width,t.spacingBox.width-s),c=t.spacingBox.width-2*s-i.x,["rm","lm"].indexOf(this.getAlignment().substring(0,2))>-1&&(c/=2),this.maxLegendWidth=this.widthOption||c,l||(this.group=l=e.g("legend").addClass(i.className||"").attr({zIndex:7}).add(),this.contentGroup=e.g().attr({zIndex:1}).add(l),this.scrollGroup=e.g().add(this.contentGroup)),this.renderTitle(),mc(o,(p,g)=>(p.options?.legendIndex||0)-(g.options?.legendIndex||0)),i.reversed&&o.reverse(),this.allItems=o,this.display=r=!!o.length,this.lastLineHeight=0,this.maxItemWidth=0,this.totalItemWidth=0,this.itemHeight=0,o.forEach(this.renderItem,this),o.forEach(this.layoutItem,this),a=(this.widthOption||this.offsetWidth)+s,n=this.lastItemY+this.lastLineHeight+this.titleHeight,n=this.handleOverflow(n)+s,d||(this.box=d=e.rect().addClass("highcharts-legend-box").attr({r:i.borderRadius}).add(l)),t.styledMode||d.attr({stroke:i.borderColor,"stroke-width":i.borderWidth||0,fill:i.backgroundColor||"none"}).shadow(i.shadow),a>0&&n>0&&d[d.placed?"animate":"attr"](d.crisp.call({},{x:0,y:0,width:a,height:n},d.strokeWidth())),l[r?"show":"hide"](),t.styledMode&&l.getStyle("display")==="none"&&(a=n=0),this.legendWidth=a,this.legendHeight=n,r&&this.align(),this.proximate||this.positionItems(),Wt(this,"afterRender")}align(t=this.chart.spacingBox){let e=this.chart,i=this.options,s=t.y;/(lth|ct|rth)/.test(this.getAlignment())&&e.titleOffset[0]>0?s+=e.titleOffset[0]:/(lbh|cb|rbh)/.test(this.getAlignment())&&e.titleOffset[2]>0&&(s-=e.titleOffset[2]),s!==t.y&&(t=he(t,{y:s})),e.hasRendered||(this.group.placed=!1),this.group.align(he(i,{width:this.legendWidth,height:this.legendHeight,verticalAlign:this.proximate?"top":i.verticalAlign}),!0,t)}handleOverflow(t){let e=this,i=this.chart,s=i.renderer,o=this.options,r=o.y,a=o.verticalAlign==="top",n=this.padding,l=o.maxHeight,c=o.navigation,d=St(c.animation,!0),p=c.arrowSize||12,g=this.pages,u=this.allItems,f=function(M){typeof M=="number"?k.attr({height:M}):k&&(e.clipRect=k.destroy(),e.contentGroup.clip()),e.contentGroup.div&&(e.contentGroup.div.style.clip=M?"rect("+n+"px,9999px,"+(n+M)+"px,0)":"auto")},x=function(M){return e[M]=s.circle(0,0,1.3*p).translate(p/2,p/2).add(w),i.styledMode||e[M].attr("fill","rgba(0,0,0,0.0001)"),e[M]},m,y,b,v,S=i.spacingBox.height+(a?-r:r)-n,w=this.nav,k=this.clipRect;return o.layout!=="horizontal"||o.verticalAlign==="middle"||o.floating||(S/=2),l&&(S=Math.min(S,l)),g.length=0,t&&S>0&&t>S&&c.enabled!==!1?(this.clipHeight=m=Math.max(S-20-this.titleHeight-n,0),this.currentPage=St(this.currentPage,1),this.fullHeight=t,u.forEach((M,C)=>{let T=(b=M.legendItem||{}).y||0,A=Math.round(b.label.getBBox().height),O=g.length;(!O||T-g[O-1]>m&&(y||T)!==g[O-1])&&(g.push(y||T),O++),b.pageIx=O-1,y&&v&&(v.pageIx=O-1),C===u.length-1&&T+A-g[O-1]>m&&T>g[O-1]&&(g.push(T),b.pageIx=O),T!==y&&(y=T),v=b}),k||(k=e.clipRect=s.clipRect(0,n-2,9999,0),e.contentGroup.clip(k)),f(m),w||(this.nav=w=s.g().attr({zIndex:1}).add(this.group),this.up=s.symbol("triangle",0,0,p,p).add(w),x("upTracker").on("click",function(){e.scroll(-1,d)}),this.pager=s.text("",15,10).addClass("highcharts-legend-navigation"),!i.styledMode&&c.style&&this.pager.css(c.style),this.pager.add(w),this.down=s.symbol("triangle-down",0,0,p,p).add(w),x("downTracker").on("click",function(){e.scroll(1,d)})),e.scroll(0),t=S):w&&(f(),this.nav=w.destroy(),this.scrollGroup.attr({translateY:1}),this.clipHeight=0),t}scroll(t,e){let i=this.chart,s=this.pages,o=s.length,r=this.clipHeight,a=this.options.navigation,n=this.pager,l=this.padding,c=this.currentPage+t;c>o&&(c=o),c>0&&(e!==void 0&&ac(e,i),this.nav.attr({translateX:l,translateY:r+this.padding+7+this.titleHeight,visibility:"inherit"}),[this.up,this.upTracker].forEach(function(d){d.attr({class:c===1?"highcharts-legend-nav-inactive":"highcharts-legend-nav-active"})}),n.attr({text:c+"/"+o}),[this.down,this.downTracker].forEach(function(d){d.attr({x:18+this.pager.getBBox().width,class:c===o?"highcharts-legend-nav-inactive":"highcharts-legend-nav-active"})},this),i.styledMode||(this.up.attr({fill:c===1?a.inactiveColor:a.activeColor}),this.upTracker.css({cursor:c===1?"default":"pointer"}),this.down.attr({fill:c===o?a.inactiveColor:a.activeColor}),this.downTracker.css({cursor:c===o?"default":"pointer"})),this.scrollOffset=-s[c-1]+this.initialItemY,this.scrollGroup.animate({translateY:this.scrollOffset}),this.currentPage=c,this.positionCheckboxes(),xc(()=>{Wt(this,"afterScroll",{currentPage:c})},rc(St(e,i.renderer.globalAnimation,!0)).duration))}setItemEvents(t,e,i){let s=this,o=t.legendItem||{},r=s.chart.renderer.boxWrapper,a=t instanceof Ut,n=t instanceof bt,l="highcharts-legend-"+(a?"point":"series")+"-active",c=s.chart.styledMode,d=i?[e,o.symbol]:[o.group],p=g=>{s.allItems.forEach(u=>{t!==u&&[u].concat(u.linkedSeries||[]).forEach(f=>{f.setState(g,!a)})})};for(let g of d)g&&g.on("mouseover",function(){t.visible&&p("inactive"),t.setState("hover"),t.visible&&r.addClass(l),c||e.css(s.options.itemHoverStyle)}).on("mouseout",function(){s.chart.styledMode||e.css(he(t.visible?s.itemStyle:s.itemHiddenStyle)),p(""),r.removeClass(l),t.setState()}).on("click",function(u){let f=function(){t.setVisible&&t.setVisible(),p(t.visible?"inactive":"")};r.removeClass(l),Wt(s,"itemClick",{browserEvent:u,legendItem:t},f),a?t.firePointEvent("legendItemClick",{browserEvent:u}):n&&Wt(t,"legendItemClick",{browserEvent:u})})}createCheckboxForItem(t){t.checkbox=dc("input",{type:"checkbox",className:"highcharts-legend-checkbox",checked:t.selected,defaultChecked:t.selected},this.options.itemCheckboxStyle,this.chart.container),Hi(t.checkbox,"click",function(e){let i=e.target;Wt(t.series||t,"checkboxClick",{checked:i.checked,item:t},function(){t.select()})})}}(function(h){h.compose=function(t){uc(nc,"Core.Legend")&&Hi(t,"beforeMargins",function(){this.legend=new h(this,this.options.legend)})}})(ao||(ao={}));let Ma=ao,{animate:no,animObject:yc,setAnimation:ho}=dt,{defaultOptions:lo}=kt,{numberFormat:bc}=wt,{registerEventOptions:Sa}=Mi,{charts:le,doc:$e,marginNames:Ca,svg:vc,win:Ta}=P,{seriesTypes:co}=st,{addEvent:po,attr:Aa,createElement:go,css:At,defined:$t,diffObjects:Pa,discardElement:kc,erase:wc,error:uo,extend:Zt,find:fo,fireEvent:G,getAlignFactor:Mc,getStyle:mo,isArray:Sc,isNumber:Pe,isObject:Cc,isString:Xi,merge:Nt,objectEach:xo,pick:ct,pInt:Tc,relativeLength:Oa,removeEvent:La,splat:Fi,syncTimeout:Ac,uniqueKey:Pc}=N;class qt{static chart(t,e,i){return new qt(t,e,i)}constructor(t,e,i){this.sharedClips={};let s=[...arguments];(Xi(t)||t.nodeName)&&(this.renderTo=s.shift()),this.init(s[0],s[1])}setZoomOptions(){let t=this.options.chart,e=t.zooming;this.zooming=Ht(vt({},e),{type:ct(t.zoomType,e.type),key:ct(t.zoomKey,e.key),pinchType:ct(t.pinchType,e.pinchType),singleTouch:ct(t.zoomBySingleTouch,e.singleTouch,!1),resetButton:Nt(e.resetButton,t.resetZoomButton)})}init(t,e){G(this,"init",{args:arguments},function(){let i=Nt(lo,t),s=i.chart,o=this.renderTo||s.renderTo;this.userOptions=Zt({},t),(this.renderTo=Xi(o)?$e.getElementById(o):o)||uo(13,!0,this),this.margin=[],this.spacing=[],this.labelCollectors=[],this.callback=e,this.isResizing=0,this.options=i,this.axes=[],this.series=[],this.locale=i.lang.locale??this.renderTo.closest("[lang]")?.lang,this.time=new Ms(Zt(i.time||{},{locale:this.locale}),i.lang),i.time=this.time.options,this.numberFormatter=(s.numberFormatter||bc).bind(this),this.styledMode=s.styledMode,this.hasCartesianSeries=s.showAxes,this.index=le.length,le.push(this),P.chartCount++,Sa(this,s),this.xAxis=[],this.yAxis=[],this.pointCount=this.colorCounter=this.symbolCounter=0,this.setZoomOptions(),G(this,"afterInit"),this.firstRender()})}initSeries(t){let e=this.options.chart,i=t.type||e.type,s=co[i];s||uo(17,!0,this,{missingModuleFor:i});let o=new s;return typeof o.init=="function"&&o.init(this,t),o}setSortedData(){this.getSeriesOrderByLinks().forEach(function(t){t.points||t.data||!t.enabledDataSorting||t.setData(t.options.data,!1)})}getSeriesOrderByLinks(){return this.series.concat().sort(function(t,e){return t.linkedSeries.length||e.linkedSeries.length?e.linkedSeries.length-t.linkedSeries.length:0})}orderItems(t,e=0){let i=this[t],s=this.options[t]=Fi(this.options[t]).slice(),o=this.userOptions[t]=this.userOptions[t]?Fi(this.userOptions[t]).slice():[];if(this.hasRendered&&(s.splice(e),o.splice(e)),i)for(let r=e,a=i.length;r<a;++r){let n=i[r];n&&(n.index=r,n instanceof bt&&(n.name=n.getName()),n.options.isInternal||(s[r]=n.options,o[r]=n.userOptions))}}getClipBox(t,e){let i=this.inverted,{xAxis:s,yAxis:o}=t||{},{x:r,y:a,width:n,height:l}=Nt(this.clipBox);return t&&(s&&s.len!==this.plotSizeX&&(n=s.len),o&&o.len!==this.plotSizeY&&(l=o.len),i&&!t.invertible&&([n,l]=[l,n])),e&&(r+=(i?o:s)?.pos??this.plotLeft,a+=(i?s:o)?.pos??this.plotTop),{x:r,y:a,width:n,height:l}}isInsidePlot(t,e,i={}){let{inverted:s,plotBox:o,plotLeft:r,plotTop:a,scrollablePlotBox:n}=this,{scrollLeft:l=0,scrollTop:c=0}=i.visiblePlotOnly&&this.scrollablePlotArea?.scrollingContainer||{},d=i.series,p=i.visiblePlotOnly&&n||o,g=i.inverted?e:t,u=i.inverted?t:e,f={x:g,y:u,isInsidePlot:!0,options:i};if(!i.ignoreX){let x=d&&(s&&!this.polar?d.yAxis:d.xAxis)||{pos:r,len:1/0},m=i.paneCoordinates?x.pos+g:r+g;m>=Math.max(l+r,x.pos)&&m<=Math.min(l+r+p.width,x.pos+x.len)||(f.isInsidePlot=!1)}if(!i.ignoreY&&f.isInsidePlot){let x=!s&&i.axis&&!i.axis.isXAxis&&i.axis||d&&(s?d.xAxis:d.yAxis)||{pos:a,len:1/0},m=i.paneCoordinates?x.pos+u:a+u;m>=Math.max(c+a,x.pos)&&m<=Math.min(c+a+p.height,x.pos+x.len)||(f.isInsidePlot=!1)}return G(this,"afterIsInsidePlot",f),f.isInsidePlot}redraw(t){G(this,"beforeRedraw");let e=this.hasCartesianSeries?this.axes:this.colorAxis||[],i=this.series,s=this.pointer,o=this.legend,r=this.userOptions.legend,a=this.renderer,n=a.isHidden(),l=[],c,d,p,g=this.isDirtyBox,u=this.isDirtyLegend,f;for(a.rootFontSize=a.boxWrapper.getStyle("font-size"),this.setResponsive&&this.setResponsive(!1),ho(!!this.hasRendered&&t,this),n&&this.temporaryDisplay(),this.layOutTitles(!1),p=i.length;p--;)if(((f=i[p]).options.stacking||f.options.centerInCategory)&&(d=!0,f.isDirty)){c=!0;break}if(c)for(p=i.length;p--;)(f=i[p]).options.stacking&&(f.isDirty=!0);i.forEach(function(x){x.isDirty&&(x.options.legendType==="point"?(typeof x.updateTotals=="function"&&x.updateTotals(),u=!0):r&&(r.labelFormatter||r.labelFormat)&&(u=!0)),x.isDirtyData&&G(x,"updatedData")}),u&&o&&o.options.enabled&&(o.render(),this.isDirtyLegend=!1),d&&this.getStacks(),e.forEach(function(x){x.updateNames(),x.setScale()}),this.getMargins(),e.forEach(function(x){x.isDirty&&(g=!0)}),e.forEach(function(x){let m=x.min+","+x.max;x.extKey!==m&&(x.extKey=m,l.push(function(){G(x,"afterSetExtremes",Zt(x.eventArgs,x.getExtremes())),delete x.eventArgs})),(g||d)&&x.redraw()}),g&&this.drawChartBox(),G(this,"predraw"),i.forEach(function(x){(g||x.isDirty)&&x.visible&&x.redraw(),x.isDirtyData=!1}),s&&s.reset(!0),a.draw(),G(this,"redraw"),G(this,"render"),n&&this.temporaryDisplay(!0),l.forEach(function(x){x.call()})}get(t){let e=this.series;function i(o){return o.id===t||o.options&&o.options.id===t}let s=fo(this.axes,i)||fo(this.series,i);for(let o=0;!s&&o<e.length;o++)s=fo(e[o].points||[],i);return s}createAxes(){let t=this.userOptions;for(let e of(G(this,"createAxes"),["xAxis","yAxis"]))for(let i of t[e]=Fi(t[e]||{}))new Zs(this,i,e);G(this,"afterCreateAxes")}getSelectedPoints(){return this.series.reduce((t,e)=>(e.getPointsCollection().forEach(i=>{ct(i.selectedStaging,i.selected)&&t.push(i)}),t),[])}getSelectedSeries(){return this.series.filter(t=>t.selected)}setTitle(t,e,i){this.applyDescription("title",t),this.applyDescription("subtitle",e),this.applyDescription("caption",void 0),this.layOutTitles(i)}applyDescription(t,e){let i=this,s=this.options[t]=Nt(this.options[t],e),o=this[t];o&&e&&(this[t]=o=o.destroy()),s&&!o&&((o=this.renderer.text(s.text,0,0,s.useHTML).attr({align:s.align,class:"highcharts-"+t,zIndex:s.zIndex||4}).css({textOverflow:"ellipsis",whiteSpace:"nowrap"}).add()).update=function(r,a){i.applyDescription(t,r),i.layOutTitles(a)},this.styledMode||o.css(Zt(t==="title"?{fontSize:this.options.isStock?"1em":"1.2em"}:{},s.style)),o.textPxLength=o.getBBox().width,o.css({whiteSpace:s.style?.whiteSpace}),this[t]=o)}layOutTitles(t=!0){let e=[0,0,0],{options:i,renderer:s,spacingBox:o}=this;["title","subtitle","caption"].forEach(a=>{let n=this[a],l=this.options[a],c=Nt(o),d=n?.textPxLength||0;if(n&&l){G(this,"layOutTitle",{alignTo:c,key:a,textPxLength:d});let p=s.fontMetrics(n),g=p.b,u=p.h,f=l.verticalAlign||"top",x=f==="top",m=x&&l.minScale||1,y=a==="title"?x?-3:0:x?e[0]+2:0,b=Math.min(c.width/d,1),v=Math.max(m,b),S=Nt({y:f==="bottom"?g:y+g},{align:a==="title"?b<m?"left":"center":this.title?.alignValue},l),w=(l.width||(b>m?this.chartWidth:c.width)/v)+"px";n.alignValue!==S.align&&(n.placed=!1);let k=Math.round(n.css({width:w}).getBBox(l.useHTML).height);if(S.height=k,n.align(S,!1,c).attr({align:S.align,scaleX:v,scaleY:v,"transform-origin":`${c.x+d*v*Mc(S.align)} ${u}`}),!l.floating){let M=k*(k<1.2*u?1:v);f==="top"?e[0]=Math.ceil(e[0]+M):f==="bottom"&&(e[2]=Math.ceil(e[2]+M))}}},this),e[0]&&(i.title?.verticalAlign||"top")==="top"&&(e[0]+=i.title?.margin||0),e[2]&&i.caption?.verticalAlign==="bottom"&&(e[2]+=i.caption?.margin||0);let r=!this.titleOffset||this.titleOffset.join(",")!==e.join(",");this.titleOffset=e,G(this,"afterLayOutTitles"),!this.isDirtyBox&&r&&(this.isDirtyBox=this.isDirtyLegend=r,this.hasRendered&&t&&this.isDirtyBox&&this.redraw())}getContainerBox(){let t=[].map.call(this.renderTo.children,i=>{if(i!==this.container){let s=i.style.display;return i.style.display="none",[i,s]}}),e={width:mo(this.renderTo,"width",!0)||0,height:mo(this.renderTo,"height",!0)||0};return t.filter(Boolean).forEach(([i,s])=>{i.style.display=s}),e}getChartSize(){let t=this.options.chart,e=t.width,i=t.height,s=this.getContainerBox(),o=s.height<=1||!this.renderTo.parentElement?.style.height&&this.renderTo.style.height==="100%";this.chartWidth=Math.max(0,e||s.width||600),this.chartHeight=Math.max(0,Oa(i,this.chartWidth)||(o?400:s.height)),this.containerBox=s}temporaryDisplay(t){let e=this.renderTo,i;if(t)for(;e?.style;)e.hcOrigStyle&&(At(e,e.hcOrigStyle),delete e.hcOrigStyle),e.hcOrigDetached&&($e.body.removeChild(e),e.hcOrigDetached=!1),e=e.parentNode;else for(;e?.style&&($e.body.contains(e)||e.parentNode||(e.hcOrigDetached=!0,$e.body.appendChild(e)),(mo(e,"display",!1)==="none"||e.hcOricDetached)&&(e.hcOrigStyle={display:e.style.display,height:e.style.height,overflow:e.style.overflow},i={display:"block",overflow:"hidden"},e!==this.renderTo&&(i.height=0),At(e,i),e.offsetWidth||e.style.setProperty("display","block","important")),(e=e.parentNode)!==$e.body););}setClassName(t){this.container.className="highcharts-container "+(t||"")}getContainer(){let t,e=this.options,i=e.chart,s="data-highcharts-chart",o=Pc(),r=this.renderTo,a=Tc(Aa(r,s));Pe(a)&&le[a]&&le[a].hasRendered&&le[a].destroy(),Aa(r,s,this.index),r.innerHTML=_.emptyHTML,i.skipClone||r.offsetWidth||this.temporaryDisplay(),this.getChartSize();let n=this.chartHeight,l=this.chartWidth;At(r,{overflow:"hidden"}),this.styledMode||(t=Zt({position:"relative",overflow:"hidden",width:l+"px",height:n+"px",textAlign:"left",lineHeight:"normal",zIndex:0,"-webkit-tap-highlight-color":"rgba(0,0,0,0)",userSelect:"none","touch-action":"manipulation",outline:"none",padding:"0px"},i.style||{}));let c=go("div",{id:o},t,r);this.container=c,this.getChartSize(),l===this.chartWidth||(l=this.chartWidth,this.styledMode||At(c,{width:ct(i.style?.width,l+"px")})),this.containerBox=this.getContainerBox(),this._cursor=c.style.cursor;let d=i.renderer||!vc?Re.getRendererType(i.renderer):ki;if(this.renderer=new d(c,l,n,void 0,i.forExport,e.exporting?.allowHTML,this.styledMode),ho(void 0,this),this.setClassName(i.className),this.styledMode)for(let p in e.defs)this.renderer.definition(e.defs[p]);else this.renderer.setStyle(i.style);this.renderer.chartIndex=this.index,G(this,"afterGetContainer")}getMargins(t){let{spacing:e,margin:i,titleOffset:s}=this;this.resetMargins(),s[0]&&!$t(i[0])&&(this.plotTop=Math.max(this.plotTop,s[0]+e[0])),s[2]&&!$t(i[2])&&(this.marginBottom=Math.max(this.marginBottom,s[2]+e[2])),this.legend?.display&&this.legend.adjustMargins(i,e),G(this,"getMargins"),t||this.getAxisMargins()}getAxisMargins(){let t=this,e=t.axisOffset=[0,0,0,0],i=t.colorAxis,s=t.margin,o=function(r){r.forEach(function(a){a.visible&&a.getOffset()})};t.hasCartesianSeries?o(t.axes):i?.length&&o(i),Ca.forEach(function(r,a){$t(s[a])||(t[r]+=e[a])}),t.setChartSize()}getOptions(){return Pa(this.userOptions,lo)}reflow(t){let e=this,i=e.containerBox,s=e.getContainerBox();delete e.pointer?.chartPosition,!e.isPrinting&&!e.isResizing&&i&&s.width&&((s.width!==i.width||s.height!==i.height)&&(N.clearTimeout(e.reflowTimeout),e.reflowTimeout=Ac(function(){e.container&&e.setSize(void 0,void 0,!1)},100*!!t)),e.containerBox=s)}setReflow(){let t=this,e=i=>{t.options?.chart.reflow&&t.hasLoaded&&t.reflow(i)};if(typeof ResizeObserver=="function")new ResizeObserver(e).observe(t.renderTo);else{let i=po(Ta,"resize",e);po(this,"destroy",i)}}setSize(t,e,i){let s=this,o=s.renderer;s.isResizing+=1,ho(i,s);let r=o.globalAnimation;s.oldChartHeight=s.chartHeight,s.oldChartWidth=s.chartWidth,t!==void 0&&(s.options.chart.width=t),e!==void 0&&(s.options.chart.height=e),s.getChartSize();let{chartWidth:a,chartHeight:n,scrollablePixelsX:l=0,scrollablePixelsY:c=0}=s;(s.isDirtyBox||a!==s.oldChartWidth||n!==s.oldChartHeight)&&(s.styledMode||(r?no:At)(s.container,{width:`${a+l}px`,height:`${n+c}px`},r),s.setChartSize(!0),o.setSize(a,n,r),s.axes.forEach(function(d){d.isDirty=!0,d.setScale()}),s.isDirtyLegend=!0,s.isDirtyBox=!0,s.layOutTitles(),s.getMargins(),s.redraw(r),s.oldChartHeight=void 0,G(s,"resize"),setTimeout(()=>{s&&G(s,"endResize")},yc(r).duration)),s.isResizing-=1}setChartSize(t){let e,i,s,o,{chartHeight:r,chartWidth:a,inverted:n,spacing:l,renderer:c}=this,d=this.clipOffset,p=Math[n?"floor":"round"];this.plotLeft=e=Math.round(this.plotLeft),this.plotTop=i=Math.round(this.plotTop),this.plotWidth=s=Math.max(0,Math.round(a-e-(this.marginRight??0))),this.plotHeight=o=Math.max(0,Math.round(r-i-(this.marginBottom??0))),this.plotSizeX=n?o:s,this.plotSizeY=n?s:o,this.spacingBox=c.spacingBox={x:l[3],y:l[0],width:a-l[3]-l[1],height:r-l[0]-l[2]},this.plotBox=c.plotBox={x:e,y:i,width:s,height:o},d&&(this.clipBox={x:p(d[3]),y:p(d[0]),width:p(this.plotSizeX-d[1]-d[3]),height:p(this.plotSizeY-d[0]-d[2])}),t||(this.axes.forEach(function(g){g.setAxisSize(),g.setAxisTranslation()}),c.alignElements()),G(this,"afterSetChartSize",{skipAxes:t})}resetMargins(){G(this,"resetMargins");let t=this,e=t.options.chart,i=e.plotBorderWidth||0,s=Math.round(i)/2;["margin","spacing"].forEach(function(o){let r=e[o],a=Cc(r)?r:[r,r,r,r];["Top","Right","Bottom","Left"].forEach(function(n,l){t[o][l]=ct(e[o+n],a[l])})}),Ca.forEach(function(o,r){t[o]=ct(t.margin[r],t.spacing[r])}),t.axisOffset=[0,0,0,0],t.clipOffset=[s,s,s,s],t.plotBorderWidth=i}drawChartBox(){let t=this.options.chart,e=this.renderer,i=this.chartWidth,s=this.chartHeight,o=this.styledMode,r=this.plotBGImage,a=t.backgroundColor,n=t.plotBackgroundColor,l=t.plotBackgroundImage,c=this.plotLeft,d=this.plotTop,p=this.plotWidth,g=this.plotHeight,u=this.plotBox,f=this.clipRect,x=this.clipBox,m=this.chartBackground,y=this.plotBackground,b=this.plotBorder,v,S,w,k="animate";m||(this.chartBackground=m=e.rect().addClass("highcharts-background").add(),k="attr"),o?v=S=m.strokeWidth():(S=(v=t.borderWidth||0)+8*!!t.shadow,w={fill:a||"none"},(v||m["stroke-width"])&&(w.stroke=t.borderColor,w["stroke-width"]=v),m.attr(w).shadow(t.shadow)),m[k]({x:S/2,y:S/2,width:i-S-v%2,height:s-S-v%2,r:t.borderRadius}),k="animate",y||(k="attr",this.plotBackground=y=e.rect().addClass("highcharts-plot-background").add()),y[k](u),!o&&(y.attr({fill:n||"none"}).shadow(t.plotShadow),l&&(r?(l!==r.attr("href")&&r.attr("href",l),r.animate(u)):this.plotBGImage=e.image(l,c,d,p,g).add())),f?f.animate({width:x.width,height:x.height}):this.clipRect=e.clipRect(x),k="animate",b||(k="attr",this.plotBorder=b=e.rect().addClass("highcharts-plot-border").attr({zIndex:1}).add()),o||b.attr({stroke:t.plotBorderColor,"stroke-width":t.plotBorderWidth||0,fill:"none"}),b[k](b.crisp(u,-b.strokeWidth())),this.isDirtyBox=!1,G(this,"afterDrawChartBox")}propFromSeries(){let t,e,i,s=this,o=s.options.chart,r=s.options.series;["inverted","angular","polar"].forEach(function(a){for(e=co[o.type],i=o[a]||e&&e.prototype[a],t=r?.length;!i&&t--;)(e=co[r[t].type])&&e.prototype[a]&&(i=!0);s[a]=i})}linkSeries(t){let e=this,i=e.series;i.forEach(function(s){s.linkedSeries.length=0}),i.forEach(function(s){let{linkedTo:o}=s.options;if(Xi(o)){let r;(r=o===":previous"?e.series[s.index-1]:e.get(o))&&r.linkedParent!==s&&(r.linkedSeries.push(s),s.linkedParent=r,r.enabledDataSorting&&s.setDataSortingOptions(),s.visible=ct(s.options.visible,r.options.visible,s.visible))}}),G(this,"afterLinkSeries",{isUpdating:t})}renderSeries(){this.series.forEach(function(t){t.translate(),t.render()})}render(){let t=this.axes,e=this.colorAxis,i=this.renderer,s=this.options.chart.axisLayoutRuns||2,o=c=>{c.forEach(d=>{d.visible&&d.render()})},r=0,a=!0,n,l=0;for(let c of(this.setTitle(),G(this,"beforeMargins"),this.getStacks?.(),this.getMargins(!0),this.setChartSize(),t)){let{options:d}=c,{labels:p}=d;if(this.hasCartesianSeries&&c.horiz&&c.visible&&p.enabled&&c.series.length&&c.coll!=="colorAxis"&&!this.polar){r=d.tickLength,c.createGroups();let g=new Me(c,0,"",!0),u=g.createLabel("x",p);if(g.destroy(),u&&ct(p.reserveSpace,!Pe(d.crossing))&&(r=u.getBBox().height+p.distance+Math.max(d.offset||0,0)),r){u?.destroy();break}}}for(this.plotHeight=Math.max(this.plotHeight-r,0);(a||n||s>1)&&l<s;){let c=this.plotWidth,d=this.plotHeight;for(let p of t)l===0?p.setScale():(p.horiz&&a||!p.horiz&&n)&&p.setTickInterval(!0);l===0?this.getAxisMargins():this.getMargins(),a=c/this.plotWidth>(l?1:1.1),n=d/this.plotHeight>(l?1:1.05),l++}this.drawChartBox(),this.hasCartesianSeries?o(t):e?.length&&o(e),this.seriesGroup||(this.seriesGroup=i.g("series-group").attr({zIndex:3}).shadow(this.options.chart.seriesGroupShadow).add()),this.renderSeries(),this.addCredits(),this.setResponsive&&this.setResponsive(),this.hasRendered=!0}addCredits(t){let e=this,i=Nt(!0,this.options.credits,t);i.enabled&&!this.credits&&(this.credits=this.renderer.text(i.text+(this.mapCredits||""),0,0).addClass("highcharts-credits").on("click",function(){i.href&&(Ta.location.href=i.href)}).attr({align:i.position.align,zIndex:8}),e.styledMode||this.credits.css(i.style),this.credits.add().align(i.position),this.credits.update=function(s){e.credits=e.credits.destroy(),e.addCredits(s)})}destroy(){let t,e=this,i=e.axes,s=e.series,o=e.container,r=o?.parentNode;for(G(e,"destroy"),e.renderer.forExport?wc(le,e):le[e.index]=void 0,P.chartCount--,e.renderTo.removeAttribute("data-highcharts-chart"),La(e),t=i.length;t--;)i[t]=i[t].destroy();for(this.scroller?.destroy?.(),t=s.length;t--;)s[t]=s[t].destroy();["title","subtitle","chartBackground","plotBackground","plotBGImage","plotBorder","seriesGroup","clipRect","credits","pointer","rangeSelector","legend","resetZoomButton","tooltip","renderer"].forEach(a=>{e[a]=e[a]?.destroy?.()}),o&&(o.innerHTML=_.emptyHTML,La(o),r&&kc(o)),xo(e,function(a,n){delete e[n]})}firstRender(){let t=this,e=t.options;t.getContainer(),t.resetMargins(),t.setChartSize(),t.propFromSeries(),t.createAxes();let i=Sc(e.series)?e.series:[];e.series=[],i.forEach(function(s){t.initSeries(s)}),t.linkSeries(),t.setSortedData(),G(t,"beforeRender"),t.render(),t.pointer?.getChartPosition(),t.renderer.imgCount||t.hasLoaded||t.onload(),t.temporaryDisplay(!0)}onload(){this.callbacks.concat([this.callback]).forEach(function(t){t&&this.index!==void 0&&t.apply(this,[this])},this),G(this,"load"),G(this,"render"),$t(this.index)&&this.setReflow(),this.warnIfA11yModuleNotLoaded(),this.hasLoaded=!0}warnIfA11yModuleNotLoaded(){let{options:t,title:e}=this;!t||this.accessibility||(this.renderer.boxWrapper.attr({role:"img","aria-label":(e?.element.textContent||"").replace(/</g,"<")}),t.accessibility&&t.accessibility.enabled===!1||uo('Highcharts warning: Consider including the "accessibility.js" module to make your chart more usable for people with disabilities. Set the "accessibility.enabled" option to false to remove this warning. See https://www.highcharts.com/docs/accessibility/accessibility-module.',!1,this))}addSeries(t,e,i){let s,o=this;return t&&(e=ct(e,!0),G(o,"addSeries",{options:t},function(){s=o.initSeries(t),o.isDirtyLegend=!0,o.linkSeries(),s.enabledDataSorting&&s.setData(t.data,!1),G(o,"afterAddSeries",{series:s}),e&&o.redraw(i)})),s}addAxis(t,e,i,s){return this.createAxis(e?"xAxis":"yAxis",{axis:t,redraw:i,animation:s})}addColorAxis(t,e,i){return this.createAxis("colorAxis",{axis:t,redraw:e,animation:i})}createAxis(t,e){let i=new Zs(this,e.axis,t);return ct(e.redraw,!0)&&this.redraw(e.animation),i}showLoading(t){let e=this,i=e.options,s=i.loading,o=function(){r&&At(r,{left:e.plotLeft+"px",top:e.plotTop+"px",width:e.plotWidth+"px",height:e.plotHeight+"px"})},r=e.loadingDiv,a=e.loadingSpan;r||(e.loadingDiv=r=go("div",{className:"highcharts-loading highcharts-loading-hidden"},null,e.container)),a||(e.loadingSpan=a=go("span",{className:"highcharts-loading-inner"},null,r),po(e,"redraw",o)),r.className="highcharts-loading",_.setElementHTML(a,ct(t,i.lang.loading,"")),e.styledMode||(At(r,Zt(s.style,{zIndex:10})),At(a,s.labelStyle),e.loadingShown||(At(r,{opacity:0,display:""}),no(r,{opacity:s.style.opacity||.5},{duration:s.showDuration||0}))),e.loadingShown=!0,o()}hideLoading(){let t=this.options,e=this.loadingDiv;e&&(e.className="highcharts-loading highcharts-loading-hidden",this.styledMode||no(e,{opacity:0},{duration:t.loading.hideDuration||100,complete:function(){At(e,{display:"none"})}})),this.loadingShown=!1}update(t,e,i,s){let o,r,a,n=this,l={credits:"addCredits",title:"setTitle",subtitle:"setSubtitle",caption:"setCaption"},c=t.isResponsiveOptions,d=[];G(n,"update",{options:t}),c||n.setResponsive(!1,!0),t=Pa(t,n.options),n.userOptions=Nt(n.userOptions,t);let p=t.chart;p&&(Nt(!0,n.options.chart,p),this.setZoomOptions(),"className"in p&&n.setClassName(p.className),("inverted"in p||"polar"in p||"type"in p)&&(n.propFromSeries(),o=!0),"alignTicks"in p&&(o=!0),"events"in p&&Sa(this,p),xo(p,function(f,x){n.propsRequireUpdateSeries.indexOf("chart."+x)!==-1&&(r=!0),n.propsRequireDirtyBox.indexOf(x)!==-1&&(n.isDirtyBox=!0),n.propsRequireReflow.indexOf(x)===-1||(n.isDirtyBox=!0,c||(a=!0))}),!n.styledMode&&p.style&&n.renderer.setStyle(n.options.chart.style||{})),!n.styledMode&&t.colors&&(this.options.colors=t.colors),xo(t,function(f,x){n[x]&&typeof n[x].update=="function"?n[x].update(f,!1):typeof n[l[x]]=="function"?n[l[x]](f):x!=="colors"&&n.collectionsWithUpdate.indexOf(x)===-1&&Nt(!0,n.options[x],t[x]),x!=="chart"&&n.propsRequireUpdateSeries.indexOf(x)!==-1&&(r=!0)}),this.collectionsWithUpdate.forEach(function(f){t[f]&&(Fi(t[f]).forEach(function(x,m){let y,b=$t(x.id);b&&(y=n.get(x.id)),!y&&n[f]&&(y=n[f][ct(x.index,m)])&&(b&&$t(y.options.id)||y.options.isInternal)&&(y=void 0),y&&y.coll===f&&(y.update(x,!1),i&&(y.touched=!0)),!y&&i&&n.collectionsWithInit[f]&&(n.collectionsWithInit[f][0].apply(n,[x].concat(n.collectionsWithInit[f][1]||[]).concat([!1])).touched=!0)}),i&&n[f].forEach(function(x){x.touched||x.options.isInternal?delete x.touched:d.push(x)}))}),d.forEach(function(f){f.chart&&f.remove&&f.remove(!1)}),o&&n.axes.forEach(function(f){f.update({},!1)}),r&&n.getSeriesOrderByLinks().forEach(function(f){f.chart&&f.update({},!1)},this);let g=p?.width,u=p&&(Xi(p.height)?Oa(p.height,g||n.chartWidth):p.height);a||Pe(g)&&g!==n.chartWidth||Pe(u)&&u!==n.chartHeight?n.setSize(g,u,s):ct(e,!0)&&n.redraw(s),G(n,"afterUpdate",{options:t,redraw:e,animation:s})}setSubtitle(t,e){this.applyDescription("subtitle",t),this.layOutTitles(e)}setCaption(t,e){this.applyDescription("caption",t),this.layOutTitles(e)}showResetZoom(){let t=this,e=lo.lang,i=t.zooming.resetButton,s=i.theme,o=i.relativeTo==="chart"||i.relativeTo==="spacingBox"?null:"plotBox";function r(){t.zoomOut()}G(this,"beforeShowResetZoom",null,function(){t.resetZoomButton=t.renderer.button(e.resetZoom,null,null,r,s).attr({align:i.position.align,title:e.resetZoomTitle}).addClass("highcharts-reset-zoom").add().align(i.position,!1,o)}),G(this,"afterShowResetZoom")}zoomOut(){G(this,"selection",{resetSelection:!0},()=>this.transform({reset:!0,trigger:"zoom"}))}pan(t,e){let i=this,s=typeof e=="object"?e:{enabled:e,type:"x"},o=s.type,r=o&&i[{x:"xAxis",xy:"axes",y:"yAxis"}[o]].filter(n=>n.options.panningEnabled&&!n.options.isInternal),a=i.options.chart;a?.panning&&(a.panning=s),G(this,"pan",{originalEvent:t},()=>{i.transform({axes:r,event:t,to:{x:t.chartX-(i.mouseDownX||0),y:t.chartY-(i.mouseDownY||0)},trigger:"pan"}),At(i.container,{cursor:"move"})})}transform(t){let{axes:e=this.axes,event:i,from:s={},reset:o,selection:r,to:a={},trigger:n}=t,{inverted:l,time:c}=this,d=!1,p,g;for(let u of(this.hoverPoints?.forEach(f=>f.setState()),e)){let{horiz:f,len:x,minPointOffset:m=0,options:y,reversed:b}=u,v=f?"width":"height",S=f?"x":"y",w=ct(a[v],u.len),k=ct(s[v],u.len),M=10>Math.abs(w)?1:w/k,C=(s[S]||0)+k/2-u.pos,T=C-((a[S]??u.pos)+w/2-u.pos)/M,A=b&&!l||!b&&l?-1:1;if(!o&&(C<0||C>u.len))continue;let O=u.toValue(T,!0)+(r||u.isOrdinal?0:m*A),L=u.toValue(T+x/M,!0)-(r||u.isOrdinal?0:m*A||0),I=u.allExtremes;if(O>L&&([O,L]=[L,O]),M===1&&!o&&u.coll==="yAxis"&&!I){for(let xt of u.series){let Jt=xt.getExtremes(xt.getProcessedData(!0).modified.getColumn("y")||[],!0);I??(I={dataMin:Number.MAX_VALUE,dataMax:-Number.MAX_VALUE}),Pe(Jt.dataMin)&&Pe(Jt.dataMax)&&(I.dataMin=Math.min(Jt.dataMin,I.dataMin),I.dataMax=Math.max(Jt.dataMax,I.dataMax))}u.allExtremes=I}let{dataMin:D,dataMax:E,min:B,max:K}=Zt(u.getExtremes(),I||{}),Y=c.parse(y.min),pt=c.parse(y.max),R=D??Y,W=E??pt,j=L-O,X=u.categories?0:Math.min(j,W-R),$=R-X*($t(Y)?0:y.minPadding),q=W+X*($t(pt)?0:y.maxPadding),U=u.allowZoomOutside||M===1||n!=="zoom"&&M>1,J=Math.min(Y??$,$,U?B:$),gt=Math.max(pt??q,q,U?K:q);(!u.isOrdinal||u.options.overscroll||M!==1||o)&&(O<J&&(O=J,M>=1&&(L=O+j)),L>gt&&(L=gt,M>=1&&(O=L-j)),(o||u.series.length&&(O!==B||L!==K)&&O>=J&&L<=gt)&&(r?r[u.coll].push({axis:u,min:O,max:L}):(u.isPanning=n!=="zoom",u.isPanning&&(g=!0),u.setExtremes(o?void 0:O,o?void 0:L,!1,!1,{move:T,trigger:n,scale:M}),!o&&(O>J||L<gt)&&n!=="mousewheel"&&(p=!0)),d=!0),i&&(this[f?"mouseDownX":"mouseDownY"]=i[f?"chartX":"chartY"]))}return d&&(r?G(this,"selection",r,()=>{delete t.selection,t.trigger="zoom",this.transform(t)}):(!p||g||this.resetZoomButton?!p&&this.resetZoomButton&&(this.resetZoomButton=this.resetZoomButton.destroy()):this.showResetZoom(),this.redraw(n==="zoom"&&(this.options.chart.animation??this.pointCount<100)))),d}}Zt(qt.prototype,{callbacks:[],collectionsWithInit:{xAxis:[qt.prototype.addAxis,[!0]],yAxis:[qt.prototype.addAxis,[!1]],series:[qt.prototype.addSeries]},collectionsWithUpdate:["xAxis","yAxis","series"],propsRequireDirtyBox:["backgroundColor","borderColor","borderWidth","borderRadius","plotBackgroundColor","plotBackgroundImage","plotBorderColor","plotBorderWidth","plotShadow","shadow"],propsRequireReflow:["margin","marginTop","marginRight","marginBottom","marginLeft","spacing","spacingTop","spacingRight","spacingBottom","spacingLeft"],propsRequireUpdateSeries:["chart.inverted","chart.polar","chart.ignoreHiddenSeries","chart.type","colors","plotOptions","time","tooltip"]});let{stop:Oc}=dt,{composed:Lc}=P,{addEvent:Kt,createElement:Gi,css:yo,defined:bo,erase:Ec,merge:Ea,pushUnique:Ia}=N;function Ic(){let h=this.scrollablePlotArea;(this.scrollablePixelsX||this.scrollablePixelsY)&&!h&&(this.scrollablePlotArea=h=new Ba(this)),h?.applyFixed()}function Da(){this.chart.scrollablePlotArea&&(this.chart.scrollablePlotArea.isDirty=!0)}let Ba=(()=>{class h{static compose(e,i,s){Ia(Lc,this.compose)&&(Kt(e,"afterInit",Da),Kt(i,"afterSetChartSize",o=>this.afterSetSize(o.target,o)),Kt(i,"render",Ic),Kt(s,"show",Da))}static afterSetSize(e,i){let s,o,r,{minWidth:a,minHeight:n}=e.options.chart.scrollablePlotArea||{},{clipBox:l,plotBox:c,inverted:d,renderer:p}=e;if(!p.forExport&&(a?(e.scrollablePixelsX=s=Math.max(0,a-e.chartWidth),s&&(e.scrollablePlotBox=Ea(e.plotBox),c.width=e.plotWidth+=s,l[d?"height":"width"]+=s,r=!0)):n&&(e.scrollablePixelsY=o=Math.max(0,n-e.chartHeight),bo(o)&&(e.scrollablePlotBox=Ea(e.plotBox),c.height=e.plotHeight+=o,l[d?"width":"height"]+=o,r=!1)),bo(r)&&!i.skipAxes))for(let g of e.axes)(g.horiz===r||e.hasParallelCoordinates&&g.coll==="yAxis")&&(g.setAxisSize(),g.setAxisTranslation())}constructor(e){let i,s=e.options.chart,o=Re.getRendererType(),r=s.scrollablePlotArea||{},a=this.moveFixedElements.bind(this),n={WebkitOverflowScrolling:"touch",overflowX:"hidden",overflowY:"hidden"};e.scrollablePixelsX&&(n.overflowX="auto"),e.scrollablePixelsY&&(n.overflowY="auto"),this.chart=e;let l=this.parentDiv=Gi("div",{className:"highcharts-scrolling-parent"},{position:"relative"},e.renderTo),c=this.scrollingContainer=Gi("div",{className:"highcharts-scrolling"},n,l),d=this.innerContainer=Gi("div",{className:"highcharts-inner-container"},void 0,c),p=this.fixedDiv=Gi("div",{className:"highcharts-fixed"},{position:"absolute",overflow:"hidden",pointerEvents:"none",zIndex:(s.style?.zIndex||0)+2,top:0},void 0,!0),g=this.fixedRenderer=new o(p,e.chartWidth,e.chartHeight,s.style);this.mask=g.path().attr({fill:s.backgroundColor||"#fff","fill-opacity":r.opacity??.85,zIndex:-1}).addClass("highcharts-scrollable-mask").add(),c.parentNode.insertBefore(p,c),yo(e.renderTo,{overflow:"visible"}),Kt(e,"afterShowResetZoom",a),Kt(e,"afterApplyDrilldown",a),Kt(e,"afterLayOutTitles",a),Kt(c,"scroll",()=>{let{pointer:u,hoverPoint:f}=e;u&&(delete u.chartPosition,f&&(i=f),u.runPointActions(void 0,i,!0))}),d.appendChild(e.container)}applyFixed(){let{chart:e,fixedRenderer:i,isDirty:s,scrollingContainer:o}=this,{axisOffset:r,chartWidth:a,chartHeight:n,container:l,plotHeight:c,plotLeft:d,plotTop:p,plotWidth:g,scrollablePixelsX:u=0,scrollablePixelsY:f=0}=e,{scrollPositionX:x=0,scrollPositionY:m=0}=e.options.chart.scrollablePlotArea||{},y=a+u,b=n+f;i.setSize(a,n),(s??!0)&&(this.isDirty=!1,this.moveFixedElements()),Oc(e.container),yo(l,{width:`${y}px`,height:`${b}px`}),e.renderer.boxWrapper.attr({width:y,height:b,viewBox:[0,0,y,b].join(" ")}),e.chartBackground?.attr({width:y,height:b}),yo(o,{width:`${a}px`,height:`${n}px`}),bo(s)||(o.scrollLeft=u*x,o.scrollTop=f*m);let v=p-r[0]-1,S=d-r[3]-1,w=p+c+r[2]+1,k=d+g+r[1]+1,M=d+g-u,C=p+c-f,T=[["M",0,0]];u?T=[["M",0,v],["L",d-1,v],["L",d-1,w],["L",0,w],["Z"],["M",M,v],["L",a,v],["L",a,w],["L",M,w],["Z"]]:f&&(T=[["M",S,0],["L",S,p-1],["L",k,p-1],["L",k,0],["Z"],["M",S,C],["L",S,n],["L",k,n],["L",k,C],["Z"]]),e.redrawTrigger!=="adjustHeight"&&this.mask.attr({d:T})}moveFixedElements(){let e,{container:i,inverted:s,scrollablePixelsX:o,scrollablePixelsY:r}=this.chart,a=this.fixedRenderer,n=h.fixedSelectors;if(o&&!s?e=".highcharts-yaxis":o&&s||r&&!s?e=".highcharts-xaxis":r&&s&&(e=".highcharts-yaxis"),e&&!(this.chart.hasParallelCoordinates&&e===".highcharts-yaxis"))for(let l of[`${e}:not(.highcharts-radial-axis)`,`${e}-labels:not(.highcharts-radial-axis-labels)`])Ia(n,l);else for(let l of[".highcharts-xaxis",".highcharts-yaxis"])for(let c of[`${l}:not(.highcharts-radial-axis)`,`${l}-labels:not(.highcharts-radial-axis-labels)`])Ec(n,c);for(let l of n)[].forEach.call(i.querySelectorAll(l),c=>{(c.namespaceURI===a.SVG_NS?a.box:a.box.parentNode).appendChild(c),c.style.pointerEvents="auto"})}}return h.fixedSelectors=[".highcharts-breadcrumbs-group",".highcharts-contextbutton",".highcharts-caption",".highcharts-credits",".highcharts-drillup-button",".highcharts-legend",".highcharts-legend-checkbox",".highcharts-navigator-series",".highcharts-navigator-xaxis",".highcharts-navigator-yaxis",".highcharts-navigator",".highcharts-range-selector-group",".highcharts-reset-zoom",".highcharts-scrollbar",".highcharts-subtitle",".highcharts-title"],h})(),{format:Dc}=wt,{series:Bc}=st,{destroyObjectProperties:Nc,fireEvent:Na,getAlignFactor:vo,isNumber:ko,pick:Ze}=N,za=class{constructor(h,t,e,i,s){let o=h.chart.inverted,r=h.reversed;this.axis=h;let a=this.isNegative=!!e!=!!r;this.options=t=t||{},this.x=i,this.total=null,this.cumulative=null,this.points={},this.hasValidPoints=!1,this.stack=s,this.leftCliff=0,this.rightCliff=0,this.alignOptions={align:t.align||(o?a?"left":"right":"center"),verticalAlign:t.verticalAlign||(o?"middle":a?"bottom":"top"),y:t.y,x:t.x},this.textAlign=t.textAlign||(o?a?"right":"left":"center")}destroy(){Nc(this,this.axis)}render(h){let t=this.axis.chart,e=this.options,i=e.format,s=i?Dc(i,this,t):e.formatter.call(this);if(this.label)this.label.attr({text:s,visibility:"hidden"});else{this.label=t.renderer.label(s,null,void 0,e.shape,void 0,void 0,e.useHTML,!1,"stack-labels");let o={r:e.borderRadius||0,text:s,padding:Ze(e.padding,5),visibility:"hidden"};t.styledMode||(o.fill=e.backgroundColor,o.stroke=e.borderColor,o["stroke-width"]=e.borderWidth,this.label.css(e.style||{})),this.label.attr(o),this.label.added||this.label.add(h)}this.label.labelrank=t.plotSizeY,Na(this,"afterRender")}setOffset(h,t,e,i,s,o){let{alignOptions:r,axis:a,label:n,options:l,textAlign:c}=this,d=a.chart,p=this.getStackBox({xOffset:h,width:t,boxBottom:e,boxTop:i,defaultX:s,xAxis:o}),{verticalAlign:g}=r;if(n&&p){let u=n.getBBox(void 0,0),f=n.padding,x=Ze(l.overflow,"justify")==="justify",m;r.x=l.x||0,r.y=l.y||0;let{x:y,y:b}=this.adjustStackPosition({labelBox:u,verticalAlign:g,textAlign:c});p.x-=y,p.y-=b,n.align(r,!1,p),(m=d.isInsidePlot(n.alignAttr.x+r.x+y,n.alignAttr.y+r.y+b))||(x=!1),x&&Bc.prototype.justifyDataLabel.call(a,n,r,n.alignAttr,u,p),n.attr({x:n.alignAttr.x,y:n.alignAttr.y,rotation:l.rotation,rotationOriginX:u.width*vo(l.textAlign||"center"),rotationOriginY:u.height/2}),Ze(!x&&l.crop,!0)&&(m=ko(n.x)&&ko(n.y)&&d.isInsidePlot(n.x-f+(n.width||0),n.y)&&d.isInsidePlot(n.x+f,n.y)),n[m?"show":"hide"]()}Na(this,"afterSetOffset",{xOffset:h,width:t})}adjustStackPosition({labelBox:h,verticalAlign:t,textAlign:e}){return{x:h.width/2+h.width/2*(2*vo(e)-1),y:h.height/2*2*(1-vo(t))}}getStackBox(h){let t=this.axis,e=t.chart,{boxTop:i,defaultX:s,xOffset:o,width:r,boxBottom:a}=h,n=t.stacking.usePercentage?100:Ze(i,this.total,0),l=t.toPixels(n),c=h.xAxis||e.xAxis[0],d=Ze(s,c.translate(this.x))+o,p=Math.abs(l-t.toPixels(a||ko(t.min)&&t.logarithmic&&t.logarithmic.lin2log(t.min)||0)),g=e.inverted,u=this.isNegative;return g?{x:(u?l:l-p)-e.plotLeft,y:c.height-d-r+c.top-e.plotTop,width:p,height:r}:{x:d+c.transB-e.plotLeft,y:(u?l-p:l)-e.plotTop,width:r,height:p}}},{getDeferredAnimation:zc}=dt,{series:{prototype:Rc}}=st,{addEvent:Ra,correctFloat:qe,defined:Wa,destroyObjectProperties:Wc,fireEvent:Hc,isNumber:wo,objectEach:de,pick:Mo}=N;function Xc(){let h=this.inverted;this.axes.forEach(t=>{t.stacking?.stacks&&t.hasVisibleSeries&&(t.stacking.oldStacks=t.stacking.stacks)}),this.series.forEach(t=>{let e=t.xAxis?.options||{};t.options.stacking&&t.reserveSpace()&&(t.stackKey=[t.type,Mo(t.options.stack,""),h?e.top:e.left,h?e.height:e.width].join(","))})}function Fc(){let h=this.stacking;if(h){let t=h.stacks;de(t,(e,i)=>{Wc(e),delete t[i]}),h.stackTotalGroup?.destroy()}}function Gc(){this.stacking||(this.stacking=new Zc(this))}function Yc(h,t,e,i){return!Wa(h)||h.x!==t||i&&h.stackKey!==i?h={x:t,index:0,key:i,stackKey:i}:h.index++,h.key=[e,t,h.index].join(","),h}function jc(){let h,t=this,e=t.yAxis,i=t.stackKey||"",s=e.stacking.stacks,o=t.getColumn("x",!0),r=t.options.stacking,a=t[r+"Stacker"];a&&[i,"-"+i].forEach(n=>{let l=o.length,c,d,p;for(;l--;)c=o[l],h=t.getStackIndicator(h,c,t.index,n),d=s[n]?.[c],(p=d?.points[h.key||""])&&a.call(t,p,d,l)})}function Uc(h,t,e){let i=t.total?100/t.total:0;h[0]=qe(h[0]*i),h[1]=qe(h[1]*i),this.stackedYData[e]=h[1]}function Vc(h){(this.is("column")||this.is("columnrange"))&&(this.options.centerInCategory&&this.chart.series.length>1?Rc.setStackedPoints.call(this,h,"group"):h.stacking.resetStacks())}function $c(h,t){let e,i,s,o,r,a,n,l=t||this.options.stacking;if(!l||!this.reserveSpace()||({group:"xAxis"}[l]||"yAxis")!==h.coll)return;let c=this.getColumn("x",!0),d=this.getColumn(this.pointValKey||"y",!0),p=[],g=d.length,u=this.options,f=u.threshold||0,x=u.startFromThreshold?f:0,m=u.stack,y=t?`${this.type},${l}`:this.stackKey||"",b="-"+y,v=this.negStacks,S=h.stacking,w=S.stacks,k=S.oldStacks;for(S.stacksTouched+=1,n=0;n<g;n++){let M=c[n]||0,C=d[n],T=wo(C)&&C||0;a=(e=this.getStackIndicator(e,M,this.index)).key||"",w[r=(i=v&&T<(x?0:f))?b:y]||(w[r]={}),w[r][M]||(k[r]?.[M]?(w[r][M]=k[r][M],w[r][M].total=null):w[r][M]=new za(h,h.options.stackLabels,!!i,M,m)),s=w[r][M],C!==null?(s.points[a]=s.points[this.index]=[Mo(s.cumulative,x)],Wa(s.cumulative)||(s.base=a),s.touched=S.stacksTouched,e.index>0&&this.singleStacks===!1&&(s.points[a][0]=s.points[this.index+","+M+",0"][0])):(delete s.points[a],delete s.points[this.index]);let A=s.total||0;l==="percent"?(o=i?y:b,A=v&&w[o]?.[M]?(o=w[o][M]).total=Math.max(o.total||0,A)+Math.abs(T):qe(A+Math.abs(T))):l==="group"?wo(C)&&A++:A=qe(A+T),l==="group"?s.cumulative=(A||1)-1:s.cumulative=qe(Mo(s.cumulative,x)+T),s.total=A,C!==null&&(s.points[a].push(s.cumulative),p[n]=s.cumulative,s.hasValidPoints=!0)}l==="percent"&&(S.usePercentage=!0),l!=="group"&&(this.stackedYData=p),S.oldStacks={}}class Zc{constructor(t){this.oldStacks={},this.stacks={},this.stacksTouched=0,this.axis=t}buildStacks(){let t,e,i=this.axis,s=i.series,o=i.coll==="xAxis",r=i.options.reversedStacks,a=s.length;for(this.resetStacks(),this.usePercentage=!1,e=a;e--;)t=s[r?e:a-e-1],o&&t.setGroupedPoints(i),t.setStackedPoints(i);if(!o)for(e=0;e<a;e++)s[e].modifyStacks();Hc(i,"afterBuildStacks")}cleanStacks(){this.oldStacks&&(this.stacks=this.oldStacks,de(this.stacks,t=>{de(t,e=>{e.cumulative=e.total})}))}resetStacks(){de(this.stacks,t=>{de(t,(e,i)=>{wo(e.touched)&&e.touched<this.stacksTouched?(e.destroy(),delete t[i]):(e.total=null,e.cumulative=null)})})}renderStackTotals(){let t=this.axis,e=t.chart,i=e.renderer,s=this.stacks,o=zc(e,t.options.stackLabels?.animation||!1),r=this.stackTotalGroup=this.stackTotalGroup||i.g("stack-labels").attr({zIndex:6,opacity:0}).add();r.translate(e.plotLeft,e.plotTop),de(s,a=>{de(a,n=>{n.render(r)})}),r.animate({opacity:1},o)}}(ds||(ds={})).compose=function(h,t,e){let i=t.prototype,s=e.prototype;i.getStacks||(Ra(h,"init",Gc),Ra(h,"destroy",Fc),i.getStacks=Xc,s.getStackIndicator=Yc,s.modifyStacks=jc,s.percentStacker=Uc,s.setGroupedPoints=Vc,s.setStackedPoints=$c)};let qc=ds,{defined:Kc,merge:Ha,isObject:_c}=N;class Xa extends bt{drawGraph(){let t=this.options,e=(this.gappedPath||this.getGraphPath).call(this),i=this.chart.styledMode;[this,...this.zones].forEach((s,o)=>{let r,a=s.graph,n=a?"animate":"attr",l=s.dashStyle||t.dashStyle;a?(a.endX=this.preventGraphAnimation?null:e.xMap,a.animate({d:e})):e.length&&(s.graph=a=this.chart.renderer.path(e).addClass("highcharts-graph"+(o?` highcharts-zone-graph-${o-1} `:" ")+(o&&s.className||"")).attr({zIndex:1}).add(this.group)),a&&!i&&(r={stroke:!o&&t.lineColor||s.color||this.color||"#cccccc","stroke-width":t.lineWidth||0,fill:this.fillGraph&&this.color||"none"},l?r.dashstyle=l:t.linecap!=="square"&&(r["stroke-linecap"]=r["stroke-linejoin"]="round"),a[n](r).shadow(t.shadow&&Ha({filterUnits:"userSpaceOnUse"},_c(t.shadow)?t.shadow:{}))),a&&(a.startX=e.xMap,a.isArea=e.isArea)})}getGraphPath(t,e,i){let s=this,o=s.options,r=[],a=[],n,l=o.step,c=(t=t||s.points).reversed;return c&&t.reverse(),(l={right:1,center:2}[l]||l&&3)&&c&&(l=4-l),(t=this.getValidPoints(t,!1,o.nullInteraction||!(o.connectNulls&&!e&&!i))).forEach(function(d,p){let g,u=d.plotX,f=d.plotY,x=t[p-1],m=d.isNull||typeof f!="number";(d.leftCliff||x?.rightCliff)&&!i&&(n=!0),m&&!Kc(e)&&p>0?n=!o.connectNulls:m&&!e?n=!0:(p===0||n?g=[["M",d.plotX,d.plotY]]:s.getPointSpline?g=[s.getPointSpline(t,d,p)]:l?(g=l===1?[["L",x.plotX,f]]:l===2?[["L",(x.plotX+u)/2,x.plotY],["L",(x.plotX+u)/2,f]]:[["L",u,x.plotY]]).push(["L",u,f]):g=[["L",u,f]],a.push(d.x),l&&(a.push(d.x),l===2&&a.push(d.x)),r.push.apply(r,g),n=!1)}),r.xMap=a,s.graphPath=r,r}}Xa.defaultOptions=Ha(bt.defaultOptions,{legendSymbol:"lineMarker"}),st.registerSeriesType("line",Xa);let{seriesTypes:{line:So}}=st,{extend:Jc,merge:Qc,objectEach:tp,pick:Yi}=N;class Co extends So{drawGraph(){this.areaPath=[],super.drawGraph.apply(this);let{areaPath:t,options:e}=this;[this,...this.zones].forEach((i,s)=>{let o={},r=i.fillColor||e.fillColor,a=i.area,n=a?"animate":"attr";a?(a.endX=this.preventGraphAnimation?null:t.xMap,a.animate({d:t})):(o.zIndex=0,(a=i.area=this.chart.renderer.path(t).addClass("highcharts-area"+(s?` highcharts-zone-area-${s-1} `:" ")+(s&&i.className||"")).add(this.group)).isArea=!0),this.chart.styledMode||(o.fill=r||i.color||this.color,o["fill-opacity"]=r?1:e.fillOpacity??.75,a.css({pointerEvents:this.stickyTracking?"none":"auto"})),a[n](o),a.startX=t.xMap,a.shiftUnit=e.step?2:1})}getGraphPath(t){let e,i,s,o=So.prototype.getGraphPath,r=this.options,a=r.stacking,n=this.yAxis,l=[],c=[],d=this.index,p=n.stacking.stacks[this.stackKey],g=r.threshold,u=Math.round(n.getThreshold(r.threshold)),f=Yi(r.connectNulls,a==="percent"),x=function(w,k,M){let C=t[w],T=a&&p[C.x].points[d],A=C[M+"Null"]||0,O=C[M+"Cliff"]||0,L,I,D=!0;O||A?(L=(A?T[0]:T[1])+O,I=T[0]+O,D=!!A):!a&&t[k]&&t[k].isNull&&(L=I=g),L!==void 0&&(c.push({plotX:e,plotY:L===null?u:n.getThreshold(L),isNull:D,isCliff:!0}),l.push({plotX:e,plotY:I===null?u:n.getThreshold(I),doCurve:!1}))};t=t||this.points,a&&(t=this.getStackPoints(t));for(let w=0,k=t.length;w<k;++w)a||(t[w].leftCliff=t[w].rightCliff=t[w].leftNull=t[w].rightNull=void 0),i=t[w].isNull,e=Yi(t[w].rectPlotX,t[w].plotX),s=a?Yi(t[w].yBottom,u):u,i&&!f||(f||x(w,w-1,"left"),i&&!a&&f||(c.push(t[w]),l.push({x:w,plotX:e,plotY:s})),f||x(w,w+1,"right"));let m=o.call(this,c,!0,!0);l.reversed=!0;let y=o.call(this,l,!0,!0),b=y[0];b&&b[0]==="M"&&(y[0]=["L",b[1],b[2]]);let v=m.concat(y);v.length&&v.push(["Z"]);let S=o.call(this,c,!1,f);return this.chart.series.length>1&&a&&c.some(w=>w.isCliff)&&(v.hasStackedCliffs=S.hasStackedCliffs=!0),v.xMap=m.xMap,this.areaPath=v,S}getStackPoints(t){let e=this,i=[],s=[],o=this.xAxis,r=this.yAxis,a=r.stacking.stacks[this.stackKey],n={},l=r.series,c=l.length,d=r.options.reversedStacks?1:-1,p=l.indexOf(e);if(t=t||this.points,this.options.stacking){for(let u=0;u<t.length;u++)t[u].leftNull=t[u].rightNull=void 0,n[t[u].x]=t[u];tp(a,function(u,f){u.total!==null&&s.push(f)}),s.sort(function(u,f){return u-f});let g=l.map(u=>u.visible);s.forEach(function(u,f){let x=0,m,y;if(n[u]&&!n[u].isNull)i.push(n[u]),[-1,1].forEach(function(b){let v=b===1?"rightNull":"leftNull",S=a[s[f+b]],w=0;if(S){let k=p;for(;k>=0&&k<c;){let M=l[k].index;!(m=S.points[M])&&(M===e.index?n[u][v]=!0:g[k]&&(y=a[u].points[M])&&(w-=y[1]-y[0])),k+=d}}n[u][b===1?"rightCliff":"leftCliff"]=w});else{let b=p;for(;b>=0&&b<c;){let v=l[b].index;if(m=a[u].points[v]){x=m[1];break}b+=d}x=Yi(x,0),x=r.translate(x,0,1,0,1),i.push({isNull:!0,plotX:o.translate(u,0,0,0,1),x:u,plotY:x,yBottom:x})}})}return i}}Co.defaultOptions=Qc(So.defaultOptions,{threshold:0,legendSymbol:"areaMarker"}),Jc(Co.prototype,{singleStacks:!1}),st.registerSeriesType("area",Co);let{line:Fa}=st.seriesTypes,{merge:ep,pick:ji}=N;class To extends Fa{getPointSpline(t,e,i){let s,o,r,a,n=e.plotX||0,l=e.plotY||0,c=t[i-1],d=t[i+1];function p(u){return u&&!u.isNull&&u.doCurve!==!1&&!e.isCliff}if(p(c)&&p(d)){let u=c.plotX||0,f=c.plotY||0,x=d.plotX||0,m=d.plotY||0,y=0;s=(1.5*n+u)/2.5,o=(1.5*l+f)/2.5,r=(1.5*n+x)/2.5,a=(1.5*l+m)/2.5,r!==s&&(y=(a-o)*(r-n)/(r-s)+l-a),o+=y,a+=y,o>f&&o>l?(o=Math.max(f,l),a=2*l-o):o<f&&o<l&&(o=Math.min(f,l),a=2*l-o),a>m&&a>l?(a=Math.max(m,l),o=2*l-a):a<m&&a<l&&(a=Math.min(m,l),o=2*l-a),e.rightContX=r,e.rightContY=a,e.controlPoints={low:[s,o],high:[r,a]}}let g=["C",ji(c.rightContX,c.plotX,0),ji(c.rightContY,c.plotY,0),ji(s,n,0),ji(o,l,0),n,l];return c.rightContX=c.rightContY=void 0,g}}To.defaultOptions=ep(Fa.defaultOptions),st.registerSeriesType("spline",To);let Ga=To,{area:ip,area:{prototype:Ao}}=st.seriesTypes,{extend:sp,merge:op}=N;class Po extends Ga{}Po.defaultOptions=op(Ga.defaultOptions,ip.defaultOptions),sp(Po.prototype,{getGraphPath:Ao.getGraphPath,getStackPoints:Ao.getStackPoints,drawGraph:Ao.drawGraph}),st.registerSeriesType("areaspline",Po);let{animObject:rp}=dt,{parse:ap}=tt,{noop:np}=P,{clamp:Ui,crisp:Vi,defined:Ya,extend:ja,fireEvent:Ua,isArray:Va,isNumber:$i,merge:Oo,pick:Ke,objectEach:hp}=N;class Zi extends bt{animate(t){let e,i,s=this,o=this.yAxis,r=o.pos,a=o.reversed,n=s.options,{clipOffset:l,inverted:c}=this.chart,d={},p=c?"translateX":"translateY";t&&l?(d.scaleY=.001,i=Ui(o.toPixels(n.threshold||0),r,r+o.len),c?d.translateX=(i+=a?-Math.floor(l[0]):Math.ceil(l[2]))-o.len:d.translateY=i+=a?Math.ceil(l[0]):-Math.floor(l[2]),s.clipBox&&s.setClip(),s.group.attr(d)):(e=Number(s.group.attr(p)),s.group.animate({scaleY:1},ja(rp(s.options.animation),{step:function(g,u){s.group&&(d[p]=e+u.pos*(r-e),s.group.attr(d))}})))}init(t,e){super.init.apply(this,arguments);let i=this;(t=i.chart).hasRendered&&t.series.forEach(function(s){s.type===i.type&&(s.isDirty=!0)})}getColumnMetrics(){let t=this,e=t.options,i=t.xAxis,s=t.yAxis,o=i.options.reversedStacks,r=i.reversed&&!o||!i.reversed&&o,a={},n,l=0;e.grouping===!1?l=1:t.chart.series.forEach(function(f){let x,m=f.yAxis,y=f.options;f.type===t.type&&f.reserveSpace()&&s.len===m.len&&s.pos===m.pos&&(y.stacking&&y.stacking!=="group"?(a[n=f.stackKey]===void 0&&(a[n]=l++),x=a[n]):y.grouping!==!1&&(x=l++),f.columnIndex=x)});let c=Math.min(Math.abs(i.transA)*(!i.brokenAxis?.hasBreaks&&i.ordinal?.slope||e.pointRange||i.closestPointRange||i.tickInterval||1),i.len),d=c*e.groupPadding,p=(c-2*d)/(l||1),g=Math.min(e.maxPointWidth||i.len,Ke(e.pointWidth,p*(1-2*e.pointPadding))),u=(t.columnIndex||0)+ +!!r;return t.columnMetrics={width:g,offset:(p-g)/2+(d+u*p-c/2)*(r?-1:1),paddedWidth:p,columnCount:l},t.columnMetrics}crispCol(t,e,i,s){let o=this.borderWidth,r=this.chart.inverted;return s=Vi(e+s,o,r)-(e=Vi(e,o,r)),this.options.crisp&&(i=Vi(t+i,o)-(t=Vi(t,o))),{x:t,y:e,width:i,height:s}}adjustForMissingColumns(t,e,i,s){if(!i.isNull&&s.columnCount>1){let o=this.xAxis.series.filter(l=>l.visible).map(l=>l.index),r=0,a=0;hp(this.xAxis.stacking?.stacks,l=>{let c=typeof i.x=="number"?l[i.x.toString()]?.points:void 0,d=c?.[this.index],p={};if(c&&Va(d)){let g=this.index,u=Object.keys(c).filter(f=>!f.match(",")&&c[f]&&c[f].length>1).map(parseFloat).filter(f=>o.indexOf(f)!==-1).filter(f=>{let x=this.chart.series[f].options,m=x.stacking&&x.stack;if(Ya(m)){if($i(p[m]))return g===f&&(g=p[m]),!1;p[m]=f}return!0}).sort((f,x)=>x-f);r=u.indexOf(g),a=u.length}}),r=this.xAxis.reversed?a-1-r:r;let n=(a-1)*s.paddedWidth+e;t=(i.plotX||0)+n/2-e-r*s.paddedWidth}return t}translate(){let t=this,e=t.chart,i=t.options,s=t.dense=t.closestPointRange*t.xAxis.transA<2,o=t.borderWidth=Ke(i.borderWidth,+!s),r=t.xAxis,a=t.yAxis,n=i.threshold,l=Ke(i.minPointLength,5),c=t.getColumnMetrics(),d=c.width,p=t.pointXOffset=c.offset,g=t.dataMin,u=t.dataMax,f=t.translatedThreshold=a.getThreshold(n),x=t.barW=Math.max(d,1+2*o);i.pointPadding&&i.crisp&&(x=Math.ceil(x)),bt.prototype.translate.apply(t),t.points.forEach(function(m){let y=Ke(m.yBottom,f),b=999+Math.abs(y),v=m.plotX||0,S=Ui(m.plotY,-b,a.len+b),w,k=Math.min(S,y),M=Math.max(S,y)-k,C=d,T=v+p,A=x;l&&Math.abs(M)<l&&(M=l,w=!a.reversed&&!m.negative||a.reversed&&m.negative,$i(n)&&$i(u)&&m.y===n&&u<=n&&(a.min||0)<n&&(g!==u||(a.max||0)<=n)&&(w=!w,m.negative=!m.negative),k=Math.abs(k-f)>l?y-l:f-(w?l:0)),Ya(m.options.pointWidth)&&(T-=Math.round(((C=A=Math.ceil(m.options.pointWidth))-d)/2)),i.centerInCategory&&(T=t.adjustForMissingColumns(T,C,m,c)),m.barX=T,m.pointWidth=C,m.tooltipPos=e.inverted?[Ui(a.len+a.pos-e.plotLeft-S,a.pos-e.plotLeft,a.len+a.pos-e.plotLeft),r.len+r.pos-e.plotTop-T-A/2,M]:[r.left-e.plotLeft+T+A/2,Ui(S+a.pos-e.plotTop,a.pos-e.plotTop,a.len+a.pos-e.plotTop),M],m.shapeType=t.pointClass.prototype.shapeType||"roundedRect",m.shapeArgs=t.crispCol(T,k,A,m.isNull?0:M)}),Ua(this,"afterColumnTranslate")}drawGraph(){this.group[this.dense?"addClass":"removeClass"]("highcharts-dense-data")}pointAttribs(t,e){let i=this.options,s=this.pointAttrToOptions||{},o=s.stroke||"borderColor",r=s["stroke-width"]||"borderWidth",a,n,l,c=t&&t.color||this.color,d=t&&t[o]||i[o]||c,p=t&&t.options.dashStyle||i.dashStyle,g=t&&t[r]||i[r]||this[r]||0,u=t?.isNull&&i.nullInteraction?0:t?.opacity??i.opacity??1;t&&this.zones.length&&(n=t.getZone(),c=t.options.color||n&&(n.color||t.nonZonedColor)||this.color,n&&(d=n.borderColor||d,p=n.dashStyle||p,g=n.borderWidth||g)),e&&t&&(l=(a=Oo(i.states[e],t.options.states&&t.options.states[e]||{})).brightness,c=a.color||l!==void 0&&ap(c).brighten(a.brightness).get()||c,d=a[o]||d,g=a[r]||g,p=a.dashStyle||p,u=Ke(a.opacity,u));let f={fill:c,stroke:d,"stroke-width":g,opacity:u};return p&&(f.dashstyle=p),f}drawPoints(t=this.points){let e,i=this,s=this.chart,o=i.options,r=o.nullInteraction,a=s.renderer,n=o.animationLimit||250;t.forEach(function(l){let c=l.plotY,d=l.graphic,p=!!d,g=d&&s.pointCount<n?"animate":"attr";$i(c)&&(l.y!==null||r)?(e=l.shapeArgs,d&&l.hasNewShapeType()&&(d=d.destroy()),i.enabledDataSorting&&(l.startXPos=i.xAxis.reversed?-(e&&e.width||0):i.xAxis.width),!d&&(l.graphic=d=a[l.shapeType](e).add(l.group||i.group),d&&i.enabledDataSorting&&s.hasRendered&&s.pointCount<n&&(d.attr({x:l.startXPos}),p=!0,g="animate")),d&&p&&d[g](Oo(e)),s.styledMode||d[g](i.pointAttribs(l,l.selected&&"select")).shadow(l.allowShadow!==!1&&o.shadow),d&&(d.addClass(l.getClassName(),!0),d.attr({visibility:l.visible?"inherit":"hidden"}))):d&&(l.graphic=d.destroy())})}drawTracker(t=this.points){let e,i=this,s=i.chart,o=s.pointer,r=function(a){o?.normalize(a);let n=o?.getPointFromEvent(a);o&&n&&i.options.enableMouseTracking&&(s.isInsidePlot(a.chartX-s.plotLeft,a.chartY-s.plotTop,{visiblePlotOnly:!0})||o?.inClass(a.target,"highcharts-data-label"))&&(o.isDirectTouch=!0,n.onMouseOver(a))};t.forEach(function(a){e=Va(a.dataLabels)?a.dataLabels:a.dataLabel?[a.dataLabel]:[],a.graphic&&(a.graphic.element.point=a),e.forEach(function(n){(n.div||n.element).point=a})}),i._hasTracking||(i.trackerGroups.forEach(function(a){i[a]&&(i[a].addClass("highcharts-tracker").on("mouseover",r).on("mouseout",function(n){o?.onTrackerMouseOut(n)}).on("touchstart",r),!s.styledMode&&i.options.cursor&&i[a].css({cursor:i.options.cursor}))}),i._hasTracking=!0),Ua(this,"afterDrawTracker")}remove(){let t=this,e=t.chart;e.hasRendered&&e.series.forEach(function(i){i.type===t.type&&(i.isDirty=!0)}),bt.prototype.remove.apply(t,arguments)}}Zi.defaultOptions=Oo(bt.defaultOptions,{borderRadius:3,centerInCategory:!1,groupPadding:.2,marker:null,pointPadding:.1,minPointLength:0,cropThreshold:50,pointRange:null,states:{hover:{halo:!1,brightness:.1},select:{color:"#cccccc",borderColor:"#000000"}},dataLabels:{align:void 0,verticalAlign:void 0,y:void 0},startFromThreshold:!0,stickyTracking:!1,tooltip:{distance:6},threshold:0,borderColor:"#ffffff"}),ja(Zi.prototype,{directTouch:!0,getSymbol:np,negStacks:!0,trackerGroups:["group","dataLabelsGroup"]}),st.registerSeriesType("column",Zi);let qi=Zi,{getDeferredAnimation:lp}=dt,{format:dp}=wt,{defined:ce,extend:$a,fireEvent:Lo,getAlignFactor:Za,isArray:_t,isString:_e,merge:Je,objectEach:cp,pick:Qe,pInt:pp,splat:qa}=N;(function(h){function t(){return n(this).some(c=>c?.enabled)}function e(c,d,p,g,u){let{chart:f,enabledDataSorting:x}=this,m=this.isCartesian&&f.inverted,y=c.plotX,b=c.plotY,v=p.rotation||0,S=ce(y)&&ce(b)&&f.isInsidePlot(y,Math.round(b),{inverted:m,paneCoordinates:!0,series:this}),w=v===0&&Qe(p.overflow,x?"none":"justify")==="justify",k=this.visible&&c.visible!==!1&&ce(y)&&(c.series.forceDL||x&&!w||S||Qe(p.inside,!!this.options.stacking)&&g&&f.isInsidePlot(y,m?g.x+1:g.y+g.height-1,{inverted:m,paneCoordinates:!0,series:this})),M=c.pos();if(k&&M){var C;let T=d.getBBox(),A=d.getBBox(void 0,0);if(g=$a({x:M[0],y:Math.round(M[1]),width:0,height:0},g||{}),p.alignTo==="plotEdges"&&this.isCartesian&&(g[m?"x":"y"]=0,g[m?"width":"height"]=this.yAxis?.len||0),$a(p,{width:T.width,height:T.height}),C=g,x&&this.xAxis&&!w&&this.setDataLabelStartPos(c,d,u,S,C),d.align(Je(p,{width:A.width,height:A.height}),!1,g,!1),d.alignAttr.x+=Za(p.align)*(A.width-T.width),d.alignAttr.y+=Za(p.verticalAlign)*(A.height-T.height),d[d.placed?"animate":"attr"]({"text-align":d.alignAttr["text-align"]||"center",x:d.alignAttr.x+(T.width-A.width)/2,y:d.alignAttr.y+(T.height-A.height)/2,rotationOriginX:(d.width||0)/2,rotationOriginY:(d.height||0)/2}),w&&g.height>=0)this.justifyDataLabel(d,p,d.alignAttr,T,g,u);else if(Qe(p.crop,!0)){let{x:O,y:L}=d.alignAttr;k=f.isInsidePlot(O,L,{paneCoordinates:!0,series:this})&&f.isInsidePlot(O+T.width-1,L+T.height-1,{paneCoordinates:!0,series:this})}p.shape&&!v&&d[u?"attr":"animate"]({anchorX:M[0],anchorY:M[1]})}u&&x&&(d.placed=!1),k||x&&!w?(d.show(),d.placed=!0):(d.hide(),d.placed=!1)}function i(){return this.plotGroup("dataLabelsGroup","data-labels",this.hasRendered?"inherit":"hidden",this.options.dataLabels.zIndex||6)}function s(c){let d=this.hasRendered||0,p=this.initDataLabelsGroup().attr({opacity:+d});return!d&&p&&(this.visible&&p.show(),this.options.animation?p.animate({opacity:1},c):p.attr({opacity:1})),p}function o(c){let d;c=c||this.points;let p=this,g=p.chart,u=p.options,f=g.renderer,{backgroundColor:x,plotBackgroundColor:m}=g.options.chart,y=f.getContrast(_e(m)&&m||_e(x)&&x||"#000000"),b=n(p),{animation:v,defer:S}=b[0],w=S?lp(g,v,p):{defer:0,duration:0};Lo(this,"drawDataLabels"),p.hasDataLabels?.()&&(d=this.initDataLabels(w),c.forEach(k=>{let M=k.dataLabels||[],C=k.color||p.color;qa(a(b,k.dlOptions||k.options?.dataLabels)).forEach((A,O)=>{let L=A.enabled&&(k.visible||k.dataLabelOnHidden)&&(!k.isNull||k.dataLabelOnNull)&&function($,q){let U=q.filter;if(U){let J=U.operator,gt=$[U.property],xt=U.value;return J===">"&>>xt||J==="<"&><xt||J===">="&>>=xt||J==="<="&><=xt||J==="=="&>==xt||J==="==="&>===xt||J==="!="&>!=xt||J==="!=="&>!==xt||!1}return!0}(k,A),{backgroundColor:I,borderColor:D,distance:E,style:B={}}=A,K,Y,pt,R={},W=M[O],j=!W,X;L&&(Y=ce(K=Qe(A[k.formatPrefix+"Format"],A.format))?dp(K,k,g):(A[k.formatPrefix+"Formatter"]||A.formatter).call(k,A),pt=A.rotation,!g.styledMode&&(B.color=Qe(A.color,B.color,_e(p.color)?p.color:void 0,"#000000"),B.color==="contrast"?(I!=="none"&&(X=I),k.contrastColor=f.getContrast(X!=="auto"&&_e(X)&&X||(_e(C)?C:"")),B.color=X||!ce(E)&&A.inside||0>pp(E||0)||u.stacking?k.contrastColor:y):delete k.contrastColor,u.cursor&&(B.cursor=u.cursor)),R={r:A.borderRadius||0,rotation:pt,padding:A.padding,zIndex:1},g.styledMode||(R.fill=I==="auto"?k.color:I,R.stroke=D==="auto"?k.color:D,R["stroke-width"]=A.borderWidth),cp(R,($,q)=>{$===void 0&&delete R[q]})),!W||L&&ce(Y)&&!!(W.div||W.text?.foreignObject)==!!A.useHTML&&(W.rotation&&A.rotation||W.rotation===A.rotation)||(W=void 0,j=!0),L&&ce(Y)&&(W?R.text=Y:(W=f.label(Y,0,0,A.shape,void 0,void 0,A.useHTML,void 0,"data-label")).addClass(" highcharts-data-label-color-"+k.colorIndex+" "+(A.className||"")+(A.useHTML?" highcharts-tracker":"")),W&&(W.options=A,W.attr(R),g.styledMode?B.width&&W.css({width:B.width,textOverflow:B.textOverflow,whiteSpace:B.whiteSpace}):W.css(B).shadow(A.shadow),Lo(W,"beforeAddingDataLabel",{labelOptions:A,point:k}),W.added||W.add(d),p.alignDataLabel(k,W,A,void 0,j),W.isActive=!0,M[O]&&M[O]!==W&&M[O].destroy(),M[O]=W))});let T=M.length;for(;T--;)M[T]?.isActive?M[T].isActive=!1:(M[T]?.destroy(),M.splice(T,1));k.dataLabel=M[0],k.dataLabels=M})),Lo(this,"afterDrawDataLabels")}function r(c,d,p,g,u,f){let x=this.chart,m=d.align,y=d.verticalAlign,b=c.box?0:c.padding||0,v=x.inverted?this.yAxis:this.xAxis,S=v?v.left-x.plotLeft:0,w=x.inverted?this.xAxis:this.yAxis,k=w?w.top-x.plotTop:0,{x:M=0,y:C=0}=d,T,A;return(T=(p.x||0)+b+S)<0&&(m==="right"&&M>=0?(d.align="left",d.inside=!0):M-=T,A=!0),(T=(p.x||0)+g.width-b+S)>x.plotWidth&&(m==="left"&&M<=0?(d.align="right",d.inside=!0):M+=x.plotWidth-T,A=!0),(T=p.y+b+k)<0&&(y==="bottom"&&C>=0?(d.verticalAlign="top",d.inside=!0):C-=T,A=!0),(T=(p.y||0)+g.height-b+k)>x.plotHeight&&(y==="top"&&C<=0?(d.verticalAlign="bottom",d.inside=!0):C+=x.plotHeight-T,A=!0),A&&(d.x=M,d.y=C,c.placed=!f,c.align(d,void 0,u)),A}function a(c,d){let p=[],g;if(_t(c)&&!_t(d))p=c.map(function(u){return Je(u,d)});else if(_t(d)&&!_t(c))p=d.map(function(u){return Je(c,u)});else if(_t(c)||_t(d)){if(_t(c)&&_t(d))for(g=Math.max(c.length,d.length);g--;)p[g]=Je(c[g],d[g])}else p=Je(c,d);return p}function n(c){let d=c.chart.options.plotOptions;return qa(a(a(d?.series?.dataLabels,d?.[c.type]?.dataLabels),c.options.dataLabels))}function l(c,d,p,g,u){let f=this.chart,x=f.inverted,m=this.xAxis,y=m.reversed,b=((x?d.height:d.width)||0)/2,v=c.pointWidth,S=v?v/2:0;d.startXPos=x?u.x:y?-b-S:m.width-b+S,d.startYPos=x?y?this.yAxis.height-b+S:-b-S:u.y,g?d.visibility==="hidden"&&(d.show(),d.attr({opacity:0}).animate({opacity:1})):d.attr({opacity:1}).animate({opacity:0},void 0,d.hide),f.hasRendered&&(p&&d.attr({x:d.startXPos,y:d.startYPos}),d.placed=!0)}h.compose=function(c){let d=c.prototype;d.initDataLabels||(d.initDataLabels=s,d.initDataLabelsGroup=i,d.alignDataLabel=e,d.drawDataLabels=o,d.justifyDataLabel=r,d.mergeArrays=a,d.setDataLabelStartPos=l,d.hasDataLabels=t)}})(cs||(cs={}));let Ki=cs,{composed:gp}=P,{series:Ka}=st,{merge:up,pushUnique:fp}=N;(function(h){function t(e,i,s,o,r){let{chart:a,options:n}=this,l=a.inverted,c=this.xAxis?.len||a.plotSizeX||0,d=this.yAxis?.len||a.plotSizeY||0,p=e.dlBox||e.shapeArgs,g=e.below??(e.plotY||0)>(this.translatedThreshold??d),u=s.inside??!!n.stacking;if(p){if(o=up(p),s.overflow!=="allow"||s.crop!==!1||n.clip!==!1){o.y<0&&(o.height+=o.y,o.y=0);let f=o.y+o.height-d;f>0&&f<o.height-1&&(o.height-=f)}l&&(o={x:d-o.y-o.height,y:c-o.x-o.width,width:o.height,height:o.width}),u||(l?(o.x+=g?0:o.width,o.width=0):(o.y+=g?o.height:0,o.height=0))}s.align??(s.align=!l||u?"center":g?"right":"left"),s.verticalAlign??(s.verticalAlign=l||u?"middle":g?"top":"bottom"),Ka.prototype.alignDataLabel.call(this,e,i,s,o,r),s.inside&&e.contrastColor&&i.css({color:e.contrastColor})}h.compose=function(e){Ki.compose(Ka),fp(gp,"ColumnDataLabel")&&(e.prototype.alignDataLabel=t)}})(ps||(ps={}));let mp=ps,{extend:xp,merge:yp}=N;class Eo extends qi{}Eo.defaultOptions=yp(qi.defaultOptions,{}),xp(Eo.prototype,{inverted:!0}),st.registerSeriesType("bar",Eo);let{column:bp,line:_a}=st.seriesTypes,{addEvent:vp,extend:kp,merge:wp}=N;class _i extends _a{applyJitter(){let t=this,e=this.options.jitter,i=this.points.length;e&&this.points.forEach(function(s,o){["x","y"].forEach(function(r,a){if(e[r]&&!s.isNull){let n=`plot${r.toUpperCase()}`,l=t[`${r}Axis`],c=e[r]*l.transA;if(l&&!l.logarithmic){let d=Math.max(0,(s[n]||0)-c),p=Math.min(l.len,(s[n]||0)+c);s[n]=d+(p-d)*function(g){let u=1e4*Math.sin(g);return u-Math.floor(u)}(o+a*i),r==="x"&&(s.clientX=s.plotX)}}})})}drawGraph(){this.options.lineWidth?super.drawGraph():this.graph&&(this.graph=this.graph.destroy())}}_i.defaultOptions=wp(_a.defaultOptions,{lineWidth:0,findNearestPointBy:"xy",jitter:{x:0,y:0},marker:{enabled:!0},tooltip:{headerFormat:'<span style="color:{point.color}">\u25CF</span> <span style="font-size: 0.8em"> {series.name}</span><br/>',pointFormat:"x: <b>{point.x}</b><br/>y: <b>{point.y}</b><br/>"}}),kp(_i.prototype,{drawTracker:bp.prototype.drawTracker,sorted:!1,requireSorting:!1,noSharedTooltip:!0,trackerGroups:["group","markerGroup","dataLabelsGroup"]}),vp(_i,"afterTranslate",function(){this.applyJitter()}),st.registerSeriesType("scatter",_i);let{deg2rad:Ja}=P,{fireEvent:Mp,isNumber:Io,pick:Ji,relativeLength:Sp}=N;(function(h){h.getCenter=function(){let t=this.options,e=this.chart,i=2*(t.slicedOffset||0),s=e.plotWidth-2*i,o=e.plotHeight-2*i,r=t.center,a=Math.min(s,o),n=t.thickness,l,c=t.size,d=t.innerSize||0,p,g;typeof c=="string"&&(c=parseFloat(c)),typeof d=="string"&&(d=parseFloat(d));let u=[Ji(r?.[0],"50%"),Ji(r?.[1],"50%"),Ji(c&&c<0?void 0:t.size,"100%"),Ji(d&&d<0?void 0:t.innerSize||0,"0%")];for(!e.angular||this instanceof bt||(u[3]=0),p=0;p<4;++p)g=u[p],l=p<2||p===2&&/%$/.test(g),u[p]=Sp(g,[s,o,a,u[2]][p])+(l?i:0);return u[3]>u[2]&&(u[3]=u[2]),Io(n)&&2*n<u[2]&&n>0&&(u[3]=u[2]-2*n),Mp(this,"afterGetCenter",{positions:u}),u},h.getStartAndEndRadians=function(t,e){let i=Io(t)?t:0,s=Io(e)&&e>i&&e-i<360?e:i+360;return{start:Ja*(i+-90),end:Ja*(s+-90)}}})(gs||(gs={}));let Qa=gs,{setAnimation:Cp}=dt,{addEvent:tn,defined:Tp,extend:Ap,isNumber:Pp,pick:Op,relativeLength:Lp}=N;class en extends Ut{getConnectorPath(t){let e=t.dataLabelPosition,i=t.options||{},s=i.connectorShape,o=this.connectorShapes[s]||s;return e&&o.call(this,Ht(vt({},e.computed),{alignment:e.alignment}),e.connectorPosition,i)||[]}getTranslate(){return this.sliced&&this.slicedTranslation||{translateX:0,translateY:0}}haloPath(t){let e=this.shapeArgs;return this.sliced||!this.visible?[]:this.series.chart.renderer.symbols.arc(e.x,e.y,e.r+t,e.r+t,{innerR:e.r-1,start:e.start,end:e.end,borderRadius:e.borderRadius})}constructor(t,e,i){super(t,e,i),this.half=0,this.name??(this.name=t.chart.options.lang.pieSliceName);let s=o=>{this.slice(o.type==="select")};tn(this,"select",s),tn(this,"unselect",s)}isValid(){return Pp(this.y)&&this.y>=0}setVisible(t,e=!0){t!==this.visible&&this.update({visible:t??!this.visible},e,void 0,!1)}slice(t,e,i){let s=this.series;Cp(i,s.chart),e=Op(e,!0),this.sliced=this.options.sliced=t=Tp(t)?t:!this.sliced,s.options.data[s.data.indexOf(this)]=this.options,this.graphic&&this.graphic.animate(this.getTranslate())}}Ap(en.prototype,{connectorShapes:{fixedOffset:function(h,t,e){let i=t.breakAt,s=t.touchingSliceAt,o=e.softConnector?["C",h.x+(h.alignment==="left"?-5:5),h.y,2*i.x-s.x,2*i.y-s.y,i.x,i.y]:["L",i.x,i.y];return[["M",h.x,h.y],o,["L",s.x,s.y]]},straight:function(h,t){let e=t.touchingSliceAt;return[["M",h.x,h.y],["L",e.x,e.y]]},crookedLine:function(h,t,e){let{angle:i=this.angle||0,breakAt:s,touchingSliceAt:o}=t,{series:r}=this,[a,n,l]=r.center,c=l/2,{plotLeft:d,plotWidth:p}=r.chart,g=h.alignment==="left",{x:u,y:f}=h,x=s.x;if(e.crookDistance){let y=Lp(e.crookDistance,1);x=g?a+c+(p+d-a-c)*(1-y):d+(a-c)*y}else x=a+(n-f)*Math.tan(i-Math.PI/2);let m=[["M",u,f]];return(g?x<=u&&x>=s.x:x>=u&&x<=s.x)&&m.push(["L",x,f]),m.push(["L",s.x,s.y],["L",o.x,o.y]),m}}});let{getStartAndEndRadians:Ep}=Qa,{noop:sn}=P,{clamp:Ip,extend:Dp,fireEvent:on,merge:Do,pick:Bp}=N;class Bo extends bt{animate(t){let e=this,i=e.points,s=e.startAngleRad;t||i.forEach(function(o){let r=o.graphic,a=o.shapeArgs;r&&a&&(r.attr({r:Bp(o.startR,e.center&&e.center[3]/2),start:s,end:s}),r.animate({r:a.r,start:a.start,end:a.end},e.options.animation))})}drawEmpty(){let t,e,i=this.startAngleRad,s=this.endAngleRad,o=this.options;this.total===0&&this.center?(t=this.center[0],e=this.center[1],this.graph||(this.graph=this.chart.renderer.arc(t,e,this.center[1]/2,0,i,s).addClass("highcharts-empty-series").add(this.group)),this.graph.attr({d:Or.arc(t,e,this.center[2]/2,0,{start:i,end:s,innerR:this.center[3]/2})}),this.chart.styledMode||this.graph.attr({"stroke-width":o.borderWidth,fill:o.fillColor||"none",stroke:o.color||"#cccccc"})):this.graph&&(this.graph=this.graph.destroy())}drawPoints(){let t=this.chart.renderer;this.points.forEach(function(e){e.graphic&&e.hasNewShapeType()&&(e.graphic=e.graphic.destroy()),e.graphic||(e.graphic=t[e.shapeType](e.shapeArgs).add(e.series.group),e.delayedRendering=!0)})}generatePoints(){super.generatePoints(),this.updateTotals()}getX(t,e,i,s){let o=this.center,r=this.radii?this.radii[i.index]||0:o[2]/2,a=s.dataLabelPosition,n=a?.distance||0,l=Math.asin(Ip((t-o[1])/(r+n),-1,1));return o[0]+Math.cos(l)*(r+n)*(e?-1:1)+(n>0?(e?-1:1)*(s.padding||0):0)}hasData(){return!!this.dataTable.rowCount}redrawPoints(){let t,e,i,s,o=this,r=o.chart;this.drawEmpty(),o.group&&!r.styledMode&&o.group.shadow(o.options.shadow),o.points.forEach(function(a){let n={};e=a.graphic,!a.isNull&&e?(s=a.shapeArgs,t=a.getTranslate(),r.styledMode||(i=o.pointAttribs(a,a.selected&&"select")),a.delayedRendering?(e.setRadialReference(o.center).attr(s).attr(t),r.styledMode||e.attr(i).attr({"stroke-linejoin":"round"}),a.delayedRendering=!1):(e.setRadialReference(o.center),r.styledMode||Do(!0,n,i),Do(!0,n,s,t),e.animate(n)),e.attr({visibility:a.visible?"inherit":"hidden"}),e.addClass(a.getClassName(),!0)):e&&(a.graphic=e.destroy())})}sortByAngle(t,e){t.sort(function(i,s){return i.angle!==void 0&&(s.angle-i.angle)*e})}translate(t){on(this,"translate"),this.generatePoints();let e=this.options,i=e.slicedOffset,s=Ep(e.startAngle,e.endAngle),o=this.startAngleRad=s.start,r=(this.endAngleRad=s.end)-o,a=this.points,n=e.ignoreHiddenPoint,l=a.length,c,d,p,g,u,f,x,m=0;for(t||(this.center=t=this.getCenter()),f=0;f<l;f++){x=a[f],c=o+m*r,x.isValid()&&(!n||x.visible)&&(m+=x.percentage/100),d=o+m*r;let y={x:t[0],y:t[1],r:t[2]/2,innerR:t[3]/2,start:Math.round(1e3*c)/1e3,end:Math.round(1e3*d)/1e3};x.shapeType="arc",x.shapeArgs=y,(p=(d+c)/2)>1.5*Math.PI?p-=2*Math.PI:p<-Math.PI/2&&(p+=2*Math.PI),x.slicedTranslation={translateX:Math.round(Math.cos(p)*i),translateY:Math.round(Math.sin(p)*i)},g=Math.cos(p)*t[2]/2,u=Math.sin(p)*t[2]/2,x.tooltipPos=[t[0]+.7*g,t[1]+.7*u],x.half=+(p<-Math.PI/2||p>Math.PI/2),x.angle=p}on(this,"afterTranslate")}updateTotals(){let t=this.points,e=t.length,i=this.options.ignoreHiddenPoint,s,o,r=0;for(s=0;s<e;s++)(o=t[s]).isValid()&&(!i||o.visible)&&(r+=o.y);for(s=0,this.total=r;s<e;s++)(o=t[s]).percentage=r>0&&(o.visible||!i)?o.y/r*100:0,o.total=r}}Bo.defaultOptions=Do(bt.defaultOptions,{borderRadius:3,center:[null,null],clip:!1,colorByPoint:!0,dataLabels:{connectorPadding:5,connectorShape:"crookedLine",crookDistance:void 0,distance:30,enabled:!0,formatter:function(){return this.isNull?void 0:this.name},softConnector:!0,x:0},fillColor:void 0,ignoreHiddenPoint:!0,inactiveOtherPoints:!0,legendType:"point",marker:null,size:null,showInLegend:!1,slicedOffset:10,stickyTracking:!1,tooltip:{followPointer:!0},borderColor:"#ffffff",borderWidth:1,lineWidth:void 0,states:{hover:{brightness:.1}}}),Dp(Bo.prototype,{axisTypes:[],directTouch:!0,drawGraph:void 0,drawTracker:qi.prototype.drawTracker,getCenter:Qa.getCenter,getSymbol:sn,invertible:!1,isCartesian:!1,noSharedTooltip:!0,pointAttribs:qi.prototype.pointAttribs,pointClass:en,requireSorting:!1,searchPoint:sn,trackerGroups:["group","dataLabelsGroup"]}),st.registerSeriesType("pie",Bo);let{composed:Np,noop:zp}=P,{distribute:Rp}=gi,{series:rn}=st,{arrayMax:Wp,clamp:an,defined:nn,pick:Hp,pushUnique:Xp,relativeLength:hn}=N;(function(h){let t={radialDistributionY:function(r,a){return(a.dataLabelPosition?.top||0)+r.distributeBox.pos},radialDistributionX:function(r,a,n,l,c){let d=c.dataLabelPosition;return r.getX(n<(d?.top||0)+2||n>(d?.bottom||0)-2?l:n,a.half,a,c)},justify:function(r,a,n,l){return l[0]+(r.half?-1:1)*(n+(a.dataLabelPosition?.distance||0))},alignToPlotEdges:function(r,a,n,l){let c=r.getBBox().width;return a?c+l:n-c-l},alignToConnectors:function(r,a,n,l){let c=0,d;return r.forEach(function(p){(d=p.dataLabel.getBBox().width)>c&&(c=d)}),a?c+l:n-c-l}};function e(r,a){let n=Math.PI/2,{start:l=0,end:c=0}=r.shapeArgs||{},d=r.angle||0;a>0&&l<n&&c>n&&d>n/2&&d<1.5*n&&(d=d<=n?Math.max(n/2,(l+n)/2):Math.min(1.5*n,(n+c)/2));let{center:p,options:g}=this,u=p[2]/2,f=Math.cos(d),x=Math.sin(d),m=p[0]+f*u,y=p[1]+x*u,b=Math.min((g.slicedOffset||0)+(g.borderWidth||0),a/5);return{natural:{x:m+f*a,y:y+x*a},computed:{},alignment:a<0?"center":r.half?"right":"left",connectorPosition:{angle:d,breakAt:{x:m+f*b,y:y+x*b},touchingSliceAt:{x:m,y}},distance:a}}function i(){let r=this,a=r.points,n=r.chart,l=n.plotWidth,c=n.plotHeight,d=n.plotLeft,p=Math.round(n.chartWidth/3),g=r.center,u=g[2]/2,f=g[1],x=[[],[]],m=[0,0,0,0],y=r.dataLabelPositioners,b,v,S,w=0;r.visible&&r.hasDataLabels?.()&&(a.forEach(k=>{(k.dataLabels||[]).forEach(M=>{M.shortened&&(M.attr({width:"auto"}).css({width:"auto",textOverflow:"clip"}),M.shortened=!1)})}),rn.prototype.drawDataLabels.apply(r),a.forEach(k=>{(k.dataLabels||[]).forEach((M,C)=>{let T=g[2]/2,A=M.options,O=hn(A?.distance||0,T);C===0&&x[k.half].push(k),!nn(A?.style?.width)&&M.getBBox().width>p&&(M.css({width:Math.round(.7*p)+"px"}),M.shortened=!0),M.dataLabelPosition=this.getDataLabelPosition(k,O),w=Math.max(w,O)})}),x.forEach((k,M)=>{let C=k.length,T=[],A,O,L=0,I;C&&(r.sortByAngle(k,M-.5),w>0&&(A=Math.max(0,f-u-w),O=Math.min(f+u+w,n.plotHeight),k.forEach(D=>{(D.dataLabels||[]).forEach(E=>{let B=E.dataLabelPosition;B&&B.distance>0&&(B.top=Math.max(0,f-u-B.distance),B.bottom=Math.min(f+u+B.distance,n.plotHeight),L=E.getBBox().height||21,E.lineHeight=n.renderer.fontMetrics(E.text||E).h+2*E.padding,D.distributeBox={target:(E.dataLabelPosition?.natural.y||0)-B.top+E.lineHeight/2,size:L,rank:D.y},T.push(D.distributeBox))})}),Rp(T,I=O+L-A,I/5)),k.forEach(D=>{(D.dataLabels||[]).forEach(E=>{let B=E.options||{},K=D.distributeBox,Y=E.dataLabelPosition,pt=Y?.natural.y||0,R=B.connectorPadding||0,W=E.lineHeight||21,j=(W-E.getBBox().height)/2,X=0,$=pt,q="inherit";if(Y){if(T&&nn(K)&&Y.distance>0&&(K.pos===void 0?q="hidden":(S=K.size,$=y.radialDistributionY(D,E))),B.justify)X=y.justify(D,E,u,g);else switch(B.alignTo){case"connectors":X=y.alignToConnectors(k,M,l,d);break;case"plotEdges":X=y.alignToPlotEdges(E,M,l,d);break;default:X=y.radialDistributionX(r,D,$-j,pt,E)}if(Y.attribs={visibility:q,align:Y.alignment},Y.posAttribs={x:X+(B.x||0)+({left:R,right:-R}[Y.alignment]||0),y:$+(B.y||0)-W/2},Y.computed.x=X,Y.computed.y=$-j,Hp(B.crop,!0)){let U;X-(v=E.getBBox().width)<R&&M===1?(U=Math.round(v-X+R),m[3]=Math.max(U,m[3])):X+v>l-R&&M===0&&(U=Math.round(X+v-l+R),m[1]=Math.max(U,m[1])),$-S/2<0?m[0]=Math.max(Math.round(-$+S/2),m[0]):$+S/2>c&&(m[2]=Math.max(Math.round($+S/2-c),m[2])),Y.sideOverflow=U}}})}))}),(Wp(m)===0||this.verifyDataLabelOverflow(m))&&(this.placeDataLabels(),this.points.forEach(k=>{(k.dataLabels||[]).forEach(M=>{let{connectorColor:C,connectorWidth:T=1}=M.options||{},A=M.dataLabelPosition;if(T){let O;b=M.connector,A&&A.distance>0?(O=!b,b||(M.connector=b=n.renderer.path().addClass("highcharts-data-label-connector highcharts-color-"+k.colorIndex+(k.className?" "+k.className:"")).add(r.dataLabelsGroup)),n.styledMode||b.attr({"stroke-width":T,stroke:C||k.color||"#666666"}),b[O?"attr":"animate"]({d:k.getConnectorPath(M)}),b.attr({visibility:A.attribs?.visibility})):b&&(M.connector=b.destroy())}})})))}function s(){this.points.forEach(r=>{(r.dataLabels||[]).forEach(a=>{let n=a.dataLabelPosition;n?(n.sideOverflow&&(a.css({width:Math.max(a.getBBox().width-n.sideOverflow,0)+"px",textOverflow:a.options?.style?.textOverflow||"ellipsis"}),a.shortened=!0),a.attr(n.attribs),a[a.moved?"animate":"attr"](n.posAttribs),a.moved=!0):a&&a.attr({y:-9999})}),delete r.distributeBox},this)}function o(r){let a=this.center,n=this.options,l=n.center,c=n.minSize||80,d=c,p=n.size!==null;return!p&&(l[0]!==null?d=Math.max(a[2]-Math.max(r[1],r[3]),c):(d=Math.max(a[2]-r[1]-r[3],c),a[0]+=(r[3]-r[1])/2),l[1]!==null?d=an(d,c,a[2]-Math.max(r[0],r[2])):(d=an(d,c,a[2]-r[0]-r[2]),a[1]+=(r[0]-r[2])/2),d<a[2]?(a[2]=d,a[3]=Math.min(n.thickness?Math.max(0,d-2*n.thickness):Math.max(0,hn(n.innerSize||0,d)),d),this.translate(a),this.drawDataLabels&&this.drawDataLabels()):p=!0),p}h.compose=function(r){if(Ki.compose(rn),Xp(Np,"PieDataLabel")){let a=r.prototype;a.dataLabelPositioners=t,a.alignDataLabel=zp,a.drawDataLabels=i,a.getDataLabelPosition=e,a.placeDataLabels=s,a.verifyDataLabelOverflow=o}}})(us||(us={}));let Fp=us;(function(h){h.getCenterOfPoints=function(t){let e=t.reduce((i,s)=>(i.x+=s.x,i.y+=s.y,i),{x:0,y:0});return{x:e.x/t.length,y:e.y/t.length}},h.getDistanceBetweenPoints=function(t,e){return Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2))},h.getAngleBetweenPoints=function(t,e){return Math.atan2(e.x-t.x,e.y-t.y)},h.pointInPolygon=function({x:t,y:e},i){let s=i.length,o,r,a=!1;for(o=0,r=s-1;o<s;r=o++){let[n,l]=i[o],[c,d]=i[r];l>e!=d>e&&t<(c-n)*(e-l)/(d-l)+n&&(a=!a)}return a}})(fs||(fs={}));let{pointInPolygon:Gp}=fs,{addEvent:Yp,getAlignFactor:jp,fireEvent:ln,objectEach:dn,pick:Up}=N;function Vp(h){let t=h.length,e=(c,d)=>!(d.x>=c.x+c.width||d.x+d.width<=c.x||d.y>=c.y+c.height||d.y+d.height<=c.y),i=(c,d)=>{for(let p of c)if(Gp({x:p[0],y:p[1]},d))return!0;return!1},s,o,r,a,n,l=!1;for(let c=0;c<t;c++)(s=h[c])&&(s.oldOpacity=s.opacity,s.newOpacity=1,s.absoluteBox=function(d){if(d&&(!d.alignAttr||d.placed)){let p=d.box?0:d.padding||0,g=d.alignAttr||{x:d.attr("x"),y:d.attr("y")},{height:u,polygon:f,width:x}=d.getBBox(),m=jp(d.alignValue)*x;return d.width=x,d.height=u,{x:g.x+(d.parentGroup?.translateX||0)+p-m,y:g.y+(d.parentGroup?.translateY||0)+p,width:x-2*p,height:u-2*p,polygon:f}}}(s));h.sort((c,d)=>(d.labelrank||0)-(c.labelrank||0));for(let c=0;c<t;++c){a=(o=h[c])&&o.absoluteBox;let d=a?.polygon;for(let p=c+1;p<t;++p){n=(r=h[p])&&r.absoluteBox;let g=!1;if(a&&n&&o!==r&&o.newOpacity!==0&&r.newOpacity!==0&&o.visibility!=="hidden"&&r.visibility!=="hidden"){let u=n.polygon;if(d&&u&&d!==u?i(d,u)&&(g=!0):e(a,n)&&(g=!0),g){let f=o.labelrank<r.labelrank?o:r,x=f.text;f.newOpacity=0,x?.element.querySelector("textPath")&&x.hide()}}}}for(let c of h)cn(c,this)&&(l=!0);l&&ln(this,"afterHideAllOverlappingLabels")}function cn(h,t){let e,i=!1;return h&&(e=h.newOpacity,h.oldOpacity!==e&&(h.hasClass("highcharts-data-label")?(h[e?"removeClass":"addClass"]("highcharts-data-label-hidden"),i=!0,h[h.isOld?"animate":"attr"]({opacity:e},void 0,function(){t.styledMode||h.css({pointerEvents:e?"auto":"none"})}),ln(t,"afterHideOverlappingLabel")):h.attr({opacity:e})),h.isOld=!0),i}function $p(){let h=this,t=[];for(let e of h.labelCollectors||[])t=t.concat(e());for(let e of h.yAxis||[])e.stacking&&e.options.stackLabels&&!e.options.stackLabels.allowOverlap&&dn(e.stacking.stacks,i=>{dn(i,s=>{s.label&&t.push(s.label)})});for(let e of h.series||[])if(e.visible&&e.hasDataLabels?.()){let i=s=>{for(let o of s)o.visible&&(o.dataLabels||[]).forEach(r=>{let a=r.options||{};r.labelrank=Up(a.labelrank,o.labelrank,o.shapeArgs?.height),a.allowOverlap??Number(a.distance)>0?(r.oldOpacity=r.opacity,r.newOpacity=1,cn(r,h)):t.push(r)})};i(e.nodes||[]),i(e.points)}this.hideOverlappingLabels(t)}let pn={compose:function(h){let t=h.prototype;t.hideOverlappingLabels||(t.hideOverlappingLabels=Vp,Yp(h,"render",$p))}},{defaultOptions:Zp}=kt,{noop:gn}=P,{addEvent:un,extend:qp,isObject:fn,merge:Kp,relativeLength:No}=N,_p={radius:0,scope:"stack",where:void 0},mn=gn,xn=gn;function Jp(h,t,e,i,s={}){let o=mn(h,t,e,i,s),{innerR:r=0,r:a=e,start:n=0,end:l=0}=s;if(s.open||!s.borderRadius)return o;let c=l-n,d=Math.sin(c/2),p=Math.max(Math.min(No(s.borderRadius||0,a-r),(a-r)/2,a*d/(1+d)),0),g=Math.min(p,c/Math.PI*2*r),u=o.length-1;for(;u--;)(function(f,x,m){let y,b,v,S=f[x],w=f[x+1];if(w[0]==="Z"&&(w=f[0]),(S[0]==="M"||S[0]==="L")&&w[0]==="A"?(y=S,b=w,v=!0):S[0]==="A"&&(w[0]==="M"||w[0]==="L")&&(y=w,b=S),y&&b&&b.params){let k=b[1],M=b[5],C=b.params,{start:T,end:A,cx:O,cy:L}=C,I=M?k-m:k+m,D=I?Math.asin(m/I):0,E=M?D:-D,B=Math.cos(D)*I;v?(C.start=T+E,y[1]=O+B*Math.cos(T),y[2]=L+B*Math.sin(T),f.splice(x+1,0,["A",m,m,0,0,1,O+k*Math.cos(C.start),L+k*Math.sin(C.start)])):(C.end=A-E,b[6]=O+k*Math.cos(C.end),b[7]=L+k*Math.sin(C.end),f.splice(x+1,0,["A",m,m,0,0,1,O+B*Math.cos(A),L+B*Math.sin(A)])),b[4]=Math.abs(C.end-C.start)<Math.PI?0:1}})(o,u,u>1?g:p);return o}function Qp(){if(this.options.borderRadius&&!(this.chart.is3d&&this.chart.is3d())){let{options:h,yAxis:t}=this,e=h.stacking==="percent",i=Zp.plotOptions?.[this.type]?.borderRadius,s=zo(h.borderRadius,fn(i)?i:{}),o=t.options.reversed;for(let r of this.points){let{shapeArgs:a}=r;if(r.shapeType==="roundedRect"&&a){let{width:n=0,height:l=0,y:c=0}=a,d=c,p=l;if(s.scope==="stack"&&r.stackTotal){let x=t.translate(e?100:r.stackTotal,!1,!0,!1,!0),m=t.translate(h.threshold||0,!1,!0,!1,!0),y=this.crispCol(0,Math.min(x,m),0,Math.abs(x-m));d=y.y,p=y.height}let g=(r.negative?-1:1)*(o?-1:1)==-1,u=s.where;!u&&this.is("waterfall")&&Math.abs((r.yBottom||0)-(this.translatedThreshold||0))>this.borderWidth&&(u="all"),u||(u="end");let f=Math.min(No(s.radius,n),n/2,u==="all"?l/2:1/0)||0;u==="end"&&(g&&(d-=f),p+=f),qp(a,{brBoxHeight:p,brBoxY:d,r:f})}}}}function zo(h,t){return fn(h)||(h={radius:h||0}),Kp(_p,t,h)}function tg(){let h=zo(this.options.borderRadius);for(let t of this.points){let e=t.shapeArgs;e&&(e.borderRadius=No(h.radius,(e.r||0)-(e.innerR||0)))}}function eg(h,t,e,i,s={}){let o=xn(h,t,e,i,s),{r=0,brBoxHeight:a=i,brBoxY:n=t}=s,l=t-n,c=n+a-(t+i),d=l-r>-.1?0:r,p=c-r>-.1?0:r,g=Math.max(d&&l,0),u=Math.max(p&&c,0),f=[h+d,t],x=[h+e-d,t],m=[h+e,t+d],y=[h+e,t+i-p],b=[h+e-p,t+i],v=[h+p,t+i],S=[h,t+i-p],w=[h,t+d],k=(M,C)=>Math.sqrt(Math.pow(M,2)-Math.pow(C,2));if(g){let M=k(d,d-g);f[0]-=M,x[0]+=M,m[1]=w[1]=t+d-g}if(i<d-g){let M=k(d,d-g-i);m[0]=y[0]=h+e-d+M,b[0]=Math.min(m[0],b[0]),v[0]=Math.max(y[0],v[0]),S[0]=w[0]=h+d-M,m[1]=w[1]=t+i}if(u){let M=k(p,p-u);b[0]+=M,v[0]-=M,y[1]=S[1]=t+i-p+u}if(i<p-u){let M=k(p,p-u-i);m[0]=y[0]=h+e-p+M,x[0]=Math.min(m[0],x[0]),f[0]=Math.max(y[0],f[0]),S[0]=w[0]=h+p-M,y[1]=S[1]=t}return o.length=0,o.push(["M",...f],["L",...x],["A",d,d,0,0,1,...m],["L",...y],["A",p,p,0,0,1,...b],["L",...v],["A",p,p,0,0,1,...S],["L",...w],["A",d,d,0,0,1,...f],["Z"]),o}let{diffObjects:ig,extend:sg,find:og,merge:rg,pick:Qi,uniqueKey:ag}=N;(function(h){function t(i,s){let o=i.condition;(o.callback||function(){return this.chartWidth<=Qi(o.maxWidth,Number.MAX_VALUE)&&this.chartHeight<=Qi(o.maxHeight,Number.MAX_VALUE)&&this.chartWidth>=Qi(o.minWidth,0)&&this.chartHeight>=Qi(o.minHeight,0)}).call(this)&&s.push(i._id)}function e(i,s){let o=this.options.responsive,r=this.currentResponsive,a=[],n;!s&&o&&o.rules&&o.rules.forEach(d=>{d._id===void 0&&(d._id=ag()),this.matchResponsiveRule(d,a)},this);let l=rg(...a.map(d=>og(o?.rules||[],p=>p._id===d)).map(d=>d?.chartOptions));l.isResponsiveOptions=!0,a=a.toString()||void 0;let c=r?.ruleIds;a===c||(r&&(this.currentResponsive=void 0,this.updatingResponsive=!0,this.update(r.undoOptions,i,!0),this.updatingResponsive=!1),a?((n=ig(l,this.options,!0,this.collectionsWithUpdate)).isResponsiveOptions=!0,this.currentResponsive={ruleIds:a,mergedOptions:l,undoOptions:n},this.updatingResponsive||this.update(l,i,!0)):this.currentResponsive=void 0)}h.compose=function(i){let s=i.prototype;return s.matchResponsiveRule||sg(s,{matchResponsiveRule:t,setResponsive:e}),i}})(ms||(ms={}));let ng=ms;P.AST=_,P.Axis=Zs,P.Chart=qt,P.Color=tt,P.DataLabel=Ki,P.DataTableCore=zi,P.Fx=se,P.HTMLElement=we,P.Legend=Ma,P.LegendSymbol=la,P.OverlappingDataLabels=P.OverlappingDataLabels||pn,P.PlotLineOrBand=Ei,P.Point=Ut,P.Pointer=aa,P.RendererRegistry=Re,P.Series=bt,P.SeriesRegistry=st,P.StackItem=za,P.SVGElement=Et,P.SVGRenderer=ki,P.Templating=wt,P.Tick=Me,P.Time=Ms,P.Tooltip=ea,P.animate=dt.animate,P.animObject=dt.animObject,P.chart=qt.chart,P.color=tt.parse,P.dateFormat=wt.dateFormat,P.defaultOptions=kt.defaultOptions,P.distribute=gi.distribute,P.format=wt.format,P.getDeferredAnimation=dt.getDeferredAnimation,P.getOptions=kt.getOptions,P.numberFormat=wt.numberFormat,P.seriesType=st.seriesType,P.setAnimation=dt.setAnimation,P.setOptions=kt.setOptions,P.stop=dt.stop,P.time=kt.defaultTime,P.timers=se.timers,{compose:function(h,t,e){let i=h.types.pie;if(!t.symbolCustomAttribs.includes("borderRadius")){let s=e.prototype.symbols;un(h,"afterColumnTranslate",Qp,{order:9}),un(i,"afterTranslate",tg),t.symbolCustomAttribs.push("borderRadius","brBoxHeight","brBoxY"),mn=s.arc,xn=s.roundedRect,s.arc=Jp,s.roundedRect=eg}},optionsToObject:zo}.compose(P.Series,P.SVGElement,P.SVGRenderer),mp.compose(P.Series.types.column),Ki.compose(P.Series),Kl.compose(P.Axis),we.compose(P.SVGRenderer),Ma.compose(P.Chart),Ql.compose(P.Axis),pn.compose(P.Chart),Fp.compose(P.Series.types.pie),Ei.compose(P.Chart,P.Axis),aa.compose(P.Chart),ng.compose(P.Chart),Ba.compose(P.Axis,P.Chart,P.Series),qc.compose(P.Axis,P.Chart,P.Series),ea.compose(P.Pointer),N.extend(P,N);let hg=P;return Go.default})())});var Gn=(()=>{class F{constructor(V,Q){this.el=V,this._zone=Q,this.updateChange=new Ro(!0),this.chartInstance=new Ro}ngOnChanges(V){let Q=V.update?.currentValue;(V.options||Q)&&(this.wrappedUpdateOrCreateChart(),Q&&this.updateChange.emit(!1))}wrappedUpdateOrCreateChart(){this.runOutsideAngular?this._zone.runOutsideAngular(()=>{this.updateOrCreateChart()}):this.updateOrCreateChart()}updateOrCreateChart(){this.chart?.update?this.chart.update(this.options,!0,this.oneToOne||!1):(this.chart=this.Highcharts[this.constructorType||"chart"](this.el.nativeElement,this.options,this.callbackFunction||null),this.chartInstance.emit(this.chart))}ngOnDestroy(){this.chart&&(this.chart.destroy(),this.chart=null,this.chartInstance.emit(this.chart))}static{this.\u0275fac=function(Q){return new(Q||F)(Wo(Sn),Wo(Mn))}}static{this.\u0275cmp=es({type:F,selectors:[["highcharts-chart"]],inputs:{Highcharts:"Highcharts",constructorType:"constructorType",callbackFunction:"callbackFunction",oneToOne:"oneToOne",runOutsideAngular:"runOutsideAngular",options:"options",update:"update"},outputs:{updateChange:"updateChange",chartInstance:"chartInstance"},standalone:!1,features:[wn],decls:0,vars:0,template:function(Q,ue){},encapsulation:2})}}return F})(),Yn=(()=>{class F{static{this.\u0275fac=function(Q){return new(Q||F)}}static{this.\u0275mod=Tn({type:F})}static{this.\u0275inj=kn({})}}return F})();var pg=dg(jn());var Un=(()=>{class F{constructor(){this.httpService=ts(zn)}getDashboardData(){return this.httpService.get(void 0,"api/Dashboard")}static{this.\u0275fac=function(Q){return new(Q||F)}}static{this.\u0275prov=vn({token:F,factory:F.\u0275fac,providedIn:"root"})}}return F})();function gg(F,Ot){if(F&1&&(ut(0,"main",3)(1,"div",4)(2,"div",5)(3,"p-card")(4,"div",6)(5,"div"),ge(6,"i",7),ft(),ut(7,"div",8)(8,"h3",9),Xt(9,"Cash and Bank"),ft(),ut(10,"p"),Xt(11),oi(12,"number"),ft()()()()(),ut(13,"div",5)(14,"p-card")(15,"div",6)(16,"div"),ge(17,"i",10),ft(),ut(18,"div",8)(19,"h3",9),Xt(20,"Revenue"),ft(),ut(21,"p"),Xt(22),oi(23,"number"),ft()()()()(),ut(24,"div",5)(25,"p-card")(26,"div",6)(27,"div"),ge(28,"i",11),ft(),ut(29,"div",8)(30,"h3",9),Xt(31,"Expense"),ft(),ut(32,"p"),Xt(33),oi(34,"number"),ft()()()()(),ut(35,"div",5)(36,"p-card")(37,"div",6)(38,"div"),ge(39,"i",12),ft(),ut(40,"div",8)(41,"h3",9),Xt(42,"Total Journal"),ft(),ut(43,"p"),Xt(44),oi(45,"number"),ft()()()()()(),ut(46,"div",13)(47,"div",14)(48,"div",15),ge(49,"highcharts-chart",16),ft()(),ut(50,"div",14)(51,"div",15),ge(52,"highcharts-chart",16),ft()()()()),F&2){let V=Xo(2);te(11),si(ri(12,8,V.dashboardData().cashAndBank)),te(11),si(ri(23,10,V.dashboardData().revenue)),te(11),si(ri(34,12,V.dashboardData().expense)),te(11),si(ri(45,14,V.dashboardData().totalJournal)),te(5),ii("Highcharts",V.Highcharts)("options",V.chartOptionsLeft),te(3),ii("Highcharts",V.Highcharts)("options",V.chartOptionsRight)}}function ug(F,Ot){if(F&1&&(An(0),ut(1,"app-main-panel",2),Ho(2,gg,53,16,"ng-template",null,0,On),ft(),Pn()),F&2){let V=Xo();te(),ii("pageTitle","Dashboard "+V.dashboardData().title)}}var jg=(()=>{class F{constructor(){this.dashboardService=ts(Un),this.dashboardData=Cn(null),this.Highcharts=pg,this.isActive=!1,Ln(()=>{this.dashboardData()&&(this.chartOptionsLeft.series=this.dashboardData().pie.series.map(V=>Ht(vt({},V),{type:"pie"})))})}ngOnInit(){this.dashboardService.getDashboardData().pipe(Xn("Dashboard Data"),bn(V=>{this.dashboardData.set(V),this.chartOptionsLeft={series:this.dashboardData().pie.series.map(Q=>Ht(vt({},Q),{type:"pie"})),title:{text:"This Month's Expense"}},this.chartOptionsRight={series:this.dashboardData().chart.series.map(Q=>Ht(vt({},Q),{type:"spline"})),xAxis:{categories:this.dashboardData().chart.labels},title:{text:"Daily Revenue and Expense"}}})).subscribe()}toggleClass(){this.isActive=!this.isActive}static{this.\u0275fac=function(Q){return new(Q||F)}}static{this.\u0275cmp=es({type:F,selectors:[["ng-component"]],decls:1,vars:1,consts:[["content",""],[4,"ngIf"],[3,"pageTitle"],[1,"d-flex","flex-column","gap-4"],[1,"row","row-gap-4"],[1,"col-12","col-md-3"],[1,"d-flex","justify-content-between","align-items-center"],[1,"fa-light","fa-dollar-sign","fa-2x"],[1,"d-flex","flex-column","align-items-end"],[1,"fs-4"],[1,"fa-light","fa-wallet","fa-2x"],[1,"fa-light","fa-chart-line","fa-2x"],[1,"fa-light","fa-list-ol","fa-2x"],[1,"row"],[1,"col-12","col-md-6"],[1,"d-flex"],[1,"flex-grow-1",3,"Highcharts","options"]],template:function(Q,ue){Q&1&&Ho(0,ug,4,1,"ng-container",1),Q&2&&ii("ngIf",ue.dashboardData())},dependencies:[Nn,Bn,Rn,Yn,Gn,Hn,Wn,Dn,En,In],encapsulation:2})}}return F})();export{jg as Dashboard1Component};
|