diff --git a/dist/lunar-phase-card.js b/dist/lunar-phase-card.js new file mode 100644 index 0000000..350a347 --- /dev/null +++ b/dist/lunar-phase-card.js @@ -0,0 +1,1634 @@ +function A(A,e,t,n){var r,P=arguments.length,z=P<3?e:null===n?n=Object.getOwnPropertyDescriptor(e,t):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)z=Reflect.decorate(A,e,t,n);else for(var f=A.length-1;f>=0;f--)(r=A[f])&&(z=(P<3?r(z):P>3?r(e,t,z):r(e,t))||z);return P>3&&z&&Object.defineProperty(e,t,z),z}console.groupCollapsed("%c 🌒 LUNAR-PHASE-CARD 🌃 v1.6.0 🔭 \n%c ","color: cyan; font-weight: bold; background: transparent","font-weight: bold; background: dimgray"),console.info("Lovelace custom card for tracking Moon phases"),console.info("Github: https://github.com/ngocjohn/lunar-phase-card"),console.info("If you like the card, consider supporting the developer: https://github.com/sponsors/ngocjohn"),console.groupEnd(),"function"==typeof SuppressedError&&SuppressedError; +/** + * @license + * Copyright 2019 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */ +const e=globalThis,t=e.ShadowRoot&&(void 0===e.ShadyCSS||e.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,n=Symbol(),r=new WeakMap;class P{constructor(A,e,t){if(this._$cssResult$=!0,t!==n)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=A,this.t=e}get styleSheet(){let A=this.o;const e=this.t;if(t&&void 0===A){const t=void 0!==e&&1===e.length;t&&(A=r.get(e)),void 0===A&&((this.o=A=new CSSStyleSheet).replaceSync(this.cssText),t&&r.set(e,A))}return A}toString(){return this.cssText}}const z=A=>new P("string"==typeof A?A:A+"",void 0,n),f=(A,...e)=>{const t=1===A.length?A[0]:e.reduce(((e,t,n)=>e+(A=>{if(!0===A._$cssResult$)return A.cssText;if("number"==typeof A)return A;throw Error("Value passed to 'css' function must be a 'css' function result: "+A+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(t)+A[n+1]),A[0]);return new P(t,A,n)},v=(A,n)=>{if(t)A.adoptedStyleSheets=n.map((A=>A instanceof CSSStyleSheet?A:A.styleSheet));else for(const t of n){const n=document.createElement("style"),r=e.litNonce;void 0!==r&&n.setAttribute("nonce",r),n.textContent=t.cssText,A.appendChild(n)}},s=t?A=>A:A=>A instanceof CSSStyleSheet?(A=>{let e="";for(const t of A.cssRules)e+=t.cssText;return z(e)})(A):A +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */,{is:a,defineProperty:w,getOwnPropertyDescriptor:D,getOwnPropertyNames:c,getOwnPropertySymbols:l,getPrototypeOf:d}=Object,M=globalThis,g=M.trustedTypes,u=g?g.emptyScript:"",j=M.reactiveElementPolyfillSupport,b=(A,e)=>A,x={toAttribute(A,e){switch(e){case Boolean:A=A?u:null;break;case Object:case Array:A=null==A?A:JSON.stringify(A)}return A},fromAttribute(A,e){let t=A;switch(e){case Boolean:t=null!==A;break;case Number:t=null===A?null:Number(A);break;case Object:case Array:try{t=JSON.parse(A)}catch(A){t=null}}return t}},X=(A,e)=>!a(A,e),H={attribute:!0,type:String,converter:x,reflect:!1,hasChanged:X};Symbol.metadata??=Symbol("metadata"),M.litPropertyMetadata??=new WeakMap;class W extends HTMLElement{static addInitializer(A){this._$Ei(),(this.l??=[]).push(A)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(A,e=H){if(e.state&&(e.attribute=!1),this._$Ei(),this.elementProperties.set(A,e),!e.noAccessor){const t=Symbol(),n=this.getPropertyDescriptor(A,t,e);void 0!==n&&w(this.prototype,A,n)}}static getPropertyDescriptor(A,e,t){const{get:n,set:r}=D(this.prototype,A)??{get(){return this[e]},set(A){this[e]=A}};return{get(){return n?.call(this)},set(e){const P=n?.call(this);r.call(this,e),this.requestUpdate(A,P,t)},configurable:!0,enumerable:!0}}static getPropertyOptions(A){return this.elementProperties.get(A)??H}static _$Ei(){if(this.hasOwnProperty(b("elementProperties")))return;const A=d(this);A.finalize(),void 0!==A.l&&(this.l=[...A.l]),this.elementProperties=new Map(A.elementProperties)}static finalize(){if(this.hasOwnProperty(b("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(b("properties"))){const A=this.properties,e=[...c(A),...l(A)];for(const t of e)this.createProperty(t,A[t])}const A=this[Symbol.metadata];if(null!==A){const e=litPropertyMetadata.get(A);if(void 0!==e)for(const[A,t]of e)this.elementProperties.set(A,t)}this._$Eh=new Map;for(const[A,e]of this.elementProperties){const t=this._$Eu(A,e);void 0!==t&&this._$Eh.set(t,A)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(A){const e=[];if(Array.isArray(A)){const t=new Set(A.flat(1/0).reverse());for(const A of t)e.unshift(s(A))}else void 0!==A&&e.push(s(A));return e}static _$Eu(A,e){const t=e.attribute;return!1===t?void 0:"string"==typeof t?t:"string"==typeof A?A.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise((A=>this.enableUpdating=A)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((A=>A(this)))}addController(A){(this._$EO??=new Set).add(A),void 0!==this.renderRoot&&this.isConnected&&A.hostConnected?.()}removeController(A){this._$EO?.delete(A)}_$E_(){const A=new Map,e=this.constructor.elementProperties;for(const t of e.keys())this.hasOwnProperty(t)&&(A.set(t,this[t]),delete this[t]);A.size>0&&(this._$Ep=A)}createRenderRoot(){const A=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return v(A,this.constructor.elementStyles),A}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((A=>A.hostConnected?.()))}enableUpdating(A){}disconnectedCallback(){this._$EO?.forEach((A=>A.hostDisconnected?.()))}attributeChangedCallback(A,e,t){this._$AK(A,t)}_$EC(A,e){const t=this.constructor.elementProperties.get(A),n=this.constructor._$Eu(A,t);if(void 0!==n&&!0===t.reflect){const r=(void 0!==t.converter?.toAttribute?t.converter:x).toAttribute(e,t.type);this._$Em=A,null==r?this.removeAttribute(n):this.setAttribute(n,r),this._$Em=null}}_$AK(A,e){const t=this.constructor,n=t._$Eh.get(A);if(void 0!==n&&this._$Em!==n){const A=t.getPropertyOptions(n),r="function"==typeof A.converter?{fromAttribute:A.converter}:void 0!==A.converter?.fromAttribute?A.converter:x;this._$Em=n,this[n]=r.fromAttribute(e,A.type),this._$Em=null}}requestUpdate(A,e,t){if(void 0!==A){if(t??=this.constructor.getPropertyOptions(A),!(t.hasChanged??X)(this[A],e))return;this.P(A,e,t)}!1===this.isUpdatePending&&(this._$ES=this._$ET())}P(A,e,t){this._$AL.has(A)||this._$AL.set(A,e),!0===t.reflect&&this._$Em!==A&&(this._$Ej??=new Set).add(A)}async _$ET(){this.isUpdatePending=!0;try{await this._$ES}catch(A){Promise.reject(A)}const A=this.scheduleUpdate();return null!=A&&await A,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[A,e]of this._$Ep)this[A]=e;this._$Ep=void 0}const A=this.constructor.elementProperties;if(A.size>0)for(const[e,t]of A)!0!==t.wrapped||this._$AL.has(e)||void 0===this[e]||this.P(e,this[e],t)}let A=!1;const e=this._$AL;try{A=this.shouldUpdate(e),A?(this.willUpdate(e),this._$EO?.forEach((A=>A.hostUpdate?.())),this.update(e)):this._$EU()}catch(e){throw A=!1,this._$EU(),e}A&&this._$AE(e)}willUpdate(A){}_$AE(A){this._$EO?.forEach((A=>A.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(A)),this.updated(A)}_$EU(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(A){return!0}update(A){this._$Ej&&=this._$Ej.forEach((A=>this._$EC(A,this[A]))),this._$EU()}updated(A){}firstUpdated(A){}}W.elementStyles=[],W.shadowRootOptions={mode:"open"},W[b("elementProperties")]=new Map,W[b("finalized")]=new Map,j?.({ReactiveElement:W}),(M.reactiveElementVersions??=[]).push("2.0.4"); +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */ +const B=globalThis,O=B.trustedTypes,p=O?O.createPolicy("lit-html",{createHTML:A=>A}):void 0,Z="$lit$",y=`lit$${Math.random().toFixed(9).slice(2)}$`,G="?"+y,m=`<${G}>`,L=document,Y=()=>L.createComment(""),o=A=>null===A||"object"!=typeof A&&"function"!=typeof A,N=Array.isArray,i=A=>N(A)||"function"==typeof A?.[Symbol.iterator],Q="[ \t\n\f\r]",T=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,C=/-->/g,V=/>/g,h=RegExp(`>|${Q}(?:([^\\s"'>=/]+)(${Q}*=${Q}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),q=/'/g,I=/"/g,k=/^(?:script|style|textarea|title)$/i,K=A=>(e,...t)=>({_$litType$:A,strings:e,values:t}),U=K(1),S=Symbol.for("lit-noChange"),E=Symbol.for("lit-nothing"),R=new WeakMap,J=L.createTreeWalker(L,129);function F(A,e){if(!Array.isArray(A)||!A.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==p?p.createHTML(e):e}const _=(A,e)=>{const t=A.length-1,n=[];let r,P=2===e?"":"",z=T;for(let e=0;e"===v[0]?(z=r??T,s=-1):void 0===v[1]?s=-2:(s=z.lastIndex-v[2].length,f=v[1],z=void 0===v[3]?h:'"'===v[3]?I:q):z===I||z===q?z=h:z===C||z===V?z=T:(z=h,r=void 0);const w=z===h&&A[e+1].startsWith("/>")?" ":"";P+=z===T?t+m:s>=0?(n.push(f),t.slice(0,s)+Z+t.slice(s)+y+w):t+y+(-2===s?e:w)}return[F(A,P+(A[t]||"")+(2===e?"":"")),n]};class ${constructor({strings:A,_$litType$:e},t){let n;this.parts=[];let r=0,P=0;const z=A.length-1,f=this.parts,[v,s]=_(A,e);if(this.el=$.createElement(v,t),J.currentNode=this.el.content,2===e){const A=this.el.content.firstChild;A.replaceWith(...A.childNodes)}for(;null!==(n=J.nextNode())&&f.length0){n.textContent=O?O.emptyScript:"";for(let t=0;t2||""!==t[0]||""!==t[1]?(this._$AH=Array(t.length-1).fill(new String),this.strings=t):this._$AH=E}_$AI(A,e=this,t,n){const r=this.strings;let P=!1;if(void 0===r)A=AA(this,A,e,0),P=!o(A)||A!==this._$AH&&A!==S,P&&(this._$AH=A);else{const n=A;let z,f;for(A=r[0],z=0;z{const n=t?.renderBefore??e;let r=n._$litPart$;if(void 0===r){const A=t?.renderBefore??null;n._$litPart$=r=new tA(e.insertBefore(Y(),A),A,void 0,t??{})}return r._$AI(A),r +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */};class aA extends W{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){const A=super.createRenderRoot();return this.renderOptions.renderBefore??=A.firstChild,A}update(A){const e=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(A),this._$Do=sA(e,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return S}}aA._$litElement$=!0,aA.finalized=!0,globalThis.litElementHydrateSupport?.({LitElement:aA});const wA=globalThis.litElementPolyfillSupport;wA?.({LitElement:aA}),(globalThis.litElementVersions??=[]).push("4.0.6"); +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */ +const DA=A=>(e,t)=>{void 0!==t?t.addInitializer((()=>{customElements.define(A,e)})):customElements.define(A,e)} +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */,cA={attribute:!0,type:String,converter:x,reflect:!1,hasChanged:X},lA=(A=cA,e,t)=>{const{kind:n,metadata:r}=t;let P=globalThis.litPropertyMetadata.get(r);if(void 0===P&&globalThis.litPropertyMetadata.set(r,P=new Map),P.set(t.name,A),"accessor"===n){const{name:n}=t;return{set(t){const r=e.get.call(this);e.set.call(this,t),this.requestUpdate(n,r,A)},init(e){return void 0!==e&&this.P(n,void 0,A),e}}}if("setter"===n){const{name:n}=t;return function(t){const r=this[n];e.call(this,t),this.requestUpdate(n,r,A)}}throw Error("Unsupported decorator location: "+n)};function dA(A){return(e,t)=>"object"==typeof t?lA(A,e,t):((A,e,t)=>{const n=e.hasOwnProperty(t);return e.constructor.createProperty(t,n?{...A,wrapped:!0}:A),n?Object.getOwnPropertyDescriptor(e,t):void 0})(A,e,t) +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */}function MA(A){return dA({...A,state:!0,attribute:!1})} +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */const gA=(A,e,t)=>(t.configurable=!0,t.enumerable=!0,Reflect.decorate&&"object"!=typeof e&&Object.defineProperty(A,e,t),t) +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */;function uA(A,e){return(t,n,r)=>{const P=e=>e.renderRoot?.querySelector(A)??null;if(e){const{get:A,set:e}="object"==typeof n?t:r??(()=>{const A=Symbol();return{get(){return this[A]},set(e){this[A]=e}}})();return gA(t,n,{get(){let t=A.call(this);return void 0===t&&(t=P(this),(null!==t||this.hasUpdated)&&e.call(this,t)),t}})}return gA(t,n,{get(){return P(this)}})}} +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */const jA={ATTRIBUTE:1,CHILD:2,PROPERTY:3,BOOLEAN_ATTRIBUTE:4,EVENT:5,ELEMENT:6},bA=A=>(...e)=>({_$litDirective$:A,values:e});class xA{constructor(A){}get _$AU(){return this._$AM._$AU}_$AT(A,e,t){this._$Ct=A,this._$AM=e,this._$Ci=t}_$AS(A,e){return this.update(A,e)}update(A,e){return this.render(...e)}} +/** + * @license + * Copyright 2018 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */const XA=bA(class extends xA{constructor(A){if(super(A),A.type!==jA.ATTRIBUTE||"class"!==A.name||A.strings?.length>2)throw Error("`classMap()` can only be used in the `class` attribute and must be the only part in the attribute.")}render(A){return" "+Object.keys(A).filter((e=>A[e])).join(" ")+" "}update(A,[e]){if(void 0===this.st){this.st=new Set,void 0!==A.strings&&(this.nt=new Set(A.strings.join(" ").split(/\s/).filter((A=>""!==A))));for(const A in e)e[A]&&!this.nt?.has(A)&&this.st.add(A);return this.render(e)}const t=A.element.classList;for(const A of this.st)A in e||(t.remove(A),this.st.delete(A));for(const A in e){const n=!!e[A];n===this.st.has(A)||this.nt?.has(A)||(n?(t.add(A),this.st.add(A)):(t.remove(A),this.st.delete(A)))}return S}}),HA="important",WA=" !"+HA,BA=bA(class extends xA{constructor(A){if(super(A),A.type!==jA.ATTRIBUTE||"style"!==A.name||A.strings?.length>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(A){return Object.keys(A).reduce(((e,t)=>{const n=A[t];return null==n?e:e+`${t=t.includes("-")?t:t.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${n};`}),"")}update(A,[e]){const{style:t}=A.element;if(void 0===this.ft)return this.ft=new Set(Object.keys(e)),this.render(e);for(const A of this.ft)null==e[A]&&(this.ft.delete(A),A.includes("-")?t.removeProperty(A):t[A]=null);for(const A in e){const n=e[A];if(null!=n){this.ft.add(A);const e="string"==typeof n&&n.endsWith(WA);A.includes("-")||e?t.setProperty(A,e?n.slice(0,-11):n,e?HA:""):t[A]=n}}return S}}),OA={type:"custom:lunar-phase-card",entity:"",use_default:!0,use_custom:!1,use_entity:!1,show_background:!0,selected_language:"en",compact_view:!0,"12hr_format":!1,font_customize:{header_font_size:"x-large",header_font_style:"capitalize",header_font_color:"",label_font_size:"auto",label_font_style:"none",label_font_color:"",hide_label:!1}}; +/** + * @license + * Copyright 2018 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */var pA="1.6.0",ZA={type:"git",url:"https://github.com/ngocjohn/lunar-phase-card",repo:"ngocjohn/lunar-phase-card"},yA="";const GA=ZA.repo,mA=`v${pA}`,LA=6e4,YA=yA,oA=["auto","small","medium","large","x-large","xx-large"],NA=["none","capitalize","uppercase","lowercase"],iA=["white","black","red","green","blue","yellow","orange","purple","pink","brown","gray"];var QA="Catalan",TA="Català",CA={phase:{firstQuarterMoon:"Quart creixent",fullMoon:"Lluna plena",thirdQuarterMoon:"Quart minvant",newMoon:"Lluna nova",waxingCrescentMoon:"Lluna creixent",waxingGibbousMoon:"Gibosa creixent",waningCrescentMoon:"Lluna minvant",waningGibbousMoon:"Gibosa minvant"},illumination:"Il·luminació",illuminated:"Il·luminada",moonRise:"Sortida de la lluna",moonSet:"Posta de la lluna",moonHigh:"Punt més alt de la lluna",moonAge:"Edat de la lluna",distance:"Distància",azimuth:"Azimut",altitude:"Elevació",fullMoon:"Lluna plena",newMoon:"Lluna nova",relativeTime:{days:"dies",justNow:"ara",minutesAgo:"fa {0} minuts",hoursAgo:"fa {0} hores",inMinutes:"d'aquí a {0} minuts",inHours:"d'aqui a {0} hores"}},VA={viewConfig:{title:"Llenguatge i mode de vista",description:"Estableix una configuració per l'idioma i el fons"},baseConfig:{title:"Latitud i longitud",description:"Estableix una configuració per la latitud i la longitud"},optionsConfig:{useDefault:"Fer servir el sistema",useEntity:"Fer servir l'entitat",useCustom:"Personalitza"},fontOptions:{title:"Personalització de la font",description:"Estableix una configuració per a la mida i el color de la font",hideLabel:"Amaga l'etiqueta",headerFontConfig:{title:"Font de la capçalera",description:"Estableix una configuració per a la font de la capçalera"},labelFontConfig:{title:"Font de l'etiqueta",description:"Estableix una configuració per a la font de l'etiqueta"},headerFontSize:"Mida de la font de capçalera",headerFontColor:"Color de la font de capçalera",headerFontStyle:"Estil de la font de capçalera",labelFontSize:"Mida de la font de l'etiqueta",labelFontColor:"Color de la font de l'etiqueta",labelFontStyle:"Estil de la font de l'etiqueta",valueFontSize:"Mida de la font del valor"},compactView:"Vista compacta",showBackground:"Mostra el fons",timeFormat:"Format del temps de 12 hores",placeHolder:{latitude:"Entra la latitud",longitude:"Entra la longitud",customBackground:"URL o camí a la imatge del fons",language:"Selecciona l'idioma",moonPosition:"Selecciona la posició de la lluna a la targeta"}},hA={name:QA,nativeName:TA,card:CA,editor:VA},qA=Object.freeze({__proto__:null,name:QA,nativeName:TA,card:CA,editor:VA,default:hA}),IA="Czech",kA="Čeština",KA={phase:{firstQuarterMoon:"První čtvrť",fullMoon:"Úplněk",thirdQuarterMoon:"Poslední čtvrť",newMoon:"Novoluní",waxingCrescentMoon:"Ubývající srpek",waxingGibbousMoon:"Dorůstající měsíc",waningCrescentMoon:"Ubývající srpek",waningGibbousMoon:"Ubývající měsíc"},illumination:"Osvětlená plocha",illuminated:"Osvětleno",moonRise:"Východ",moonSet:"Západ",moonHigh:"Měsíc vysoko",moonAge:"Věk Měsíce",distance:"Vzdálenost",azimuth:"Azimut",altitude:"Výška",fullMoon:"Úplněk",newMoon:"Novoluní",relativeTime:{days:"dny",justNow:"právě teď",minutesAgo:"před {0} minutami",hoursAgo:"před {0} hodinami",inMinutes:"za {0} minut",inHours:"za {0} hodin"}},UA={viewConfig:{title:"Jazyk a zobrazení",description:"Nastavte konfiguraci pro jazyk a pozadí"},baseConfig:{title:"Zeměpisná šířka a délka",description:"Nastavte konfiguraci pro zeměpisnou šířku a délku"},optionsConfig:{useDefault:"Použít výchozí",useEntity:"Použít entitu",useCustom:"Použít vlastní"},fontOptions:{title:"Stylizace textu",description:"Nastavte stylizaci textu",hideLabel:"Skrýt popisek",headerFontConfig:{title:"Nadpis",description:"Nastavte stylizaci nadpisu"},labelFontConfig:{title:"Popisek",description:"Nastavte stylizaci popisku"},headerFontSize:"Velikost písma nadpisu",headerFontColor:"Barva písma nadpisu",headerFontStyle:"Styl písma nadpisu",labelFontSize:"Velikost písma popisku",labelFontColor:"Barva písma popisku",labelFontStyle:"Styl písma popisku",valueFontSize:"Velikost písma hodnoty"},compactView:"Kompaktní zobrazení",showBackground:"Zobrazit pozadí",timeFormat:"12-hodinový formát času",placeHolder:{latitude:"Zadejte zeměpisnou šířku",longitude:"Zadejte zeměpisnou délku",customBackground:"URL nebo cesta k obrázku",language:"Vyberte jazyk",moonPosition:"Vyberte polohu Měsíce na kartě"}},SA={name:IA,nativeName:kA,card:KA,editor:UA},EA=Object.freeze({__proto__:null,name:IA,nativeName:kA,card:KA,editor:UA,default:SA}),RA="Danish",JA="Dansk",FA={phase:{firstQuarterMoon:"Tiltagende Måne",fullMoon:"Fuldmåne",thirdQuarterMoon:"Aftagende måne",newMoon:"Nymåne",waxingCrescentMoon:"Tiltagende halvmåne",waxingGibbousMoon:"Tiltagende måne",waningCrescentMoon:"Aftagende halvmåne",waningGibbousMoon:"Aftagende måne"},illumination:"Belysning",illuminated:"Oplyst",moonRise:"Måneopgang",moonSet:"Månenedgang",moonHigh:"Månen højest",moonAge:"Månealderen",distance:"Afstand",azimuth:"Azimuth",altitude:"Højde",fullMoon:"Fuldmåne",newMoon:"Nymåne",relativeTime:{days:"dage",justNow:"lige nu",minutesAgo:"{0} minutter siden",hoursAgo:"{0} timer siden",inMinutes:"in {0} minutter",inHours:"in {0} timer"}},_A={viewConfig:{title:"Sprog og visningstilstand",description:"Indstil en konfiguration for sprog og baggrund"},baseConfig:{title:"Bredde og længdegrad",description:"Indstil en konfiguration for breddegrad og længdegrad"},optionsConfig:{useDefault:"Brug systemet",useEntity:"Brug enhed",useCustom:"Brug brugerdefineret"},fontOptions:{title:"Fonttilpasning",description:"Indstil en konfiguration for skriftstørrelse og farve",hideLabel:"Skjul etiket",headerFontConfig:{title:"Header font",description:"Indstil en konfiguration for header font"},labelFontConfig:{title:"Etiket skrifttype",description:"Indstil en konfiguration for etiket skrifttype"},headerFontSize:"Header skriftstørrelse",headerFontColor:"Header skriftfarve",headerFontStyle:"Header skrifttype",labelFontSize:"Etiket skriftstørrelse",labelFontColor:"Etiket skriftfarve",labelFontStyle:"Etiket skrifttype",valueFontSize:"Værdi skriftstørrelse"},compactView:"Kompakt udsigt",showBackground:"Vis baggrund",timeFormat:"12-timers tidsformat",placeHolder:{latitude:"Indtast breddegrad",longitude:"Indtast længdegrad",customBackground:"URL eller sti til billede",language:"Vælg sprog",moonPosition:"Vælg måneposition på kortet"}},$A={name:RA,nativeName:JA,card:FA,editor:_A},Ae=Object.freeze({__proto__:null,name:RA,nativeName:JA,card:FA,editor:_A,default:$A}),ee="German",te="Deutsch",ne={phase:{firstQuarterMoon:"Erstes Viertel",fullMoon:"Vollmond",thirdQuarterMoon:"Letztes Viertel",newMoon:"Neumond",waxingCrescentMoon:"Zunehmende Sichel",waxingGibbousMoon:"Zunehmender Halbmond",waningCrescentMoon:"Abnehmender Halbmond",waningGibbousMoon:"Abnehmende Sichel"},illumination:"Beleuchtung",illuminated:"beleuchtet",moonRise:"Aufgang",moonSet:"Untergang",moonHigh:"Kulmination",moonAge:"Alter",distance:"Entfernung",azimuth:"Azimut",altitude:"Höhe",fullMoon:"Nächster Vollmond",newMoon:"Nächster Neumond",relativeTime:{days:"Tage",justNow:"jetzt",minutesAgo:"vor {0} Minuten",hoursAgo:"vor {0} Stunden",inMinutes:"in {0} Minuten",inHours:"in {0} Stunden"}},re={viewConfig:{title:"Sprach- und Ansichtsmodus",description:"Einstellung der Sprache und des Hintergrunds"},baseConfig:{title:"Breiten- und Längengrad",description:"Breiten- und Längengradkonfiguration"},optionsConfig:{useDefault:"Systemeinstellungen verwenden",useEntity:"Entität verwenden",useCustom:"Benutzerdefinierte Einstellungen verwenden "},fontOptions:{title:"Schriftartanpassungen",description:"Schriftgröße und -farbe festlegen",hideLabel:"Beschriftung ausblenden",headerFontConfig:{title:"Schriftart der Überschrift",description:"Schriftartkonfiguration der Überschrift"},labelFontConfig:{title:"Schriftart des Labels",description:"Schriftartkonfiguration des Labels"},headerFontSize:"Schriftgröße der Überschrift",headerFontColor:"Schriftfarbe der Überschrift",headerFontStyle:"Schriftstil der Überschrift",labelFontSize:"Schriftgröße des Labels",labelFontColor:"Schriftfarbe des Labels",labelFontStyle:"Schriftstil des Labels",valueFontSize:"Schriftgröße der ausgegebenen Werte"},compactView:"Kompakte Ansicht",showBackground:"Hintergrund anzeigen",timeFormat:"12-Stunden-Zeitformat",placeHolder:{latitude:"Breitengrad eingeben",longitude:"Längengrad eingeben",customBackground:"URL oder Pfad zum Hintergrundbild",language:"Sprachauswahl",moonPosition:"Mondposition auf der Karte auswählen"}},Pe={name:ee,nativeName:te,card:ne,editor:re},ze=Object.freeze({__proto__:null,name:ee,nativeName:te,card:ne,editor:re,default:Pe}),fe="English",ve="English",se={phase:{firstQuarterMoon:"First quarter",fullMoon:"Full moon",thirdQuarterMoon:"Last quarter",newMoon:"New moon",waxingCrescentMoon:"Waxing crescent",waxingGibbousMoon:"Waxing gibbous",waningCrescentMoon:"Waning crescent",waningGibbousMoon:"Waning gibbous"},illumination:"Illumination",illuminated:"Illuminated",moonRise:"Moonrise",moonSet:"Moonset",moonHigh:"Moon highest",moonAge:"Moon age",distance:"Distance",azimuth:"Azimuth",altitude:"Altitude",fullMoon:"Full moon",newMoon:"New moon",relativeTime:{days:"days",justNow:"just now",minutesAgo:"{0} minutes ago",hoursAgo:"{0} hours ago",inMinutes:"in {0} minutes",inHours:"in {0} hours"}},ae={viewConfig:{title:"Language and view mode",description:"Set a configuration for language and background"},baseConfig:{title:"Latitude and Longitude",description:"Set a configuration for latitude and longitude"},optionsConfig:{useDefault:"Use system",useEntity:"Use entity",useCustom:"Use custom"},fontOptions:{title:"Font customization",description:"Set a configuration for font size and color",hideLabel:"Hide label",headerFontConfig:{title:"Header font",description:"Set a configuration for header font"},labelFontConfig:{title:"Label font",description:"Set a configuration for label font"},headerFontSize:"Header font size",headerFontColor:"Header font color",headerFontStyle:"Header font style",labelFontSize:"Label font size",labelFontColor:"Label font color",labelFontStyle:"Label font style",valueFontSize:"Value font size"},compactView:"Compact view",showBackground:"Show background",timeFormat:"12-hour time format",placeHolder:{latitude:"Enter latitude",longitude:"Enter longitude",customBackground:"URL or path to image",language:"Select language",moonPosition:"Select moon position on card"}},we={name:fe,nativeName:ve,card:se,editor:ae},De=Object.freeze({__proto__:null,name:fe,nativeName:ve,card:se,editor:ae,default:we}),ce="French",le="Français",de={phase:{firstQuarterMoon:"Premier quartier",fullMoon:"Pleine lune",thirdQuarterMoon:"Dernier quartier",newMoon:"Nouvelle lune",waxingCrescentMoon:"Premier croissant",waxingGibbousMoon:"Lune gibbeuse croissante",waningCrescentMoon:"Dernier croissant",waningGibbousMoon:"Lune gibbeuse décroissante"},illumination:"Illumination",illuminated:"Illuminé",moonRise:"Lever de la lune",moonSet:"Coucher de la lune",moonHigh:"Lune au plus haut",moonAge:"Âge de la lune",distance:"Distance",azimuth:"Azimuth",altitude:"Altitude",fullMoon:"Pleine lune",newMoon:"Nouvelle lune",relativeTime:{days:"jours",justNow:"maintenant",minutesAgo:"il y a {0} minutes",hoursAgo:"il y a {0} heures",inMinutes:"dans {0} minutes",inHours:"dans {0} heures"}},Me={viewConfig:{title:"Langue et affichage",description:"Configuration de la langue et du fond d'écran"},baseConfig:{title:"Latitude et Longitude",description:"Configuration de la latitude et de la longitude"},optionsConfig:{useDefault:"Système",useEntity:"Entitée",useCustom:"Custom"},fontOptions:{title:"Modification polices",description:"Configuration de la taille et couleur des polices",hideLabel:"Cacher label",headerFontConfig:{title:"Police titre",description:"Configuration de la police du titre"},labelFontConfig:{title:"Police label",description:"Configuration de la police du label"},headerFontSize:"Taille police titre",headerFontColor:"Couleur police titre",headerFontStyle:"Style police titre",labelFontSize:"Taille police label",labelFontColor:"Couleur police label",labelFontStyle:"Style police label",valueFontSize:"Valeur taille police"},compactView:"Affichage compact",showBackground:"Afficher fond d'écran",timeFormat:"Format 12h",placeHolder:{latitude:"Entrer latitude",longitude:"Entrer longitude",customBackground:"URL ou chemin vers une image",language:"Langue",moonPosition:"Sélectionnez la position de la lune sur la carte"}},ge={name:ce,nativeName:le,card:de,editor:Me},ue=Object.freeze({__proto__:null,name:ce,nativeName:le,card:de,editor:Me,default:ge}),je="Indonesian",be="Bahasa Indonesia",xe={phase:{firstQuarterMoon:"Bulan Paruh awal",fullMoon:"Bulan purnama ",thirdQuarterMoon:"Bulan Paruh akhir",newMoon:"Bulan baru",waxingCrescentMoon:"Bulan Sabit awal",waxingGibbousMoon:"Bulan Cembung awal",waningCrescentMoon:"Bulan Sabit akhir",waningGibbousMoon:"Bulan Cembung akhir"},illumination:"Pencahayaan bulan",illuminated:"diterangi",moonRise:"Bulan terbit",moonSet:"Bulan terbenam",moonHigh:"Bulan tertinggi",moonAge:"Usia bulan",distance:"Jarak bulan",azimuth:"Azimut bulan",altitude:"Ketinggian bulan",fullMoon:"Bulan purnama berikutnya",newMoon:"Bulan baru berikutnya",relativeTime:{days:"hari",justNow:"baru saja",minutesAgo:"{0} menit yang lalu",hoursAgo:"{0} jam yang lalu",inMinutes:"dalam {0} menit",inHours:"dalam {0} jam"}},Xe={viewConfig:{title:"Bahasa dan mode tampilan",description:"Tetapkan konfigurasi untuk bahasa dan latar belakang"},baseConfig:{title:"Lintang dan Bujur",description:"Tetapkan konfigurasi untuk lintang dan bujur"},optionsConfig:{useDefault:"Gunakan pengaturan dari sistem",useEntity:"Gunakan entitas",useCustom:"Gunakan pengaturan khusus"},fontOptions:{title:"Konfigurasi jenis huruf",description:"Tetapkan konfigurasi untuk ukuran dan warna huruf",hideLabel:"Sembunyikan label",headerFontConfig:{title:"Jenis huruf pada judul",description:"Tetapkan konfigurasi untuk huruf pada judul"},labelFontConfig:{title:"Jenis huruf pada label",description:"Tetapkan konfigurasi untuk huruf pada label"},headerFontSize:"Ukuran huruf pada judul",headerFontColor:"Warna huruf pada judul",headerFontStyle:"Gaya huruf pada judul",labelFontSize:"Ukuran huruf pada label",labelFontColor:"Warna huruf pada label",labelFontStyle:"Gaya huruf pada label",valueFontSize:"Ukuran angka dari nilai yang ditampil"},compactView:"Tampilan kompak",showBackground:"Tampilkan gambar latar belakang",timeFormat:"Format waktu 12 jam",placeHolder:{latitude:"Masukkan garis lintang",longitude:"Masukkan garis bujur",customBackground:"URL atau lokasi penyimpanan gambar",language:"Pilih bahasa",moonPosition:"Pilih posisi bulan pada kartu"}},He={name:je,nativeName:be,card:xe,editor:Xe},We=Object.freeze({__proto__:null,name:je,nativeName:be,card:xe,editor:Xe,default:He}),Be="Italian",Oe="Italiano",pe={phase:{firstQuarterMoon:"Primo Quarto",fullMoon:"Luna piena",thirdQuarterMoon:"Ultimo Quarto",newMoon:"Luna nuova",waxingCrescentMoon:"Luna crescente",waxingGibbousMoon:"Gibbosa crescente",waningCrescentMoon:"Luna calante",waningGibbousMoon:"Gibbosa calante"},illumination:"Illuminazione",illuminated:"Illuminata",moonRise:"Sorgere",moonSet:"Tramonto",moonHigh:"Luna all'altezza massima",moonAge:"Età della Luna",distance:"Distanza",azimuth:"Azimut",altitude:"Altitudine",fullMoon:"Luna piena",newMoon:"Luna nuova",relativeTime:{days:"giorni",justNow:"adesso",minutesAgo:"{0} minuti fa",hoursAgo:"{0} ore fa",inMinutes:"tra {0} minuti",inHours:"tra {0} ore"}},Ze={viewConfig:{title:"Lingua e visualizzazione",description:"Imposta una configurazione per lingua e sfondo"},baseConfig:{title:"Latitudine e Longitudine",description:"Imposta una configurazione per Latitudine e Longitudine"},optionsConfig:{useDefault:"Sistema",useEntity:"Entità",useCustom:"Personalizzata"},fontOptions:{title:"Personalizzazione carattere",description:"Imposta una configurazione per dimensione e colore carattere",hideLabel:"Nascondi etichetta",headerFontConfig:{title:"Carattere intestazione",description:"Imposta una configurazione per carattere intestazione"},labelFontConfig:{title:"Carattere etichetta",description:"Imposta una configurazione per carattere etichetta"},headerFontSize:"Dimensione carattere intestazione",headerFontColor:"Colore carattere intestazione",headerFontStyle:"Stile carattere intestazione",labelFontSize:"Dimensione carattere etichetta",labelFontColor:"Colore carattere etichetta",labelFontStyle:"Stile carattere etichetta",valueFontSize:"Valore dimensione carattere"},compactView:"Visualizzazione compatta",showBackground:"Mostra sfondo",timeFormat:"Formato a 12 ore",placeHolder:{latitude:"Inserisci Latitudine",longitude:"Inserisci Longitudine",customBackground:"URL o percorso dell'immagine",language:"Seleziona lingua",moonPosition:"Seleziona la posizione della luna sulla carta"}},ye={name:Be,nativeName:Oe,card:pe,editor:Ze},Ge=Object.freeze({__proto__:null,name:Be,nativeName:Oe,card:pe,editor:Ze,default:ye}),me="Nederlands",Le="Dutch",Ye={phase:{firstQuarterMoon:"Eerste kwartier",fullMoon:"Volle maan",thirdQuarterMoon:"Laatste kwartier",newMoon:"Nieuwe maan",waxingCrescentMoon:"Afnemende halve maan",waxingGibbousMoon:"Afnemende maan",waningCrescentMoon:"Wassende halve maan",waningGibbousMoon:"Wassende maan"},illumination:"Verlichting ",illuminated:" Verlicht ",moonRise:" Maanopkomst",moonSet:"Maanondergang",moonHigh:"Hoogste punt",moonAge:"Leeftijd",distance:"Afstand",azimuth:"Azimut",altitude:" Hoogte ",fullMoon:"Volle Maan",newMoon:"Nieuwe maan",relativeTime:{days:"dagen",justNow:"nu",minutesAgo:"{0} minute geleden",hoursAgo:"{0} uren geleden",inMinutes:"in {0} minuten",inHours:"in {0} uur"}},oe={viewConfig:{title:"Taal en weergave",description:"Configureer taal en achtergrond"},baseConfig:{title:" Breedtegraad en lengtegraad",description:"Configuratie voor breedte- en lengtegraad"},optionsConfig:{useDefault:" Gebruik systeem",useEntity:"Gebruik entity",useCustom:" Gebruik aangepast "},fontOptions:{title:" Aanpassing van lettertypen ",description:"Configureer lettergrootte en kleur",hideLabel:" Label verbergen",headerFontConfig:{title:" Koptekst lettertype",description:"Stel koptekst lettertype in"},labelFontConfig:{title:"Label lettertype",description:"Stel lettertype labels in"},headerFontSize:"Header font grootte",headerFontColor:"Header font kleur",headerFontStyle:"Header font stijl",labelFontSize:"Label font grootte",labelFontColor:"Label font kleur",labelFontStyle:"Label font stijl",valueFontSize:"Waarde font grootte"},compactView:"Compacte weergave",showBackground:"toon achtergrond",timeFormat:"12-uur formaat",placeHolder:{latitude:"Enter breedtegraad",longitude:"Enter lengtegraad",customBackground:"URL of path naar afbeelding",language:"Seleceer taal",moonPosition:"Selecteer maanpositie op de kaart"}},Ne={name:me,nativeName:Le,card:Ye,editor:oe},ie=Object.freeze({__proto__:null,name:me,nativeName:Le,card:Ye,editor:oe,default:Ne}),Qe="Portuguese",Te="Português (Brasil)",Ce={phase:{firstQuarterMoon:"Primeiro quarto",fullMoon:"Lua cheia",thirdQuarterMoon:"Último quarto",newMoon:"Lua nova",waxingCrescentMoon:"Lua crescente crescente",waxingGibbousMoon:"Lua crescente convexa",waningCrescentMoon:"Lua minguante crescente",waningGibbousMoon:"Lua minguante convexa"},illumination:"Iluminação",illuminated:"Iluminada",moonRise:"Nascer da lua",moonSet:"Pôr da lua",moonHigh:"Lua mais alta",moonAge:"Idade da lua",distance:"Distância",azimuth:"Azimute",altitude:"Altitude",fullMoon:"Lua chei",newMoon:"Lua nova",relativeTime:{days:"dias",justNow:"agora mesmo",minutesAgo:"há {0} minutos",hoursAgo:"há {0} horas",inMinutes:"em {0} minutos",inHours:"em {0} horas"}},Ve={viewConfig:{title:"Idioma e modo de visualização",description:"Definir uma configuração para idioma e plano de fundo"},baseConfig:{title:"Latitude e Longitude",description:"Definir uma configuração para latitude e longitude"},optionsConfig:{useDefault:"Usar sistema",useEntity:"Usar entidade",useCustom:"Usar personalizado"},fontOptions:{title:"Estilização de texto",description:"Definir estilização de texto",hideLabel:"Ocultar rótulo",headerFontConfig:{title:"Título",description:"Definir estilização de título"},labelFontConfig:{title:"Rótulo",description:"Definir estilização de rótulo"},headerFontSize:"Tamanho da fonte do título",headerFontColor:"Cor da fonte do título",headerFontStyle:"Estilo da fonte do título",labelFontSize:"Tamanho da fonte do rótulo",labelFontColor:"Cor da fonte do rótulo",labelFontStyle:"Estilo da fonte do rótulo",valueFontSize:"Tamanho da fonte do valor"},compactView:"Visualização compacta",showBackground:"Mostrar plano de fundo",timeFormat:"Formato de 12 horas",placeHolder:{latitude:"Inserir latitude",longitude:"Inserir longitude",customBackground:"URL ou caminho para a imagem",language:"Selecionar idioma",moonPosition:"Selecione a posição da lua no cartão"}},he={name:Qe,nativeName:Te,card:Ce,editor:Ve},qe=Object.freeze({__proto__:null,name:Qe,nativeName:Te,card:Ce,editor:Ve,default:he}),Ie="Русский",ke="Русский",Ke={phase:{firstQuarterMoon:"Первая четверть",fullMoon:"Полнолуние",thirdQuarterMoon:"Последняя четверть",newMoon:"Новолуние",waxingCrescentMoon:"Растущий полумесяц",waxingGibbousMoon:"Растущая луна",waningCrescentMoon:"Убывающий полумесяц",waningGibbousMoon:"Убывающая луна"},illumination:"Освещенность",illuminated:"Освещено",moonRise:"Восход Луны",moonSet:"Закат Луны",moonHigh:"Луна наивысшая",moonAge:"Возраст Луны",distance:"Расстояние",azimuth:"Азимут",altitude:"Высота",fullMoon:"Полнолуние",newMoon:"Новолуние",relativeTime:{days:"дней",justNow:"только что",minutesAgo:"{0} минут назад",hoursAgo:"{0} часов назад",inMinutes:"через {0} минут",inHours:"через {0} часов"}},Ue={viewConfig:{title:"Язык и режим отображения",description:"Настройка языка и фона"},baseConfig:{title:"Широта и долгота",description:"Настройка широты и долготы"},optionsConfig:{useDefault:"Cистемная",useEntity:"Entity",useCustom:"Ручная"},fontOptions:{title:"Настройка шрифтов",description:"Настройка размера и цвета шрифта",hideLabel:"Скрыть метку",headerFontConfig:{title:"Шрифт заголовка",description:"Настройка шрифта заголовка"},labelFontConfig:{title:"Шрифт метки",description:"Настройка шрифта метки"},headerFontSize:"Размер текста",headerFontColor:"Цвет текста",headerFontStyle:"Стиль",labelFontSize:"Размер текста",labelFontColor:"Цвет текста",labelFontStyle:"Стиль",valueFontSize:"Размер текста"},compactView:"Компактный вид",showBackground:"Показать фон",timeFormat:"12-часовой формат времени",placeHolder:{latitude:"Введите широту",longitude:"Введите долготу",customBackground:"URL или путь к изображению",language:"Выберите язык",moonPosition:"Выберите положение луны на карте"}},Se={name:Ie,nativeName:ke,card:Ke,editor:Ue},Ee=Object.freeze({__proto__:null,name:Ie,nativeName:ke,card:Ke,editor:Ue,default:Se}),Re="Slovak",Je="Slovenčina",Fe={phase:{firstQuarterMoon:"Prvá štvrtina",fullMoon:"Úplnok",thirdQuarterMoon:"Posledná štvrtina",newMoon:"Nov",waxingCrescentMoon:"Dorastajúci kosáčik",waxingGibbousMoon:"Dorastajúci mesiac",waningCrescentMoon:"Ubúdajúci kosáčik",waningGibbousMoon:"Ubúdajúci mesiac"},illumination:"Osvetlenie",illuminated:"Osvetlené",moonRise:"Východ Mesiaca",moonSet:"Západ Mesiaca",moonHigh:"Najvyšší bod Mesiaca",moonAge:"Vek Mesiaca",distance:"Vzdialenosť",azimuth:"Azimut",altitude:"Nadmorská výška",fullMoon:"Úplnok",newMoon:"Nov",relativeTime:{days:"dní",justNow:"práve teraz",minutesAgo:"pred {0} minútami",hoursAgo:"pred {0} hodinami",inMinutes:"za {0} minút",inHours:"za {0} hodín"}},_e={viewConfig:{title:"Jazyk a režim zobrazenia",description:"Nastavte konfiguráciu pre jazyk a pozadie"},baseConfig:{title:"Zemepisná šírka a dĺžka",description:"Nastavte konfiguráciu pre zemepisnú šírku a dĺžku"},optionsConfig:{useDefault:"Použiť systémové",useEntity:"Použiť entitu",useCustom:"Použiť vlastné"},fontOptions:{title:"Prispôsobenie písma",description:"Nastavte konfiguráciu pre veľkosť a farbu písma",hideLabel:"Skryť štítok",headerFontConfig:{title:"Písmo hlavičky",description:"Nastavte konfiguráciu pre písmo hlavičky"},labelFontConfig:{title:"Písmo štítku",description:"Nastavte konfiguráciu pre písmo štítku"},headerFontSize:"Veľkosť písma hlavičky",headerFontColor:"Farba písma hlavičky",headerFontStyle:"Štýl písma hlavičky",labelFontSize:"Veľkosť písma štítku",labelFontColor:"Farba písma štítku",labelFontStyle:"Štýl písma štítku",valueFontSize:"Veľkosť písma hodnoty"},compactView:"Kompaktný pohľad",showBackground:"Zobraziť pozadie",timeFormat:"12-hodinový formát času",placeHolder:{latitude:"Zadajte zemepisnú šírku",longitude:"Zadajte zemepisnú dĺžku",customBackground:"URL alebo cesta k obrázku",language:"Vyberte jazyk",moonPosition:"Vyberte polohu Mesiaca na karte"}},$e={name:Re,nativeName:Je,card:Fe,editor:_e},At=Object.freeze({__proto__:null,name:Re,nativeName:Je,card:Fe,editor:_e,default:$e});const et={ca:qA,cs:EA,da:Ae,de:ze,en:De,fr:ue,id:We,it:Ge,nl:ie,pt:qe,ru:Ee,sk:At},tt=[{key:"ca",name:QA,nativeName:TA},{key:"cs",name:IA,nativeName:kA},{key:"da",name:RA,nativeName:JA},{key:"de",name:ee,nativeName:te},{key:"en",name:fe,nativeName:ve},{key:"fr",name:ce,nativeName:le},{key:"id",name:je,nativeName:be},{key:"it",name:Be,nativeName:Oe},{key:"nl",name:me,nativeName:Le},{key:"pt",name:Qe,nativeName:Te},{key:"ru",name:Ie,nativeName:ke},{key:"sk",name:Re,nativeName:Je}];function nt(A,e,t="",n=""){const r=e.replace(/['"]+/g,"").replace("-","_");let P;try{P=A.split(".").reduce(((A,e)=>A[e]),et[r])}catch(e){P=A.split(".").reduce(((A,e)=>A[e]),et.en)}return void 0!==P&&""!==P||(P=A.split(".").reduce(((A,e)=>A[e]),et.en)),""!==t&&""!==n&&(P=P.replace(t,n)),P}const rt=Math.sin,Pt=Math.cos,zt=Math.tan,ft=Math.asin,vt=Math.atan2,st=Math.acos,at=Math.PI/180,wt=180/Math.PI,Dt=864e5,ct=2440587.5,lt=2451545,dt=2551442778,Mt=94717884e4;function gt(A){return A/Dt+ct-lt}const ut=23.4397*at;function jt(A,e){return vt(rt(A)*Pt(ut)-zt(e)*rt(ut),Pt(A))}function bt(A,e){return ft(rt(e)*Pt(ut)+Pt(e)*rt(ut)*rt(A))}function xt(A,e,t){return vt(rt(A),Pt(A)*rt(e)-zt(t)*Pt(e))+Math.PI}function Xt(A,e,t){return ft(rt(e)*rt(t)+Pt(e)*Pt(t)*Pt(A))}function Ht(A,e){return at*(280.16+360.9856235*A)-e}function Wt(A){return A<0&&(A=0),2967e-7/Math.tan(A+.00312536/(A+.08901179))}function Bt(A){return at*(357.5291+.98560028*A)}function Ot(A){return A+at*(1.9148*rt(A)+.02*rt(2*A)+3e-4*rt(3*A))+102.9372*at+Math.PI}function pt(A){const e=Ot(Bt(A));return{dec:bt(e,0),ra:jt(e,0)}}function Zt(A){const e=at*(134.963+13.064993*A),t=at*(93.272+13.22935*A),n=at*(218.316+13.176396*A)+6.289*at*rt(e),r=5.128*at*rt(t),P=385001-20905*Pt(e);return{ra:jt(n,r),dec:bt(n,r),dist:P}}function yt(A,e,t){if(isNaN(e))throw new Error("latitude missing");if(isNaN(t))throw new Error("longitude missing");A instanceof Date&&(A=A.valueOf());const n=at*-t,r=at*e,P=gt(A),z=Zt(P),f=Ht(P,n)-z.ra;let v=Xt(f,r,z.dec);v+=Wt(v);const s=vt(rt(f),zt(r)*Pt(z.dec)-rt(z.dec)*Pt(f)),a=xt(f,r,z.dec);return{azimuth:a,altitude:v,azimuthDegrees:wt*a,altitudeDegrees:wt*v,distance:z.dist,parallacticAngle:s,parallacticAngleDegrees:wt*s}}const Gt=[{from:0,to:.033863193308711,id:"newMoon",emoji:"🌚",code:":new_moon_with_face:",name:"New Moon",weight:1,css:"wi-moon-new"},{from:.033863193308711,to:.216136806691289,id:"waxingCrescentMoon",emoji:"🌒",code:":waxing_crescent_moon:",name:"Waxing Crescent",weight:6.3825,css:"wi-moon-wax-cres"},{from:.216136806691289,to:.283863193308711,id:"firstQuarterMoon",emoji:"🌓",code:":first_quarter_moon:",name:"First Quarter",weight:1,css:"wi-moon-first-quart"},{from:.283863193308711,to:.466136806691289,id:"waxingGibbousMoon",emoji:"🌔",code:":waxing_gibbous_moon:",name:"Waxing Gibbous",weight:6.3825,css:"wi-moon-wax-gibb"},{from:.466136806691289,to:.533863193308711,id:"fullMoon",emoji:"🌝",code:":full_moon_with_face:",name:"Full Moon",weight:1,css:"wi-moon-full"},{from:.533863193308711,to:.716136806691289,id:"waningGibbousMoon",emoji:"🌖",code:":waning_gibbous_moon:",name:"Waning Gibbous",weight:6.3825,css:"wi-moon-wan-gibb"},{from:.716136806691289,to:.783863193308711,id:"thirdQuarterMoon",emoji:"🌗",code:":last_quarter_moon:",name:"third Quarter",weight:1,css:"wi-moon-third-quart"},{from:.783863193308711,to:.966136806691289,id:"waningCrescentMoon",emoji:"🌘",code:":waning_crescent_moon:",name:"Waning Crescent",weight:6.3825,css:"wi-moon-wan-cres"},{from:.966136806691289,to:1,id:"newMoon",emoji:"🌚",code:":new_moon_with_face:",name:"New Moon",weight:1,css:"wi-moon-new"}],mt=Gt;function Lt(A){A instanceof Date&&(A=A.valueOf());const e=gt(A),t=pt(e),n=Zt(e),r=149598e3,P=st(rt(t.dec)*rt(n.dec)+Pt(t.dec)*Pt(n.dec)*Pt(t.ra-n.ra)),z=vt(r*rt(P),n.dist-r*Pt(P)),f=vt(Pt(t.dec)*rt(t.ra-n.ra),rt(t.dec)*Pt(n.dec)-Pt(t.dec)*rt(n.dec)*Pt(t.ra-n.ra)),v=.5+.5*z*(f<0?-1:1)/Math.PI;let s=(A-Mt)%dt;s<0&&(s+=dt);const a=dt-s+A;let w=dt/2-s+A;w=e.from&&v<=e.to){M=e;break}}return{fraction:(1+Pt(z))/2,phase:M,phaseValue:v,angle:f,next:{value:d,date:new Date(d).toISOString(),type:d===a?"newMoon":d===c?"firstQuarter":d===w?"fullMoon":"thirdQuarter",newMoon:{value:a,date:new Date(a).toISOString()},fullMoon:{value:w,date:new Date(w).toISOString()},firstQuarter:{value:c,date:new Date(c).toISOString()},thirdQuarter:{value:l,date:new Date(l).toISOString()}}}}function Yt(A,e,t){const n=yt(A,e,t),r=Lt(A);return Object.assign({illumination:r,zenithAngle:r.angle-n.parallacticAngle},n)}function ot(A,e){return A+e*Dt/24}function Nt(A,e,t,n){if(isNaN(e))throw new Error("latitude missing");if(isNaN(t))throw new Error("longitude missing");const r=new Date(A);n?r.setUTCHours(0,0,0,0):r.setHours(0,0,0,0),A=r.valueOf();const P=.133*at;let z,f,v,s,a,w,D,c,l=yt(A,e,t).altitude-P;for(let n=1;n<=26;n+=2){const r=yt(ot(A,n),e,t).altitude-P,d=yt(ot(A,n+1),e,t).altitude-P,M=(l+d)/2-r,g=(d-l)/2,u=-g/(2*M);if(v=(M*u+g)*u+r,s=g*g-4*M*r,a=0,s>=0&&(c=Math.sqrt(s)/(2*Math.abs(M)),w=u-c,D=u+c,Math.abs(w)<=1&&a++,Math.abs(D)<=1&&a++,w<-1&&(w=D)),1===a?l<0?z=n+w:f=n+w:2===a&&(z=n+(v<0?D:w),f=n+(v<0?w:D)),z&&f)break;l=d}const d={};return d.rise=z?new Date(ot(A,z)):NaN,d.set=f?new Date(ot(A,f)):NaN,z||f?z&&f?(d.alwaysUp=!1,d.alwaysDown=!1,d.highest=new Date(ot(A,Math.min(z,f)+Math.abs(f-z)/2))):(d.alwaysUp=!1,d.alwaysDown=!1):v>0?(d.alwaysUp=!0,d.alwaysDown=!1):(d.alwaysUp=!1,d.alwaysDown=!0),d}function it(A,e){return A>e?new Date(e+(A-e)/2):new Date(A+(e-A)/2)}function Qt(A,e,t,n){let r=null,P=null;const z=new Date(A),f=new Date(e),v=z.getTime(),s=f.getTime(),a=f.getDate();let w,D;return A&&e&&(A0?{key:"card.relativeTime.inMinutes",value:A.toString()}:{key:"card.relativeTime.minutesAgo",value:Math.abs(A).toString()}}return r>0?{key:"card.relativeTime.inHours",value:r.toString()}:{key:"card.relativeTime.hoursAgo",value:Math.abs(r).toString()}}return{key:""}}function Ct(A,e,t){if(!A||""===A)return"";const n=e||"en-US";return new Date(A).toLocaleTimeString(n,{hour:"2-digit",minute:"2-digit",hour12:t})}function Vt(A,e){A=A.startsWith("v")?A.slice(1):A,e=e.startsWith("v")?e.slice(1):e;const t=A.split(/[\.-]/).map((A=>isNaN(A)?A:parseInt(A,10))),n=e.split(/[\.-]/).map((A=>isNaN(A)?A:parseInt(A,10)));for(let A=0;Ar)return 1;if(er)return 1;if(ent(A,this.lang,e,t),this.createItem=(A,e,t,n)=>({label:this.localize(`card.${A}`),value:`${e}${t?` ${t}`:""}`,secondValue:n?`${n}`:""}),this.createMoonTime=(A,e)=>{const t=this.config["12hr_format"]||!1,n=Ct(new Date(e).toISOString(),this.lang,t),r=(A=>{const e=Tt(new Date(A).toISOString());return e.value?this.localize(e.key,"{0}",e.value):this.localize(e.key)})(e);return this.createItem(A,n,"",r)},this._getMoonTime=A=>Nt(A,this.location.latitude,this.location.longitude),this._getMoonTransit=(A,e)=>Qt(A,e,this.location.latitude,this.location.longitude),this._getAltituteData=(A,e,t)=>{const n={};for(let r=0;r{const A=new Date,e=new Date(A.setHours(0,0,0,0)),t=new Date(A.setHours(23,59,59,999)),n=Yt(A,this.location.latitude,this.location.longitude),{zenithAngle:r,parallacticAngle:P}=n,z=(r-P)*(180/Math.PI),f={};f.time=Nt(A,this.location.latitude,this.location.longitude);const v=this._getAltituteData(e,t,24);return f.altitude=v,f.moonPhase=Lt(A),f.moonPhase=Object.assign(Object.assign({},f.moonPhase),{emojiRotation:z}),f.lang={rise:this.localize("card.moonRise"),set:this.localize("card.moonSet")},f},this._date=A.date,this.lang=A.lang,this.config=A.config,this.location={latitude:A.config.latitude,longitude:A.config.longitude}}get _moonTime(){return Nt(this._date,this.location.latitude,this.location.longitude)}get _moonData(){return Yt(this._date,this.location.latitude,this.location.longitude)}get moonTransit(){return Qt(this._moonTime.rise,this._moonTime.set,this.location.latitude,this.location.longitude)}get phaseName(){return this.localize(`card.phase.${this._moonData.illumination.phase.id}`)}get moonImage(){const A=Math.floor(31*this._moonData.illumination.phaseValue)%31,{zenithAngle:e,parallacticAngle:t}=this._moonData,n=(e-t)*(180/Math.PI);return{moonPic:un[A],rotateDeg:n}}_getMoonRotation(){const{zenithAngle:A,parallacticAngle:e}=this._moonData;return(A-e)*(180/Math.PI)}get moonData(){const{createItem:A,createMoonTime:e}=this,t=A=>new Date(A).toLocaleDateString(this.lang,{weekday:"short",month:"short",day:"numeric"}),{distance:n,azimuthDegrees:r,altitudeDegrees:P}=this._moonData,{fraction:z,phaseValue:f}=this._moonData.illumination,{fullMoon:v,newMoon:s}=this._moonData.illumination.next,{rise:a,set:w,highest:D}=this._moonTime;return{moonFraction:A("illumination",`${(100*z).toFixed(2)}%`),moonAge:A("moonAge",`${(29.53*f).toFixed(2)}`,this.localize("card.relativeTime.days")),moonRise:e("moonRise",a),moonSet:e("moonSet",w),moonHighest:D?e("moonHigh",D):void 0,distance:A("distance",n.toFixed(2),"km"),azimuthDegress:A("azimuth",r.toFixed(2),"°"),altitudeDegrees:A("altitude",P.toFixed(2),"°"),nextFullMoon:A("fullMoon",t(v.value)),nextNewMoon:A("newMoon",t(s.value))}}}function bn(A){return null!==A&&"object"==typeof A&&"constructor"in A&&A.constructor===Object}function xn(A,e){void 0===A&&(A={}),void 0===e&&(e={}),Object.keys(e).forEach((t=>{void 0===A[t]?A[t]=e[t]:bn(e[t])&&bn(A[t])&&Object.keys(e[t]).length>0&&xn(A[t],e[t])}))}const Xn={body:{},addEventListener(){},removeEventListener(){},activeElement:{blur(){},nodeName:""},querySelector:()=>null,querySelectorAll:()=>[],getElementById:()=>null,createEvent:()=>({initEvent(){}}),createElement:()=>({children:[],childNodes:[],style:{},setAttribute(){},getElementsByTagName:()=>[]}),createElementNS:()=>({}),importNode:()=>null,location:{hash:"",host:"",hostname:"",href:"",origin:"",pathname:"",protocol:"",search:""}};function Hn(){const A="undefined"!=typeof document?document:{};return xn(A,Xn),A}const Wn={document:Xn,navigator:{userAgent:""},location:{hash:"",host:"",hostname:"",href:"",origin:"",pathname:"",protocol:"",search:""},history:{replaceState(){},pushState(){},go(){},back(){}},CustomEvent:function(){return this},addEventListener(){},removeEventListener(){},getComputedStyle:()=>({getPropertyValue:()=>""}),Image(){},Date(){},screen:{},setTimeout(){},clearTimeout(){},matchMedia:()=>({}),requestAnimationFrame:A=>"undefined"==typeof setTimeout?(A(),null):setTimeout(A,0),cancelAnimationFrame(A){"undefined"!=typeof setTimeout&&clearTimeout(A)}};function Bn(){const A="undefined"!=typeof window?window:{};return xn(A,Wn),A}function On(A){return void 0===A&&(A=""),A.trim().split(" ").filter((A=>!!A.trim()))}function pn(A){const e=A;Object.keys(e).forEach((A=>{try{e[A]=null}catch(A){}try{delete e[A]}catch(A){}}))}function Zn(A,e){return void 0===e&&(e=0),setTimeout(A,e)}function yn(){return Date.now()}function Gn(A){const e=Bn();let t;return e.getComputedStyle&&(t=e.getComputedStyle(A,null)),!t&&A.currentStyle&&(t=A.currentStyle),t||(t=A.style),t}function mn(A,e){void 0===e&&(e="x");const t=Bn();let n,r,P;const z=Gn(A);return t.WebKitCSSMatrix?(r=z.transform||z.webkitTransform,r.split(",").length>6&&(r=r.split(", ").map((A=>A.replace(",","."))).join(", ")),P=new t.WebKitCSSMatrix("none"===r?"":r)):(P=z.MozTransform||z.OTransform||z.MsTransform||z.msTransform||z.transform||z.getPropertyValue("transform").replace("translate(","matrix(1, 0, 0, 1,"),n=P.toString().split(",")),"x"===e&&(r=t.WebKitCSSMatrix?P.m41:16===n.length?parseFloat(n[12]):parseFloat(n[4])),"y"===e&&(r=t.WebKitCSSMatrix?P.m42:16===n.length?parseFloat(n[13]):parseFloat(n[5])),r||0}function Ln(A){return"object"==typeof A&&null!==A&&A.constructor&&"Object"===Object.prototype.toString.call(A).slice(8,-1)}function Yn(A){return"undefined"!=typeof window&&void 0!==window.HTMLElement?A instanceof HTMLElement:A&&(1===A.nodeType||11===A.nodeType)}function on(){const A=Object(arguments.length<=0?void 0:arguments[0]),e=["__proto__","constructor","prototype"];for(let t=1;te.indexOf(A)<0));for(let e=0,r=t.length;eP?"next":"prev",a=(A,e)=>"next"===s&&A>=e||"prev"===s&&A<=e,w=()=>{z=(new Date).getTime(),null===f&&(f=z);const A=Math.max(Math.min((z-f)/v,1),0),s=.5-Math.cos(A*Math.PI)/2;let D=P+s*(t-P);if(a(D,t)&&(D=t),e.wrapperEl.scrollTo({[n]:D}),a(D,t))return e.wrapperEl.style.overflow="hidden",e.wrapperEl.style.scrollSnapType="",setTimeout((()=>{e.wrapperEl.style.overflow="",e.wrapperEl.scrollTo({[n]:D})})),void r.cancelAnimationFrame(e.cssModeFrameID);e.cssModeFrameID=r.requestAnimationFrame(w)};w()}function Tn(A,e){return void 0===e&&(e=""),[...A.children].filter((A=>A.matches(e)))}function Cn(A){try{return void console.warn(A)}catch(A){}}function Vn(A,e){void 0===e&&(e=[]);const t=document.createElement(A);return t.classList.add(...Array.isArray(e)?e:On(e)),t}function hn(A,e){const t=[];for(;A.previousElementSibling;){const n=A.previousElementSibling;e?n.matches(e)&&t.push(n):t.push(n),A=n}return t}function qn(A,e){const t=[];for(;A.nextElementSibling;){const n=A.nextElementSibling;e?n.matches(e)&&t.push(n):t.push(n),A=n}return t}function In(A,e){return Bn().getComputedStyle(A,null).getPropertyValue(e)}function kn(A){let e,t=A;if(t){for(e=0;null!==(t=t.previousSibling);)1===t.nodeType&&(e+=1);return e}}function Kn(A,e){const t=[];let n=A.parentElement;for(;n;)e?n.matches(e)&&t.push(n):t.push(n),n=n.parentElement;return t}function Un(A,e,t){const n=Bn();return t?A["width"===e?"offsetWidth":"offsetHeight"]+parseFloat(n.getComputedStyle(A,null).getPropertyValue("width"===e?"margin-right":"margin-top"))+parseFloat(n.getComputedStyle(A,null).getPropertyValue("width"===e?"margin-left":"margin-bottom")):A.offsetWidth}function Sn(A){return(Array.isArray(A)?A:[A]).filter((A=>!!A))}let En,Rn,Jn;function Fn(){const A=Bn(),e=Hn();return{smoothScroll:e.documentElement&&e.documentElement.style&&"scrollBehavior"in e.documentElement.style,touch:!!("ontouchstart"in A||A.DocumentTouch&&e instanceof A.DocumentTouch)}}function _n(){return En||(En=Fn()),En}function $n(A){let{userAgent:e}=void 0===A?{}:A;const t=_n(),n=Bn(),r=n.navigator.platform,P=e||n.navigator.userAgent,z={ios:!1,android:!1},f=n.screen.width,v=n.screen.height,s=P.match(/(Android);?[\s\/]+([\d.]+)?/);let a=P.match(/(iPad).*OS\s([\d_]+)/);const w=P.match(/(iPod)(.*OS\s([\d_]+))?/),D=!a&&P.match(/(iPhone\sOS|iOS)\s([\d_]+)/),c="Win32"===r;let l="MacIntel"===r;return!a&&l&&t.touch&&["1024x1366","1366x1024","834x1194","1194x834","834x1112","1112x834","768x1024","1024x768","820x1180","1180x820","810x1080","1080x810"].indexOf(`${f}x${v}`)>=0&&(a=P.match(/(Version)\/([\d.]+)/),a||(a=[0,1,"13_0_0"]),l=!1),s&&!c&&(z.os="android",z.android=!0),(a||D||w)&&(z.os="ios",z.ios=!0),z}function Ar(A){return void 0===A&&(A={}),Rn||(Rn=$n(A)),Rn}function er(){const A=Bn(),e=Ar();let t=!1;function n(){const e=A.navigator.userAgent.toLowerCase();return e.indexOf("safari")>=0&&e.indexOf("chrome")<0&&e.indexOf("android")<0}if(n()){const e=String(A.navigator.userAgent);if(e.includes("Version/")){const[A,n]=e.split("Version/")[1].split(" ")[0].split(".").map((A=>Number(A)));t=A<16||16===A&&n<2}}const r=/(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(A.navigator.userAgent),P=n();return{isSafari:t||P,needPerspectiveFix:t,need3dFix:P||r&&e.ios,isWebView:r}}function tr(){return Jn||(Jn=er()),Jn}function nr(A){let{swiper:e,on:t,emit:n}=A;const r=Bn();let P=null,z=null;const f=()=>{e&&!e.destroyed&&e.initialized&&(n("beforeResize"),n("resize"))},v=()=>{e&&!e.destroyed&&e.initialized&&n("orientationchange")};t("init",(()=>{e.params.resizeObserver&&void 0!==r.ResizeObserver?e&&!e.destroyed&&e.initialized&&(P=new ResizeObserver((A=>{z=r.requestAnimationFrame((()=>{const{width:t,height:n}=e;let r=t,P=n;A.forEach((A=>{let{contentBoxSize:t,contentRect:n,target:z}=A;z&&z!==e.el||(r=n?n.width:(t[0]||t).inlineSize,P=n?n.height:(t[0]||t).blockSize)})),r===t&&P===n||f()}))})),P.observe(e.el)):(r.addEventListener("resize",f),r.addEventListener("orientationchange",v))})),t("destroy",(()=>{z&&r.cancelAnimationFrame(z),P&&P.unobserve&&e.el&&(P.unobserve(e.el),P=null),r.removeEventListener("resize",f),r.removeEventListener("orientationchange",v)}))}function rr(A){let{swiper:e,extendParams:t,on:n,emit:r}=A;const P=[],z=Bn(),f=function(A,t){void 0===t&&(t={});const n=new(z.MutationObserver||z.WebkitMutationObserver)((A=>{if(e.__preventObserver__)return;if(1===A.length)return void r("observerUpdate",A[0]);const t=function(){r("observerUpdate",A[0])};z.requestAnimationFrame?z.requestAnimationFrame(t):z.setTimeout(t,0)}));n.observe(A,{attributes:void 0===t.attributes||t.attributes,childList:void 0===t.childList||t.childList,characterData:void 0===t.characterData||t.characterData}),P.push(n)};t({observer:!1,observeParents:!1,observeSlideChildren:!1}),n("init",(()=>{if(e.params.observer){if(e.params.observeParents){const A=Kn(e.hostEl);for(let e=0;e{P.forEach((A=>{A.disconnect()})),P.splice(0,P.length)}))}var Pr={on(A,e,t){const n=this;if(!n.eventsListeners||n.destroyed)return n;if("function"!=typeof e)return n;const r=t?"unshift":"push";return A.split(" ").forEach((A=>{n.eventsListeners[A]||(n.eventsListeners[A]=[]),n.eventsListeners[A][r](e)})),n},once(A,e,t){const n=this;if(!n.eventsListeners||n.destroyed)return n;if("function"!=typeof e)return n;function r(){n.off(A,r),r.__emitterProxy&&delete r.__emitterProxy;for(var t=arguments.length,P=new Array(t),z=0;z=0&&e.eventsAnyListeners.splice(t,1),e},off(A,e){const t=this;return!t.eventsListeners||t.destroyed?t:t.eventsListeners?(A.split(" ").forEach((A=>{void 0===e?t.eventsListeners[A]=[]:t.eventsListeners[A]&&t.eventsListeners[A].forEach(((n,r)=>{(n===e||n.__emitterProxy&&n.__emitterProxy===e)&&t.eventsListeners[A].splice(r,1)}))})),t):t},emit(){const A=this;if(!A.eventsListeners||A.destroyed)return A;if(!A.eventsListeners)return A;let e,t,n;for(var r=arguments.length,P=new Array(r),z=0;z{A.eventsAnyListeners&&A.eventsAnyListeners.length&&A.eventsAnyListeners.forEach((A=>{A.apply(n,[e,...t])})),A.eventsListeners&&A.eventsListeners[e]&&A.eventsListeners[e].forEach((A=>{A.apply(n,t)}))})),A}};function zr(){const A=this;let e,t;const n=A.el;e=void 0!==A.params.width&&null!==A.params.width?A.params.width:n.clientWidth,t=void 0!==A.params.height&&null!==A.params.height?A.params.height:n.clientHeight,0===e&&A.isHorizontal()||0===t&&A.isVertical()||(e=e-parseInt(In(n,"padding-left")||0,10)-parseInt(In(n,"padding-right")||0,10),t=t-parseInt(In(n,"padding-top")||0,10)-parseInt(In(n,"padding-bottom")||0,10),Number.isNaN(e)&&(e=0),Number.isNaN(t)&&(t=0),Object.assign(A,{width:e,height:t,size:A.isHorizontal()?e:t}))}function fr(){const A=this;function e(e,t){return parseFloat(e.getPropertyValue(A.getDirectionLabel(t))||0)}const t=A.params,{wrapperEl:n,slidesEl:r,size:P,rtlTranslate:z,wrongRTL:f}=A,v=A.virtual&&t.virtual.enabled,s=v?A.virtual.slides.length:A.slides.length,a=Tn(r,`.${A.params.slideClass}, swiper-slide`),w=v?A.virtual.slides.length:a.length;let D=[];const c=[],l=[];let d=t.slidesOffsetBefore;"function"==typeof d&&(d=t.slidesOffsetBefore.call(A));let M=t.slidesOffsetAfter;"function"==typeof M&&(M=t.slidesOffsetAfter.call(A));const g=A.snapGrid.length,u=A.slidesGrid.length;let j=t.spaceBetween,b=-d,x=0,X=0;if(void 0===P)return;"string"==typeof j&&j.indexOf("%")>=0?j=parseFloat(j.replace("%",""))/100*P:"string"==typeof j&&(j=parseFloat(j)),A.virtualSize=-j,a.forEach((A=>{z?A.style.marginLeft="":A.style.marginRight="",A.style.marginBottom="",A.style.marginTop=""})),t.centeredSlides&&t.cssMode&&(Nn(n,"--swiper-centered-offset-before",""),Nn(n,"--swiper-centered-offset-after",""));const H=t.grid&&t.grid.rows>1&&A.grid;let W;H?A.grid.initSlides(a):A.grid&&A.grid.unsetSlides();const B="auto"===t.slidesPerView&&t.breakpoints&&Object.keys(t.breakpoints).filter((A=>void 0!==t.breakpoints[A].slidesPerView)).length>0;for(let n=0;n1&&D.push(A.virtualSize-P)}if(v&&t.loop){const e=l[0]+j;if(t.slidesPerGroup>1){const n=Math.ceil((A.virtual.slidesBefore+A.virtual.slidesAfter)/t.slidesPerGroup),r=e*t.slidesPerGroup;for(let A=0;A!(t.cssMode&&!t.loop)||e!==a.length-1)).forEach((A=>{A.style[e]=`${j}px`}))}if(t.centeredSlides&&t.centeredSlidesBounds){let A=0;l.forEach((e=>{A+=e+(j||0)})),A-=j;const e=A-P;D=D.map((A=>A<=0?-d:A>e?e+M:A))}if(t.centerInsufficientSlides){let A=0;l.forEach((e=>{A+=e+(j||0)})),A-=j;const e=(t.slidesOffsetBefore||0)+(t.slidesOffsetAfter||0);if(A+e{D[e]=A-t})),c.forEach(((A,e)=>{c[e]=A+t}))}}if(Object.assign(A,{slides:a,snapGrid:D,slidesGrid:c,slidesSizesGrid:l}),t.centeredSlides&&t.cssMode&&!t.centeredSlidesBounds){Nn(n,"--swiper-centered-offset-before",-D[0]+"px"),Nn(n,"--swiper-centered-offset-after",A.size/2-l[l.length-1]/2+"px");const e=-A.snapGrid[0],t=-A.slidesGrid[0];A.snapGrid=A.snapGrid.map((A=>A+e)),A.slidesGrid=A.slidesGrid.map((A=>A+t))}if(w!==s&&A.emit("slidesLengthChange"),D.length!==g&&(A.params.watchOverflow&&A.checkOverflow(),A.emit("snapGridLengthChange")),c.length!==u&&A.emit("slidesGridLengthChange"),t.watchSlidesProgress&&A.updateSlidesOffset(),A.emit("slidesUpdated"),!(v||t.cssMode||"slide"!==t.effect&&"fade"!==t.effect)){const e=`${t.containerModifierClass}backface-hidden`,n=A.el.classList.contains(e);w<=t.maxBackfaceHiddenSlides?n||A.el.classList.add(e):n&&A.el.classList.remove(e)}}function vr(A){const e=this,t=[],n=e.virtual&&e.params.virtual.enabled;let r,P=0;"number"==typeof A?e.setTransition(A):!0===A&&e.setTransition(e.params.speed);const z=A=>n?e.slides[e.getSlideIndexByData(A)]:e.slides[A];if("auto"!==e.params.slidesPerView&&e.params.slidesPerView>1)if(e.params.centeredSlides)(e.visibleSlides||[]).forEach((A=>{t.push(A)}));else for(r=0;re.slides.length&&!n)break;t.push(z(A))}else t.push(z(e.activeIndex));for(r=0;rP?A:P}(P||0===P)&&(e.wrapperEl.style.height=`${P}px`)}function sr(){const A=this,e=A.slides,t=A.isElement?A.isHorizontal()?A.wrapperEl.offsetLeft:A.wrapperEl.offsetTop:0;for(let n=0;n{e&&!A.classList.contains(t)?A.classList.add(t):!e&&A.classList.contains(t)&&A.classList.remove(t)};function wr(A){void 0===A&&(A=this&&this.translate||0);const e=this,t=e.params,{slides:n,rtlTranslate:r,snapGrid:P}=e;if(0===n.length)return;void 0===n[0].swiperSlideOffset&&e.updateSlidesOffset();let z=-A;r&&(z=A),e.visibleSlidesIndexes=[],e.visibleSlides=[];let f=t.spaceBetween;"string"==typeof f&&f.indexOf("%")>=0?f=parseFloat(f.replace("%",""))/100*e.size:"string"==typeof f&&(f=parseFloat(f));for(let A=0;A=0&&D<=e.size-e.slidesSizesGrid[A],d=D>=0&&D1&&c<=e.size||D<=0&&c>=e.size;d&&(e.visibleSlides.push(v),e.visibleSlidesIndexes.push(A)),ar(v,d,t.slideVisibleClass),ar(v,l,t.slideFullyVisibleClass),v.progress=r?-a:a,v.originalProgress=r?-w:w}}function Dr(A){const e=this;if(void 0===A){const t=e.rtlTranslate?-1:1;A=e&&e.translate&&e.translate*t||0}const t=e.params,n=e.maxTranslate()-e.minTranslate();let{progress:r,isBeginning:P,isEnd:z,progressLoop:f}=e;const v=P,s=z;if(0===n)r=0,P=!0,z=!0;else{r=(A-e.minTranslate())/n;const t=Math.abs(A-e.minTranslate())<1,f=Math.abs(A-e.maxTranslate())<1;P=t||r<=0,z=f||r>=1,t&&(r=0),f&&(r=1)}if(t.loop){const t=e.getSlideIndexByData(0),n=e.getSlideIndexByData(e.slides.length-1),r=e.slidesGrid[t],P=e.slidesGrid[n],z=e.slidesGrid[e.slidesGrid.length-1],v=Math.abs(A);f=v>=r?(v-r)/z:(v+z-P)/z,f>1&&(f-=1)}Object.assign(e,{progress:r,progressLoop:f,isBeginning:P,isEnd:z}),(t.watchSlidesProgress||t.centeredSlides&&t.autoHeight)&&e.updateSlidesProgress(A),P&&!v&&e.emit("reachBeginning toEdge"),z&&!s&&e.emit("reachEnd toEdge"),(v&&!P||s&&!z)&&e.emit("fromEdge"),e.emit("progress",r)}const cr=(A,e,t)=>{e&&!A.classList.contains(t)?A.classList.add(t):!e&&A.classList.contains(t)&&A.classList.remove(t)};function lr(){const A=this,{slides:e,params:t,slidesEl:n,activeIndex:r}=A,P=A.virtual&&t.virtual.enabled,z=A.grid&&t.grid&&t.grid.rows>1,f=A=>Tn(n,`.${t.slideClass}${A}, swiper-slide${A}`)[0];let v,s,a;if(P)if(t.loop){let e=r-A.virtual.slidesBefore;e<0&&(e=A.virtual.slides.length+e),e>=A.virtual.slides.length&&(e-=A.virtual.slides.length),v=f(`[data-swiper-slide-index="${e}"]`)}else v=f(`[data-swiper-slide-index="${r}"]`);else z?(v=e.filter((A=>A.column===r))[0],a=e.filter((A=>A.column===r+1))[0],s=e.filter((A=>A.column===r-1))[0]):v=e[r];v&&(z||(a=qn(v,`.${t.slideClass}, swiper-slide`)[0],t.loop&&!a&&(a=e[0]),s=hn(v,`.${t.slideClass}, swiper-slide`)[0],t.loop&&0===!s&&(s=e[e.length-1]))),e.forEach((A=>{cr(A,A===v,t.slideActiveClass),cr(A,A===a,t.slideNextClass),cr(A,A===s,t.slidePrevClass)})),A.emitSlidesClasses()}const dr=(A,e)=>{if(!A||A.destroyed||!A.params)return;const t=e.closest(A.isElement?"swiper-slide":`.${A.params.slideClass}`);if(t){let e=t.querySelector(`.${A.params.lazyPreloaderClass}`);!e&&A.isElement&&(t.shadowRoot?e=t.shadowRoot.querySelector(`.${A.params.lazyPreloaderClass}`):requestAnimationFrame((()=>{t.shadowRoot&&(e=t.shadowRoot.querySelector(`.${A.params.lazyPreloaderClass}`),e&&e.remove())}))),e&&e.remove()}},Mr=(A,e)=>{if(!A.slides[e])return;const t=A.slides[e].querySelector('[loading="lazy"]');t&&t.removeAttribute("loading")},gr=A=>{if(!A||A.destroyed||!A.params)return;let e=A.params.lazyPreloadPrevNext;const t=A.slides.length;if(!t||!e||e<0)return;e=Math.min(e,t);const n="auto"===A.params.slidesPerView?A.slidesPerViewDynamic():Math.ceil(A.params.slidesPerView),r=A.activeIndex;if(A.params.grid&&A.params.grid.rows>1){const t=r,P=[t-e];return P.push(...Array.from({length:e}).map(((A,e)=>t+n+e))),void A.slides.forEach(((e,t)=>{P.includes(e.column)&&Mr(A,t)}))}const P=r+n-1;if(A.params.rewind||A.params.loop)for(let n=r-e;n<=P+e;n+=1){const e=(n%t+t)%t;(eP)&&Mr(A,e)}else for(let n=Math.max(r-e,0);n<=Math.min(P+e,t-1);n+=1)n!==r&&(n>P||n=e[A]&&n=e[A]&&n=e[A]&&(r=A);return t.normalizeSlideIndex&&(r<0||void 0===r)&&(r=0),r}function jr(A){const e=this,t=e.rtlTranslate?e.translate:-e.translate,{snapGrid:n,params:r,activeIndex:P,realIndex:z,snapIndex:f}=e;let v,s=A;const a=A=>{let t=A-e.virtual.slidesBefore;return t<0&&(t=e.virtual.slides.length+t),t>=e.virtual.slides.length&&(t-=e.virtual.slides.length),t};if(void 0===s&&(s=ur(e)),n.indexOf(t)>=0)v=n.indexOf(t);else{const A=Math.min(r.slidesPerGroupSkip,s);v=A+Math.floor((s-A)/r.slidesPerGroup)}if(v>=n.length&&(v=n.length-1),s===P&&!e.params.loop)return void(v!==f&&(e.snapIndex=v,e.emit("snapIndexChange")));if(s===P&&e.params.loop&&e.virtual&&e.params.virtual.enabled)return void(e.realIndex=a(s));const w=e.grid&&r.grid&&r.grid.rows>1;let D;if(e.virtual&&r.virtual.enabled&&r.loop)D=a(s);else if(w){const A=e.slides.filter((A=>A.column===s))[0];let t=parseInt(A.getAttribute("data-swiper-slide-index"),10);Number.isNaN(t)&&(t=Math.max(e.slides.indexOf(A),0)),D=Math.floor(t/r.grid.rows)}else if(e.slides[s]){const A=e.slides[s].getAttribute("data-swiper-slide-index");D=A?parseInt(A,10):s}else D=s;Object.assign(e,{previousSnapIndex:f,snapIndex:v,previousRealIndex:z,realIndex:D,previousIndex:P,activeIndex:s}),e.initialized&&gr(e),e.emit("activeIndexChange"),e.emit("snapIndexChange"),(e.initialized||e.params.runCallbacksOnInit)&&(z!==D&&e.emit("realIndexChange"),e.emit("slideChange"))}function br(A,e){const t=this,n=t.params;let r=A.closest(`.${n.slideClass}, swiper-slide`);!r&&t.isElement&&e&&e.length>1&&e.includes(A)&&[...e.slice(e.indexOf(A)+1,e.length)].forEach((A=>{!r&&A.matches&&A.matches(`.${n.slideClass}, swiper-slide`)&&(r=A)}));let P,z=!1;if(r)for(let A=0;Av?v:n&&Az?"next":P=v.length&&(M=v.length-1);const g=-v[M];if(f.normalizeSlideIndex)for(let A=0;A=t&&e=t&&e=t&&(z=A)}if(P.initialized&&z!==w){if(!P.allowSlideNext&&(D?g>P.translate&&g>P.minTranslate():gP.translate&&g>P.maxTranslate()&&(w||0)!==z)return!1}let u;if(z!==(a||0)&&t&&P.emit("beforeSlideChangeStart"),P.updateProgress(g),u=z>w?"next":z0?(P._cssModeVirtualInitialSet=!0,requestAnimationFrame((()=>{c[A?"scrollLeft":"scrollTop"]=t}))):c[A?"scrollLeft":"scrollTop"]=t,e&&requestAnimationFrame((()=>{P.wrapperEl.style.scrollSnapType="",P._immediateVirtual=!1}))}else{if(!P.support.smoothScroll)return Qn({swiper:P,targetPosition:t,side:A?"left":"top"}),!0;c.scrollTo({[A?"left":"top"]:t,behavior:"smooth"})}return!0}return P.setTransition(e),P.setTranslate(g),P.updateActiveIndex(z),P.updateSlidesClasses(),P.emit("beforeTransitionStart",e,n),P.transitionStart(t,u),0===e?P.transitionEnd(t,u):P.animating||(P.animating=!0,P.onSlideToWrapperTransitionEnd||(P.onSlideToWrapperTransitionEnd=function(A){P&&!P.destroyed&&A.target===this&&(P.wrapperEl.removeEventListener("transitionend",P.onSlideToWrapperTransitionEnd),P.onSlideToWrapperTransitionEnd=null,delete P.onSlideToWrapperTransitionEnd,P.transitionEnd(t,u))}),P.wrapperEl.addEventListener("transitionend",P.onSlideToWrapperTransitionEnd)),!0}function or(A,e,t,n){if(void 0===A&&(A=0),void 0===t&&(t=!0),"string"==typeof A){A=parseInt(A,10)}const r=this;if(r.destroyed)return;void 0===e&&(e=r.params.speed);const P=r.grid&&r.params.grid&&r.params.grid.rows>1;let z=A;if(r.params.loop)if(r.virtual&&r.params.virtual.enabled)z+=r.virtual.slidesBefore;else{let A;if(P){const e=z*r.params.grid.rows;A=r.slides.filter((A=>1*A.getAttribute("data-swiper-slide-index")===e))[0].column}else A=r.getSlideIndexByData(z);const e=P?Math.ceil(r.slides.length/r.params.grid.rows):r.slides.length,{centeredSlides:t}=r.params;let f=r.params.slidesPerView;"auto"===f?f=r.slidesPerViewDynamic():(f=Math.ceil(parseFloat(r.params.slidesPerView,10)),t&&f%2==0&&(f+=1));let v=e-A1*e.getAttribute("data-swiper-slide-index")===A))[0].column}else z=r.getSlideIndexByData(z)}return requestAnimationFrame((()=>{r.slideTo(z,e,t,n)})),r}function Nr(A,e,t){void 0===e&&(e=!0);const n=this,{enabled:r,params:P,animating:z}=n;if(!r||n.destroyed)return n;void 0===A&&(A=n.params.speed);let f=P.slidesPerGroup;"auto"===P.slidesPerView&&1===P.slidesPerGroup&&P.slidesPerGroupAuto&&(f=Math.max(n.slidesPerViewDynamic("current",!0),1));const v=n.activeIndex{n.slideTo(n.activeIndex+v,A,e,t)})),!0}return P.rewind&&n.isEnd?n.slideTo(0,A,e,t):n.slideTo(n.activeIndex+v,A,e,t)}function ir(A,e,t){void 0===e&&(e=!0);const n=this,{params:r,snapGrid:P,slidesGrid:z,rtlTranslate:f,enabled:v,animating:s}=n;if(!v||n.destroyed)return n;void 0===A&&(A=n.params.speed);const a=n.virtual&&r.virtual.enabled;if(r.loop){if(s&&!a&&r.loopPreventsSliding)return!1;n.loopFix({direction:"prev"}),n._clientLeft=n.wrapperEl.clientLeft}function w(A){return A<0?-Math.floor(Math.abs(A)):Math.floor(A)}const D=w(f?n.translate:-n.translate),c=P.map((A=>w(A)));let l=P[c.indexOf(D)-1];if(void 0===l&&r.cssMode){let A;P.forEach(((e,t)=>{D>=e&&(A=t)})),void 0!==A&&(l=P[A>0?A-1:A])}let d=0;if(void 0!==l&&(d=z.indexOf(l),d<0&&(d=n.activeIndex-1),"auto"===r.slidesPerView&&1===r.slidesPerGroup&&r.slidesPerGroupAuto&&(d=d-n.slidesPerViewDynamic("previous",!0)+1,d=Math.max(d,0))),r.rewind&&n.isBeginning){const r=n.params.virtual&&n.params.virtual.enabled&&n.virtual?n.virtual.slides.length-1:n.slides.length-1;return n.slideTo(r,A,e,t)}return r.loop&&0===n.activeIndex&&r.cssMode?(requestAnimationFrame((()=>{n.slideTo(d,A,e,t)})),!0):n.slideTo(d,A,e,t)}function Qr(A,e,t){void 0===e&&(e=!0);const n=this;if(!n.destroyed)return void 0===A&&(A=n.params.speed),n.slideTo(n.activeIndex,A,e,t)}function Tr(A,e,t,n){void 0===e&&(e=!0),void 0===n&&(n=.5);const r=this;if(r.destroyed)return;void 0===A&&(A=r.params.speed);let P=r.activeIndex;const z=Math.min(r.params.slidesPerGroupSkip,P),f=z+Math.floor((P-z)/r.params.slidesPerGroup),v=r.rtlTranslate?r.translate:-r.translate;if(v>=r.snapGrid[f]){const A=r.snapGrid[f];v-A>(r.snapGrid[f+1]-A)*n&&(P+=r.params.slidesPerGroup)}else{const A=r.snapGrid[f-1];v-A<=(r.snapGrid[f]-A)*n&&(P-=r.params.slidesPerGroup)}return P=Math.max(P,0),P=Math.min(P,r.slidesGrid.length-1),r.slideTo(P,A,e,t)}function Cr(){const A=this;if(A.destroyed)return;const{params:e,slidesEl:t}=A,n="auto"===e.slidesPerView?A.slidesPerViewDynamic():e.slidesPerView;let r,P=A.clickedIndex;const z=A.isElement?"swiper-slide":`.${e.slideClass}`;if(e.loop){if(A.animating)return;r=parseInt(A.clickedSlide.getAttribute("data-swiper-slide-index"),10),e.centeredSlides?PA.slides.length-A.loopedSlides+n/2?(A.loopFix(),P=A.getSlideIndex(Tn(t,`${z}[data-swiper-slide-index="${r}"]`)[0]),Zn((()=>{A.slideTo(P)}))):A.slideTo(P):P>A.slides.length-n?(A.loopFix(),P=A.getSlideIndex(Tn(t,`${z}[data-swiper-slide-index="${r}"]`)[0]),Zn((()=>{A.slideTo(P)}))):A.slideTo(P)}else A.slideTo(P)}var Vr={slideTo:Yr,slideToLoop:or,slideNext:Nr,slidePrev:ir,slideReset:Qr,slideToClosest:Tr,slideToClickedSlide:Cr};function hr(A){const e=this,{params:t,slidesEl:n}=e;if(!t.loop||e.virtual&&e.params.virtual.enabled)return;const r=()=>{Tn(n,`.${t.slideClass}, swiper-slide`).forEach(((A,e)=>{A.setAttribute("data-swiper-slide-index",e)}))},P=e.grid&&t.grid&&t.grid.rows>1,z=t.slidesPerGroup*(P?t.grid.rows:1),f=e.slides.length%z!=0,v=P&&e.slides.length%t.grid.rows!=0,s=A=>{for(let n=0;n1;s.lengthA.classList.contains(c.slideActiveClass)))[0]):x=P;const X="next"===n||!n,H="prev"===n||!n;let W=0,B=0;const O=u?Math.ceil(s.length/c.grid.rows):s.length,p=(u?s[P].column:P)+(l&&void 0===r?-d/2+.5:0);if(p=0;e-=1)s[e].column===A&&j.push(e)}else j.push(O-e-1)}}else if(p+d>O-g){B=Math.max(p-(O-2*g),M);for(let A=0;A{A.column===e&&b.push(t)})):b.push(e)}}if(v.__preventObserver__=!0,requestAnimationFrame((()=>{v.__preventObserver__=!1})),H&&j.forEach((A=>{s[A].swiperLoopMoveDOM=!0,D.prepend(s[A]),s[A].swiperLoopMoveDOM=!1})),X&&b.forEach((A=>{s[A].swiperLoopMoveDOM=!0,D.append(s[A]),s[A].swiperLoopMoveDOM=!1})),v.recalcSlides(),"auto"===c.slidesPerView?v.updateSlides():u&&(j.length>0&&H||b.length>0&&X)&&v.slides.forEach(((A,e)=>{v.grid.updateSlide(e,A,v.slides)})),c.watchSlidesProgress&&v.updateSlidesOffset(),t)if(j.length>0&&H){if(void 0===e){const A=v.slidesGrid[x],e=v.slidesGrid[x+W]-A;f?v.setTranslate(v.translate-e):(v.slideTo(x+Math.ceil(W),0,!1,!0),r&&(v.touchEventsData.startTranslate=v.touchEventsData.startTranslate-e,v.touchEventsData.currentTranslate=v.touchEventsData.currentTranslate-e))}else if(r){const A=u?j.length/c.grid.rows:j.length;v.slideTo(v.activeIndex+A,0,!1,!0),v.touchEventsData.currentTranslate=v.translate}}else if(b.length>0&&X)if(void 0===e){const A=v.slidesGrid[x],e=v.slidesGrid[x-B]-A;f?v.setTranslate(v.translate-e):(v.slideTo(x-B,0,!1,!0),r&&(v.touchEventsData.startTranslate=v.touchEventsData.startTranslate-e,v.touchEventsData.currentTranslate=v.touchEventsData.currentTranslate-e))}else{const A=u?b.length/c.grid.rows:b.length;v.slideTo(v.activeIndex-A,0,!1,!0)}if(v.allowSlidePrev=a,v.allowSlideNext=w,v.controller&&v.controller.control&&!z){const A={slideRealIndex:e,direction:n,setTranslate:r,activeSlideIndex:P,byController:!0};Array.isArray(v.controller.control)?v.controller.control.forEach((e=>{!e.destroyed&&e.params.loop&&e.loopFix({...A,slideTo:e.params.slidesPerView===c.slidesPerView&&t})})):v.controller.control instanceof v.constructor&&v.controller.control.params.loop&&v.controller.control.loopFix({...A,slideTo:v.controller.control.params.slidesPerView===c.slidesPerView&&t})}v.emit("loopFix")}function Ir(){const A=this,{params:e,slidesEl:t}=A;if(!e.loop||A.virtual&&A.params.virtual.enabled)return;A.recalcSlides();const n=[];A.slides.forEach((A=>{const e=void 0===A.swiperSlideIndex?1*A.getAttribute("data-swiper-slide-index"):A.swiperSlideIndex;n[e]=A})),A.slides.forEach((A=>{A.removeAttribute("data-swiper-slide-index")})),n.forEach((A=>{t.append(A)})),A.recalcSlides(),A.slideTo(A.realIndex,0)}var kr={loopCreate:hr,loopFix:qr,loopDestroy:Ir};function Kr(A){const e=this;if(!e.params.simulateTouch||e.params.watchOverflow&&e.isLocked||e.params.cssMode)return;const t="container"===e.params.touchEventsTarget?e.el:e.wrapperEl;e.isElement&&(e.__preventObserver__=!0),t.style.cursor="move",t.style.cursor=A?"grabbing":"grab",e.isElement&&requestAnimationFrame((()=>{e.__preventObserver__=!1}))}function Ur(){const A=this;A.params.watchOverflow&&A.isLocked||A.params.cssMode||(A.isElement&&(A.__preventObserver__=!0),A["container"===A.params.touchEventsTarget?"el":"wrapperEl"].style.cursor="",A.isElement&&requestAnimationFrame((()=>{A.__preventObserver__=!1})))}var Sr={setGrabCursor:Kr,unsetGrabCursor:Ur};function Er(A,e){return void 0===e&&(e=this),function e(t){if(!t||t===Hn()||t===Bn())return null;t.assignedSlot&&(t=t.assignedSlot);const n=t.closest(A);return n||t.getRootNode?n||e(t.getRootNode().host):null}(e)}function Rr(A,e,t){const n=Bn(),{params:r}=A,P=r.edgeSwipeDetection,z=r.edgeSwipeThreshold;return!P||!(t<=z||t>=n.innerWidth-z)||"prevent"===P&&(e.preventDefault(),!0)}function Jr(A){const e=this,t=Hn();let n=A;n.originalEvent&&(n=n.originalEvent);const r=e.touchEventsData;if("pointerdown"===n.type){if(null!==r.pointerId&&r.pointerId!==n.pointerId)return;r.pointerId=n.pointerId}else"touchstart"===n.type&&1===n.targetTouches.length&&(r.touchId=n.targetTouches[0].identifier);if("touchstart"===n.type)return void Rr(e,n,n.targetTouches[0].pageX);const{params:P,touches:z,enabled:f}=e;if(!f)return;if(!P.simulateTouch&&"mouse"===n.pointerType)return;if(e.animating&&P.preventInteractionOnTransition)return;!e.animating&&P.cssMode&&P.loop&&e.loopFix();let v=n.target;if("wrapper"===P.touchEventsTarget&&!e.wrapperEl.contains(v))return;if("which"in n&&3===n.which)return;if("button"in n&&n.button>0)return;if(r.isTouched&&r.isMoved)return;const s=!!P.noSwipingClass&&""!==P.noSwipingClass,a=n.composedPath?n.composedPath():n.path;s&&n.target&&n.target.shadowRoot&&a&&(v=a[0]);const w=P.noSwipingSelector?P.noSwipingSelector:`.${P.noSwipingClass}`,D=!(!n.target||!n.target.shadowRoot);if(P.noSwiping&&(D?Er(w,v):v.closest(w)))return void(e.allowClick=!0);if(P.swipeHandler&&!v.closest(P.swipeHandler))return;z.currentX=n.pageX,z.currentY=n.pageY;const c=z.currentX,l=z.currentY;if(!Rr(e,n,c))return;Object.assign(r,{isTouched:!0,isMoved:!1,allowTouchCallbacks:!0,isScrolling:void 0,startMoving:void 0}),z.startX=c,z.startY=l,r.touchStartTime=yn(),e.allowClick=!0,e.updateSize(),e.swipeDirection=void 0,P.threshold>0&&(r.allowThresholdMove=!1);let d=!0;v.matches(r.focusableElements)&&(d=!1,"SELECT"===v.nodeName&&(r.isTouched=!1)),t.activeElement&&t.activeElement.matches(r.focusableElements)&&t.activeElement!==v&&t.activeElement.blur();const M=d&&e.allowTouchMove&&P.touchStartPreventDefault;!P.touchStartForcePreventDefault&&!M||v.isContentEditable||n.preventDefault(),P.freeMode&&P.freeMode.enabled&&e.freeMode&&e.animating&&!P.cssMode&&e.freeMode.onTouchStart(),e.emit("touchStart",n)}function Fr(A){const e=Hn(),t=this,n=t.touchEventsData,{params:r,touches:P,rtlTranslate:z,enabled:f}=t;if(!f)return;if(!r.simulateTouch&&"mouse"===A.pointerType)return;let v,s=A;if(s.originalEvent&&(s=s.originalEvent),"pointermove"===s.type){if(null!==n.touchId)return;if(s.pointerId!==n.pointerId)return}if("touchmove"===s.type){if(v=[...s.changedTouches].filter((A=>A.identifier===n.touchId))[0],!v||v.identifier!==n.touchId)return}else v=s;if(!n.isTouched)return void(n.startMoving&&n.isScrolling&&t.emit("touchMoveOpposite",s));const a=v.pageX,w=v.pageY;if(s.preventedByNestedSwiper)return P.startX=a,void(P.startY=w);if(!t.allowTouchMove)return s.target.matches(n.focusableElements)||(t.allowClick=!1),void(n.isTouched&&(Object.assign(P,{startX:a,startY:w,currentX:a,currentY:w}),n.touchStartTime=yn()));if(r.touchReleaseOnEdges&&!r.loop)if(t.isVertical()){if(wP.startY&&t.translate>=t.minTranslate())return n.isTouched=!1,void(n.isMoved=!1)}else if(aP.startX&&t.translate>=t.minTranslate())return;if(e.activeElement&&s.target===e.activeElement&&s.target.matches(n.focusableElements))return n.isMoved=!0,void(t.allowClick=!1);n.allowTouchCallbacks&&t.emit("touchMove",s),P.previousX=P.currentX,P.previousY=P.currentY,P.currentX=a,P.currentY=w;const D=P.currentX-P.startX,c=P.currentY-P.startY;if(t.params.threshold&&Math.sqrt(D**2+c**2)=25&&(A=180*Math.atan2(Math.abs(c),Math.abs(D))/Math.PI,n.isScrolling=t.isHorizontal()?A>r.touchAngle:90-A>r.touchAngle)}if(n.isScrolling&&t.emit("touchMoveOpposite",s),void 0===n.startMoving&&(P.currentX===P.startX&&P.currentY===P.startY||(n.startMoving=!0)),n.isScrolling||"touchmove"===s.type&&n.preventTouchMoveFromPointerMove)return void(n.isTouched=!1);if(!n.startMoving)return;t.allowClick=!1,!r.cssMode&&s.cancelable&&s.preventDefault(),r.touchMoveStopPropagation&&!r.nested&&s.stopPropagation();let l=t.isHorizontal()?D:c,d=t.isHorizontal()?P.currentX-P.previousX:P.currentY-P.previousY;r.oneWayMovement&&(l=Math.abs(l)*(z?1:-1),d=Math.abs(d)*(z?1:-1)),P.diff=l,l*=r.touchRatio,z&&(l=-l,d=-d);const M=t.touchesDirection;t.swipeDirection=l>0?"prev":"next",t.touchesDirection=d>0?"prev":"next";const g=t.params.loop&&!r.cssMode,u="next"===t.touchesDirection&&t.allowSlideNext||"prev"===t.touchesDirection&&t.allowSlidePrev;if(!n.isMoved){if(g&&u&&t.loopFix({direction:t.swipeDirection}),n.startTranslate=t.getTranslate(),t.setTransition(0),t.animating){const A=new window.CustomEvent("transitionend",{bubbles:!0,cancelable:!0,detail:{bySwiperTouchMove:!0}});t.wrapperEl.dispatchEvent(A)}n.allowMomentumBounce=!1,!r.grabCursor||!0!==t.allowSlideNext&&!0!==t.allowSlidePrev||t.setGrabCursor(!0),t.emit("sliderFirstMove",s)}if((new Date).getTime(),n.isMoved&&n.allowThresholdMove&&M!==t.touchesDirection&&g&&u&&Math.abs(l)>=1)return Object.assign(P,{startX:a,startY:w,currentX:a,currentY:w,startTranslate:n.currentTranslate}),n.loopSwapReset=!0,void(n.startTranslate=n.currentTranslate);t.emit("sliderMove",s),n.isMoved=!0,n.currentTranslate=l+n.startTranslate;let j=!0,b=r.resistanceRatio;if(r.touchReleaseOnEdges&&(b=0),l>0?(g&&u&&n.allowThresholdMove&&n.currentTranslate>(r.centeredSlides?t.minTranslate()-t.slidesSizesGrid[t.activeIndex+1]:t.minTranslate())&&t.loopFix({direction:"prev",setTranslate:!0,activeSlideIndex:0}),n.currentTranslate>t.minTranslate()&&(j=!1,r.resistance&&(n.currentTranslate=t.minTranslate()-1+(-t.minTranslate()+n.startTranslate+l)**b))):l<0&&(g&&u&&n.allowThresholdMove&&n.currentTranslate<(r.centeredSlides?t.maxTranslate()+t.slidesSizesGrid[t.slidesSizesGrid.length-1]:t.maxTranslate())&&t.loopFix({direction:"next",setTranslate:!0,activeSlideIndex:t.slides.length-("auto"===r.slidesPerView?t.slidesPerViewDynamic():Math.ceil(parseFloat(r.slidesPerView,10)))}),n.currentTranslaten.startTranslate&&(n.currentTranslate=n.startTranslate),t.allowSlidePrev||t.allowSlideNext||(n.currentTranslate=n.startTranslate),r.threshold>0){if(!(Math.abs(l)>r.threshold||n.allowThresholdMove))return void(n.currentTranslate=n.startTranslate);if(!n.allowThresholdMove)return n.allowThresholdMove=!0,P.startX=P.currentX,P.startY=P.currentY,n.currentTranslate=n.startTranslate,void(P.diff=t.isHorizontal()?P.currentX-P.startX:P.currentY-P.startY)}r.followFinger&&!r.cssMode&&((r.freeMode&&r.freeMode.enabled&&t.freeMode||r.watchSlidesProgress)&&(t.updateActiveIndex(),t.updateSlidesClasses()),r.freeMode&&r.freeMode.enabled&&t.freeMode&&t.freeMode.onTouchMove(),t.updateProgress(n.currentTranslate),t.setTranslate(n.currentTranslate))}function _r(A){const e=this,t=e.touchEventsData;let n,r=A;r.originalEvent&&(r=r.originalEvent);if("touchend"===r.type||"touchcancel"===r.type){if(n=[...r.changedTouches].filter((A=>A.identifier===t.touchId))[0],!n||n.identifier!==t.touchId)return}else{if(null!==t.touchId)return;if(r.pointerId!==t.pointerId)return;n=r}if(["pointercancel","pointerout","pointerleave","contextmenu"].includes(r.type)){if(!(["pointercancel","contextmenu"].includes(r.type)&&(e.browser.isSafari||e.browser.isWebView)))return}t.pointerId=null,t.touchId=null;const{params:P,touches:z,rtlTranslate:f,slidesGrid:v,enabled:s}=e;if(!s)return;if(!P.simulateTouch&&"mouse"===r.pointerType)return;if(t.allowTouchCallbacks&&e.emit("touchEnd",r),t.allowTouchCallbacks=!1,!t.isTouched)return t.isMoved&&P.grabCursor&&e.setGrabCursor(!1),t.isMoved=!1,void(t.startMoving=!1);P.grabCursor&&t.isMoved&&t.isTouched&&(!0===e.allowSlideNext||!0===e.allowSlidePrev)&&e.setGrabCursor(!1);const a=yn(),w=a-t.touchStartTime;if(e.allowClick){const A=r.path||r.composedPath&&r.composedPath();e.updateClickedSlide(A&&A[0]||r.target,A),e.emit("tap click",r),w<300&&a-t.lastClickTime<300&&e.emit("doubleTap doubleClick",r)}if(t.lastClickTime=yn(),Zn((()=>{e.destroyed||(e.allowClick=!0)})),!t.isTouched||!t.isMoved||!e.swipeDirection||0===z.diff&&!t.loopSwapReset||t.currentTranslate===t.startTranslate&&!t.loopSwapReset)return t.isTouched=!1,t.isMoved=!1,void(t.startMoving=!1);let D;if(t.isTouched=!1,t.isMoved=!1,t.startMoving=!1,D=P.followFinger?f?e.translate:-e.translate:-t.currentTranslate,P.cssMode)return;if(P.freeMode&&P.freeMode.enabled)return void e.freeMode.onTouchEnd({currentPos:D});const c=D>=-e.maxTranslate()&&!e.params.loop;let l=0,d=e.slidesSizesGrid[0];for(let A=0;A=v[A]&&D=v[A])&&(l=A,d=v[v.length-1]-v[v.length-2])}let M=null,g=null;P.rewind&&(e.isBeginning?g=P.virtual&&P.virtual.enabled&&e.virtual?e.virtual.slides.length-1:e.slides.length-1:e.isEnd&&(M=0));const u=(D-v[l])/d,j=lP.longSwipesMs){if(!P.longSwipes)return void e.slideTo(e.activeIndex);"next"===e.swipeDirection&&(u>=P.longSwipesRatio?e.slideTo(P.rewind&&e.isEnd?M:l+j):e.slideTo(l)),"prev"===e.swipeDirection&&(u>1-P.longSwipesRatio?e.slideTo(l+j):null!==g&&u<0&&Math.abs(u)>P.longSwipesRatio?e.slideTo(g):e.slideTo(l))}else{if(!P.shortSwipes)return void e.slideTo(e.activeIndex);e.navigation&&(r.target===e.navigation.nextEl||r.target===e.navigation.prevEl)?r.target===e.navigation.nextEl?e.slideTo(l+j):e.slideTo(l):("next"===e.swipeDirection&&e.slideTo(null!==M?M:l+j),"prev"===e.swipeDirection&&e.slideTo(null!==g?g:l))}}function $r(){const A=this,{params:e,el:t}=A;if(t&&0===t.offsetWidth)return;e.breakpoints&&A.setBreakpoint();const{allowSlideNext:n,allowSlidePrev:r,snapGrid:P}=A,z=A.virtual&&A.params.virtual.enabled;A.allowSlideNext=!0,A.allowSlidePrev=!0,A.updateSize(),A.updateSlides(),A.updateSlidesClasses();const f=z&&e.loop;!("auto"===e.slidesPerView||e.slidesPerView>1)||!A.isEnd||A.isBeginning||A.params.centeredSlides||f?A.params.loop&&!z?A.slideToLoop(A.realIndex,0,!1,!0):A.slideTo(A.activeIndex,0,!1,!0):A.slideTo(A.slides.length-1,0,!1,!0),A.autoplay&&A.autoplay.running&&A.autoplay.paused&&(clearTimeout(A.autoplay.resizeTimeout),A.autoplay.resizeTimeout=setTimeout((()=>{A.autoplay&&A.autoplay.running&&A.autoplay.paused&&A.autoplay.resume()}),500)),A.allowSlidePrev=r,A.allowSlideNext=n,A.params.watchOverflow&&P!==A.snapGrid&&A.checkOverflow()}function AP(A){const e=this;e.enabled&&(e.allowClick||(e.params.preventClicks&&A.preventDefault(),e.params.preventClicksPropagation&&e.animating&&(A.stopPropagation(),A.stopImmediatePropagation())))}function eP(){const A=this,{wrapperEl:e,rtlTranslate:t,enabled:n}=A;if(!n)return;let r;A.previousTranslate=A.translate,A.isHorizontal()?A.translate=-e.scrollLeft:A.translate=-e.scrollTop,0===A.translate&&(A.translate=0),A.updateActiveIndex(),A.updateSlidesClasses();const P=A.maxTranslate()-A.minTranslate();r=0===P?0:(A.translate-A.minTranslate())/P,r!==A.progress&&A.updateProgress(t?-A.translate:A.translate),A.emit("setTranslate",A.translate,!1)}function tP(A){const e=this;dr(e,A.target),e.params.cssMode||"auto"!==e.params.slidesPerView&&!e.params.autoHeight||e.update()}function nP(){const A=this;A.documentTouchHandlerProceeded||(A.documentTouchHandlerProceeded=!0,A.params.touchReleaseOnEdges&&(A.el.style.touchAction="auto"))}const rP=(A,e)=>{const t=Hn(),{params:n,el:r,wrapperEl:P,device:z}=A,f=!!n.nested,v="on"===e?"addEventListener":"removeEventListener",s=e;r&&"string"!=typeof r&&(t[v]("touchstart",A.onDocumentTouchStart,{passive:!1,capture:f}),r[v]("touchstart",A.onTouchStart,{passive:!1}),r[v]("pointerdown",A.onTouchStart,{passive:!1}),t[v]("touchmove",A.onTouchMove,{passive:!1,capture:f}),t[v]("pointermove",A.onTouchMove,{passive:!1,capture:f}),t[v]("touchend",A.onTouchEnd,{passive:!0}),t[v]("pointerup",A.onTouchEnd,{passive:!0}),t[v]("pointercancel",A.onTouchEnd,{passive:!0}),t[v]("touchcancel",A.onTouchEnd,{passive:!0}),t[v]("pointerout",A.onTouchEnd,{passive:!0}),t[v]("pointerleave",A.onTouchEnd,{passive:!0}),t[v]("contextmenu",A.onTouchEnd,{passive:!0}),(n.preventClicks||n.preventClicksPropagation)&&r[v]("click",A.onClick,!0),n.cssMode&&P[v]("scroll",A.onScroll),n.updateOnWindowResize?A[s](z.ios||z.android?"resize orientationchange observerUpdate":"resize observerUpdate",$r,!0):A[s]("observerUpdate",$r,!0),r[v]("load",A.onLoad,{capture:!0}))};function PP(){const A=this,{params:e}=A;A.onTouchStart=Jr.bind(A),A.onTouchMove=Fr.bind(A),A.onTouchEnd=_r.bind(A),A.onDocumentTouchStart=nP.bind(A),e.cssMode&&(A.onScroll=eP.bind(A)),A.onClick=AP.bind(A),A.onLoad=tP.bind(A),rP(A,"on")}function zP(){rP(this,"off")}var fP={attachEvents:PP,detachEvents:zP};const vP=(A,e)=>A.grid&&e.grid&&e.grid.rows>1;function sP(){const A=this,{realIndex:e,initialized:t,params:n,el:r}=A,P=n.breakpoints;if(!P||P&&0===Object.keys(P).length)return;const z=A.getBreakpoint(P,A.params.breakpointsBase,A.el);if(!z||A.currentBreakpoint===z)return;const f=(z in P?P[z]:void 0)||A.originalParams,v=vP(A,n),s=vP(A,f),a=A.params.grabCursor,w=f.grabCursor,D=n.enabled;v&&!s?(r.classList.remove(`${n.containerModifierClass}grid`,`${n.containerModifierClass}grid-column`),A.emitContainerClasses()):!v&&s&&(r.classList.add(`${n.containerModifierClass}grid`),(f.grid.fill&&"column"===f.grid.fill||!f.grid.fill&&"column"===n.grid.fill)&&r.classList.add(`${n.containerModifierClass}grid-column`),A.emitContainerClasses()),a&&!w?A.unsetGrabCursor():!a&&w&&A.setGrabCursor(),["navigation","pagination","scrollbar"].forEach((e=>{if(void 0===f[e])return;const t=n[e]&&n[e].enabled,r=f[e]&&f[e].enabled;t&&!r&&A[e].disable(),!t&&r&&A[e].enable()}));const c=f.direction&&f.direction!==n.direction,l=n.loop&&(f.slidesPerView!==n.slidesPerView||c),d=n.loop;c&&t&&A.changeDirection(),on(A.params,f);const M=A.params.enabled,g=A.params.loop;Object.assign(A,{allowTouchMove:A.params.allowTouchMove,allowSlideNext:A.params.allowSlideNext,allowSlidePrev:A.params.allowSlidePrev}),D&&!M?A.disable():!D&&M&&A.enable(),A.currentBreakpoint=z,A.emit("_beforeBreakpoint",f),t&&(l?(A.loopDestroy(),A.loopCreate(e),A.updateSlides()):!d&&g?(A.loopCreate(e),A.updateSlides()):d&&!g&&A.loopDestroy()),A.emit("breakpoint",f)}function aP(A,e,t){if(void 0===e&&(e="window"),!A||"container"===e&&!t)return;let n=!1;const r=Bn(),P="window"===e?r.innerHeight:t.clientHeight,z=Object.keys(A).map((A=>{if("string"==typeof A&&0===A.indexOf("@")){const e=parseFloat(A.substr(1));return{value:P*e,point:A}}return{value:A,point:A}}));z.sort(((A,e)=>parseInt(A.value,10)-parseInt(e.value,10)));for(let A=0;A{"object"==typeof A?Object.keys(A).forEach((n=>{A[n]&&t.push(e+n)})):"string"==typeof A&&t.push(e+A)})),t}function cP(){const A=this,{classNames:e,params:t,rtl:n,el:r,device:P}=A,z=DP(["initialized",t.direction,{"free-mode":A.params.freeMode&&t.freeMode.enabled},{autoheight:t.autoHeight},{rtl:n},{grid:t.grid&&t.grid.rows>1},{"grid-column":t.grid&&t.grid.rows>1&&"column"===t.grid.fill},{android:P.android},{ios:P.ios},{"css-mode":t.cssMode},{centered:t.cssMode&&t.centeredSlides},{"watch-progress":t.watchSlidesProgress}],t.containerModifierClass);e.push(...z),r.classList.add(...e),A.emitContainerClasses()}function lP(){const{el:A,classNames:e}=this;A&&"string"!=typeof A&&(A.classList.remove(...e),this.emitContainerClasses())}var dP={addClasses:cP,removeClasses:lP};function MP(){const A=this,{isLocked:e,params:t}=A,{slidesOffsetBefore:n}=t;if(n){const e=A.slides.length-1,t=A.slidesGrid[e]+A.slidesSizesGrid[e]+2*n;A.isLocked=A.size>t}else A.isLocked=1===A.snapGrid.length;!0===t.allowSlideNext&&(A.allowSlideNext=!A.isLocked),!0===t.allowSlidePrev&&(A.allowSlidePrev=!A.isLocked),e&&e!==A.isLocked&&(A.isEnd=!1),e!==A.isLocked&&A.emit(A.isLocked?"lock":"unlock")}var gP={checkOverflow:MP},uP={init:!0,direction:"horizontal",oneWayMovement:!1,swiperElementNodeName:"SWIPER-CONTAINER",touchEventsTarget:"wrapper",initialSlide:0,speed:300,cssMode:!1,updateOnWindowResize:!0,resizeObserver:!0,nested:!1,createElements:!1,eventsPrefix:"swiper",enabled:!0,focusableElements:"input, select, option, textarea, button, video, label",width:null,height:null,preventInteractionOnTransition:!1,userAgent:null,url:null,edgeSwipeDetection:!1,edgeSwipeThreshold:20,autoHeight:!1,setWrapperSize:!1,virtualTranslate:!1,effect:"slide",breakpoints:void 0,breakpointsBase:"window",spaceBetween:0,slidesPerView:1,slidesPerGroup:1,slidesPerGroupSkip:0,slidesPerGroupAuto:!1,centeredSlides:!1,centeredSlidesBounds:!1,slidesOffsetBefore:0,slidesOffsetAfter:0,normalizeSlideIndex:!0,centerInsufficientSlides:!1,watchOverflow:!0,roundLengths:!1,touchRatio:1,touchAngle:45,simulateTouch:!0,shortSwipes:!0,longSwipes:!0,longSwipesRatio:.5,longSwipesMs:300,followFinger:!0,allowTouchMove:!0,threshold:5,touchMoveStopPropagation:!1,touchStartPreventDefault:!0,touchStartForcePreventDefault:!1,touchReleaseOnEdges:!1,uniqueNavElements:!0,resistance:!0,resistanceRatio:.85,watchSlidesProgress:!1,grabCursor:!1,preventClicks:!0,preventClicksPropagation:!0,slideToClickedSlide:!1,loop:!1,loopAddBlankSlides:!0,loopAdditionalSlides:0,loopPreventsSliding:!0,rewind:!1,allowSlidePrev:!0,allowSlideNext:!0,swipeHandler:null,noSwiping:!0,noSwipingClass:"swiper-no-swiping",noSwipingSelector:null,passiveListeners:!0,maxBackfaceHiddenSlides:10,containerModifierClass:"swiper-",slideClass:"swiper-slide",slideBlankClass:"swiper-slide-blank",slideActiveClass:"swiper-slide-active",slideVisibleClass:"swiper-slide-visible",slideFullyVisibleClass:"swiper-slide-fully-visible",slideNextClass:"swiper-slide-next",slidePrevClass:"swiper-slide-prev",wrapperClass:"swiper-wrapper",lazyPreloaderClass:"swiper-lazy-preloader",lazyPreloadPrevNext:0,runCallbacksOnInit:!0,_emitClasses:!1};function jP(A,e){return function(t){void 0===t&&(t={});const n=Object.keys(t)[0],r=t[n];"object"==typeof r&&null!==r?(!0===A[n]&&(A[n]={enabled:!0}),"navigation"===n&&A[n]&&A[n].enabled&&!A[n].prevEl&&!A[n].nextEl&&(A[n].auto=!0),["pagination","scrollbar"].indexOf(n)>=0&&A[n]&&A[n].enabled&&!A[n].el&&(A[n].auto=!0),n in A&&"enabled"in r?("object"!=typeof A[n]||"enabled"in A[n]||(A[n].enabled=!0),A[n]||(A[n]={enabled:!1}),on(e,t)):on(e,t)):on(e,t)}}const bP={eventsEmitter:Pr,update:xr,translate:pr,transition:Lr,slide:Vr,loop:kr,grabCursor:Sr,events:fP,breakpoints:wP,checkOverflow:gP,classes:dP},xP={};class XP{constructor(){let A,e;for(var t=arguments.length,n=new Array(t),r=0;r1){const A=[];return P.querySelectorAll(e.el).forEach((t=>{const n=on({},e,{el:t});A.push(new XP(n))})),A}const z=this;z.__swiper__=!0,z.support=_n(),z.device=Ar({userAgent:e.userAgent}),z.browser=tr(),z.eventsListeners={},z.eventsAnyListeners=[],z.modules=[...z.__modules__],e.modules&&Array.isArray(e.modules)&&z.modules.push(...e.modules);const f={};z.modules.forEach((A=>{A({params:e,swiper:z,extendParams:jP(e,f),on:z.on.bind(z),once:z.once.bind(z),off:z.off.bind(z),emit:z.emit.bind(z)})}));const v=on({},uP,f);return z.params=on({},v,xP,e),z.originalParams=on({},z.params),z.passedParams=on({},e),z.params&&z.params.on&&Object.keys(z.params.on).forEach((A=>{z.on(A,z.params.on[A])})),z.params&&z.params.onAny&&z.onAny(z.params.onAny),Object.assign(z,{enabled:z.params.enabled,el:A,classNames:[],slides:[],slidesGrid:[],snapGrid:[],slidesSizesGrid:[],isHorizontal:()=>"horizontal"===z.params.direction,isVertical:()=>"vertical"===z.params.direction,activeIndex:0,realIndex:0,isBeginning:!0,isEnd:!1,translate:0,previousTranslate:0,progress:0,velocity:0,animating:!1,cssOverflowAdjustment(){return Math.trunc(this.translate/2**23)*2**23},allowSlideNext:z.params.allowSlideNext,allowSlidePrev:z.params.allowSlidePrev,touchEventsData:{isTouched:void 0,isMoved:void 0,allowTouchCallbacks:void 0,touchStartTime:void 0,isScrolling:void 0,currentTranslate:void 0,startTranslate:void 0,allowThresholdMove:void 0,focusableElements:z.params.focusableElements,lastClickTime:0,clickTimeout:void 0,velocities:[],allowMomentumBounce:void 0,startMoving:void 0,pointerId:null,touchId:null},allowClick:!0,allowTouchMove:z.params.allowTouchMove,touches:{startX:0,startY:0,currentX:0,currentY:0,diff:0},imagesToLoad:[],imagesLoaded:0}),z.emit("_swiper"),z.params.init&&z.init(),z}getDirectionLabel(A){return this.isHorizontal()?A:{width:"height","margin-top":"margin-left","margin-bottom ":"margin-right","margin-left":"margin-top","margin-right":"margin-bottom","padding-left":"padding-top","padding-right":"padding-bottom",marginRight:"marginBottom"}[A]}getSlideIndex(A){const{slidesEl:e,params:t}=this,n=kn(Tn(e,`.${t.slideClass}, swiper-slide`)[0]);return kn(A)-n}getSlideIndexByData(A){return this.getSlideIndex(this.slides.filter((e=>1*e.getAttribute("data-swiper-slide-index")===A))[0])}recalcSlides(){const{slidesEl:A,params:e}=this;this.slides=Tn(A,`.${e.slideClass}, swiper-slide`)}enable(){const A=this;A.enabled||(A.enabled=!0,A.params.grabCursor&&A.setGrabCursor(),A.emit("enable"))}disable(){const A=this;A.enabled&&(A.enabled=!1,A.params.grabCursor&&A.unsetGrabCursor(),A.emit("disable"))}setProgress(A,e){const t=this;A=Math.min(Math.max(A,0),1);const n=t.minTranslate(),r=(t.maxTranslate()-n)*A+n;t.translateTo(r,void 0===e?0:e),t.updateActiveIndex(),t.updateSlidesClasses()}emitContainerClasses(){const A=this;if(!A.params._emitClasses||!A.el)return;const e=A.el.className.split(" ").filter((e=>0===e.indexOf("swiper")||0===e.indexOf(A.params.containerModifierClass)));A.emit("_containerClasses",e.join(" "))}getSlideClasses(A){const e=this;return e.destroyed?"":A.className.split(" ").filter((A=>0===A.indexOf("swiper-slide")||0===A.indexOf(e.params.slideClass))).join(" ")}emitSlidesClasses(){const A=this;if(!A.params._emitClasses||!A.el)return;const e=[];A.slides.forEach((t=>{const n=A.getSlideClasses(t);e.push({slideEl:t,classNames:n}),A.emit("_slideClass",t,n)})),A.emit("_slideClasses",e)}slidesPerViewDynamic(A,e){void 0===A&&(A="current"),void 0===e&&(e=!1);const{params:t,slides:n,slidesGrid:r,slidesSizesGrid:P,size:z,activeIndex:f}=this;let v=1;if("number"==typeof t.slidesPerView)return t.slidesPerView;if(t.centeredSlides){let A,e=n[f]?Math.ceil(n[f].swiperSlideSize):0;for(let t=f+1;tz&&(A=!0));for(let t=f-1;t>=0;t-=1)n[t]&&!A&&(e+=n[t].swiperSlideSize,v+=1,e>z&&(A=!0))}else if("current"===A)for(let A=f+1;A=0;A-=1){r[f]-r[A]{e.complete&&dr(A,e)})),A.updateSize(),A.updateSlides(),A.updateProgress(),A.updateSlidesClasses(),t.freeMode&&t.freeMode.enabled&&!t.cssMode)n(),t.autoHeight&&A.updateAutoHeight();else{if(("auto"===t.slidesPerView||t.slidesPerView>1)&&A.isEnd&&!t.centeredSlides){const e=A.virtual&&t.virtual.enabled?A.virtual.slides:A.slides;r=A.slideTo(e.length-1,0,!1,!0)}else r=A.slideTo(A.activeIndex,0,!1,!0);r||n()}t.watchOverflow&&e!==A.snapGrid&&A.checkOverflow(),A.emit("update")}changeDirection(A,e){void 0===e&&(e=!0);const t=this,n=t.params.direction;return A||(A="horizontal"===n?"vertical":"horizontal"),A===n||"horizontal"!==A&&"vertical"!==A||(t.el.classList.remove(`${t.params.containerModifierClass}${n}`),t.el.classList.add(`${t.params.containerModifierClass}${A}`),t.emitContainerClasses(),t.params.direction=A,t.slides.forEach((e=>{"vertical"===A?e.style.width="":e.style.height=""})),t.emit("changeDirection"),e&&t.update()),t}changeLanguageDirection(A){const e=this;e.rtl&&"rtl"===A||!e.rtl&&"ltr"===A||(e.rtl="rtl"===A,e.rtlTranslate="horizontal"===e.params.direction&&e.rtl,e.rtl?(e.el.classList.add(`${e.params.containerModifierClass}rtl`),e.el.dir="rtl"):(e.el.classList.remove(`${e.params.containerModifierClass}rtl`),e.el.dir="ltr"),e.update())}mount(A){const e=this;if(e.mounted)return!0;let t=A||e.params.el;if("string"==typeof t&&(t=document.querySelector(t)),!t)return!1;t.swiper=e,t.parentNode&&t.parentNode.host&&t.parentNode.host.nodeName===e.params.swiperElementNodeName.toUpperCase()&&(e.isElement=!0);const n=()=>`.${(e.params.wrapperClass||"").trim().split(" ").join(".")}`;let r=(()=>{if(t&&t.shadowRoot&&t.shadowRoot.querySelector){return t.shadowRoot.querySelector(n())}return Tn(t,n())[0]})();return!r&&e.params.createElements&&(r=Vn("div",e.params.wrapperClass),t.append(r),Tn(t,`.${e.params.slideClass}`).forEach((A=>{r.append(A)}))),Object.assign(e,{el:t,wrapperEl:r,slidesEl:e.isElement&&!t.parentNode.host.slideSlots?t.parentNode.host:r,hostEl:e.isElement?t.parentNode.host:t,mounted:!0,rtl:"rtl"===t.dir.toLowerCase()||"rtl"===In(t,"direction"),rtlTranslate:"horizontal"===e.params.direction&&("rtl"===t.dir.toLowerCase()||"rtl"===In(t,"direction")),wrongRTL:"-webkit-box"===In(r,"display")}),!0}init(A){const e=this;if(e.initialized)return e;if(!1===e.mount(A))return e;e.emit("beforeInit"),e.params.breakpoints&&e.setBreakpoint(),e.addClasses(),e.updateSize(),e.updateSlides(),e.params.watchOverflow&&e.checkOverflow(),e.params.grabCursor&&e.enabled&&e.setGrabCursor(),e.params.loop&&e.virtual&&e.params.virtual.enabled?e.slideTo(e.params.initialSlide+e.virtual.slidesBefore,0,e.params.runCallbacksOnInit,!1,!0):e.slideTo(e.params.initialSlide,0,e.params.runCallbacksOnInit,!1,!0),e.params.loop&&e.loopCreate(),e.attachEvents();const t=[...e.el.querySelectorAll('[loading="lazy"]')];return e.isElement&&t.push(...e.hostEl.querySelectorAll('[loading="lazy"]')),t.forEach((A=>{A.complete?dr(e,A):A.addEventListener("load",(A=>{dr(e,A.target)}))})),gr(e),e.initialized=!0,gr(e),e.emit("init"),e.emit("afterInit"),e}destroy(A,e){void 0===A&&(A=!0),void 0===e&&(e=!0);const t=this,{params:n,el:r,wrapperEl:P,slides:z}=t;return void 0===t.params||t.destroyed||(t.emit("beforeDestroy"),t.initialized=!1,t.detachEvents(),n.loop&&t.loopDestroy(),e&&(t.removeClasses(),r&&"string"!=typeof r&&r.removeAttribute("style"),P&&P.removeAttribute("style"),z&&z.length&&z.forEach((A=>{A.classList.remove(n.slideVisibleClass,n.slideFullyVisibleClass,n.slideActiveClass,n.slideNextClass,n.slidePrevClass),A.removeAttribute("style"),A.removeAttribute("data-swiper-slide-index")}))),t.emit("destroy"),Object.keys(t.eventsListeners).forEach((A=>{t.off(A)})),!1!==A&&(t.el&&"string"!=typeof t.el&&(t.el.swiper=null),pn(t)),t.destroyed=!0),null}static extendDefaults(A){on(xP,A)}static get extendedDefaults(){return xP}static get defaults(){return uP}static installModule(A){XP.prototype.__modules__||(XP.prototype.__modules__=[]);const e=XP.prototype.__modules__;"function"==typeof A&&e.indexOf(A)<0&&e.push(A)}static use(A){return Array.isArray(A)?(A.forEach((A=>XP.installModule(A))),XP):(XP.installModule(A),XP)}}function HP(A,e,t,n){return A.params.createElements&&Object.keys(n).forEach((r=>{if(!t[r]&&!0===t.auto){let P=Tn(A.el,`.${n[r]}`)[0];P||(P=Vn("div",n[r]),P.className=n[r],A.el.append(P)),t[r]=P,e[r]=P}})),t}function WP(A){return void 0===A&&(A=""),`.${A.trim().replace(/([\.:!+\/])/g,"\\$1").replace(/ /g,".")}`}function BP(A){let{swiper:e,extendParams:t,on:n,emit:r}=A;const P="swiper-pagination";let z;t({pagination:{el:null,bulletElement:"span",clickable:!1,hideOnClick:!1,renderBullet:null,renderProgressbar:null,renderFraction:null,renderCustom:null,progressbarOpposite:!1,type:"bullets",dynamicBullets:!1,dynamicMainBullets:1,formatFractionCurrent:A=>A,formatFractionTotal:A=>A,bulletClass:`${P}-bullet`,bulletActiveClass:`${P}-bullet-active`,modifierClass:`${P}-`,currentClass:`${P}-current`,totalClass:`${P}-total`,hiddenClass:`${P}-hidden`,progressbarFillClass:`${P}-progressbar-fill`,progressbarOppositeClass:`${P}-progressbar-opposite`,clickableClass:`${P}-clickable`,lockClass:`${P}-lock`,horizontalClass:`${P}-horizontal`,verticalClass:`${P}-vertical`,paginationDisabledClass:`${P}-disabled`}}),e.pagination={el:null,bullets:[]};let f=0;function v(){return!e.params.pagination.el||!e.pagination.el||Array.isArray(e.pagination.el)&&0===e.pagination.el.length}function s(A,t){const{bulletActiveClass:n}=e.params.pagination;A&&(A=A[("prev"===t?"previous":"next")+"ElementSibling"])&&(A.classList.add(`${n}-${t}`),(A=A[("prev"===t?"previous":"next")+"ElementSibling"])&&A.classList.add(`${n}-${t}-${t}`))}function a(A){const t=A.target.closest(WP(e.params.pagination.bulletClass));if(!t)return;A.preventDefault();const n=kn(t)*e.params.slidesPerGroup;if(e.params.loop){if(e.realIndex===n)return;e.slideToLoop(n)}else e.slideTo(n)}function w(){const A=e.rtl,t=e.params.pagination;if(v())return;let n,P,a=e.pagination.el;a=Sn(a);const w=e.virtual&&e.params.virtual.enabled?e.virtual.slides.length:e.slides.length,D=e.params.loop?Math.ceil(w/e.params.slidesPerGroup):e.snapGrid.length;if(e.params.loop?(P=e.previousRealIndex||0,n=e.params.slidesPerGroup>1?Math.floor(e.realIndex/e.params.slidesPerGroup):e.realIndex):void 0!==e.snapIndex?(n=e.snapIndex,P=e.previousSnapIndex):(P=e.previousIndex||0,n=e.activeIndex||0),"bullets"===t.type&&e.pagination.bullets&&e.pagination.bullets.length>0){const r=e.pagination.bullets;let v,w,D;if(t.dynamicBullets&&(z=Un(r[0],e.isHorizontal()?"width":"height",!0),a.forEach((A=>{A.style[e.isHorizontal()?"width":"height"]=z*(t.dynamicMainBullets+4)+"px"})),t.dynamicMainBullets>1&&void 0!==P&&(f+=n-(P||0),f>t.dynamicMainBullets-1?f=t.dynamicMainBullets-1:f<0&&(f=0)),v=Math.max(n-f,0),w=v+(Math.min(r.length,t.dynamicMainBullets)-1),D=(w+v)/2),r.forEach((A=>{const e=[...["","-next","-next-next","-prev","-prev-prev","-main"].map((A=>`${t.bulletActiveClass}${A}`))].map((A=>"string"==typeof A&&A.includes(" ")?A.split(" "):A)).flat();A.classList.remove(...e)})),a.length>1)r.forEach((A=>{const r=kn(A);r===n?A.classList.add(...t.bulletActiveClass.split(" ")):e.isElement&&A.setAttribute("part","bullet"),t.dynamicBullets&&(r>=v&&r<=w&&A.classList.add(...`${t.bulletActiveClass}-main`.split(" ")),r===v&&s(A,"prev"),r===w&&s(A,"next"))}));else{const A=r[n];if(A&&A.classList.add(...t.bulletActiveClass.split(" ")),e.isElement&&r.forEach(((A,e)=>{A.setAttribute("part",e===n?"bullet-active":"bullet")})),t.dynamicBullets){const A=r[v],e=r[w];for(let A=v;A<=w;A+=1)r[A]&&r[A].classList.add(...`${t.bulletActiveClass}-main`.split(" "));s(A,"prev"),s(e,"next")}}if(t.dynamicBullets){const n=Math.min(r.length,t.dynamicMainBullets+4),P=(z*n-z)/2-D*z,f=A?"right":"left";r.forEach((A=>{A.style[e.isHorizontal()?f:"top"]=`${P}px`}))}}a.forEach(((A,P)=>{if("fraction"===t.type&&(A.querySelectorAll(WP(t.currentClass)).forEach((A=>{A.textContent=t.formatFractionCurrent(n+1)})),A.querySelectorAll(WP(t.totalClass)).forEach((A=>{A.textContent=t.formatFractionTotal(D)}))),"progressbar"===t.type){let r;r=t.progressbarOpposite?e.isHorizontal()?"vertical":"horizontal":e.isHorizontal()?"horizontal":"vertical";const P=(n+1)/D;let z=1,f=1;"horizontal"===r?z=P:f=P,A.querySelectorAll(WP(t.progressbarFillClass)).forEach((A=>{A.style.transform=`translate3d(0,0,0) scaleX(${z}) scaleY(${f})`,A.style.transitionDuration=`${e.params.speed}ms`}))}"custom"===t.type&&t.renderCustom?(A.innerHTML=t.renderCustom(e,n+1,D),0===P&&r("paginationRender",A)):(0===P&&r("paginationRender",A),r("paginationUpdate",A)),e.params.watchOverflow&&e.enabled&&A.classList[e.isLocked?"add":"remove"](t.lockClass)}))}function D(){const A=e.params.pagination;if(v())return;const t=e.virtual&&e.params.virtual.enabled?e.virtual.slides.length:e.grid&&e.params.grid.rows>1?e.slides.length/Math.ceil(e.params.grid.rows):e.slides.length;let n=e.pagination.el;n=Sn(n);let P="";if("bullets"===A.type){let n=e.params.loop?Math.ceil(t/e.params.slidesPerGroup):e.snapGrid.length;e.params.freeMode&&e.params.freeMode.enabled&&n>t&&(n=t);for(let t=0;t`}"fraction"===A.type&&(P=A.renderFraction?A.renderFraction.call(e,A.currentClass,A.totalClass):` / `),"progressbar"===A.type&&(P=A.renderProgressbar?A.renderProgressbar.call(e,A.progressbarFillClass):``),e.pagination.bullets=[],n.forEach((t=>{"custom"!==A.type&&(t.innerHTML=P||""),"bullets"===A.type&&e.pagination.bullets.push(...t.querySelectorAll(WP(A.bulletClass)))})),"custom"!==A.type&&r("paginationRender",n[0])}function c(){e.params.pagination=HP(e,e.originalParams.pagination,e.params.pagination,{el:"swiper-pagination"});const A=e.params.pagination;if(!A.el)return;let t;"string"==typeof A.el&&e.isElement&&(t=e.el.querySelector(A.el)),t||"string"!=typeof A.el||(t=[...document.querySelectorAll(A.el)]),t||(t=A.el),t&&0!==t.length&&(e.params.uniqueNavElements&&"string"==typeof A.el&&Array.isArray(t)&&t.length>1&&(t=[...e.el.querySelectorAll(A.el)],t.length>1&&(t=t.filter((A=>Kn(A,".swiper")[0]===e.el))[0])),Array.isArray(t)&&1===t.length&&(t=t[0]),Object.assign(e.pagination,{el:t}),t=Sn(t),t.forEach((t=>{"bullets"===A.type&&A.clickable&&t.classList.add(...(A.clickableClass||"").split(" ")),t.classList.add(A.modifierClass+A.type),t.classList.add(e.isHorizontal()?A.horizontalClass:A.verticalClass),"bullets"===A.type&&A.dynamicBullets&&(t.classList.add(`${A.modifierClass}${A.type}-dynamic`),f=0,A.dynamicMainBullets<1&&(A.dynamicMainBullets=1)),"progressbar"===A.type&&A.progressbarOpposite&&t.classList.add(A.progressbarOppositeClass),A.clickable&&t.addEventListener("click",a),e.enabled||t.classList.add(A.lockClass)})))}function l(){const A=e.params.pagination;if(v())return;let t=e.pagination.el;t&&(t=Sn(t),t.forEach((t=>{t.classList.remove(A.hiddenClass),t.classList.remove(A.modifierClass+A.type),t.classList.remove(e.isHorizontal()?A.horizontalClass:A.verticalClass),A.clickable&&(t.classList.remove(...(A.clickableClass||"").split(" ")),t.removeEventListener("click",a))}))),e.pagination.bullets&&e.pagination.bullets.forEach((e=>e.classList.remove(...A.bulletActiveClass.split(" "))))}n("changeDirection",(()=>{if(!e.pagination||!e.pagination.el)return;const A=e.params.pagination;let{el:t}=e.pagination;t=Sn(t),t.forEach((t=>{t.classList.remove(A.horizontalClass,A.verticalClass),t.classList.add(e.isHorizontal()?A.horizontalClass:A.verticalClass)}))})),n("init",(()=>{!1===e.params.pagination.enabled?d():(c(),D(),w())})),n("activeIndexChange",(()=>{void 0===e.snapIndex&&w()})),n("snapIndexChange",(()=>{w()})),n("snapGridLengthChange",(()=>{D(),w()})),n("destroy",(()=>{l()})),n("enable disable",(()=>{let{el:A}=e.pagination;A&&(A=Sn(A),A.forEach((A=>A.classList[e.enabled?"remove":"add"](e.params.pagination.lockClass))))})),n("lock unlock",(()=>{w()})),n("click",((A,t)=>{const n=t.target,P=Sn(e.pagination.el);if(e.params.pagination.el&&e.params.pagination.hideOnClick&&P&&P.length>0&&!n.classList.contains(e.params.pagination.bulletClass)){if(e.navigation&&(e.navigation.nextEl&&n===e.navigation.nextEl||e.navigation.prevEl&&n===e.navigation.prevEl))return;const A=P[0].classList.contains(e.params.pagination.hiddenClass);r(!0===A?"paginationShow":"paginationHide"),P.forEach((A=>A.classList.toggle(e.params.pagination.hiddenClass)))}}));const d=()=>{e.el.classList.add(e.params.pagination.paginationDisabledClass);let{el:A}=e.pagination;A&&(A=Sn(A),A.forEach((A=>A.classList.add(e.params.pagination.paginationDisabledClass)))),l()};Object.assign(e.pagination,{enable:()=>{e.el.classList.remove(e.params.pagination.paginationDisabledClass);let{el:A}=e.pagination;A&&(A=Sn(A),A.forEach((A=>A.classList.remove(e.params.pagination.paginationDisabledClass)))),c(),D(),w()},disable:d,render:D,update:w,init:c,destroy:l})}function OP(A,e){void 0===e&&(e={});var t=e.insertAt;if(A&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],r=document.createElement("style");r.type="text/css","top"===t&&n.firstChild?n.insertBefore(r,n.firstChild):n.appendChild(r),r.styleSheet?r.styleSheet.cssText=A:r.appendChild(document.createTextNode(A))}}Object.keys(bP).forEach((A=>{Object.keys(bP[A]).forEach((e=>{XP.prototype[e]=bP[A][e]}))})),XP.use([nr,rr]);var pP=f`:host { + --swiper-pagination-bullet-inactive-color: var(--secondary-text-color); + --swiper-pagination-bottom: 0; + --lunar-card-padding: 12px; + /* --lunar-card-header-font-color: var(--primary-text-color); + --lunar-card-label-font-color: var(--primary-text-color); */ + --lunar-card-header-text-transform: capitalize; + --lunar-card-header-font-size: x-large; + --lunar-card-label-font-size: 14px; +} + +*:focus { + outline: none; +} + +*, +*::before, +*::after { + box-sizing: border-box; +} + +ha-card { + position: relative; + overflow: hidden; + display: block; + width: 100%; + height: auto; + background-color: var(--card-background-color); + letter-spacing: 0.5px; + padding: 12px; + padding: var(--lunar-card-padding, 12px); + --primary-text-color: var(--lunar-card-label-font-color, var(--primary-text-color)); + --swiper-theme-color: var(--lunar-card-label-font-color, var(--primary-text-color)); +} + +ha-card.__background { + background-size: cover; + background-position: bottom; + background-repeat: no-repeat; + background-image: var(--lunar-background-image); + transition: all 0.5s ease; + --primary-text-color: var(--lunar-card-label-font-color, #e1e1e1); + --swiper-theme-color: var(--lunar-card-label-font-color, #e1e1e1); +} + +ha-card.__flex-col .lunar-card-content { + flex-direction: column; + gap: 1rem; +} + +ha-card.__reverse .lunar-card-content { + flex-direction: row-reverse; +} + +ha-card.__compact-header .lunar-card-header { + padding: 0; +} + +.lunar-card-header { + display: flex; + justify-content: space-between; + align-items: center; + padding: 8px 0 14px 6px; + width: 100%; +} + +.lunar-card-header>.action-btns { + display: inline-flex; + gap: 0.5rem; +} + +.lunar-card-header.flexend { + justify-content: flex-end; +} + + + +ha-card.__background h1 { + color: #e1e1e1; + color: var(--lunar-card-header-font-color, #e1e1e1); +} + +h1 { + color: var(--lunar-card-header-font-color, var(--primary-text-color)); + font-family: inherit; + font-family: var(--ha-card-header-font-family, inherit); + display: block; + margin-top: 0px; + margin-bottom: 0px; + font-weight: 400; + text-transform: capitalize; + text-transform: var(--lunar-card-header-text-transform, capitalize); + font-size: x-large; + font-size: var(--lunar-card-header-font-size, x-large); +} + +.btn-action { + display: block; + color: var(--lunar-card-label-font-color); + cursor: pointer; + opacity: 0.4; +} + +.btn-action[active], +.btn-action:hover { + color: var(--lunar-card-label-font-color); + opacity: 0.8; +} + +.click-shrink { + transition: transform 0.1s; +} + +.click-shrink:active { + transform: scale(0.9); +} + +.lunar-card-content { + display: flex; + padding: 0; + justify-content: center; + align-items: center; + gap: 0.5rem; + font-size: 14px; + font-size: var(--lunar-card-label-font-size, 14px); + text-transform: none; + text-transform: var(--lunar-card-label-text-transform, none); +} + + + +.moon-image { + display: block; + width: 100%; + max-width: 27%; + transition: transform 0.5s; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + max-height: 185px; + aspect-ratio: 1; +} + +.moon-image[calendar] { + max-width: 35%; +} + +.moon-image>img { + width: 100%; + height: 100%; + transform: rotate(0deg); + /* Initial state */ + filter: grayscale(1) brightness(1.2) drop-shadow(2px 2px 6px rgba(0, 0, 0, 0.45)) +} + +.moon-image img.rotatable { + transform-origin: center center; + will-change: transform; + transition: transform 0.5s ease; + /* Smooth rotation */ +} + +@keyframes fadeIn { + 0% { + opacity: 0; + } + + 100% { + opacity: 1; + } +} + +.slide-animation { + animation: fadeIn 1s ease-out forwards; +} + +.moon-data { + width: 100%; + box-sizing: border-box; + margin: 0; + padding-left: 0.5rem; + padding-right: 0.5rem; +} + +.moon-data-item { + display: flex; + /* flex-direction: row; */ + justify-content: space-between; + align-items: center; + gap: 0.5rem; + border-bottom: 1px solid var(--divider-color); + padding-top: 0.25rem; + padding-bottom: 0.25rem; + width: 100%; + flex: 1 1 0%; +} + +.moon-data-item:last-child { + border-bottom: none; + padding-bottom: 0; +} + +.moon-data-item>span.label { + display: flex; + color: var(--lunar-card-label-font-color); + width: -moz-fit-content; + width: fit-content; + text-wrap: nowrap; + flex: 0; +} + +.moon-data-item>.value { + display: flex; + color: var(--lunar-card-label-font-color); + font-weight: 600; + width: auto; + text-wrap: nowrap !important; +} + +.value>span { + font-weight: 400; + font-size: smaller; + padding-right: 2px; + text-wrap: nowrap; +} + +/* SWIPER */ +lunar-base-data { + display: block; + width: 100%; + padding: 0; + margin: 0; + overflow: hidden; +} + +section { + display: block; + width: 100%; + height: auto; + overflow: hidden; +} + +.swiper-container { + width: 100%; + height: 100%; + display: block; + -webkit-backdrop-filter: blur(4px); + backdrop-filter: blur(4px); +} + +/* .swiper-wrapper { + margin-bottom: 1rem; +} */ + +.swiper-slide { + display: block; + width: -moz-fit-content; + width: fit-content; +} + +.swiper-pagination { + position: relative !important; +} + +.swiper-pagination-bullet { + background-color: var(--swiper-theme-color); + transition: all 0.3s ease-in-out !important; +} + +.swiper-pagination-bullet-active { + width: 12px !important; + border-radius: 0.5rem !important; + opacity: 0.7; +} + +/* CALENDAR */ +.calendar-wrapper { + display: flex; + width: 100%; + flex-direction: column; + gap: 1rem; + --calendar-background-color: rgba(255,255,255,0.12157); +} + +.date-input-wrapper { + display: flex; + width: 100%; + position: relative; + justify-content: space-around; + align-items: normal; + gap: 1rem; + text-wrap: nowrap; +} + +.date-input-label { + display: block; + color: var(--lunar-card-label-font-color); + font-size: 16px; + font-weight: 600; + margin-bottom: 8px; +} + +.date-input { + display: block; + width: -moz-fit-content; + width: fit-content; + padding: 0.5rem; + border: 1px solid var(--divider-color); + border-radius: 12px; + border-radius: var(--ha-card-border-radius, 12px); + color: var(--lunar-card-label-font-color); + background-color: var(--calendar-background-color); + transition: all 0.3s ease; + box-sizing: border-box; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + cursor: pointer; +} + +.date-input:focus { + border-color: var(--primary-color); + outline: none; +} + +button.date-input-btn { + cursor: pointer; + background-color: var(--calendar-background-color); + border: 1px solid var(--divider-color); + border-radius: 12px; + border-radius: var(--ha-card-border-radius, 12px); + /* padding: 0.5rem 1rem; */ + color: var(--primary-text-color); + transition: all 0.3s ease; + font-weight: 600; +} + +button.date-input-btn:hover { + background-color: var(--primary-color); + color: var(--primary-background-color); +} + +/* COMPACT VIEW */ + +.btn-action.compact { + position: absolute; + top: 1rem; + right: 1rem; +} + +.compact-view { + display: flex; + width: 100%; + flex-direction: column; + gap: 0.5rem; +} + +.moon-fraction { + font-weight: inherit; + color: var(--lunar-card-label-font-color); + letter-spacing: 1.5px; + line-height: 24px; +} + +.compact-view-items { + margin-top: 1rem; + display: flex; + width: 100%; + justify-content: space-between; + --mdc-icon-size: 17px; +} + +.compact-item { + display: flex; + width: calc(100% / 3); + flex-direction: column; + justify-content: center; + align-items: center; +} + +.compact-item .icon-value { + text-wrap: nowrap; +} + +.compact-item .value { + color: var(--lunar-card-label-font-color); + opacity: 0.8; +}`;OP(pP);var ZP=f`/** + * Swiper 11.1.4 + * Most modern mobile touch slider and framework with hardware accelerated transitions + * https://swiperjs.com + * + * Copyright 2014-2024 Vladimir Kharlampidi + * + * Released under the MIT License + * + * Released on: May 30, 2024 + */ + +/* FONT_START */ +@font-face { + font-family: 'swiper-icons'; + src: url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA'); + font-weight: 400; + font-style: normal; +} +/* FONT_END */ +:root { + --swiper-theme-color: #007aff; + /* + --swiper-preloader-color: var(--swiper-theme-color); + --swiper-wrapper-transition-timing-function: initial; + */ +} +:host { + position: relative; + display: block; + margin-left: auto; + margin-right: auto; + z-index: 1; +} +.swiper { + margin-left: auto; + margin-right: auto; + position: relative; + overflow: hidden; + list-style: none; + padding: 0; + /* Fix of Webkit flickering */ + z-index: 1; + display: block; +} +.swiper-vertical > .swiper-wrapper { + flex-direction: column; +} +.swiper-wrapper { + position: relative; + width: 100%; + height: 100%; + z-index: 1; + display: flex; + transition-property: transform; + transition-timing-function: ease; + transition-timing-function: initial; + transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial); + box-sizing: content-box; +} +.swiper-android .swiper-slide, +.swiper-ios .swiper-slide, +.swiper-wrapper { + transform: translate3d(0px, 0, 0); +} +.swiper-horizontal { + touch-action: pan-y; +} +.swiper-vertical { + touch-action: pan-x; +} +.swiper-slide { + flex-shrink: 0; + width: 100%; + height: 100%; + position: relative; + transition-property: transform; + display: block; +} +.swiper-slide-invisible-blank { + visibility: hidden; +} +/* Auto Height */ +.swiper-autoheight, +.swiper-autoheight .swiper-slide { + height: auto; +} +.swiper-autoheight .swiper-wrapper { + align-items: flex-start; + transition-property: transform, height; +} +.swiper-backface-hidden .swiper-slide { + transform: translateZ(0); + backface-visibility: hidden; +} +/* 3D Effects */ +.swiper-3d.swiper-css-mode .swiper-wrapper { + perspective: 1200px; +} +.swiper-3d .swiper-wrapper { + transform-style: preserve-3d; +} +.swiper-3d { + perspective: 1200px; +} +.swiper-3d .swiper-slide, +.swiper-3d .swiper-cube-shadow { + transform-style: preserve-3d; +} +/* CSS Mode */ +.swiper-css-mode > .swiper-wrapper { + overflow: auto; + scrollbar-width: none; + /* For Firefox */ + -ms-overflow-style: none; + /* For Internet Explorer and Edge */ +} +.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar { + display: none; +} +.swiper-css-mode > .swiper-wrapper > .swiper-slide { + scroll-snap-align: start start; +} +.swiper-css-mode.swiper-horizontal > .swiper-wrapper { + scroll-snap-type: x mandatory; +} +.swiper-css-mode.swiper-vertical > .swiper-wrapper { + scroll-snap-type: y mandatory; +} +.swiper-css-mode.swiper-free-mode > .swiper-wrapper { + scroll-snap-type: none; +} +.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide { + scroll-snap-align: none; +} +.swiper-css-mode.swiper-centered > .swiper-wrapper::before { + content: ''; + flex-shrink: 0; + order: 9999; +} +.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide { + scroll-snap-align: center center; + scroll-snap-stop: always; +} +.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child { + margin-left: var(--swiper-centered-offset-before); +} +.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper::before { + height: 100%; + min-height: 1px; + width: var(--swiper-centered-offset-after); +} +.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child { + margin-top: var(--swiper-centered-offset-before); +} +.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper::before { + width: 100%; + min-width: 1px; + height: var(--swiper-centered-offset-after); +} +/* Slide styles start */ +/* 3D Shadows */ +.swiper-3d .swiper-slide-shadow, +.swiper-3d .swiper-slide-shadow-left, +.swiper-3d .swiper-slide-shadow-right, +.swiper-3d .swiper-slide-shadow-top, +.swiper-3d .swiper-slide-shadow-bottom, +.swiper-3d .swiper-slide-shadow, +.swiper-3d .swiper-slide-shadow-left, +.swiper-3d .swiper-slide-shadow-right, +.swiper-3d .swiper-slide-shadow-top, +.swiper-3d .swiper-slide-shadow-bottom { + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + pointer-events: none; + z-index: 10; +} +.swiper-3d .swiper-slide-shadow { + background: rgba(0, 0, 0, 0.15); +} +.swiper-3d .swiper-slide-shadow-left { + background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); +} +.swiper-3d .swiper-slide-shadow-right { + background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); +} +.swiper-3d .swiper-slide-shadow-top { + background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); +} +.swiper-3d .swiper-slide-shadow-bottom { + background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); +} +.swiper-lazy-preloader { + width: 42px; + height: 42px; + position: absolute; + left: 50%; + top: 50%; + margin-left: -21px; + margin-top: -21px; + z-index: 10; + transform-origin: 50%; + box-sizing: border-box; + border: 4px solid #007aff; + border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color)); + border-radius: 50%; + border-top-color: transparent; +} +.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader, +.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader { + animation: swiper-preloader-spin 1s infinite linear; +} +.swiper-lazy-preloader-white { + --swiper-preloader-color: #fff; +} +.swiper-lazy-preloader-black { + --swiper-preloader-color: #000; +} +@keyframes swiper-preloader-spin { + 0% { + transform: rotate(0deg); + } + 100% { + transform: rotate(360deg); + } +} +/* Slide styles end */ +.swiper-virtual .swiper-slide { + -webkit-backface-visibility: hidden; + transform: translateZ(0); +} +.swiper-virtual.swiper-css-mode .swiper-wrapper::after { + content: ''; + position: absolute; + left: 0; + top: 0; + pointer-events: none; +} +.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after { + height: 1px; + width: var(--swiper-virtual-size); +} +.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after { + width: 1px; + height: var(--swiper-virtual-size); +} +:root { + --swiper-navigation-size: 44px; + /* + --swiper-navigation-top-offset: 50%; + --swiper-navigation-sides-offset: 10px; + --swiper-navigation-color: var(--swiper-theme-color); + */ +} +.swiper-button-prev, +.swiper-button-next { + position: absolute; + top: 50%; + top: var(--swiper-navigation-top-offset, 50%); + width: calc(44px / 44 * 27); + width: calc(var(--swiper-navigation-size) / 44 * 27); + height: 44px; + height: var(--swiper-navigation-size); + margin-top: calc(0px - (44px / 2)); + margin-top: calc(0px - (var(--swiper-navigation-size) / 2)); + z-index: 10; + cursor: pointer; + display: flex; + align-items: center; + justify-content: center; + color: #007aff; + color: var(--swiper-navigation-color, var(--swiper-theme-color)); +} +.swiper-button-prev.swiper-button-disabled, +.swiper-button-next.swiper-button-disabled { + opacity: 0.35; + cursor: auto; + pointer-events: none; +} +.swiper-button-prev.swiper-button-hidden, +.swiper-button-next.swiper-button-hidden { + opacity: 0; + cursor: auto; + pointer-events: none; +} +.swiper-navigation-disabled .swiper-button-prev, +.swiper-navigation-disabled .swiper-button-next { + display: none !important; +} +.swiper-button-prev svg, +.swiper-button-next svg { + width: 100%; + height: 100%; + -o-object-fit: contain; + object-fit: contain; + transform-origin: center; +} +.swiper-rtl .swiper-button-prev svg, +.swiper-rtl .swiper-button-next svg { + transform: rotate(180deg); +} +.swiper-button-prev, +.swiper-rtl .swiper-button-next { + left: 10px; + left: var(--swiper-navigation-sides-offset, 10px); + right: auto; +} +.swiper-button-next, +.swiper-rtl .swiper-button-prev { + right: 10px; + right: var(--swiper-navigation-sides-offset, 10px); + left: auto; +} +.swiper-button-lock { + display: none; +} +/* Navigation font start */ +.swiper-button-prev:after, +.swiper-button-next:after { + font-family: swiper-icons; + font-size: 44px; + font-size: var(--swiper-navigation-size); + text-transform: none !important; + letter-spacing: 0; + font-feature-settings: ; + font-variant: normal; + font-variant: initial; + line-height: 1; +} +.swiper-button-prev:after, +.swiper-rtl .swiper-button-next:after { + content: 'prev'; +} +.swiper-button-next, +.swiper-rtl .swiper-button-prev { + right: 10px; + right: var(--swiper-navigation-sides-offset, 10px); + left: auto; +} +.swiper-button-next:after, +.swiper-rtl .swiper-button-prev:after { + content: 'next'; +} +/* Navigation font end */ +:root { + /* + --swiper-pagination-color: var(--swiper-theme-color); + --swiper-pagination-left: auto; + --swiper-pagination-right: 8px; + --swiper-pagination-bottom: 8px; + --swiper-pagination-top: auto; + --swiper-pagination-fraction-color: inherit; + --swiper-pagination-progressbar-bg-color: rgba(0,0,0,0.25); + --swiper-pagination-progressbar-size: 4px; + --swiper-pagination-bullet-size: 8px; + --swiper-pagination-bullet-width: 8px; + --swiper-pagination-bullet-height: 8px; + --swiper-pagination-bullet-border-radius: 50%; + --swiper-pagination-bullet-inactive-color: #000; + --swiper-pagination-bullet-inactive-opacity: 0.2; + --swiper-pagination-bullet-opacity: 1; + --swiper-pagination-bullet-horizontal-gap: 4px; + --swiper-pagination-bullet-vertical-gap: 6px; + */ +} +.swiper-pagination { + position: absolute; + text-align: center; + transition: 300ms opacity; + transform: translate3d(0, 0, 0); + z-index: 10; +} +.swiper-pagination.swiper-pagination-hidden { + opacity: 0; +} +.swiper-pagination-disabled > .swiper-pagination, +.swiper-pagination.swiper-pagination-disabled { + display: none !important; +} +/* Common Styles */ +.swiper-pagination-fraction, +.swiper-pagination-custom, +.swiper-horizontal > .swiper-pagination-bullets, +.swiper-pagination-bullets.swiper-pagination-horizontal { + bottom: 8px; + bottom: var(--swiper-pagination-bottom, 8px); + top: auto; + top: var(--swiper-pagination-top, auto); + left: 0; + width: 100%; +} +/* Bullets */ +.swiper-pagination-bullets-dynamic { + overflow: hidden; + font-size: 0; +} +.swiper-pagination-bullets-dynamic .swiper-pagination-bullet { + transform: scale(0.33); + position: relative; +} +.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active { + transform: scale(1); +} +.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main { + transform: scale(1); +} +.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev { + transform: scale(0.66); +} +.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev { + transform: scale(0.33); +} +.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next { + transform: scale(0.66); +} +.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next { + transform: scale(0.33); +} +.swiper-pagination-bullet { + width: 8px; + width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px)); + height: 8px; + height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px)); + display: inline-block; + border-radius: 50%; + border-radius: var(--swiper-pagination-bullet-border-radius, 50%); + background: #000; + background: var(--swiper-pagination-bullet-inactive-color, #000); + opacity: 0.2; + opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2); +} +button.swiper-pagination-bullet { + border: none; + margin: 0; + padding: 0; + box-shadow: none; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; +} +.swiper-pagination-clickable .swiper-pagination-bullet { + cursor: pointer; +} +.swiper-pagination-bullet:only-child { + display: none !important; +} +.swiper-pagination-bullet-active { + opacity: 1; + opacity: var(--swiper-pagination-bullet-opacity, 1); + background: #007aff; + background: var(--swiper-pagination-color, var(--swiper-theme-color)); +} +.swiper-vertical > .swiper-pagination-bullets, +.swiper-pagination-vertical.swiper-pagination-bullets { + right: 8px; + right: var(--swiper-pagination-right, 8px); + left: auto; + left: var(--swiper-pagination-left, auto); + top: 50%; + transform: translate3d(0px, -50%, 0); +} +.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet, +.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet { + margin: 6px 0; + margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0; + display: block; +} +.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, +.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic { + top: 50%; + transform: translateY(-50%); + width: 8px; +} +.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, +.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet { + display: inline-block; + transition: 200ms transform, 200ms top; +} +.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, +.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet { + margin: 0 4px; + margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px); +} +.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, +.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic { + left: 50%; + transform: translateX(-50%); + white-space: nowrap; +} +.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, +.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet { + transition: 200ms transform, 200ms left; +} +.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet { + transition: 200ms transform, 200ms right; +} +/* Fraction */ +.swiper-pagination-fraction { + color: inherit; + color: var(--swiper-pagination-fraction-color, inherit); +} +/* Progress */ +.swiper-pagination-progressbar { + background: rgba(0, 0, 0, 0.25); + background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.25)); + position: absolute; +} +.swiper-pagination-progressbar .swiper-pagination-progressbar-fill { + background: #007aff; + background: var(--swiper-pagination-color, var(--swiper-theme-color)); + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + transform: scale(0); + transform-origin: left top; +} +.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill { + transform-origin: right top; +} +.swiper-horizontal > .swiper-pagination-progressbar, +.swiper-pagination-progressbar.swiper-pagination-horizontal, +.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, +.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite { + width: 100%; + height: 4px; + height: var(--swiper-pagination-progressbar-size, 4px); + left: 0; + top: 0; +} +.swiper-vertical > .swiper-pagination-progressbar, +.swiper-pagination-progressbar.swiper-pagination-vertical, +.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, +.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite { + width: 4px; + width: var(--swiper-pagination-progressbar-size, 4px); + height: 100%; + left: 0; + top: 0; +} +.swiper-pagination-lock { + display: none; +} +:root { + /* + --swiper-scrollbar-border-radius: 10px; + --swiper-scrollbar-top: auto; + --swiper-scrollbar-bottom: 4px; + --swiper-scrollbar-left: auto; + --swiper-scrollbar-right: 4px; + --swiper-scrollbar-sides-offset: 1%; + --swiper-scrollbar-bg-color: rgba(0, 0, 0, 0.1); + --swiper-scrollbar-drag-bg-color: rgba(0, 0, 0, 0.5); + --swiper-scrollbar-size: 4px; + */ +} +.swiper-scrollbar { + border-radius: 10px; + border-radius: var(--swiper-scrollbar-border-radius, 10px); + position: relative; + touch-action: none; + background: rgba(0, 0, 0, 0.1); + background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, 0.1)); +} +.swiper-scrollbar-disabled > .swiper-scrollbar, +.swiper-scrollbar.swiper-scrollbar-disabled { + display: none !important; +} +.swiper-horizontal > .swiper-scrollbar, +.swiper-scrollbar.swiper-scrollbar-horizontal { + position: absolute; + left: 1%; + left: var(--swiper-scrollbar-sides-offset, 1%); + bottom: 4px; + bottom: var(--swiper-scrollbar-bottom, 4px); + top: auto; + top: var(--swiper-scrollbar-top, auto); + z-index: 50; + height: 4px; + height: var(--swiper-scrollbar-size, 4px); + width: calc(100% - 2 * 1%); + width: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%)); +} +.swiper-vertical > .swiper-scrollbar, +.swiper-scrollbar.swiper-scrollbar-vertical { + position: absolute; + left: auto; + left: var(--swiper-scrollbar-left, auto); + right: 4px; + right: var(--swiper-scrollbar-right, 4px); + top: 1%; + top: var(--swiper-scrollbar-sides-offset, 1%); + z-index: 50; + width: 4px; + width: var(--swiper-scrollbar-size, 4px); + height: calc(100% - 2 * 1%); + height: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%)); +} +.swiper-scrollbar-drag { + height: 100%; + width: 100%; + position: relative; + background: rgba(0, 0, 0, 0.5); + background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5)); + border-radius: 10px; + border-radius: var(--swiper-scrollbar-border-radius, 10px); + left: 0; + top: 0; +} +.swiper-scrollbar-cursor-drag { + cursor: move; +} +.swiper-scrollbar-lock { + display: none; +} +/* Zoom container styles start */ +.swiper-zoom-container { + width: 100%; + height: 100%; + display: flex; + justify-content: center; + align-items: center; + text-align: center; +} +.swiper-zoom-container > img, +.swiper-zoom-container > svg, +.swiper-zoom-container > canvas { + max-width: 100%; + max-height: 100%; + -o-object-fit: contain; + object-fit: contain; +} +/* Zoom container styles end */ +.swiper-slide-zoomed { + cursor: move; + touch-action: none; +} +/* a11y */ +.swiper .swiper-notification { + position: absolute; + left: 0; + top: 0; + pointer-events: none; + opacity: 0; + z-index: -1000; +} +.swiper-free-mode > .swiper-wrapper { + transition-timing-function: ease-out; + margin: 0 auto; +} +.swiper-grid > .swiper-wrapper { + flex-wrap: wrap; +} +.swiper-grid-column > .swiper-wrapper { + flex-wrap: wrap; + flex-direction: column; +} +.swiper-fade.swiper-free-mode .swiper-slide { + transition-timing-function: ease-out; +} +.swiper-fade .swiper-slide { + pointer-events: none; + transition-property: opacity; +} +.swiper-fade .swiper-slide .swiper-slide { + pointer-events: none; +} +.swiper-fade .swiper-slide-active { + pointer-events: auto; +} +.swiper-fade .swiper-slide-active .swiper-slide-active { + pointer-events: auto; +} +.swiper-cube { + overflow: visible; +} +.swiper-cube .swiper-slide { + pointer-events: none; + backface-visibility: hidden; + z-index: 1; + visibility: hidden; + transform-origin: 0 0; + width: 100%; + height: 100%; +} +.swiper-cube .swiper-slide .swiper-slide { + pointer-events: none; +} +.swiper-cube.swiper-rtl .swiper-slide { + transform-origin: 100% 0; +} +.swiper-cube .swiper-slide-active, +.swiper-cube .swiper-slide-active .swiper-slide-active { + pointer-events: auto; +} +.swiper-cube .swiper-slide-active, +.swiper-cube .swiper-slide-next, +.swiper-cube .swiper-slide-prev { + pointer-events: auto; + visibility: visible; +} +.swiper-cube .swiper-cube-shadow { + position: absolute; + left: 0; + bottom: 0px; + width: 100%; + height: 100%; + opacity: 0.6; + z-index: 0; +} +.swiper-cube .swiper-cube-shadow:before { + content: ''; + background: #000; + position: absolute; + left: 0; + top: 0; + bottom: 0; + right: 0; + filter: blur(50px); +} +.swiper-cube .swiper-slide-next + .swiper-slide { + pointer-events: auto; + visibility: visible; +} +/* Cube slide shadows start */ +.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top, +.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom, +.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left, +.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right { + z-index: 0; + backface-visibility: hidden; +} +/* Cube slide shadows end */ +.swiper-flip { + overflow: visible; +} +.swiper-flip .swiper-slide { + pointer-events: none; + backface-visibility: hidden; + z-index: 1; +} +.swiper-flip .swiper-slide .swiper-slide { + pointer-events: none; +} +.swiper-flip .swiper-slide-active, +.swiper-flip .swiper-slide-active .swiper-slide-active { + pointer-events: auto; +} +/* Flip slide shadows start */ +.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top, +.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom, +.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left, +.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right { + z-index: 0; + backface-visibility: hidden; +} +/* Flip slide shadows end */ +.swiper-creative .swiper-slide { + backface-visibility: hidden; + overflow: hidden; + transition-property: transform, opacity, height; +} +.swiper-cards { + overflow: visible; +} +.swiper-cards .swiper-slide { + transform-origin: center bottom; + backface-visibility: hidden; + overflow: hidden; +} +`;OP(ZP);let yP=class extends aA{constructor(){super(...arguments),this.swiper=null,this._chunkObject=(A,e)=>Object.keys(A).reduce(((t,n,r)=>{const P=Math.floor(r/e);return t[P]||(t[P]={}),t[P][n]=A[n],t}),{})}static get styles(){return[ZP,pP]}firstUpdated(A){super.firstUpdated(A),this.moon&&this.initSwiper()}initSwiper(){var A;const e=null===(A=this.shadowRoot)||void 0===A?void 0:A.querySelector(".swiper-container");if(!e)return;const t=e.querySelector(".swiper-pagination");this.swiper=new XP(e,{modules:[BP],centeredSlides:!0,grabCursor:!0,roundLengths:!0,spaceBetween:12,keyboard:{enabled:!0,onlyInViewport:!0},loop:!1,slidesPerView:1,pagination:{el:t,clickable:!0}})}render(){const A=this.moon.moonData,e=this._chunkObject(A,5),t=Object.keys(e).map((A=>U` +
+
${Object.keys(e[A]).map((A=>this.renderItem(A)))}
+
+ `));return U` +
+
+
${t}
+
+
+
+ `}renderItem(A){const{label:e,value:t,secondValue:n}=this.moon.moonData[A];return U` +
+ ${e} +
+ ${n?U`(${n}) `:""} ${t} +
+
+ + `}}; +/*! + * @kurkle/color v0.3.2 + * https://github.com/kurkle/color#readme + * (c) 2023 Jukka Kurkela + * Released under the MIT License + */ +function GP(A){return A+.5|0}A([MA()],yP.prototype,"moon",void 0),A([MA()],yP.prototype,"swiper",void 0),yP=A([DA("lunar-base-data")],yP);const mP=(A,e,t)=>Math.max(Math.min(A,t),e);function LP(A){return mP(GP(2.55*A),0,255)}function YP(A){return mP(GP(255*A),0,255)}function oP(A){return mP(GP(A/2.55)/100,0,1)}function NP(A){return mP(GP(100*A),0,100)}const iP={0:0,1:1,2:2,3:3,4:4,5:5,6:6,7:7,8:8,9:9,A:10,B:11,C:12,D:13,E:14,F:15,a:10,b:11,c:12,d:13,e:14,f:15},QP=[..."0123456789ABCDEF"],TP=A=>QP[15&A],CP=A=>QP[(240&A)>>4]+QP[15&A],VP=A=>(240&A)>>4==(15&A),hP=A=>VP(A.r)&&VP(A.g)&&VP(A.b)&&VP(A.a);function qP(A){var e,t=A.length;return"#"===A[0]&&(4===t||5===t?e={r:255&17*iP[A[1]],g:255&17*iP[A[2]],b:255&17*iP[A[3]],a:5===t?17*iP[A[4]]:255}:7!==t&&9!==t||(e={r:iP[A[1]]<<4|iP[A[2]],g:iP[A[3]]<<4|iP[A[4]],b:iP[A[5]]<<4|iP[A[6]],a:9===t?iP[A[7]]<<4|iP[A[8]]:255})),e}const IP=(A,e)=>A<255?e(A):"";function kP(A){var e=hP(A)?TP:CP;return A?"#"+e(A.r)+e(A.g)+e(A.b)+IP(A.a,e):void 0}const KP=/^(hsla?|hwb|hsv)\(\s*([-+.e\d]+)(?:deg)?[\s,]+([-+.e\d]+)%[\s,]+([-+.e\d]+)%(?:[\s,]+([-+.e\d]+)(%)?)?\s*\)$/;function UP(A,e,t){const n=e*Math.min(t,1-t),r=(e,r=(e+A/30)%12)=>t-n*Math.max(Math.min(r-3,9-r,1),-1);return[r(0),r(8),r(4)]}function SP(A,e,t){const n=(n,r=(n+A/60)%6)=>t-t*e*Math.max(Math.min(r,4-r,1),0);return[n(5),n(3),n(1)]}function EP(A,e,t){const n=UP(A,1,.5);let r;for(e+t>1&&(r=1/(e+t),e*=r,t*=r),r=0;r<3;r++)n[r]*=1-e-t,n[r]+=e;return n}function RP(A,e,t,n,r){return A===r?(e-t)/n+(e.5?s/(2-r-P):s/(r+P),f=RP(e,t,n,s,r),f=60*f+.5),[0|f,v||0,z]}function FP(A,e,t,n){return(Array.isArray(e)?A(e[0],e[1],e[2]):A(e,t,n)).map(YP)}function _P(A,e,t){return FP(UP,A,e,t)}function $P(A,e,t){return FP(EP,A,e,t)}function Az(A,e,t){return FP(SP,A,e,t)}function ez(A){return(A%360+360)%360}function tz(A){const e=KP.exec(A);let t,n=255;if(!e)return;e[5]!==t&&(n=e[6]?LP(+e[5]):YP(+e[5]));const r=ez(+e[2]),P=+e[3]/100,z=+e[4]/100;return t="hwb"===e[1]?$P(r,P,z):"hsv"===e[1]?Az(r,P,z):_P(r,P,z),{r:t[0],g:t[1],b:t[2],a:n}}function nz(A,e){var t=JP(A);t[0]=ez(t[0]+e),t=_P(t),A.r=t[0],A.g=t[1],A.b=t[2]}function rz(A){if(!A)return;const e=JP(A),t=e[0],n=NP(e[1]),r=NP(e[2]);return A.a<255?`hsla(${t}, ${n}%, ${r}%, ${oP(A.a)})`:`hsl(${t}, ${n}%, ${r}%)`}const Pz={x:"dark",Z:"light",Y:"re",X:"blu",W:"gr",V:"medium",U:"slate",A:"ee",T:"ol",S:"or",B:"ra",C:"lateg",D:"ights",R:"in",Q:"turquois",E:"hi",P:"ro",O:"al",N:"le",M:"de",L:"yello",F:"en",K:"ch",G:"arks",H:"ea",I:"ightg",J:"wh"},zz={OiceXe:"f0f8ff",antiquewEte:"faebd7",aqua:"ffff",aquamarRe:"7fffd4",azuY:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"0",blanKedOmond:"ffebcd",Xe:"ff",XeviTet:"8a2be2",bPwn:"a52a2a",burlywood:"deb887",caMtXe:"5f9ea0",KartYuse:"7fff00",KocTate:"d2691e",cSO:"ff7f50",cSnflowerXe:"6495ed",cSnsilk:"fff8dc",crimson:"dc143c",cyan:"ffff",xXe:"8b",xcyan:"8b8b",xgTMnPd:"b8860b",xWay:"a9a9a9",xgYF:"6400",xgYy:"a9a9a9",xkhaki:"bdb76b",xmagFta:"8b008b",xTivegYF:"556b2f",xSange:"ff8c00",xScEd:"9932cc",xYd:"8b0000",xsOmon:"e9967a",xsHgYF:"8fbc8f",xUXe:"483d8b",xUWay:"2f4f4f",xUgYy:"2f4f4f",xQe:"ced1",xviTet:"9400d3",dAppRk:"ff1493",dApskyXe:"bfff",dimWay:"696969",dimgYy:"696969",dodgerXe:"1e90ff",fiYbrick:"b22222",flSOwEte:"fffaf0",foYstWAn:"228b22",fuKsia:"ff00ff",gaRsbSo:"dcdcdc",ghostwEte:"f8f8ff",gTd:"ffd700",gTMnPd:"daa520",Way:"808080",gYF:"8000",gYFLw:"adff2f",gYy:"808080",honeyMw:"f0fff0",hotpRk:"ff69b4",RdianYd:"cd5c5c",Rdigo:"4b0082",ivSy:"fffff0",khaki:"f0e68c",lavFMr:"e6e6fa",lavFMrXsh:"fff0f5",lawngYF:"7cfc00",NmoncEffon:"fffacd",ZXe:"add8e6",ZcSO:"f08080",Zcyan:"e0ffff",ZgTMnPdLw:"fafad2",ZWay:"d3d3d3",ZgYF:"90ee90",ZgYy:"d3d3d3",ZpRk:"ffb6c1",ZsOmon:"ffa07a",ZsHgYF:"20b2aa",ZskyXe:"87cefa",ZUWay:"778899",ZUgYy:"778899",ZstAlXe:"b0c4de",ZLw:"ffffe0",lime:"ff00",limegYF:"32cd32",lRF:"faf0e6",magFta:"ff00ff",maPon:"800000",VaquamarRe:"66cdaa",VXe:"cd",VScEd:"ba55d3",VpurpN:"9370db",VsHgYF:"3cb371",VUXe:"7b68ee",VsprRggYF:"fa9a",VQe:"48d1cc",VviTetYd:"c71585",midnightXe:"191970",mRtcYam:"f5fffa",mistyPse:"ffe4e1",moccasR:"ffe4b5",navajowEte:"ffdead",navy:"80",Tdlace:"fdf5e6",Tive:"808000",TivedBb:"6b8e23",Sange:"ffa500",SangeYd:"ff4500",ScEd:"da70d6",pOegTMnPd:"eee8aa",pOegYF:"98fb98",pOeQe:"afeeee",pOeviTetYd:"db7093",papayawEp:"ffefd5",pHKpuff:"ffdab9",peru:"cd853f",pRk:"ffc0cb",plum:"dda0dd",powMrXe:"b0e0e6",purpN:"800080",YbeccapurpN:"663399",Yd:"ff0000",Psybrown:"bc8f8f",PyOXe:"4169e1",saddNbPwn:"8b4513",sOmon:"fa8072",sandybPwn:"f4a460",sHgYF:"2e8b57",sHshell:"fff5ee",siFna:"a0522d",silver:"c0c0c0",skyXe:"87ceeb",UXe:"6a5acd",UWay:"708090",UgYy:"708090",snow:"fffafa",sprRggYF:"ff7f",stAlXe:"4682b4",tan:"d2b48c",teO:"8080",tEstN:"d8bfd8",tomato:"ff6347",Qe:"40e0d0",viTet:"ee82ee",JHt:"f5deb3",wEte:"ffffff",wEtesmoke:"f5f5f5",Lw:"ffff00",LwgYF:"9acd32"};function fz(){const A={},e=Object.keys(zz),t=Object.keys(Pz);let n,r,P,z,f;for(n=0;n>16&255,P>>8&255,255&P]}return A}let vz;function sz(A){vz||(vz=fz(),vz.transparent=[0,0,0,0]);const e=vz[A.toLowerCase()];return e&&{r:e[0],g:e[1],b:e[2],a:4===e.length?e[3]:255}}const az=/^rgba?\(\s*([-+.\d]+)(%)?[\s,]+([-+.e\d]+)(%)?[\s,]+([-+.e\d]+)(%)?(?:[\s,/]+([-+.e\d]+)(%)?)?\s*\)$/;function wz(A){const e=az.exec(A);let t,n,r,P=255;if(e){if(e[7]!==t){const A=+e[7];P=e[8]?LP(A):mP(255*A,0,255)}return t=+e[1],n=+e[3],r=+e[5],t=255&(e[2]?LP(t):mP(t,0,255)),n=255&(e[4]?LP(n):mP(n,0,255)),r=255&(e[6]?LP(r):mP(r,0,255)),{r:t,g:n,b:r,a:P}}}function Dz(A){return A&&(A.a<255?`rgba(${A.r}, ${A.g}, ${A.b}, ${oP(A.a)})`:`rgb(${A.r}, ${A.g}, ${A.b})`)}const cz=A=>A<=.0031308?12.92*A:1.055*Math.pow(A,1/2.4)-.055,lz=A=>A<=.04045?A/12.92:Math.pow((A+.055)/1.055,2.4);function dz(A,e,t){const n=lz(oP(A.r)),r=lz(oP(A.g)),P=lz(oP(A.b));return{r:YP(cz(n+t*(lz(oP(e.r))-n))),g:YP(cz(r+t*(lz(oP(e.g))-r))),b:YP(cz(P+t*(lz(oP(e.b))-P))),a:A.a+t*(e.a-A.a)}}function Mz(A,e,t){if(A){let n=JP(A);n[e]=Math.max(0,Math.min(n[e]+n[e]*t,0===e?360:1)),n=_P(n),A.r=n[0],A.g=n[1],A.b=n[2]}}function gz(A,e){return A?Object.assign(e||{},A):A}function uz(A){var e={r:0,g:0,b:0,a:255};return Array.isArray(A)?A.length>=3&&(e={r:A[0],g:A[1],b:A[2],a:255},A.length>3&&(e.a=YP(A[3]))):(e=gz(A,{r:0,g:0,b:0,a:1})).a=YP(e.a),e}function jz(A){return"r"===A.charAt(0)?wz(A):tz(A)}class bz{constructor(A){if(A instanceof bz)return A;const e=typeof A;let t;"object"===e?t=uz(A):"string"===e&&(t=qP(A)||sz(A)||jz(A)),this._rgb=t,this._valid=!!t}get valid(){return this._valid}get rgb(){var A=gz(this._rgb);return A&&(A.a=oP(A.a)),A}set rgb(A){this._rgb=uz(A)}rgbString(){return this._valid?Dz(this._rgb):void 0}hexString(){return this._valid?kP(this._rgb):void 0}hslString(){return this._valid?rz(this._rgb):void 0}mix(A,e){if(A){const t=this.rgb,n=A.rgb;let r;const P=e===r?.5:e,z=2*P-1,f=t.a-n.a,v=((z*f==-1?z:(z+f)/(1+z*f))+1)/2;r=1-v,t.r=255&v*t.r+r*n.r+.5,t.g=255&v*t.g+r*n.g+.5,t.b=255&v*t.b+r*n.b+.5,t.a=P*t.a+(1-P)*n.a,this.rgb=t}return this}interpolate(A,e){return A&&(this._rgb=dz(this._rgb,A._rgb,e)),this}clone(){return new bz(this.rgb)}alpha(A){return this._rgb.a=YP(A),this}clearer(A){return this._rgb.a*=1-A,this}greyscale(){const A=this._rgb,e=GP(.3*A.r+.59*A.g+.11*A.b);return A.r=A.g=A.b=e,this}opaquer(A){return this._rgb.a*=1+A,this}negate(){const A=this._rgb;return A.r=255-A.r,A.g=255-A.g,A.b=255-A.b,this}lighten(A){return Mz(this._rgb,2,A),this}darken(A){return Mz(this._rgb,2,-A),this}saturate(A){return Mz(this._rgb,1,A),this}desaturate(A){return Mz(this._rgb,1,-A),this}rotate(A){return nz(this._rgb,A),this}} +/*! + * Chart.js v4.4.5 + * https://www.chartjs.org + * (c) 2024 Chart.js Contributors + * Released under the MIT License + */function xz(){}const Xz=(()=>{let A=0;return()=>A++})();function Hz(A){return null==A}function Wz(A){if(Array.isArray&&Array.isArray(A))return!0;const e=Object.prototype.toString.call(A);return"[object"===e.slice(0,7)&&"Array]"===e.slice(-6)}function Bz(A){return null!==A&&"[object Object]"===Object.prototype.toString.call(A)}function Oz(A){return("number"==typeof A||A instanceof Number)&&isFinite(+A)}function pz(A,e){return Oz(A)?A:e}function Zz(A,e){return void 0===A?e:A}const yz=(A,e)=>"string"==typeof A&&A.endsWith("%")?parseFloat(A)/100:+A/e,Gz=(A,e)=>"string"==typeof A&&A.endsWith("%")?parseFloat(A)/100*e:+A;function mz(A,e,t){if(A&&"function"==typeof A.call)return A.apply(t,e)}function Lz(A,e,t,n){let r,P,z;if(Wz(A))if(P=A.length,n)for(r=P-1;r>=0;r--)e.call(t,A[r],r);else for(r=0;rA,x:A=>A.x,y:A=>A.y};function hz(A){const e=A.split("."),t=[];let n="";for(const A of e)n+=A,n.endsWith("\\")?n=n.slice(0,-1)+".":(t.push(n),n="");return t}function qz(A){const e=hz(A);return A=>{for(const t of e){if(""===t)break;A=A&&A[t]}return A}}function Iz(A,e){return(Vz[e]||(Vz[e]=qz(e)))(A)}function kz(A){return A.charAt(0).toUpperCase()+A.slice(1)}const Kz=A=>void 0!==A,Uz=A=>"function"==typeof A,Sz=(A,e)=>{if(A.size!==e.size)return!1;for(const t of A)if(!e.has(t))return!1;return!0};function Ez(A){return"mouseup"===A.type||"click"===A.type||"contextmenu"===A.type}const Rz=Math.PI,Jz=2*Rz,Fz=Jz+Rz,_z=Number.POSITIVE_INFINITY,$z=Rz/180,Af=Rz/2,ef=Rz/4,tf=2*Rz/3,nf=Math.log10,rf=Math.sign;function Pf(A,e,t){return Math.abs(A-e)A-e)).pop(),e}function vf(A){return!isNaN(parseFloat(A))&&isFinite(A)}function sf(A,e){const t=Math.round(A);return t-e<=A&&t+e>=A}function af(A,e,t){let n,r,P;for(n=0,r=A.length;nv&&s=Math.min(e,t)-n&&A<=Math.max(e,t)+n}function Xf(A,e,t){t=t||(t=>A[t]1;)n=P+r>>1,t(n)?P=n:r=n;return{lo:P,hi:r}}const Hf=(A,e,t,n)=>Xf(A,t,n?n=>{const r=A[n][e];return rA[n][e]Xf(A,t,(n=>A[n][e]>=t));function Bf(A,e,t){let n=0,r=A.length;for(;nn&&A[r-1]>t;)r--;return n>0||r{const t="_onData"+kz(e),n=A[e];Object.defineProperty(A,e,{configurable:!0,enumerable:!1,value(...e){const r=n.apply(this,e);return A._chartjs.listeners.forEach((A=>{"function"==typeof A[t]&&A[t](...e)})),r}})})))}function Zf(A,e){const t=A._chartjs;if(!t)return;const n=t.listeners,r=n.indexOf(e);-1!==r&&n.splice(r,1),n.length>0||(Of.forEach((e=>{delete A[e]})),delete A._chartjs)}function yf(A){const e=new Set(A);return e.size===A.length?A:Array.from(e)}const Gf="undefined"==typeof window?function(A){return A()}:window.requestAnimationFrame;function mf(A,e){let t=[],n=!1;return function(...r){t=r,n||(n=!0,Gf.call(window,(()=>{n=!1,A.apply(e,t)})))}}function Lf(A,e){let t;return function(...n){return e?(clearTimeout(t),t=setTimeout(A,e,n)):A.apply(this,n),e}}const Yf=A=>"start"===A?"left":"end"===A?"right":"center",of=(A,e,t)=>"start"===A?e:"end"===A?t:(e+t)/2,Nf=(A,e,t,n)=>A===(n?"left":"right")?t:"center"===A?(e+t)/2:e;function Qf(A,e,t){const n=e.length;let r=0,P=n;if(A._sorted){const{iScale:z,_parsed:f}=A,v=z.axis,{min:s,max:a,minDefined:w,maxDefined:D}=z.getUserBounds();w&&(r=jf(Math.min(Hf(f,v,s).lo,t?n:Hf(e,v,z.getPixelForValue(s)).lo),0,n-1)),P=D?jf(Math.max(Hf(f,z.axis,a,!0).hi+1,t?0:Hf(e,v,z.getPixelForValue(a),!0).hi+1),r,n)-r:n-r}return{start:r,count:P}}function Tf(A){const{xScale:e,yScale:t,_scaleRanges:n}=A,r={xmin:e.min,xmax:e.max,ymin:t.min,ymax:t.max};if(!n)return A._scaleRanges=r,!0;const P=n.xmin!==e.min||n.xmax!==e.max||n.ymin!==t.min||n.ymax!==t.max;return Object.assign(n,r),P}const Cf=A=>0===A||1===A,Vf=(A,e,t)=>-Math.pow(2,10*(A-=1))*Math.sin((A-e)*Jz/t),hf=(A,e,t)=>Math.pow(2,-10*A)*Math.sin((A-e)*Jz/t)+1,qf={linear:A=>A,easeInQuad:A=>A*A,easeOutQuad:A=>-A*(A-2),easeInOutQuad:A=>(A/=.5)<1?.5*A*A:-.5*(--A*(A-2)-1),easeInCubic:A=>A*A*A,easeOutCubic:A=>(A-=1)*A*A+1,easeInOutCubic:A=>(A/=.5)<1?.5*A*A*A:.5*((A-=2)*A*A+2),easeInQuart:A=>A*A*A*A,easeOutQuart:A=>-((A-=1)*A*A*A-1),easeInOutQuart:A=>(A/=.5)<1?.5*A*A*A*A:-.5*((A-=2)*A*A*A-2),easeInQuint:A=>A*A*A*A*A,easeOutQuint:A=>(A-=1)*A*A*A*A+1,easeInOutQuint:A=>(A/=.5)<1?.5*A*A*A*A*A:.5*((A-=2)*A*A*A*A+2),easeInSine:A=>1-Math.cos(A*Af),easeOutSine:A=>Math.sin(A*Af),easeInOutSine:A=>-.5*(Math.cos(Rz*A)-1),easeInExpo:A=>0===A?0:Math.pow(2,10*(A-1)),easeOutExpo:A=>1===A?1:1-Math.pow(2,-10*A),easeInOutExpo:A=>Cf(A)?A:A<.5?.5*Math.pow(2,10*(2*A-1)):.5*(2-Math.pow(2,-10*(2*A-1))),easeInCirc:A=>A>=1?A:-(Math.sqrt(1-A*A)-1),easeOutCirc:A=>Math.sqrt(1-(A-=1)*A),easeInOutCirc:A=>(A/=.5)<1?-.5*(Math.sqrt(1-A*A)-1):.5*(Math.sqrt(1-(A-=2)*A)+1),easeInElastic:A=>Cf(A)?A:Vf(A,.075,.3),easeOutElastic:A=>Cf(A)?A:hf(A,.075,.3),easeInOutElastic(A){const e=.1125;return Cf(A)?A:A<.5?.5*Vf(2*A,e,.45):.5+.5*hf(2*A-1,e,.45)},easeInBack(A){const e=1.70158;return A*A*((e+1)*A-e)},easeOutBack(A){const e=1.70158;return(A-=1)*A*((e+1)*A+e)+1},easeInOutBack(A){let e=1.70158;return(A/=.5)<1?A*A*((1+(e*=1.525))*A-e)*.5:.5*((A-=2)*A*((1+(e*=1.525))*A+e)+2)},easeInBounce:A=>1-qf.easeOutBounce(1-A),easeOutBounce(A){const e=7.5625,t=2.75;return A<1/t?e*A*A:A<2/t?e*(A-=1.5/t)*A+.75:A<2.5/t?e*(A-=2.25/t)*A+.9375:e*(A-=2.625/t)*A+.984375},easeInOutBounce:A=>A<.5?.5*qf.easeInBounce(2*A):.5*qf.easeOutBounce(2*A-1)+.5};function If(A){if(A&&"object"==typeof A){const e=A.toString();return"[object CanvasPattern]"===e||"[object CanvasGradient]"===e}return!1}function kf(A){return If(A)?A:new bz(A)}function Kf(A){return If(A)?A:new bz(A).saturate(.5).darken(.1).hexString()}const Uf=["x","y","borderWidth","radius","tension"],Sf=["color","borderColor","backgroundColor"];function Ef(A){A.set("animation",{delay:void 0,duration:1e3,easing:"easeOutQuart",fn:void 0,from:void 0,loop:void 0,to:void 0,type:void 0}),A.describe("animation",{_fallback:!1,_indexable:!1,_scriptable:A=>"onProgress"!==A&&"onComplete"!==A&&"fn"!==A}),A.set("animations",{colors:{type:"color",properties:Sf},numbers:{type:"number",properties:Uf}}),A.describe("animations",{_fallback:"animation"}),A.set("transitions",{active:{animation:{duration:400}},resize:{animation:{duration:0}},show:{animations:{colors:{from:"transparent"},visible:{type:"boolean",duration:0}}},hide:{animations:{colors:{to:"transparent"},visible:{type:"boolean",easing:"linear",fn:A=>0|A}}}})}function Rf(A){A.set("layout",{autoPadding:!0,padding:{top:0,right:0,bottom:0,left:0}})}const Jf=new Map;function Ff(A,e){e=e||{};const t=A+JSON.stringify(e);let n=Jf.get(t);return n||(n=new Intl.NumberFormat(A,e),Jf.set(t,n)),n}function _f(A,e,t){return Ff(e,t).format(A)}const $f={values:A=>Wz(A)?A:""+A,numeric(A,e,t){if(0===A)return"0";const n=this.chart.options.locale;let r,P=A;if(t.length>1){const e=Math.max(Math.abs(t[0].value),Math.abs(t[t.length-1].value));(e<1e-4||e>1e15)&&(r="scientific"),P=Av(A,t)}const z=nf(Math.abs(P)),f=isNaN(z)?1:Math.max(Math.min(-1*Math.floor(z),20),0),v={notation:r,minimumFractionDigits:f,maximumFractionDigits:f};return Object.assign(v,this.options.ticks.format),_f(A,n,v)},logarithmic(A,e,t){if(0===A)return"0";const n=t[e].significand||A/Math.pow(10,Math.floor(nf(A)));return[1,2,3,5,10,15].includes(n)||e>.8*t.length?$f.numeric.call(this,A,e,t):""}};function Av(A,e){let t=e.length>3?e[2].value-e[1].value:e[1].value-e[0].value;return Math.abs(t)>=1&&A!==Math.floor(A)&&(t=A-Math.floor(A)),t}var ev={formatters:$f};function tv(A){A.set("scale",{display:!0,offset:!1,reverse:!1,beginAtZero:!1,bounds:"ticks",clip:!0,grace:0,grid:{display:!0,lineWidth:1,drawOnChartArea:!0,drawTicks:!0,tickLength:8,tickWidth:(A,e)=>e.lineWidth,tickColor:(A,e)=>e.color,offset:!1},border:{display:!0,dash:[],dashOffset:0,width:1},title:{display:!1,text:"",padding:{top:4,bottom:4}},ticks:{minRotation:0,maxRotation:50,mirror:!1,textStrokeWidth:0,textStrokeColor:"",padding:3,display:!0,autoSkip:!0,autoSkipPadding:3,labelOffset:0,callback:ev.formatters.values,minor:{},major:{},align:"center",crossAlign:"near",showLabelBackdrop:!1,backdropColor:"rgba(255, 255, 255, 0.75)",backdropPadding:2}}),A.route("scale.ticks","color","","color"),A.route("scale.grid","color","","borderColor"),A.route("scale.border","color","","borderColor"),A.route("scale.title","color","","color"),A.describe("scale",{_fallback:!1,_scriptable:A=>!A.startsWith("before")&&!A.startsWith("after")&&"callback"!==A&&"parser"!==A,_indexable:A=>"borderDash"!==A&&"tickBorderDash"!==A&&"dash"!==A}),A.describe("scales",{_fallback:"scale"}),A.describe("scale.ticks",{_scriptable:A=>"backdropPadding"!==A&&"callback"!==A,_indexable:A=>"backdropPadding"!==A})}const nv=Object.create(null),rv=Object.create(null);function Pv(A,e){if(!e)return A;const t=e.split(".");for(let e=0,n=t.length;eA.chart.platform.getDevicePixelRatio(),this.elements={},this.events=["mousemove","mouseout","click","touchstart","touchmove"],this.font={family:"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif",size:12,style:"normal",lineHeight:1.2,weight:null},this.hover={},this.hoverBackgroundColor=(A,e)=>Kf(e.backgroundColor),this.hoverBorderColor=(A,e)=>Kf(e.borderColor),this.hoverColor=(A,e)=>Kf(e.color),this.indexAxis="x",this.interaction={mode:"nearest",intersect:!0,includeInvisible:!1},this.maintainAspectRatio=!0,this.onHover=null,this.onClick=null,this.parsing=!0,this.plugins={},this.responsive=!0,this.scale=void 0,this.scales={},this.showLine=!0,this.drawActiveElementsOnTop=!0,this.describe(A),this.apply(e)}set(A,e){return zv(this,A,e)}get(A){return Pv(this,A)}describe(A,e){return zv(rv,A,e)}override(A,e){return zv(nv,A,e)}route(A,e,t,n){const r=Pv(this,A),P=Pv(this,t),z="_"+e;Object.defineProperties(r,{[z]:{value:r[e],writable:!0},[e]:{enumerable:!0,get(){const A=this[z],e=P[n];return Bz(A)?Object.assign({},e,A):Zz(A,e)},set(A){this[z]=A}}})}apply(A){A.forEach((A=>A(this)))}}var vv=new fv({_scriptable:A=>!A.startsWith("on"),_indexable:A=>"events"!==A,hover:{_fallback:"interaction"},interaction:{_scriptable:!1,_indexable:!1}},[Ef,Rf,tv]);function sv(A){return!A||Hz(A.size)||Hz(A.family)?null:(A.style?A.style+" ":"")+(A.weight?A.weight+" ":"")+A.size+"px "+A.family}function av(A,e,t,n,r){let P=e[r];return P||(P=e[r]=A.measureText(r).width,t.push(r)),P>n&&(n=P),n}function wv(A,e,t,n){let r=(n=n||{}).data=n.data||{},P=n.garbageCollect=n.garbageCollect||[];n.font!==e&&(r=n.data={},P=n.garbageCollect=[],n.font=e),A.save(),A.font=e;let z=0;const f=t.length;let v,s,a,w,D;for(v=0;vt.length){for(v=0;v0&&A.stroke()}}function Mv(A,e,t){return t=t||.5,!e||A&&A.x>e.left-t&&A.xe.top-t&&A.y0&&""!==P.strokeColor;let v,s;for(A.save(),A.font=r.string,xv(A,P),v=0;v+A||0;function Gv(A,e){const t={},n=Bz(e),r=n?Object.keys(e):e,P=Bz(A)?n?t=>Zz(A[t],A[e[t]]):e=>A[e]:()=>A;for(const A of r)t[A]=yv(P(A));return t}function mv(A){return Gv(A,{top:"y",right:"x",bottom:"y",left:"x"})}function Lv(A){return Gv(A,["topLeft","topRight","bottomLeft","bottomRight"])}function Yv(A){const e=mv(A);return e.width=e.left+e.right,e.height=e.top+e.bottom,e}function ov(A,e){A=A||{},e=e||vv.font;let t=Zz(A.size,e.size);"string"==typeof t&&(t=parseInt(t,10));let n=Zz(A.style,e.style);n&&!(""+n).match(pv)&&(console.warn('Invalid font style specified: "'+n+'"'),n=void 0);const r={family:Zz(A.family,e.family),lineHeight:Zv(Zz(A.lineHeight,e.lineHeight),t),size:t,style:n,weight:Zz(A.weight,e.weight),string:""};return r.string=sv(r),r}function Nv(A,e,t,n){let r,P,z,f=!0;for(r=0,P=A.length;rt&&0===A?0:A+e;return{min:z(n,-Math.abs(P)),max:z(r,P)}}function Qv(A,e){return Object.assign(Object.create(A),e)}function Tv(A,e=[""],t,n,r=(()=>A[0])){const P=t||A;void 0===n&&(n=As("_fallback",A));const z={[Symbol.toStringTag]:"Object",_cacheable:!0,_scopes:A,_rootScopes:P,_fallback:n,_getTarget:r,override:t=>Tv([t,...A],e,P,n)};return new Proxy(z,{deleteProperty:(e,t)=>(delete e[t],delete e._keys,delete A[0][t],!0),get:(t,n)=>Iv(t,n,(()=>$v(n,e,A,t))),getOwnPropertyDescriptor:(A,e)=>Reflect.getOwnPropertyDescriptor(A._scopes[0],e),getPrototypeOf:()=>Reflect.getPrototypeOf(A[0]),has:(A,e)=>es(A).includes(e),ownKeys:A=>es(A),set(A,e,t){const n=A._storage||(A._storage=r());return A[e]=n[e]=t,delete A._keys,!0}})}function Cv(A,e,t,n){const r={_cacheable:!1,_proxy:A,_context:e,_subProxy:t,_stack:new Set,_descriptors:Vv(A,n),setContext:e=>Cv(A,e,t,n),override:r=>Cv(A.override(r),e,t,n)};return new Proxy(r,{deleteProperty:(e,t)=>(delete e[t],delete A[t],!0),get:(A,e,t)=>Iv(A,e,(()=>kv(A,e,t))),getOwnPropertyDescriptor:(e,t)=>e._descriptors.allKeys?Reflect.has(A,t)?{enumerable:!0,configurable:!0}:void 0:Reflect.getOwnPropertyDescriptor(A,t),getPrototypeOf:()=>Reflect.getPrototypeOf(A),has:(e,t)=>Reflect.has(A,t),ownKeys:()=>Reflect.ownKeys(A),set:(e,t,n)=>(A[t]=n,delete e[t],!0)})}function Vv(A,e={scriptable:!0,indexable:!0}){const{_scriptable:t=e.scriptable,_indexable:n=e.indexable,_allKeys:r=e.allKeys}=A;return{allKeys:r,scriptable:t,indexable:n,isScriptable:Uz(t)?t:()=>t,isIndexable:Uz(n)?n:()=>n}}const hv=(A,e)=>A?A+kz(e):e,qv=(A,e)=>Bz(e)&&"adapters"!==A&&(null===Object.getPrototypeOf(e)||e.constructor===Object);function Iv(A,e,t){if(Object.prototype.hasOwnProperty.call(A,e)||"constructor"===e)return A[e];const n=t();return A[e]=n,n}function kv(A,e,t){const{_proxy:n,_context:r,_subProxy:P,_descriptors:z}=A;let f=n[e];return Uz(f)&&z.isScriptable(e)&&(f=Kv(e,f,A,t)),Wz(f)&&f.length&&(f=Uv(e,f,A,z.isIndexable)),qv(e,f)&&(f=Cv(f,r,P&&P[e],z)),f}function Kv(A,e,t,n){const{_proxy:r,_context:P,_subProxy:z,_stack:f}=t;if(f.has(A))throw new Error("Recursion detected: "+Array.from(f).join("->")+"->"+A);f.add(A);let v=e(P,z||n);return f.delete(A),qv(A,v)&&(v=Jv(r._scopes,r,A,v)),v}function Uv(A,e,t,n){const{_proxy:r,_context:P,_subProxy:z,_descriptors:f}=t;if(void 0!==P.index&&n(A))return e[P.index%e.length];if(Bz(e[0])){const t=e,n=r._scopes.filter((A=>A!==t));e=[];for(const v of t){const t=Jv(n,r,A,v);e.push(Cv(t,P,z&&z[A],f))}}return e}function Sv(A,e,t){return Uz(A)?A(e,t):A}const Ev=(A,e)=>!0===A?e:"string"==typeof A?Iz(e,A):void 0;function Rv(A,e,t,n,r){for(const P of e){const e=Ev(t,P);if(e){A.add(e);const P=Sv(e._fallback,t,r);if(void 0!==P&&P!==t&&P!==n)return P}else if(!1===e&&void 0!==n&&t!==n)return null}return!1}function Jv(A,e,t,n){const r=e._rootScopes,P=Sv(e._fallback,t,n),z=[...A,...r],f=new Set;f.add(n);let v=Fv(f,z,t,P||t,n);return null!==v&&((void 0===P||P===t||(v=Fv(f,z,P,v,n),null!==v))&&Tv(Array.from(f),[""],r,P,(()=>_v(e,t,n))))}function Fv(A,e,t,n,r){for(;t;)t=Rv(A,e,t,n,r);return t}function _v(A,e,t){const n=A._getTarget();e in n||(n[e]={});const r=n[e];return Wz(r)&&Bz(t)?t:r||{}}function $v(A,e,t,n){let r;for(const P of e)if(r=As(hv(P,A),t),void 0!==r)return qv(A,r)?Jv(t,n,A,r):r}function As(A,e){for(const t of e){if(!t)continue;const e=t[A];if(void 0!==e)return e}}function es(A){let e=A._keys;return e||(e=A._keys=ts(A._scopes)),e}function ts(A){const e=new Set;for(const t of A)for(const A of Object.keys(t).filter((A=>!A.startsWith("_"))))e.add(A);return Array.from(e)}function ns(A,e,t,n){const{iScale:r}=A,{key:P="r"}=this._parsing,z=new Array(n);let f,v,s,a;for(f=0,v=n;fe"x"===A?"y":"x";function fs(A,e,t,n){const r=A.skip?e:A,P=e,z=t.skip?e:t,f=df(P,r),v=df(z,P);let s=f/(f+v),a=v/(f+v);s=isNaN(s)?0:s,a=isNaN(a)?0:a;const w=n*s,D=n*a;return{previous:{x:P.x-w*(z.x-r.x),y:P.y-w*(z.y-r.y)},next:{x:P.x+D*(z.x-r.x),y:P.y+D*(z.y-r.y)}}}function vs(A,e,t){const n=A.length;let r,P,z,f,v,s=Ps(A,0);for(let a=0;a!A.skip))),"monotone"===e.cubicInterpolationMode)as(A,r);else{let t=n?A[A.length-1]:A[0];for(P=0,z=A.length;PA.ownerDocument.defaultView.getComputedStyle(A,null);function us(A,e){return gs(A).getPropertyValue(e)}const js=["top","right","bottom","left"];function bs(A,e,t){const n={};t=t?"-"+t:"";for(let r=0;r<4;r++){const P=js[r];n[P]=parseFloat(A[e+"-"+P+t])||0}return n.width=n.left+n.right,n.height=n.top+n.bottom,n}const xs=(A,e,t)=>(A>0||e>0)&&(!t||!t.shadowRoot);function Xs(A,e){const t=A.touches,n=t&&t.length?t[0]:A,{offsetX:r,offsetY:P}=n;let z,f,v=!1;if(xs(r,P,A.target))z=r,f=P;else{const A=e.getBoundingClientRect();z=n.clientX-A.left,f=n.clientY-A.top,v=!0}return{x:z,y:f,box:v}}function Hs(A,e){if("native"in A)return A;const{canvas:t,currentDevicePixelRatio:n}=e,r=gs(t),P="border-box"===r.boxSizing,z=bs(r,"padding"),f=bs(r,"border","width"),{x:v,y:s,box:a}=Xs(A,t),w=z.left+(a&&f.left),D=z.top+(a&&f.top);let{width:c,height:l}=e;return P&&(c-=z.width+f.width,l-=z.height+f.height),{x:Math.round((v-w)/c*t.width/n),y:Math.round((s-D)/l*t.height/n)}}function Ws(A,e,t){let n,r;if(void 0===e||void 0===t){const P=A&&ds(A);if(P){const A=P.getBoundingClientRect(),z=gs(P),f=bs(z,"border","width"),v=bs(z,"padding");e=A.width-v.width-f.width,t=A.height-v.height-f.height,n=Ms(z.maxWidth,P,"clientWidth"),r=Ms(z.maxHeight,P,"clientHeight")}else e=A.clientWidth,t=A.clientHeight}return{width:e,height:t,maxWidth:n||_z,maxHeight:r||_z}}const Bs=A=>Math.round(10*A)/10;function Os(A,e,t,n){const r=gs(A),P=bs(r,"margin"),z=Ms(r.maxWidth,A,"clientWidth")||_z,f=Ms(r.maxHeight,A,"clientHeight")||_z,v=Ws(A,e,t);let{width:s,height:a}=v;if("content-box"===r.boxSizing){const A=bs(r,"border","width"),e=bs(r,"padding");s-=e.width+A.width,a-=e.height+A.height}s=Math.max(0,s-P.width),a=Math.max(0,n?s/n:a-P.height),s=Bs(Math.min(s,z,v.maxWidth)),a=Bs(Math.min(a,f,v.maxHeight)),s&&!a&&(a=Bs(s/2));return(void 0!==e||void 0!==t)&&n&&v.height&&a>v.height&&(a=v.height,s=Bs(Math.floor(a*n))),{width:s,height:a}}function ps(A,e,t){const n=e||1,r=Math.floor(A.height*n),P=Math.floor(A.width*n);A.height=Math.floor(A.height),A.width=Math.floor(A.width);const z=A.canvas;return z.style&&(t||!z.style.height&&!z.style.width)&&(z.style.height=`${A.height}px`,z.style.width=`${A.width}px`),(A.currentDevicePixelRatio!==n||z.height!==r||z.width!==P)&&(A.currentDevicePixelRatio=n,z.height=r,z.width=P,A.ctx.setTransform(n,0,0,n,0,0),!0)}const Zs=function(){let A=!1;try{const e={get passive(){return A=!0,!1}};ls()&&(window.addEventListener("test",null,e),window.removeEventListener("test",null,e))}catch(A){}return A}();function ys(A,e){const t=us(A,e),n=t&&t.match(/^(\d+)(\.\d+)?px$/);return n?+n[1]:void 0}function Gs(A,e,t,n){return{x:A.x+t*(e.x-A.x),y:A.y+t*(e.y-A.y)}}function ms(A,e,t,n){return{x:A.x+t*(e.x-A.x),y:"middle"===n?t<.5?A.y:e.y:"after"===n?t<1?A.y:e.y:t>0?e.y:A.y}}function Ls(A,e,t,n){const r={x:A.cp2x,y:A.cp2y},P={x:e.cp1x,y:e.cp1y},z=Gs(A,r,t),f=Gs(r,P,t),v=Gs(P,e,t),s=Gs(z,f,t),a=Gs(f,v,t);return Gs(s,a,t)}const Ys=function(A,e){return{x:t=>A+A+e-t,setWidth(A){e=A},textAlign:A=>"center"===A?A:"right"===A?"left":"right",xPlus:(A,e)=>A-e,leftForLtr:(A,e)=>A-e}},os=function(){return{x:A=>A,setWidth(A){},textAlign:A=>A,xPlus:(A,e)=>A+e,leftForLtr:(A,e)=>A}};function Ns(A,e,t){return A?Ys(e,t):os()}function is(A,e){let t,n;"ltr"!==e&&"rtl"!==e||(t=A.canvas.style,n=[t.getPropertyValue("direction"),t.getPropertyPriority("direction")],t.setProperty("direction",e,"important"),A.prevTextDirection=n)}function Qs(A,e){void 0!==e&&(delete A.prevTextDirection,A.canvas.style.setProperty("direction",e[0],e[1]))}function Ts(A){return"angle"===A?{between:uf,compare:Mf,normalize:gf}:{between:xf,compare:(A,e)=>A-e,normalize:A=>A}}function Cs({start:A,end:e,count:t,loop:n,style:r}){return{start:A%t,end:e%t,loop:n&&(e-A+1)%t==0,style:r}}function Vs(A,e,t){const{property:n,start:r,end:P}=t,{between:z,normalize:f}=Ts(n),v=e.length;let s,a,{start:w,end:D,loop:c}=A;if(c){for(w+=v,D+=v,s=0,a=v;su||v(r,g,d)&&0!==f(r,g),x=()=>!u||0===f(P,d)||v(P,g,d);for(let A=a,t=a;A<=w;++A)M=e[A%z],M.skip||(d=s(M[n]),d!==g&&(u=v(d,r,P),null===j&&b()&&(j=0===f(d,r)?A:t),null!==j&&x()&&(l.push(Cs({start:j,end:A,loop:D,count:z,style:c})),j=null),t=A,g=d));return null!==j&&l.push(Cs({start:j,end:w,loop:D,count:z,style:c})),l}function qs(A,e){const t=[],n=A.segments;for(let r=0;rr&&A[P%e].skip;)P--;return P%=e,{start:r,end:P}}function ks(A,e,t,n){const r=A.length,P=[];let z,f=e,v=A[e];for(z=e+1;z<=t;++z){const t=A[z%r];t.skip||t.stop?v.skip||(n=!1,P.push({start:e%r,end:(z-1)%r,loop:n}),e=f=t.stop?z:null):(f=z,v.skip&&(e=z)),v=t}return null!==f&&P.push({start:e%r,end:f%r,loop:n}),P}function Ks(A,e){const t=A.points,n=A.options.spanGaps,r=t.length;if(!r)return[];const P=!!A._loop,{start:z,end:f}=Is(t,r,P,n);if(!0===n)return Us(A,[{start:z,end:f,loop:P}],t,e);return Us(A,ks(t,z,fn({chart:A,initial:e.initial,numSteps:P,currentStep:Math.min(t-e.start,P)})))}_refresh(){this._request||(this._running=!0,this._request=Gf.call(window,(()=>{this._update(),this._request=null,this._running&&this._refresh()})))}_update(A=Date.now()){let e=0;this._charts.forEach(((t,n)=>{if(!t.running||!t.items.length)return;const r=t.items;let P,z=r.length-1,f=!1;for(;z>=0;--z)P=r[z],P._active?(P._total>t.duration&&(t.duration=P._total),P.tick(A),f=!0):(r[z]=r[r.length-1],r.pop());f&&(n.draw(),this._notify(n,t,A,"progress")),r.length||(t.running=!1,this._notify(n,t,A,"complete"),t.initial=!1),e+=r.length})),this._lastDate=A,0===e&&(this._running=!1)}_getAnims(A){const e=this._charts;let t=e.get(A);return t||(t={running:!1,initial:!0,items:[],listeners:{complete:[],progress:[]}},e.set(A,t)),t}listen(A,e,t){this._getAnims(A).listeners[e].push(t)}add(A,e){e&&e.length&&this._getAnims(A).items.push(...e)}has(A){return this._getAnims(A).items.length>0}start(A){const e=this._charts.get(A);e&&(e.running=!0,e.start=Date.now(),e.duration=e.items.reduce(((A,e)=>Math.max(A,e._duration)),0),this._refresh())}running(A){if(!this._running)return!1;const e=this._charts.get(A);return!!(e&&e.running&&e.items.length)}stop(A){const e=this._charts.get(A);if(!e||!e.items.length)return;const t=e.items;let n=t.length-1;for(;n>=0;--n)t[n].cancel();e.items=[],this._notify(A,e,Date.now(),"complete")}remove(A){return this._charts.delete(A)}}var Fs=new Js;const _s="transparent",$s={boolean:(A,e,t)=>t>.5?e:A,color(A,e,t){const n=kf(A||_s),r=n.valid&&kf(e||_s);return r&&r.valid?r.mix(n,t).hexString():e},number:(A,e,t)=>A+(e-A)*t};class Aa{constructor(A,e,t,n){const r=e[t];n=Nv([A.to,n,r,A.from]);const P=Nv([A.from,r,n]);this._active=!0,this._fn=A.fn||$s[A.type||typeof P],this._easing=qf[A.easing]||qf.linear,this._start=Math.floor(Date.now()+(A.delay||0)),this._duration=this._total=Math.floor(A.duration),this._loop=!!A.loop,this._target=e,this._prop=t,this._from=P,this._to=n,this._promises=void 0}active(){return this._active}update(A,e,t){if(this._active){this._notify(!1);const n=this._target[this._prop],r=t-this._start,P=this._duration-r;this._start=t,this._duration=Math.floor(Math.max(P,A.duration)),this._total+=r,this._loop=!!A.loop,this._to=Nv([A.to,e,n,A.from]),this._from=Nv([A.from,n,e])}}cancel(){this._active&&(this.tick(Date.now()),this._active=!1,this._notify(!1))}tick(A){const e=A-this._start,t=this._duration,n=this._prop,r=this._from,P=this._loop,z=this._to;let f;if(this._active=r!==z&&(P||e1?2-f:f,f=this._easing(Math.min(1,Math.max(0,f))),this._target[n]=this._fn(r,z,f))}wait(){const A=this._promises||(this._promises=[]);return new Promise(((e,t)=>{A.push({res:e,rej:t})}))}_notify(A){const e=A?"res":"rej",t=this._promises||[];for(let A=0;A{const r=A[n];if(!Bz(r))return;const P={};for(const A of e)P[A]=r[A];(Wz(r.properties)&&r.properties||[n]).forEach((A=>{A!==n&&t.has(A)||t.set(A,P)}))}))}_animateOptions(A,e){const t=e.options,n=na(A,t);if(!n)return[];const r=this._createAnimations(n,t);return t.$shared&&ta(A.options.$animations,t).then((()=>{A.options=t}),(()=>{})),r}_createAnimations(A,e){const t=this._properties,n=[],r=A.$animations||(A.$animations={}),P=Object.keys(e),z=Date.now();let f;for(f=P.length-1;f>=0;--f){const v=P[f];if("$"===v.charAt(0))continue;if("options"===v){n.push(...this._animateOptions(A,e));continue}const s=e[v];let a=r[v];const w=t.get(v);if(a){if(w&&a.active()){a.update(w,s,z);continue}a.cancel()}w&&w.duration?(r[v]=a=new Aa(w,A,v,s),n.push(a)):A[v]=s}return n}update(A,e){if(0===this._properties.size)return void Object.assign(A,e);const t=this._createAnimations(A,e);return t.length?(Fs.add(this._chart,t),!0):void 0}}function ta(A,e){const t=[],n=Object.keys(e);for(let e=0;e0||!t&&e<0)return r.index}return null}function da(A,e){const{chart:t,_cachedMeta:n}=A,r=t._stacks||(t._stacks={}),{iScale:P,vScale:z,index:f}=n,v=P.axis,s=z.axis,a=wa(P,z,n),w=e.length;let D;for(let A=0;At[A].axis===e)).shift()}function ga(A,e){return Qv(A,{active:!1,dataset:void 0,datasetIndex:e,index:e,mode:"default",type:"dataset"})}function ua(A,e,t){return Qv(A,{active:!1,dataIndex:e,parsed:void 0,raw:void 0,element:t,index:e,mode:"default",type:"data"})}function ja(A,e){const t=A.controller.index,n=A.vScale&&A.vScale.axis;if(n){e=e||A._parsed;for(const A of e){const e=A._stacks;if(!e||void 0===e[n]||void 0===e[n][t])return;delete e[n][t],void 0!==e[n]._visualValues&&void 0!==e[n]._visualValues[t]&&delete e[n]._visualValues[t]}}}const ba=A=>"reset"===A||"none"===A,xa=(A,e)=>e?A:Object.assign({},A),Xa=(A,e,t)=>A&&!e.hidden&&e._stacked&&{keys:fa(t,!0),values:null};class Ha{static defaults={};static datasetElementType=null;static dataElementType=null;constructor(A,e){this.chart=A,this._ctx=A.ctx,this.index=e,this._cachedDataOpts={},this._cachedMeta=this.getMeta(),this._type=this._cachedMeta.type,this.options=void 0,this._parsing=!1,this._data=void 0,this._objectData=void 0,this._sharedOptions=void 0,this._drawStart=void 0,this._drawCount=void 0,this.enableOptionSharing=!1,this.supportsDecimation=!1,this.$context=void 0,this._syncList=[],this.datasetElementType=new.target.datasetElementType,this.dataElementType=new.target.dataElementType,this.initialize()}initialize(){const A=this._cachedMeta;this.configure(),this.linkScales(),A._stacked=aa(A.vScale,A),this.addElements(),this.options.fill&&!this.chart.isPluginEnabled("filler")&&console.warn("Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options")}updateIndex(A){this.index!==A&&ja(this._cachedMeta),this.index=A}linkScales(){const A=this.chart,e=this._cachedMeta,t=this.getDataset(),n=(A,e,t,n)=>"x"===A?e:"r"===A?n:t,r=e.xAxisID=Zz(t.xAxisID,Ma(A,"x")),P=e.yAxisID=Zz(t.yAxisID,Ma(A,"y")),z=e.rAxisID=Zz(t.rAxisID,Ma(A,"r")),f=e.indexAxis,v=e.iAxisID=n(f,r,P,z),s=e.vAxisID=n(f,P,r,z);e.xScale=this.getScaleForId(r),e.yScale=this.getScaleForId(P),e.rScale=this.getScaleForId(z),e.iScale=this.getScaleForId(v),e.vScale=this.getScaleForId(s)}getDataset(){return this.chart.data.datasets[this.index]}getMeta(){return this.chart.getDatasetMeta(this.index)}getScaleForId(A){return this.chart.scales[A]}_getOtherScale(A){const e=this._cachedMeta;return A===e.iScale?e.vScale:e.iScale}reset(){this._update("reset")}_destroy(){const A=this._cachedMeta;this._data&&Zf(this._data,this),A._stacked&&ja(A)}_dataCheck(){const A=this.getDataset(),e=A.data||(A.data=[]),t=this._data;if(Bz(e)){const A=this._cachedMeta;this._data=sa(e,A)}else if(t!==e){if(t){Zf(t,this);const A=this._cachedMeta;ja(A),A._parsed=[]}e&&Object.isExtensible(e)&&pf(e,this),this._syncList=[],this._data=e}}addElements(){const A=this._cachedMeta;this._dataCheck(),this.datasetElementType&&(A.dataset=new this.datasetElementType)}buildOrUpdateElements(A){const e=this._cachedMeta,t=this.getDataset();let n=!1;this._dataCheck();const r=e._stacked;e._stacked=aa(e.vScale,e),e.stack!==t.stack&&(n=!0,ja(e),e.stack=t.stack),this._resyncElements(A),(n||r!==e._stacked)&&(da(this,e._parsed),e._stacked=aa(e.vScale,e))}configure(){const A=this.chart.config,e=A.datasetScopeKeys(this._type),t=A.getOptionScopes(this.getDataset(),e,!0);this.options=A.createResolver(t,this.getContext()),this._parsing=this.options.parsing,this._cachedDataOpts={}}parse(A,e){const{_cachedMeta:t,_data:n}=this,{iScale:r,_stacked:P}=t,z=r.axis;let f,v,s,a=0===A&&e===n.length||t._sorted,w=A>0&&t._parsed[A-1];if(!1===this._parsing)t._parsed=n,t._sorted=!0,s=n;else{s=Wz(n[A])?this.parseArrayData(t,n,A,e):Bz(n[A])?this.parseObjectData(t,n,A,e):this.parsePrimitiveData(t,n,A,e);const r=()=>null===v[z]||w&&v[z]e||a=0;--w)if(!c()){this.updateRangeFromParsed(v,A,D,f);break}return v}getAllParsedValues(A){const e=this._cachedMeta._parsed,t=[];let n,r,P;for(n=0,r=e.length;n=0&&Athis.getContext(t,n,e)),a);return c.$shared&&(c.$shared=f,r[P]=Object.freeze(xa(c,f))),c}_resolveAnimations(A,e,t){const n=this.chart,r=this._cachedDataOpts,P=`animation-${e}`,z=r[P];if(z)return z;let f;if(!1!==n.options.animation){const n=this.chart.config,r=n.datasetAnimationScopeKeys(this._type,e),P=n.getOptionScopes(this.getDataset(),r);f=n.createResolver(P,this.getContext(A,t,e))}const v=new ea(n,f&&f.animations);return f&&f._cacheable&&(r[P]=Object.freeze(v)),v}getSharedOptions(A){if(A.$shared)return this._sharedOptions||(this._sharedOptions=Object.assign({},A))}includeOptions(A,e){return!e||ba(A)||this.chart._animationsDisabled}_getSharedOptions(A,e){const t=this.resolveDataElementOptions(A,e),n=this._sharedOptions,r=this.getSharedOptions(t),P=this.includeOptions(e,r)||r!==n;return this.updateSharedOptions(r,e,t),{sharedOptions:r,includeOptions:P}}updateElement(A,e,t,n){ba(n)?Object.assign(A,t):this._resolveAnimations(e,n).update(A,t)}updateSharedOptions(A,e,t){A&&!ba(e)&&this._resolveAnimations(void 0,e).update(A,t)}_setStyle(A,e,t,n){A.active=n;const r=this.getStyle(e,n);this._resolveAnimations(e,t,n).update(A,{options:!n&&this.getSharedOptions(r)||r})}removeHoverStyle(A,e,t){this._setStyle(A,t,"active",!1)}setHoverStyle(A,e,t){this._setStyle(A,t,"active",!0)}_removeDatasetHoverStyle(){const A=this._cachedMeta.dataset;A&&this._setStyle(A,void 0,"active",!1)}_setDatasetHoverStyle(){const A=this._cachedMeta.dataset;A&&this._setStyle(A,void 0,"active",!0)}_resyncElements(A){const e=this._data,t=this._cachedMeta.data;for(const[A,e,t]of this._syncList)this[A](e,t);this._syncList=[];const n=t.length,r=e.length,P=Math.min(r,n);P&&this.parse(0,P),r>n?this._insertElements(n,r-n,A):r{for(A.length+=e,z=A.length-1;z>=P;z--)A[z]=A[z-e]};for(f(r),z=A;zA-e)))}return A._cache.$bar}function Ba(A){const e=A.iScale,t=Wa(e,A.type);let n,r,P,z,f=e._length;const v=()=>{32767!==P&&-32768!==P&&(Kz(z)&&(f=Math.min(f,Math.abs(P-z)||f)),z=P)};for(n=0,r=t.length;n0?r[A-1]:null,f=AMath.abs(f)&&(v=f,s=z),e[t.axis]=s,e._custom={barStart:v,barEnd:s,start:r,end:P,min:z,max:f}}function ya(A,e,t,n){return Wz(A)?Za(A,e,t,n):e[t.axis]=t.parse(A,n),e}function Ga(A,e,t,n){const r=A.iScale,P=A.vScale,z=r.getLabels(),f=r===P,v=[];let s,a,w,D;for(s=t,a=t+n;s=t?1:-1)}function Ya(A){let e,t,n,r,P;return A.horizontal?(e=A.base>A.x,t="left",n="right"):(e=A.baseA.controller.options.grouped)),r=t.options.stacked,P=[],z=this._cachedMeta.controller.getParsed(e),f=z&&z[t.axis],v=A=>{const e=A._parsed.find((A=>A[t.axis]===f)),n=e&&e[A.vScale.axis];if(Hz(n)||isNaN(n))return!0};for(const t of n)if((void 0===e||!v(t))&&((!1===r||-1===P.indexOf(t.stack)||void 0===r&&void 0===t.stack)&&P.push(t.stack),t.index===A))break;return P.length||P.push(void 0),P}_getStackCount(A){return this._getStacks(void 0,A).length}_getStackIndex(A,e,t){const n=this._getStacks(A,t),r=void 0!==e?n.indexOf(e):-1;return-1===r?n.length-1:r}_getRuler(){const A=this.options,e=this._cachedMeta,t=e.iScale,n=[];let r,P;for(r=0,P=e.data.length;r=0;--t)e=Math.max(e,A[t].size(this.resolveDataElementOptions(t))/2);return e>0&&e}getLabelAndValue(A){const e=this._cachedMeta,t=this.chart.data.labels||[],{xScale:n,yScale:r}=e,P=this.getParsed(A),z=n.getLabelForValue(P.x),f=r.getLabelForValue(P.y),v=P._custom;return{label:t[A]||"",value:"("+z+", "+f+(v?", "+v:"")+")"}}update(A){const e=this._cachedMeta.data;this.updateElements(e,0,e.length,A)}updateElements(A,e,t,n){const r="reset"===n,{iScale:P,vScale:z}=this._cachedMeta,{sharedOptions:f,includeOptions:v}=this._getSharedOptions(e,n),s=P.axis,a=z.axis;for(let w=e;wuf(A,f,v,!0)?1:Math.max(e,e*t,n,n*t),l=(A,e,n)=>uf(A,f,v,!0)?-1:Math.min(e,e*t,n,n*t),d=c(0,s,w),M=c(Af,a,D),g=l(Rz,s,w),u=l(Rz+Af,a,D);n=(d-g)/2,r=(M-u)/2,P=-(d+g)/2,z=-(M+u)/2}return{ratioX:n,ratioY:r,offsetX:P,offsetY:z}}class qa extends Ha{static id="doughnut";static defaults={datasetElementType:!1,dataElementType:"arc",animation:{animateRotate:!0,animateScale:!1},animations:{numbers:{type:"number",properties:["circumference","endAngle","innerRadius","outerRadius","startAngle","x","y","offset","borderWidth","spacing"]}},cutout:"50%",rotation:0,circumference:360,radius:"100%",spacing:0,indexAxis:"r"};static descriptors={_scriptable:A=>"spacing"!==A,_indexable:A=>"spacing"!==A&&!A.startsWith("borderDash")&&!A.startsWith("hoverBorderDash")};static overrides={aspectRatio:1,plugins:{legend:{labels:{generateLabels(A){const e=A.data;if(e.labels.length&&e.datasets.length){const{labels:{pointStyle:t,color:n}}=A.legend.options;return e.labels.map(((e,r)=>{const P=A.getDatasetMeta(0).controller.getStyle(r);return{text:e,fillStyle:P.backgroundColor,strokeStyle:P.borderColor,fontColor:n,lineWidth:P.borderWidth,pointStyle:t,hidden:!A.getDataVisibility(r),index:r}}))}return[]}},onClick(A,e,t){t.chart.toggleDataVisibility(e.index),t.chart.update()}}}};constructor(A,e){super(A,e),this.enableOptionSharing=!0,this.innerRadius=void 0,this.outerRadius=void 0,this.offsetX=void 0,this.offsetY=void 0}linkScales(){}parse(A,e){const t=this.getDataset().data,n=this._cachedMeta;if(!1===this._parsing)n._parsed=t;else{let r,P,z=A=>+t[A];if(Bz(t[A])){const{key:A="value"}=this._parsing;z=e=>+Iz(t[e],A)}for(r=A,P=A+e;r0&&!isNaN(A)?Jz*(Math.abs(A)/e):0}getLabelAndValue(A){const e=this._cachedMeta,t=this.chart,n=t.data.labels||[],r=_f(e._parsed[A],t.options.locale);return{label:n[A]||"",value:r}}getMaxBorderWidth(A){let e=0;const t=this.chart;let n,r,P,z,f;if(!A)for(n=0,r=t.data.datasets.length;n0&&this.getParsed(e-1);for(let t=0;t=g){u.skip=!0;continue}const b=this.getParsed(t),x=Hz(b[D]),X=u[w]=P.getPixelForValue(b[w],t),H=u[D]=r||x?z.getBasePixel():z.getPixelForValue(f?this.applyStack(z,b,f):b[D],t);u.skip=isNaN(X)||isNaN(H)||x,u.stop=t>0&&Math.abs(b[w]-j[w])>d,l&&(u.parsed=b,u.raw=v.data[t]),a&&(u.options=s||this.resolveDataElementOptions(t,c.active?"active":n)),M||this.updateElement(c,t,u,n),j=b}}getMaxOverflow(){const A=this._cachedMeta,e=A.dataset,t=e.options&&e.options.borderWidth||0,n=A.data||[];if(!n.length)return t;const r=n[0].size(this.resolveDataElementOptions(0)),P=n[n.length-1].size(this.resolveDataElementOptions(n.length-1));return Math.max(t,r,P)/2}draw(){const A=this._cachedMeta;A.dataset.updateControlPoints(this.chart.chartArea,A.iScale.axis),super.draw()}}class ka extends Ha{static id="polarArea";static defaults={dataElementType:"arc",animation:{animateRotate:!0,animateScale:!0},animations:{numbers:{type:"number",properties:["x","y","startAngle","endAngle","innerRadius","outerRadius"]}},indexAxis:"r",startAngle:0};static overrides={aspectRatio:1,plugins:{legend:{labels:{generateLabels(A){const e=A.data;if(e.labels.length&&e.datasets.length){const{labels:{pointStyle:t,color:n}}=A.legend.options;return e.labels.map(((e,r)=>{const P=A.getDatasetMeta(0).controller.getStyle(r);return{text:e,fillStyle:P.backgroundColor,strokeStyle:P.borderColor,fontColor:n,lineWidth:P.borderWidth,pointStyle:t,hidden:!A.getDataVisibility(r),index:r}}))}return[]}},onClick(A,e,t){t.chart.toggleDataVisibility(e.index),t.chart.update()}}},scales:{r:{type:"radialLinear",angleLines:{display:!1},beginAtZero:!0,grid:{circular:!0},pointLabels:{display:!1},startAngle:0}}};constructor(A,e){super(A,e),this.innerRadius=void 0,this.outerRadius=void 0}getLabelAndValue(A){const e=this._cachedMeta,t=this.chart,n=t.data.labels||[],r=_f(e._parsed[A].r,t.options.locale);return{label:n[A]||"",value:r}}parseObjectData(A,e,t,n){return ns.bind(this)(A,e,t,n)}update(A){const e=this._cachedMeta.data;this._updateRadius(),this.updateElements(e,0,e.length,A)}getMinMax(){const A=this._cachedMeta,e={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY};return A.data.forEach(((A,t)=>{const n=this.getParsed(t).r;!isNaN(n)&&this.chart.getDataVisibility(t)&&(ne.max&&(e.max=n))})),e}_updateRadius(){const A=this.chart,e=A.chartArea,t=A.options,n=Math.min(e.right-e.left,e.bottom-e.top),r=Math.max(n/2,0),P=(r-Math.max(t.cutoutPercentage?r/100*t.cutoutPercentage:1,0))/A.getVisibleDatasetCount();this.outerRadius=r-P*this.index,this.innerRadius=this.outerRadius-P}updateElements(A,e,t,n){const r="reset"===n,P=this.chart,z=P.options.animation,f=this._cachedMeta.rScale,v=f.xCenter,s=f.yCenter,a=f.getIndexAngle(0)-.5*Rz;let w,D=a;const c=360/this.countVisibleElements();for(w=0;w{!isNaN(this.getParsed(t).r)&&this.chart.getDataVisibility(t)&&e++})),e}_computeAngle(A,e,t){return this.chart.getDataVisibility(A)?wf(this.resolveDataElementOptions(A,e).angle||t):0}}class Ka extends qa{static id="pie";static defaults={cutout:0,rotation:0,circumference:360,radius:"100%"}}class Ua extends Ha{static id="radar";static defaults={datasetElementType:"line",dataElementType:"point",indexAxis:"r",showLine:!0,elements:{line:{fill:"start"}}};static overrides={aspectRatio:1,scales:{r:{type:"radialLinear"}}};getLabelAndValue(A){const e=this._cachedMeta.vScale,t=this.getParsed(A);return{label:e.getLabels()[A],value:""+e.getLabelForValue(t[e.axis])}}parseObjectData(A,e,t,n){return ns.bind(this)(A,e,t,n)}update(A){const e=this._cachedMeta,t=e.dataset,n=e.data||[],r=e.iScale.getLabels();if(t.points=n,"resize"!==A){const e=this.resolveDatasetElementOptions(A);this.options.showLine||(e.borderWidth=0);const P={_loop:!0,_fullLoop:r.length===n.length,options:e};this.updateElement(t,void 0,P,A)}this.updateElements(n,0,n.length,A)}updateElements(A,e,t,n){const r=this._cachedMeta.rScale,P="reset"===n;for(let z=e;z0&&this.getParsed(e-1);for(let s=e;s0&&Math.abs(t[D]-u[D])>M,d&&(l.parsed=t,l.raw=v.data[s]),w&&(l.options=a||this.resolveDataElementOptions(s,e.active?"active":n)),g||this.updateElement(e,s,l,n),u=t}this.updateSharedOptions(a,n,s)}getMaxOverflow(){const A=this._cachedMeta,e=A.data||[];if(!this.options.showLine){let A=0;for(let t=e.length-1;t>=0;--t)A=Math.max(A,e[t].size(this.resolveDataElementOptions(t))/2);return A>0&&A}const t=A.dataset,n=t.options&&t.options.borderWidth||0;if(!e.length)return n;const r=e[0].size(this.resolveDataElementOptions(0)),P=e[e.length-1].size(this.resolveDataElementOptions(e.length-1));return Math.max(n,r,P)/2}}var Ea=Object.freeze({__proto__:null,BarController:Ca,BubbleController:Va,DoughnutController:qa,LineController:Ia,PieController:Ka,PolarAreaController:ka,RadarController:Ua,ScatterController:Sa});function Ra(){throw new Error("This method is not implemented: Check that a complete date adapter is provided.")}class Ja{static override(A){Object.assign(Ja.prototype,A)}options;constructor(A){this.options=A||{}}init(){}formats(){return Ra()}parse(){return Ra()}format(){return Ra()}add(){return Ra()}diff(){return Ra()}startOf(){return Ra()}endOf(){return Ra()}}var Fa={_date:Ja};function _a(A,e,t,n){const{controller:r,data:P,_sorted:z}=A,f=r._cachedMeta.iScale;if(f&&e===f.axis&&"r"!==e&&z&&P.length){const A=f._reversePixels?Wf:Hf;if(!n)return A(P,e,t);if(r._sharedOptions){const n=P[0],r="function"==typeof n.getRange&&n.getRange(e);if(r){const n=A(P,e,t-r),z=A(P,e,t+r);return{lo:n.lo,hi:z.hi}}}}return{lo:0,hi:P.length-1}}function $a(A,e,t,n,r){const P=A.getSortedVisibleDatasetMetas(),z=t[e];for(let A=0,t=P.length;A{A[z]&&A[z](e[t],r)&&(P.push({element:A,datasetIndex:n,index:v}),f=f||A.inRange(e.x,e.y,r))})),n&&!f?[]:P}var zw={evaluateInteractionItems:$a,modes:{index(A,e,t,n){const r=Hs(e,A),P=t.axis||"x",z=t.includeInvisible||!1,f=t.intersect?ew(A,r,P,n,z):rw(A,r,P,!1,n,z),v=[];return f.length?(A.getSortedVisibleDatasetMetas().forEach((A=>{const e=f[0].index,t=A.data[e];t&&!t.skip&&v.push({element:t,datasetIndex:A.index,index:e})})),v):[]},dataset(A,e,t,n){const r=Hs(e,A),P=t.axis||"xy",z=t.includeInvisible||!1;let f=t.intersect?ew(A,r,P,n,z):rw(A,r,P,!1,n,z);if(f.length>0){const e=f[0].datasetIndex,t=A.getDatasetMeta(e).data;f=[];for(let A=0;Aew(A,Hs(e,A),t.axis||"xy",n,t.includeInvisible||!1),nearest(A,e,t,n){const r=Hs(e,A),P=t.axis||"xy",z=t.includeInvisible||!1;return rw(A,r,P,t.intersect,n,z)},x:(A,e,t,n)=>Pw(A,Hs(e,A),"x",t.intersect,n),y:(A,e,t,n)=>Pw(A,Hs(e,A),"y",t.intersect,n)}};const fw=["left","top","right","bottom"];function vw(A,e){return A.filter((A=>A.pos===e))}function sw(A,e){return A.filter((A=>-1===fw.indexOf(A.pos)&&A.box.axis===e))}function aw(A,e){return A.sort(((A,t)=>{const n=e?t:A,r=e?A:t;return n.weight===r.weight?n.index-r.index:n.weight-r.weight}))}function ww(A){const e=[];let t,n,r,P,z,f;for(t=0,n=(A||[]).length;tA.box.fullSize)),!0),n=aw(vw(e,"left"),!0),r=aw(vw(e,"right")),P=aw(vw(e,"top"),!0),z=aw(vw(e,"bottom")),f=sw(e,"x"),v=sw(e,"y");return{fullSize:t,leftAndTop:n.concat(P),rightAndBottom:r.concat(v).concat(z).concat(f),chartArea:vw(e,"chartArea"),vertical:n.concat(r).concat(v),horizontal:P.concat(z).concat(f)}}function dw(A,e,t,n){return Math.max(A[t],e[t])+Math.max(A[n],e[n])}function Mw(A,e){A.top=Math.max(A.top,e.top),A.left=Math.max(A.left,e.left),A.bottom=Math.max(A.bottom,e.bottom),A.right=Math.max(A.right,e.right)}function gw(A,e,t,n){const{pos:r,box:P}=t,z=A.maxPadding;if(!Bz(r)){t.size&&(A[r]-=t.size);const e=n[t.stack]||{size:0,count:1};e.size=Math.max(e.size,t.horizontal?P.height:P.width),t.size=e.size/e.count,A[r]+=t.size}P.getPadding&&Mw(z,P.getPadding());const f=Math.max(0,e.outerWidth-dw(z,A,"left","right")),v=Math.max(0,e.outerHeight-dw(z,A,"top","bottom")),s=f!==A.w,a=v!==A.h;return A.w=f,A.h=v,t.horizontal?{same:s,other:a}:{same:a,other:s}}function uw(A){const e=A.maxPadding;function t(t){const n=Math.max(e[t]-A[t],0);return A[t]+=n,n}A.y+=t("top"),A.x+=t("left"),t("right"),t("bottom")}function jw(A,e){const t=e.maxPadding;function n(A){const n={left:0,top:0,right:0,bottom:0};return A.forEach((A=>{n[A]=Math.max(e[A],t[A])})),n}return n(A?["left","right"]:["top","bottom"])}function bw(A,e,t,n){const r=[];let P,z,f,v,s,a;for(P=0,z=A.length,s=0;P{"function"==typeof A.beforeLayout&&A.beforeLayout()}));const a=v.reduce(((A,e)=>e.box.options&&!1===e.box.options.display?A:A+1),0)||1,w=Object.freeze({outerWidth:e,outerHeight:t,padding:r,availableWidth:P,availableHeight:z,vBoxMaxWidth:P/2/a,hBoxMaxHeight:z/2}),D=Object.assign({},r);Mw(D,Yv(n));const c=Object.assign({maxPadding:D,w:P,h:z,x:r.left,y:r.top},r),l=cw(v.concat(s),w);bw(f.fullSize,c,w,l),bw(v,c,w,l),bw(s,c,w,l)&&bw(v,c,w,l),uw(c),Xw(f.leftAndTop,c,w,l),c.x+=c.w,c.y+=c.h,Xw(f.rightAndBottom,c,w,l),A.chartArea={left:c.left,top:c.top,right:c.left+c.w,bottom:c.top+c.h,height:c.h,width:c.w},Lz(f.chartArea,(e=>{const t=e.box;Object.assign(t,A.chartArea),t.update(c.w,c.h,{left:0,top:0,right:0,bottom:0})}))}};class Ww{acquireContext(A,e){}releaseContext(A){return!1}addEventListener(A,e,t){}removeEventListener(A,e,t){}getDevicePixelRatio(){return 1}getMaximumSize(A,e,t,n){return e=Math.max(0,e||A.width),t=t||A.height,{width:e,height:Math.max(0,n?Math.floor(e/n):t)}}isAttached(A){return!0}updateConfig(A){}}class Bw extends Ww{acquireContext(A){return A&&A.getContext&&A.getContext("2d")||null}updateConfig(A){A.options.animation=!1}}const Ow="$chartjs",pw={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup",pointerenter:"mouseenter",pointerdown:"mousedown",pointermove:"mousemove",pointerup:"mouseup",pointerleave:"mouseout",pointerout:"mouseout"},Zw=A=>null===A||""===A;function yw(A,e){const t=A.style,n=A.getAttribute("height"),r=A.getAttribute("width");if(A[Ow]={initial:{height:n,width:r,style:{display:t.display,height:t.height,width:t.width}}},t.display=t.display||"block",t.boxSizing=t.boxSizing||"border-box",Zw(r)){const e=ys(A,"width");void 0!==e&&(A.width=e)}if(Zw(n))if(""===A.style.height)A.height=A.width/(e||2);else{const e=ys(A,"height");void 0!==e&&(A.height=e)}return A}const Gw=!!Zs&&{passive:!0};function mw(A,e,t){A&&A.addEventListener(e,t,Gw)}function Lw(A,e,t){A&&A.canvas&&A.canvas.removeEventListener(e,t,Gw)}function Yw(A,e){const t=pw[A.type]||A.type,{x:n,y:r}=Hs(A,e);return{type:t,chart:e,native:A,x:void 0!==n?n:null,y:void 0!==r?r:null}}function ow(A,e){for(const t of A)if(t===e||t.contains(e))return!0}function Nw(A,e,t){const n=A.canvas,r=new MutationObserver((A=>{let e=!1;for(const t of A)e=e||ow(t.addedNodes,n),e=e&&!ow(t.removedNodes,n);e&&t()}));return r.observe(document,{childList:!0,subtree:!0}),r}function iw(A,e,t){const n=A.canvas,r=new MutationObserver((A=>{let e=!1;for(const t of A)e=e||ow(t.removedNodes,n),e=e&&!ow(t.addedNodes,n);e&&t()}));return r.observe(document,{childList:!0,subtree:!0}),r}const Qw=new Map;let Tw=0;function Cw(){const A=window.devicePixelRatio;A!==Tw&&(Tw=A,Qw.forEach(((e,t)=>{t.currentDevicePixelRatio!==A&&e()})))}function Vw(A,e){Qw.size||window.addEventListener("resize",Cw),Qw.set(A,e)}function hw(A){Qw.delete(A),Qw.size||window.removeEventListener("resize",Cw)}function qw(A,e,t){const n=A.canvas,r=n&&ds(n);if(!r)return;const P=mf(((A,e)=>{const n=r.clientWidth;t(A,e),n{const e=A[0],t=e.contentRect.width,n=e.contentRect.height;0===t&&0===n||P(t,n)}));return z.observe(r),Vw(A,P),z}function Iw(A,e,t){t&&t.disconnect(),"resize"===e&&hw(A)}function kw(A,e,t){const n=A.canvas,r=mf((e=>{null!==A.ctx&&t(Yw(e,A))}),A);return mw(n,e,r),r}class Kw extends Ww{acquireContext(A,e){const t=A&&A.getContext&&A.getContext("2d");return t&&t.canvas===A?(yw(A,e),t):null}releaseContext(A){const e=A.canvas;if(!e[Ow])return!1;const t=e[Ow].initial;["height","width"].forEach((A=>{const n=t[A];Hz(n)?e.removeAttribute(A):e.setAttribute(A,n)}));const n=t.style||{};return Object.keys(n).forEach((A=>{e.style[A]=n[A]})),e.width=e.width,delete e[Ow],!0}addEventListener(A,e,t){this.removeEventListener(A,e);const n=A.$proxies||(A.$proxies={}),r={attach:Nw,detach:iw,resize:qw}[e]||kw;n[e]=r(A,e,t)}removeEventListener(A,e){const t=A.$proxies||(A.$proxies={}),n=t[e];if(!n)return;({attach:Iw,detach:Iw,resize:Iw}[e]||Lw)(A,e,n),t[e]=void 0}getDevicePixelRatio(){return window.devicePixelRatio}getMaximumSize(A,e,t,n){return Os(A,e,t,n)}isAttached(A){const e=A&&ds(A);return!(!e||!e.isConnected)}}function Uw(A){return!ls()||"undefined"!=typeof OffscreenCanvas&&A instanceof OffscreenCanvas?Bw:Kw}class Sw{static defaults={};static defaultRoutes=void 0;x;y;active=!1;options;$animations;tooltipPosition(A){const{x:e,y:t}=this.getProps(["x","y"],A);return{x:e,y:t}}hasValue(){return vf(this.x)&&vf(this.y)}getProps(A,e){const t=this.$animations;if(!e||!t)return this;const n={};return A.forEach((A=>{n[A]=t[A]&&t[A].active()?t[A]._to:this[A]})),n}}function Ew(A,e){const t=A.options.ticks,n=Rw(A),r=Math.min(t.maxTicksLimit||n,n),P=t.major.enabled?Fw(e):[],z=P.length,f=P[0],v=P[z-1],s=[];if(z>r)return _w(e,s,P,z/r),s;const a=Jw(P,e,r);if(z>0){let A,t;const n=z>1?Math.round((v-f)/(z-1)):null;for($w(e,s,a,Hz(n)?0:f-n,f),A=0,t=z-1;Ar)return e}return Math.max(r,1)}function Fw(A){const e=[];let t,n;for(t=0,n=A.length;t"left"===A?"right":"right"===A?"left":A,tD=(A,e,t)=>"top"===e||"left"===e?A[e]+t:A[e]-t,nD=(A,e)=>Math.min(e||A,A);function rD(A,e){const t=[],n=A.length/e,r=A.length;let P=0;for(;Pz+f)))return s}function zD(A,e){Lz(A,(A=>{const t=A.gc,n=t.length/2;let r;if(n>e){for(r=0;rn?n:t,n=r&&t>n?t:n,{min:pz(t,pz(n,t)),max:pz(n,pz(t,n))}}getPadding(){return{left:this.paddingLeft||0,top:this.paddingTop||0,right:this.paddingRight||0,bottom:this.paddingBottom||0}}getTicks(){return this.ticks}getLabels(){const A=this.chart.data;return this.options.labels||(this.isHorizontal()?A.xLabels:A.yLabels)||A.labels||[]}getLabelItems(A=this.chart.chartArea){return this._labelItems||(this._labelItems=this._computeLabelItems(A))}beforeLayout(){this._cache={},this._dataLimitsCached=!1}beforeUpdate(){mz(this.options.beforeUpdate,[this])}update(A,e,t){const{beginAtZero:n,grace:r,ticks:P}=this.options,z=P.sampleSize;this.beforeUpdate(),this.maxWidth=A,this.maxHeight=e,this._margins=t=Object.assign({left:0,right:0,top:0,bottom:0},t),this.ticks=null,this._labelSizes=null,this._gridLineItems=null,this._labelItems=null,this.beforeSetDimensions(),this.setDimensions(),this.afterSetDimensions(),this._maxLength=this.isHorizontal()?this.width+t.left+t.right:this.height+t.top+t.bottom,this._dataLimitsCached||(this.beforeDataLimits(),this.determineDataLimits(),this.afterDataLimits(),this._range=iv(this,r,n),this._dataLimitsCached=!0),this.beforeBuildTicks(),this.ticks=this.buildTicks()||[],this.afterBuildTicks();const f=z=r||t<=1||!this.isHorizontal())return void(this.labelRotation=n);const s=this._getLabelSizes(),a=s.widest.width,w=s.highest.height,D=jf(this.chart.width-a,0,this.maxWidth);P=A.offset?this.maxWidth/t:D/(t-1),a+6>P&&(P=D/(t-(A.offset?.5:1)),z=this.maxHeight-fD(A.grid)-e.padding-vD(A.title,this.chart.options.font),f=Math.sqrt(a*a+w*w),v=Df(Math.min(Math.asin(jf((s.highest.height+6)/P,-1,1)),Math.asin(jf(z/f,-1,1))-Math.asin(jf(w/f,-1,1)))),v=Math.max(n,Math.min(r,v))),this.labelRotation=v}afterCalculateLabelRotation(){mz(this.options.afterCalculateLabelRotation,[this])}afterAutoSkip(){}beforeFit(){mz(this.options.beforeFit,[this])}fit(){const A={width:0,height:0},{chart:e,options:{ticks:t,title:n,grid:r}}=this,P=this._isVisible(),z=this.isHorizontal();if(P){const P=vD(n,e.options.font);if(z?(A.width=this.maxWidth,A.height=fD(r)+P):(A.height=this.maxHeight,A.width=fD(r)+P),t.display&&this.ticks.length){const{first:e,last:n,widest:r,highest:P}=this._getLabelSizes(),f=2*t.padding,v=wf(this.labelRotation),s=Math.cos(v),a=Math.sin(v);if(z){const e=t.mirror?0:a*r.width+s*P.height;A.height=Math.min(this.maxHeight,A.height+e+f)}else{const e=t.mirror?0:s*r.width+a*P.height;A.width=Math.min(this.maxWidth,A.width+e+f)}this._calculatePadding(e,n,a,s)}}this._handleMargins(),z?(this.width=this._length=e.width-this._margins.left-this._margins.right,this.height=A.height):(this.width=A.width,this.height=this._length=e.height-this._margins.top-this._margins.bottom)}_calculatePadding(A,e,t,n){const{ticks:{align:r,padding:P},position:z}=this.options,f=0!==this.labelRotation,v="top"!==z&&"x"===this.axis;if(this.isHorizontal()){const z=this.getPixelForTick(0)-this.left,s=this.right-this.getPixelForTick(this.ticks.length-1);let a=0,w=0;f?v?(a=n*A.width,w=t*e.height):(a=t*A.height,w=n*e.width):"start"===r?w=e.width:"end"===r?a=A.width:"inner"!==r&&(a=A.width/2,w=e.width/2),this.paddingLeft=Math.max((a-z+P)*this.width/(this.width-z),0),this.paddingRight=Math.max((w-s+P)*this.width/(this.width-s),0)}else{let t=e.height/2,n=A.height/2;"start"===r?(t=0,n=A.height):"end"===r&&(t=e.height,n=0),this.paddingTop=t+P,this.paddingBottom=n+P}}_handleMargins(){this._margins&&(this._margins.left=Math.max(this.paddingLeft,this._margins.left),this._margins.top=Math.max(this.paddingTop,this._margins.top),this._margins.right=Math.max(this.paddingRight,this._margins.right),this._margins.bottom=Math.max(this.paddingBottom,this._margins.bottom))}afterFit(){mz(this.options.afterFit,[this])}isHorizontal(){const{axis:A,position:e}=this.options;return"top"===e||"bottom"===e||"x"===A}isFullSize(){return this.options.fullSize}_convertTicksToLabels(A){let e,t;for(this.beforeTickToLabelConversion(),this.generateTickLabels(A),e=0,t=A.length;e({width:P[A]||0,height:z[A]||0});return{first:H(0),last:H(e-1),widest:H(x),highest:H(X),widths:P,heights:z}}getLabelForValue(A){return A}getPixelForValue(A,e){return NaN}getValueForPixel(A){}getPixelForTick(A){const e=this.ticks;return A<0||A>e.length-1?null:this.getPixelForValue(e[A].value)}getPixelForDecimal(A){this._reversePixels&&(A=1-A);const e=this._startPixel+A*this._length;return bf(this._alignToPixels?Dv(this.chart,e,0):e)}getDecimalForPixel(A){const e=(A-this._startPixel)/this._length;return this._reversePixels?1-e:e}getBasePixel(){return this.getPixelForValue(this.getBaseValue())}getBaseValue(){const{min:A,max:e}=this;return A<0&&e<0?e:A>0&&e>0?A:0}getContext(A){const e=this.ticks||[];if(A>=0&&Az*n?z/t:f/n:f*n0}_computeGridLineItems(A){const e=this.axis,t=this.chart,n=this.options,{grid:r,position:P,border:z}=n,f=r.offset,v=this.isHorizontal(),s=this.ticks.length+(f?1:0),a=fD(r),w=[],D=z.setContext(this.getContext()),c=D.display?D.width:0,l=c/2,d=function(A){return Dv(t,A,c)};let M,g,u,j,b,x,X,H,W,B,O,p;if("top"===P)M=d(this.bottom),x=this.bottom-a,H=M-l,B=d(A.top)+l,p=A.bottom;else if("bottom"===P)M=d(this.top),B=A.top,p=d(A.bottom)-l,x=M+l,H=this.top+a;else if("left"===P)M=d(this.right),b=this.right-a,X=M-l,W=d(A.left)+l,O=A.right;else if("right"===P)M=d(this.left),W=A.left,O=d(A.right)-l,b=M+l,X=this.left+a;else if("x"===e){if("center"===P)M=d((A.top+A.bottom)/2+.5);else if(Bz(P)){const A=Object.keys(P)[0],e=P[A];M=d(this.chart.scales[A].getPixelForValue(e))}B=A.top,p=A.bottom,x=M+l,H=x+a}else if("y"===e){if("center"===P)M=d((A.left+A.right)/2);else if(Bz(P)){const A=Object.keys(P)[0],e=P[A];M=d(this.chart.scales[A].getPixelForValue(e))}b=M-l,X=b-a,W=A.left,O=A.right}const Z=Zz(n.ticks.maxTicksLimit,s),y=Math.max(1,Math.ceil(s/Z));for(g=0;g0&&(P-=n/2)}w={left:P,top:r,width:n+e.width,height:t+e.height,color:A.backdropColor}}d.push({label:j,font:W,textOffset:p,options:{rotation:l,color:t,strokeColor:f,strokeWidth:s,textAlign:D,textBaseline:Z,translation:[b,x],backdrop:w}})}return d}_getXAxisLabelAlignment(){const{position:A,ticks:e}=this.options;if(-wf(this.labelRotation))return"top"===A?"left":"right";let t="center";return"start"===e.align?t="left":"end"===e.align?t="right":"inner"===e.align&&(t="inner"),t}_getYAxisLabelAlignment(A){const{position:e,ticks:{crossAlign:t,mirror:n,padding:r}}=this.options,P=A+r,z=this._getLabelSizes().widest.width;let f,v;return"left"===e?n?(v=this.right+r,"near"===t?f="left":"center"===t?(f="center",v+=z/2):(f="right",v+=z)):(v=this.right-P,"near"===t?f="right":"center"===t?(f="center",v-=z/2):(f="left",v=this.left)):"right"===e?n?(v=this.left+r,"near"===t?f="right":"center"===t?(f="center",v-=z/2):(f="left",v-=z)):(v=this.left+P,"near"===t?f="left":"center"===t?(f="center",v+=z/2):(f="right",v=this.right)):f="right",{textAlign:f,x:v}}_computeLabelArea(){if(this.options.ticks.mirror)return;const A=this.chart,e=this.options.position;return"left"===e||"right"===e?{top:0,left:this.left,bottom:A.height,right:this.right}:"top"===e||"bottom"===e?{top:this.top,left:0,bottom:this.bottom,right:A.width}:void 0}drawBackground(){const{ctx:A,options:{backgroundColor:e},left:t,top:n,width:r,height:P}=this;e&&(A.save(),A.fillStyle=e,A.fillRect(t,n,r,P),A.restore())}getLineWidthForValue(A){const e=this.options.grid;if(!this._isVisible()||!e.display)return 0;const t=this.ticks.findIndex((e=>e.value===A));if(t>=0){return e.setContext(this.getContext(t)).lineWidth}return 0}drawGrid(A){const e=this.options.grid,t=this.ctx,n=this._gridLineItems||(this._gridLineItems=this._computeGridLineItems(A));let r,P;const z=(A,e,n)=>{n.width&&n.color&&(t.save(),t.lineWidth=n.width,t.strokeStyle=n.color,t.setLineDash(n.borderDash||[]),t.lineDashOffset=n.borderDashOffset,t.beginPath(),t.moveTo(A.x,A.y),t.lineTo(e.x,e.y),t.stroke(),t.restore())};if(e.display)for(r=0,P=n.length;r{this.drawBackground(),this.drawGrid(A),this.drawTitle()}},{z:n,draw:()=>{this.drawBorder()}},{z:e,draw:A=>{this.drawLabels(A)}}]:[{z:e,draw:A=>{this.draw(A)}}]}getMatchingVisibleMetas(A){const e=this.chart.getSortedVisibleDatasetMetas(),t=this.axis+"AxisID",n=[];let r,P;for(r=0,P=e.length;r{const n=t.split("."),r=n.pop(),P=[A].concat(n).join("."),z=e[t].split("."),f=z.pop(),v=z.join(".");vv.route(P,r,v,f)}))}function gD(A){return"id"in A&&"defaults"in A}class uD{constructor(){this.controllers=new lD(Ha,"datasets",!0),this.elements=new lD(Sw,"elements"),this.plugins=new lD(Object,"plugins"),this.scales=new lD(cD,"scales"),this._typedRegistries=[this.controllers,this.scales,this.elements]}add(...A){this._each("register",A)}remove(...A){this._each("unregister",A)}addControllers(...A){this._each("register",A,this.controllers)}addElements(...A){this._each("register",A,this.elements)}addPlugins(...A){this._each("register",A,this.plugins)}addScales(...A){this._each("register",A,this.scales)}getController(A){return this._get(A,this.controllers,"controller")}getElement(A){return this._get(A,this.elements,"element")}getPlugin(A){return this._get(A,this.plugins,"plugin")}getScale(A){return this._get(A,this.scales,"scale")}removeControllers(...A){this._each("unregister",A,this.controllers)}removeElements(...A){this._each("unregister",A,this.elements)}removePlugins(...A){this._each("unregister",A,this.plugins)}removeScales(...A){this._each("unregister",A,this.scales)}_each(A,e,t){[...e].forEach((e=>{const n=t||this._getRegistryForType(e);t||n.isForType(e)||n===this.plugins&&e.id?this._exec(A,n,e):Lz(e,(e=>{const n=t||this._getRegistryForType(e);this._exec(A,n,e)}))}))}_exec(A,e,t){const n=kz(A);mz(t["before"+n],[],t),e[A](t),mz(t["after"+n],[],t)}_getRegistryForType(A){for(let e=0;eA.filter((A=>!e.some((e=>A.plugin.id===e.plugin.id))));this._notify(n(e,t),A,"stop"),this._notify(n(t,e),A,"start")}}function xD(A){const e={},t=[],n=Object.keys(jD.plugins.items);for(let A=0;A1&&ZD(A[0].toLowerCase());if(e)return e}throw new Error(`Cannot determine type of '${A}' axis. Please provide 'axis' or 'position' option.`)}function mD(A,e,t){if(t[e+"AxisID"]===A)return{axis:e}}function LD(A,e){if(e.data&&e.data.datasets){const t=e.data.datasets.filter((e=>e.xAxisID===A||e.yAxisID===A));if(t.length)return mD(A,"x",t[0])||mD(A,"y",t[0])}return{}}function YD(A,e){const t=nv[A.type]||{scales:{}},n=e.scales||{},r=BD(A.type,e),P=Object.create(null);return Object.keys(n).forEach((e=>{const z=n[e];if(!Bz(z))return;if(z._proxy)return console.warn(`Ignoring resolver passed as options for scale: ${e}`);const f=GD(e,z,LD(e,A),vv.scales[z.type]),v=pD(f,r),s=t.scales||{};P[e]=Tz(Object.create(null),[{axis:f},z,s[f],s[v]])})),A.data.datasets.forEach((t=>{const r=t.type||A.type,z=t.indexAxis||BD(r,e),f=(nv[r]||{}).scales||{};Object.keys(f).forEach((A=>{const e=OD(A,z),r=t[e+"AxisID"]||e;P[r]=P[r]||Object.create(null),Tz(P[r],[{axis:e},n[r],f[A]])}))})),Object.keys(P).forEach((A=>{const e=P[A];Tz(e,[vv.scales[e.type],vv.scale])})),P}function oD(A){const e=A.options||(A.options={});e.plugins=Zz(e.plugins,{}),e.scales=YD(A,e)}function ND(A){return(A=A||{}).datasets=A.datasets||[],A.labels=A.labels||[],A}function iD(A){return(A=A||{}).data=ND(A.data),oD(A),A}const QD=new Map,TD=new Set;function CD(A,e){let t=QD.get(A);return t||(t=e(),QD.set(A,t),TD.add(t)),t}const VD=(A,e,t)=>{const n=Iz(e,t);void 0!==n&&A.add(n)};class hD{constructor(A){this._config=iD(A),this._scopeCache=new Map,this._resolverCache=new Map}get platform(){return this._config.platform}get type(){return this._config.type}set type(A){this._config.type=A}get data(){return this._config.data}set data(A){this._config.data=ND(A)}get options(){return this._config.options}set options(A){this._config.options=A}get plugins(){return this._config.plugins}update(){const A=this._config;this.clearCache(),oD(A)}clearCache(){this._scopeCache.clear(),this._resolverCache.clear()}datasetScopeKeys(A){return CD(A,(()=>[[`datasets.${A}`,""]]))}datasetAnimationScopeKeys(A,e){return CD(`${A}.transition.${e}`,(()=>[[`datasets.${A}.transitions.${e}`,`transitions.${e}`],[`datasets.${A}`,""]]))}datasetElementScopeKeys(A,e){return CD(`${A}-${e}`,(()=>[[`datasets.${A}.elements.${e}`,`datasets.${A}`,`elements.${e}`,""]]))}pluginScopeKeys(A){const e=A.id;return CD(`${this.type}-plugin-${e}`,(()=>[[`plugins.${e}`,...A.additionalOptionScopes||[]]]))}_cachedScopes(A,e){const t=this._scopeCache;let n=t.get(A);return n&&!e||(n=new Map,t.set(A,n)),n}getOptionScopes(A,e,t){const{options:n,type:r}=this,P=this._cachedScopes(A,t),z=P.get(e);if(z)return z;const f=new Set;e.forEach((e=>{A&&(f.add(A),e.forEach((e=>VD(f,A,e)))),e.forEach((A=>VD(f,n,A))),e.forEach((A=>VD(f,nv[r]||{},A))),e.forEach((A=>VD(f,vv,A))),e.forEach((A=>VD(f,rv,A)))}));const v=Array.from(f);return 0===v.length&&v.push(Object.create(null)),TD.has(e)&&P.set(e,v),v}chartOptionScopes(){const{options:A,type:e}=this;return[A,nv[e]||{},vv.datasets[e]||{},{type:e},vv,rv]}resolveNamedOptions(A,e,t,n=[""]){const r={$shared:!0},{resolver:P,subPrefixes:z}=qD(this._resolverCache,A,n);let f=P;if(kD(P,e)){r.$shared=!1;f=Cv(P,t=Uz(t)?t():t,this.createResolver(A,t,z))}for(const A of e)r[A]=f[A];return r}createResolver(A,e,t=[""],n){const{resolver:r}=qD(this._resolverCache,A,t);return Bz(e)?Cv(r,e,void 0,n):r}}function qD(A,e,t){let n=A.get(e);n||(n=new Map,A.set(e,n));const r=t.join();let P=n.get(r);if(!P){P={resolver:Tv(e,t),subPrefixes:t.filter((A=>!A.toLowerCase().includes("hover")))},n.set(r,P)}return P}const ID=A=>Bz(A)&&Object.getOwnPropertyNames(A).some((e=>Uz(A[e])));function kD(A,e){const{isScriptable:t,isIndexable:n}=Vv(A);for(const r of e){const e=t(r),P=n(r),z=(P||e)&&A[r];if(e&&(Uz(z)||ID(z))||P&&Wz(z))return!0}return!1}var KD="4.4.5";const UD=["top","bottom","left","right","chartArea"];function SD(A,e){return"top"===A||"bottom"===A||-1===UD.indexOf(A)&&"x"===e}function ED(A,e){return function(t,n){return t[A]===n[A]?t[e]-n[e]:t[A]-n[A]}}function RD(A){const e=A.chart,t=e.options.animation;e.notifyPlugins("afterRender"),mz(t&&t.onComplete,[A],e)}function JD(A){const e=A.chart,t=e.options.animation;mz(t&&t.onProgress,[A],e)}function FD(A){return ls()&&"string"==typeof A?A=document.getElementById(A):A&&A.length&&(A=A[0]),A&&A.canvas&&(A=A.canvas),A}const _D={},$D=A=>{const e=FD(A);return Object.values(_D).filter((A=>A.canvas===e)).pop()};function Ac(A,e,t){const n=Object.keys(A);for(const r of n){const n=+r;if(n>=e){const P=A[r];delete A[r],(t>0||n>e)&&(A[n+t]=P)}}}function ec(A,e,t,n){return t&&"mouseout"!==A.type?n?e:A:null}function tc(A,e,t){return A.options.clip?A[t]:e[t]}function nc(A,e){const{xScale:t,yScale:n}=A;return t&&n?{left:tc(t,e,"left"),right:tc(t,e,"right"),top:tc(n,e,"top"),bottom:tc(n,e,"bottom")}:e}class rc{static defaults=vv;static instances=_D;static overrides=nv;static registry=jD;static version=KD;static getChart=$D;static register(...A){jD.add(...A),Pc()}static unregister(...A){jD.remove(...A),Pc()}constructor(A,e){const t=this.config=new hD(e),n=FD(A),r=$D(n);if(r)throw new Error("Canvas is already in use. Chart with ID '"+r.id+"' must be destroyed before the canvas with ID '"+r.canvas.id+"' can be reused.");const P=t.createResolver(t.chartOptionScopes(),this.getContext());this.platform=new(t.platform||Uw(n)),this.platform.updateConfig(t);const z=this.platform.acquireContext(n,P.aspectRatio),f=z&&z.canvas,v=f&&f.height,s=f&&f.width;this.id=Xz(),this.ctx=z,this.canvas=f,this.width=s,this.height=v,this._options=P,this._aspectRatio=this.aspectRatio,this._layers=[],this._metasets=[],this._stacks=void 0,this.boxes=[],this.currentDevicePixelRatio=void 0,this.chartArea=void 0,this._active=[],this._lastEvent=void 0,this._listeners={},this._responsiveListeners=void 0,this._sortedMetasets=[],this.scales={},this._plugins=new bD,this.$proxies={},this._hiddenIndices={},this.attached=!1,this._animationsDisabled=void 0,this.$context=void 0,this._doResize=Lf((A=>this.update(A)),P.resizeDelay||0),this._dataChanges=[],_D[this.id]=this,z&&f&&(Fs.listen(this,"complete",RD),Fs.listen(this,"progress",JD),this._initialize(),this.attached&&this.update())}get aspectRatio(){const{options:{aspectRatio:A,maintainAspectRatio:e},width:t,height:n,_aspectRatio:r}=this;return Hz(A)?e&&r?r:n?t/n:null:A}get data(){return this.config.data}set data(A){this.config.data=A}get options(){return this._options}set options(A){this.config.options=A}get registry(){return jD}_initialize(){return this.notifyPlugins("beforeInit"),this.options.responsive?this.resize():ps(this,this.options.devicePixelRatio),this.bindEvents(),this.notifyPlugins("afterInit"),this}clear(){return cv(this.canvas,this.ctx),this}stop(){return Fs.stop(this),this}resize(A,e){Fs.running(this)?this._resizeBeforeDraw={width:A,height:e}:this._resize(A,e)}_resize(A,e){const t=this.options,n=this.canvas,r=t.maintainAspectRatio&&this.aspectRatio,P=this.platform.getMaximumSize(n,A,e,r),z=t.devicePixelRatio||this.platform.getDevicePixelRatio(),f=this.width?"resize":"attach";this.width=P.width,this.height=P.height,this._aspectRatio=this.aspectRatio,ps(this,z,!0)&&(this.notifyPlugins("resize",{size:P}),mz(t.onResize,[this,P],this),this.attached&&this._doResize(f)&&this.render())}ensureScalesHaveIDs(){Lz(this.options.scales||{},((A,e)=>{A.id=e}))}buildOrUpdateScales(){const A=this.options,e=A.scales,t=this.scales,n=Object.keys(t).reduce(((A,e)=>(A[e]=!1,A)),{});let r=[];e&&(r=r.concat(Object.keys(e).map((A=>{const t=e[A],n=GD(A,t),r="r"===n,P="x"===n;return{options:t,dposition:r?"chartArea":P?"bottom":"left",dtype:r?"radialLinear":P?"category":"linear"}})))),Lz(r,(e=>{const r=e.options,P=r.id,z=GD(P,r),f=Zz(r.type,e.dtype);void 0!==r.position&&SD(r.position,z)===SD(e.dposition)||(r.position=e.dposition),n[P]=!0;let v=null;if(P in t&&t[P].type===f)v=t[P];else{v=new(jD.getScale(f))({id:P,type:f,ctx:this.ctx,chart:this}),t[v.id]=v}v.init(r,A)})),Lz(n,((A,e)=>{A||delete t[e]})),Lz(t,(A=>{Hw.configure(this,A,A.options),Hw.addBox(this,A)}))}_updateMetasets(){const A=this._metasets,e=this.data.datasets.length,t=A.length;if(A.sort(((A,e)=>A.index-e.index)),t>e){for(let A=e;Ae.length&&delete this._stacks,A.forEach(((A,t)=>{0===e.filter((e=>e===A._dataset)).length&&this._destroyDatasetMeta(t)}))}buildOrUpdateControllers(){const A=[],e=this.data.datasets;let t,n;for(this._removeUnreferencedMetasets(),t=0,n=e.length;t{this.getDatasetMeta(e).controller.reset()}),this)}reset(){this._resetElements(),this.notifyPlugins("reset")}update(A){const e=this.config;e.update();const t=this._options=e.createResolver(e.chartOptionScopes(),this.getContext()),n=this._animationsDisabled=!t.animation;if(this._updateScales(),this._checkEventBindings(),this._updateHiddenIndices(),this._plugins.invalidate(),!1===this.notifyPlugins("beforeUpdate",{mode:A,cancelable:!0}))return;const r=this.buildOrUpdateControllers();this.notifyPlugins("beforeElementsUpdate");let P=0;for(let A=0,e=this.data.datasets.length;A{A.reset()})),this._updateDatasets(A),this.notifyPlugins("afterUpdate",{mode:A}),this._layers.sort(ED("z","_idx"));const{_active:z,_lastEvent:f}=this;f?this._eventHandler(f,!0):z.length&&this._updateHoverStyles(z,z,!0),this.render()}_updateScales(){Lz(this.scales,(A=>{Hw.removeBox(this,A)})),this.ensureScalesHaveIDs(),this.buildOrUpdateScales()}_checkEventBindings(){const A=this.options,e=new Set(Object.keys(this._listeners)),t=new Set(A.events);Sz(e,t)&&!!this._responsiveListeners===A.responsive||(this.unbindEvents(),this.bindEvents())}_updateHiddenIndices(){const{_hiddenIndices:A}=this,e=this._getUniformDataChanges()||[];for(const{method:t,start:n,count:r}of e){Ac(A,n,"_removeElements"===t?-r:r)}}_getUniformDataChanges(){const A=this._dataChanges;if(!A||!A.length)return;this._dataChanges=[];const e=this.data.datasets.length,t=e=>new Set(A.filter((A=>A[0]===e)).map(((A,e)=>e+","+A.splice(1).join(",")))),n=t(0);for(let A=1;AA.split(","))).map((A=>({method:A[1],start:+A[2],count:+A[3]})))}_updateLayout(A){if(!1===this.notifyPlugins("beforeLayout",{cancelable:!0}))return;Hw.update(this,this.width,this.height,A);const e=this.chartArea,t=e.width<=0||e.height<=0;this._layers=[],Lz(this.boxes,(A=>{t&&"chartArea"===A.position||(A.configure&&A.configure(),this._layers.push(...A._layers()))}),this),this._layers.forEach(((A,e)=>{A._idx=e})),this.notifyPlugins("afterLayout")}_updateDatasets(A){if(!1!==this.notifyPlugins("beforeDatasetsUpdate",{mode:A,cancelable:!0})){for(let A=0,e=this.data.datasets.length;A=0;--e)this._drawDataset(A[e]);this.notifyPlugins("afterDatasetsDraw")}_drawDataset(A){const e=this.ctx,t=A._clip,n=!t.disabled,r=nc(A,this.chartArea),P={meta:A,index:A.index,cancelable:!0};!1!==this.notifyPlugins("beforeDatasetDraw",P)&&(n&&gv(e,{left:!1===t.left?0:r.left-t.left,right:!1===t.right?this.width:r.right+t.right,top:!1===t.top?0:r.top-t.top,bottom:!1===t.bottom?this.height:r.bottom+t.bottom}),A.controller.draw(),n&&uv(e),P.cancelable=!1,this.notifyPlugins("afterDatasetDraw",P))}isPointInArea(A){return Mv(A,this.chartArea,this._minPadding)}getElementsAtEventForMode(A,e,t,n){const r=zw.modes[e];return"function"==typeof r?r(this,A,t,n):[]}getDatasetMeta(A){const e=this.data.datasets[A],t=this._metasets;let n=t.filter((A=>A&&A._dataset===e)).pop();return n||(n={type:null,data:[],dataset:null,controller:null,hidden:null,xAxisID:null,yAxisID:null,order:e&&e.order||0,index:A,_dataset:e,_parsed:[],_sorted:!1},t.push(n)),n}getContext(){return this.$context||(this.$context=Qv(null,{chart:this,type:"chart"}))}getVisibleDatasetCount(){return this.getSortedVisibleDatasetMetas().length}isDatasetVisible(A){const e=this.data.datasets[A];if(!e)return!1;const t=this.getDatasetMeta(A);return"boolean"==typeof t.hidden?!t.hidden:!e.hidden}setDatasetVisibility(A,e){this.getDatasetMeta(A).hidden=!e}toggleDataVisibility(A){this._hiddenIndices[A]=!this._hiddenIndices[A]}getDataVisibility(A){return!this._hiddenIndices[A]}_updateVisibility(A,e,t){const n=t?"show":"hide",r=this.getDatasetMeta(A),P=r.controller._resolveAnimations(void 0,n);Kz(e)?(r.data[e].hidden=!t,this.update()):(this.setDatasetVisibility(A,t),P.update(r,{visible:t}),this.update((e=>e.datasetIndex===A?n:void 0)))}hide(A,e){this._updateVisibility(A,e,!1)}show(A,e){this._updateVisibility(A,e,!0)}_destroyDatasetMeta(A){const e=this._metasets[A];e&&e.controller&&e.controller._destroy(),delete this._metasets[A]}_stop(){let A,e;for(this.stop(),Fs.remove(this),A=0,e=this.data.datasets.length;A{e.addEventListener(this,t,n),A[t]=n},n=(A,e,t)=>{A.offsetX=e,A.offsetY=t,this._eventHandler(A)};Lz(this.options.events,(A=>t(A,n)))}bindResponsiveEvents(){this._responsiveListeners||(this._responsiveListeners={});const A=this._responsiveListeners,e=this.platform,t=(t,n)=>{e.addEventListener(this,t,n),A[t]=n},n=(t,n)=>{A[t]&&(e.removeEventListener(this,t,n),delete A[t])},r=(A,e)=>{this.canvas&&this.resize(A,e)};let P;const z=()=>{n("attach",z),this.attached=!0,this.resize(),t("resize",r),t("detach",P)};P=()=>{this.attached=!1,n("resize",r),this._stop(),this._resize(0,0),t("attach",z)},e.isAttached(this.canvas)?z():P()}unbindEvents(){Lz(this._listeners,((A,e)=>{this.platform.removeEventListener(this,e,A)})),this._listeners={},Lz(this._responsiveListeners,((A,e)=>{this.platform.removeEventListener(this,e,A)})),this._responsiveListeners=void 0}updateHoverStyle(A,e,t){const n=t?"set":"remove";let r,P,z,f;for("dataset"===e&&(r=this.getDatasetMeta(A[0].datasetIndex),r.controller["_"+n+"DatasetHoverStyle"]()),z=0,f=A.length;z{const t=this.getDatasetMeta(A);if(!t)throw new Error("No dataset found at index "+A);return{datasetIndex:A,element:t.data[e],index:e}}));!Yz(t,e)&&(this._active=t,this._lastEvent=null,this._updateHoverStyles(t,e))}notifyPlugins(A,e,t){return this._plugins.notify(this,A,e,t)}isPluginEnabled(A){return 1===this._plugins._cache.filter((e=>e.plugin.id===A)).length}_updateHoverStyles(A,e,t){const n=this.options.hover,r=(A,e)=>A.filter((A=>!e.some((e=>A.datasetIndex===e.datasetIndex&&A.index===e.index)))),P=r(e,A),z=t?A:r(A,e);P.length&&this.updateHoverStyle(P,n.mode,!1),z.length&&n.mode&&this.updateHoverStyle(z,n.mode,!0)}_eventHandler(A,e){const t={event:A,replay:e,cancelable:!0,inChartArea:this.isPointInArea(A)},n=e=>(e.options.events||this.options.events).includes(A.native.type);if(!1===this.notifyPlugins("beforeEvent",t,n))return;const r=this._handleEvent(A,e,t.inChartArea);return t.cancelable=!1,this.notifyPlugins("afterEvent",t,n),(r||t.changed)&&this.render(),this}_handleEvent(A,e,t){const{_active:n=[],options:r}=this,P=e,z=this._getActiveElements(A,n,t,P),f=Ez(A),v=ec(A,this._lastEvent,t,f);t&&(this._lastEvent=null,mz(r.onHover,[A,z,this],this),f&&mz(r.onClick,[A,z,this],this));const s=!Yz(z,n);return(s||e)&&(this._active=z,this._updateHoverStyles(z,n,e)),this._lastEvent=v,s}_getActiveElements(A,e,t,n){if("mouseout"===A.type)return[];if(!t)return e;const r=this.options.hover;return this.getElementsAtEventForMode(A,r.mode,r,n)}}function Pc(){return Lz(rc.instances,(A=>A._plugins.invalidate()))}function zc(A,e,t){const{startAngle:n,pixelMargin:r,x:P,y:z,outerRadius:f,innerRadius:v}=e;let s=r/f;A.beginPath(),A.arc(P,z,f,n-s,t+s),v>r?(s=r/v,A.arc(P,z,v,t+s,n-s,!0)):A.arc(P,z,r,t+Af,n-Af),A.closePath(),A.clip()}function fc(A){return Gv(A,["outerStart","outerEnd","innerStart","innerEnd"])}function vc(A,e,t,n){const r=fc(A.options.borderRadius),P=(t-e)/2,z=Math.min(P,n*e/2),f=A=>{const e=(t-Math.min(P,A))*n/2;return jf(A,0,Math.min(P,e))};return{outerStart:f(r.outerStart),outerEnd:f(r.outerEnd),innerStart:jf(r.innerStart,0,z),innerEnd:jf(r.innerEnd,0,z)}}function sc(A,e,t,n){return{x:t+A*Math.cos(e),y:n+A*Math.sin(e)}}function ac(A,e,t,n,r,P){const{x:z,y:f,startAngle:v,pixelMargin:s,innerRadius:a}=e,w=Math.max(e.outerRadius+n+t-s,0),D=a>0?a+n+t+s:0;let c=0;const l=r-v;if(n){const A=((a>0?a-n:0)+(w>0?w-n:0))/2;c=(l-(0!==A?l*A/(A+n):l))/2}const d=(l-Math.max(.001,l*w-t/Rz)/w)/2,M=v+d+c,g=r-d-c,{outerStart:u,outerEnd:j,innerStart:b,innerEnd:x}=vc(e,D,w,g-M),X=w-u,H=w-j,W=M+u/X,B=g-j/H,O=D+b,p=D+x,Z=M+b/O,y=g-x/p;if(A.beginPath(),P){const e=(W+B)/2;if(A.arc(z,f,w,W,e),A.arc(z,f,w,e,B),j>0){const e=sc(H,B,z,f);A.arc(e.x,e.y,j,B,g+Af)}const t=sc(p,g,z,f);if(A.lineTo(t.x,t.y),x>0){const e=sc(p,y,z,f);A.arc(e.x,e.y,x,g+Af,y+Math.PI)}const n=(g-x/D+(M+b/D))/2;if(A.arc(z,f,D,g-x/D,n,!0),A.arc(z,f,D,n,M+b/D,!0),b>0){const e=sc(O,Z,z,f);A.arc(e.x,e.y,b,Z+Math.PI,M-Af)}const r=sc(X,M,z,f);if(A.lineTo(r.x,r.y),u>0){const e=sc(X,W,z,f);A.arc(e.x,e.y,u,M-Af,W)}}else{A.moveTo(z,f);const e=Math.cos(W)*w+z,t=Math.sin(W)*w+f;A.lineTo(e,t);const n=Math.cos(B)*w+z,r=Math.sin(B)*w+f;A.lineTo(n,r)}A.closePath()}function wc(A,e,t,n,r){const{fullCircles:P,startAngle:z,circumference:f}=e;let v=e.endAngle;if(P){ac(A,e,t,n,v,r);for(let e=0;e"borderDash"!==A};circumference;endAngle;fullCircles;innerRadius;outerRadius;pixelMargin;startAngle;constructor(A){super(),this.options=void 0,this.circumference=void 0,this.startAngle=void 0,this.endAngle=void 0,this.innerRadius=void 0,this.outerRadius=void 0,this.pixelMargin=0,this.fullCircles=0,A&&Object.assign(this,A)}inRange(A,e,t){const n=this.getProps(["x","y"],t),{angle:r,distance:P}=lf(n,{x:A,y:e}),{startAngle:z,endAngle:f,innerRadius:v,outerRadius:s,circumference:a}=this.getProps(["startAngle","endAngle","innerRadius","outerRadius","circumference"],t),w=(this.options.spacing+this.options.borderWidth)/2,D=Zz(a,f-z),c=uf(r,z,f)&&z!==f,l=D>=Jz||c,d=xf(P,v+w,s+w);return l&&d}getCenterPoint(A){const{x:e,y:t,startAngle:n,endAngle:r,innerRadius:P,outerRadius:z}=this.getProps(["x","y","startAngle","endAngle","innerRadius","outerRadius"],A),{offset:f,spacing:v}=this.options,s=(n+r)/2,a=(P+z+v+f)/2;return{x:e+Math.cos(s)*a,y:t+Math.sin(s)*a}}tooltipPosition(A){return this.getCenterPoint(A)}draw(A){const{options:e,circumference:t}=this,n=(e.offset||0)/4,r=(e.spacing||0)/2,P=e.circular;if(this.pixelMargin="inner"===e.borderAlign?.33:0,this.fullCircles=t>Jz?Math.floor(t/Jz):0,0===t||this.innerRadius<0||this.outerRadius<0)return;A.save();const z=(this.startAngle+this.endAngle)/2;A.translate(Math.cos(z)*n,Math.sin(z)*n);const f=n*(1-Math.sin(Math.min(Rz,t||0)));A.fillStyle=e.backgroundColor,A.strokeStyle=e.borderColor,wc(A,this,f,r,P),Dc(A,this,f,r,P),A.restore()}}function lc(A,e,t=e){A.lineCap=Zz(t.borderCapStyle,e.borderCapStyle),A.setLineDash(Zz(t.borderDash,e.borderDash)),A.lineDashOffset=Zz(t.borderDashOffset,e.borderDashOffset),A.lineJoin=Zz(t.borderJoinStyle,e.borderJoinStyle),A.lineWidth=Zz(t.borderWidth,e.borderWidth),A.strokeStyle=Zz(t.borderColor,e.borderColor)}function dc(A,e,t){A.lineTo(t.x,t.y)}function Mc(A){return A.stepped?jv:A.tension||"monotone"===A.cubicInterpolationMode?bv:dc}function gc(A,e,t={}){const n=A.length,{start:r=0,end:P=n-1}=t,{start:z,end:f}=e,v=Math.max(r,z),s=Math.min(P,f),a=rf&&P>f;return{count:n,start:v,loop:e.loop,ilen:s(z+(s?f-A:A))%P,j=()=>{c!==l&&(A.lineTo(M,l),A.lineTo(M,c),A.lineTo(M,d))};for(v&&(w=r[u(0)],A.moveTo(w.x,w.y)),a=0;a<=f;++a){if(w=r[u(a)],w.skip)continue;const e=w.x,t=w.y,n=0|e;n===D?(tl&&(l=t),M=(g*M+e)/++g):(j(),A.lineTo(e,t),D=n,g=0,c=l=t),d=t}j()}function bc(A){const e=A.options,t=e.borderDash&&e.borderDash.length;return!(A._decimated||A._loop||e.tension||"monotone"===e.cubicInterpolationMode||e.stepped||t)?jc:uc}function xc(A){return A.stepped?ms:A.tension||"monotone"===A.cubicInterpolationMode?Ls:Gs}function Xc(A,e,t,n){let r=e._path;r||(r=e._path=new Path2D,e.path(r,t,n)&&r.closePath()),lc(A,e.options),A.stroke(r)}function Hc(A,e,t,n){const{segments:r,options:P}=e,z=bc(e);for(const f of r)lc(A,P,f.style),A.beginPath(),z(A,e,f,{start:t,end:t+n-1})&&A.closePath(),A.stroke()}const Wc="function"==typeof Path2D;function Bc(A,e,t,n){Wc&&!e.options.segment?Xc(A,e,t,n):Hc(A,e,t,n)}class Oc extends Sw{static id="line";static defaults={borderCapStyle:"butt",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderWidth:3,capBezierPoints:!0,cubicInterpolationMode:"default",fill:!1,spanGaps:!1,stepped:!1,tension:0};static defaultRoutes={backgroundColor:"backgroundColor",borderColor:"borderColor"};static descriptors={_scriptable:!0,_indexable:A=>"borderDash"!==A&&"fill"!==A};constructor(A){super(),this.animated=!0,this.options=void 0,this._chart=void 0,this._loop=void 0,this._fullLoop=void 0,this._path=void 0,this._points=void 0,this._segments=void 0,this._decimated=!1,this._pointsUpdated=!1,this._datasetIndex=void 0,A&&Object.assign(this,A)}updateControlPoints(A,e){const t=this.options;if((t.tension||"monotone"===t.cubicInterpolationMode)&&!t.stepped&&!this._pointsUpdated){const n=t.spanGaps?this._loop:this._fullLoop;cs(this._points,t,A,n,e),this._pointsUpdated=!0}}set points(A){this._points=A,delete this._segments,delete this._path,this._pointsUpdated=!1}get points(){return this._points}get segments(){return this._segments||(this._segments=Ks(this,this.options.segment))}first(){const A=this.segments,e=this.points;return A.length&&e[A[0].start]}last(){const A=this.segments,e=this.points,t=A.length;return t&&e[A[t-1].end]}interpolate(A,e){const t=this.options,n=A[e],r=this.points,P=qs(this,{property:e,start:n,end:n});if(!P.length)return;const z=[],f=xc(t);let v,s;for(v=0,s=P.length;vA.replace("rgb(","rgba(").replace(")",", 0.5)")));function qc(A){return Vc[A%Vc.length]}function Ic(A){return hc[A%hc.length]}function kc(A,e){return A.borderColor=qc(e),A.backgroundColor=Ic(e),++e}function Kc(A,e){return A.backgroundColor=A.data.map((()=>qc(e++))),e}function Uc(A,e){return A.backgroundColor=A.data.map((()=>Ic(e++))),e}function Sc(A){let e=0;return(t,n)=>{const r=A.getDatasetMeta(n).controller;r instanceof qa?e=Kc(t,e):r instanceof ka?e=Uc(t,e):r&&(e=kc(t,e))}}function Ec(A){let e;for(e in A)if(A[e].borderColor||A[e].backgroundColor)return!0;return!1}function Rc(A){return A&&(A.borderColor||A.backgroundColor)}function Jc(){return"rgba(0,0,0,0.1)"!==vv.borderColor||"rgba(0,0,0,0.1)"!==vv.backgroundColor}var Fc={id:"colors",defaults:{enabled:!0,forceOverride:!1},beforeLayout(A,e,t){if(!t.enabled)return;const{data:{datasets:n},options:r}=A.config,{elements:P}=r,z=Ec(n)||Rc(r)||P&&Ec(P)||Jc();if(!t.forceOverride&&z)return;const f=Sc(A);n.forEach(f)}};function _c(A,e,t,n,r){const P=r.samples||n;if(P>=t)return A.slice(e,e+t);const z=[],f=(t-2)/(P-2);let v=0;const s=e+t-1;let a,w,D,c,l,d=e;for(z[v++]=A[d],a=0;aD&&(D=c,w=A[n],l=n);z[v++]=w,d=l}return z[v++]=A[s],z}function $c(A,e,t,n){let r,P,z,f,v,s,a,w,D,c,l=0,d=0;const M=[],g=e+t-1,u=A[e].x,j=A[g].x-u;for(r=e;rc&&(c=f,a=r),l=(d*l+P.x)/++d;else{const t=r-1;if(!Hz(s)&&!Hz(a)){const e=Math.min(s,a),n=Math.max(s,a);e!==w&&e!==t&&M.push({...A[e],x:l}),n!==w&&n!==t&&M.push({...A[n],x:l})}r>0&&t!==w&&M.push(A[t]),M.push(P),v=e,d=0,D=c=f,s=a=w=r}}return M}function Al(A){if(A._decimated){const e=A._data;delete A._decimated,delete A._data,Object.defineProperty(A,"data",{configurable:!0,enumerable:!0,writable:!0,value:e})}}function el(A){A.data.datasets.forEach((A=>{Al(A)}))}function tl(A,e){const t=e.length;let n,r=0;const{iScale:P}=A,{min:z,max:f,minDefined:v,maxDefined:s}=P.getUserBounds();return v&&(r=jf(Hf(e,P.axis,z).lo,0,t-1)),n=s?jf(Hf(e,P.axis,f).hi+1,r,t)-r:t-r,{start:r,count:n}}var nl={id:"decimation",defaults:{algorithm:"min-max",enabled:!1},beforeElementsUpdate:(A,e,t)=>{if(!t.enabled)return void el(A);const n=A.width;A.data.datasets.forEach(((e,r)=>{const{_data:P,indexAxis:z}=e,f=A.getDatasetMeta(r),v=P||e.data;if("y"===Nv([z,A.options.indexAxis]))return;if(!f.controller.supportsDecimation)return;const s=A.scales[f.xAxisID];if("linear"!==s.type&&"time"!==s.type)return;if(A.options.parsing)return;let{start:a,count:w}=tl(f,v);if(w<=(t.threshold||4*n))return void Al(e);let D;switch(Hz(P)&&(e._data=v,delete e.data,Object.defineProperty(e,"data",{configurable:!0,enumerable:!0,get:function(){return this._decimated},set:function(A){this._data=A}})),t.algorithm){case"lttb":D=_c(v,a,w,n,t);break;case"min-max":D=$c(v,a,w,n);break;default:throw new Error(`Unsupported decimation algorithm '${t.algorithm}'`)}e._decimated=D}))},destroy(A){el(A)}};function rl(A,e,t){const n=A.segments,r=A.points,P=e.points,z=[];for(const A of n){let{start:n,end:f}=A;f=fl(n,f,r);const v=Pl(t,r[n],r[f],A.loop);if(!e.segments){z.push({source:A,target:v,start:r[n],end:r[f]});continue}const s=qs(e,v);for(const e of s){const n=Pl(t,P[e.start],P[e.end],e.loop),f=hs(A,r,n);for(const A of f)z.push({source:A,target:e,start:{[t]:vl(v,n,"start",Math.max)},end:{[t]:vl(v,n,"end",Math.min)}})}}return z}function Pl(A,e,t,n){if(n)return;let r=e[A],P=t[A];return"angle"===A&&(r=gf(r),P=gf(P)),{property:A,start:r,end:P}}function zl(A,e){const{x:t=null,y:n=null}=A||{},r=e.points,P=[];return e.segments.forEach((({start:A,end:e})=>{e=fl(A,e,r);const z=r[A],f=r[e];null!==n?(P.push({x:z.x,y:n}),P.push({x:f.x,y:n})):null!==t&&(P.push({x:t,y:z.y}),P.push({x:t,y:f.y}))})),P}function fl(A,e,t){for(;e>A;e--){const A=t[e];if(!isNaN(A.x)&&!isNaN(A.y))break}return e}function vl(A,e,t,n){return A&&e?n(A[t],e[t]):A?A[t]:e?e[t]:0}function sl(A,e){let t=[],n=!1;return Wz(A)?(n=!0,t=A):t=zl(A,e),t.length?new Oc({points:t,options:{tension:0},_loop:n,_fullLoop:n}):null}function al(A){return A&&!1!==A.fill}function wl(A,e,t){let n=A[e].fill;const r=[e];let P;if(!t)return n;for(;!1!==n&&-1===r.indexOf(n);){if(!Oz(n))return n;if(P=A[n],!P)return!1;if(P.visible)return n;r.push(n),n=P.fill}return!1}function Dl(A,e,t){const n=Ml(A);if(Bz(n))return!isNaN(n.value)&&n;let r=parseFloat(n);return Oz(r)&&Math.floor(r)===r?cl(n[0],e,r,t):["origin","start","end","stack","shape"].indexOf(n)>=0&&n}function cl(A,e,t,n){return"-"!==A&&"+"!==A||(t=e+t),!(t===e||t<0||t>=n)&&t}function ll(A,e){let t=null;return"start"===A?t=e.bottom:"end"===A?t=e.top:Bz(A)?t=e.getPixelForValue(A.value):e.getBasePixel&&(t=e.getBasePixel()),t}function dl(A,e,t){let n;return n="start"===A?t:"end"===A?e.options.reverse?e.min:e.max:Bz(A)?A.value:e.getBaseValue(),n}function Ml(A){const e=A.options,t=e.fill;let n=Zz(t&&t.target,t);return void 0===n&&(n=!!e.backgroundColor),!1!==n&&null!==n&&(!0===n?"origin":n)}function gl(A){const{scale:e,index:t,line:n}=A,r=[],P=n.segments,z=n.points,f=ul(e,t);f.push(sl({x:null,y:e.bottom},n));for(let A=0;A=0;--e){const t=r[e].$filler;t&&(t.line.updateControlPoints(P,t.axis),n&&t.fill&&pl(A.ctx,t,P))}},beforeDatasetsDraw(A,e,t){if("beforeDatasetsDraw"!==t.drawTime)return;const n=A.getSortedVisibleDatasetMetas();for(let e=n.length-1;e>=0;--e){const t=n[e].$filler;al(t)&&pl(A.ctx,t,A.chartArea)}},beforeDatasetDraw(A,e,t){const n=e.meta.$filler;al(n)&&"beforeDatasetDraw"===t.drawTime&&pl(A.ctx,n,A.chartArea)},defaults:{propagate:!0,drawTime:"beforeDatasetDraw"}};const ol=(A,e)=>{let{boxHeight:t=e,boxWidth:n=e}=A;return A.usePointStyle&&(t=Math.min(t,e),n=A.pointStyleWidth||Math.min(n,e)),{boxWidth:n,boxHeight:t,itemHeight:Math.max(e,t)}},Nl=(A,e)=>null!==A&&null!==e&&A.datasetIndex===e.datasetIndex&&A.index===e.index;class il extends Sw{constructor(A){super(),this._added=!1,this.legendHitBoxes=[],this._hoveredItem=null,this.doughnutMode=!1,this.chart=A.chart,this.options=A.options,this.ctx=A.ctx,this.legendItems=void 0,this.columnSizes=void 0,this.lineWidths=void 0,this.maxHeight=void 0,this.maxWidth=void 0,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.height=void 0,this.width=void 0,this._margins=void 0,this.position=void 0,this.weight=void 0,this.fullSize=void 0}update(A,e,t){this.maxWidth=A,this.maxHeight=e,this._margins=t,this.setDimensions(),this.buildLabels(),this.fit()}setDimensions(){this.isHorizontal()?(this.width=this.maxWidth,this.left=this._margins.left,this.right=this.width):(this.height=this.maxHeight,this.top=this._margins.top,this.bottom=this.height)}buildLabels(){const A=this.options.labels||{};let e=mz(A.generateLabels,[this.chart],this)||[];A.filter&&(e=e.filter((e=>A.filter(e,this.chart.data)))),A.sort&&(e=e.sort(((e,t)=>A.sort(e,t,this.chart.data)))),this.options.reverse&&e.reverse(),this.legendItems=e}fit(){const{options:A,ctx:e}=this;if(!A.display)return void(this.width=this.height=0);const t=A.labels,n=ov(t.font),r=n.size,P=this._computeTitleHeight(),{boxWidth:z,itemHeight:f}=ol(t,r);let v,s;e.font=n.string,this.isHorizontal()?(v=this.maxWidth,s=this._fitRows(P,r,z,f)+10):(s=this.maxHeight,v=this._fitCols(P,n,z,f)+10),this.width=Math.min(v,A.maxWidth||this.maxWidth),this.height=Math.min(s,A.maxHeight||this.maxHeight)}_fitRows(A,e,t,n){const{ctx:r,maxWidth:P,options:{labels:{padding:z}}}=this,f=this.legendHitBoxes=[],v=this.lineWidths=[0],s=n+z;let a=A;r.textAlign="left",r.textBaseline="middle";let w=-1,D=-s;return this.legendItems.forEach(((A,c)=>{const l=t+e/2+r.measureText(A.text).width;(0===c||v[v.length-1]+l+2*z>P)&&(a+=s,v[v.length-(c>0?0:1)]=0,D+=s,w++),f[c]={left:0,top:D,row:w,width:l,height:n},v[v.length-1]+=l+z})),a}_fitCols(A,e,t,n){const{ctx:r,maxHeight:P,options:{labels:{padding:z}}}=this,f=this.legendHitBoxes=[],v=this.columnSizes=[],s=P-A;let a=z,w=0,D=0,c=0,l=0;return this.legendItems.forEach(((A,P)=>{const{itemWidth:d,itemHeight:M}=Ql(t,e,r,A,n);P>0&&D+M+2*z>s&&(a+=w+z,v.push({width:w,height:D}),c+=w+z,l++,w=D=0),f[P]={left:c,top:D,col:l,width:d,height:M},w=Math.max(w,d),D+=M+z})),a+=w,v.push({width:w,height:D}),a}adjustHitBoxes(){if(!this.options.display)return;const A=this._computeTitleHeight(),{legendHitBoxes:e,options:{align:t,labels:{padding:n},rtl:r}}=this,P=Ns(r,this.left,this.width);if(this.isHorizontal()){let r=0,z=of(t,this.left+n,this.right-this.lineWidths[r]);for(const f of e)r!==f.row&&(r=f.row,z=of(t,this.left+n,this.right-this.lineWidths[r])),f.top+=this.top+A+n,f.left=P.leftForLtr(P.x(z),f.width),z+=f.width+n}else{let r=0,z=of(t,this.top+A+n,this.bottom-this.columnSizes[r].height);for(const f of e)f.col!==r&&(r=f.col,z=of(t,this.top+A+n,this.bottom-this.columnSizes[r].height)),f.top=z,f.left+=this.left+n,f.left=P.leftForLtr(P.x(f.left),f.width),z+=f.height+n}}isHorizontal(){return"top"===this.options.position||"bottom"===this.options.position}draw(){if(this.options.display){const A=this.ctx;gv(A,this),this._draw(),uv(A)}}_draw(){const{options:A,columnSizes:e,lineWidths:t,ctx:n}=this,{align:r,labels:P}=A,z=vv.color,f=Ns(A.rtl,this.left,this.width),v=ov(P.font),{padding:s}=P,a=v.size,w=a/2;let D;this.drawTitle(),n.textAlign=f.textAlign("left"),n.textBaseline="middle",n.lineWidth=.5,n.font=v.string;const{boxWidth:c,boxHeight:l,itemHeight:d}=ol(P,a),M=this.isHorizontal(),g=this._computeTitleHeight();D=M?{x:of(r,this.left+s,this.right-t[0]),y:this.top+s+g,line:0}:{x:this.left+s,y:of(r,this.top+g+s,this.bottom-e[0].height),line:0},is(this.ctx,A.textDirection);const u=d+s;this.legendItems.forEach(((j,b)=>{n.strokeStyle=j.fontColor,n.fillStyle=j.fontColor;const x=n.measureText(j.text).width,X=f.textAlign(j.textAlign||(j.textAlign=P.textAlign)),H=c+w+x;let W=D.x,B=D.y;f.setWidth(this.width),M?b>0&&W+H+s>this.right&&(B=D.y+=u,D.line++,W=D.x=of(r,this.left+s,this.right-t[D.line])):b>0&&B+u>this.bottom&&(W=D.x=W+e[D.line].width+s,D.line++,B=D.y=of(r,this.top+g+s,this.bottom-e[D.line].height));if(function(A,e,t){if(isNaN(c)||c<=0||isNaN(l)||l<0)return;n.save();const r=Zz(t.lineWidth,1);if(n.fillStyle=Zz(t.fillStyle,z),n.lineCap=Zz(t.lineCap,"butt"),n.lineDashOffset=Zz(t.lineDashOffset,0),n.lineJoin=Zz(t.lineJoin,"miter"),n.lineWidth=r,n.strokeStyle=Zz(t.strokeStyle,z),n.setLineDash(Zz(t.lineDash,[])),P.usePointStyle){const z={radius:l*Math.SQRT2/2,pointStyle:t.pointStyle,rotation:t.rotation,borderWidth:r},v=f.xPlus(A,c/2);dv(n,z,v,e+w,P.pointStyleWidth&&c)}else{const P=e+Math.max((a-l)/2,0),z=f.leftForLtr(A,c),v=Lv(t.borderRadius);n.beginPath(),Object.values(v).some((A=>0!==A))?Bv(n,{x:z,y:P,w:c,h:l,radius:v}):n.rect(z,P,c,l),n.fill(),0!==r&&n.stroke()}n.restore()}(f.x(W),B,j),W=Nf(X,W+c+w,M?W+H:this.right,A.rtl),function(A,e,t){Wv(n,t.text,A,e+d/2,v,{strikethrough:t.hidden,textAlign:f.textAlign(t.textAlign)})}(f.x(W),B,j),M)D.x+=H+s;else if("string"!=typeof j.text){const A=v.lineHeight;D.y+=Vl(j,A)+s}else D.y+=u})),Qs(this.ctx,A.textDirection)}drawTitle(){const A=this.options,e=A.title,t=ov(e.font),n=Yv(e.padding);if(!e.display)return;const r=Ns(A.rtl,this.left,this.width),P=this.ctx,z=e.position,f=t.size/2,v=n.top+f;let s,a=this.left,w=this.width;if(this.isHorizontal())w=Math.max(...this.lineWidths),s=this.top+v,a=of(A.align,a,this.right-w);else{const e=this.columnSizes.reduce(((A,e)=>Math.max(A,e.height)),0);s=v+of(A.align,this.top,this.bottom-e-A.labels.padding-this._computeTitleHeight())}const D=of(z,a,a+w);P.textAlign=r.textAlign(Yf(z)),P.textBaseline="middle",P.strokeStyle=e.color,P.fillStyle=e.color,P.font=t.string,Wv(P,e.text,D,s,t)}_computeTitleHeight(){const A=this.options.title,e=ov(A.font),t=Yv(A.padding);return A.display?e.lineHeight+t.height:0}_getLegendItemAt(A,e){let t,n,r;if(xf(A,this.left,this.right)&&xf(e,this.top,this.bottom))for(r=this.legendHitBoxes,t=0;tA.length>e.length?A:e))),e+t.size/2+n.measureText(r).width}function Cl(A,e,t){let n=A;return"string"!=typeof e.text&&(n=Vl(e,t)),n}function Vl(A,e){return e*(A.text?A.text.length:0)}function hl(A,e){return!("mousemove"!==A&&"mouseout"!==A||!e.onHover&&!e.onLeave)||!(!e.onClick||"click"!==A&&"mouseup"!==A)}var ql={id:"legend",_element:il,start(A,e,t){const n=A.legend=new il({ctx:A.ctx,options:t,chart:A});Hw.configure(A,n,t),Hw.addBox(A,n)},stop(A){Hw.removeBox(A,A.legend),delete A.legend},beforeUpdate(A,e,t){const n=A.legend;Hw.configure(A,n,t),n.options=t},afterUpdate(A){const e=A.legend;e.buildLabels(),e.adjustHitBoxes()},afterEvent(A,e){e.replay||A.legend.handleEvent(e.event)},defaults:{display:!0,position:"top",align:"center",fullSize:!0,reverse:!1,weight:1e3,onClick(A,e,t){const n=e.datasetIndex,r=t.chart;r.isDatasetVisible(n)?(r.hide(n),e.hidden=!0):(r.show(n),e.hidden=!1)},onHover:null,onLeave:null,labels:{color:A=>A.chart.options.color,boxWidth:40,padding:10,generateLabels(A){const e=A.data.datasets,{labels:{usePointStyle:t,pointStyle:n,textAlign:r,color:P,useBorderRadius:z,borderRadius:f}}=A.legend.options;return A._getSortedDatasetMetas().map((A=>{const v=A.controller.getStyle(t?0:void 0),s=Yv(v.borderWidth);return{text:e[A.index].label,fillStyle:v.backgroundColor,fontColor:P,hidden:!A.visible,lineCap:v.borderCapStyle,lineDash:v.borderDash,lineDashOffset:v.borderDashOffset,lineJoin:v.borderJoinStyle,lineWidth:(s.width+s.height)/4,strokeStyle:v.borderColor,pointStyle:n||v.pointStyle,rotation:v.rotation,textAlign:r||v.textAlign,borderRadius:z&&(f||v.borderRadius),datasetIndex:A.index}}),this)}},title:{color:A=>A.chart.options.color,display:!1,position:"center",text:""}},descriptors:{_scriptable:A=>!A.startsWith("on"),labels:{_scriptable:A=>!["generateLabels","filter","sort"].includes(A)}}};class Il extends Sw{constructor(A){super(),this.chart=A.chart,this.options=A.options,this.ctx=A.ctx,this._padding=void 0,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.width=void 0,this.height=void 0,this.position=void 0,this.weight=void 0,this.fullSize=void 0}update(A,e){const t=this.options;if(this.left=0,this.top=0,!t.display)return void(this.width=this.height=this.right=this.bottom=0);this.width=this.right=A,this.height=this.bottom=e;const n=Wz(t.text)?t.text.length:1;this._padding=Yv(t.padding);const r=n*ov(t.font).lineHeight+this._padding.height;this.isHorizontal()?this.height=r:this.width=r}isHorizontal(){const A=this.options.position;return"top"===A||"bottom"===A}_drawArgs(A){const{top:e,left:t,bottom:n,right:r,options:P}=this,z=P.align;let f,v,s,a=0;return this.isHorizontal()?(v=of(z,t,r),s=e+A,f=r-t):("left"===P.position?(v=t+A,s=of(z,n,e),a=-.5*Rz):(v=r-A,s=of(z,e,n),a=.5*Rz),f=n-e),{titleX:v,titleY:s,maxWidth:f,rotation:a}}draw(){const A=this.ctx,e=this.options;if(!e.display)return;const t=ov(e.font),n=t.lineHeight/2+this._padding.top,{titleX:r,titleY:P,maxWidth:z,rotation:f}=this._drawArgs(n);Wv(A,e.text,0,0,t,{color:e.color,maxWidth:z,rotation:f,textAlign:Yf(e.align),textBaseline:"middle",translation:[r,P]})}}function kl(A,e){const t=new Il({ctx:A.ctx,options:e,chart:A});Hw.configure(A,t,e),Hw.addBox(A,t),A.titleBlock=t}var Kl={id:"title",_element:Il,start(A,e,t){kl(A,t)},stop(A){const e=A.titleBlock;Hw.removeBox(A,e),delete A.titleBlock},beforeUpdate(A,e,t){const n=A.titleBlock;Hw.configure(A,n,t),n.options=t},defaults:{align:"center",display:!1,font:{weight:"bold"},fullSize:!0,padding:10,position:"top",text:"",weight:2e3},defaultRoutes:{color:"color"},descriptors:{_scriptable:!0,_indexable:!1}};const Ul=new WeakMap;var Sl={id:"subtitle",start(A,e,t){const n=new Il({ctx:A.ctx,options:t,chart:A});Hw.configure(A,n,t),Hw.addBox(A,n),Ul.set(A,n)},stop(A){Hw.removeBox(A,Ul.get(A)),Ul.delete(A)},beforeUpdate(A,e,t){const n=Ul.get(A);Hw.configure(A,n,t),n.options=t},defaults:{align:"center",display:!1,font:{weight:"normal"},fullSize:!0,padding:0,position:"top",text:"",weight:1500},defaultRoutes:{color:"color"},descriptors:{_scriptable:!0,_indexable:!1}};const El={average(A){if(!A.length)return!1;let e,t,n=new Set,r=0,P=0;for(e=0,t=A.length;eA+e))/n.size;return{x:z,y:r/P}},nearest(A,e){if(!A.length)return!1;let t,n,r,P=e.x,z=e.y,f=Number.POSITIVE_INFINITY;for(t=0,n=A.length;t-1?A.split("\n"):A}function Fl(A,e){const{element:t,datasetIndex:n,index:r}=e,P=A.getDatasetMeta(n).controller,{label:z,value:f}=P.getLabelAndValue(r);return{chart:A,label:z,parsed:P.getParsed(r),raw:A.data.datasets[n].data[r],formattedValue:f,dataset:P.getDataset(),dataIndex:r,datasetIndex:n,element:t}}function _l(A,e){const t=A.chart.ctx,{body:n,footer:r,title:P}=A,{boxWidth:z,boxHeight:f}=e,v=ov(e.bodyFont),s=ov(e.titleFont),a=ov(e.footerFont),w=P.length,D=r.length,c=n.length,l=Yv(e.padding);let d=l.height,M=0,g=n.reduce(((A,e)=>A+e.before.length+e.lines.length+e.after.length),0);if(g+=A.beforeBody.length+A.afterBody.length,w&&(d+=w*s.lineHeight+(w-1)*e.titleSpacing+e.titleMarginBottom),g){d+=c*(e.displayColors?Math.max(f,v.lineHeight):v.lineHeight)+(g-c)*v.lineHeight+(g-1)*e.bodySpacing}D&&(d+=e.footerMarginTop+D*a.lineHeight+(D-1)*e.footerSpacing);let u=0;const j=function(A){M=Math.max(M,t.measureText(A).width+u)};return t.save(),t.font=s.string,Lz(A.title,j),t.font=v.string,Lz(A.beforeBody.concat(A.afterBody),j),u=e.displayColors?z+2+e.boxPadding:0,Lz(n,(A=>{Lz(A.before,j),Lz(A.lines,j),Lz(A.after,j)})),u=0,t.font=a.string,Lz(A.footer,j),t.restore(),M+=l.width,{width:M,height:d}}function $l(A,e){const{y:t,height:n}=e;return tA.height-n/2?"bottom":"center"}function Ad(A,e,t,n){const{x:r,width:P}=n,z=t.caretSize+t.caretPadding;return"left"===A&&r+P+z>e.width||("right"===A&&r-P-z<0||void 0)}function ed(A,e,t,n){const{x:r,width:P}=t,{width:z,chartArea:{left:f,right:v}}=A;let s="center";return"center"===n?s=r<=(f+v)/2?"left":"right":r<=P/2?s="left":r>=z-P/2&&(s="right"),Ad(s,A,e,t)&&(s="center"),s}function td(A,e,t){const n=t.yAlign||e.yAlign||$l(A,t);return{xAlign:t.xAlign||e.xAlign||ed(A,e,t,n),yAlign:n}}function nd(A,e){let{x:t,width:n}=A;return"right"===e?t-=n:"center"===e&&(t-=n/2),t}function rd(A,e,t){let{y:n,height:r}=A;return"top"===e?n+=t:n-="bottom"===e?r+t:r/2,n}function Pd(A,e,t,n){const{caretSize:r,caretPadding:P,cornerRadius:z}=A,{xAlign:f,yAlign:v}=t,s=r+P,{topLeft:a,topRight:w,bottomLeft:D,bottomRight:c}=Lv(z);let l=nd(e,f);const d=rd(e,v,s);return"center"===v?"left"===f?l+=s:"right"===f&&(l-=s):"left"===f?l-=Math.max(a,D)+r:"right"===f&&(l+=Math.max(w,c)+r),{x:jf(l,0,n.width-e.width),y:jf(d,0,n.height-e.height)}}function zd(A,e,t){const n=Yv(t.padding);return"center"===e?A.x+A.width/2:"right"===e?A.x+A.width-n.right:A.x+n.left}function fd(A){return Rl([],Jl(A))}function vd(A,e,t){return Qv(A,{tooltip:e,tooltipItems:t,type:"tooltip"})}function sd(A,e){const t=e&&e.dataset&&e.dataset.tooltip&&e.dataset.tooltip.callbacks;return t?A.override(t):A}const ad={beforeTitle:xz,title(A){if(A.length>0){const e=A[0],t=e.chart.data.labels,n=t?t.length:0;if(this&&this.options&&"dataset"===this.options.mode)return e.dataset.label||"";if(e.label)return e.label;if(n>0&&e.dataIndex{const e={before:[],lines:[],after:[]},r=sd(t,A);Rl(e.before,Jl(wd(r,"beforeLabel",this,A))),Rl(e.lines,wd(r,"label",this,A)),Rl(e.after,Jl(wd(r,"afterLabel",this,A))),n.push(e)})),n}getAfterBody(A,e){return fd(wd(e.callbacks,"afterBody",this,A))}getFooter(A,e){const{callbacks:t}=e,n=wd(t,"beforeFooter",this,A),r=wd(t,"footer",this,A),P=wd(t,"afterFooter",this,A);let z=[];return z=Rl(z,Jl(n)),z=Rl(z,Jl(r)),z=Rl(z,Jl(P)),z}_createItems(A){const e=this._active,t=this.chart.data,n=[],r=[],P=[];let z,f,v=[];for(z=0,f=e.length;zA.filter(e,n,r,t)))),A.itemSort&&(v=v.sort(((e,n)=>A.itemSort(e,n,t)))),Lz(v,(e=>{const t=sd(A.callbacks,e);n.push(wd(t,"labelColor",this,e)),r.push(wd(t,"labelPointStyle",this,e)),P.push(wd(t,"labelTextColor",this,e))})),this.labelColors=n,this.labelPointStyles=r,this.labelTextColors=P,this.dataPoints=v,v}update(A,e){const t=this.options.setContext(this.getContext()),n=this._active;let r,P=[];if(n.length){const A=El[t.position].call(this,n,this._eventPosition);P=this._createItems(t),this.title=this.getTitle(P,t),this.beforeBody=this.getBeforeBody(P,t),this.body=this.getBody(P,t),this.afterBody=this.getAfterBody(P,t),this.footer=this.getFooter(P,t);const e=this._size=_l(this,t),z=Object.assign({},A,e),f=td(this.chart,t,z),v=Pd(t,z,f,this.chart);this.xAlign=f.xAlign,this.yAlign=f.yAlign,r={opacity:1,x:v.x,y:v.y,width:e.width,height:e.height,caretX:A.x,caretY:A.y}}else 0!==this.opacity&&(r={opacity:0});this._tooltipItems=P,this.$context=void 0,r&&this._resolveAnimations().update(this,r),A&&t.external&&t.external.call(this,{chart:this.chart,tooltip:this,replay:e})}drawCaret(A,e,t,n){const r=this.getCaretPosition(A,t,n);e.lineTo(r.x1,r.y1),e.lineTo(r.x2,r.y2),e.lineTo(r.x3,r.y3)}getCaretPosition(A,e,t){const{xAlign:n,yAlign:r}=this,{caretSize:P,cornerRadius:z}=t,{topLeft:f,topRight:v,bottomLeft:s,bottomRight:a}=Lv(z),{x:w,y:D}=A,{width:c,height:l}=e;let d,M,g,u,j,b;return"center"===r?(j=D+l/2,"left"===n?(d=w,M=d-P,u=j+P,b=j-P):(d=w+c,M=d+P,u=j-P,b=j+P),g=d):(M="left"===n?w+Math.max(f,s)+P:"right"===n?w+c-Math.max(v,a)-P:this.caretX,"top"===r?(u=D,j=u-P,d=M-P,g=M+P):(u=D+l,j=u+P,d=M+P,g=M-P),b=u),{x1:d,x2:M,x3:g,y1:u,y2:j,y3:b}}drawTitle(A,e,t){const n=this.title,r=n.length;let P,z,f;if(r){const v=Ns(t.rtl,this.x,this.width);for(A.x=zd(this,t.titleAlign,t),e.textAlign=v.textAlign(t.titleAlign),e.textBaseline="middle",P=ov(t.titleFont),z=t.titleSpacing,e.fillStyle=t.titleColor,e.font=P.string,f=0;f0!==A))?(A.beginPath(),A.fillStyle=r.multiKeyBackground,Bv(A,{x:e,y:c,w:v,h:f,radius:z}),A.fill(),A.stroke(),A.fillStyle=P.backgroundColor,A.beginPath(),Bv(A,{x:t,y:c+1,w:v-2,h:f-2,radius:z}),A.fill()):(A.fillStyle=r.multiKeyBackground,A.fillRect(e,c,v,f),A.strokeRect(e,c,v,f),A.fillStyle=P.backgroundColor,A.fillRect(t,c+1,v-2,f-2))}A.fillStyle=this.labelTextColors[t]}drawBody(A,e,t){const{body:n}=this,{bodySpacing:r,bodyAlign:P,displayColors:z,boxHeight:f,boxWidth:v,boxPadding:s}=t,a=ov(t.bodyFont);let w=a.lineHeight,D=0;const c=Ns(t.rtl,this.x,this.width),l=function(t){e.fillText(t,c.x(A.x+D),A.y+w/2),A.y+=w+r},d=c.textAlign(P);let M,g,u,j,b,x,X;for(e.textAlign=P,e.textBaseline="middle",e.font=a.string,A.x=zd(this,d,t),e.fillStyle=t.bodyColor,Lz(this.beforeBody,l),D=z&&"right"!==d?"center"===P?v/2+s:v+2+s:0,j=0,x=n.length;j0&&e.stroke()}_updateAnimationTarget(A){const e=this.chart,t=this.$animations,n=t&&t.x,r=t&&t.y;if(n||r){const t=El[A.position].call(this,this._active,this._eventPosition);if(!t)return;const P=this._size=_l(this,A),z=Object.assign({},t,this._size),f=td(e,A,z),v=Pd(A,z,f,e);n._to===v.x&&r._to===v.y||(this.xAlign=f.xAlign,this.yAlign=f.yAlign,this.width=P.width,this.height=P.height,this.caretX=t.x,this.caretY=t.y,this._resolveAnimations().update(this,v))}}_willRender(){return!!this.opacity}draw(A){const e=this.options.setContext(this.getContext());let t=this.opacity;if(!t)return;this._updateAnimationTarget(e);const n={width:this.width,height:this.height},r={x:this.x,y:this.y};t=Math.abs(t)<.001?0:t;const P=Yv(e.padding),z=this.title.length||this.beforeBody.length||this.body.length||this.afterBody.length||this.footer.length;e.enabled&&z&&(A.save(),A.globalAlpha=t,this.drawBackground(r,A,n,e),is(A,e.textDirection),r.y+=P.top,this.drawTitle(r,A,e),this.drawBody(r,A,e),this.drawFooter(r,A,e),Qs(A,e.textDirection),A.restore())}getActiveElements(){return this._active||[]}setActiveElements(A,e){const t=this._active,n=A.map((({datasetIndex:A,index:e})=>{const t=this.chart.getDatasetMeta(A);if(!t)throw new Error("Cannot find a dataset at index "+A);return{datasetIndex:A,element:t.data[e],index:e}})),r=!Yz(t,n),P=this._positionChanged(n,e);(r||P)&&(this._active=n,this._eventPosition=e,this._ignoreReplayEvents=!0,this.update(!0))}handleEvent(A,e,t=!0){if(e&&this._ignoreReplayEvents)return!1;this._ignoreReplayEvents=!1;const n=this.options,r=this._active||[],P=this._getActiveElements(A,r,e,t),z=this._positionChanged(P,A),f=e||!Yz(P,r)||z;return f&&(this._active=P,(n.enabled||n.external)&&(this._eventPosition={x:A.x,y:A.y},this.update(!0,e))),f}_getActiveElements(A,e,t,n){const r=this.options;if("mouseout"===A.type)return[];if(!n)return e.filter((A=>this.chart.data.datasets[A.datasetIndex]&&void 0!==this.chart.getDatasetMeta(A.datasetIndex).controller.getParsed(A.index)));const P=this.chart.getElementsAtEventForMode(A,r.mode,r,t);return r.reverse&&P.reverse(),P}_positionChanged(A,e){const{caretX:t,caretY:n,options:r}=this,P=El[r.position].call(this,A,e);return!1!==P&&(t!==P.x||n!==P.y)}}var cd={id:"tooltip",_element:Dd,positioners:El,afterInit(A,e,t){t&&(A.tooltip=new Dd({chart:A,options:t}))},beforeUpdate(A,e,t){A.tooltip&&A.tooltip.initialize(t)},reset(A,e,t){A.tooltip&&A.tooltip.initialize(t)},afterDraw(A){const e=A.tooltip;if(e&&e._willRender()){const t={tooltip:e};if(!1===A.notifyPlugins("beforeTooltipDraw",{...t,cancelable:!0}))return;e.draw(A.ctx),A.notifyPlugins("afterTooltipDraw",t)}},afterEvent(A,e){if(A.tooltip){const t=e.replay;A.tooltip.handleEvent(e.event,t,e.inChartArea)&&(e.changed=!0)}},defaults:{enabled:!0,external:null,position:"average",backgroundColor:"rgba(0,0,0,0.8)",titleColor:"#fff",titleFont:{weight:"bold"},titleSpacing:2,titleMarginBottom:6,titleAlign:"left",bodyColor:"#fff",bodySpacing:2,bodyFont:{},bodyAlign:"left",footerColor:"#fff",footerSpacing:2,footerMarginTop:6,footerFont:{weight:"bold"},footerAlign:"left",padding:6,caretPadding:2,caretSize:5,cornerRadius:6,boxHeight:(A,e)=>e.bodyFont.size,boxWidth:(A,e)=>e.bodyFont.size,multiKeyBackground:"#fff",displayColors:!0,boxPadding:0,borderColor:"rgba(0,0,0,0)",borderWidth:0,animation:{duration:400,easing:"easeOutQuart"},animations:{numbers:{type:"number",properties:["x","y","width","height","caretX","caretY"]},opacity:{easing:"linear",duration:200}},callbacks:ad},defaultRoutes:{bodyFont:"font",footerFont:"font",titleFont:"font"},descriptors:{_scriptable:A=>"filter"!==A&&"itemSort"!==A&&"external"!==A,_indexable:!1,callbacks:{_scriptable:!1,_indexable:!1},animation:{_fallback:!1},animations:{_fallback:"animation"}},additionalOptionScopes:["interaction"]},ld=Object.freeze({__proto__:null,Colors:Fc,Decimation:nl,Filler:Yl,Legend:ql,SubTitle:Sl,Title:Kl,Tooltip:cd});const dd=(A,e,t,n)=>("string"==typeof e?(t=A.push(e)-1,n.unshift({index:t,label:e})):isNaN(e)&&(t=null),t);function Md(A,e,t,n){const r=A.indexOf(e);if(-1===r)return dd(A,e,t,n);return r!==A.lastIndexOf(e)?t:r}const gd=(A,e)=>null===A?null:jf(Math.round(A),0,e);function ud(A){const e=this.getLabels();return A>=0&&Ae.length-1?null:this.getPixelForValue(e[A].value)}getValueForPixel(A){return Math.round(this._startValue+this.getDecimalForPixel(A)*this._valueRange)}getBasePixel(){return this.bottom}}function bd(A,e){const t=[],{bounds:n,step:r,min:P,max:z,precision:f,count:v,maxTicks:s,maxDigits:a,includeBounds:w}=A,D=r||1,c=s-1,{min:l,max:d}=e,M=!Hz(P),g=!Hz(z),u=!Hz(v),j=(d-l)/(a+1);let b,x,X,H,W=zf((d-l)/c/D)*D;if(W<1e-14&&!M&&!g)return[{value:l},{value:d}];H=Math.ceil(d/W)-Math.floor(l/W),H>c&&(W=zf(H*W/c/D)*D),Hz(f)||(b=Math.pow(10,f),W=Math.ceil(W*b)/b),"ticks"===n?(x=Math.floor(l/W)*W,X=Math.ceil(d/W)*W):(x=l,X=d),M&&g&&r&&sf((z-P)/r,W/1e3)?(H=Math.round(Math.min((z-P)/W,s)),W=(z-P)/H,x=P,X=z):u?(x=M?P:x,X=g?z:X,H=v-1,W=(X-x)/H):(H=(X-x)/W,H=Pf(H,Math.round(H),W/1e3)?Math.round(H):Math.ceil(H));const B=Math.max(cf(W),cf(x));b=Math.pow(10,Hz(f)?B:f),x=Math.round(x*b)/b,X=Math.round(X*b)/b;let O=0;for(M&&(w&&x!==P?(t.push({value:P}),xz)break;t.push({value:A})}return g&&w&&X!==z?t.length&&Pf(t[t.length-1].value,z,xd(z,j,A))?t[t.length-1].value=z:t.push({value:z}):g&&X!==z||t.push({value:X}),t}function xd(A,e,{horizontal:t,minRotation:n}){const r=wf(n),P=(t?Math.sin(r):Math.cos(r))||.001,z=.75*e*(""+A).length;return Math.min(e/P,z)}class Xd extends cD{constructor(A){super(A),this.start=void 0,this.end=void 0,this._startValue=void 0,this._endValue=void 0,this._valueRange=0}parse(A,e){return Hz(A)||("number"==typeof A||A instanceof Number)&&!isFinite(+A)?null:+A}handleTickRangeOptions(){const{beginAtZero:A}=this.options,{minDefined:e,maxDefined:t}=this.getUserBounds();let{min:n,max:r}=this;const P=A=>n=e?n:A,z=A=>r=t?r:A;if(A){const A=rf(n),e=rf(r);A<0&&e<0?z(0):A>0&&e>0&&P(0)}if(n===r){let e=0===r?1:Math.abs(.05*r);z(r+e),A||P(n-e)}this.min=n,this.max=r}getTickLimit(){const A=this.options.ticks;let e,{maxTicksLimit:t,stepSize:n}=A;return n?(e=Math.ceil(this.max/n)-Math.floor(this.min/n)+1,e>1e3&&(console.warn(`scales.${this.id}.ticks.stepSize: ${n} would result generating up to ${e} ticks. Limiting to 1000.`),e=1e3)):(e=this.computeTickLimit(),t=t||11),t&&(e=Math.min(t,e)),e}computeTickLimit(){return Number.POSITIVE_INFINITY}buildTicks(){const A=this.options,e=A.ticks;let t=this.getTickLimit();t=Math.max(2,t);const n=bd({maxTicks:t,bounds:A.bounds,min:A.min,max:A.max,precision:e.precision,step:e.stepSize,count:e.count,maxDigits:this._maxDigits(),horizontal:this.isHorizontal(),minRotation:e.minRotation||0,includeBounds:!1!==e.includeBounds},this._range||this);return"ticks"===A.bounds&&af(n,this,"value"),A.reverse?(n.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),n}configure(){const A=this.ticks;let e=this.min,t=this.max;if(super.configure(),this.options.offset&&A.length){const n=(t-e)/Math.max(A.length-1,1)/2;e-=n,t+=n}this._startValue=e,this._endValue=t,this._valueRange=t-e}getLabelForValue(A){return _f(A,this.chart.options.locale,this.options.ticks.format)}}class Hd extends Xd{static id="linear";static defaults={ticks:{callback:ev.formatters.numeric}};determineDataLimits(){const{min:A,max:e}=this.getMinMax(!0);this.min=Oz(A)?A:0,this.max=Oz(e)?e:1,this.handleTickRangeOptions()}computeTickLimit(){const A=this.isHorizontal(),e=A?this.width:this.height,t=wf(this.options.ticks.minRotation),n=(A?Math.sin(t):Math.cos(t))||.001,r=this._resolveTickFontOptions(0);return Math.ceil(e/Math.min(40,r.lineHeight/n))}getPixelForValue(A){return null===A?NaN:this.getPixelForDecimal((A-this._startValue)/this._valueRange)}getValueForPixel(A){return this._startValue+this.getDecimalForPixel(A)*this._valueRange}}const Wd=A=>Math.floor(nf(A)),Bd=(A,e)=>Math.pow(10,Wd(A)+e);function Od(A){return 1===A/Math.pow(10,Wd(A))}function pd(A,e,t){const n=Math.pow(10,t),r=Math.floor(A/n);return Math.ceil(e/n)-r}function Zd(A,e){let t=Wd(e-A);for(;pd(A,e,t)>10;)t++;for(;pd(A,e,t)<10;)t--;return Math.min(t,Wd(A))}function yd(A,{min:e,max:t}){e=pz(A.min,e);const n=[],r=Wd(e);let P=Zd(e,t),z=P<0?Math.pow(10,Math.abs(P)):1;const f=Math.pow(10,P),v=r>P?Math.pow(10,r):0,s=Math.round((e-v)*z)/z,a=Math.floor((e-v)/f/10)*f*10;let w=Math.floor((s-a)/Math.pow(10,P)),D=pz(A.min,Math.round((v+a+w*Math.pow(10,P))*z)/z);for(;D=10?w=w<15?15:20:w++,w>=20&&(P++,w=2,z=P>=0?1:z),D=Math.round((v+a+w*Math.pow(10,P))*z)/z;const c=pz(A.max,D);return n.push({value:c,major:Od(c),significand:w}),n}class Gd extends cD{static id="logarithmic";static defaults={ticks:{callback:ev.formatters.logarithmic,major:{enabled:!0}}};constructor(A){super(A),this.start=void 0,this.end=void 0,this._startValue=void 0,this._valueRange=0}parse(A,e){const t=Xd.prototype.parse.apply(this,[A,e]);if(0!==t)return Oz(t)&&t>0?t:null;this._zero=!0}determineDataLimits(){const{min:A,max:e}=this.getMinMax(!0);this.min=Oz(A)?Math.max(0,A):null,this.max=Oz(e)?Math.max(0,e):null,this.options.beginAtZero&&(this._zero=!0),this._zero&&this.min!==this._suggestedMin&&!Oz(this._userMin)&&(this.min=A===Bd(this.min,0)?Bd(this.min,-1):Bd(this.min,0)),this.handleTickRangeOptions()}handleTickRangeOptions(){const{minDefined:A,maxDefined:e}=this.getUserBounds();let t=this.min,n=this.max;const r=e=>t=A?t:e,P=A=>n=e?n:A;t===n&&(t<=0?(r(1),P(10)):(r(Bd(t,-1)),P(Bd(n,1)))),t<=0&&r(Bd(n,-1)),n<=0&&P(Bd(t,1)),this.min=t,this.max=n}buildTicks(){const A=this.options,e=yd({min:this._userMin,max:this._userMax},this);return"ticks"===A.bounds&&af(e,this,"value"),A.reverse?(e.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),e}getLabelForValue(A){return void 0===A?"0":_f(A,this.chart.options.locale,this.options.ticks.format)}configure(){const A=this.min;super.configure(),this._startValue=nf(A),this._valueRange=nf(this.max)-nf(A)}getPixelForValue(A){return void 0!==A&&0!==A||(A=this.min),null===A||isNaN(A)?NaN:this.getPixelForDecimal(A===this.min?0:(nf(A)-this._startValue)/this._valueRange)}getValueForPixel(A){const e=this.getDecimalForPixel(A);return Math.pow(10,this._startValue+e*this._valueRange)}}function md(A){const e=A.ticks;if(e.display&&A.display){const A=Yv(e.backdropPadding);return Zz(e.font&&e.font.size,vv.font.size)+A.height}return 0}function Ld(A,e,t){return t=Wz(t)?t:[t],{w:wv(A,e.string,t),h:t.length*e.lineHeight}}function Yd(A,e,t,n,r){return A===n||A===r?{start:e-t/2,end:e+t/2}:Ar?{start:e-t,end:e}:{start:e,end:e+t}}function od(A){const e={l:A.left+A._padding.left,r:A.right-A._padding.right,t:A.top+A._padding.top,b:A.bottom-A._padding.bottom},t=Object.assign({},e),n=[],r=[],P=A._pointLabels.length,z=A.options.pointLabels,f=z.centerPointLabels?Rz/P:0;for(let v=0;ve.r&&(f=(n.end-e.r)/P,A.r=Math.max(A.r,e.r+f)),r.starte.b&&(v=(r.end-e.b)/z,A.b=Math.max(A.b,e.b+v))}function id(A,e,t){const n=A.drawingArea,{extra:r,additionalAngle:P,padding:z,size:f}=t,v=A.getPointPosition(e,n+r+z,P),s=Math.round(Df(gf(v.angle+Af))),a=hd(v.y,f.h,s),w=Cd(s),D=Vd(v.x,f.w,w);return{visible:!0,x:v.x,y:a,textAlign:w,left:D,top:a,right:D+f.w,bottom:a+f.h}}function Qd(A,e){if(!e)return!0;const{left:t,top:n,right:r,bottom:P}=A;return!(Mv({x:t,y:n},e)||Mv({x:t,y:P},e)||Mv({x:r,y:n},e)||Mv({x:r,y:P},e))}function Td(A,e,t){const n=[],r=A._pointLabels.length,P=A.options,{centerPointLabels:z,display:f}=P.pointLabels,v={extra:md(P)/2,additionalAngle:z?Rz/r:0};let s;for(let P=0;P270||t<90)&&(A-=e),A}function qd(A,e,t){const{left:n,top:r,right:P,bottom:z}=t,{backdropColor:f}=e;if(!Hz(f)){const t=Lv(e.borderRadius),v=Yv(e.backdropPadding);A.fillStyle=f;const s=n-v.left,a=r-v.top,w=P-n+v.width,D=z-r+v.height;Object.values(t).some((A=>0!==A))?(A.beginPath(),Bv(A,{x:s,y:a,w:w,h:D,radius:t}),A.fill()):A.fillRect(s,a,w,D)}}function Id(A,e){const{ctx:t,options:{pointLabels:n}}=A;for(let r=e-1;r>=0;r--){const e=A._pointLabelItems[r];if(!e.visible)continue;const P=n.setContext(A.getPointLabelContext(r));qd(t,P,e);const z=ov(P.font),{x:f,y:v,textAlign:s}=e;Wv(t,A._pointLabels[r],f,v+z.lineHeight/2,z,{color:P.color,textAlign:s,textBaseline:"middle"})}}function kd(A,e,t,n){const{ctx:r}=A;if(t)r.arc(A.xCenter,A.yCenter,e,0,Jz);else{let t=A.getPointPosition(0,e);r.moveTo(t.x,t.y);for(let P=1;PA,padding:5,centerPointLabels:!1}};static defaultRoutes={"angleLines.color":"borderColor","pointLabels.color":"color","ticks.color":"color"};static descriptors={angleLines:{_fallback:"grid"}};constructor(A){super(A),this.xCenter=void 0,this.yCenter=void 0,this.drawingArea=void 0,this._pointLabels=[],this._pointLabelItems=[]}setDimensions(){const A=this._padding=Yv(md(this.options)/2),e=this.width=this.maxWidth-A.width,t=this.height=this.maxHeight-A.height;this.xCenter=Math.floor(this.left+e/2+A.left),this.yCenter=Math.floor(this.top+t/2+A.top),this.drawingArea=Math.floor(Math.min(e,t)/2)}determineDataLimits(){const{min:A,max:e}=this.getMinMax(!1);this.min=Oz(A)&&!isNaN(A)?A:0,this.max=Oz(e)&&!isNaN(e)?e:0,this.handleTickRangeOptions()}computeTickLimit(){return Math.ceil(this.drawingArea/md(this.options))}generateTickLabels(A){Xd.prototype.generateTickLabels.call(this,A),this._pointLabels=this.getLabels().map(((A,e)=>{const t=mz(this.options.pointLabels.callback,[A,e],this);return t||0===t?t:""})).filter(((A,e)=>this.chart.getDataVisibility(e)))}fit(){const A=this.options;A.display&&A.pointLabels.display?od(this):this.setCenterPoint(0,0,0,0)}setCenterPoint(A,e,t,n){this.xCenter+=Math.floor((A-e)/2),this.yCenter+=Math.floor((t-n)/2),this.drawingArea-=Math.min(this.drawingArea/2,Math.max(A,e,t,n))}getIndexAngle(A){return gf(A*(Jz/(this._pointLabels.length||1))+wf(this.options.startAngle||0))}getDistanceFromCenterForValue(A){if(Hz(A))return NaN;const e=this.drawingArea/(this.max-this.min);return this.options.reverse?(this.max-A)*e:(A-this.min)*e}getValueForDistanceFromCenter(A){if(Hz(A))return NaN;const e=A/(this.drawingArea/(this.max-this.min));return this.options.reverse?this.max-e:this.min+e}getPointLabelContext(A){const e=this._pointLabels||[];if(A>=0&&A{if(0!==e||0===e&&this.min<0){f=this.getDistanceFromCenterForValue(A.value);const t=this.getContext(e),z=n.setContext(t),v=r.setContext(t);Kd(this,z,f,P,v)}})),t.display){for(A.save(),z=P-1;z>=0;z--){const n=t.setContext(this.getPointLabelContext(z)),{color:r,lineWidth:P}=n;P&&r&&(A.lineWidth=P,A.strokeStyle=r,A.setLineDash(n.borderDash),A.lineDashOffset=n.borderDashOffset,f=this.getDistanceFromCenterForValue(e.reverse?this.min:this.max),v=this.getPointPosition(z,f),A.beginPath(),A.moveTo(this.xCenter,this.yCenter),A.lineTo(v.x,v.y),A.stroke())}A.restore()}}drawBorder(){}drawLabels(){const A=this.ctx,e=this.options,t=e.ticks;if(!t.display)return;const n=this.getIndexAngle(0);let r,P;A.save(),A.translate(this.xCenter,this.yCenter),A.rotate(n),A.textAlign="center",A.textBaseline="middle",this.ticks.forEach(((n,z)=>{if(0===z&&this.min>=0&&!e.reverse)return;const f=t.setContext(this.getContext(z)),v=ov(f.font);if(r=this.getDistanceFromCenterForValue(this.ticks[z].value),f.showLabelBackdrop){A.font=v.string,P=A.measureText(n.label).width,A.fillStyle=f.backdropColor;const e=Yv(f.backdropPadding);A.fillRect(-P/2-e.left,-r-v.size/2-e.top,P+e.width,v.size+e.height)}Wv(A,n.label,0,-r,v,{color:f.color,strokeColor:f.textStrokeColor,strokeWidth:f.textStrokeWidth})})),A.restore()}drawTitle(){}}const Ed={millisecond:{common:!0,size:1,steps:1e3},second:{common:!0,size:1e3,steps:60},minute:{common:!0,size:6e4,steps:60},hour:{common:!0,size:36e5,steps:24},day:{common:!0,size:864e5,steps:30},week:{common:!1,size:6048e5,steps:4},month:{common:!0,size:2628e6,steps:12},quarter:{common:!1,size:7884e6,steps:4},year:{common:!0,size:3154e7}},Rd=Object.keys(Ed);function Jd(A,e){return A-e}function Fd(A,e){if(Hz(e))return null;const t=A._adapter,{parser:n,round:r,isoWeekday:P}=A._parseOpts;let z=e;return"function"==typeof n&&(z=n(z)),Oz(z)||(z="string"==typeof n?t.parse(z,n):t.parse(z)),null===z?null:(r&&(z="week"!==r||!vf(P)&&!0!==P?t.startOf(z,r):t.startOf(z,"isoWeek",P)),+z)}function _d(A,e,t,n){const r=Rd.length;for(let P=Rd.indexOf(A);P=Rd.indexOf(t);P--){const t=Rd[P];if(Ed[t].common&&A._adapter.diff(r,n,t)>=e-1)return t}return Rd[t?Rd.indexOf(t):0]}function AM(A){for(let e=Rd.indexOf(A)+1,t=Rd.length;e=e?t[n]:t[r]]=!0}}else A[e]=!0}function tM(A,e,t,n){const r=A._adapter,P=+r.startOf(e[0].value,n),z=e[e.length-1].value;let f,v;for(f=P;f<=z;f=+r.add(f,1,n))v=t[f],v>=0&&(e[v].major=!0);return e}function nM(A,e,t){const n=[],r={},P=e.length;let z,f;for(z=0;z+A.value)))}initOffsets(A=[]){let e,t,n=0,r=0;this.options.offset&&A.length&&(e=this.getDecimalForValue(A[0]),n=1===A.length?1-e:(this.getDecimalForValue(A[1])-e)/2,t=this.getDecimalForValue(A[A.length-1]),r=1===A.length?t:(t-this.getDecimalForValue(A[A.length-2]))/2);const P=A.length<3?.5:.25;n=jf(n,0,P),r=jf(r,0,P),this._offsets={start:n,end:r,factor:1/(n+1+r)}}_generate(){const A=this._adapter,e=this.min,t=this.max,n=this.options,r=n.time,P=r.unit||_d(r.minUnit,e,t,this._getLabelCapacity(e)),z=Zz(n.ticks.stepSize,1),f="week"===P&&r.isoWeekday,v=vf(f)||!0===f,s={};let a,w,D=e;if(v&&(D=+A.startOf(D,"isoWeek",f)),D=+A.startOf(D,v?"day":P),A.diff(t,e,P)>1e5*z)throw new Error(e+" and "+t+" are too far apart with stepSize of "+z+" "+P);const c="data"===n.ticks.source&&this.getDataTimestamps();for(a=D,w=0;a+A))}getLabelForValue(A){const e=this._adapter,t=this.options.time;return t.tooltipFormat?e.format(A,t.tooltipFormat):e.format(A,t.displayFormats.datetime)}format(A,e){const t=this.options.time.displayFormats,n=this._unit,r=e||t[n];return this._adapter.format(A,r)}_tickFormatFunction(A,e,t,n){const r=this.options,P=r.ticks.callback;if(P)return mz(P,[A,e,t],this);const z=r.time.displayFormats,f=this._unit,v=this._majorUnit,s=f&&z[f],a=v&&z[v],w=t[e],D=v&&a&&w&&w.major;return this._adapter.format(A,n||(D?a:s))}generateTickLabels(A){let e,t,n;for(e=0,t=A.length;e0?z:1}getDataTimestamps(){let A,e,t=this._cache.data||[];if(t.length)return t;const n=this.getMatchingVisibleMetas();if(this._normalized&&n.length)return this._cache.data=n[0].controller.getAllParsedValues(this);for(A=0,e=n.length;A=A[f].pos&&e<=A[v].pos&&({lo:f,hi:v}=Hf(A,"pos",e)),({pos:n,time:P}=A[f]),({pos:r,time:z}=A[v])):(e>=A[f].time&&e<=A[v].time&&({lo:f,hi:v}=Hf(A,"time",e)),({time:n,pos:P}=A[f]),({time:r,pos:z}=A[v]));const s=r-n;return s?P+(z-P)*(e-n)/s:P}class zM extends rM{static id="timeseries";static defaults=rM.defaults;constructor(A){super(A),this._table=[],this._minPos=void 0,this._tableRange=void 0}initOffsets(){const A=this._getTimestampsForTable(),e=this._table=this.buildLookupTable(A);this._minPos=PM(e,this.min),this._tableRange=PM(e,this.max)-this._minPos,super.initOffsets(A)}buildLookupTable(A){const{min:e,max:t}=this,n=[],r=[];let P,z,f,v,s;for(P=0,z=A.length;P=e&&v<=t&&n.push(v);if(n.length<2)return[{time:e,pos:0},{time:t,pos:1}];for(P=0,z=n.length;PA-e))}_getTimestampsForTable(){let A=this._cache.all||[];if(A.length)return A;const e=this.getDataTimestamps(),t=this.getLabelTimestamps();return A=e.length&&t.length?this.normalize(e.concat(t)):e.length?e:t,A=this._cache.all=A,A}getDecimalForValue(A){return(PM(this._table,A)-this._minPos)/this._tableRange}getValueForPixel(A){const e=this._offsets,t=this.getDecimalForPixel(A)/e.factor-e.end;return PM(this._table,t*this._tableRange+this._minPos,!0)}}var fM=Object.freeze({__proto__:null,CategoryScale:jd,LinearScale:Hd,LogarithmicScale:Gd,RadialLinearScale:Sd,TimeScale:rM,TimeSeriesScale:zM});const vM=[Ea,Cc,ld,fM];rc.register(...vM);let sM=class extends aA{constructor(){super(...arguments),this.moonChart=null}static get styles(){return[f` + .moon-horizon { + display: flex; + position: relative; + margin: 0; + width: 100%; + height: 100%; + box-shadow: 0 0 6px #00000082; + max-width: 500px; + backdrop-filter: blur(4px); + border-radius: 4px; + border: 1px solid var(--divider-color); + box-sizing: border-box; + padding: 4px; + } + .moon-horizon canvas { + width: 100%; + height: 100%; + } + `,pP]}connectedCallback(){super.connectedCallback(),window.MoonCard=this}get todayData(){return this.moon._getAltitudeToday()}firstUpdated(){this.initChart()}initChart(){var A;const e={pointRadius:2,pointHoverRadius:5,pointHoverBackgroundColor:"#fff",pointHoverBorderWidth:4},t={color:"rgba(255, 255, 255, 0.5)"},n=[],r=new Date,P=new Date(r.setHours(0,0,0,0));for(let A=0;A<24;A++){const e=new Date(P.getTime()+60*A*60*1e3);n.push(e.toLocaleString("en-US",{hour:"numeric",minute:"numeric",hour12:!1}))}const z=this.todayData,f=Object.values(z.altitude),v=this._getPosition(new Date,f),s=new Date(z.time.set),a=this._getPosition(new Date(z.time.set),f),w=new Date(z.time.rise),D=this._getPosition(new Date(z.time.rise),f),c=new Date;c.setHours(0,0,0,0);const l=new Date;l.setHours(23,59,59,999);const d=s>c&&sc&&w + + + `}};A([MA()],sM.prototype,"moon",void 0),A([MA()],sM.prototype,"moonChart",void 0),A([MA()],sM.prototype,"cardWidth",void 0),sM=A([DA("moon-horizon")],sM);let aM=class extends aA{constructor(){super(...arguments),this._activeCard="base",this._connected=!1,this._cardWidth=0,this.localize=(A,e="",t="")=>nt(A,this.selectedLanguage,e,t),this.togglePage=A=>{this._activeCard=this._activeCard===A?"base":A}}static async getConfigElement(){return await Promise.resolve().then((function(){return xM})),document.createElement("lunar-phase-card-editor")}set hass(A){this._hass=A}async setConfig(A){if(!A)throw new Error("Invalid configuration");this.config=Object.assign({},A)}getGridRowSize(){let A=2;return this.config.compact_view||(A+=2),"calendar"===this._activeCard&&(A+=6),A}getLayoutOptions(){return{grid_min_rows:this.getGridRowSize(),grid_max_rows:8,grid_columns:4,grid_min_columns:4}}getCardSize(){return 5}connectedCallback(){super.connectedCallback(),this._connected=!0,this.startRefreshInterval()}disconnectedCallback(){this.clearRefreshInterval(),this._connected=!1,super.disconnectedCallback()}firstUpdated(A){super.firstUpdated(A),this.measureCard()}shouldUpdate(A){return A.has("_activeCard")&&"base"!==this._activeCard?this.clearRefreshInterval():(A.has("_activeCard")&&"base"===this._activeCard||"horizon"===this._activeCard)&&void 0!==this.selectedDate&&(this.selectedDate=void 0,this.startRefreshInterval()),A.has("_activeCard")||A.has("selectedDate")&&void 0!==this.selectedDate}get hass(){return this._hass}get selectedLanguage(){var A;return(null===(A=this.config)||void 0===A?void 0:A.selected_language)||this._hass.language}get _isCalendar(){return"calendar"===this._activeCard}get _showBackground(){return this.config.show_background||!1}get _date(){return this.selectedDate?new Date(this.selectedDate):new Date}startRefreshInterval(){void 0!==this._refreshInterval&&clearInterval(this._refreshInterval),this._refreshInterval=window.setInterval((()=>{"base"===this._activeCard?this.requestUpdate():this.clearRefreshInterval()}),LA)}clearRefreshInterval(){this._refreshInterval&&(clearInterval(this._refreshInterval),this._refreshInterval=void 0)}render(){if(!this._hass||!this.config)return U``;this.createMoon();const A=this.config.compact_view&&"calendar"!==this._activeCard&&"horizon"!==this._activeCard?E:this.renderHeader();return U` + + ${A} +
${this._renderPage()}
+
+ `}_renderPage(){const A=U` ${this.renderMoonImage()} ${this.renderMoonData()} `;switch(this._activeCard){case"calendar":return this.renderCalendar();case"horizon":return this.renderHorizon();default:return A}}createMoon(){const A={date:this._date,lang:this.selectedLanguage,config:this.config};this.moon=new jn(A)}renderHeader(){var A,e;const t={calendar:null===(A=this.moon)||void 0===A?void 0:A.phaseName,base:null===(e=this.moon)||void 0===e?void 0:e.phaseName,horizon:"Today's Moon Horizon"};return U` +
+

${t[this._activeCard]}

+
+
this.togglePage("calendar")} + class="btn-action click-shrink" + ?active=${"calendar"===this._activeCard} + > + +
+
this.togglePage("horizon")} + class="btn-action click-shrink" + ?active=${"horizon"===this._activeCard} + > + +
+
+
+ `}renderMoonImage(){if(!this.moon)return;const{moonPic:A}=this.moon.moonImage;return U`
+ +
`}renderMoonData(){const A=this.config.compact_view&&"base"===this._activeCard;return U` + ${A?this.renderCompactView():U``} + `}renderCompactView(){if(!this.config.compact_view)return E;const A=this.moon.moonData,e={moonAge:"mdi:progress-clock",moonRise:"mdi:weather-moonset-up",moonSet:"mdi:weather-moonset"},t=t=>{var n;const{label:r,value:P}=A[t];return U` +
+
+ + ${P} +
+ ${(null===(n=this.config.font_customize)||void 0===n?void 0:n.hide_label)?U``:U` ${r}`} +
+ `};return U` +
+ ${this.renderHeader()} + +
${A.moonFraction.value} ${this.localize("card.illuminated")}
+
${Object.keys(e).map((A=>t(A)))}
+
+ `}renderCalendar(){const A=this._date.toISOString().split("T")[0],e=U`
+ + + +
`;return U` + ${this.renderMoonImage()} +
${e}${this.renderMoonData()}
+ `}renderHorizon(){return U``}updateDate(A){const e=new Date(this._date);"next"===A?e.setDate(e.getDate()+1):"prev"===A&&e.setDate(e.getDate()-1),this.selectedDate=e}_handleDateChange(A){const e=A.target;e.value||(e.value=(new Date).toISOString().split("T")[0]),this.selectedDate=new Date(e.value)}measureCard(){var A;const e=null===(A=this.shadowRoot)||void 0===A?void 0:A.querySelector("ha-card");e&&(this._cardWidth=e.clientWidth)}_computeClasses(){const A="right"===this.config.moon_position,e=Boolean(this.config.compact_view&&"base"===this._activeCard);return XA({__background:this._showBackground,"__flex-col":this._isCalendar,__reverse:A&&!this._isCalendar,"__compact-header":e})}_computeStyles(){var A;const e=null===(A=this.config)||void 0===A?void 0:A.font_customize,t=this.config.custom_background||YA,n={"--lunar-card-header-font-size":e.header_font_size,"--lunar-card-header-text-transform":e.header_font_style,"--lunar-card-header-font-color":e.header_font_color?e.header_font_color:this._showBackground?"#e1e1e1":"var(--primary-text-color)","--lunar-card-label-font-size":e.label_font_size,"--lunar-card-label-text-transform":e.label_font_style,"--lunar-card-label-font-color":e.label_font_color?e.label_font_color:this._showBackground?"#e1e1e1":"var(--primary-text-color)","--swiper-theme-color":"var(--lunar-card-label-font-color, var(--primary-color))"};return BA(Object.assign({"--lunar-background-image":`url(${t})`},n))}static get styles(){return[pP]}};var wM,DM;aM.getStubConfig=A=>{const e=A.config.latitude||0,t=A.config.longitude||0,n=A.language;return Object.assign(Object.assign({},OA),{latitude:e,longitude:t,selected_language:n})},A([dA({attribute:!1})],aM.prototype,"hass",null),A([MA()],aM.prototype,"_hass",void 0),A([MA()],aM.prototype,"config",void 0),A([dA({type:Object})],aM.prototype,"moon",void 0),A([MA()],aM.prototype,"_activeCard",void 0),A([MA()],aM.prototype,"selectedDate",void 0),A([MA()],aM.prototype,"_connected",void 0),A([MA()],aM.prototype,"_refreshInterval",void 0),A([MA()],aM.prototype,"_cardWidth",void 0),A([uA("lunar-base-data")],aM.prototype,"_data",void 0),aM=A([DA("lunar-phase-card")],aM),window.customCards=window.customCards||[],window.customCards.push({type:"lunar-phase-card",name:"Lunar Phase Card",preview:!0,description:"A custom card to display the current lunar phase."}),function(A){A.language="language",A.system="system",A.comma_decimal="comma_decimal",A.decimal_comma="decimal_comma",A.space_comma="space_comma",A.none="none"}(wM||(wM={})),function(A){A.language="language",A.system="system",A.am_pm="12",A.twenty_four="24"}(DM||(DM={}));var cM=function(A,e,t,n){n=n||{},t=null==t?{}:t;var r=new Event(e,{bubbles:void 0===n.bubbles||n.bubbles,cancelable:Boolean(n.cancelable),composed:void 0===n.composed||n.composed});return r.detail=t,A.dispatchEvent(r),r};const lM=()=>{var A,e,t,n;customElements.get("ha-form")||null===(A=customElements.get("hui-button-card"))||void 0===A||A.getConfigElement(),customElements.get("ha-entity-picker")||null===(e=customElements.get("hui-entities-card"))||void 0===e||e.getConfigElement(),customElements.get("ha-card-conditions-editor")||null===(t=customElements.get("hui-conditional-card"))||void 0===t||t.getConfigElement(),customElements.get("ha-form-multi_select")||null===(n=customElements.get("hui-entities-card"))||void 0===n||n.getConfigElement()},dM=()=>{var A,e;const t=null===(A=document.querySelector("body > home-assistant"))||void 0===A?void 0:A.shadowRoot,n=null===(e=null==t?void 0:t.querySelector("hui-dialog-edit-card"))||void 0===e?void 0:e.shadowRoot,r=null==n?void 0:n.querySelector("ha-dialog > div.content > div.element-preview");r&&"sticky"!==r.style.position&&(r.style.position="sticky",r.style.top="0")};async function MM(){const A=`https://api.github.com/repos/${GA}/releases/latest`;try{const e=await fetch(A);if(e.ok){const A=await e.json();return A.tag_name}}catch(A){}}function gM(A,e){for(const t of Object.keys(e))e[t]instanceof Object&&t in A?A[t]=gM(A[t],e[t]):A[t]=e[t];return A}function uM(){return{type:"custom:lunar-phase-card",entity:"",use_default:!0,use_custom:!1,use_entity:!1,show_background:!0,selected_language:"en",compact_view:!0,"12hr_format":!1,font_customize:{header_font_size:"x-large",header_font_style:"capitalize",header_font_color:"",label_font_size:"auto",label_font_style:"none",label_font_color:"",hide_label:!1}}}var jM=f`.card-config { + width: 100%; + display: flex; + gap: 12px; + flex-direction: column; + border: 1px solid rgba(0, 0, 0, 0.87); + border: 1px solid var(--divider-color, rgba(0, 0, 0, 0.87)); + justify-content: space-evenly; + margin: 0; + box-sizing: border-box; + padding: 8px; +} + +.header-container { + flex: 1 1 0%; + display: flex; + border-bottom: inherit; + min-height: 48px; + align-items: center; + cursor: pointer; + overflow: hidden; + font-weight: 500; + outline: 0px; +} + +.header-title { + flex: 1 1 0%; + display: flex; + flex-direction: column; +} + +.header-title>span.secondary { + display: block; + color: var(--secondary-text-color); + font-size: 12px; +} + +.switches { + display: flex; +} + +ha-textfield { + display: block; + width: 100%; +} + + +ha-select { + width: 100%; +} + + +.font-config-content { + display: grid; + grid-gap: 8px; + grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); + align-items: center; +} + +.font-config-type { + color: var(--secondary-text-color); + display: flex; + padding: 8px; + justify-content: space-between; + align-items: center; +} + +.font-config-type .title { + font-weight: 500; + text-transform: uppercase; +} + +.font-config-type .desc { + font-weight: 400; +} + +.right-icon { + padding-left: 0.5rem; + padding-right: 0.5rem; + cursor: pointer; +} + +.custom-background-wrapper { + display: inline-flex; + align-items: center; + gap: 1rem; + text-wrap: nowrap; +} + +.file-input { + display: none; +} + +.file-upload { + cursor: pointer; + display: inline-block; + padding: 0.5rem 1rem; + border: 1px solid var(--divider-color); + border-radius: 8px; + color: var(--primary-text-color); +} + +.file-upload:hover { + background-color: var(--primary-color); +} + +.radios-btn { + display: flex; + align-items: center; + justify-content: space-between; +} + +.version { + color: var(--secondary-text-color); + justify-content: space-around; + align-items: stretch; + display: flex; + flex-direction: column; + gap: 8px; + position: absolute; + bottom: auto; +} + +.version .update { + color: var(--accent-color); + opacity: 0.7; +} + +#toast { + visibility: hidden; + opacity: 0; + max-height: 0; +} + +#toast.show { + visibility: visible; + opacity: 1; + max-height: 100px; + animation: fadeIn 0.3s ease-in-out forwards; + display: flex; + justify-content: center; + align-items: center; +} + +ha-alert { + width: 100%; +} + +ha-alert>.alert-icon { + display: flex; + height: 100%; + align-items: center; + justify-content: center; + padding-left: 0.5rem; + padding-right: 0.5rem; +}`;OP(jM);let bM=class extends aA{constructor(){var A;super(...arguments),this._latestRelease="",this._activeTabIndex=0,this._systemLanguage=null===(A=this.hass)||void 0===A?void 0:A.language,this.localize=(A,e="",t="")=>nt(A,this.selectedLanguage,e,t),this.TabBar=({activeTabIndex:A,onTabChange:e,tabs:t})=>{var n;return U` + e(A.target.activeIndex)}> + ${t.map((A=>U``))} + + +
${(null===(n=t[A])||void 0===n?void 0:n.content)||U`
No content available
`}
+
+ ${mA===this._latestRelease?U`version: ${mA}`:U`version: ${mA} -> ${this._latestRelease}`} +
+ ${this._renderToast()} + `},this._haComboBox=(A,e,t,n,r=!0)=>U` + + `,this._tempCheckBox=(A,e,t)=>{var n;return U` + + `}}async setConfig(A){this._config=gM(uM(),A)}firstUpdated(A){super.firstUpdated(A)}get selectedLanguage(){var A;return(null===(A=this._config)||void 0===A?void 0:A.selected_language)||"en"}update(A){var e,t,n;if(super.update(A),A.has("_latestRelease")&&""!==this._latestRelease){const A=this._compareVersions(),n=null===(e=this.shadowRoot)||void 0===e?void 0:e.getElementById("toast"),r=null===(t=this.shadowRoot)||void 0===t?void 0:t.querySelector(".version");(n||r)&&(0!==A?(n.classList.add("show"),r.style.display="none"):r.style.display="flex")}this._systemLanguage=null===(n=this.hass)||void 0===n?void 0:n.language}connectedCallback(){super.connectedCallback(),lM(),dM(),MM().then((A=>{this._latestRelease=A}))}disconnectedCallback(){super.disconnectedCallback()}render(){if(!this.hass)return U``;const A=[{key:"baseConfig",label:"Lat & Long",content:this._renderBaseConfigSelector()},{key:"viewConfig",label:"View",content:this._renderViewConfiguration()},{key:"fontOptions",label:"Font",content:this._renderFontConfiguration()}];return this.TabBar({activeTabIndex:this._activeTabIndex,onTabChange:A=>this._activeTabIndex=A,tabs:A})}_renderBaseConfigSelector(){var A,e,t;const n=this._getBaseConfigSelector().options.map((A=>U` + + + + `)),r=U` +
${n}
+
+ ${(null===(A=this._config)||void 0===A?void 0:A.use_default)?this._renderUseDefault():(null===(e=this._config)||void 0===e?void 0:e.use_custom)?this._renderCustomLatLong():(null===(t=this._config)||void 0===t?void 0:t.use_entity)?this._renderEntityPicker():""} +
+ `;return this.contentTemplate("baseConfig","baseConfig","mdi:cog",r)}_renderUseDefault(){var A,e;const t=[{label:"Latitude",value:null===(A=this._config)||void 0===A?void 0:A.latitude},{label:"Longitude",value:null===(e=this._config)||void 0===e?void 0:e.longitude}];return U`
+ ${t.map((A=>U` `))} +
`}_renderCustomLatLong(){const A=[{label:this.localize("editor.placeHolder.latitude"),configKey:"latitude"},{label:this.localize("editor.placeHolder.longitude"),configKey:"longitude"}];return U`
+ ${A.map((A=>{var e;return U` + + `}))} +
`}_renderEntityPicker(){var A,e;const t=[...Object.keys(this.hass.states).filter((A=>A.startsWith("sensor")&&A.endsWith("_moon_phase"))).filter((A=>A.startsWith("sensor")&&!A.endsWith("next_moon_phase"))),"separator",...Object.keys(this.hass.states).filter((A=>this.hass.states[A].attributes.latitude&&this.hass.states[A].attributes.longitude))],n=U` + + `,r=!!(null===(e=this._config)||void 0===e?void 0:e.entity),P=this._getEntityLatLong(),z=U`
+ ${P.map((A=>U` `))} +
`;return U` ${n} ${r?z:""} `}_renderViewConfiguration(){var A,e,t,n;const r=[{key:"system",name:"System",nativeName:this._systemLanguage},...tt.sort(((A,e)=>A.name.localeCompare(e.name)))],P=r.map((A=>({value:A.key,label:`${A.name} (${A.nativeName})`}))),z=U` +
+ ${[{label:"compactView",configValue:"compact_view"},{label:"showBackground",configValue:"show_background"},{label:"timeFormat",configValue:"12hr_format"}].map((A=>this._tempCheckBox(A.label,A.configValue,A.configValue)))} +
+ `,f=U` + ${this._haComboBox(P,"placeHolder.language",(null===(A=this._config)||void 0===A?void 0:A.selected_language)||"","selected_language",!1)} + `,v=this._haComboBox([{value:"left",label:"Left"},{value:"right",label:"Right"}],"placeHolder.moonPosition",(null===(e=this._config)||void 0===e?void 0:e.moon_position)||"left","moon_position",!1),s=U` +
+ + ${(null===(n=this._config)||void 0===n?void 0:n.custom_background)?U` +
+ +
+ `:U` + {var A,e;return null===(e=null===(A=this.shadowRoot)||void 0===A?void 0:A.getElementById("file-upload-new"))||void 0===e?void 0:e.click()}}> + Upload + + + `} +
+ `,a=U` ${z} ${f} ${v} ${s} `;return this.contentTemplate("viewConfig","viewConfig","mdi:image",a)}_renderFontConfiguration(){var A;const e="fontOptions",t=A=>this.localize(`editor.${e}.${A}`),n=A=>{const t=(t,n=!0)=>{var r,P;const z=`${A}_font_${t}`,f=null!==(P=null===(r=this._config)||void 0===r?void 0:r.font_customize)&&void 0!==P?P:OA.font_customize,v="color"===t?iA.map((A=>({value:A,label:A}))):"size"===t?oA.map((A=>({value:A,label:A}))):NA.map((A=>({value:A,label:A})));return this._haComboBox(v,`${e}.${A}Font${t.charAt(0).toUpperCase()+t.slice(1)}`,f[z]||("size"===t?"auto":"style"===t?"none":""),z,n)};return U` ${t("size")} ${t("style",!1)} ${t("color")} `},r=(null===(A=this._config)||void 0===A?void 0:A.compact_view)?this._tempCheckBox("fontOptions.hideLabel","font_customize.hide_label","hide_label"):"";return this.contentTemplate("fontOptions","fontOptions","mdi:format-font",U` +
+
+ ${t("headerFontConfig.title")} + ${t("headerFontConfig.description")} +
+
${n("header")}
+
+ +
+
+ ${t("labelFontConfig.title")} + ${t("labelFontConfig.description")} +
+
${n("label")} ${r}
+
+ `)}contentTemplate(A,e,t,n){const r=this.localize(`editor.${A}.title`),P=this.localize(`editor.${e}.description`);return U` +
+
+
+
${r}
+ ${P} +
+ +
+ ${n} +
+ `}_renderToast(){const A=this._compareVersions();if(0===A)return U``;const e={"-1":{title:"New version available",icon:"🎉"},1:{title:"You are using a beta version",icon:"🚨"}};return U` +
+ + ${e[A].icon} + Latest: ${this._latestRelease} + +
+ `}_handleValueChange(A){var e;if(!this._config||!this.hass)return;const t=A.target,n=null==t?void 0:t.configValue,r=void 0!==(null==t?void 0:t.checked)?t.checked:A.detail.value,P={},z={header_font_size:"x-large",header_font_style:"capitalize",header_font_color:"",label_font_size:"auto",label_font_style:"none",label_font_color:"",hide_label:!1};if(n in this._config.font_customize){const A=n,e=void 0!==r?r:z[A];P.font_customize=Object.assign(Object.assign({},this._config.font_customize),{[A]:e})}else"selected_language"===n?P.selected_language="system"===r||void 0===r?null===(e=this.hass)||void 0===e?void 0:e.language:r:P[n]=r;Object.keys(P).length>0&&(this._config=Object.assign(Object.assign({},this._config),P),cM(this,"config-changed",{config:this._config}))}_getEntityLatLong(){var A,e,t;if(!(null===(A=this._config)||void 0===A?void 0:A.entity))return[];const n=this.hass.states[this._config.entity];return n&&n.attributes?[{label:"Latitude",value:null!==(e=n.attributes.latitude)&&void 0!==e?e:n.attributes.location.latitude},{label:"Longitude",value:null!==(t=n.attributes.longitude)&&void 0!==t?t:n.attributes.location.longitude}]:[]}_handleRadioChange(A){if(!this._config||!this.hass)return;const e=A.target.value;if(!0===this._config[e])return;const t={};this._getBaseConfigSelector().options.map((A=>A.key)).forEach((A=>{t[A]=A===e})),"use_custom"===e&&(t.entity=""),"use_default"===e&&(t.entity="",t.latitude=this.hass.config.latitude,t.longitude=this.hass.config.longitude),Object.keys(t).length>0&&(this._config=Object.assign(Object.assign({},this._config),t),cM(this,"config-changed",{config:this._config}))}_handleAlertDismissed(){var A,e;const t=null===(A=this.shadowRoot)||void 0===A?void 0:A.getElementById("toast"),n=null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector(".version");(t||n)&&(t.classList.remove("show"),n.style.visibility="visible")}_compareVersions(){return Vt(mA,this._latestRelease)}async _handleFilePicked(A){const e=A.target;if(!e.files||0===e.files.length)return;const t=e.files[0],n=new FormData;n.append("file",t);try{const A=await fetch("/api/image/upload",{method:"POST",body:n,headers:{Authorization:`Bearer ${this.hass.auth.data.access_token}`}});if(!A.ok)throw new Error("Failed to upload image");const e=(await A.json()).id;if(!e)throw new Error("Image ID is missing in the response");const t=`/api/image/serve/${e}/original`;this._config&&(this._config=Object.assign(Object.assign({},this._config),{custom_background:t}),cM(this,"config-changed",{config:this._config}),this.requestUpdate())}catch(A){}}handleRemoveBackground(){this._config&&(this._config=Object.assign(Object.assign({},this._config),{custom_background:void 0}),cM(this,"config-changed",{config:this._config}),this.requestUpdate())}_getBaseConfigSelector(){return{options:[{key:"use_default",label:this.localize("editor.optionsConfig.useDefault")},{key:"use_custom",label:this.localize("editor.optionsConfig.useCustom")},{key:"use_entity",label:this.localize("editor.optionsConfig.useEntity")}]}}_entityChanged(A){var e,t;if(!this._config||!this.hass)return;const n=A.detail.value;if(this._config.entity===n||!n)return;const r=this.hass.states[n].attributes,P={entity:n,latitude:null!==(e=r.latitude)&&void 0!==e?e:r.location.latitude,longitude:null!==(t=r.longitude)&&void 0!==t?t:r.location.longitude};this._config=Object.assign(Object.assign({},this._config),P),cM(this,"config-changed",{config:this._config})}static get styles(){return f` + ${jM} + `}};A([dA({attribute:!1})],bM.prototype,"hass",void 0),A([MA()],bM.prototype,"_config",void 0),A([MA()],bM.prototype,"_latestRelease",void 0),A([MA()],bM.prototype,"_activeTabIndex",void 0),bM=A([DA("lunar-phase-card-editor")],bM);var xM=Object.freeze({__proto__:null,get LunarPhaseCardEditor(){return bM}});export{aM as LunarPhaseCard};