@mxtommy/kip 3.1.7 → 3.2.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +5 -0
- package/package.json +1 -1
- package/public/{chunk-77C4Q6FL.js → chunk-36TH3DJS.js} +1 -1
- package/public/{chunk-4K4AXXSU.js → chunk-AB7BX4CL.js} +1 -1
- package/public/{chunk-Y4F3O2ZU.js → chunk-C3SKHG6H.js} +1 -1
- package/public/{chunk-WRDOUMT5.js → chunk-EAJKXTFC.js} +1 -1
- package/public/chunk-EQ5CPWIU.js +7 -0
- package/public/{chunk-NGNSVXS2.js → chunk-I4I2PP4V.js} +1 -1
- package/public/chunk-KIGTUPYH.js +1 -0
- package/public/{chunk-KLP6YAJZ.js → chunk-LN7UJX74.js} +8 -8
- package/public/{chunk-SVVDCHCH.js → chunk-LXHXBOHL.js} +1 -1
- package/public/{chunk-GQFDVLM2.js → chunk-QMIJ5LO6.js} +1 -1
- package/public/{chunk-UH5I5JPF.js → chunk-R3627Y4G.js} +1 -1
- package/public/{chunk-CEBDBQUK.js → chunk-SHKAX4XV.js} +1 -1
- package/public/{chunk-7DMBDKNL.js → chunk-TFGDG5I5.js} +1 -1
- package/public/{chunk-7YDAKESU.js → chunk-UQ35FIC4.js} +1 -1
- package/public/{chunk-M5RCQLIY.js → chunk-WE4P4WBD.js} +1 -1
- package/public/{chunk-2X76LO7F.js → chunk-YUK2NVZK.js} +1 -1
- package/public/{chunk-RHXDNDPP.js → chunk-YZ6RJSLE.js} +1 -1
- package/public/index.html +1 -1
- package/public/main-T26TGEFK.js +234 -0
- package/public/chunk-23ZXPO62.js +0 -1
- package/public/chunk-D3QHJ7S5.js +0 -7
- package/public/main-KK5SYSZA.js +0 -234
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
import{A as Sd,B as Cd,C as xd,D as ji,E as cn,F as Td,G as Ed,H as Dd,I as Ad,J as Pd,K as Md,L as Od,a as Fi,b as Hi,c as Ui,d as go,e as ln,f as Tr,g as hi,h as Gi,i as Gt,j as vo,k as yo,l as Xn,m as dn,n as bo,o as _o,p as ui,q as Fa,r as wo,s as Er,t as kd,u as Ha,v as Ua,w as Ga,x as ja,y as Kn,z as Dr}from"./chunk-LXHXBOHL.js";import{b as Wd,g as Bd}from"./chunk-OTD7HT32.js";import{a as st,b as pd,c as uo,d as $n,e as Qn,f as fd,g as gd,h as vd}from"./chunk-LN7UJX74.js";import"./chunk-SHKAX4XV.js";import{a as yd,b as bd,c as _d,d as wd,e as po,f as fo}from"./chunk-JZUG3W7P.js";import{a as Yn,b as mo}from"./chunk-AB7BX4CL.js";import{a as Id,b as Rd,c as Nd}from"./chunk-MR7RUNKP.js";import{a as ho}from"./chunk-WE4P4WBD.js";import"./chunk-36TH3DJS.js";import"./chunk-QMIJ5LO6.js";import{a as Wl,b as Bl,c as zl,d as Ll,e as Vl,f as Fl,g as Vn,h as Hl,i as oo,k as Ul,l as Gl,m as jl,n as Yl,o as wi,p as Bt}from"./chunk-6QHCHGTT.js";import{f as hd}from"./chunk-CD375FDG.js";import"./chunk-SGYCFQGT.js";import{a as ti}from"./chunk-KIGTUPYH.js";import{a as md}from"./chunk-7TWI6ZJI.js";import{a as Ln,b as Ml,c as Ol,d as no,f as ro,g as ei,h as xr,i as Fn,j as Wa,k as Wt,l as te,m as Hn,n as _i,o as Un,p as ql,r as Vi,y as ud}from"./chunk-EQ5CPWIU.js";import{$ as Pa,$a as Ei,$b as Nt,$c as to,$d as so,Ac as de,Ae as od,Bb as Ra,Bc as Qe,Be as ad,Cb as le,Cc as kl,Da as yi,Dc as T,Ea as z,Eb as Cr,Ec as lt,Ee as La,Fa as L,Fc as ut,Fd as Il,G as ol,Ga as Dt,Gd as Rl,H as Ea,Ha as cl,Hb as U,Hd as Nl,I as al,Ia as Nn,Ib as Zt,Ic as Ee,J as sl,Jb as bi,Jc as De,K as Mn,Ka as on,Kb as yl,Kc as Ae,Ke as sd,Lb as pe,Lc as Sl,Le as qn,Ma as hl,Mc as Cl,Me as ld,Nb as Te,Nc as xl,Ne as Va,O as Xr,Oa as at,Oc as Bn,Od as Gn,Pa as ht,Pe as dd,Q as kr,Qd as Ba,R as Da,Ra as Ni,Rc as eo,S as Aa,Sa as Y,Sc as Tl,Se as cd,Ta as Me,Tc as El,Td as $l,U as ll,Ub as bl,Va as Wn,Vc as Na,Vd as Ql,Wa as ul,Wd as Xl,Xc as zn,Yb as fe,Yd as ao,Zb as G,_b as He,a as K,aa as On,ae as Kl,b as rt,bd as io,be as Zl,c as nl,cb as ml,cd as Pe,ce as Jl,d as Sa,db as pl,dc as Ue,de as lo,e as wr,eb as Sr,ec as Jr,ed as Dl,ee as ed,f as Ca,fa as Ma,fd as zi,g as rn,gc as Wi,ha as Ut,hc as Bi,ia as Oa,ic as v,jc as _,je as td,kc as B,ke as id,la as Ve,lc as _l,le as jn,m as bt,mc as wl,ne as sn,o as Ri,oa as ot,oc as ee,od as Al,pa as Kt,qb as Ia,qc as V,ra as In,rb as Kr,rc as ge,sc as Jt,sd as Li,t as rl,ta as Rn,tb as fl,tc as Ct,te as nd,u as xa,ua as M,ub as P,uc as di,vc as an,ve as ii,wb as gl,wc as Je,wd as Pl,we as co,xb as vl,xc as Ge,xe as rd,y as Ta,ya as dl,yb as Zr,yc as je,ye as ci,z as Ht,zb as Rt,ze as za}from"./chunk-Y7X77HSW.js";var Qa=Sa(Po=>{(function(){"use strict";var r=function(){this.init()};r.prototype={init:function(){var s=this||n;return s._counter=1e3,s._html5AudioPool=[],s.html5PoolSize=10,s._codecs={},s._howls=[],s._muted=!1,s._volume=1,s._canPlayEvent="canplaythrough",s._navigator=typeof window<"u"&&window.navigator?window.navigator:null,s.masterGain=null,s.noAudio=!1,s.usingWebAudio=!0,s.autoSuspend=!0,s.ctx=null,s.autoUnlock=!0,s._setup(),s},volume:function(s){var c=this||n;if(s=parseFloat(s),c.ctx||f(),typeof s<"u"&&s>=0&&s<=1){if(c._volume=s,c._muted)return c;c.usingWebAudio&&c.masterGain.gain.setValueAtTime(s,n.ctx.currentTime);for(var m=0;m<c._howls.length;m++)if(!c._howls[m]._webAudio)for(var y=c._howls[m]._getSoundIds(),k=0;k<y.length;k++){var x=c._howls[m]._soundById(y[k]);x&&x._node&&(x._node.volume=x._volume*s)}return c}return c._volume},mute:function(s){var c=this||n;c.ctx||f(),c._muted=s,c.usingWebAudio&&c.masterGain.gain.setValueAtTime(s?0:c._volume,n.ctx.currentTime);for(var m=0;m<c._howls.length;m++)if(!c._howls[m]._webAudio)for(var y=c._howls[m]._getSoundIds(),k=0;k<y.length;k++){var x=c._howls[m]._soundById(y[k]);x&&x._node&&(x._node.muted=s?!0:x._muted)}return c},stop:function(){for(var s=this||n,c=0;c<s._howls.length;c++)s._howls[c].stop();return s},unload:function(){for(var s=this||n,c=s._howls.length-1;c>=0;c--)s._howls[c].unload();return s.usingWebAudio&&s.ctx&&typeof s.ctx.close<"u"&&(s.ctx.close(),s.ctx=null,f()),s},codecs:function(s){return(this||n)._codecs[s.replace(/^x-/,"")]},_setup:function(){var s=this||n;if(s.state=s.ctx&&s.ctx.state||"suspended",s._autoSuspend(),!s.usingWebAudio)if(typeof Audio<"u")try{var c=new Audio;typeof c.oncanplaythrough>"u"&&(s._canPlayEvent="canplay")}catch{s.noAudio=!0}else s.noAudio=!0;try{var c=new Audio;c.muted&&(s.noAudio=!0)}catch{}return s.noAudio||s._setupCodecs(),s},_setupCodecs:function(){var s=this||n,c=null;try{c=typeof Audio<"u"?new Audio:null}catch{return s}if(!c||typeof c.canPlayType!="function")return s;var m=c.canPlayType("audio/mpeg;").replace(/^no$/,""),y=s._navigator?s._navigator.userAgent:"",k=y.match(/OPR\/(\d+)/g),x=k&&parseInt(k[0].split("/")[1],10)<33,D=y.indexOf("Safari")!==-1&&y.indexOf("Chrome")===-1,F=y.match(/Version\/(.*?) /),$=D&&F&&parseInt(F[1],10)<15;return s._codecs={mp3:!!(!x&&(m||c.canPlayType("audio/mp3;").replace(/^no$/,""))),mpeg:!!m,opus:!!c.canPlayType('audio/ogg; codecs="opus"').replace(/^no$/,""),ogg:!!c.canPlayType('audio/ogg; codecs="vorbis"').replace(/^no$/,""),oga:!!c.canPlayType('audio/ogg; codecs="vorbis"').replace(/^no$/,""),wav:!!(c.canPlayType('audio/wav; codecs="1"')||c.canPlayType("audio/wav")).replace(/^no$/,""),aac:!!c.canPlayType("audio/aac;").replace(/^no$/,""),caf:!!c.canPlayType("audio/x-caf;").replace(/^no$/,""),m4a:!!(c.canPlayType("audio/x-m4a;")||c.canPlayType("audio/m4a;")||c.canPlayType("audio/aac;")).replace(/^no$/,""),m4b:!!(c.canPlayType("audio/x-m4b;")||c.canPlayType("audio/m4b;")||c.canPlayType("audio/aac;")).replace(/^no$/,""),mp4:!!(c.canPlayType("audio/x-mp4;")||c.canPlayType("audio/mp4;")||c.canPlayType("audio/aac;")).replace(/^no$/,""),weba:!!(!$&&c.canPlayType('audio/webm; codecs="vorbis"').replace(/^no$/,"")),webm:!!(!$&&c.canPlayType('audio/webm; codecs="vorbis"').replace(/^no$/,"")),dolby:!!c.canPlayType('audio/mp4; codecs="ec-3"').replace(/^no$/,""),flac:!!(c.canPlayType("audio/x-flac;")||c.canPlayType("audio/flac;")).replace(/^no$/,"")},s},_unlockAudio:function(){var s=this||n;if(!(s._audioUnlocked||!s.ctx)){s._audioUnlocked=!1,s.autoUnlock=!1,!s._mobileUnloaded&&s.ctx.sampleRate!==44100&&(s._mobileUnloaded=!0,s.unload()),s._scratchBuffer=s.ctx.createBuffer(1,1,22050);var c=function(m){for(;s._html5AudioPool.length<s.html5PoolSize;)try{var y=new Audio;y._unlocked=!0,s._releaseHtml5Audio(y)}catch{s.noAudio=!0;break}for(var k=0;k<s._howls.length;k++)if(!s._howls[k]._webAudio)for(var x=s._howls[k]._getSoundIds(),D=0;D<x.length;D++){var F=s._howls[k]._soundById(x[D]);F&&F._node&&!F._node._unlocked&&(F._node._unlocked=!0,F._node.load())}s._autoResume();var $=s.ctx.createBufferSource();$.buffer=s._scratchBuffer,$.connect(s.ctx.destination),typeof $.start>"u"?$.noteOn(0):$.start(0),typeof s.ctx.resume=="function"&&s.ctx.resume(),$.onended=function(){$.disconnect(0),s._audioUnlocked=!0,document.removeEventListener("touchstart",c,!0),document.removeEventListener("touchend",c,!0),document.removeEventListener("click",c,!0),document.removeEventListener("keydown",c,!0);for(var se=0;se<s._howls.length;se++)s._howls[se]._emit("unlock")}};return document.addEventListener("touchstart",c,!0),document.addEventListener("touchend",c,!0),document.addEventListener("click",c,!0),document.addEventListener("keydown",c,!0),s}},_obtainHtml5Audio:function(){var s=this||n;if(s._html5AudioPool.length)return s._html5AudioPool.pop();var c=new Audio().play();return c&&typeof Promise<"u"&&(c instanceof Promise||typeof c.then=="function")&&c.catch(function(){console.warn("HTML5 Audio pool exhausted, returning potentially locked audio object.")}),new Audio},_releaseHtml5Audio:function(s){var c=this||n;return s._unlocked&&c._html5AudioPool.push(s),c},_autoSuspend:function(){var s=this;if(!(!s.autoSuspend||!s.ctx||typeof s.ctx.suspend>"u"||!n.usingWebAudio)){for(var c=0;c<s._howls.length;c++)if(s._howls[c]._webAudio){for(var m=0;m<s._howls[c]._sounds.length;m++)if(!s._howls[c]._sounds[m]._paused)return s}return s._suspendTimer&&clearTimeout(s._suspendTimer),s._suspendTimer=setTimeout(function(){if(s.autoSuspend){s._suspendTimer=null,s.state="suspending";var y=function(){s.state="suspended",s._resumeAfterSuspend&&(delete s._resumeAfterSuspend,s._autoResume())};s.ctx.suspend().then(y,y)}},3e4),s}},_autoResume:function(){var s=this;if(!(!s.ctx||typeof s.ctx.resume>"u"||!n.usingWebAudio))return s.state==="running"&&s.ctx.state!=="interrupted"&&s._suspendTimer?(clearTimeout(s._suspendTimer),s._suspendTimer=null):s.state==="suspended"||s.state==="running"&&s.ctx.state==="interrupted"?(s.ctx.resume().then(function(){s.state="running";for(var c=0;c<s._howls.length;c++)s._howls[c]._emit("resume")}),s._suspendTimer&&(clearTimeout(s._suspendTimer),s._suspendTimer=null)):s.state==="suspending"&&(s._resumeAfterSuspend=!0),s}};var n=new r,e=function(s){var c=this;if(!s.src||s.src.length===0){console.error("An array of source files must be passed with any new Howl.");return}c.init(s)};e.prototype={init:function(s){var c=this;return n.ctx||f(),c._autoplay=s.autoplay||!1,c._format=typeof s.format!="string"?s.format:[s.format],c._html5=s.html5||!1,c._muted=s.mute||!1,c._loop=s.loop||!1,c._pool=s.pool||5,c._preload=typeof s.preload=="boolean"||s.preload==="metadata"?s.preload:!0,c._rate=s.rate||1,c._sprite=s.sprite||{},c._src=typeof s.src!="string"?s.src:[s.src],c._volume=s.volume!==void 0?s.volume:1,c._xhr={method:s.xhr&&s.xhr.method?s.xhr.method:"GET",headers:s.xhr&&s.xhr.headers?s.xhr.headers:null,withCredentials:s.xhr&&s.xhr.withCredentials?s.xhr.withCredentials:!1},c._duration=0,c._state="unloaded",c._sounds=[],c._endTimers={},c._queue=[],c._playLock=!1,c._onend=s.onend?[{fn:s.onend}]:[],c._onfade=s.onfade?[{fn:s.onfade}]:[],c._onload=s.onload?[{fn:s.onload}]:[],c._onloaderror=s.onloaderror?[{fn:s.onloaderror}]:[],c._onplayerror=s.onplayerror?[{fn:s.onplayerror}]:[],c._onpause=s.onpause?[{fn:s.onpause}]:[],c._onplay=s.onplay?[{fn:s.onplay}]:[],c._onstop=s.onstop?[{fn:s.onstop}]:[],c._onmute=s.onmute?[{fn:s.onmute}]:[],c._onvolume=s.onvolume?[{fn:s.onvolume}]:[],c._onrate=s.onrate?[{fn:s.onrate}]:[],c._onseek=s.onseek?[{fn:s.onseek}]:[],c._onunlock=s.onunlock?[{fn:s.onunlock}]:[],c._onresume=[],c._webAudio=n.usingWebAudio&&!c._html5,typeof n.ctx<"u"&&n.ctx&&n.autoUnlock&&n._unlockAudio(),n._howls.push(c),c._autoplay&&c._queue.push({event:"play",action:function(){c.play()}}),c._preload&&c._preload!=="none"&&c.load(),c},load:function(){var s=this,c=null;if(n.noAudio){s._emit("loaderror",null,"No audio support.");return}typeof s._src=="string"&&(s._src=[s._src]);for(var m=0;m<s._src.length;m++){var y,k;if(s._format&&s._format[m])y=s._format[m];else{if(k=s._src[m],typeof k!="string"){s._emit("loaderror",null,"Non-string found in selected audio sources - ignoring.");continue}y=/^data:audio\/([^;,]+);/i.exec(k),y||(y=/\.([^.]+)$/.exec(k.split("?",1)[0])),y&&(y=y[1].toLowerCase())}if(y||console.warn('No file extension was found. Consider using the "format" property or specify an extension.'),y&&n.codecs(y)){c=s._src[m];break}}if(!c){s._emit("loaderror",null,"No codec support for selected audio sources.");return}return s._src=c,s._state="loading",window.location.protocol==="https:"&&c.slice(0,5)==="http:"&&(s._html5=!0,s._webAudio=!1),new t(s),s._webAudio&&o(s),s},play:function(s,c){var m=this,y=null;if(typeof s=="number")y=s,s=null;else{if(typeof s=="string"&&m._state==="loaded"&&!m._sprite[s])return null;if(typeof s>"u"&&(s="__default",!m._playLock)){for(var k=0,x=0;x<m._sounds.length;x++)m._sounds[x]._paused&&!m._sounds[x]._ended&&(k++,y=m._sounds[x]._id);k===1?s=null:y=null}}var D=y?m._soundById(y):m._inactiveSound();if(!D)return null;if(y&&!s&&(s=D._sprite||"__default"),m._state!=="loaded"){D._sprite=s,D._ended=!1;var F=D._id;return m._queue.push({event:"play",action:function(){m.play(F)}}),F}if(y&&!D._paused)return c||m._loadQueue("play"),D._id;m._webAudio&&n._autoResume();var $=Math.max(0,D._seek>0?D._seek:m._sprite[s][0]/1e3),se=Math.max(0,(m._sprite[s][0]+m._sprite[s][1])/1e3-$),ke=se*1e3/Math.abs(D._rate),Ye=m._sprite[s][0]/1e3,Ke=(m._sprite[s][0]+m._sprite[s][1])/1e3;D._sprite=s,D._ended=!1;var it=function(){D._paused=!1,D._seek=$,D._start=Ye,D._stop=Ke,D._loop=!!(D._loop||m._sprite[s][2])};if($>=Ke){m._ended(D);return}var ce=D._node;if(m._webAudio){var mt=function(){m._playLock=!1,it(),m._refreshBuffer(D);var ft=D._muted||m._muted?0:D._volume;ce.gain.setValueAtTime(ft,n.ctx.currentTime),D._playStart=n.ctx.currentTime,typeof ce.bufferSource.start>"u"?D._loop?ce.bufferSource.noteGrainOn(0,$,86400):ce.bufferSource.noteGrainOn(0,$,se):D._loop?ce.bufferSource.start(0,$,86400):ce.bufferSource.start(0,$,se),ke!==1/0&&(m._endTimers[D._id]=setTimeout(m._ended.bind(m,D),ke)),c||setTimeout(function(){m._emit("play",D._id),m._loadQueue()},0)};n.state==="running"&&n.ctx.state!=="interrupted"?mt():(m._playLock=!0,m.once("resume",mt),m._clearTimer(D._id))}else{var dt=function(){ce.currentTime=$,ce.muted=D._muted||m._muted||n._muted||ce.muted,ce.volume=D._volume*n.volume(),ce.playbackRate=D._rate;try{var ft=ce.play();if(ft&&typeof Promise<"u"&&(ft instanceof Promise||typeof ft.then=="function")?(m._playLock=!0,it(),ft.then(function(){m._playLock=!1,ce._unlocked=!0,c?m._loadQueue():m._emit("play",D._id)}).catch(function(){m._playLock=!1,m._emit("playerror",D._id,"Playback was unable to start. This is most commonly an issue on mobile devices and Chrome where playback was not within a user interaction."),D._ended=!0,D._paused=!0})):c||(m._playLock=!1,it(),m._emit("play",D._id)),ce.playbackRate=D._rate,ce.paused){m._emit("playerror",D._id,"Playback was unable to start. This is most commonly an issue on mobile devices and Chrome where playback was not within a user interaction.");return}s!=="__default"||D._loop?m._endTimers[D._id]=setTimeout(m._ended.bind(m,D),ke):(m._endTimers[D._id]=function(){m._ended(D),ce.removeEventListener("ended",m._endTimers[D._id],!1)},ce.addEventListener("ended",m._endTimers[D._id],!1))}catch(Ci){m._emit("playerror",D._id,Ci)}};ce.src==="data:audio/wav;base64,UklGRigAAABXQVZFZm10IBIAAAABAAEARKwAAIhYAQACABAAAABkYXRhAgAAAAEA"&&(ce.src=m._src,ce.load());var qt=window&&window.ejecta||!ce.readyState&&n._navigator.isCocoonJS;if(ce.readyState>=3||qt)dt();else{m._playLock=!0,m._state="loading";var pt=function(){m._state="loaded",dt(),ce.removeEventListener(n._canPlayEvent,pt,!1)};ce.addEventListener(n._canPlayEvent,pt,!1),m._clearTimer(D._id)}}return D._id},pause:function(s){var c=this;if(c._state!=="loaded"||c._playLock)return c._queue.push({event:"pause",action:function(){c.pause(s)}}),c;for(var m=c._getSoundIds(s),y=0;y<m.length;y++){c._clearTimer(m[y]);var k=c._soundById(m[y]);if(k&&!k._paused&&(k._seek=c.seek(m[y]),k._rateSeek=0,k._paused=!0,c._stopFade(m[y]),k._node))if(c._webAudio){if(!k._node.bufferSource)continue;typeof k._node.bufferSource.stop>"u"?k._node.bufferSource.noteOff(0):k._node.bufferSource.stop(0),c._cleanBuffer(k._node)}else(!isNaN(k._node.duration)||k._node.duration===1/0)&&k._node.pause();arguments[1]||c._emit("pause",k?k._id:null)}return c},stop:function(s,c){var m=this;if(m._state!=="loaded"||m._playLock)return m._queue.push({event:"stop",action:function(){m.stop(s)}}),m;for(var y=m._getSoundIds(s),k=0;k<y.length;k++){m._clearTimer(y[k]);var x=m._soundById(y[k]);x&&(x._seek=x._start||0,x._rateSeek=0,x._paused=!0,x._ended=!0,m._stopFade(y[k]),x._node&&(m._webAudio?x._node.bufferSource&&(typeof x._node.bufferSource.stop>"u"?x._node.bufferSource.noteOff(0):x._node.bufferSource.stop(0),m._cleanBuffer(x._node)):(!isNaN(x._node.duration)||x._node.duration===1/0)&&(x._node.currentTime=x._start||0,x._node.pause(),x._node.duration===1/0&&m._clearSound(x._node))),c||m._emit("stop",x._id))}return m},mute:function(s,c){var m=this;if(m._state!=="loaded"||m._playLock)return m._queue.push({event:"mute",action:function(){m.mute(s,c)}}),m;if(typeof c>"u")if(typeof s=="boolean")m._muted=s;else return m._muted;for(var y=m._getSoundIds(c),k=0;k<y.length;k++){var x=m._soundById(y[k]);x&&(x._muted=s,x._interval&&m._stopFade(x._id),m._webAudio&&x._node?x._node.gain.setValueAtTime(s?0:x._volume,n.ctx.currentTime):x._node&&(x._node.muted=n._muted?!0:s),m._emit("mute",x._id))}return m},volume:function(){var s=this,c=arguments,m,y;if(c.length===0)return s._volume;if(c.length===1||c.length===2&&typeof c[1]>"u"){var k=s._getSoundIds(),x=k.indexOf(c[0]);x>=0?y=parseInt(c[0],10):m=parseFloat(c[0])}else c.length>=2&&(m=parseFloat(c[0]),y=parseInt(c[1],10));var D;if(typeof m<"u"&&m>=0&&m<=1){if(s._state!=="loaded"||s._playLock)return s._queue.push({event:"volume",action:function(){s.volume.apply(s,c)}}),s;typeof y>"u"&&(s._volume=m),y=s._getSoundIds(y);for(var F=0;F<y.length;F++)D=s._soundById(y[F]),D&&(D._volume=m,c[2]||s._stopFade(y[F]),s._webAudio&&D._node&&!D._muted?D._node.gain.setValueAtTime(m,n.ctx.currentTime):D._node&&!D._muted&&(D._node.volume=m*n.volume()),s._emit("volume",D._id))}else return D=y?s._soundById(y):s._sounds[0],D?D._volume:0;return s},fade:function(s,c,m,y){var k=this;if(k._state!=="loaded"||k._playLock)return k._queue.push({event:"fade",action:function(){k.fade(s,c,m,y)}}),k;s=Math.min(Math.max(0,parseFloat(s)),1),c=Math.min(Math.max(0,parseFloat(c)),1),m=parseFloat(m),k.volume(s,y);for(var x=k._getSoundIds(y),D=0;D<x.length;D++){var F=k._soundById(x[D]);if(F){if(y||k._stopFade(x[D]),k._webAudio&&!F._muted){var $=n.ctx.currentTime,se=$+m/1e3;F._volume=s,F._node.gain.setValueAtTime(s,$),F._node.gain.linearRampToValueAtTime(c,se)}k._startFadeInterval(F,s,c,m,x[D],typeof y>"u")}}return k},_startFadeInterval:function(s,c,m,y,k,x){var D=this,F=c,$=m-c,se=Math.abs($/.01),ke=Math.max(4,se>0?y/se:y),Ye=Date.now();s._fadeTo=m,s._interval=setInterval(function(){var Ke=(Date.now()-Ye)/y;Ye=Date.now(),F+=$*Ke,F=Math.round(F*100)/100,$<0?F=Math.max(m,F):F=Math.min(m,F),D._webAudio?s._volume=F:D.volume(F,s._id,!0),x&&(D._volume=F),(m<c&&F<=m||m>c&&F>=m)&&(clearInterval(s._interval),s._interval=null,s._fadeTo=null,D.volume(m,s._id),D._emit("fade",s._id))},ke)},_stopFade:function(s){var c=this,m=c._soundById(s);return m&&m._interval&&(c._webAudio&&m._node.gain.cancelScheduledValues(n.ctx.currentTime),clearInterval(m._interval),m._interval=null,c.volume(m._fadeTo,s),m._fadeTo=null,c._emit("fade",s)),c},loop:function(){var s=this,c=arguments,m,y,k;if(c.length===0)return s._loop;if(c.length===1)if(typeof c[0]=="boolean")m=c[0],s._loop=m;else return k=s._soundById(parseInt(c[0],10)),k?k._loop:!1;else c.length===2&&(m=c[0],y=parseInt(c[1],10));for(var x=s._getSoundIds(y),D=0;D<x.length;D++)k=s._soundById(x[D]),k&&(k._loop=m,s._webAudio&&k._node&&k._node.bufferSource&&(k._node.bufferSource.loop=m,m&&(k._node.bufferSource.loopStart=k._start||0,k._node.bufferSource.loopEnd=k._stop,s.playing(x[D])&&(s.pause(x[D],!0),s.play(x[D],!0)))));return s},rate:function(){var s=this,c=arguments,m,y;if(c.length===0)y=s._sounds[0]._id;else if(c.length===1){var k=s._getSoundIds(),x=k.indexOf(c[0]);x>=0?y=parseInt(c[0],10):m=parseFloat(c[0])}else c.length===2&&(m=parseFloat(c[0]),y=parseInt(c[1],10));var D;if(typeof m=="number"){if(s._state!=="loaded"||s._playLock)return s._queue.push({event:"rate",action:function(){s.rate.apply(s,c)}}),s;typeof y>"u"&&(s._rate=m),y=s._getSoundIds(y);for(var F=0;F<y.length;F++)if(D=s._soundById(y[F]),D){s.playing(y[F])&&(D._rateSeek=s.seek(y[F]),D._playStart=s._webAudio?n.ctx.currentTime:D._playStart),D._rate=m,s._webAudio&&D._node&&D._node.bufferSource?D._node.bufferSource.playbackRate.setValueAtTime(m,n.ctx.currentTime):D._node&&(D._node.playbackRate=m);var $=s.seek(y[F]),se=(s._sprite[D._sprite][0]+s._sprite[D._sprite][1])/1e3-$,ke=se*1e3/Math.abs(D._rate);(s._endTimers[y[F]]||!D._paused)&&(s._clearTimer(y[F]),s._endTimers[y[F]]=setTimeout(s._ended.bind(s,D),ke)),s._emit("rate",D._id)}}else return D=s._soundById(y),D?D._rate:s._rate;return s},seek:function(){var s=this,c=arguments,m,y;if(c.length===0)s._sounds.length&&(y=s._sounds[0]._id);else if(c.length===1){var k=s._getSoundIds(),x=k.indexOf(c[0]);x>=0?y=parseInt(c[0],10):s._sounds.length&&(y=s._sounds[0]._id,m=parseFloat(c[0]))}else c.length===2&&(m=parseFloat(c[0]),y=parseInt(c[1],10));if(typeof y>"u")return 0;if(typeof m=="number"&&(s._state!=="loaded"||s._playLock))return s._queue.push({event:"seek",action:function(){s.seek.apply(s,c)}}),s;var D=s._soundById(y);if(D)if(typeof m=="number"&&m>=0){var F=s.playing(y);F&&s.pause(y,!0),D._seek=m,D._ended=!1,s._clearTimer(y),!s._webAudio&&D._node&&!isNaN(D._node.duration)&&(D._node.currentTime=m);var $=function(){F&&s.play(y,!0),s._emit("seek",y)};if(F&&!s._webAudio){var se=function(){s._playLock?setTimeout(se,0):$()};setTimeout(se,0)}else $()}else if(s._webAudio){var ke=s.playing(y)?n.ctx.currentTime-D._playStart:0,Ye=D._rateSeek?D._rateSeek-D._seek:0;return D._seek+(Ye+ke*Math.abs(D._rate))}else return D._node.currentTime;return s},playing:function(s){var c=this;if(typeof s=="number"){var m=c._soundById(s);return m?!m._paused:!1}for(var y=0;y<c._sounds.length;y++)if(!c._sounds[y]._paused)return!0;return!1},duration:function(s){var c=this,m=c._duration,y=c._soundById(s);return y&&(m=c._sprite[y._sprite][1]/1e3),m},state:function(){return this._state},unload:function(){for(var s=this,c=s._sounds,m=0;m<c.length;m++)c[m]._paused||s.stop(c[m]._id),s._webAudio||(s._clearSound(c[m]._node),c[m]._node.removeEventListener("error",c[m]._errorFn,!1),c[m]._node.removeEventListener(n._canPlayEvent,c[m]._loadFn,!1),c[m]._node.removeEventListener("ended",c[m]._endFn,!1),n._releaseHtml5Audio(c[m]._node)),delete c[m]._node,s._clearTimer(c[m]._id);var y=n._howls.indexOf(s);y>=0&&n._howls.splice(y,1);var k=!0;for(m=0;m<n._howls.length;m++)if(n._howls[m]._src===s._src||s._src.indexOf(n._howls[m]._src)>=0){k=!1;break}return i&&k&&delete i[s._src],n.noAudio=!1,s._state="unloaded",s._sounds=[],s=null,null},on:function(s,c,m,y){var k=this,x=k["_on"+s];return typeof c=="function"&&x.push(y?{id:m,fn:c,once:y}:{id:m,fn:c}),k},off:function(s,c,m){var y=this,k=y["_on"+s],x=0;if(typeof c=="number"&&(m=c,c=null),c||m)for(x=0;x<k.length;x++){var D=m===k[x].id;if(c===k[x].fn&&D||!c&&D){k.splice(x,1);break}}else if(s)y["_on"+s]=[];else{var F=Object.keys(y);for(x=0;x<F.length;x++)F[x].indexOf("_on")===0&&Array.isArray(y[F[x]])&&(y[F[x]]=[])}return y},once:function(s,c,m){var y=this;return y.on(s,c,m,1),y},_emit:function(s,c,m){for(var y=this,k=y["_on"+s],x=k.length-1;x>=0;x--)(!k[x].id||k[x].id===c||s==="load")&&(setTimeout(function(D){D.call(this,c,m)}.bind(y,k[x].fn),0),k[x].once&&y.off(s,k[x].fn,k[x].id));return y._loadQueue(s),y},_loadQueue:function(s){var c=this;if(c._queue.length>0){var m=c._queue[0];m.event===s&&(c._queue.shift(),c._loadQueue()),s||m.action()}return c},_ended:function(s){var c=this,m=s._sprite;if(!c._webAudio&&s._node&&!s._node.paused&&!s._node.ended&&s._node.currentTime<s._stop)return setTimeout(c._ended.bind(c,s),100),c;var y=!!(s._loop||c._sprite[m][2]);if(c._emit("end",s._id),!c._webAudio&&y&&c.stop(s._id,!0).play(s._id),c._webAudio&&y){c._emit("play",s._id),s._seek=s._start||0,s._rateSeek=0,s._playStart=n.ctx.currentTime;var k=(s._stop-s._start)*1e3/Math.abs(s._rate);c._endTimers[s._id]=setTimeout(c._ended.bind(c,s),k)}return c._webAudio&&!y&&(s._paused=!0,s._ended=!0,s._seek=s._start||0,s._rateSeek=0,c._clearTimer(s._id),c._cleanBuffer(s._node),n._autoSuspend()),!c._webAudio&&!y&&c.stop(s._id,!0),c},_clearTimer:function(s){var c=this;if(c._endTimers[s]){if(typeof c._endTimers[s]!="function")clearTimeout(c._endTimers[s]);else{var m=c._soundById(s);m&&m._node&&m._node.removeEventListener("ended",c._endTimers[s],!1)}delete c._endTimers[s]}return c},_soundById:function(s){for(var c=this,m=0;m<c._sounds.length;m++)if(s===c._sounds[m]._id)return c._sounds[m];return null},_inactiveSound:function(){var s=this;s._drain();for(var c=0;c<s._sounds.length;c++)if(s._sounds[c]._ended)return s._sounds[c].reset();return new t(s)},_drain:function(){var s=this,c=s._pool,m=0,y=0;if(!(s._sounds.length<c)){for(y=0;y<s._sounds.length;y++)s._sounds[y]._ended&&m++;for(y=s._sounds.length-1;y>=0;y--){if(m<=c)return;s._sounds[y]._ended&&(s._webAudio&&s._sounds[y]._node&&s._sounds[y]._node.disconnect(0),s._sounds.splice(y,1),m--)}}},_getSoundIds:function(s){var c=this;if(typeof s>"u"){for(var m=[],y=0;y<c._sounds.length;y++)m.push(c._sounds[y]._id);return m}else return[s]},_refreshBuffer:function(s){var c=this;return s._node.bufferSource=n.ctx.createBufferSource(),s._node.bufferSource.buffer=i[c._src],s._panner?s._node.bufferSource.connect(s._panner):s._node.bufferSource.connect(s._node),s._node.bufferSource.loop=s._loop,s._loop&&(s._node.bufferSource.loopStart=s._start||0,s._node.bufferSource.loopEnd=s._stop||0),s._node.bufferSource.playbackRate.setValueAtTime(s._rate,n.ctx.currentTime),c},_cleanBuffer:function(s){var c=this,m=n._navigator&&n._navigator.vendor.indexOf("Apple")>=0;if(!s.bufferSource)return c;if(n._scratchBuffer&&s.bufferSource&&(s.bufferSource.onended=null,s.bufferSource.disconnect(0),m))try{s.bufferSource.buffer=n._scratchBuffer}catch{}return s.bufferSource=null,c},_clearSound:function(s){var c=/MSIE |Trident\//.test(n._navigator&&n._navigator.userAgent);c||(s.src="data:audio/wav;base64,UklGRigAAABXQVZFZm10IBIAAAABAAEARKwAAIhYAQACABAAAABkYXRhAgAAAAEA")}};var t=function(s){this._parent=s,this.init()};t.prototype={init:function(){var s=this,c=s._parent;return s._muted=c._muted,s._loop=c._loop,s._volume=c._volume,s._rate=c._rate,s._seek=0,s._paused=!0,s._ended=!0,s._sprite="__default",s._id=++n._counter,c._sounds.push(s),s.create(),s},create:function(){var s=this,c=s._parent,m=n._muted||s._muted||s._parent._muted?0:s._volume;return c._webAudio?(s._node=typeof n.ctx.createGain>"u"?n.ctx.createGainNode():n.ctx.createGain(),s._node.gain.setValueAtTime(m,n.ctx.currentTime),s._node.paused=!0,s._node.connect(n.masterGain)):n.noAudio||(s._node=n._obtainHtml5Audio(),s._errorFn=s._errorListener.bind(s),s._node.addEventListener("error",s._errorFn,!1),s._loadFn=s._loadListener.bind(s),s._node.addEventListener(n._canPlayEvent,s._loadFn,!1),s._endFn=s._endListener.bind(s),s._node.addEventListener("ended",s._endFn,!1),s._node.src=c._src,s._node.preload=c._preload===!0?"auto":c._preload,s._node.volume=m*n.volume(),s._node.load()),s},reset:function(){var s=this,c=s._parent;return s._muted=c._muted,s._loop=c._loop,s._volume=c._volume,s._rate=c._rate,s._seek=0,s._rateSeek=0,s._paused=!0,s._ended=!0,s._sprite="__default",s._id=++n._counter,s},_errorListener:function(){var s=this;s._parent._emit("loaderror",s._id,s._node.error?s._node.error.code:0),s._node.removeEventListener("error",s._errorFn,!1)},_loadListener:function(){var s=this,c=s._parent;c._duration=Math.ceil(s._node.duration*10)/10,Object.keys(c._sprite).length===0&&(c._sprite={__default:[0,c._duration*1e3]}),c._state!=="loaded"&&(c._state="loaded",c._emit("load"),c._loadQueue()),s._node.removeEventListener(n._canPlayEvent,s._loadFn,!1)},_endListener:function(){var s=this,c=s._parent;c._duration===1/0&&(c._duration=Math.ceil(s._node.duration*10)/10,c._sprite.__default[1]===1/0&&(c._sprite.__default[1]=c._duration*1e3),c._ended(s)),s._node.removeEventListener("ended",s._endFn,!1)}};var i={},o=function(s){var c=s._src;if(i[c]){s._duration=i[c].duration,d(s);return}if(/^data:[^;]+;base64,/.test(c)){for(var m=atob(c.split(",")[1]),y=new Uint8Array(m.length),k=0;k<m.length;++k)y[k]=m.charCodeAt(k);l(y.buffer,s)}else{var x=new XMLHttpRequest;x.open(s._xhr.method,c,!0),x.withCredentials=s._xhr.withCredentials,x.responseType="arraybuffer",s._xhr.headers&&Object.keys(s._xhr.headers).forEach(function(D){x.setRequestHeader(D,s._xhr.headers[D])}),x.onload=function(){var D=(x.status+"")[0];if(D!=="0"&&D!=="2"&&D!=="3"){s._emit("loaderror",null,"Failed loading audio file with status: "+x.status+".");return}l(x.response,s)},x.onerror=function(){s._webAudio&&(s._html5=!0,s._webAudio=!1,s._sounds=[],delete i[c],s.load())},a(x)}},a=function(s){try{s.send()}catch{s.onerror()}},l=function(s,c){var m=function(){c._emit("loaderror",null,"Decoding audio data failed.")},y=function(k){k&&c._sounds.length>0?(i[c._src]=k,d(c,k)):m()};typeof Promise<"u"&&n.ctx.decodeAudioData.length===1?n.ctx.decodeAudioData(s).then(y).catch(m):n.ctx.decodeAudioData(s,y,m)},d=function(s,c){c&&!s._duration&&(s._duration=c.duration),Object.keys(s._sprite).length===0&&(s._sprite={__default:[0,s._duration*1e3]}),s._state!=="loaded"&&(s._state="loaded",s._emit("load"),s._loadQueue())},f=function(){if(n.usingWebAudio){try{typeof AudioContext<"u"?n.ctx=new AudioContext:typeof webkitAudioContext<"u"?n.ctx=new webkitAudioContext:n.usingWebAudio=!1}catch{n.usingWebAudio=!1}n.ctx||(n.usingWebAudio=!1);var s=/iP(hone|od|ad)/.test(n._navigator&&n._navigator.platform),c=n._navigator&&n._navigator.appVersion.match(/OS (\d+)_(\d+)_?(\d+)?/),m=c?parseInt(c[1],10):null;if(s&&m&&m<9){var y=/safari/.test(n._navigator&&n._navigator.userAgent.toLowerCase());n._navigator&&!y&&(n.usingWebAudio=!1)}n.usingWebAudio&&(n.masterGain=typeof n.ctx.createGain>"u"?n.ctx.createGainNode():n.ctx.createGain(),n.masterGain.gain.setValueAtTime(n._muted?0:n._volume,n.ctx.currentTime),n.masterGain.connect(n.ctx.destination)),n._setup()}};typeof define=="function"&&define.amd&&define([],function(){return{Howler:n,Howl:e}}),typeof Po<"u"&&(Po.Howler=n,Po.Howl=e),typeof global<"u"?(global.HowlerGlobal=r,global.Howler=n,global.Howl=e,global.Sound=t):typeof window<"u"&&(window.HowlerGlobal=r,window.Howler=n,window.Howl=e,window.Sound=t)})();(function(){"use strict";HowlerGlobal.prototype._pos=[0,0,0],HowlerGlobal.prototype._orientation=[0,0,-1,0,1,0],HowlerGlobal.prototype.stereo=function(n){var e=this;if(!e.ctx||!e.ctx.listener)return e;for(var t=e._howls.length-1;t>=0;t--)e._howls[t].stereo(n);return e},HowlerGlobal.prototype.pos=function(n,e,t){var i=this;if(!i.ctx||!i.ctx.listener)return i;if(e=typeof e!="number"?i._pos[1]:e,t=typeof t!="number"?i._pos[2]:t,typeof n=="number")i._pos=[n,e,t],typeof i.ctx.listener.positionX<"u"?(i.ctx.listener.positionX.setTargetAtTime(i._pos[0],Howler.ctx.currentTime,.1),i.ctx.listener.positionY.setTargetAtTime(i._pos[1],Howler.ctx.currentTime,.1),i.ctx.listener.positionZ.setTargetAtTime(i._pos[2],Howler.ctx.currentTime,.1)):i.ctx.listener.setPosition(i._pos[0],i._pos[1],i._pos[2]);else return i._pos;return i},HowlerGlobal.prototype.orientation=function(n,e,t,i,o,a){var l=this;if(!l.ctx||!l.ctx.listener)return l;var d=l._orientation;if(e=typeof e!="number"?d[1]:e,t=typeof t!="number"?d[2]:t,i=typeof i!="number"?d[3]:i,o=typeof o!="number"?d[4]:o,a=typeof a!="number"?d[5]:a,typeof n=="number")l._orientation=[n,e,t,i,o,a],typeof l.ctx.listener.forwardX<"u"?(l.ctx.listener.forwardX.setTargetAtTime(n,Howler.ctx.currentTime,.1),l.ctx.listener.forwardY.setTargetAtTime(e,Howler.ctx.currentTime,.1),l.ctx.listener.forwardZ.setTargetAtTime(t,Howler.ctx.currentTime,.1),l.ctx.listener.upX.setTargetAtTime(i,Howler.ctx.currentTime,.1),l.ctx.listener.upY.setTargetAtTime(o,Howler.ctx.currentTime,.1),l.ctx.listener.upZ.setTargetAtTime(a,Howler.ctx.currentTime,.1)):l.ctx.listener.setOrientation(n,e,t,i,o,a);else return d;return l},Howl.prototype.init=function(n){return function(e){var t=this;return t._orientation=e.orientation||[1,0,0],t._stereo=e.stereo||null,t._pos=e.pos||null,t._pannerAttr={coneInnerAngle:typeof e.coneInnerAngle<"u"?e.coneInnerAngle:360,coneOuterAngle:typeof e.coneOuterAngle<"u"?e.coneOuterAngle:360,coneOuterGain:typeof e.coneOuterGain<"u"?e.coneOuterGain:0,distanceModel:typeof e.distanceModel<"u"?e.distanceModel:"inverse",maxDistance:typeof e.maxDistance<"u"?e.maxDistance:1e4,panningModel:typeof e.panningModel<"u"?e.panningModel:"HRTF",refDistance:typeof e.refDistance<"u"?e.refDistance:1,rolloffFactor:typeof e.rolloffFactor<"u"?e.rolloffFactor:1},t._onstereo=e.onstereo?[{fn:e.onstereo}]:[],t._onpos=e.onpos?[{fn:e.onpos}]:[],t._onorientation=e.onorientation?[{fn:e.onorientation}]:[],n.call(this,e)}}(Howl.prototype.init),Howl.prototype.stereo=function(n,e){var t=this;if(!t._webAudio)return t;if(t._state!=="loaded")return t._queue.push({event:"stereo",action:function(){t.stereo(n,e)}}),t;var i=typeof Howler.ctx.createStereoPanner>"u"?"spatial":"stereo";if(typeof e>"u")if(typeof n=="number")t._stereo=n,t._pos=[n,0,0];else return t._stereo;for(var o=t._getSoundIds(e),a=0;a<o.length;a++){var l=t._soundById(o[a]);if(l)if(typeof n=="number")l._stereo=n,l._pos=[n,0,0],l._node&&(l._pannerAttr.panningModel="equalpower",(!l._panner||!l._panner.pan)&&r(l,i),i==="spatial"?typeof l._panner.positionX<"u"?(l._panner.positionX.setValueAtTime(n,Howler.ctx.currentTime),l._panner.positionY.setValueAtTime(0,Howler.ctx.currentTime),l._panner.positionZ.setValueAtTime(0,Howler.ctx.currentTime)):l._panner.setPosition(n,0,0):l._panner.pan.setValueAtTime(n,Howler.ctx.currentTime)),t._emit("stereo",l._id);else return l._stereo}return t},Howl.prototype.pos=function(n,e,t,i){var o=this;if(!o._webAudio)return o;if(o._state!=="loaded")return o._queue.push({event:"pos",action:function(){o.pos(n,e,t,i)}}),o;if(e=typeof e!="number"?0:e,t=typeof t!="number"?-.5:t,typeof i>"u")if(typeof n=="number")o._pos=[n,e,t];else return o._pos;for(var a=o._getSoundIds(i),l=0;l<a.length;l++){var d=o._soundById(a[l]);if(d)if(typeof n=="number")d._pos=[n,e,t],d._node&&((!d._panner||d._panner.pan)&&r(d,"spatial"),typeof d._panner.positionX<"u"?(d._panner.positionX.setValueAtTime(n,Howler.ctx.currentTime),d._panner.positionY.setValueAtTime(e,Howler.ctx.currentTime),d._panner.positionZ.setValueAtTime(t,Howler.ctx.currentTime)):d._panner.setPosition(n,e,t)),o._emit("pos",d._id);else return d._pos}return o},Howl.prototype.orientation=function(n,e,t,i){var o=this;if(!o._webAudio)return o;if(o._state!=="loaded")return o._queue.push({event:"orientation",action:function(){o.orientation(n,e,t,i)}}),o;if(e=typeof e!="number"?o._orientation[1]:e,t=typeof t!="number"?o._orientation[2]:t,typeof i>"u")if(typeof n=="number")o._orientation=[n,e,t];else return o._orientation;for(var a=o._getSoundIds(i),l=0;l<a.length;l++){var d=o._soundById(a[l]);if(d)if(typeof n=="number")d._orientation=[n,e,t],d._node&&(d._panner||(d._pos||(d._pos=o._pos||[0,0,-.5]),r(d,"spatial")),typeof d._panner.orientationX<"u"?(d._panner.orientationX.setValueAtTime(n,Howler.ctx.currentTime),d._panner.orientationY.setValueAtTime(e,Howler.ctx.currentTime),d._panner.orientationZ.setValueAtTime(t,Howler.ctx.currentTime)):d._panner.setOrientation(n,e,t)),o._emit("orientation",d._id);else return d._orientation}return o},Howl.prototype.pannerAttr=function(){var n=this,e=arguments,t,i,o;if(!n._webAudio)return n;if(e.length===0)return n._pannerAttr;if(e.length===1)if(typeof e[0]=="object")t=e[0],typeof i>"u"&&(t.pannerAttr||(t.pannerAttr={coneInnerAngle:t.coneInnerAngle,coneOuterAngle:t.coneOuterAngle,coneOuterGain:t.coneOuterGain,distanceModel:t.distanceModel,maxDistance:t.maxDistance,refDistance:t.refDistance,rolloffFactor:t.rolloffFactor,panningModel:t.panningModel}),n._pannerAttr={coneInnerAngle:typeof t.pannerAttr.coneInnerAngle<"u"?t.pannerAttr.coneInnerAngle:n._coneInnerAngle,coneOuterAngle:typeof t.pannerAttr.coneOuterAngle<"u"?t.pannerAttr.coneOuterAngle:n._coneOuterAngle,coneOuterGain:typeof t.pannerAttr.coneOuterGain<"u"?t.pannerAttr.coneOuterGain:n._coneOuterGain,distanceModel:typeof t.pannerAttr.distanceModel<"u"?t.pannerAttr.distanceModel:n._distanceModel,maxDistance:typeof t.pannerAttr.maxDistance<"u"?t.pannerAttr.maxDistance:n._maxDistance,refDistance:typeof t.pannerAttr.refDistance<"u"?t.pannerAttr.refDistance:n._refDistance,rolloffFactor:typeof t.pannerAttr.rolloffFactor<"u"?t.pannerAttr.rolloffFactor:n._rolloffFactor,panningModel:typeof t.pannerAttr.panningModel<"u"?t.pannerAttr.panningModel:n._panningModel});else return o=n._soundById(parseInt(e[0],10)),o?o._pannerAttr:n._pannerAttr;else e.length===2&&(t=e[0],i=parseInt(e[1],10));for(var a=n._getSoundIds(i),l=0;l<a.length;l++)if(o=n._soundById(a[l]),o){var d=o._pannerAttr;d={coneInnerAngle:typeof t.coneInnerAngle<"u"?t.coneInnerAngle:d.coneInnerAngle,coneOuterAngle:typeof t.coneOuterAngle<"u"?t.coneOuterAngle:d.coneOuterAngle,coneOuterGain:typeof t.coneOuterGain<"u"?t.coneOuterGain:d.coneOuterGain,distanceModel:typeof t.distanceModel<"u"?t.distanceModel:d.distanceModel,maxDistance:typeof t.maxDistance<"u"?t.maxDistance:d.maxDistance,refDistance:typeof t.refDistance<"u"?t.refDistance:d.refDistance,rolloffFactor:typeof t.rolloffFactor<"u"?t.rolloffFactor:d.rolloffFactor,panningModel:typeof t.panningModel<"u"?t.panningModel:d.panningModel};var f=o._panner;f||(o._pos||(o._pos=n._pos||[0,0,-.5]),r(o,"spatial"),f=o._panner),f.coneInnerAngle=d.coneInnerAngle,f.coneOuterAngle=d.coneOuterAngle,f.coneOuterGain=d.coneOuterGain,f.distanceModel=d.distanceModel,f.maxDistance=d.maxDistance,f.refDistance=d.refDistance,f.rolloffFactor=d.rolloffFactor,f.panningModel=d.panningModel}return n},Sound.prototype.init=function(n){return function(){var e=this,t=e._parent;e._orientation=t._orientation,e._stereo=t._stereo,e._pos=t._pos,e._pannerAttr=t._pannerAttr,n.call(this),e._stereo?t.stereo(e._stereo):e._pos&&t.pos(e._pos[0],e._pos[1],e._pos[2],e._id)}}(Sound.prototype.init),Sound.prototype.reset=function(n){return function(){var e=this,t=e._parent;return e._orientation=t._orientation,e._stereo=t._stereo,e._pos=t._pos,e._pannerAttr=t._pannerAttr,e._stereo?t.stereo(e._stereo):e._pos?t.pos(e._pos[0],e._pos[1],e._pos[2],e._id):e._panner&&(e._panner.disconnect(0),e._panner=void 0,t._refreshBuffer(e)),n.call(this)}}(Sound.prototype.reset);var r=function(n,e){e=e||"spatial",e==="spatial"?(n._panner=Howler.ctx.createPanner(),n._panner.coneInnerAngle=n._pannerAttr.coneInnerAngle,n._panner.coneOuterAngle=n._pannerAttr.coneOuterAngle,n._panner.coneOuterGain=n._pannerAttr.coneOuterGain,n._panner.distanceModel=n._pannerAttr.distanceModel,n._panner.maxDistance=n._pannerAttr.maxDistance,n._panner.refDistance=n._pannerAttr.refDistance,n._panner.rolloffFactor=n._pannerAttr.rolloffFactor,n._panner.panningModel=n._pannerAttr.panningModel,typeof n._panner.positionX<"u"?(n._panner.positionX.setValueAtTime(n._pos[0],Howler.ctx.currentTime),n._panner.positionY.setValueAtTime(n._pos[1],Howler.ctx.currentTime),n._panner.positionZ.setValueAtTime(n._pos[2],Howler.ctx.currentTime)):n._panner.setPosition(n._pos[0],n._pos[1],n._pos[2]),typeof n._panner.orientationX<"u"?(n._panner.orientationX.setValueAtTime(n._orientation[0],Howler.ctx.currentTime),n._panner.orientationY.setValueAtTime(n._orientation[1],Howler.ctx.currentTime),n._panner.orientationZ.setValueAtTime(n._orientation[2],Howler.ctx.currentTime)):n._panner.setOrientation(n._orientation[0],n._orientation[1],n._orientation[2])):(n._panner=Howler.ctx.createStereoPanner(),n._panner.pan.setValueAtTime(n._stereo,Howler.ctx.currentTime)),n._panner.connect(n._node),n._paused||n._parent.pause(n._id,!0).play(n._id,!0)}})()});var ms=Sa((ik,Lo)=>{(function(r){"use strict";function n(u){if(Array.isArray(u)){for(var h=0,p=Array(u.length);h<u.length;h++)p[h]=u[h];return p}return Array.from(u)}function e(u,h){if(!u)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!h||typeof h!="object"&&typeof h!="function"?u:h}function t(u,h){if(typeof h!="function"&&h!==null)throw new TypeError("Super expression must either be null or a function, not "+typeof h);u.prototype=Object.create(h&&h.prototype,{constructor:{value:u,enumerable:!1,writable:!0,configurable:!0}}),h&&(Object.setPrototypeOf?Object.setPrototypeOf(u,h):u.__proto__=h)}function i(u,h){if(!(u instanceof h))throw new TypeError("Cannot call a class as a function")}function o(u,h){if(h||(h=typeof window>"u"?global:window),h[u]!==void 0)return h[u];if(xi===null){var p=window.getComputedStyle(document.documentElement,"");xi=(Array.prototype.slice.call(p).join("").match(/-(moz|webkit|ms)-/)||p.OLink===""&&["","o"]||["",""])[1]}if(xi==="")return null;var w=u.charAt(0).toUpperCase()+u.substr(1),C=h[xi+w];return C!==void 0?C:null}function a(u,h,p,w,C,E,O){if(typeof w!="function")throw new TypeError("Invalid animation rule:",w);var N=u-p,R=N/C,W=0;R>1&&(R=1),R!==1&&(W=w(R),isFinite(W)&&!isNaN(W)&&(R=W)),h&&h(R),N<C?O.frame=qr(function(j){return a(j,h,p,w,C,E,O)}):(E&&E(),O.inProgress=!1)}function l(){Array.prototype.constructor.apply(this,arguments)}function d(u){if(!(u instanceof DOMException&&u.result===2152923147))throw u}function f(u,h){return h.replace(ya,function(p,w){var C=u[w];return C!==void 0?C:p})}function s(u){return u.majorTicks instanceof Array||(u.majorTicks=u.majorTicks?[u.majorTicks]:[]),u.majorTicks.length||(u.majorTicks.push(Z.formatMajorTickNumber(u.minValue,u)),u.majorTicks.push(Z.formatMajorTickNumber(u.maxValue,u))),[u.tickSide!=="right",u.tickSide!=="left"]}function c(u,h,p,w,C,E){u.beginPath(),u.moveTo(h+E,p),u.lineTo(h+w-E,p),u.quadraticCurveTo(h+w,p,h+w,p+E),u.lineTo(h+w,p+C-E),u.quadraticCurveTo(h+w,p+C,h+w-E,p+C),u.lineTo(h+E,p+C),u.quadraticCurveTo(h,p+C,h,p+C-E),u.lineTo(h,p+E),u.quadraticCurveTo(h,p,h+E,p),u.closePath()}function m(u,h){var p=h.valueDec,w=h.valueInt,C=0,E=void 0,O=void 0,N=void 0;if(u=parseFloat(u),N=u<0,u=Math.abs(u),p>0){for(O=u.toFixed(p).toString().split("."),E=w-O[0].length;C<E;++C)O[0]="0"+O[0];O=(N?"-":"")+O[0]+"."+O[1]}else{for(O=Math.round(u).toString(),E=w-O.length;C<E;++C)O="0"+O;O=(N?"-":"")+O}return O}function y(u,h){var p=void 0,w=!1;return p=h.majorTicksDec===0?Math.round(u).toString():u.toFixed(h.majorTicksDec),h.majorTicksInt>1?(w=~p.indexOf("."),~p.indexOf("-")?"-"+[h.majorTicksInt+h.majorTicksDec+2+(w?1:0)-p.length].join("0")+p.replace("-",""):[h.majorTicksInt+h.majorTicksDec+1+(w?1:0)-p.length].join("0")+p):p}function k(u){return u*Math.PI/180}function x(u,h){return{x:-u*Math.sin(h),y:u*Math.cos(h)}}function D(u,h,p,w){var C=!(arguments.length>4&&arguments[4]!==void 0)||arguments[4],E=arguments.length>5&&arguments[5]!==void 0?arguments[5]:0,O=u.createLinearGradient(C?0:E,C?E:0,C?0:w,C?w:0);return O.addColorStop(0,h),O.addColorStop(1,p),O}function F(u,h){h.needleShadow&&(u.shadowOffsetX=2,u.shadowOffsetY=2,u.shadowBlur=10,u.shadowColor=h.colorNeedleShadowDown)}function $(u,h,p){return u["font"+h+"Style"]+" "+u["font"+h+"Weight"]+" "+u["font"+h+"Size"]*p+"px "+u["font"+h]}function se(u){u.shadowOffsetX=null,u.shadowOffsetY=null,u.shadowBlur=null,u.shadowColor="",u.strokeStyle=null,u.lineWidth=0,u.save()}function ke(u,h,p,w){h.valueTextShadow&&(u.shadowOffsetX=p,u.shadowOffsetY=p,u.shadowBlur=w,u.shadowColor=h.colorValueTextShadow)}function Ye(u,h,p,w,C,E){if(h.valueBox){se(u);var O=h.valueDec?1+h.valueDec:0,N="9".repeat(Math.max.apply(null,[String(parseInt(p)).length+O].concat(h.majorTicks.map(function(_e){return String(parseInt(_e,10)).length+O})))),R=h.valueText||m(p,h),W=E/200,j=E/100,q=.4*j,J=1.2*j;u.font=$(h,"Value",W),ke(u,h,q,J);var ae=u.measureText(h.valueText?R:"-"+m(Number(N),h)).width;se(u);var me=parseFloat(h.fontValueSize)*W+q+J,Ie=j*parseFloat(h.valueBoxStroke),ve=2*E-2*Ie,We=ae+10*j,Be=1.1*me+q+J,ze=j*h.valueBoxBorderRadius,he=(parseFloat(h.valueBoxWidth)||0)/100*ve;he>We&&(We=he),We>ve&&(We=ve);var Ce=w-We/2,ye=C-Be/2,re=C-5.75*j;if(u.beginPath(),ze?c(u,Ce,ye,We,Be,ze):u.rect(Ce,ye,We,Be),Ie){var be=u.createRadialGradient(w,re,10*j,w,re,20*j);be.addColorStop(0,h.colorValueBoxRect),be.addColorStop(1,h.colorValueBoxRectEnd),u.strokeStyle=be,u.lineWidth=Ie,u.stroke()}h.colorValueBoxShadow&&(u.shadowBlur=1.2*j,u.shadowColor=h.colorValueBoxShadow),h.colorValueBoxBackground&&(u.fillStyle=h.colorValueBoxBackground,u.fill()),u.closePath(),u.restore(),ke(u,h,q,J),u.fillStyle=h.colorValueText,u.textAlign="center",u.textBaseline="alphabetic",u.fillText(R,Ce+We/2,C+Be/2-me/3),u.restore()}}function Ke(u){var h=u.value,p=u.minValue,w=u.maxValue,C=.01*(w-p);return{normal:h<p?p:h>w?w:h,indented:h<p?p-C:h>w?w+C:h}}function it(u,h,p,w,C){p.beginPath(),p.arc(0,0,Ot(u),0,2*nn,!0),p.lineWidth=h,p.strokeStyle=C?Z.linearGradient(p,w,C,u):w,p.stroke(),p.closePath()}function ce(u,h){var p=Ft.pixelRatio;return u.maxRadius||(u.maxRadius=u.max-h.borderShadowWidth-h.borderOuterWidth*p-h.borderMiddleWidth*p-h.borderInnerWidth*p+(h.borderOuterWidth?.5:0)+(h.borderMiddleWidth?.5:0)+(h.borderInnerWidth?.5:0)),u.maxRadius}function mt(u,h){function p(q,J,ae,me,Ie,ve){return J&&(!ve&&h.borderShadowWidth&&(ae.save(),ae.shadowBlur=h.borderShadowWidth,ae.shadowColor=h.colorBorderShadow),it(q,J*w,ae,me,Ie),!ve&&h.borderShadowWidth&&(ve=!0,ae.restore())),ve}var w=Ft.pixelRatio,C=h.borderShadowWidth*w,E=u.max-C-h.borderOuterWidth*w/2,O=E-h.borderOuterWidth*w/2-h.borderMiddleWidth*w/2+.5,N=O-h.borderMiddleWidth*w/2-h.borderInnerWidth*w/2+.5,R=ce(u,h),W=void 0,j=!1;u.save(),j=p(E,h.borderOuterWidth,u,h.colorBorderOuter,h.colorBorderOuterEnd,j),j=p(O,h.borderMiddleWidth,u,h.colorBorderMiddle,h.colorBorderMiddleEnd,j),j=p(N,h.borderInnerWidth,u,h.colorBorderInner,h.colorBorderInnerEnd,j),!j&&h.borderShadowWidth&&(u.shadowBlur=h.borderShadowWidth,u.shadowColor=h.colorBorderShadow),u.beginPath(),u.arc(0,0,Ot(R),0,2*nn,!0),h.colorPlateEnd?(W=u.createRadialGradient(0,0,R/2,0,0,R),W.addColorStop(0,h.colorPlate),W.addColorStop(1,h.colorPlateEnd)):W=h.colorPlate,u.fillStyle=W,u.fill(),u.closePath(),u.restore()}function dt(u,h){if(h.highlights!=="false"&&h.highlights.length&&h.highlightsWidth!==0){var p=u.max*(parseFloat(h.highlightsWidth)||0)/100,w=Ot(pt(u,h)-p/2),C=h.highlights.length,E=(h.maxValue-h.minValue)/h.ticksAngle;u.save();for(var O=0;O<C;O++){var N=h.highlights[O];u.lineWidth=p,u.lineCap=h.highlightsLineCap,u.strokeStyle=N.color,u.beginPath(),u.rotate(En),u.arc(0,0,w,Z.radians(h.startAngle+(N.from-h.minValue)/E),Z.radians(h.startAngle+(N.to-h.minValue)/E),!1),u.stroke(),u.closePath(),u.restore(),u.save()}u.restore()}}function qt(u,h){var p=pt(u,h),w=void 0,C=void 0,E=void 0,O=0,N=Math.abs(h.minorTicks)||0,R=h.ticksAngle/(h.maxValue-h.minValue);h.exactTicks?(C=h.maxValue-h.minValue,w=N?C/N:0,O=(It.mod(h.majorTicks[0],N)||0)*R):w=N*(h.majorTicks.length-1),u.lineWidth=Ft.pixelRatio,u.strokeStyle=h.colorMinorTicks||h.colorStrokeTicks,u.save();for(var W=0;W<w;++W)(E=h.startAngle+O+W*(h.ticksAngle/w))<=h.ticksAngle+h.startAngle&&(u.rotate(Z.radians(E)),u.beginPath(),u.moveTo(0,p),u.lineTo(0,p-.075*u.max),Sn(u));u.restore()}function pt(u,h){var p=u.max/100;return ce(u,h)-5*p-(h.barWidth?2*(parseFloat(h.barStrokeWidth)||0)+((parseFloat(h.barWidth)||0)+5)*p:0)}function ft(u,h){Z.prepareTicks(h);var p=Ot(pt(u,h)),w=void 0,C=h.majorTicks.length,E=Ft.pixelRatio;u.lineWidth=2*E,w=h.colorMajorTicks instanceof Array?h.colorMajorTicks:new Array(C).fill(h.colorStrokeTicks||h.colorMajorTicks);for(var O=0;O<C;++O)u.save(),u.strokeStyle=w[O],u.rotate(Z.radians(Ci(h,h.exactTicks?h.majorTicks[O]:O,C))),u.beginPath(),u.moveTo(0,p),u.lineTo(0,p-.15*u.max),u.stroke(),u.closePath(),u.restore();h.strokeTicks&&(u.save(),u.strokeStyle=h.colorStrokeTicks||w[0],u.rotate(En),u.beginPath(),u.arc(0,0,p,Z.radians(h.startAngle),Z.radians(h.startAngle+h.ticksAngle),!1),u.stroke(),u.closePath(),u.restore())}function Ci(u,h,p){if(u.exactTicks){var w=u.ticksAngle/(u.maxValue-u.minValue);return u.startAngle+w*(h-u.minValue)}return u.startAngle+h*(u.ticksAngle/(p-1))}function Sn(u){u.stroke(),u.restore(),u.closePath(),u.save()}function Q(u,h){var p=pt(u,h)-.15*u.max,w={},C=0,E=h.majorTicks.length,O=h.animationTarget!=="needle",N=h.colorNumbers instanceof Array?h.colorNumbers:new Array(E).fill(h.colorNumbers),R=O?-(h.value-h.minValue)/(h.maxValue-h.minValue)*h.ticksAngle:0;for(O&&(u.save(),u.rotate(-Z.radians(R))),u.font=Z.font(h,"Numbers",u.max/200),u.lineWidth=0,u.textAlign="center",u.textBaseline="middle";C<E;++C){var W=R+Ci(h,h.exactTicks?h.majorTicks[C]:C,E),j=u.measureText(h.majorTicks[C]).width,q=h.fontNumbersSize,J=Math.sqrt(j*j+q*q)/2,ae=Z.radialPoint(p-J-h.numbersMargin/100*u.max,Z.radians(W));W===360&&(W=0),w[W]||(w[W]=!0,u.fillStyle=N[C],u.fillText(h.majorTicks[C],ae.x,ae.y))}O&&u.restore()}function ie(u,h){h.title&&(u.save(),u.font=Z.font(h,"Title",u.max/200),u.fillStyle=h.colorTitle,u.textAlign="center",u.fillText(h.title,0,-u.max/4.25,.8*u.max),u.restore())}function oe(u,h){h.units&&(u.save(),u.font=Z.font(h,"Units",u.max/200),u.fillStyle=h.colorUnits,u.textAlign="center",u.fillText(Z.formatContext(h,h.units),0,u.max/3.25,.8*u.max),u.restore())}function Oe(u,h){if(h.needle){var p=h.animationTarget!=="needle",w=h.ticksAngle<360?Z.normalizedValue(h).indented:h.value,C=p?h.startAngle:h.startAngle+(w-h.minValue)/(h.maxValue-h.minValue)*h.ticksAngle;h.barStartPosition==="right"&&(C=h.startAngle+h.ticksAngle-(w-h.minValue)/(h.maxValue-h.minValue)*h.ticksAngle);var E=ce(u,h),O=Ot(E/100*h.needleCircleSize),N=Ot(E/100*h.needleCircleSize*.75),R=Ot(E/100*h.needleEnd),W=Ot(h.needleStart?E/100*h.needleStart:0),j=E/100*h.needleWidth,q=E/100*h.needleWidth/2,J=Ft.pixelRatio;u.save(),Z.drawNeedleShadow(u,h),u.rotate(Z.radians(C)),u.fillStyle=Z.linearGradient(u,h.colorNeedle,h.colorNeedleEnd,R-W),h.needleType==="arrow"?(u.beginPath(),u.moveTo(-q,-W),u.lineTo(-j,0),u.lineTo(-1*J,R),u.lineTo(J,R),u.lineTo(j,0),u.lineTo(q,-W),u.closePath(),u.fill(),u.beginPath(),u.lineTo(-.5*J,R),u.lineTo(-1*J,R),u.lineTo(-j,0),u.lineTo(-q,-W),u.lineTo(q/2*J-2*J,-W),u.closePath(),u.fillStyle=h.colorNeedleShadowUp,u.fill()):(u.beginPath(),u.moveTo(-q,R),u.lineTo(-q,W),u.lineTo(q,W),u.lineTo(q,R),u.closePath(),u.fill()),u.restore(),h.needleCircleSize&&(u.save(),Z.drawNeedleShadow(u,h),h.needleCircleOuter&&(u.beginPath(),u.arc(0,0,O,0,2*nn,!0),u.fillStyle=Z.linearGradient(u,h.colorNeedleCircleOuter,h.colorNeedleCircleOuterEnd,O),u.fill(),u.closePath()),h.needleCircleInner&&(u.beginPath(),u.arc(0,0,N,0,2*nn,!0),u.fillStyle=Z.linearGradient(u,h.colorNeedleCircleInner,h.colorNeedleCircleInnerEnd,N),u.fill(),u.closePath()),u.restore())}}function nt(u,h,p){Z.drawValueBox(u,h,p,0,u.max-.33*u.max,u.max)}function gt(u){var h=u.startAngle,p=u.startAngle+u.ticksAngle,w=h,C=h+(Z.normalizedValue(u).normal-u.minValue)/(u.maxValue-u.minValue)*u.ticksAngle;if(u.barStartPosition==="middle"){var E=.5*(u.minValue+u.maxValue);u.value<E?(w=180-(E-Z.normalizedValue(u).normal)/(u.maxValue-u.minValue)*u.ticksAngle,C=180):(w=180,C=180+(Z.normalizedValue(u).normal-E)/(u.maxValue-u.minValue)*u.ticksAngle)}else u.barStartPosition==="right"&&(w=p-C+h,C=p);return{startAngle:w,endAngle:C}}function vt(u,h){var p=u.max/100,w=ce(u,h)-5*p,C=parseFloat(h.barStrokeWidth+"")||0,E=(parseFloat(h.barWidth+"")||0)*p,O=w-2*C-E,N=(w-O)/2,R=O+N,W=C/R,j=h.startAngle,q=h.startAngle+h.ticksAngle;if(u.save(),u.rotate(En),C&&(u.beginPath(),u.arc(0,0,R,Z.radians(j)-W,Z.radians(q)+W,!1),u.strokeStyle=h.colorBarStroke,u.lineWidth=2*N,u.stroke(),u.closePath()),E&&(u.beginPath(),u.arc(0,0,R,Z.radians(j),Z.radians(q),!1),u.strokeStyle=h.colorBar,u.lineWidth=E,u.stroke(),u.closePath(),h.barShadow&&(u.save(),u.beginPath(),u.arc(0,0,w,Z.radians(j),Z.radians(q),!1),u.clip(),u.beginPath(),u.strokeStyle=h.colorBar,u.lineWidth=1,u.shadowBlur=h.barShadow,u.shadowColor=h.colorBarShadow,u.shadowOffsetX=0,u.shadowOffsetY=0,u.arc(0,0,w,Z.radians(h.startAngle),Z.radians(h.startAngle+h.ticksAngle),!1),u.stroke(),u.closePath(),u.restore()),h.barProgress)){var J=gt(h),ae=J.startAngle,me=J.endAngle;u.beginPath(),u.arc(0,0,R,Z.radians(ae),Z.radians(me),!1),u.strokeStyle=h.colorBarProgress,u.lineWidth=E,u.stroke(),u.closePath()}u.restore()}function Tt(u){return u.options.animatedValue?u.options.value:u.value}function Xe(u,h,p,w,C,E,O,N){u.beginPath(),u.fillStyle=N?Z.linearGradient(u,O,N,C>E?C:E,E>C,C>E?p:w):O,h>0?Z.roundRect(u,p,w,C,E,h):u.rect(p,w,C,E),u.fill(),u.closePath()}function Cn(u,h,p,w,C,E,O,N,R){u.beginPath(),u.lineWidth=h,u.strokeStyle=R?Z.linearGradient(u,N,R,O,!0,C):N,p>0?Z.roundRect(u,w,C,E,O,p):u.rect(w,C,E,O),u.stroke(),u.closePath()}function ct(u,h,p,w,C,E){function O(_e,xe,$e,_t){return _e&&(!_t&&h.borderShadowWidth&&(u.save(),u.shadowBlur=h.borderShadowWidth,u.shadowColor=h.colorBorderShadow),Cn(u,_e*N,R,p+_e*N/2-re,w+_e*N/2-re,W,ae,xe,$e),re+=.5*N,!_t&&h.borderShadowWidth&&(_t=!0,u.restore())),_t}var N=Ft.pixelRatio,R=h.borderRadius*N,W=C-h.borderShadowWidth-h.borderOuterWidth*N,j=W-h.borderOuterWidth*N-h.borderMiddleWidth*N,q=j-h.borderMiddleWidth*N-h.borderInnerWidth*N,J=q-h.borderInnerWidth*N,ae=E-h.borderShadowWidth-h.borderOuterWidth*N,me=ae-h.borderOuterWidth*N-h.borderMiddleWidth*N,Ie=me-h.borderMiddleWidth*N-h.borderInnerWidth*N,ve=Ie-h.borderInnerWidth*N,We=p-(j-W)/2,Be=We-(q-j)/2,ze=Be-(J-q)/2,he=w-(me-ae)/2,Ce=he-(Ie-me)/2,ye=Ce-(ve-Ie)/2,re=0,be=!1;return u.save(),be=O(h.borderOuterWidth,h.colorBorderOuter,h.colorBorderOuterEnd,be),be=O(h.borderMiddleWidth,h.colorBorderMiddle,h.colorBorderMiddleEnd,be),be=O(h.borderInnerWidth,h.colorBorderInner,h.colorBorderInnerEnd,be),!be&&h.borderShadowWidth&&(u.shadowBlur=h.borderShadowWidth,u.shadowColor=h.colorBorderShadow),Xe(u,R,ze,ye,J+2*re,ve+2*re,h.colorPlate,h.colorPlateEnd),u.restore(),[ze,ye,J,ve]}function Ze(u,h,p,w,C,E){var O=Ft.pixelRatio,N=E>=C,R=N?.85*C:E,W=N?E:C;p=N?Se(p+(C-R)/2):p;var j=!!h.title,q=!!h.units,J=!!h.valueBox,ae=void 0,me=void 0,Ie=void 0;N?(me=Se(.05*W),ae=Se(.075*W),Ie=Se(.11*W),j&&(W-=ae,w+=ae),q&&(W-=me),J&&(W-=Ie)):(me=ae=Se(.15*R),j&&(R-=ae,w+=ae),q&&(R-=me));var ve=2*h.barStrokeWidth,We=h.barBeginCircle?Se(R*h.barBeginCircle/200-ve/2):0,Be=Se(R*h.barWidth/100-ve),ze=Se(W*h.barLength/100-ve),he=Se((W-ze)/2),Ce=Se(p+(N?R/2:he+We)),ye=Se(w+(N?W-he-We+ve/2:R/2)),re=!N||h.hasLeft&&h.hasRight?0:(h.hasRight?-1:1)*h.ticksWidth/100*R,be=N||h.hasLeft&&h.hasRight?0:(h.hasRight?-1:1)*h.ticksWidth/100*R;return u.barDimensions={isVertical:N,width:R,length:W,barWidth:Be,barLength:ze,strokeWidth:ve,barMargin:he,radius:We,pixelRatio:O,barOffset:null,titleMargin:j?ae:0,unitsMargin:q?me:0,get ticksLength(){return this.barLength-this.barOffset-this.strokeWidth},X:p+re,Y:w+be,x0:Ce+re,y0:ye+be,baseX:p,baseY:w,ticksPadding:h.ticksPadding/100},u.barDimensions}function Fe(u,h,p,w,C,E,O){var N=Ze(u,h,w,C,E,O),R=N.isVertical,W=N.width,j=N.barWidth,q=N.barLength,J=N.strokeWidth,ae=N.barMargin,me=N.radius,Ie=N.x0,ve=N.y0,We=N.X,Be=N.Y,ze=q;u.save(),u.beginPath();var he=null;if(h.barBeginCircle){var Ce=Z.radians(R?270:0),ye=Math.asin(j/2/me),re=Math.cos(ye),be=Math.sin(ye),_e=Ie+(R?me*be:me*re-J/2),xe=R?ve-me*re:ve+me*be,$e=Ot(R?xe-ve:_e-Ie);he=Se($e+me);var _t=R?Se(Ie-me*be):_e,wt=R?xe:Se(ve-me*be);p==="progress"&&(q=he+(q-he)*(Z.normalizedValue(h).normal-h.minValue)/(h.maxValue-h.minValue));var kt=Se(_e+q-he+J/2),Xt=Se(xe-q+he-J/2);u.arc(Ie,ve,me,Ce+ye,Ce-ye),R?(u.moveTo(_e,wt),u.lineTo(_e,Xt),u.lineTo(_t,Xt),u.lineTo(_t,wt)):(u.moveTo(_e,wt),u.lineTo(kt,wt),u.lineTo(kt,xe),u.lineTo(_e,xe))}else{var An=Se(R?We+(W-j)/2:We+ae),Pn=Se(R?Be+q+ae:Be+(W-j)/2);p==="progress"&&(q*=(h.value-h.minValue)/(h.maxValue-h.minValue)),R?u.rect(An,Pn,j,-q):u.rect(An,Pn,q,j)}p!=="progress"&&h.barStrokeWidth&&(u.lineWidth=J,u.strokeStyle=h.colorBarStroke,u.stroke()),p!=="progress"&&h.colorBar?(u.fillStyle=h.colorBarEnd?Z.linearGradient(u,h.colorBar,h.colorBarEnd,q,R,R?Be:We):h.colorBar,u.fill()):p==="progress"&&h.colorBarProgress&&(u.fillStyle=h.colorBarProgressEnd?Z.linearGradient(u,h.colorBarProgress,h.colorBarProgressEnd,ze,R,R?Be:We):h.colorBarProgress,u.fill()),u.closePath(),u.restore(),h.barBeginCircle&&(u.barDimensions.radius+=J),u.barDimensions.barOffset=he,u.barDimensions.barWidth+=J,u.barDimensions.barLength+=J}function qe(u,h,p,w,C,E){Fe(u,h,"",p,w,C,E)}function Yt(u,h){return h.needleSide!==u||h.tickSide!==u||h.numberSide!==u}function li(u,h,p,w,C,E){h.barProgress&&Fe(u,h,"progress",p,w,C,E)}function en(u,h){var p=u.barDimensions,w=p.isVertical,C=p.width,E=p.length,O=p.barWidth,N=p.barOffset,R=p.barMargin,W=p.X,j=p.Y,q=p.ticksLength,J=p.ticksPadding,ae=C*(parseFloat(h.highlightsWidth)||0)/100;if(h.highlights&&ae){var me=h.tickSide!=="right",Ie=h.tickSide!=="left",ve=0,We=h.highlights.length,Be=(C-O)/2,ze=h.maxValue-h.minValue,he=Se(w?W+Be:W+R+N),Ce=ae,ye=w?j+E-R-N:j+Be,re=Se((h.ticksWidth/100+J)*C)+(ae-h.ticksWidth/100*C),be=Se(O+J*C);for(u.save();ve<We;ve++){var _e=h.highlights[ve],xe=q*Ot(h.minValue-_e.from)/ze,$e=q*Ot((_e.to-_e.from)/ze);u.beginPath(),u.fillStyle=_e.color,w?(me&&u.rect(he-re,ye-xe,Ce,-$e),Ie&&u.rect(he+be,ye-xe,Ce,-$e)):(me&&u.rect(he+xe,ye-re,$e,Ce),Ie&&u.rect(he+xe,ye+be,$e,Ce)),u.fill(),u.closePath()}u.restore()}}function fi(u,h,p,w,C){u.beginPath(),u.moveTo(h,p),u.lineTo(w,C),u.stroke(),u.closePath()}function Pi(u,h,p,w,C,E,O,N,R){var W=u.barDimensions,j=W.isVertical,q=W.length,J=W.barWidth,ae=W.barOffset,me=W.barMargin,Ie=W.pixelRatio,ve=W.width,We=W.X,Be=W.Y,ze=W.ticksLength,he=W.ticksPadding,Ce=(ve-J)/2,ye=void 0,re=void 0,be=0,_e=p.length,xe=void 0,$e=R*ve,_t=Ce-he*ve,wt=Ce+J+$e+he*ve,kt=h instanceof Array?h:new Array(p.length).fill(h);u.save(),u.lineWidth=N*Ie;for(var Xt=ze/(C-w);be<_e;be++)xe=p[be],u.strokeStyle=kt[be],j?(re=Be+q-me-ae+(w-xe)*Xt,E&&(ye=We+_t,fi(u,ye,re,Se(ye-$e),re)),O&&(ye=We+wt,fi(u,ye,re,Se(ye-$e),re))):(ye=We+me+ae-(w-xe)*Xt,E&&(re=Be+_t,fi(u,ye,re,ye,Se(re-$e))),O&&(re=Be+wt,fi(u,ye,Se(re),ye,re-$e)));u.restore()}function $t(u,h){var p=Z.prepareTicks(h),w=vr(p,2),C=w[0],E=w[1],O=2,N=(h.maxValue-h.minValue)/(h.majorTicks.length-1),R=h.colorMajorTicks instanceof Array?h.colorMajorTicks:new Array(h.majorTicks.length).fill(h.colorStrokeTicks||h.colorMajorTicks);if(Pi(u,R,h.exactTicks?h.majorTicks:h.majorTicks.map(function($e,_t){return h.minValue+N*_t}),h.minValue,h.maxValue,C,E,O,h.ticksWidth/100),h.strokeTicks){var W=u.barDimensions,j=W.isVertical,q=W.length,J=W.width,ae=W.barWidth,me=W.barMargin,Ie=W.barOffset,ve=W.X,We=W.Y,Be=W.ticksLength,ze=W.pixelRatio,he=W.ticksPadding,Ce=(J-ae)/2+ae+he*J,ye=(J-ae)/2-he*J,re=void 0,be=void 0,_e=void 0,xe=void 0;u.strokeStyle=h.colorStrokeTicks||R[0],O*=ze,j?(be=We+q-me-Ie+O/2,xe=be-Be-O,C&&(_e=re=Se(ve+ye),Qt(u,re,be,_e,xe)),E&&(_e=re=Se(ve+Ce),Qt(u,re,be,_e,xe))):(re=ve+me+Ie-O/2,_e=re+Be+O,C&&(xe=be=Se(We+ye),Qt(u,re,be,_e,xe)),E&&(xe=be=Se(We+Ce),Qt(u,re,be,_e,xe)))}}function Qt(u,h,p,w,C){u.beginPath(),u.moveTo(h,p),u.lineTo(w,C),u.stroke(),u.closePath()}function Hr(u,h){var p=Z.prepareTicks(h),w=vr(p,2),C=w[0],E=w[1],O=[],N=h.minValue,R=Math.abs(h.minorTicks)||0,W=R?(h.maxValue-h.minValue)/(R*(h.majorTicks.length-1)):0;if(R)if(h.exactTicks)for(var j=It.mod(h.majorTicks[0],R)||0;N<h.maxValue;N+=R)j+N<h.maxValue&&O.push(j+N);else for(;N<h.maxValue;N+=W)O.push(N);Pi(u,h.colorMinorTicks||h.colorStrokeTicks,O,h.minValue,h.maxValue,C,E,1,h.ticksWidthMinor/100)}function Ur(u,h){var p=u.barDimensions,w=p.isVertical,C=p.length,E=p.width,O=p.barWidth,N=p.barMargin,R=p.barOffset,W=p.X,j=p.Y,q=p.ticksLength,J=p.ticksPadding,ae=h.maxValue-h.minValue,me=ae/(h.majorTicks.length-1),Ie=h.exactTicks?h.majorTicks:h.majorTicks.map(function(kt,Xt){return h.minValue+me*Xt}),ve=Ie.length,We=h.numberSide!=="right",Be=h.numberSide!=="left",ze=h.fontNumbersSize*E/200,he=0,Ce=(h.ticksWidth/100+2*J)*E,ye=(E-O)/2-Ce,re=(E-O)/2+O+Ce,be=void 0,_e=void 0,xe=void 0,$e=void 0,_t=h.colorNumbers instanceof Array?h.colorNumbers:new Array(ve).fill(h.colorNumbers),wt=h.numbersMargin/100*E;for(u.font=Z.font(h,"Numbers",E/200),u.lineWidth=0,u.textAlign="center";he<ve;he++)u.fillStyle=_t[he],$e=h.majorTicks[he],xe=h.exactTicks?q*((Ie[he]-h.minValue)/ae):he*q/(ve-1),w?(_e=j+C-N-R-xe+ze/3,We&&(u.textAlign="right",u.fillText($e,W+ye-wt,_e)),Be&&(u.textAlign="left",u.fillText($e,W+re+wt,_e))):(u.measureText($e).width,be=W+N+R+xe,We&&u.fillText($e,be,j+ye-wt),Be&&u.fillText($e,be,j+re+ze+wt))}function xn(u,h){if(h.title){var p=u.barDimensions,w=p.isVertical,C=p.width,E=p.length,O=p.baseX,N=p.baseY,R=p.titleMargin,W=h.fontTitleSize*C/200,j=Se(O+(w?C:E)/2),q=Se(N+R/2-(w?W:W/2)-.025*(w?E:C));u.save(),u.textAlign="center",u.fillStyle=h.colorTitle,u.font=Z.font(h,"Title",C/200),u.lineWidth=0,u.fillText(h.title,j,q,w?C:E),u.restore()}}function Mt(u,h){if(h.units){var p=u.barDimensions,w=p.isVertical,C=p.width,E=p.length,O=p.baseX,N=p.baseY,R=p.unitsMargin,W=h.fontUnitsSize*C/200,j=Se(O+(w?C:E)/2),q=Se(N+(w?E:C)+R/2-W/2);u.save(),u.textAlign="center",u.fillStyle=h.colorUnits,u.font=Z.font(h,"Units",C/200),u.lineWidth=0,u.fillText(Z.formatContext(h,h.units),j,q,w?C:E),u.restore()}}function pa(u,h){if(h.needle){var p=u.barDimensions,w=p.isVertical,C=p.width,E=p.length,O=p.barWidth,N=p.barOffset,R=p.barMargin,W=p.ticksLength,j=p.X,q=p.Y,J=p.ticksPadding,ae=h.needleSide!=="right",me=h.needleSide!=="left",Ie=W*(Z.normalizedValue(h).indented-h.minValue)/(h.maxValue-h.minValue),ve=(h.ticksWidth/100+J)*C,We=O/2+ve,Be=We*(h.needleEnd/100),ze=void 0,he=void 0,Ce=void 0,ye=void 0,re=h.needleType.toLowerCase()==="arrow"?ga:fa,be=(C-O)/2,_e=We*(h.needleStart/100),xe=be-ve-_e,$e=be+O+ve+_e;u.save(),Z.drawNeedleShadow(u,h),w?(Ce=Se(q+E-R-N-Ie),ae&&(ze=Se(j+xe),he=ze+Be,re(u,h,ze,Ce,he,Ce,Be)),me&&(ze=Se(j+$e),he=ze-Be,re(u,h,ze,Ce,he,Ce,Be,!0))):(ze=Se(j+R+N+Ie),ae&&(Ce=Se(q+xe),ye=Ce+Be,re(u,h,ze,Ce,ze,ye,Be)),me&&(Ce=Se(q+$e),ye=Ce-Be,re(u,h,ze,Ce,ze,ye,Be,!0))),u.restore()}}function Gr(u,h,p,w){return h.colorNeedleEnd?Z.linearGradient(u,w?h.colorNeedleEnd:h.colorNeedle,w?h.colorNeedle:h.colorNeedleEnd,p,!u.barDimensions.isVertical):h.colorNeedle}function fa(u,h,p,w,C,E,O,N){u.lineWidth=h.needleWidth,u.strokeStyle=Gr(u,h,O,N),u.beginPath(),u.moveTo(p,w),u.lineTo(C,E),u.stroke(),u.closePath()}function ga(u,h,p,w,C,E,O,N){var R=Se(.4*O),W=O-R,j=p===C,q=h.needleWidth/2;u.fillStyle=Gr(u,h,O,N),u.beginPath(),j?(w>E&&(W*=-1),u.moveTo(p-q,w),u.lineTo(p+q,w),u.lineTo(p+q,w+W),u.lineTo(p,E),u.lineTo(p-q,w+W),u.lineTo(p-q,w)):(p>C&&(W*=-1),u.moveTo(p,w-q),u.lineTo(p,w+q),u.lineTo(p+W,w+q),u.lineTo(C,w),u.lineTo(p+W,w-q),u.lineTo(p,w-q)),u.fill(),u.closePath()}function va(u,h,p,w,C,E,O){var N=(parseFloat(h.fontValueSize)||0)*E/200,R=(.11*O-N)/2;u.barDimensions.isVertical&&Z.drawValueBox(u,h,p,w+E/2,C+O-N-R,E)}var vr=function(){function u(h,p){var w=[],C=!0,E=!1,O=void 0;try{for(var N,R=h[Symbol.iterator]();!(C=(N=R.next()).done)&&(w.push(N.value),!p||w.length!==p);C=!0);}catch(W){E=!0,O=W}finally{try{!C&&R.return&&R.return()}finally{if(E)throw O}}return w}return function(h,p){if(Array.isArray(h))return h;if(Symbol.iterator in Object(h))return u(h,p);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),Tn=function u(h,p,w){h===null&&(h=Function.prototype);var C=Object.getOwnPropertyDescriptor(h,p);if(C===void 0){var E=Object.getPrototypeOf(h);return E===null?void 0:u(E,p,w)}if("value"in C)return C.value;var O=C.get;if(O!==void 0)return O.call(w)},jr=function u(h,p,w,C){var E=Object.getOwnPropertyDescriptor(h,p);if(E===void 0){var O=Object.getPrototypeOf(h);O!==null&&u(O,p,w,C)}else if("value"in E&&E.writable)E.value=w;else{var N=E.set;N!==void 0&&N.call(C,w)}return w},gi=function(){function u(h,p){for(var w=0;w<p.length;w++){var C=p[w];C.enumerable=C.enumerable||!1,C.configurable=!0,"value"in C&&(C.writable=!0),Object.defineProperty(h,C.key,C)}}return function(h,p,w){return p&&u(h.prototype,p),w&&u(h,w),h}}(),xi=null,yr=function(){function u(){i(this,u),this._events={},this.addListener=this.on,this.removeListener=this.off}return gi(u,[{key:"emit",value:function(h){if(this._events[h]){for(var p=0,w=this._events[h].length,C=arguments.length,E=Array(C>1?C-1:0),O=1;O<C;O++)E[O-1]=arguments[O];for(;p<w;p++)this._events[h][p]&&this._events[h][p].apply(this,E)}}},{key:"once",value:function(h){for(var p=arguments.length,w=Array(p>1?p-1:0),C=1;C<p;C++)w[C-1]=arguments[C];for(var E=0,O=w.length,N=this;E<O;E++)(function(){var R=w[E],W=function j(){N.off(h,j),R.apply(N,arguments)};w[E]=W})();this.on.apply(this,[h].concat(w))}},{key:"on",value:function(h){this._events[h]||(this._events[h]=[]);for(var p=0,w=arguments.length<=1?0:arguments.length-1;p<w;p++)this._events[h].push(arguments.length<=p+1?void 0:arguments[p+1])}},{key:"off",value:function(h){if(this._events[h])for(var p=0,w=arguments.length<=1?0:arguments.length-1;p<w;p++)for(var C=arguments.length<=p+1?void 0:arguments[p+1],E=void 0;~(E=this._events[h].indexOf(C));)this._events[h].splice(E,1)}},{key:"removeAllListeners",value:function(h){delete this._events[h]}},{key:"listeners",get:function(){return this._events}}]),u}(),qr=o("requestAnimationFrame")||function(u){return setTimeout(function(){return u(new Date().getTime())},1e3/60)},tn={linear:function(u){return u},quad:function(u){return Math.pow(u,2)},dequad:function(u){return 1-tn.quad(1-u)},quint:function(u){return Math.pow(u,5)},dequint:function(u){return 1-Math.pow(1-u,5)},cycle:function(u){return 1-Math.sin(Math.acos(u))},decycle:function(u){return Math.sin(Math.acos(1-u))},bounce:function(u){return 1-tn.debounce(1-u)},debounce:function(u){for(var h=0,p=1;;h+=p,p/=2)if(u>=(7-4*h)/11)return-Math.pow((11-6*h-11*u)/4,2)+Math.pow(p,2)},elastic:function(u){return 1-tn.delastic(1-u)},delastic:function(u){return Math.pow(2,10*(u-1))*Math.cos(20*Math.PI*1.5/3*u)}},br=function(){function u(){var h=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"linear",p=arguments.length>1&&arguments[1]!==void 0?arguments[1]:250,w=arguments.length>2&&arguments[2]!==void 0?arguments[2]:function(){},C=arguments.length>3&&arguments[3]!==void 0?arguments[3]:function(){};if(i(this,u),this.duration=p,this.rule=h,this.draw=w,this.end=C,typeof this.draw!="function")throw new TypeError("Invalid animation draw callback:",w);if(typeof this.end!="function")throw new TypeError("Invalid animation end callback:",C)}return gi(u,[{key:"animate",value:function(h,p){var w=this;this.frame&&this.cancel();var C=window.performance&&window.performance.now?window.performance.now():o("animationStartTime")||Date.now();h=h||this.draw,p=p||this.end,this.draw=h,this.end=p,this.frame=qr(function(E){return a(E,h,C,tn[w.rule]||w.rule,w.duration,p,w)})}},{key:"cancel",value:function(){this.frame&&((o("cancelAnimationFrame")||function(h){})(this.frame),this.frame=null)}},{key:"destroy",value:function(){this.cancel(),this.draw=null,this.end=null}}]),u}();br.rules=tn;var Mi=function(){function u(h,p,w){i(this,u),this.options=h,this.element=p.toLowerCase(),this.type=u.toDashed(w),this.Type=r[w],this.mutationsObserved=!1,this.isObservable=!!window.MutationObserver,window.GAUGES_NO_AUTO_INIT||u.domReady(this.traverse.bind(this))}return gi(u,[{key:"isValidNode",value:function(h){return!(!h.tagName||h.tagName.toLowerCase()!==this.element||h.getAttribute("data-type")!==this.type)}},{key:"traverse",value:function(){for(var h=document.getElementsByTagName(this.element),p=0,w=h.length;p<w;p++)this.process(h[p]);this.isObservable&&!this.mutationsObserved&&(new MutationObserver(this.observe.bind(this)).observe(document.body,{childList:!0,subtree:!0,attributes:!0,characterData:!0,attributeOldValue:!0,characterDataOldValue:!0}),this.mutationsObserved=!0)}},{key:"observe",value:function(h){for(var p=0,w=h.length;p<w;p++){var C=h[p];if(C.type==="attributes"&&C.attributeName==="data-type"&&this.isValidNode(C.target)&&C.oldValue!==this.type)setTimeout(this.process.bind(this,C.target));else if(C.addedNodes&&C.addedNodes.length)for(var E=0,O=C.addedNodes.length;E<O;E++)setTimeout(this.process.bind(this,C.addedNodes[E]))}}},{key:"process",value:function(h){var p=this;if(!this.isValidNode(h))return null;var w=void 0,C=JSON.parse(JSON.stringify(this.options)),E=null;for(w in C)if(C.hasOwnProperty(w)){var O=u.toAttributeName(w),N=u.parse(h.getAttribute(O));N!=null&&(C[w]=N)}return C.renderTo=h,E=new this.Type(C),E.draw&&E.draw(),this.isObservable&&(E.observer=new MutationObserver(function(R){R.forEach(function(W){if(W.type==="attributes"){var j=W.attributeName.toLowerCase(),q=h.getAttribute(j).toLowerCase();if(j==="data-type"&&q&&q!==p.type)E.observer.disconnect(),delete E.observer,E.destroy&&E.destroy();else if(j.substr(0,5)==="data-"){var J=j.substr(5).split("-").map(function(me,Ie){return Ie?me.charAt(0).toUpperCase()+me.substr(1):me}).join(""),ae={};ae[J]=u.parse(h.getAttribute(W.attributeName)),J==="value"?E&&(E.value=ae[J]):E.update&&E.update(ae)}}})}),E.observer.observe(h,{attributes:!0})),E}}],[{key:"parse",value:function(h){if(h==="true")return!0;if(h==="false")return!1;if(h!=="undefined"){if(h==="null")return null;if(/^[-+#.\w\d\s]+(?:,[-+#.\w\d\s]*)+$/.test(h))return h.split(",");try{return JSON.parse(h)}catch{}return h}}},{key:"toDashed",value:function(h){for(var p=h.split(/(?=[A-Z])/),w=1,C=p.length,E=p[0].toLowerCase();w<C;w++)E+="-"+p[w].toLowerCase();return E}},{key:"toCamelCase",value:function(h){for(var p=!(arguments.length>1&&arguments[1]!==void 0)||arguments[1],w=h.split(/-/),C=0,E=w.length,O="";C<E;C++)O+=C||p?w[C][0].toUpperCase()+w[C].substr(1).toLowerCase():w[C].toLowerCase();return O}},{key:"toAttributeName",value:function(h){return"data-"+u.toDashed(h)}},{key:"domReady",value:function(h){if(/comp|inter|loaded/.test((window.document||{}).readyState+""))return h();window.addEventListener?window.addEventListener("DOMContentLoaded",h,!1):window.attachEvent&&window.attachEvent("onload",h)}}]),u}(),Ft=function(){function u(h,p,w){i(this,u),u.collection.push(this),this.width=p||0,this.height=w||0,this.element=h,this.init()}return gi(u,[{key:"init",value:function(){var h=u.pixelRatio;this.element.width=this.width*h,this.element.height=this.height*h,this.element.style.width=this.width+"px",this.element.style.height=this.height+"px",this.elementClone=this.element.cloneNode(!0),this.context=this.element.getContext("2d"),this.contextClone=this.elementClone.getContext("2d"),this.drawWidth=this.element.width,this.drawHeight=this.element.height,this.drawX=this.drawWidth/2,this.drawY=this.drawHeight/2,this.minSide=this.drawX<this.drawY?this.drawX:this.drawY,this.contextClone.translate(this.drawX,this.drawY),this.elementClone.initialized=!1,this.context.translate(this.drawX,this.drawY),this.context.max=this.contextClone.max=this.minSide,this.context.maxRadius=this.contextClone.maxRadius=null}},{key:"destroy",value:function(){var h=u.collection.indexOf(this);~h&&u.collection.splice(h,1),this.context.clearRect(-this.drawX,-this.drawY,this.drawWidth,this.drawHeight),this.context.max=null,delete this.context.max,this.context.maxRadius=null,delete this.context.maxRadius,this.context=null,this.contextClone=null,this.elementClone=null,this.element=null,this.onRedraw=null}},{key:"commit",value:function(){var h=u.pixelRatio;return h!==1&&this.contextClone.scale(h,h),this}},{key:"redraw",value:function(){return this.init(),this.onRedraw&&this.onRedraw(),this}}],[{key:"redraw",value:function(){for(var h=0,p=u.collection.length;h<p;h++)u.collection[h].redraw()}},{key:"pixelRatio",get:function(){return window.devicePixelRatio||1}}]),u}();Ft.collection=[],window.matchMedia&&window.matchMedia("screen and (min-resolution: 2dppx)").addListener(Ft.redraw);var Oi={renderTo:null,width:0,height:0,minValue:0,maxValue:100,value:0,units:!1,exactTicks:!1,majorTicks:[0,20,40,60,80,100],minorTicks:10,strokeTicks:!0,animatedValue:!1,animateOnInit:!1,title:!1,borders:!0,numbersMargin:1,listeners:null,valueInt:3,valueDec:2,majorTicksInt:1,majorTicksDec:0,animation:!0,animationDuration:500,animationRule:"cycle",colorPlate:"#fff",colorPlateEnd:"",colorMajorTicks:"#444",colorMinorTicks:"#666",colorStrokeTicks:"",colorTitle:"#888",colorUnits:"#888",colorNumbers:"#444",colorNeedle:"rgba(240,128,128,1)",colorNeedleEnd:"rgba(255,160,122,.9)",colorValueText:"#444",colorValueTextShadow:"rgba(0,0,0,0.3)",colorBorderShadow:"rgba(0,0,0,0.5)",colorBorderOuter:"#ddd",colorBorderOuterEnd:"#aaa",colorBorderMiddle:"#eee",colorBorderMiddleEnd:"#f0f0f0",colorBorderInner:"#fafafa",colorBorderInnerEnd:"#ccc",colorValueBoxRect:"#888",colorValueBoxRectEnd:"#666",colorValueBoxBackground:"#babab2",colorValueBoxShadow:"rgba(0,0,0,1)",colorNeedleShadowUp:"rgba(2,255,255,0.2)",colorNeedleShadowDown:"rgba(188,143,143,0.45)",colorBarStroke:"#222",colorBar:"#ccc",colorBarProgress:"#888",colorBarShadow:"#000",fontNumbers:"Arial",fontTitle:"Arial",fontUnits:"Arial",fontValue:"Arial",fontNumbersSize:20,fontTitleSize:24,fontUnitsSize:22,fontValueSize:26,fontNumbersStyle:"normal",fontTitleStyle:"normal",fontUnitsStyle:"normal",fontValueStyle:"normal",fontNumbersWeight:"normal",fontTitleWeight:"normal",fontUnitsWeight:"normal",fontValueWeight:"normal",needle:!0,needleShadow:!0,needleType:"arrow",needleStart:5,needleEnd:85,needleWidth:4,borderOuterWidth:3,borderMiddleWidth:3,borderInnerWidth:3,borderShadowWidth:3,valueBox:!0,valueBoxStroke:5,valueBoxWidth:0,valueText:"",valueTextShadow:!0,valueBoxBorderRadius:2.5,highlights:[{from:20,to:60,color:"#eee"},{from:60,to:80,color:"#ccc"},{from:80,to:100,color:"#999"}],highlightsWidth:15,highlightsLineCap:"butt",barWidth:20,barStrokeWidth:0,barProgress:!0,barShadow:0};l.prototype=Object.create(Array.prototype),l.prototype.constructor=l,l.prototype.get=function(u){if(typeof u=="string")for(var h=0,p=this.length;h<p;h++){var w=this[h].options.renderTo.tagName?this[h].options.renderTo:document.getElementById(this[h].options.renderTo||"");if(w.getAttribute("id")===u)return this[h]}else if(typeof u=="number")return this[u];return null};var _r="2.2.1",Se=Math.round,Ot=Math.abs,Ii=new l;Ii.version=_r;var It=function(u){function h(p){i(this,h);var w=e(this,(h.__proto__||Object.getPrototypeOf(h)).call(this)),C=w.constructor.name;if(C==="BaseGauge")throw new TypeError("Attempt to instantiate abstract class!");if(Ii.push(w),p.listeners&&Object.keys(p.listeners).forEach(function(O){(p.listeners[O]instanceof Array?p.listeners[O]:[p.listeners[O]]).forEach(function(N){w.on(O,N)})}),w.version=_r,w.type=r[C]||h,w.initialized=!1,p.minValue=parseFloat(p.minValue),p.maxValue=parseFloat(p.maxValue),p.value=parseFloat(p.value)||0,p.borders||(p.borderInnerWidth=p.borderMiddleWidth=p.borderOuterWidth=0),!p.renderTo)throw TypeError("Canvas element was not specified when creating the Gauge object!");var E=p.renderTo.tagName?p.renderTo:document.getElementById(p.renderTo);if(!(E instanceof HTMLCanvasElement))throw TypeError("Given gauge canvas element is invalid!");return p.width=parseFloat(p.width)||0,p.height=parseFloat(p.height)||0,p.width&&p.height||(p.width||(p.width=E.parentNode?E.parentNode.offsetWidth:E.offsetWidth),p.height||(p.height=E.parentNode?E.parentNode.offsetHeight:E.offsetHeight)),w.options=p||{},w.options.animateOnInit&&(w._value=w.options.value,w.options.value=w.options.minValue),w.canvas=new Ft(E,p.width,p.height),w.canvas.onRedraw=w.draw.bind(w),w.animation=new br(p.animationRule,p.animationDuration),w}return t(h,u),gi(h,[{key:"update",value:function(p){return Object.assign(this.options,this.type.configure(p||{})),this.canvas.width=this.options.width,this.canvas.height=this.options.height,this.animation.rule=this.options.animationRule,this.animation.duration=this.options.animationDuration,this.canvas.redraw(),this}},{key:"destroy",value:function(){var p=Ii.indexOf(this);~p&&Ii.splice(p,1),this.canvas.destroy(),this.canvas=null,this.animation.destroy(),this.animation=null,this.emit("destroy")}},{key:"draw",value:function(){return this.options.animateOnInit&&!this.initialized&&(this.value=this._value,this.initialized=!0,this.emit("init")),this.emit("render"),this}},{key:"value",set:function(p){var w=this;p=h.ensureValue(p,this.options.minValue);var C=this.options.value;if(p!==C)if(this.options.animation){if(this.animation.frame&&(this.options.value=this._value,this._value===p))return this.animation.cancel(),void delete this._value;this._value===void 0&&(this._value=p),this.emit("animationStart"),this.animation.animate(function(E){var O=C+(p-C)*E;w.options.animatedValue&&w.emit("value",O,w.value),w.options.value=O,w.draw(),w.emit("animate",E,w.options.value)},function(){w._value!==void 0&&(w.emit("value",w._value,w.value),w.options.value=w._value,delete w._value),w.draw(),w.emit("animationEnd"),w.animation.frame=null})}else this.emit("value",p,this.value),this.options.value=p,this.draw()},get:function(){return this._value===void 0?this.options.value:this._value}}],[{key:"configure",value:function(p){return p}},{key:"initialize",value:function(p,w){return new Mi(w,"canvas",p)}},{key:"fromElement",value:function(p){var w=Mi.toCamelCase(p.getAttribute("data-type")),C=p.attributes,E=0,O=C.length,N={};if(w){for(/Gauge$/.test(w)||(w+="Gauge");E<O;E++)N[Mi.toCamelCase(C[E].name.replace(/^data-/,""),!1)]=Mi.parse(C[E].value);new Mi(N,p.tagName,w).process(p)}}},{key:"ensureValue",value:function(p){var w=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0;return p=parseFloat(p),!isNaN(p)&&isFinite(p)||(p=parseFloat(w)||0),p}},{key:"mod",value:function(p,w){return(p%w+w)%w}},{key:"version",get:function(){return _r}}]),h}(yr);r!==void 0&&(r.BaseGauge=It,r.gauges=(window.document||{}).gauges=Ii);var ya=/{([_a-zA-Z]+[_a-zA-Z0-9]*)}/g,Z={roundRect:c,padValue:m,formatMajorTickNumber:y,radians:k,radialPoint:x,linearGradient:D,drawNeedleShadow:F,drawValueBox:Ye,verifyError:d,prepareTicks:s,font:$,normalizedValue:Ke,formatContext:f},nn=Math.PI,En=nn/2,Yr=Object.assign({},Oi,{ticksAngle:270,startAngle:45,colorNeedleCircleOuter:"#f0f0f0",colorNeedleCircleOuterEnd:"#ccc",colorNeedleCircleInner:"#e8e8e8",colorNeedleCircleInnerEnd:"#f5f5f5",needleCircleSize:10,needleCircleInner:!0,needleCircleOuter:!0,needleStart:20,animationTarget:"needle",useMinPath:!1,barWidth:0,barStartPosition:"left"}),ba=function(u){function h(p){return i(this,h),p=Object.assign({},Yr,p||{}),e(this,(h.__proto__||Object.getPrototypeOf(h)).call(this,h.configure(p)))}return t(h,u),gi(h,[{key:"draw",value:function(){try{var p=this.canvas,w=[-p.drawX,-p.drawY,p.drawWidth,p.drawHeight],C=w[0],E=w[1],O=w[2],N=w[3],R=this.options;if(R.animationTarget==="needle"){if(!p.elementClone.initialized){var W=p.contextClone;W.clearRect(C,E,O,N),this.emit("beforePlate"),mt(W,R),this.emit("beforeHighlights"),dt(W,R),this.emit("beforeMinorTicks"),qt(W,R),this.emit("beforeMajorTicks"),ft(W,R),this.emit("beforeNumbers"),Q(W,R),this.emit("beforeTitle"),ie(W,R),this.emit("beforeUnits"),oe(W,R),p.elementClone.initialized=!0}this.canvas.commit(),p.context.clearRect(C,E,O,N),p.context.drawImage(p.elementClone,C,E,O,N),this.emit("beforeProgressBar"),vt(p.context,R),this.emit("beforeValueBox"),nt(p.context,R,Tt(this)),this.emit("beforeNeedle"),Oe(p.context,R)}else{var j=-Z.radians((R.value-R.minValue)/(R.maxValue-R.minValue)*R.ticksAngle);if(p.context.clearRect(C,E,O,N),this.emit("beforePlate"),mt(p.context,R),p.context.rotate(j),this.emit("beforeHighlights"),dt(p.context,R),this.emit("beforeMinorTicks"),qt(p.context,R),this.emit("beforeMajorTicks"),ft(p.context,R),this.emit("beforeNumbers"),Q(p.context,R),this.emit("beforeProgressBar"),vt(p.context,R),p.context.rotate(-j),!p.elementClone.initialized){var q=p.contextClone;q.clearRect(C,E,O,N),this.emit("beforeTitle"),ie(q,R),this.emit("beforeUnits"),oe(q,R),this.emit("beforeNeedle"),Oe(q,R),p.elementClone.initialized=!0}p.context.drawImage(p.elementClone,C,E,O,N)}this.emit("beforeValueBox"),nt(p.context,R,Tt(this)),Tn(h.prototype.__proto__||Object.getPrototypeOf(h.prototype),"draw",this).call(this)}catch(J){Z.verifyError(J)}return this}},{key:"value",set:function(p){p=It.ensureValue(p,this.options.minValue),this.options.animation&&this.options.ticksAngle===360&&this.options.useMinPath&&(this._value=p,p=this.options.value+((p-this.options.value)%360+540)%360-180),jr(h.prototype.__proto__||Object.getPrototypeOf(h.prototype),"value",p,this)},get:function(){return Tn(h.prototype.__proto__||Object.getPrototypeOf(h.prototype),"value",this)}}],[{key:"configure",value:function(p){return p.barWidth>50&&(p.barWidth=50),isNaN(p.startAngle)&&(p.startAngle=45),isNaN(p.ticksAngle)&&(p.ticksAngle=270),p.ticksAngle>360&&(p.ticksAngle=360),p.ticksAngle<0&&(p.ticksAngle=0),p.startAngle<0&&(p.startAngle=0),p.startAngle>360&&(p.startAngle=360),p}}]),h}(It);r!==void 0&&(r.RadialGauge=ba),It.initialize("RadialGauge",Yr);var $r=Object.assign({},Oi,{borderRadius:0,barBeginCircle:30,colorBarEnd:"",colorBarProgressEnd:"",needleWidth:6,tickSide:"both",needleSide:"both",numberSide:"both",ticksWidth:10,ticksWidthMinor:5,ticksPadding:5,barLength:85,fontTitleSize:26,highlightsWidth:10}),Dn=function(u){function h(p){return i(this,h),p=Object.assign({},$r,p||{}),e(this,(h.__proto__||Object.getPrototypeOf(h)).call(this,h.configure(p)))}return t(h,u),gi(h,[{key:"draw",value:function(){try{var p=this.canvas,w=[-p.drawX,-p.drawY,p.drawWidth,p.drawHeight],C=w[0],E=w[1],O=w[2],N=w[3],R=this.options;if(!p.elementClone.initialized){var W=p.contextClone;W.clearRect(C,E,O,N),this.emit("beforePlate"),this.drawBox=ct(W,R,C,E,O,N),this.emit("beforeBar"),qe.apply(void 0,[W,R].concat(n(this.drawBox))),p.contextClone.barDimensions=W.barDimensions,this.emit("beforeHighlights"),en(W,R),this.emit("beforeMinorTicks"),Hr(W,R),this.emit("beforeMajorTicks"),$t(W,R),this.emit("beforeNumbers"),Ur(W,R),this.emit("beforeTitle"),xn(W,R),this.emit("beforeUnits"),Mt(W,R),p.elementClone.initialized=!0}this.canvas.commit(),p.context.clearRect(C,E,O,N),p.context.drawImage(p.elementClone,C,E,O,N),this.emit("beforeProgressBar"),li.apply(void 0,[p.context,R].concat(n(this.drawBox))),this.emit("beforeNeedle"),pa(p.context,R),this.emit("beforeValueBox"),va.apply(void 0,[p.context,R,R.animatedValue?this.options.value:this.value].concat(n(this.drawBox))),Tn(h.prototype.__proto__||Object.getPrototypeOf(h.prototype),"draw",this).call(this)}catch(j){Z.verifyError(j)}return this}}],[{key:"configure",value:function(p){return p.barStrokeWidth>=p.barWidth&&(p.barStrokeWidth=Se(p.barWidth/2)),p.hasLeft=Yt("right",p),p.hasRight=Yt("left",p),p.value>p.maxValue&&(p.value=p.maxValue),p.value<p.minValue&&(p.value=p.minValue),It.configure(p)}}]),h}(It);r!==void 0&&(r.LinearGauge=Dn),It.initialize("LinearGauge",$r),typeof Lo<"u"&&Object.assign(r,{Collection:l,GenericOptions:Oi,Animation:br,BaseGauge:It,drawings:Z,SmartCanvas:Ft,DomObserver:Mi,vendorize:o})})(typeof Lo<"u"?Lo.exports:window)});var Bu=Sa((CT,ma)=>{(function(r,n,e,t){"use strict";var i=["","webkit","Moz","MS","ms","o"],o=n.createElement("div"),a="function",l=Math.round,d=Math.abs,f=Date.now;function s(g,b,S){return setTimeout($(g,S),b)}function c(g,b,S){return Array.isArray(g)?(m(g,S[b],S),!0):!1}function m(g,b,S){var I;if(g)if(g.forEach)g.forEach(b,S);else if(g.length!==t)for(I=0;I<g.length;)b.call(S,g[I],I,g),I++;else for(I in g)g.hasOwnProperty(I)&&b.call(S,g[I],I,g)}function y(g,b,S){var I="DEPRECATED METHOD: "+b+`
|
|
2
|
+
`+S+` AT
|
|
3
|
+
`;return function(){var H=new Error("get-stack-trace"),X=H&&H.stack?H.stack.replace(/^[^\(]+?[\n$]/gm,"").replace(/^\s+at\s+/gm,"").replace(/^Object.<anonymous>\s*\(/gm,"{anonymous}()@"):"Unknown Stack Trace",Le=r.console&&(r.console.warn||r.console.log);return Le&&Le.call(r.console,I,X),g.apply(this,arguments)}}var k;typeof Object.assign!="function"?k=function(b){if(b===t||b===null)throw new TypeError("Cannot convert undefined or null to object");for(var S=Object(b),I=1;I<arguments.length;I++){var H=arguments[I];if(H!==t&&H!==null)for(var X in H)H.hasOwnProperty(X)&&(S[X]=H[X])}return S}:k=Object.assign;var x=y(function(b,S,I){for(var H=Object.keys(S),X=0;X<H.length;)(!I||I&&b[H[X]]===t)&&(b[H[X]]=S[H[X]]),X++;return b},"extend","Use `assign`."),D=y(function(b,S){return x(b,S,!0)},"merge","Use `assign`.");function F(g,b,S){var I=b.prototype,H;H=g.prototype=Object.create(I),H.constructor=g,H._super=I,S&&k(H,S)}function $(g,b){return function(){return g.apply(b,arguments)}}function se(g,b){return typeof g==a?g.apply(b&&b[0]||t,b):g}function ke(g,b){return g===t?b:g}function Ye(g,b,S){m(mt(b),function(I){g.addEventListener(I,S,!1)})}function Ke(g,b,S){m(mt(b),function(I){g.removeEventListener(I,S,!1)})}function it(g,b){for(;g;){if(g==b)return!0;g=g.parentNode}return!1}function ce(g,b){return g.indexOf(b)>-1}function mt(g){return g.trim().split(/\s+/g)}function dt(g,b,S){if(g.indexOf&&!S)return g.indexOf(b);for(var I=0;I<g.length;){if(S&&g[I][S]==b||!S&&g[I]===b)return I;I++}return-1}function qt(g){return Array.prototype.slice.call(g,0)}function pt(g,b,S){for(var I=[],H=[],X=0;X<g.length;){var Le=b?g[X][b]:g[X];dt(H,Le)<0&&I.push(g[X]),H[X]=Le,X++}return S&&(b?I=I.sort(function(St,Et){return St[b]>Et[b]}):I=I.sort()),I}function ft(g,b){for(var S,I,H=b[0].toUpperCase()+b.slice(1),X=0;X<i.length;){if(S=i[X],I=S?S+H:b,I in g)return I;X++}return t}var Ci=1;function Sn(){return Ci++}function Q(g){var b=g.ownerDocument||g;return b.defaultView||b.parentWindow||r}var ie=/mobile|tablet|ip(ad|hone|od)|android/i,oe="ontouchstart"in r,Oe=ft(r,"PointerEvent")!==t,nt=oe&&ie.test(navigator.userAgent),gt="touch",vt="pen",Tt="mouse",Xe="kinect",Cn=25,ct=1,Ze=2,Fe=4,qe=8,Yt=1,li=2,en=4,fi=8,Pi=16,$t=li|en,Qt=fi|Pi,Hr=$t|Qt,Ur=["x","y"],xn=["clientX","clientY"];function Mt(g,b){var S=this;this.manager=g,this.callback=b,this.element=g.element,this.target=g.options.inputTarget,this.domHandler=function(I){se(g.options.enable,[g])&&S.handler(I)},this.init()}Mt.prototype={handler:function(){},init:function(){this.evEl&&Ye(this.element,this.evEl,this.domHandler),this.evTarget&&Ye(this.target,this.evTarget,this.domHandler),this.evWin&&Ye(Q(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&Ke(this.element,this.evEl,this.domHandler),this.evTarget&&Ke(this.target,this.evTarget,this.domHandler),this.evWin&&Ke(Q(this.element),this.evWin,this.domHandler)}};function pa(g){var b,S=g.options.inputClass;return S?b=S:Oe?b=It:nt?b=Dn:oe?b=w:b=Oi,new b(g,Gr)}function Gr(g,b,S){var I=S.pointers.length,H=S.changedPointers.length,X=b&ct&&I-H===0,Le=b&(Fe|qe)&&I-H===0;S.isFirst=!!X,S.isFinal=!!Le,X&&(g.session={}),S.eventType=b,fa(g,S),g.emit("hammer.input",S),g.recognize(S),g.session.prevInput=S}function fa(g,b){var S=g.session,I=b.pointers,H=I.length;S.firstInput||(S.firstInput=vr(b)),H>1&&!S.firstMultiple?S.firstMultiple=vr(b):H===1&&(S.firstMultiple=!1);var X=S.firstInput,Le=S.firstMultiple,yt=Le?Le.center:X.center,St=b.center=Tn(I);b.timeStamp=f(),b.deltaTime=b.timeStamp-X.timeStamp,b.angle=yr(yt,St),b.distance=xi(yt,St),ga(S,b),b.offsetDirection=gi(b.deltaX,b.deltaY);var Et=jr(b.deltaTime,b.deltaX,b.deltaY);b.overallVelocityX=Et.x,b.overallVelocityY=Et.y,b.overallVelocity=d(Et.x)>d(Et.y)?Et.x:Et.y,b.scale=Le?tn(Le.pointers,I):1,b.rotation=Le?qr(Le.pointers,I):0,b.maxPointers=S.prevInput?b.pointers.length>S.prevInput.maxPointers?b.pointers.length:S.prevInput.maxPointers:b.pointers.length,va(S,b);var vi=g.element;it(b.srcEvent.target,vi)&&(vi=b.srcEvent.target),b.target=vi}function ga(g,b){var S=b.center,I=g.offsetDelta||{},H=g.prevDelta||{},X=g.prevInput||{};(b.eventType===ct||X.eventType===Fe)&&(H=g.prevDelta={x:X.deltaX||0,y:X.deltaY||0},I=g.offsetDelta={x:S.x,y:S.y}),b.deltaX=H.x+(S.x-I.x),b.deltaY=H.y+(S.y-I.y)}function va(g,b){var S=g.lastInterval||b,I=b.timeStamp-S.timeStamp,H,X,Le,yt;if(b.eventType!=qe&&(I>Cn||S.velocity===t)){var St=b.deltaX-S.deltaX,Et=b.deltaY-S.deltaY,vi=jr(I,St,Et);X=vi.x,Le=vi.y,H=d(vi.x)>d(vi.y)?vi.x:vi.y,yt=gi(St,Et),g.lastInterval=b}else H=S.velocity,X=S.velocityX,Le=S.velocityY,yt=S.direction;b.velocity=H,b.velocityX=X,b.velocityY=Le,b.direction=yt}function vr(g){for(var b=[],S=0;S<g.pointers.length;)b[S]={clientX:l(g.pointers[S].clientX),clientY:l(g.pointers[S].clientY)},S++;return{timeStamp:f(),pointers:b,center:Tn(b),deltaX:g.deltaX,deltaY:g.deltaY}}function Tn(g){var b=g.length;if(b===1)return{x:l(g[0].clientX),y:l(g[0].clientY)};for(var S=0,I=0,H=0;H<b;)S+=g[H].clientX,I+=g[H].clientY,H++;return{x:l(S/b),y:l(I/b)}}function jr(g,b,S){return{x:b/g||0,y:S/g||0}}function gi(g,b){return g===b?Yt:d(g)>=d(b)?g<0?li:en:b<0?fi:Pi}function xi(g,b,S){S||(S=Ur);var I=b[S[0]]-g[S[0]],H=b[S[1]]-g[S[1]];return Math.sqrt(I*I+H*H)}function yr(g,b,S){S||(S=Ur);var I=b[S[0]]-g[S[0]],H=b[S[1]]-g[S[1]];return Math.atan2(H,I)*180/Math.PI}function qr(g,b){return yr(b[1],b[0],xn)+yr(g[1],g[0],xn)}function tn(g,b){return xi(b[0],b[1],xn)/xi(g[0],g[1],xn)}var br={mousedown:ct,mousemove:Ze,mouseup:Fe},Mi="mousedown",Ft="mousemove mouseup";function Oi(){this.evEl=Mi,this.evWin=Ft,this.pressed=!1,Mt.apply(this,arguments)}F(Oi,Mt,{handler:function(b){var S=br[b.type];S&ct&&b.button===0&&(this.pressed=!0),S&Ze&&b.which!==1&&(S=Fe),this.pressed&&(S&Fe&&(this.pressed=!1),this.callback(this.manager,S,{pointers:[b],changedPointers:[b],pointerType:Tt,srcEvent:b}))}});var _r={pointerdown:ct,pointermove:Ze,pointerup:Fe,pointercancel:qe,pointerout:qe},Se={2:gt,3:vt,4:Tt,5:Xe},Ot="pointerdown",Ii="pointermove pointerup pointercancel";r.MSPointerEvent&&!r.PointerEvent&&(Ot="MSPointerDown",Ii="MSPointerMove MSPointerUp MSPointerCancel");function It(){this.evEl=Ot,this.evWin=Ii,Mt.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}F(It,Mt,{handler:function(b){var S=this.store,I=!1,H=b.type.toLowerCase().replace("ms",""),X=_r[H],Le=Se[b.pointerType]||b.pointerType,yt=Le==gt,St=dt(S,b.pointerId,"pointerId");X&ct&&(b.button===0||yt)?St<0&&(S.push(b),St=S.length-1):X&(Fe|qe)&&(I=!0),!(St<0)&&(S[St]=b,this.callback(this.manager,X,{pointers:S,changedPointers:[b],pointerType:Le,srcEvent:b}),I&&S.splice(St,1))}});var ya={touchstart:ct,touchmove:Ze,touchend:Fe,touchcancel:qe},Z="touchstart",nn="touchstart touchmove touchend touchcancel";function En(){this.evTarget=Z,this.evWin=nn,this.started=!1,Mt.apply(this,arguments)}F(En,Mt,{handler:function(b){var S=ya[b.type];if(S===ct&&(this.started=!0),!!this.started){var I=Yr.call(this,b,S);S&(Fe|qe)&&I[0].length-I[1].length===0&&(this.started=!1),this.callback(this.manager,S,{pointers:I[0],changedPointers:I[1],pointerType:gt,srcEvent:b})}}});function Yr(g,b){var S=qt(g.touches),I=qt(g.changedTouches);return b&(Fe|qe)&&(S=pt(S.concat(I),"identifier",!0)),[S,I]}var ba={touchstart:ct,touchmove:Ze,touchend:Fe,touchcancel:qe},$r="touchstart touchmove touchend touchcancel";function Dn(){this.evTarget=$r,this.targetIds={},Mt.apply(this,arguments)}F(Dn,Mt,{handler:function(b){var S=ba[b.type],I=u.call(this,b,S);I&&this.callback(this.manager,S,{pointers:I[0],changedPointers:I[1],pointerType:gt,srcEvent:b})}});function u(g,b){var S=qt(g.touches),I=this.targetIds;if(b&(ct|Ze)&&S.length===1)return I[S[0].identifier]=!0,[S,S];var H,X,Le=qt(g.changedTouches),yt=[],St=this.target;if(X=S.filter(function(Et){return it(Et.target,St)}),b===ct)for(H=0;H<X.length;)I[X[H].identifier]=!0,H++;for(H=0;H<Le.length;)I[Le[H].identifier]&&yt.push(Le[H]),b&(Fe|qe)&&delete I[Le[H].identifier],H++;if(yt.length)return[pt(X.concat(yt),"identifier",!0),yt]}var h=2500,p=25;function w(){Mt.apply(this,arguments);var g=$(this.handler,this);this.touch=new Dn(this.manager,g),this.mouse=new Oi(this.manager,g),this.primaryTouch=null,this.lastTouches=[]}F(w,Mt,{handler:function(b,S,I){var H=I.pointerType==gt,X=I.pointerType==Tt;if(!(X&&I.sourceCapabilities&&I.sourceCapabilities.firesTouchEvents)){if(H)C.call(this,S,I);else if(X&&O.call(this,I))return;this.callback(b,S,I)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});function C(g,b){g&ct?(this.primaryTouch=b.changedPointers[0].identifier,E.call(this,b)):g&(Fe|qe)&&E.call(this,b)}function E(g){var b=g.changedPointers[0];if(b.identifier===this.primaryTouch){var S={x:b.clientX,y:b.clientY};this.lastTouches.push(S);var I=this.lastTouches,H=function(){var X=I.indexOf(S);X>-1&&I.splice(X,1)};setTimeout(H,h)}}function O(g){for(var b=g.srcEvent.clientX,S=g.srcEvent.clientY,I=0;I<this.lastTouches.length;I++){var H=this.lastTouches[I],X=Math.abs(b-H.x),Le=Math.abs(S-H.y);if(X<=p&&Le<=p)return!0}return!1}var N=ft(o.style,"touchAction"),R=N!==t,W="compute",j="auto",q="manipulation",J="none",ae="pan-x",me="pan-y",Ie=Be();function ve(g,b){this.manager=g,this.set(b)}ve.prototype={set:function(g){g==W&&(g=this.compute()),R&&this.manager.element.style&&Ie[g]&&(this.manager.element.style[N]=g),this.actions=g.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var g=[];return m(this.manager.recognizers,function(b){se(b.options.enable,[b])&&(g=g.concat(b.getTouchAction()))}),We(g.join(" "))},preventDefaults:function(g){var b=g.srcEvent,S=g.offsetDirection;if(this.manager.session.prevented){b.preventDefault();return}var I=this.actions,H=ce(I,J)&&!Ie[J],X=ce(I,me)&&!Ie[me],Le=ce(I,ae)&&!Ie[ae];if(H){var yt=g.pointers.length===1,St=g.distance<2,Et=g.deltaTime<250;if(yt&&St&&Et)return}if(!(Le&&X)&&(H||X&&S&$t||Le&&S&Qt))return this.preventSrc(b)},preventSrc:function(g){this.manager.session.prevented=!0,g.preventDefault()}};function We(g){if(ce(g,J))return J;var b=ce(g,ae),S=ce(g,me);return b&&S?J:b||S?b?ae:me:ce(g,q)?q:j}function Be(){if(!R)return!1;var g={},b=r.CSS&&r.CSS.supports;return["auto","manipulation","pan-y","pan-x","pan-x pan-y","none"].forEach(function(S){g[S]=b?r.CSS.supports("touch-action",S):!0}),g}var ze=1,he=2,Ce=4,ye=8,re=ye,be=16,_e=32;function xe(g){this.options=k({},this.defaults,g||{}),this.id=Sn(),this.manager=null,this.options.enable=ke(this.options.enable,!0),this.state=ze,this.simultaneous={},this.requireFail=[]}xe.prototype={defaults:{},set:function(g){return k(this.options,g),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(g){if(c(g,"recognizeWith",this))return this;var b=this.simultaneous;return g=wt(g,this),b[g.id]||(b[g.id]=g,g.recognizeWith(this)),this},dropRecognizeWith:function(g){return c(g,"dropRecognizeWith",this)?this:(g=wt(g,this),delete this.simultaneous[g.id],this)},requireFailure:function(g){if(c(g,"requireFailure",this))return this;var b=this.requireFail;return g=wt(g,this),dt(b,g)===-1&&(b.push(g),g.requireFailure(this)),this},dropRequireFailure:function(g){if(c(g,"dropRequireFailure",this))return this;g=wt(g,this);var b=dt(this.requireFail,g);return b>-1&&this.requireFail.splice(b,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(g){return!!this.simultaneous[g.id]},emit:function(g){var b=this,S=this.state;function I(H){b.manager.emit(H,g)}S<ye&&I(b.options.event+$e(S)),I(b.options.event),g.additionalEvent&&I(g.additionalEvent),S>=ye&&I(b.options.event+$e(S))},tryEmit:function(g){if(this.canEmit())return this.emit(g);this.state=_e},canEmit:function(){for(var g=0;g<this.requireFail.length;){if(!(this.requireFail[g].state&(_e|ze)))return!1;g++}return!0},recognize:function(g){var b=k({},g);if(!se(this.options.enable,[this,b])){this.reset(),this.state=_e;return}this.state&(re|be|_e)&&(this.state=ze),this.state=this.process(b),this.state&(he|Ce|ye|be)&&this.tryEmit(b)},process:function(g){},getTouchAction:function(){},reset:function(){}};function $e(g){return g&be?"cancel":g&ye?"end":g&Ce?"move":g&he?"start":""}function _t(g){return g==Pi?"down":g==fi?"up":g==li?"left":g==en?"right":""}function wt(g,b){var S=b.manager;return S?S.get(g):g}function kt(){xe.apply(this,arguments)}F(kt,xe,{defaults:{pointers:1},attrTest:function(g){var b=this.options.pointers;return b===0||g.pointers.length===b},process:function(g){var b=this.state,S=g.eventType,I=b&(he|Ce),H=this.attrTest(g);return I&&(S&qe||!H)?b|be:I||H?S&Fe?b|ye:b&he?b|Ce:he:_e}});function Xt(){kt.apply(this,arguments),this.pX=null,this.pY=null}F(Xt,kt,{defaults:{event:"pan",threshold:10,pointers:1,direction:Hr},getTouchAction:function(){var g=this.options.direction,b=[];return g&$t&&b.push(me),g&Qt&&b.push(ae),b},directionTest:function(g){var b=this.options,S=!0,I=g.distance,H=g.direction,X=g.deltaX,Le=g.deltaY;return H&b.direction||(b.direction&$t?(H=X===0?Yt:X<0?li:en,S=X!=this.pX,I=Math.abs(g.deltaX)):(H=Le===0?Yt:Le<0?fi:Pi,S=Le!=this.pY,I=Math.abs(g.deltaY))),g.direction=H,S&&I>b.threshold&&H&b.direction},attrTest:function(g){return kt.prototype.attrTest.call(this,g)&&(this.state&he||!(this.state&he)&&this.directionTest(g))},emit:function(g){this.pX=g.deltaX,this.pY=g.deltaY;var b=_t(g.direction);b&&(g.additionalEvent=this.options.event+b),this._super.emit.call(this,g)}});function An(){kt.apply(this,arguments)}F(An,kt,{defaults:{event:"pinch",threshold:0,pointers:2},getTouchAction:function(){return[J]},attrTest:function(g){return this._super.attrTest.call(this,g)&&(Math.abs(g.scale-1)>this.options.threshold||this.state&he)},emit:function(g){if(g.scale!==1){var b=g.scale<1?"in":"out";g.additionalEvent=this.options.event+b}this._super.emit.call(this,g)}});function Pn(){xe.apply(this,arguments),this._timer=null,this._input=null}F(Pn,xe,{defaults:{event:"press",pointers:1,time:251,threshold:9},getTouchAction:function(){return[j]},process:function(g){var b=this.options,S=g.pointers.length===b.pointers,I=g.distance<b.threshold,H=g.deltaTime>b.time;if(this._input=g,!I||!S||g.eventType&(Fe|qe)&&!H)this.reset();else if(g.eventType&ct)this.reset(),this._timer=s(function(){this.state=re,this.tryEmit()},b.time,this);else if(g.eventType&Fe)return re;return _e},reset:function(){clearTimeout(this._timer)},emit:function(g){this.state===re&&(g&&g.eventType&Fe?this.manager.emit(this.options.event+"up",g):(this._input.timeStamp=f(),this.manager.emit(this.options.event,this._input)))}});function _a(){kt.apply(this,arguments)}F(_a,kt,{defaults:{event:"rotate",threshold:0,pointers:2},getTouchAction:function(){return[J]},attrTest:function(g){return this._super.attrTest.call(this,g)&&(Math.abs(g.rotation)>this.options.threshold||this.state&he)}});function wa(){kt.apply(this,arguments)}F(wa,kt,{defaults:{event:"swipe",threshold:10,velocity:.3,direction:$t|Qt,pointers:1},getTouchAction:function(){return Xt.prototype.getTouchAction.call(this)},attrTest:function(g){var b=this.options.direction,S;return b&($t|Qt)?S=g.overallVelocity:b&$t?S=g.overallVelocityX:b&Qt&&(S=g.overallVelocityY),this._super.attrTest.call(this,g)&&b&g.offsetDirection&&g.distance>this.options.threshold&&g.maxPointers==this.options.pointers&&d(S)>this.options.velocity&&g.eventType&Fe},emit:function(g){var b=_t(g.offsetDirection);b&&this.manager.emit(this.options.event+b,g),this.manager.emit(this.options.event,g)}});function Qr(){xe.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}F(Qr,xe,{defaults:{event:"tap",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[q]},process:function(g){var b=this.options,S=g.pointers.length===b.pointers,I=g.distance<b.threshold,H=g.deltaTime<b.time;if(this.reset(),g.eventType&ct&&this.count===0)return this.failTimeout();if(I&&H&&S){if(g.eventType!=Fe)return this.failTimeout();var X=this.pTime?g.timeStamp-this.pTime<b.interval:!0,Le=!this.pCenter||xi(this.pCenter,g.center)<b.posThreshold;this.pTime=g.timeStamp,this.pCenter=g.center,!Le||!X?this.count=1:this.count+=1,this._input=g;var yt=this.count%b.taps;if(yt===0)return this.hasRequireFailures()?(this._timer=s(function(){this.state=re,this.tryEmit()},b.interval,this),he):re}return _e},failTimeout:function(){return this._timer=s(function(){this.state=_e},this.options.interval,this),_e},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==re&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}});function Ti(g,b){return b=b||{},b.recognizers=ke(b.recognizers,Ti.defaults.preset),new ka(g,b)}Ti.VERSION="2.0.7",Ti.defaults={domEvents:!1,touchAction:W,enable:!0,inputTarget:null,inputClass:null,preset:[[_a,{enable:!1}],[An,{enable:!1},["rotate"]],[wa,{direction:$t}],[Xt,{direction:$t},["swipe"]],[Qr],[Qr,{event:"doubletap",taps:2},["tap"]],[Pn]],cssProps:{userSelect:"none",touchSelect:"none",touchCallout:"none",contentZooming:"none",userDrag:"none",tapHighlightColor:"rgba(0,0,0,0)"}};var zu=1,tl=2;function ka(g,b){this.options=k({},Ti.defaults,b||{}),this.options.inputTarget=this.options.inputTarget||g,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=g,this.input=pa(this),this.touchAction=new ve(this,this.options.touchAction),il(this,!0),m(this.options.recognizers,function(S){var I=this.add(new S[0](S[1]));S[2]&&I.recognizeWith(S[2]),S[3]&&I.requireFailure(S[3])},this)}ka.prototype={set:function(g){return k(this.options,g),g.touchAction&&this.touchAction.update(),g.inputTarget&&(this.input.destroy(),this.input.target=g.inputTarget,this.input.init()),this},stop:function(g){this.session.stopped=g?tl:zu},recognize:function(g){var b=this.session;if(!b.stopped){this.touchAction.preventDefaults(g);var S,I=this.recognizers,H=b.curRecognizer;(!H||H&&H.state&re)&&(H=b.curRecognizer=null);for(var X=0;X<I.length;)S=I[X],b.stopped!==tl&&(!H||S==H||S.canRecognizeWith(H))?S.recognize(g):S.reset(),!H&&S.state&(he|Ce|ye)&&(H=b.curRecognizer=S),X++}},get:function(g){if(g instanceof xe)return g;for(var b=this.recognizers,S=0;S<b.length;S++)if(b[S].options.event==g)return b[S];return null},add:function(g){if(c(g,"add",this))return this;var b=this.get(g.options.event);return b&&this.remove(b),this.recognizers.push(g),g.manager=this,this.touchAction.update(),g},remove:function(g){if(c(g,"remove",this))return this;if(g=this.get(g),g){var b=this.recognizers,S=dt(b,g);S!==-1&&(b.splice(S,1),this.touchAction.update())}return this},on:function(g,b){if(g!==t&&b!==t){var S=this.handlers;return m(mt(g),function(I){S[I]=S[I]||[],S[I].push(b)}),this}},off:function(g,b){if(g!==t){var S=this.handlers;return m(mt(g),function(I){b?S[I]&&S[I].splice(dt(S[I],b),1):delete S[I]}),this}},emit:function(g,b){this.options.domEvents&&Lu(g,b);var S=this.handlers[g]&&this.handlers[g].slice();if(!(!S||!S.length)){b.type=g,b.preventDefault=function(){b.srcEvent.preventDefault()};for(var I=0;I<S.length;)S[I](b),I++}},destroy:function(){this.element&&il(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}};function il(g,b){var S=g.element;if(S.style){var I;m(g.options.cssProps,function(H,X){I=ft(S.style,X),b?(g.oldCssProps[I]=S.style[I],S.style[I]=H):S.style[I]=g.oldCssProps[I]||""}),b||(g.oldCssProps={})}}function Lu(g,b){var S=n.createEvent("Event");S.initEvent(g,!0,!0),S.gesture=b,b.target.dispatchEvent(S)}k(Ti,{INPUT_START:ct,INPUT_MOVE:Ze,INPUT_END:Fe,INPUT_CANCEL:qe,STATE_POSSIBLE:ze,STATE_BEGAN:he,STATE_CHANGED:Ce,STATE_ENDED:ye,STATE_RECOGNIZED:re,STATE_CANCELLED:be,STATE_FAILED:_e,DIRECTION_NONE:Yt,DIRECTION_LEFT:li,DIRECTION_RIGHT:en,DIRECTION_UP:fi,DIRECTION_DOWN:Pi,DIRECTION_HORIZONTAL:$t,DIRECTION_VERTICAL:Qt,DIRECTION_ALL:Hr,Manager:ka,Input:Mt,TouchAction:ve,TouchInput:Dn,MouseInput:Oi,PointerEventInput:It,TouchMouseInput:w,SingleTouchInput:En,Recognizer:xe,AttrRecognizer:kt,Tap:Qr,Pan:Xt,Swipe:wa,Pinch:An,Rotate:_a,Press:Pn,on:Ye,off:Ke,each:m,merge:D,extend:x,assign:k,inherit:F,bindFn:$,prefixed:ft});var Vu=typeof r<"u"?r:typeof self<"u"?self:{};Vu.Hammer=Ti,typeof define=="function"&&define.amd?define(function(){return Ti}):typeof ma<"u"&&ma.exports?ma.exports=Ti:r[e]=Ti})(window,document,"Hammer")});function zd(r,n,e,t,i){let o=(...a)=>(console.warn("gridstack.js: Function `"+e+"` is deprecated in "+i+" and has been replaced with `"+t+"`. It will be **removed** in a future release"),n.apply(r,a));return o.prototype=n.prototype,o}var A=class r{static getElements(n,e=document){if(typeof n=="string"){let t="getElementById"in e?e:void 0;if(t&&!isNaN(+n[0])){let o=t.getElementById(n);return o?[o]:[]}let i=e.querySelectorAll(n);return!i.length&&n[0]!=="."&&n[0]!=="#"&&(i=e.querySelectorAll("."+n),i.length||(i=e.querySelectorAll("#"+n))),Array.from(i)}return[n]}static getElement(n,e=document){if(typeof n=="string"){let t="getElementById"in e?e:void 0;if(!n.length)return null;if(t&&n[0]==="#")return t.getElementById(n.substring(1));if(n[0]==="#"||n[0]==="."||n[0]==="[")return e.querySelector(n);if(t&&!isNaN(+n[0]))return t.getElementById(n);let i=e.querySelector(n);return t&&!i&&(i=t.getElementById(n)),i||(i=e.querySelector("."+n)),i}return n}static lazyLoad(n){return n.lazyLoad||n.grid?.opts?.lazyLoad&&n.lazyLoad!==!1}static createDiv(n,e){let t=document.createElement("div");return n.forEach(i=>{i&&t.classList.add(i)}),e?.appendChild(t),t}static shouldSizeToContent(n,e=!1){return n?.grid&&(e?n.sizeToContent===!0||n.grid.opts.sizeToContent===!0&&n.sizeToContent===void 0:!!n.sizeToContent||n.grid.opts.sizeToContent&&n.sizeToContent!==!1)}static isIntercepted(n,e){return!(n.y>=e.y+e.h||n.y+n.h<=e.y||n.x+n.w<=e.x||n.x>=e.x+e.w)}static isTouching(n,e){return r.isIntercepted(n,{x:e.x-.5,y:e.y-.5,w:e.w+1,h:e.h+1})}static areaIntercept(n,e){let t=n.x>e.x?n.x:e.x,i=n.x+n.w<e.x+e.w?n.x+n.w:e.x+e.w;if(i<=t)return 0;let o=n.y>e.y?n.y:e.y,a=n.y+n.h<e.y+e.h?n.y+n.h:e.y+e.h;return a<=o?0:(i-t)*(a-o)}static area(n){return n.w*n.h}static sort(n,e=1){return n.sort((i,o)=>{let a=e*((i.y??1e4)-(o.y??1e4));return a===0?e*((i.x??1e4)-(o.x??1e4)):a})}static find(n,e){return e?n.find(t=>t.id===e):void 0}static createStylesheet(n,e,t){let i=document.createElement("style"),o=t?.nonce;return o&&(i.nonce=o),i.setAttribute("type","text/css"),i.setAttribute("gs-style-id",n),i.styleSheet?i.styleSheet.cssText="":i.appendChild(document.createTextNode("")),e?e.insertBefore(i,e.firstChild):(e=document.getElementsByTagName("head")[0],e.appendChild(i)),i}static removeStylesheet(n,e){let i=(e||document).querySelector("STYLE[gs-style-id="+n+"]");i&&i.parentNode&&i.remove()}static addCSSRule(n,e,t){n.textContent+=`${e} { ${t} } `}static toBool(n){return typeof n=="boolean"?n:typeof n=="string"?(n=n.toLowerCase(),!(n===""||n==="no"||n==="false"||n==="0")):!!n}static toNumber(n){return n===null||n.length===0?void 0:Number(n)}static parseHeight(n){let e,t="px";if(typeof n=="string")if(n==="auto"||n==="")e=0;else{let i=n.match(/^(-[0-9]+\.[0-9]+|[0-9]*\.[0-9]+|-[0-9]+|[0-9]+)(px|em|rem|vh|vw|%|cm|mm)?$/);if(!i)throw new Error(`Invalid height val = ${n}`);t=i[2]||"px",e=parseFloat(i[1])}else e=n;return{h:e,unit:t}}static defaults(n,...e){return e.forEach(t=>{for(let i in t){if(!t.hasOwnProperty(i))return;n[i]===null||n[i]===void 0?n[i]=t[i]:typeof t[i]=="object"&&typeof n[i]=="object"&&this.defaults(n[i],t[i])}}),n}static same(n,e){if(typeof n!="object")return n==e;if(typeof n!=typeof e||Object.keys(n).length!==Object.keys(e).length)return!1;for(let t in n)if(n[t]!==e[t])return!1;return!0}static copyPos(n,e,t=!1){return e.x!==void 0&&(n.x=e.x),e.y!==void 0&&(n.y=e.y),e.w!==void 0&&(n.w=e.w),e.h!==void 0&&(n.h=e.h),t&&(e.minW&&(n.minW=e.minW),e.minH&&(n.minH=e.minH),e.maxW&&(n.maxW=e.maxW),e.maxH&&(n.maxH=e.maxH)),n}static samePos(n,e){return n&&e&&n.x===e.x&&n.y===e.y&&(n.w||1)===(e.w||1)&&(n.h||1)===(e.h||1)}static sanitizeMinMax(n){n.minW||delete n.minW,n.minH||delete n.minH,n.maxW||delete n.maxW,n.maxH||delete n.maxH}static removeInternalAndSame(n,e){if(!(typeof n!="object"||typeof e!="object"))for(let t in n){let i=n[t],o=e[t];t[0]==="_"||i===o?delete n[t]:i&&typeof i=="object"&&o!==void 0&&(r.removeInternalAndSame(i,o),Object.keys(i).length||delete n[t])}}static removeInternalForSave(n,e=!0){for(let t in n)(t[0]==="_"||n[t]===null||n[t]===void 0)&&delete n[t];delete n.grid,e&&delete n.el,n.autoPosition||delete n.autoPosition,n.noResize||delete n.noResize,n.noMove||delete n.noMove,n.locked||delete n.locked,(n.w===1||n.w===n.minW)&&delete n.w,(n.h===1||n.h===n.minH)&&delete n.h}static throttle(n,e){let t=!1;return(...i)=>{t||(t=!0,setTimeout(()=>{n(...i),t=!1},e))}}static removePositioningStyles(n){let e=n.style;e.position&&e.removeProperty("position"),e.left&&e.removeProperty("left"),e.top&&e.removeProperty("top"),e.width&&e.removeProperty("width"),e.height&&e.removeProperty("height")}static getScrollElement(n){if(!n)return document.scrollingElement||document.documentElement;let e=getComputedStyle(n);return/(auto|scroll)/.test(e.overflow+e.overflowY)?n:this.getScrollElement(n.parentElement)}static updateScrollPosition(n,e,t){let i=n.getBoundingClientRect(),o=window.innerHeight||document.documentElement.clientHeight;if(i.top<0||i.bottom>o){let a=i.bottom-o,l=i.top,d=this.getScrollElement(n);if(d!==null){let f=d.scrollTop;i.top<0&&t<0?n.offsetHeight>o?d.scrollTop+=t:d.scrollTop+=Math.abs(l)>Math.abs(t)?t:l:t>0&&(n.offsetHeight>o?d.scrollTop+=t:d.scrollTop+=a>t?t:a),e.top+=d.scrollTop-f}}}static updateScrollResize(n,e,t){let i=this.getScrollElement(e),o=i.clientHeight,a=i===this.getScrollElement()?0:i.getBoundingClientRect().top,l=n.clientY-a,d=l<t,f=l>o-t;d?i.scrollBy({behavior:"smooth",top:l-t}):f&&i.scrollBy({behavior:"smooth",top:t-(o-l)})}static clone(n){return n==null||typeof n!="object"?n:n instanceof Array?[...n]:K({},n)}static cloneDeep(n){let e=["parentGrid","el","grid","subGrid","engine"],t=r.clone(n);for(let i in t)t.hasOwnProperty(i)&&typeof t[i]=="object"&&i.substring(0,2)!=="__"&&!e.find(o=>o===i)&&(t[i]=r.cloneDeep(n[i]));return t}static cloneNode(n){let e=n.cloneNode(!0);return e.removeAttribute("id"),e}static appendTo(n,e){let t;typeof e=="string"?t=r.getElement(e):t=e,t&&t.appendChild(n)}static addElStyles(n,e){if(e instanceof Object)for(let t in e)e.hasOwnProperty(t)&&(Array.isArray(e[t])?e[t].forEach(i=>{n.style[t]=i}):n.style[t]=e[t])}static initEvent(n,e){let t={type:e.type},i={button:0,which:0,buttons:1,bubbles:!0,cancelable:!0,target:e.target?e.target:n.target};return["altKey","ctrlKey","metaKey","shiftKey"].forEach(o=>t[o]=n[o]),["pageX","pageY","clientX","clientY","screenX","screenY"].forEach(o=>t[o]=n[o]),K(K({},t),i)}static simulateMouseEvent(n,e,t){let i=n,o=new MouseEvent(e,{bubbles:!0,composed:!0,cancelable:!0,view:window,detail:1,screenX:n.screenX,screenY:n.screenY,clientX:n.clientX,clientY:n.clientY,ctrlKey:i.ctrlKey??!1,altKey:i.altKey??!1,shiftKey:i.shiftKey??!1,metaKey:i.metaKey??!1,button:0,relatedTarget:n.target});(t||n.target).dispatchEvent(o)}static getValuesFromTransformedElement(n){let e=document.createElement("div");r.addElStyles(e,{opacity:"0",position:"fixed",top:"0px",left:"0px",width:"1px",height:"1px",zIndex:"-999999"}),n.appendChild(e);let t=e.getBoundingClientRect();return n.removeChild(e),e.remove(),{xScale:1/t.width,yScale:1/t.height,xOffset:t.left,yOffset:t.top}}static swap(n,e,t){if(!n)return;let i=n[e];n[e]=n[t],n[t]=i}static canBeRotated(n){return!(!n||n.w===n.h||n.locked||n.noResize||n.grid?.opts.disableResize||n.minW&&n.minW===n.maxW||n.minH&&n.minH===n.maxH)}};var ko=(()=>{class r{constructor(e={}){this.addedNodes=[],this.removedNodes=[],this.defaultColumn=12,this.column=e.column||this.defaultColumn,this.column>this.defaultColumn&&(this.defaultColumn=this.column),this.maxRow=e.maxRow,this._float=e.float,this.nodes=e.nodes||[],this.onChange=e.onChange}batchUpdate(e=!0,t=!0){return!!this.batchMode===e?this:(this.batchMode=e,e?(this._prevFloat=this._float,this._float=!0,this.cleanNodes(),this.saveInitial()):(this._float=this._prevFloat,delete this._prevFloat,t&&this._packNodes(),this._notify()),this)}_useEntireRowArea(e,t){return(!this.float||this.batchMode&&!this._prevFloat)&&!this._hasLocked&&(!e._moving||e._skipDown||t.y<=e.y)}_fixCollisions(e,t=e,i,o={}){if(this.sortNodes(-1),i=i||this.collide(e,t),!i)return!1;if(e._moving&&!o.nested&&!this.float&&this.swap(e,i))return!0;let a=t;!this._loading&&this._useEntireRowArea(e,t)&&(a={x:0,w:this.column,y:t.y,h:t.h},i=this.collide(e,a,o.skip));let l=!1,d={nested:!0,pack:!1},f=0;for(;i=i||this.collide(e,a,o.skip);){if(f++>this.nodes.length*2)throw new Error("Infinite collide check");let s;if(i.locked||this._loading||e._moving&&!e._skipDown&&t.y>e.y&&!this.float&&(!this.collide(i,rt(K({},i),{y:e.y}),e)||!this.collide(i,rt(K({},i),{y:t.y-i.h}),e))){e._skipDown=e._skipDown||t.y>e.y;let c=K(rt(K({},t),{y:i.y+i.h}),d);s=this._loading&&A.samePos(e,c)?!0:this.moveNode(e,c),(i.locked||this._loading)&&s?A.copyPos(t,e):!i.locked&&s&&o.pack&&(this._packNodes(),t.y=i.y+i.h,A.copyPos(e,t)),l=l||s}else s=this.moveNode(i,K(rt(K({},i),{y:t.y+t.h,skip:e}),d));if(!s)return l;i=void 0}return l}collide(e,t=e,i){let o=e._id,a=i?._id;return this.nodes.find(l=>l._id!==o&&l._id!==a&&A.isIntercepted(l,t))}collideAll(e,t=e,i){let o=e._id,a=i?._id;return this.nodes.filter(l=>l._id!==o&&l._id!==a&&A.isIntercepted(l,t))}directionCollideCoverage(e,t,i){if(!t.rect||!e._rect)return;let o=e._rect,a=K({},t.rect);a.y>o.y?(a.h+=a.y-o.y,a.y=o.y):a.h+=o.y-a.y,a.x>o.x?(a.w+=a.x-o.x,a.x=o.x):a.w+=o.x-a.x;let l,d=.5;for(let f of i){if(f.locked||!f._rect)break;let s=f._rect,c=Number.MAX_VALUE,m=Number.MAX_VALUE;o.y<s.y?c=(a.y+a.h-s.y)/s.h:o.y+o.h>s.y+s.h&&(c=(s.y+s.h-a.y)/s.h),o.x<s.x?m=(a.x+a.w-s.x)/s.w:o.x+o.w>s.x+s.w&&(m=(s.x+s.w-a.x)/s.w);let y=Math.min(m,c);y>d&&(d=y,l=f)}return t.collide=l,l}cacheRects(e,t,i,o,a,l){return this.nodes.forEach(d=>d._rect={y:d.y*t+i,x:d.x*e+l,w:d.w*e-l-o,h:d.h*t-i-a}),this}swap(e,t){if(!t||t.locked||!e||e.locked)return!1;function i(){let a=t.x,l=t.y;return t.x=e.x,t.y=e.y,e.h!=t.h?(e.x=a,e.y=t.y+t.h):e.w!=t.w?(e.x=t.x+t.w,e.y=l):(e.x=a,e.y=l),e._dirty=t._dirty=!0,!0}let o;if(e.w===t.w&&e.h===t.h&&(e.x===t.x||e.y===t.y)&&(o=A.isTouching(e,t)))return i();if(o!==!1){if(e.w===t.w&&e.x===t.x&&(o||(o=A.isTouching(e,t)))){if(t.y<e.y){let a=e;e=t,t=a}return i()}if(o!==!1){if(e.h===t.h&&e.y===t.y&&(o||(o=A.isTouching(e,t)))){if(t.x<e.x){let a=e;e=t,t=a}return i()}return!1}}}isAreaEmpty(e,t,i,o){let a={x:e||0,y:t||0,w:i||1,h:o||1};return!this.collide(a)}compact(e="compact",t=!0){if(this.nodes.length===0)return this;t&&this.sortNodes();let i=this.batchMode;i||this.batchUpdate();let o=this._inColumnResize;o||(this._inColumnResize=!0);let a=this.nodes;return this.nodes=[],a.forEach((l,d,f)=>{let s;l.locked||(l.autoPosition=!0,e==="list"&&d&&(s=f[d-1])),this.addNode(l,!1,s)}),o||delete this._inColumnResize,i||this.batchUpdate(!1),this}set float(e){this._float!==e&&(this._float=e||!1,e||this._packNodes()._notify())}get float(){return this._float||!1}sortNodes(e=1){return this.nodes=A.sort(this.nodes,e),this}_packNodes(){return this.batchMode?this:(this.sortNodes(),this.float?this.nodes.forEach(e=>{if(e._updating||e._orig===void 0||e.y===e._orig.y)return;let t=e.y;for(;t>e._orig.y;)--t,this.collide(e,{x:e.x,y:t,w:e.w,h:e.h})||(e._dirty=!0,e.y=t)}):this.nodes.forEach((e,t)=>{if(!e.locked)for(;e.y>0;){let i=t===0?0:e.y-1;if(!(t===0||!this.collide(e,{x:e.x,y:i,w:e.w,h:e.h})))break;e._dirty=e.y!==i,e.y=i}}),this)}prepareNode(e,t){e._id=e._id??r._idSeq++;let i=e.id;if(i){let a=1;for(;this.nodes.find(l=>l.id===e.id&&l!==e);)e.id=i+"_"+a++}(e.x===void 0||e.y===void 0||e.x===null||e.y===null)&&(e.autoPosition=!0);let o={x:0,y:0,w:1,h:1};return A.defaults(e,o),e.autoPosition||delete e.autoPosition,e.noResize||delete e.noResize,e.noMove||delete e.noMove,A.sanitizeMinMax(e),typeof e.x=="string"&&(e.x=Number(e.x)),typeof e.y=="string"&&(e.y=Number(e.y)),typeof e.w=="string"&&(e.w=Number(e.w)),typeof e.h=="string"&&(e.h=Number(e.h)),isNaN(e.x)&&(e.x=o.x,e.autoPosition=!0),isNaN(e.y)&&(e.y=o.y,e.autoPosition=!0),isNaN(e.w)&&(e.w=o.w),isNaN(e.h)&&(e.h=o.h),this.nodeBoundFix(e,t),e}nodeBoundFix(e,t){let i=e._orig||A.copyPos({},e);if(e.maxW&&(e.w=Math.min(e.w||1,e.maxW)),e.maxH&&(e.h=Math.min(e.h||1,e.maxH)),e.minW&&(e.w=Math.max(e.w||1,e.minW)),e.minH&&(e.h=Math.max(e.h||1,e.minH)),(e.x||0)+(e.w||1)>this.column&&this.column<this.defaultColumn&&!this._inColumnResize&&!this.skipCacheUpdate&&e._id&&this.findCacheLayout(e,this.defaultColumn)===-1){let a=K({},e);a.autoPosition||a.x===void 0?(delete a.x,delete a.y):a.x=Math.min(this.defaultColumn-1,a.x),a.w=Math.min(this.defaultColumn,a.w||1),this.cacheOneLayout(a,this.defaultColumn)}return e.w>this.column?e.w=this.column:e.w<1&&(e.w=1),this.maxRow&&e.h>this.maxRow?e.h=this.maxRow:e.h<1&&(e.h=1),e.x<0&&(e.x=0),e.y<0&&(e.y=0),e.x+e.w>this.column&&(t?e.w=this.column-e.x:e.x=this.column-e.w),this.maxRow&&e.y+e.h>this.maxRow&&(t?e.h=this.maxRow-e.y:e.y=this.maxRow-e.h),A.samePos(e,i)||(e._dirty=!0),this}getDirtyNodes(e){return e?this.nodes.filter(t=>t._dirty&&!A.samePos(t,t._orig)):this.nodes.filter(t=>t._dirty)}_notify(e){if(this.batchMode||!this.onChange)return this;let t=(e||[]).concat(this.getDirtyNodes());return this.onChange(t),this}cleanNodes(){return this.batchMode?this:(this.nodes.forEach(e=>{delete e._dirty,delete e._lastTried}),this)}saveInitial(){return this.nodes.forEach(e=>{e._orig=A.copyPos({},e),delete e._dirty}),this._hasLocked=this.nodes.some(e=>e.locked),this}restoreInitial(){return this.nodes.forEach(e=>{!e._orig||A.samePos(e,e._orig)||(A.copyPos(e,e._orig),e._dirty=!0)}),this._notify(),this}findEmptyPosition(e,t=this.nodes,i=this.column,o){let a=o?o.y*i+(o.x+o.w):0,l=!1;for(let d=a;!l;++d){let f=d%i,s=Math.floor(d/i);if(f+e.w>i)continue;let c={x:f,y:s,w:e.w,h:e.h};t.find(m=>A.isIntercepted(c,m))||((e.x!==f||e.y!==s)&&(e._dirty=!0),e.x=f,e.y=s,delete e.autoPosition,l=!0)}return l}addNode(e,t=!1,i){let o=this.nodes.find(l=>l._id===e._id);if(o)return o;this._inColumnResize?this.nodeBoundFix(e):this.prepareNode(e),delete e._temporaryRemoved,delete e._removeDOM;let a;return e.autoPosition&&this.findEmptyPosition(e,this.nodes,this.column,i)&&(delete e.autoPosition,a=!0),this.nodes.push(e),t&&this.addedNodes.push(e),a||this._fixCollisions(e),this.batchMode||this._packNodes()._notify(),e}removeNode(e,t=!0,i=!1){return this.nodes.find(o=>o._id===e._id)?(i&&this.removedNodes.push(e),t&&(e._removeDOM=!0),this.nodes=this.nodes.filter(o=>o._id!==e._id),e._isAboutToRemove||this._packNodes(),this._notify([e]),this):this}removeAll(e=!0,t=!0){if(delete this._layouts,!this.nodes.length)return this;e&&this.nodes.forEach(o=>o._removeDOM=!0);let i=this.nodes;return this.removedNodes=t?i:[],this.nodes=[],this._notify(i)}moveNodeCheck(e,t){if(!this.changedPosConstrain(e,t))return!1;if(t.pack=!0,!this.maxRow)return this.moveNode(e,t);let i,o=new r({column:this.column,float:this.float,nodes:this.nodes.map(l=>l._id===e._id?(i=K({},l),i):K({},l))});if(!i)return!1;let a=o.moveNode(i,t)&&o.getRow()<=Math.max(this.getRow(),this.maxRow);if(!a&&!t.resizing&&t.collide){let l=t.collide.el.gridstackNode;if(this.swap(e,l))return this._notify(),!0}return a?(o.nodes.filter(l=>l._dirty).forEach(l=>{let d=this.nodes.find(f=>f._id===l._id);d&&(A.copyPos(d,l),d._dirty=!0)}),this._notify(),!0):!1}willItFit(e){if(delete e._willFitPos,!this.maxRow)return!0;let t=new r({column:this.column,float:this.float,nodes:this.nodes.map(o=>K({},o))}),i=K({},e);return this.cleanupNode(i),delete i.el,delete i._id,delete i.content,delete i.grid,t.addNode(i),t.getRow()<=this.maxRow?(e._willFitPos=A.copyPos({},i),!0):!1}changedPosConstrain(e,t){return t.w=t.w||e.w,t.h=t.h||e.h,e.x!==t.x||e.y!==t.y?!0:(e.maxW&&(t.w=Math.min(t.w,e.maxW)),e.maxH&&(t.h=Math.min(t.h,e.maxH)),e.minW&&(t.w=Math.max(t.w,e.minW)),e.minH&&(t.h=Math.max(t.h,e.minH)),e.w!==t.w||e.h!==t.h)}moveNode(e,t){if(!e||!t)return!1;let i;t.pack===void 0&&!this.batchMode&&(i=t.pack=!0),typeof t.x!="number"&&(t.x=e.x),typeof t.y!="number"&&(t.y=e.y),typeof t.w!="number"&&(t.w=e.w),typeof t.h!="number"&&(t.h=e.h);let o=e.w!==t.w||e.h!==t.h,a=A.copyPos({},e,!0);if(A.copyPos(a,t),this.nodeBoundFix(a,o),A.copyPos(t,a),!t.forceCollide&&A.samePos(e,t))return!1;let l=A.copyPos({},e),d=this.collideAll(e,a,t.skip),f=!0;if(d.length){let s=e._moving&&!t.nested,c=s?this.directionCollideCoverage(e,t,d):d[0];if(s&&c&&e.grid?.opts?.subGridDynamic&&!e.grid._isTemp){let m=A.areaIntercept(t.rect,c._rect),y=A.area(t.rect),k=A.area(c._rect);m/(y<k?y:k)>.8&&(c.grid.makeSubGrid(c.el,void 0,e),c=void 0)}c?f=!this._fixCollisions(e,a,c,t):(f=!1,i&&delete t.pack)}return f&&!A.samePos(e,a)&&(e._dirty=!0,A.copyPos(e,a)),t.pack&&this._packNodes()._notify(),!A.samePos(e,l)}getRow(){return this.nodes.reduce((e,t)=>Math.max(e,t.y+t.h),0)}beginUpdate(e){return e._updating||(e._updating=!0,delete e._skipDown,this.batchMode||this.saveInitial()),this}endUpdate(){let e=this.nodes.find(t=>t._updating);return e&&(delete e._updating,delete e._skipDown),this}save(e=!0,t){let i=this._layouts?.length,o=i&&this.column!==i-1?this._layouts[i-1]:null,a=[];return this.sortNodes(),this.nodes.forEach(l=>{let d=o?.find(s=>s._id===l._id),f=K(K({},l),d||{});A.removeInternalForSave(f,!e),t&&t(l,f),a.push(f)}),a}layoutsNodesChange(e){return!this._layouts||this._inColumnResize?this:(this._layouts.forEach((t,i)=>{if(!t||i===this.column)return this;if(i<this.column)this._layouts[i]=void 0;else{let o=i/this.column;e.forEach(a=>{if(!a._orig)return;let l=t.find(d=>d._id===a._id);l&&(l.y>=0&&a.y!==a._orig.y&&(l.y+=a.y-a._orig.y),a.x!==a._orig.x&&(l.x=Math.round(a.x*o)),a.w!==a._orig.w&&(l.w=Math.round(a.w*o)))})}}),this)}columnChanged(e,t,i="moveScale"){if(!this.nodes.length||!t||e===t)return this;let o=i==="compact"||i==="list";o&&this.sortNodes(1),t<e&&this.cacheLayout(this.nodes,e),this.batchUpdate();let a=[],l=o?this.nodes:A.sort(this.nodes,-1);if(t>e&&this._layouts){let d=this._layouts[t]||[],f=this._layouts.length-1;!d.length&&e!==f&&this._layouts[f]?.length&&(e=f,this._layouts[f].forEach(s=>{let c=l.find(m=>m._id===s._id);c&&(!o&&!s.autoPosition&&(c.x=s.x??c.x,c.y=s.y??c.y),c.w=s.w??c.w,(s.x==null||s.y===void 0)&&(c.autoPosition=!0))})),d.forEach(s=>{let c=l.findIndex(m=>m._id===s._id);if(c!==-1){let m=l[c];if(o){m.w=s.w;return}(s.autoPosition||isNaN(s.x)||isNaN(s.y))&&this.findEmptyPosition(s,a),s.autoPosition||(m.x=s.x??m.x,m.y=s.y??m.y,m.w=s.w??m.w,a.push(m)),l.splice(c,1)}})}if(o)this.compact(i,!1);else{if(l.length)if(typeof i=="function")i(t,e,a,l);else{let d=o||i==="none"?1:t/e,f=i==="move"||i==="moveScale",s=i==="scale"||i==="moveScale";l.forEach(c=>{c.x=t===1?0:f?Math.round(c.x*d):Math.min(c.x,t-1),c.w=t===1||e===1?1:s?Math.round(c.w*d)||1:Math.min(c.w,t),a.push(c)}),l=[]}a=A.sort(a,-1),this._inColumnResize=!0,this.nodes=[],a.forEach(d=>{this.addNode(d,!1),delete d._orig})}return this.nodes.forEach(d=>delete d._orig),this.batchUpdate(!1,!o),delete this._inColumnResize,this}cacheLayout(e,t,i=!1){let o=[];return e.forEach((a,l)=>{if(a._id===void 0){let d=a.id?this.nodes.find(f=>f.id===a.id):void 0;a._id=d?._id??r._idSeq++}o[l]={x:a.x,y:a.y,w:a.w,_id:a._id}}),this._layouts=i?[]:this._layouts||[],this._layouts[t]=o,this}cacheOneLayout(e,t){e._id=e._id??r._idSeq++;let i={x:e.x,y:e.y,w:e.w,_id:e._id};(e.autoPosition||e.x===void 0)&&(delete i.x,delete i.y,e.autoPosition&&(i.autoPosition=!0)),this._layouts=this._layouts||[],this._layouts[t]=this._layouts[t]||[];let o=this.findCacheLayout(e,t);return o===-1?this._layouts[t].push(i):this._layouts[t][o]=i,this}findCacheLayout(e,t){return this._layouts?.[t]?.findIndex(i=>i._id===e._id)??-1}removeNodeFromLayoutCache(e){if(this._layouts)for(let t=0;t<this._layouts.length;t++){let i=this.findCacheLayout(e,t);i!==-1&&this._layouts[t].splice(i,1)}}cleanupNode(e){for(let t in e)t[0]==="_"&&t!=="_id"&&delete e[t];return this}}return r._idSeq=0,r})();var zt={alwaysShowResizeHandle:"mobile",animate:!0,auto:!0,cellHeight:"auto",cellHeightThrottle:100,cellHeightUnit:"px",column:12,draggable:{handle:".grid-stack-item-content",appendTo:"body",scroll:!0},handle:".grid-stack-item-content",itemClass:"grid-stack-item",margin:10,marginUnit:"px",maxRow:0,minRow:0,placeholderClass:"grid-stack-placeholder",placeholderText:"",removableOptions:{accept:"grid-stack-item",decline:"grid-stack-non-removable"},resizable:{handles:"se"},rtl:"auto"};var ne=class{};var At=typeof window<"u"&&typeof document<"u"&&("ontouchstart"in document||"ontouchstart"in window||window.DocumentTouch&&document instanceof window.DocumentTouch||navigator.maxTouchPoints>0||navigator.msMaxTouchPoints>0),ni=class{};function So(r,n){r.touches.length>1||(r.cancelable&&r.preventDefault(),A.simulateMouseEvent(r.changedTouches[0],n))}function Ld(r,n){r.cancelable&&r.preventDefault(),A.simulateMouseEvent(r,n)}function Zn(r){ni.touchHandled||(ni.touchHandled=!0,So(r,"mousedown"))}function Jn(r){ni.touchHandled&&So(r,"mousemove")}function er(r){if(!ni.touchHandled)return;ni.pointerLeaveTimeout&&(window.clearTimeout(ni.pointerLeaveTimeout),delete ni.pointerLeaveTimeout);let n=!!ne.dragElement;So(r,"mouseup"),n||So(r,"click"),ni.touchHandled=!1}function tr(r){r.pointerType!=="mouse"&&r.target.releasePointerCapture(r.pointerId)}function qa(r){ne.dragElement&&r.pointerType!=="mouse"&&Ld(r,"mouseenter")}function Ya(r){ne.dragElement&&r.pointerType!=="mouse"&&(ni.pointerLeaveTimeout=window.setTimeout(()=>{delete ni.pointerLeaveTimeout,Ld(r,"mouseleave")},10))}var Vd=(()=>{class r{constructor(e,t,i){this.host=e,this.dir=t,this.option=i,this.moving=!1,this._mouseDown=this._mouseDown.bind(this),this._mouseMove=this._mouseMove.bind(this),this._mouseUp=this._mouseUp.bind(this),this._keyEvent=this._keyEvent.bind(this),this._init()}_init(){let e=this.el=document.createElement("div");return e.classList.add("ui-resizable-handle"),e.classList.add(`${r.prefix}${this.dir}`),e.style.zIndex="100",e.style.userSelect="none",this.host.appendChild(this.el),this.el.addEventListener("mousedown",this._mouseDown),At&&(this.el.addEventListener("touchstart",Zn),this.el.addEventListener("pointerdown",tr)),this}destroy(){return this.moving&&this._mouseUp(this.mouseDownEvent),this.el.removeEventListener("mousedown",this._mouseDown),At&&(this.el.removeEventListener("touchstart",Zn),this.el.removeEventListener("pointerdown",tr)),this.host.removeChild(this.el),delete this.el,delete this.host,this}_mouseDown(e){this.mouseDownEvent=e,document.addEventListener("mousemove",this._mouseMove,{capture:!0,passive:!0}),document.addEventListener("mouseup",this._mouseUp,!0),At&&(this.el.addEventListener("touchmove",Jn),this.el.addEventListener("touchend",er)),e.stopPropagation(),e.preventDefault()}_mouseMove(e){let t=this.mouseDownEvent;this.moving?this._triggerEvent("move",e):Math.abs(e.x-t.x)+Math.abs(e.y-t.y)>2&&(this.moving=!0,this._triggerEvent("start",this.mouseDownEvent),this._triggerEvent("move",e),document.addEventListener("keydown",this._keyEvent)),e.stopPropagation()}_mouseUp(e){this.moving&&(this._triggerEvent("stop",e),document.removeEventListener("keydown",this._keyEvent)),document.removeEventListener("mousemove",this._mouseMove,!0),document.removeEventListener("mouseup",this._mouseUp,!0),At&&(this.el.removeEventListener("touchmove",Jn),this.el.removeEventListener("touchend",er)),delete this.moving,delete this.mouseDownEvent,e.stopPropagation(),e.preventDefault()}_keyEvent(e){e.key==="Escape"&&(this.host.gridstackNode?.grid?.engine.restoreInitial(),this._mouseUp(this.mouseDownEvent))}_triggerEvent(e,t){return this.option[e]&&this.option[e](t),this}}return r.prefix="ui-resizable-",r})();var qi=class{constructor(){this._eventRegister={}}get disabled(){return this._disabled}on(n,e){this._eventRegister[n]=e}off(n){delete this._eventRegister[n]}enable(){this._disabled=!1}disable(){this._disabled=!0}destroy(){delete this._eventRegister}triggerEvent(n,e){if(!this.disabled&&this._eventRegister&&this._eventRegister[n])return this._eventRegister[n](e)}};var Fd=(()=>{class r extends qi{constructor(e,t={}){super(),this.el=e,this.option=t,this.rectScale={x:1,y:1},this._ui=()=>{let o=this.el.parentElement.getBoundingClientRect(),a={width:this.originalRect.width,height:this.originalRect.height+this.scrolled,left:this.originalRect.left,top:this.originalRect.top-this.scrolled},l=this.temporalRect||a;return{position:{left:(l.left-o.left)*this.rectScale.x,top:(l.top-o.top)*this.rectScale.y},size:{width:l.width*this.rectScale.x,height:l.height*this.rectScale.y}}},this._mouseOver=this._mouseOver.bind(this),this._mouseOut=this._mouseOut.bind(this),this.enable(),this._setupAutoHide(this.option.autoHide),this._setupHandlers()}on(e,t){super.on(e,t)}off(e){super.off(e)}enable(){super.enable(),this.el.classList.remove("ui-resizable-disabled"),this._setupAutoHide(this.option.autoHide)}disable(){super.disable(),this.el.classList.add("ui-resizable-disabled"),this._setupAutoHide(!1)}destroy(){this._removeHandlers(),this._setupAutoHide(!1),delete this.el,super.destroy()}updateOption(e){let t=e.handles&&e.handles!==this.option.handles,i=e.autoHide&&e.autoHide!==this.option.autoHide;return Object.keys(e).forEach(o=>this.option[o]=e[o]),t&&(this._removeHandlers(),this._setupHandlers()),i&&this._setupAutoHide(this.option.autoHide),this}_setupAutoHide(e){return e?(this.el.classList.add("ui-resizable-autohide"),this.el.addEventListener("mouseover",this._mouseOver),this.el.addEventListener("mouseout",this._mouseOut)):(this.el.classList.remove("ui-resizable-autohide"),this.el.removeEventListener("mouseover",this._mouseOver),this.el.removeEventListener("mouseout",this._mouseOut),ne.overResizeElement===this&&delete ne.overResizeElement),this}_mouseOver(e){ne.overResizeElement||ne.dragElement||(ne.overResizeElement=this,this.el.classList.remove("ui-resizable-autohide"))}_mouseOut(e){ne.overResizeElement===this&&(delete ne.overResizeElement,this.el.classList.add("ui-resizable-autohide"))}_setupHandlers(){return this.handlers=this.option.handles.split(",").map(e=>e.trim()).map(e=>new Vd(this.el,e,{start:t=>{this._resizeStart(t)},stop:t=>{this._resizeStop(t)},move:t=>{this._resizing(t,e)}})),this}_resizeStart(e){this.sizeToContent=A.shouldSizeToContent(this.el.gridstackNode,!0),this.originalRect=this.el.getBoundingClientRect(),this.scrollEl=A.getScrollElement(this.el),this.scrollY=this.scrollEl.scrollTop,this.scrolled=0,this.startEvent=e,this._setupHelper(),this._applyChange();let t=A.initEvent(e,{type:"resizestart",target:this.el});return this.option.start&&this.option.start(t,this._ui()),this.el.classList.add("ui-resizable-resizing"),this.triggerEvent("resizestart",t),this}_resizing(e,t){this.scrolled=this.scrollEl.scrollTop-this.scrollY,this.temporalRect=this._getChange(e,t),this._applyChange();let i=A.initEvent(e,{type:"resize",target:this.el});return this.option.resize&&this.option.resize(i,this._ui()),this.triggerEvent("resize",i),this}_resizeStop(e){let t=A.initEvent(e,{type:"resizestop",target:this.el});return this.option.stop&&this.option.stop(t),this.el.classList.remove("ui-resizable-resizing"),this.triggerEvent("resizestop",t),this._cleanHelper(),delete this.startEvent,delete this.originalRect,delete this.temporalRect,delete this.scrollY,delete this.scrolled,this}_setupHelper(){this.elOriginStyleVal=r._originStyleProp.map(i=>this.el.style[i]),this.parentOriginStylePosition=this.el.parentElement.style.position;let e=this.el.parentElement,t=A.getValuesFromTransformedElement(e);return this.rectScale={x:t.xScale,y:t.yScale},getComputedStyle(this.el.parentElement).position.match(/static/)&&(this.el.parentElement.style.position="relative"),this.el.style.position="absolute",this.el.style.opacity="0.8",this}_cleanHelper(){return r._originStyleProp.forEach((e,t)=>{this.el.style[e]=this.elOriginStyleVal[t]||null}),this.el.parentElement.style.position=this.parentOriginStylePosition||null,this}_getChange(e,t){let i=this.startEvent,o={width:this.originalRect.width,height:this.originalRect.height+this.scrolled,left:this.originalRect.left,top:this.originalRect.top-this.scrolled},a=e.clientX-i.clientX,l=this.sizeToContent?0:e.clientY-i.clientY,d,f;t.indexOf("e")>-1?o.width+=a:t.indexOf("w")>-1&&(o.width-=a,o.left+=a,d=!0),t.indexOf("s")>-1?o.height+=l:t.indexOf("n")>-1&&(o.height-=l,o.top+=l,f=!0);let s=this._constrainSize(o.width,o.height,d,f);return Math.round(o.width)!==Math.round(s.width)&&(t.indexOf("w")>-1&&(o.left+=o.width-s.width),o.width=s.width),Math.round(o.height)!==Math.round(s.height)&&(t.indexOf("n")>-1&&(o.top+=o.height-s.height),o.height=s.height),o}_constrainSize(e,t,i,o){let a=this.option,l=(i?a.maxWidthMoveLeft:a.maxWidth)||Number.MAX_SAFE_INTEGER,d=a.minWidth/this.rectScale.x||e,f=(o?a.maxHeightMoveUp:a.maxHeight)||Number.MAX_SAFE_INTEGER,s=a.minHeight/this.rectScale.y||t,c=Math.min(l,Math.max(d,e)),m=Math.min(f,Math.max(s,t));return{width:c,height:m}}_applyChange(){let e={left:0,top:0,width:0,height:0};if(this.el.style.position==="absolute"){let t=this.el.parentElement,{left:i,top:o}=t.getBoundingClientRect();e={left:i,top:o,width:0,height:0}}return this.temporalRect?(Object.keys(this.temporalRect).forEach(t=>{let i=this.temporalRect[t],o=t==="width"||t==="left"?this.rectScale.x:t==="height"||t==="top"?this.rectScale.y:1;this.el.style[t]=(i-e[t])*o+"px"}),this):this}_removeHandlers(){return this.handlers.forEach(e=>e.destroy()),delete this.handlers,this}}return r._originStyleProp=["width","height","position","left","top","opacity","zIndex"],r})();var Fu='input,textarea,button,select,option,[contenteditable="true"],.ui-resizable-handle',Hd=(()=>{class r extends qi{constructor(e,t={}){super(),this.el=e,this.option=t,this.dragTransform={xScale:1,yScale:1,xOffset:0,yOffset:0};let i=t?.handle?.substring(1),o=e.gridstackNode;this.dragEls=!i||e.classList.contains(i)?[e]:o?.subGrid?[e.querySelector(t.handle)||e]:Array.from(e.querySelectorAll(t.handle)),this.dragEls.length===0&&(this.dragEls=[e]),this._mouseDown=this._mouseDown.bind(this),this._mouseMove=this._mouseMove.bind(this),this._mouseUp=this._mouseUp.bind(this),this._keyEvent=this._keyEvent.bind(this),this.enable()}on(e,t){super.on(e,t)}off(e){super.off(e)}enable(){this.disabled!==!1&&(super.enable(),this.dragEls.forEach(e=>{e.addEventListener("mousedown",this._mouseDown),At&&(e.addEventListener("touchstart",Zn),e.addEventListener("pointerdown",tr))}),this.el.classList.remove("ui-draggable-disabled"))}disable(e=!1){this.disabled!==!0&&(super.disable(),this.dragEls.forEach(t=>{t.removeEventListener("mousedown",this._mouseDown),At&&(t.removeEventListener("touchstart",Zn),t.removeEventListener("pointerdown",tr))}),e||this.el.classList.add("ui-draggable-disabled"))}destroy(){this.dragTimeout&&window.clearTimeout(this.dragTimeout),delete this.dragTimeout,this.mouseDownEvent&&this._mouseUp(this.mouseDownEvent),this.disable(!0),delete this.el,delete this.helper,delete this.option,super.destroy()}updateOption(e){return Object.keys(e).forEach(t=>this.option[t]=e[t]),this}_mouseDown(e){if(!ne.mouseHandled)return e.button!==0||!this.dragEls.find(t=>t===e.target)&&e.target.closest(Fu)||this.option.cancel&&e.target.closest(this.option.cancel)||(this.mouseDownEvent=e,delete this.dragging,delete ne.dragElement,delete ne.dropElement,document.addEventListener("mousemove",this._mouseMove,{capture:!0,passive:!0}),document.addEventListener("mouseup",this._mouseUp,!0),At&&(e.currentTarget.addEventListener("touchmove",Jn),e.currentTarget.addEventListener("touchend",er)),e.preventDefault(),document.activeElement&&document.activeElement.blur(),ne.mouseHandled=!0),!0}_callDrag(e){if(!this.dragging)return;let t=A.initEvent(e,{target:this.el,type:"drag"});this.option.drag&&this.option.drag(t,this.ui()),this.triggerEvent("drag",t)}_mouseMove(e){let t=this.mouseDownEvent;if(this.lastDrag=e,this.dragging)if(this._dragFollow(e),ne.pauseDrag){let i=Number.isInteger(ne.pauseDrag)?ne.pauseDrag:100;this.dragTimeout&&window.clearTimeout(this.dragTimeout),this.dragTimeout=window.setTimeout(()=>this._callDrag(e),i)}else this._callDrag(e);else if(Math.abs(e.x-t.x)+Math.abs(e.y-t.y)>3){this.dragging=!0,ne.dragElement=this;let i=this.el.gridstackNode?.grid;i?ne.dropElement=i.el.ddElement.ddDroppable:delete ne.dropElement,this.helper=this._createHelper(),this._setupHelperContainmentStyle(),this.dragTransform=A.getValuesFromTransformedElement(this.helperContainment),this.dragOffset=this._getDragOffset(e,this.el,this.helperContainment),this._setupHelperStyle(e);let o=A.initEvent(e,{target:this.el,type:"dragstart"});this.option.start&&this.option.start(o,this.ui()),this.triggerEvent("dragstart",o),document.addEventListener("keydown",this._keyEvent)}return!0}_mouseUp(e){if(document.removeEventListener("mousemove",this._mouseMove,!0),document.removeEventListener("mouseup",this._mouseUp,!0),At&&e.currentTarget&&(e.currentTarget.removeEventListener("touchmove",Jn,!0),e.currentTarget.removeEventListener("touchend",er,!0)),this.dragging){delete this.dragging,delete this.el.gridstackNode?._origRotate,document.removeEventListener("keydown",this._keyEvent),ne.dropElement?.el===this.el.parentElement&&delete ne.dropElement,this.helperContainment.style.position=this.parentOriginStylePosition||null,this.helper!==this.el&&this.helper.remove(),this._removeHelperStyle();let t=A.initEvent(e,{target:this.el,type:"dragstop"});this.option.stop&&this.option.stop(t),this.triggerEvent("dragstop",t),ne.dropElement&&ne.dropElement.drop(e)}delete this.helper,delete this.mouseDownEvent,delete ne.dragElement,delete ne.dropElement,delete ne.mouseHandled,e.preventDefault()}_keyEvent(e){let t=this.el.gridstackNode,i=t?.grid||ne.dropElement?.el?.gridstack;if(e.key==="Escape")t&&t._origRotate&&(t._orig=t._origRotate,delete t._origRotate),i?.cancelDrag(),this._mouseUp(this.mouseDownEvent);else if(t&&i&&(e.key==="r"||e.key==="R")){if(!A.canBeRotated(t))return;t._origRotate=t._origRotate||K({},t._orig),delete t._moving,i.setAnimation(!1).rotate(t.el,{top:-this.dragOffset.offsetTop,left:-this.dragOffset.offsetLeft}).setAnimation(),t._moving=!0,this.dragOffset=this._getDragOffset(this.lastDrag,t.el,this.helperContainment),this.helper.style.width=this.dragOffset.width+"px",this.helper.style.height=this.dragOffset.height+"px",A.swap(t._orig,"w","h"),delete t._rect,this._mouseMove(this.lastDrag)}}_createHelper(){let e=this.el;return typeof this.option.helper=="function"?e=this.option.helper(this.el):this.option.helper==="clone"&&(e=A.cloneNode(this.el)),e.parentElement||A.appendTo(e,this.option.appendTo==="parent"?this.el.parentElement:this.option.appendTo),this.dragElementOriginStyle=r.originStyleProp.map(t=>this.el.style[t]),e}_setupHelperStyle(e){this.helper.classList.add("ui-draggable-dragging");let t=this.helper.style;return t.pointerEvents="none",t.width=this.dragOffset.width+"px",t.height=this.dragOffset.height+"px",t.willChange="left, top",t.position="fixed",this._dragFollow(e),t.transition="none",setTimeout(()=>{this.helper&&(t.transition=null)},0),this}_removeHelperStyle(){if(this.helper.classList.remove("ui-draggable-dragging"),!this.helper?.gridstackNode?._isAboutToRemove&&this.dragElementOriginStyle){let t=this.helper,i=this.dragElementOriginStyle.transition||null;t.style.transition=this.dragElementOriginStyle.transition="none",r.originStyleProp.forEach(o=>t.style[o]=this.dragElementOriginStyle[o]||null),setTimeout(()=>t.style.transition=i,50)}return delete this.dragElementOriginStyle,this}_dragFollow(e){let t={left:0,top:0},i=this.helper.style,o=this.dragOffset;i.left=(e.clientX+o.offsetLeft-t.left)*this.dragTransform.xScale+"px",i.top=(e.clientY+o.offsetTop-t.top)*this.dragTransform.yScale+"px"}_setupHelperContainmentStyle(){return this.helperContainment=this.helper.parentElement,this.helper.style.position!=="fixed"&&(this.parentOriginStylePosition=this.helperContainment.style.position,getComputedStyle(this.helperContainment).position.match(/static/)&&(this.helperContainment.style.position="relative")),this}_getDragOffset(e,t,i){let o=0,a=0;i&&(o=this.dragTransform.xOffset,a=this.dragTransform.yOffset);let l=t.getBoundingClientRect();return{left:l.left,top:l.top,offsetLeft:-e.clientX+l.left-o,offsetTop:-e.clientY+l.top-a,width:l.width*this.dragTransform.xScale,height:l.height*this.dragTransform.yScale}}ui(){let t=this.el.parentElement.getBoundingClientRect(),i=this.helper.getBoundingClientRect();return{position:{top:(i.top-t.top)*this.dragTransform.yScale,left:(i.left-t.left)*this.dragTransform.xScale}}}}return r.originStyleProp=["width","height","transform","transform-origin","transition","pointerEvents","position","left","top","minWidth","willChange"],r})();var Co=class extends qi{constructor(n,e={}){super(),this.el=n,this.option=e,this._mouseEnter=this._mouseEnter.bind(this),this._mouseLeave=this._mouseLeave.bind(this),this.enable(),this._setupAccept()}on(n,e){super.on(n,e)}off(n){super.off(n)}enable(){this.disabled!==!1&&(super.enable(),this.el.classList.add("ui-droppable"),this.el.classList.remove("ui-droppable-disabled"),this.el.addEventListener("mouseenter",this._mouseEnter),this.el.addEventListener("mouseleave",this._mouseLeave),At&&(this.el.addEventListener("pointerenter",qa),this.el.addEventListener("pointerleave",Ya)))}disable(n=!1){this.disabled!==!0&&(super.disable(),this.el.classList.remove("ui-droppable"),n||this.el.classList.add("ui-droppable-disabled"),this.el.removeEventListener("mouseenter",this._mouseEnter),this.el.removeEventListener("mouseleave",this._mouseLeave),At&&(this.el.removeEventListener("pointerenter",qa),this.el.removeEventListener("pointerleave",Ya)))}destroy(){this.disable(!0),this.el.classList.remove("ui-droppable"),this.el.classList.remove("ui-droppable-disabled"),super.destroy()}updateOption(n){return Object.keys(n).forEach(e=>this.option[e]=n[e]),this._setupAccept(),this}_mouseEnter(n){if(!ne.dragElement||!this._canDrop(ne.dragElement.el))return;n.preventDefault(),n.stopPropagation(),ne.dropElement&&ne.dropElement!==this&&ne.dropElement._mouseLeave(n,!0),ne.dropElement=this;let e=A.initEvent(n,{target:this.el,type:"dropover"});this.option.over&&this.option.over(e,this._ui(ne.dragElement)),this.triggerEvent("dropover",e),this.el.classList.add("ui-droppable-over")}_mouseLeave(n,e=!1){if(!ne.dragElement||ne.dropElement!==this)return;n.preventDefault(),n.stopPropagation();let t=A.initEvent(n,{target:this.el,type:"dropout"});if(this.option.out&&this.option.out(t,this._ui(ne.dragElement)),this.triggerEvent("dropout",t),ne.dropElement===this&&(delete ne.dropElement,!e)){let i,o=this.el.parentElement;for(;!i&&o;)i=o.ddElement?.ddDroppable,o=o.parentElement;i&&i._mouseEnter(n)}}drop(n){n.preventDefault();let e=A.initEvent(n,{target:this.el,type:"drop"});this.option.drop&&this.option.drop(e,this._ui(ne.dragElement)),this.triggerEvent("drop",e)}_canDrop(n){return n&&(!this.accept||this.accept(n))}_setupAccept(){return this.option.accept?(typeof this.option.accept=="string"?this.accept=n=>n.classList.contains(this.option.accept)||n.matches(this.option.accept):this.accept=this.option.accept,this):this}_ui(n){return K({draggable:n.el},n.ui())}};var xo=class r{static init(n){return n.ddElement||(n.ddElement=new r(n)),n.ddElement}constructor(n){this.el=n}on(n,e){return this.ddDraggable&&["drag","dragstart","dragstop"].indexOf(n)>-1?this.ddDraggable.on(n,e):this.ddDroppable&&["drop","dropover","dropout"].indexOf(n)>-1?this.ddDroppable.on(n,e):this.ddResizable&&["resizestart","resize","resizestop"].indexOf(n)>-1&&this.ddResizable.on(n,e),this}off(n){return this.ddDraggable&&["drag","dragstart","dragstop"].indexOf(n)>-1?this.ddDraggable.off(n):this.ddDroppable&&["drop","dropover","dropout"].indexOf(n)>-1?this.ddDroppable.off(n):this.ddResizable&&["resizestart","resize","resizestop"].indexOf(n)>-1&&this.ddResizable.off(n),this}setupDraggable(n){return this.ddDraggable?this.ddDraggable.updateOption(n):this.ddDraggable=new Hd(this.el,n),this}cleanDraggable(){return this.ddDraggable&&(this.ddDraggable.destroy(),delete this.ddDraggable),this}setupResizable(n){return this.ddResizable?this.ddResizable.updateOption(n):this.ddResizable=new Fd(this.el,n),this}cleanResizable(){return this.ddResizable&&(this.ddResizable.destroy(),delete this.ddResizable),this}setupDroppable(n){return this.ddDroppable?this.ddDroppable.updateOption(n):this.ddDroppable=new Co(this.el,n),this}cleanDroppable(){return this.ddDroppable&&(this.ddDroppable.destroy(),delete this.ddDroppable),this}};var To=class{resizable(n,e,t,i){return this._getDDElements(n,e).forEach(o=>{if(e==="disable"||e==="enable")o.ddResizable&&o.ddResizable[e]();else if(e==="destroy")o.ddResizable&&o.cleanResizable();else if(e==="option")o.setupResizable({[t]:i});else{let l=o.el.gridstackNode.grid,d=o.el.getAttribute("gs-resize-handles")||l.opts.resizable.handles||"e,s,se";d==="all"&&(d="n,e,s,w,se,sw,ne,nw");let f=!l.opts.alwaysShowResizeHandle;o.setupResizable(rt(K({},l.opts.resizable),{handles:d,autoHide:f,start:e.start,stop:e.stop,resize:e.resize}))}}),this}draggable(n,e,t,i){return this._getDDElements(n,e).forEach(o=>{if(e==="disable"||e==="enable")o.ddDraggable&&o.ddDraggable[e]();else if(e==="destroy")o.ddDraggable&&o.cleanDraggable();else if(e==="option")o.setupDraggable({[t]:i});else{let a=o.el.gridstackNode.grid;o.setupDraggable(rt(K({},a.opts.draggable),{start:e.start,stop:e.stop,drag:e.drag}))}}),this}dragIn(n,e){return this._getDDElements(n).forEach(t=>t.setupDraggable(e)),this}droppable(n,e,t,i){return typeof e.accept=="function"&&!e._accept&&(e._accept=e.accept,e.accept=o=>e._accept(o)),this._getDDElements(n,e).forEach(o=>{e==="disable"||e==="enable"?o.ddDroppable&&o.ddDroppable[e]():e==="destroy"?o.ddDroppable&&o.cleanDroppable():e==="option"?o.setupDroppable({[t]:i}):o.setupDroppable(e)}),this}isDroppable(n){return!!(n?.ddElement?.ddDroppable&&!n.ddElement.ddDroppable.disabled)}isDraggable(n){return!!(n?.ddElement?.ddDraggable&&!n.ddElement.ddDraggable.disabled)}isResizable(n){return!!(n?.ddElement?.ddResizable&&!n.ddElement.ddResizable.disabled)}on(n,e,t){return this._getDDElements(n).forEach(i=>i.on(e,o=>{t(o,ne.dragElement?ne.dragElement.el:o.target,ne.dragElement?ne.dragElement.helper:null)})),this}off(n,e){return this._getDDElements(n).forEach(t=>t.off(e)),this}_getDDElements(n,e){let t=n.gridstack||e!=="destroy"&&e!=="disable",i=A.getElements(n);return i.length?i.map(a=>a.ddElement||(t?xo.init(a):null)).filter(a=>a):[]}};var Pt=new To,ir=(()=>{class r{static init(e={},t=".grid-stack"){if(typeof document>"u")return null;let i=r.getGridElement(t);return i?(i.gridstack||(i.gridstack=new r(i,A.cloneDeep(e))),i.gridstack):(console.error(typeof t=="string"?'GridStack.initAll() no grid was found with selector "'+t+`" - element missing or wrong selector ?
|
|
4
|
+
Note: ".grid-stack" is required for proper CSS styling and drag/drop, and is the default selector.`:"GridStack.init() no grid element was passed."),null)}static initAll(e={},t=".grid-stack"){let i=[];return typeof document>"u"||(r.getGridElements(t).forEach(o=>{o.gridstack||(o.gridstack=new r(o,A.cloneDeep(e))),i.push(o.gridstack)}),i.length===0&&console.error('GridStack.initAll() no grid was found with selector "'+t+`" - element missing or wrong selector ?
|
|
5
|
+
Note: ".grid-stack" is required for proper CSS styling and drag/drop, and is the default selector.`)),i}static addGrid(e,t={}){if(!e)return null;let i=e;if(i.gridstack){let l=i.gridstack;return t&&(l.opts=K(K({},l.opts),t)),t.children!==void 0&&l.load(t.children),l}return(!e.classList.contains("grid-stack")||r.addRemoveCB)&&(r.addRemoveCB?i=r.addRemoveCB(e,t,!0,!0):i=A.createDiv(["grid-stack",t.class],e)),r.init(t,i)}static registerEngine(e){r.engineClass=e}get placeholder(){if(!this._placeholder){this._placeholder=A.createDiv([this.opts.placeholderClass,zt.itemClass,this.opts.itemClass]);let e=A.createDiv(["placeholder-content"],this._placeholder);this.opts.placeholderText&&(e.textContent=this.opts.placeholderText)}return this._placeholder}constructor(e,t={}){this.el=e,this.opts=t,this.animationDelay=310,this._gsEventHandler={},this._extraDragRow=0,this.dragTransform={xScale:1,yScale:1,xOffset:0,yOffset:0},e.gridstack=this,this.opts=t=t||{},e.classList.contains("grid-stack")||this.el.classList.add("grid-stack"),t.row&&(t.minRow=t.maxRow=t.row,delete t.row);let i=A.toNumber(e.getAttribute("gs-row"));t.column==="auto"&&delete t.column,t.alwaysShowResizeHandle!==void 0&&(t._alwaysShowResizeHandle=t.alwaysShowResizeHandle);let o=t.columnOpts?.breakpoints,a=t;if(a.oneColumnModeDomSort&&(delete a.oneColumnModeDomSort,console.log("warning: Gridstack oneColumnModeDomSort no longer supported. Use GridStackOptions.columnOpts instead.")),a.oneColumnSize||a.disableOneColumnMode===!1){let m=a.oneColumnSize||768;delete a.oneColumnSize,delete a.disableOneColumnMode,t.columnOpts=t.columnOpts||{},o=t.columnOpts.breakpoints=t.columnOpts.breakpoints||[];let y=o.find(k=>k.c===1);y?y.w=m:(y={c:1,w:m},o.push(y,{c:12,w:m+1}))}let l=t.columnOpts;l&&(!l.columnWidth&&!l.breakpoints?.length?(delete t.columnOpts,o=void 0):l.columnMax=l.columnMax||12),o?.length>1&&o.sort((m,y)=>(y.w||0)-(m.w||0));let d=rt(K({},A.cloneDeep(zt)),{column:A.toNumber(e.getAttribute("gs-column"))||zt.column,minRow:i||A.toNumber(e.getAttribute("gs-min-row"))||zt.minRow,maxRow:i||A.toNumber(e.getAttribute("gs-max-row"))||zt.maxRow,staticGrid:A.toBool(e.getAttribute("gs-static"))||zt.staticGrid,sizeToContent:A.toBool(e.getAttribute("gs-size-to-content"))||void 0,draggable:{handle:(t.handleClass?"."+t.handleClass:t.handle?t.handle:"")||zt.draggable.handle},removableOptions:{accept:t.itemClass||zt.removableOptions.accept,decline:zt.removableOptions.decline}});e.getAttribute("gs-animate")&&(d.animate=A.toBool(e.getAttribute("gs-animate"))),t=A.defaults(t,d),this._initMargin(),this.checkDynamicColumn(),this.el.classList.add("gs-"+t.column),t.rtl==="auto"&&(t.rtl=e.style.direction==="rtl"),t.rtl&&this.el.classList.add("grid-stack-rtl");let s=this.el.closest("."+zt.itemClass)?.gridstackNode;s&&(s.subGrid=this,this.parentGridNode=s,this.el.classList.add("grid-stack-nested"),s.el.classList.add("grid-stack-sub-grid")),this._isAutoCellHeight=t.cellHeight==="auto",this._isAutoCellHeight||t.cellHeight==="initial"?this.cellHeight(void 0,!1):(typeof t.cellHeight=="number"&&t.cellHeightUnit&&t.cellHeightUnit!==zt.cellHeightUnit&&(t.cellHeight=t.cellHeight+t.cellHeightUnit,delete t.cellHeightUnit),this.cellHeight(t.cellHeight,!1)),t.alwaysShowResizeHandle==="mobile"&&(t.alwaysShowResizeHandle=At),this._styleSheetClass="gs-id-"+ko._idSeq++,this.el.classList.add(this._styleSheetClass),this._setStaticClass();let c=t.engineClass||r.engineClass||ko;if(this.engine=new c({column:this.getColumn(),float:t.float,maxRow:t.maxRow,onChange:m=>{let y=0;this.engine.nodes.forEach(k=>{y=Math.max(y,k.y+k.h)}),m.forEach(k=>{let x=k.el;x&&(k._removeDOM?(x&&x.remove(),delete k._removeDOM):this._writePosAttr(x,k))}),this._updateStyles(!1,y)}}),this._updateStyles(!1,0),t.auto&&(this.batchUpdate(),this.engine._loading=!0,this.getGridItems().forEach(m=>this._prepareElement(m)),delete this.engine._loading,this.batchUpdate(!1)),t.children){let m=t.children;delete t.children,m.length&&this.load(m)}this.setAnimation(),t.subGridDynamic&&!ne.pauseDrag&&(ne.pauseDrag=!0),t.draggable?.pause!==void 0&&(ne.pauseDrag=t.draggable.pause),this._setupRemoveDrop(),this._setupAcceptWidget(),this._updateResizeEvent()}addWidget(e){if(typeof e=="string"){console.error("V11: GridStack.addWidget() does not support string anymore. see #2736");return}if(e.ELEMENT_NODE)return console.error("V11: GridStack.addWidget() does not support HTMLElement anymore. use makeWidget()"),this.makeWidget(e);let t,i=e;if(i.grid=this,i?.el?t=i.el:r.addRemoveCB?t=r.addRemoveCB(this.el,e,!0,!1):t=this.createWidgetDivs(i),!t)return;if(i=t.gridstackNode,i&&t.parentElement===this.el&&this.engine.nodes.find(a=>a._id===i._id))return t;let o=this._readAttr(t);return A.defaults(e,o),this.engine.prepareNode(e),this.el.appendChild(t),this.makeWidget(t,e),t}createWidgetDivs(e){let t=A.createDiv(["grid-stack-item",this.opts.itemClass]),i=A.createDiv(["grid-stack-item-content"],t);return A.lazyLoad(e)?e.visibleObservable||(e.visibleObservable=new IntersectionObserver(([o])=>{o.isIntersecting&&(e.visibleObservable?.disconnect(),delete e.visibleObservable,r.renderCB(i,e),e.grid?.prepareDragDrop(e.el))}),window.setTimeout(()=>e.visibleObservable?.observe(t))):r.renderCB(i,e),t}makeSubGrid(e,t,i,o=!0){let a=e.gridstackNode;if(a||(a=this.makeWidget(e).gridstackNode),a.subGrid?.el)return a.subGrid;let l,d=this;for(;d&&!l;)l=d.opts?.subGridOpts,d=d.parentGridNode?.grid;t=A.cloneDeep(K(K(rt(K({},this.opts),{id:void 0,children:void 0,column:"auto",columnOpts:void 0,layout:"list",subGridOpts:void 0}),l||{}),t||a.subGridOpts||{})),a.subGridOpts=t;let f;t.column==="auto"&&(f=!0,t.column=Math.max(a.w||1,i?.w||1),delete t.columnOpts);let s=a.el.querySelector(".grid-stack-item-content"),c,m;if(o&&(this._removeDD(a.el),m=rt(K({},a),{x:0,y:0}),A.removeInternalForSave(m),delete m.subGridOpts,a.content&&(m.content=a.content,delete a.content),r.addRemoveCB?c=r.addRemoveCB(this.el,m,!0,!1):(c=A.createDiv(["grid-stack-item"]),c.appendChild(s),s=A.createDiv(["grid-stack-item-content"],a.el)),this.prepareDragDrop(a.el)),i){let k=f?t.column:a.w,x=a.h+i.h,D=a.el.style;D.transition="none",this.update(a.el,{w:k,h:x}),setTimeout(()=>D.transition=null)}let y=a.subGrid=r.addGrid(s,t);return i?._moving&&(y._isTemp=!0),f&&(y._autoColumn=!0),o&&y.makeWidget(c,m),i&&(i._moving?window.setTimeout(()=>A.simulateMouseEvent(i._event,"mouseenter",y.el),0):y.makeWidget(a.el,a)),this.resizeToContentCheck(!1,a),y}removeAsSubGrid(e){let t=this.parentGridNode?.grid;t&&(t.batchUpdate(),t.removeWidget(this.parentGridNode.el,!0,!0),this.engine.nodes.forEach(i=>{i.x+=this.parentGridNode.x,i.y+=this.parentGridNode.y,t.makeWidget(i.el,i)}),t.batchUpdate(!1),this.parentGridNode&&delete this.parentGridNode.subGrid,delete this.parentGridNode,e&&window.setTimeout(()=>A.simulateMouseEvent(e._event,"mouseenter",t.el),0))}save(e=!0,t=!1,i=r.saveCB){let o=this.engine.save(e,i);if(o.forEach(a=>{if(e&&a.el&&!a.subGrid&&!i){let l=a.el.querySelector(".grid-stack-item-content");a.content=l?.innerHTML,a.content||delete a.content}else if(!e&&!i&&delete a.content,a.subGrid?.el){let l=a.subGrid.save(e,t,i);a.subGridOpts=t?l:{children:l},delete a.subGrid}delete a.el}),t){let a=A.cloneDeep(this.opts);a.marginBottom===a.marginTop&&a.marginRight===a.marginLeft&&a.marginTop===a.marginRight&&(a.margin=a.marginTop,delete a.marginTop,delete a.marginRight,delete a.marginBottom,delete a.marginLeft),a.rtl===(this.el.style.direction==="rtl")&&(a.rtl="auto"),this._isAutoCellHeight&&(a.cellHeight="auto"),this._autoColumn&&(a.column="auto");let l=a._alwaysShowResizeHandle;return delete a._alwaysShowResizeHandle,l!==void 0?a.alwaysShowResizeHandle=l:delete a.alwaysShowResizeHandle,A.removeInternalAndSame(a,zt),a.children=o,a}return o}load(e,t=r.addRemoveCB||!0){e=A.cloneDeep(e);let i=this.getColumn();e.forEach(s=>{s.w=s.w||1,s.h=s.h||1}),e=A.sort(e),this.engine.skipCacheUpdate=this._ignoreLayoutsNodeChange=!0;let o=0;e.forEach(s=>{o=Math.max(o,(s.x||0)+s.w)}),o>this.engine.defaultColumn&&(this.engine.defaultColumn=o),o>i&&this.engine.cacheLayout(e,o,!0);let a=r.addRemoveCB;typeof t=="function"&&(r.addRemoveCB=t);let l=[];this.batchUpdate();let d=!this.engine.nodes.length;d&&this.setAnimation(!1),!d&&t&&[...this.engine.nodes].forEach(c=>{if(!c.id)return;A.find(e,c.id)||(r.addRemoveCB&&r.addRemoveCB(this.el,c,!1,!1),l.push(c),this.removeWidget(c.el,!0,!1))}),this.engine._loading=!0;let f=[];return this.engine.nodes=this.engine.nodes.filter(s=>A.find(e,s.id)?(f.push(s),!1):!0),e.forEach(s=>{let c=A.find(f,s.id);if(c){if(A.shouldSizeToContent(c)&&(s.h=c.h),this.engine.nodeBoundFix(s),(s.autoPosition||s.x===void 0||s.y===void 0)&&(s.w=s.w||c.w,s.h=s.h||c.h,this.engine.findEmptyPosition(s)),this.engine.nodes.push(c),A.samePos(c,s)&&this.engine.nodes.length>1&&(this.moveNode(c,rt(K({},s),{forceCollide:!0})),A.copyPos(s,c)),this.update(c.el,s),s.subGridOpts?.children){let m=c.el.querySelector(".grid-stack");m&&m.gridstack&&m.gridstack.load(s.subGridOpts.children)}}else t&&this.addWidget(s)}),delete this.engine._loading,this.engine.removedNodes=l,this.batchUpdate(!1),delete this._ignoreLayoutsNodeChange,delete this.engine.skipCacheUpdate,a?r.addRemoveCB=a:delete r.addRemoveCB,d&&this.opts?.animate&&this.setAnimation(this.opts.animate,!0),this}batchUpdate(e=!0){return this.engine.batchUpdate(e),e||(this._updateContainerHeight(),this._triggerRemoveEvent(),this._triggerAddEvent(),this._triggerChangeEvent()),this}getCellHeight(e=!1){if(this.opts.cellHeight&&this.opts.cellHeight!=="auto"&&(!e||!this.opts.cellHeightUnit||this.opts.cellHeightUnit==="px"))return this.opts.cellHeight;if(this.opts.cellHeightUnit==="rem")return this.opts.cellHeight*parseFloat(getComputedStyle(document.documentElement).fontSize);if(this.opts.cellHeightUnit==="em")return this.opts.cellHeight*parseFloat(getComputedStyle(this.el).fontSize);if(this.opts.cellHeightUnit==="cm")return this.opts.cellHeight*(96/2.54);if(this.opts.cellHeightUnit==="mm")return this.opts.cellHeight*(96/2.54)/10;let t=this.el.querySelector("."+this.opts.itemClass);if(t){let o=A.toNumber(t.getAttribute("gs-h"))||1;return Math.round(t.offsetHeight/o)}let i=parseInt(this.el.getAttribute("gs-current-row"));return i?Math.round(this.el.getBoundingClientRect().height/i):this.opts.cellHeight}cellHeight(e,t=!0){if(t&&e!==void 0&&this._isAutoCellHeight!==(e==="auto")&&(this._isAutoCellHeight=e==="auto",this._updateResizeEvent()),(e==="initial"||e==="auto")&&(e=void 0),e===void 0){let o=-this.opts.marginRight-this.opts.marginLeft+this.opts.marginTop+this.opts.marginBottom;e=this.cellWidth()+o}let i=A.parseHeight(e);return this.opts.cellHeightUnit===i.unit&&this.opts.cellHeight===i.h?this:(this.opts.cellHeightUnit=i.unit,this.opts.cellHeight=i.h,this.resizeToContentCheck(),t&&this._updateStyles(!0),this)}cellWidth(){return this._widthOrContainer()/this.getColumn()}_widthOrContainer(e=!1){return e&&this.opts.columnOpts?.breakpointForWindow?window.innerWidth:this.el.clientWidth||this.el.parentElement.clientWidth||window.innerWidth}checkDynamicColumn(){let e=this.opts.columnOpts;if(!e||!e.columnWidth&&!e.breakpoints?.length)return!1;let t=this.getColumn(),i=t,o=this._widthOrContainer(!0);if(e.columnWidth)i=Math.min(Math.round(o/e.columnWidth)||1,e.columnMax);else{i=e.columnMax;let a=0;for(;a<e.breakpoints.length&&o<=e.breakpoints[a].w;)i=e.breakpoints[a++].c||t}if(i!==t){let a=e.breakpoints?.find(l=>l.c===i);return this.column(i,a?.layout||e.layout),!0}return!1}compact(e="compact",t=!0){return this.engine.compact(e,t),this._triggerChangeEvent(),this}column(e,t="moveScale"){if(!e||e<1||this.opts.column===e)return this;let i=this.getColumn();return this.opts.column=e,this.engine?(this.engine.column=e,this.el.classList.remove("gs-"+i),this.el.classList.add("gs-"+e),this.engine.columnChanged(i,e,t),this._isAutoCellHeight&&this.cellHeight(),this.resizeToContentCheck(!0),this._ignoreLayoutsNodeChange=!0,this._triggerChangeEvent(),delete this._ignoreLayoutsNodeChange,this):this}getColumn(){return this.opts.column}getGridItems(){return Array.from(this.el.children).filter(e=>e.matches("."+this.opts.itemClass)&&!e.matches("."+this.opts.placeholderClass))}isIgnoreChangeCB(){return this._ignoreLayoutsNodeChange}destroy(e=!0){if(this.el)return this.offAll(),this._updateResizeEvent(!0),this.setStatic(!0,!1),this.setAnimation(!1),e?this.el.parentNode.removeChild(this.el):(this.removeAll(e),this.el.classList.remove(this._styleSheetClass),this.el.removeAttribute("gs-current-row")),this._removeStylesheet(),delete this.parentGridNode?.subGrid,delete this.parentGridNode,delete this.opts,delete this._placeholder?.gridstackNode,delete this._placeholder,delete this.engine,delete this.el.gridstack,delete this.el,this}float(e){return this.opts.float!==e&&(this.opts.float=this.engine.float=e,this._triggerChangeEvent()),this}getFloat(){return this.engine.float}getCellFromPixel(e,t=!1){let i=this.el.getBoundingClientRect(),o;t?o={top:i.top+document.documentElement.scrollTop,left:i.left}:o={top:this.el.offsetTop,left:this.el.offsetLeft};let a=e.left-o.left,l=e.top-o.top,d=i.width/this.getColumn(),f=i.height/parseInt(this.el.getAttribute("gs-current-row"));return{x:Math.floor(a/d),y:Math.floor(l/f)}}getRow(){return Math.max(this.engine.getRow(),this.opts.minRow)}isAreaEmpty(e,t,i,o){return this.engine.isAreaEmpty(e,t,i,o)}makeWidget(e,t){let i=r.getElement(e);if(!i)return;i.parentElement||this.el.appendChild(i),this._prepareElement(i,!0,t);let o=i.gridstackNode;this._updateContainerHeight(),o.subGridOpts&&this.makeSubGrid(i,o.subGridOpts,void 0,!1);let a;return this.opts.column===1&&!this._ignoreLayoutsNodeChange&&(a=this._ignoreLayoutsNodeChange=!0),this._triggerAddEvent(),this._triggerChangeEvent(),a&&delete this._ignoreLayoutsNodeChange,i}on(e,t){return e.indexOf(" ")!==-1?(e.split(" ").forEach(o=>this.on(o,t)),this):(e==="change"||e==="added"||e==="removed"||e==="enable"||e==="disable"?(e==="enable"||e==="disable"?this._gsEventHandler[e]=o=>t(o):this._gsEventHandler[e]=o=>{o.detail&&t(o,o.detail)},this.el.addEventListener(e,this._gsEventHandler[e])):e==="drag"||e==="dragstart"||e==="dragstop"||e==="resizestart"||e==="resize"||e==="resizestop"||e==="dropped"||e==="resizecontent"?this._gsEventHandler[e]=t:console.error("GridStack.on("+e+") event not supported"),this)}off(e){return e.indexOf(" ")!==-1?(e.split(" ").forEach(i=>this.off(i)),this):((e==="change"||e==="added"||e==="removed"||e==="enable"||e==="disable")&&this._gsEventHandler[e]&&this.el.removeEventListener(e,this._gsEventHandler[e]),delete this._gsEventHandler[e],this)}offAll(){return Object.keys(this._gsEventHandler).forEach(e=>this.off(e)),this}removeWidget(e,t=!0,i=!0){return e?(r.getElements(e).forEach(o=>{if(o.parentElement&&o.parentElement!==this.el)return;let a=o.gridstackNode;a||(a=this.engine.nodes.find(l=>o===l.el)),a&&(t&&r.addRemoveCB&&r.addRemoveCB(this.el,a,!1,!1),delete o.gridstackNode,this._removeDD(o),this.engine.removeNode(a,t,i),t&&o.parentElement&&o.remove())}),i&&(this._triggerRemoveEvent(),this._triggerChangeEvent()),this):(console.error("Error: GridStack.removeWidget(undefined) called"),this)}removeAll(e=!0,t=!0){return this.engine.nodes.forEach(i=>{e&&r.addRemoveCB&&r.addRemoveCB(this.el,i,!1,!1),delete i.el.gridstackNode,this.opts.staticGrid||this._removeDD(i.el)}),this.engine.removeAll(e,t),t&&this._triggerRemoveEvent(),this}setAnimation(e=this.opts.animate,t){return t?setTimeout(()=>{this.opts&&this.setAnimation(e)}):e?this.el.classList.add("grid-stack-animate"):this.el.classList.remove("grid-stack-animate"),this}hasAnimationCSS(){return this.el.classList.contains("grid-stack-animate")}setStatic(e,t=!0,i=!0){return!!this.opts.staticGrid===e?this:(e?this.opts.staticGrid=!0:delete this.opts.staticGrid,this._setupRemoveDrop(),this._setupAcceptWidget(),this.engine.nodes.forEach(o=>{this.prepareDragDrop(o.el),o.subGrid&&i&&o.subGrid.setStatic(e,t,i)}),t&&this._setStaticClass(),this)}updateOptions(e){let t=this.opts;return e.acceptWidgets!==void 0&&this._setupAcceptWidget(),e.animate!==void 0&&this.setAnimation(),e.cellHeight&&(this.cellHeight(e.cellHeight,!0),delete e.cellHeight),e.class&&e.class!==t.class&&(t.class&&this.el.classList.remove(t.class),this.el.classList.add(e.class)),typeof e.column=="number"&&!e.columnOpts&&(this.column(e.column),delete e.column),e.margin!==void 0&&this.margin(e.margin),e.staticGrid!==void 0&&this.setStatic(e.staticGrid),e.disableDrag!==void 0&&!e.staticGrid&&this.enableMove(!e.disableDrag),e.disableResize!==void 0&&!e.staticGrid&&this.enableResize(!e.disableResize),e.float!==void 0&&this.float(e.float),e.row!==void 0&&(t.minRow=t.maxRow=e.row),e.children?.length&&(this.load(e.children),delete e.children),this.opts=K(K({},this.opts),e),this}update(e,t){return r.getElements(e).forEach(i=>{let o=i?.gridstackNode;if(!o)return;let a=K(K({},A.copyPos({},o)),A.cloneDeep(t));this.engine.nodeBoundFix(a),delete a.autoPosition;let l=["x","y","w","h"],d;if(l.some(c=>a[c]!==void 0&&a[c]!==o[c])&&(d={},l.forEach(c=>{d[c]=a[c]!==void 0?a[c]:o[c],delete a[c]})),!d&&(a.minW||a.minH||a.maxW||a.maxH)&&(d={}),a.content!==void 0){let c=i.querySelector(".grid-stack-item-content");c&&c.textContent!==a.content&&(o.content=a.content,r.renderCB(c,a),o.subGrid?.el&&(c.appendChild(o.subGrid.el),o.subGrid.opts.styleInHead||o.subGrid._updateStyles(!0))),delete a.content}let f=!1,s=!1;for(let c in a)c[0]!=="_"&&o[c]!==a[c]&&(o[c]=a[c],f=!0,s=s||!this.opts.staticGrid&&(c==="noResize"||c==="noMove"||c==="locked"));if(A.sanitizeMinMax(o),d){let c=d.w!==void 0&&d.w!==o.w;this.moveNode(o,d),c&&o.subGrid?o.subGrid.onResize(this.hasAnimationCSS()?o.w:void 0):this.resizeToContentCheck(c,o),delete o._orig}(d||f)&&this._writeAttr(i,o),s&&this.prepareDragDrop(o.el)}),this}moveNode(e,t){let i=e._updating;i||this.engine.cleanNodes().beginUpdate(e),this.engine.moveNode(e,t),this._updateContainerHeight(),i||(this._triggerChangeEvent(),this.engine.endUpdate())}resizeToContent(e){if(!e||(e.classList.remove("size-to-content-max"),!e.clientHeight))return;let t=e.gridstackNode;if(!t)return;let i=t.grid;if(!i||e.parentElement!==i.el)return;let o=i.getCellHeight(!0);if(!o)return;let a=t.h?t.h*o:e.clientHeight,l;if(t.resizeToContentParent&&(l=e.querySelector(t.resizeToContentParent)),l||(l=e.querySelector(r.resizeToContentParent)),!l)return;let d=e.clientHeight-l.clientHeight,f=t.h?t.h*o-d:l.clientHeight,s;if(t.subGrid){s=t.subGrid.getRow()*t.subGrid.getCellHeight(!0);let y=t.subGrid.el.getBoundingClientRect(),k=t.subGrid.el.parentElement.getBoundingClientRect();s+=y.top-k.top}else{if(t.subGridOpts?.children?.length)return;{let y=l.firstElementChild;if(!y){console.error(`Error: GridStack.resizeToContent() widget id:${t.id} '${r.resizeToContentParent}'.firstElementChild is null, make sure to have a div like container. Skipping sizing.`);return}s=y.getBoundingClientRect().height||f}}if(f===s)return;a+=s-f;let c=Math.ceil(a/o),m=Number.isInteger(t.sizeToContent)?t.sizeToContent:0;m&&c>m&&(c=m,e.classList.add("size-to-content-max")),t.minH&&c<t.minH?c=t.minH:t.maxH&&c>t.maxH&&(c=t.maxH),c!==t.h&&(i._ignoreLayoutsNodeChange=!0,i.moveNode(t,{h:c}),delete i._ignoreLayoutsNodeChange)}resizeToContentCBCheck(e){r.resizeToContentCB?r.resizeToContentCB(e):this.resizeToContent(e)}rotate(e,t){return r.getElements(e).forEach(i=>{let o=i.gridstackNode;if(!A.canBeRotated(o))return;let a={w:o.h,h:o.w,minH:o.minW,minW:o.minH,maxH:o.maxW,maxW:o.maxH};if(t){let d=t.left>0?Math.floor(t.left/this.cellWidth()):0,f=t.top>0?Math.floor(t.top/this.opts.cellHeight):0;a.x=o.x+d-(o.h-(f+1)),a.y=o.y+f-d}Object.keys(a).forEach(d=>{a[d]===void 0&&delete a[d]});let l=o._orig;this.update(i,a),o._orig=l}),this}margin(e){if(!(typeof e=="string"&&e.split(" ").length>1)){let i=A.parseHeight(e);if(this.opts.marginUnit===i.unit&&this.opts.margin===i.h)return}return this.opts.margin=e,this.opts.marginTop=this.opts.marginBottom=this.opts.marginLeft=this.opts.marginRight=void 0,this._initMargin(),this._updateStyles(!0),this}getMargin(){return this.opts.margin}willItFit(e){if(arguments.length>1){console.warn("gridstack.ts: `willItFit(x,y,w,h,autoPosition)` is deprecated. Use `willItFit({x, y,...})`. It will be removed soon");let t=arguments,i=0,o={x:t[i++],y:t[i++],w:t[i++],h:t[i++],autoPosition:t[i++]};return this.willItFit(o)}return this.engine.willItFit(e)}_triggerChangeEvent(){if(this.engine.batchMode)return this;let e=this.engine.getDirtyNodes(!0);return e&&e.length&&(this._ignoreLayoutsNodeChange||this.engine.layoutsNodesChange(e),this._triggerEvent("change",e)),this.engine.saveInitial(),this}_triggerAddEvent(){if(this.engine.batchMode)return this;if(this.engine.addedNodes?.length){this._ignoreLayoutsNodeChange||this.engine.layoutsNodesChange(this.engine.addedNodes),this.engine.addedNodes.forEach(t=>{delete t._dirty});let e=[...this.engine.addedNodes];this.engine.addedNodes=[],this._triggerEvent("added",e)}return this}_triggerRemoveEvent(){if(this.engine.batchMode)return this;if(this.engine.removedNodes?.length){let e=[...this.engine.removedNodes];this.engine.removedNodes=[],this._triggerEvent("removed",e)}return this}_triggerEvent(e,t){let i=t?new CustomEvent(e,{bubbles:!1,detail:t}):new Event(e);return this.el.dispatchEvent(i),this}_removeStylesheet(){if(this._styles){let e=this.opts.styleInHead?void 0:this.el.parentNode;A.removeStylesheet(this._styleSheetClass,e),delete this._styles}return this}_updateStyles(e=!1,t){if(e&&this._removeStylesheet(),t===void 0&&(t=this.getRow()),this._updateContainerHeight(),this.opts.cellHeight===0)return this;let i=this.opts.cellHeight,o=this.opts.cellHeightUnit,a=`.${this._styleSheetClass} > .${this.opts.itemClass}`;if(!this._styles){let l=this.opts.styleInHead?void 0:this.el.parentNode;if(this._styles=A.createStylesheet(this._styleSheetClass,l,{nonce:this.opts.nonce}),!this._styles)return this;this._styles._max=0,A.addCSSRule(this._styles,a,`height: ${i}${o}`);let d=this.opts.marginTop+this.opts.marginUnit,f=this.opts.marginBottom+this.opts.marginUnit,s=this.opts.marginRight+this.opts.marginUnit,c=this.opts.marginLeft+this.opts.marginUnit,m=`${a} > .grid-stack-item-content`,y=`.${this._styleSheetClass} > .grid-stack-placeholder > .placeholder-content`;A.addCSSRule(this._styles,m,`top: ${d}; right: ${s}; bottom: ${f}; left: ${c};`),A.addCSSRule(this._styles,y,`top: ${d}; right: ${s}; bottom: ${f}; left: ${c};`),A.addCSSRule(this._styles,`${a} > .ui-resizable-n`,`top: ${d};`),A.addCSSRule(this._styles,`${a} > .ui-resizable-s`,`bottom: ${f}`),A.addCSSRule(this._styles,`${a} > .ui-resizable-ne`,`right: ${s}; top: ${d}`),A.addCSSRule(this._styles,`${a} > .ui-resizable-e`,`right: ${s}`),A.addCSSRule(this._styles,`${a} > .ui-resizable-se`,`right: ${s}; bottom: ${f}`),A.addCSSRule(this._styles,`${a} > .ui-resizable-nw`,`left: ${c}; top: ${d}`),A.addCSSRule(this._styles,`${a} > .ui-resizable-w`,`left: ${c}`),A.addCSSRule(this._styles,`${a} > .ui-resizable-sw`,`left: ${c}; bottom: ${f}`)}if(t=t||this._styles._max,t>this._styles._max){let l=d=>i*d+o;for(let d=this._styles._max+1;d<=t;d++)A.addCSSRule(this._styles,`${a}[gs-y="${d}"]`,`top: ${l(d)}`),A.addCSSRule(this._styles,`${a}[gs-h="${d+1}"]`,`height: ${l(d+1)}`);this._styles._max=t}return this}_updateContainerHeight(){if(!this.engine||this.engine.batchMode)return this;let e=this.parentGridNode,t=this.getRow()+this._extraDragRow,i=this.opts.cellHeight,o=this.opts.cellHeightUnit;if(!i)return this;if(!e){let a=A.parseHeight(getComputedStyle(this.el).minHeight);if(a.h>0&&a.unit===o){let l=Math.floor(a.h/i);t<l&&(t=l)}}return this.el.setAttribute("gs-current-row",String(t)),this.el.style.removeProperty("min-height"),this.el.style.removeProperty("height"),t&&(this.el.style[e?"minHeight":"height"]=t*i+o),e&&!e.grid.engine.batchMode&&A.shouldSizeToContent(e)&&e.grid.resizeToContentCBCheck(e.el),this}_prepareElement(e,t=!1,i){i=i||this._readAttr(e),e.gridstackNode=i,i.el=e,i.grid=this,i=this.engine.addNode(i,t),this._writeAttr(e,i),e.classList.add(zt.itemClass,this.opts.itemClass);let o=A.shouldSizeToContent(i);return o?e.classList.add("size-to-content"):e.classList.remove("size-to-content"),o&&this.resizeToContentCheck(!1,i),A.lazyLoad(i)||this.prepareDragDrop(i.el),this}_writePosAttr(e,t){return t.x!==void 0&&t.x!==null&&e.setAttribute("gs-x",String(t.x)),t.y!==void 0&&t.y!==null&&e.setAttribute("gs-y",String(t.y)),t.w>1?e.setAttribute("gs-w",String(t.w)):e.removeAttribute("gs-w"),t.h>1?e.setAttribute("gs-h",String(t.h)):e.removeAttribute("gs-h"),this}_writeAttr(e,t){if(!t)return this;this._writePosAttr(e,t);let i={noResize:"gs-no-resize",noMove:"gs-no-move",locked:"gs-locked",id:"gs-id",sizeToContent:"gs-size-to-content"};for(let o in i)t[o]?e.setAttribute(i[o],String(t[o])):e.removeAttribute(i[o]);return this}_readAttr(e,t=!0){let i={};i.x=A.toNumber(e.getAttribute("gs-x")),i.y=A.toNumber(e.getAttribute("gs-y")),i.w=A.toNumber(e.getAttribute("gs-w")),i.h=A.toNumber(e.getAttribute("gs-h")),i.autoPosition=A.toBool(e.getAttribute("gs-auto-position")),i.noResize=A.toBool(e.getAttribute("gs-no-resize")),i.noMove=A.toBool(e.getAttribute("gs-no-move")),i.locked=A.toBool(e.getAttribute("gs-locked"));let o=e.getAttribute("gs-size-to-content");o&&(o==="true"||o==="false"?i.sizeToContent=A.toBool(o):i.sizeToContent=parseInt(o,10)),i.id=e.getAttribute("gs-id"),i.maxW=A.toNumber(e.getAttribute("gs-max-w")),i.minW=A.toNumber(e.getAttribute("gs-min-w")),i.maxH=A.toNumber(e.getAttribute("gs-max-h")),i.minH=A.toNumber(e.getAttribute("gs-min-h")),t&&(i.w===1&&e.removeAttribute("gs-w"),i.h===1&&e.removeAttribute("gs-h"),i.maxW&&e.removeAttribute("gs-max-w"),i.minW&&e.removeAttribute("gs-min-w"),i.maxH&&e.removeAttribute("gs-max-h"),i.minH&&e.removeAttribute("gs-min-h"));for(let a in i){if(!i.hasOwnProperty(a))return;!i[a]&&i[a]!==0&&a!=="gs-size-to-content"&&delete i[a]}return i}_setStaticClass(){let e=["grid-stack-static"];return this.opts.staticGrid?(this.el.classList.add(...e),this.el.setAttribute("gs-static","true")):(this.el.classList.remove(...e),this.el.removeAttribute("gs-static")),this}onResize(e=this.el?.clientWidth){if(!e||this.prevWidth===e)return;this.prevWidth=e,this.batchUpdate();let t=!1;return this._autoColumn&&this.parentGridNode?this.opts.column!==this.parentGridNode.w&&(this.column(this.parentGridNode.w,this.opts.layout||"list"),t=!0):t=this.checkDynamicColumn(),this._isAutoCellHeight&&this.cellHeight(),this.engine.nodes.forEach(i=>{i.subGrid&&i.subGrid.onResize()}),this._skipInitialResize||this.resizeToContentCheck(t),delete this._skipInitialResize,this.batchUpdate(!1),this}resizeToContentCheck(e=!1,t=void 0){if(this.engine){if(e&&this.hasAnimationCSS())return setTimeout(()=>this.resizeToContentCheck(!1,t),this.animationDelay);if(t)A.shouldSizeToContent(t)&&this.resizeToContentCBCheck(t.el);else if(this.engine.nodes.some(i=>A.shouldSizeToContent(i))){let i=[...this.engine.nodes];this.batchUpdate(),i.forEach(o=>{A.shouldSizeToContent(o)&&this.resizeToContentCBCheck(o.el)}),this.batchUpdate(!1)}this._gsEventHandler.resizecontent&&this._gsEventHandler.resizecontent(null,t?[t]:this.engine.nodes)}}_updateResizeEvent(e=!1){let t=!this.parentGridNode&&(this._isAutoCellHeight||this.opts.sizeToContent||this.opts.columnOpts||this.engine.nodes.find(i=>i.sizeToContent));return!e&&t&&!this.resizeObserver?(this._sizeThrottle=A.throttle(()=>this.onResize(),this.opts.cellHeightThrottle),this.resizeObserver=new ResizeObserver(()=>this._sizeThrottle()),this.resizeObserver.observe(this.el),this._skipInitialResize=!0):(e||!t)&&this.resizeObserver&&(this.resizeObserver.disconnect(),delete this.resizeObserver,delete this._sizeThrottle),this}static getElement(e=".grid-stack-item"){return A.getElement(e)}static getElements(e=".grid-stack-item"){return A.getElements(e)}static getGridElement(e){return r.getElement(e)}static getGridElements(e){return A.getElements(e)}_initMargin(){let e,t=0,i=[];return typeof this.opts.margin=="string"&&(i=this.opts.margin.split(" ")),i.length===2?(this.opts.marginTop=this.opts.marginBottom=i[0],this.opts.marginLeft=this.opts.marginRight=i[1]):i.length===4?(this.opts.marginTop=i[0],this.opts.marginRight=i[1],this.opts.marginBottom=i[2],this.opts.marginLeft=i[3]):(e=A.parseHeight(this.opts.margin),this.opts.marginUnit=e.unit,t=this.opts.margin=e.h),this.opts.marginTop===void 0?this.opts.marginTop=t:(e=A.parseHeight(this.opts.marginTop),this.opts.marginTop=e.h,delete this.opts.margin),this.opts.marginBottom===void 0?this.opts.marginBottom=t:(e=A.parseHeight(this.opts.marginBottom),this.opts.marginBottom=e.h,delete this.opts.margin),this.opts.marginRight===void 0?this.opts.marginRight=t:(e=A.parseHeight(this.opts.marginRight),this.opts.marginRight=e.h,delete this.opts.margin),this.opts.marginLeft===void 0?this.opts.marginLeft=t:(e=A.parseHeight(this.opts.marginLeft),this.opts.marginLeft=e.h,delete this.opts.margin),this.opts.marginUnit=e.unit,this.opts.marginTop===this.opts.marginBottom&&this.opts.marginLeft===this.opts.marginRight&&this.opts.marginTop===this.opts.marginRight&&(this.opts.margin=this.opts.marginTop),this}static getDD(){return Pt}static setupDragIn(e,t,i,o=document){t?.pause!==void 0&&(ne.pauseDrag=t.pause),t=K({appendTo:"body",helper:"clone"},t||{}),(typeof e=="string"?A.getElements(e,o):e).forEach((l,d)=>{Pt.isDraggable(l)||Pt.dragIn(l,t),i?.[d]&&(l.gridstackNode=i[d])})}movable(e,t){return this.opts.staticGrid?this:(r.getElements(e).forEach(i=>{let o=i.gridstackNode;o&&(t?delete o.noMove:o.noMove=!0,this.prepareDragDrop(o.el))}),this)}resizable(e,t){return this.opts.staticGrid?this:(r.getElements(e).forEach(i=>{let o=i.gridstackNode;o&&(t?delete o.noResize:o.noResize=!0,this.prepareDragDrop(o.el))}),this)}disable(e=!0){if(!this.opts.staticGrid)return this.enableMove(!1,e),this.enableResize(!1,e),this._triggerEvent("disable"),this}enable(e=!0){if(!this.opts.staticGrid)return this.enableMove(!0,e),this.enableResize(!0,e),this._triggerEvent("enable"),this}enableMove(e,t=!0){return this.opts.staticGrid?this:(e?delete this.opts.disableDrag:this.opts.disableDrag=!0,this.engine.nodes.forEach(i=>{this.prepareDragDrop(i.el),i.subGrid&&t&&i.subGrid.enableMove(e,t)}),this)}enableResize(e,t=!0){return this.opts.staticGrid?this:(e?delete this.opts.disableResize:this.opts.disableResize=!0,this.engine.nodes.forEach(i=>{this.prepareDragDrop(i.el),i.subGrid&&t&&i.subGrid.enableResize(e,t)}),this)}cancelDrag(){let e=this._placeholder?.gridstackNode;e&&(e._isExternal?(e._isAboutToRemove=!0,this.engine.removeNode(e)):e._isAboutToRemove&&r._itemRemoving(e.el,!1),this.engine.restoreInitial())}_removeDD(e){return Pt.draggable(e,"destroy").resizable(e,"destroy"),e.gridstackNode&&delete e.gridstackNode._initDD,delete e.ddElement,this}_setupAcceptWidget(){if(this.opts.staticGrid||!this.opts.acceptWidgets&&!this.opts.removable)return Pt.droppable(this.el,"destroy"),this;let e,t,i=(o,a,l)=>{l=l||a;let d=l.gridstackNode;if(!d)return;if(!d.grid?.el){l.style.transform=`scale(${1/this.dragTransform.xScale},${1/this.dragTransform.yScale})`;let y=l.getBoundingClientRect();l.style.left=y.x+(this.dragTransform.xScale-1)*(o.clientX-y.x)/this.dragTransform.xScale+"px",l.style.top=y.y+(this.dragTransform.yScale-1)*(o.clientY-y.y)/this.dragTransform.yScale+"px",l.style.transformOrigin="0px 0px"}let{top:f,left:s}=l.getBoundingClientRect(),c=this.el.getBoundingClientRect();s-=c.left,f-=c.top;let m={position:{top:f*this.dragTransform.xScale,left:s*this.dragTransform.yScale}};if(d._temporaryRemoved){if(d.x=Math.max(0,Math.round(s/t)),d.y=Math.max(0,Math.round(f/e)),delete d.autoPosition,this.engine.nodeBoundFix(d),!this.engine.willItFit(d)){if(d.autoPosition=!0,!this.engine.willItFit(d)){Pt.off(a,"drag");return}d._willFitPos&&(A.copyPos(d,d._willFitPos),delete d._willFitPos)}this._onStartMoving(l,o,m,d,t,e)}else this._dragOrResize(l,o,m,d,t,e)};return Pt.droppable(this.el,{accept:o=>{let a=o.gridstackNode||this._readAttr(o,!1);if(a?.grid===this)return!0;if(!this.opts.acceptWidgets)return!1;let l=!0;if(typeof this.opts.acceptWidgets=="function")l=this.opts.acceptWidgets(o);else{let d=this.opts.acceptWidgets===!0?".grid-stack-item":this.opts.acceptWidgets;l=o.matches(d)}if(l&&a&&this.opts.maxRow){let d={w:a.w,h:a.h,minW:a.minW,minH:a.minH};l=this.engine.willItFit(d)}return l}}).on(this.el,"dropover",(o,a,l)=>{let d=l?.gridstackNode||a.gridstackNode;if(d?.grid===this&&!d._temporaryRemoved)return!1;if(d?._sidebarOrig&&(d.w=d._sidebarOrig.w,d.h=d._sidebarOrig.h),d?.grid&&d.grid!==this&&!d._temporaryRemoved&&d.grid._leave(a,l),l=l||a,t=this.cellWidth(),e=this.getCellHeight(!0),!d){let c=l.getAttribute("data-gs-widget")||l.getAttribute("gridstacknode");if(c){try{d=JSON.parse(c)}catch{console.error("Gridstack dropover: Bad JSON format: ",c)}l.removeAttribute("data-gs-widget"),l.removeAttribute("gridstacknode")}d||(d=this._readAttr(l)),d._sidebarOrig={w:d.w,h:d.h}}d.grid||(d.el||(d=K({},d)),d._isExternal=!0,l.gridstackNode=d);let f=d.w||Math.round(l.offsetWidth/t)||1,s=d.h||Math.round(l.offsetHeight/e)||1;return d.grid&&d.grid!==this?(a._gridstackNodeOrig||(a._gridstackNodeOrig=d),a.gridstackNode=d=rt(K({},d),{w:f,h:s,grid:this}),delete d.x,delete d.y,this.engine.cleanupNode(d).nodeBoundFix(d),d._initDD=d._isExternal=d._temporaryRemoved=!0):(d.w=f,d.h=s,d._temporaryRemoved=!0),r._itemRemoving(d.el,!1),Pt.on(a,"drag",i),i(o,a,l),!1}).on(this.el,"dropout",(o,a,l)=>{let d=l?.gridstackNode||a.gridstackNode;return d&&(!d.grid||d.grid===this)&&(this._leave(a,l),this._isTemp&&this.removeAsSubGrid(d)),!1}).on(this.el,"drop",(o,a,l)=>{let d=l?.gridstackNode||a.gridstackNode;if(d?.grid===this&&!d._isExternal)return!1;let f=!!this.placeholder.parentElement,s=a!==l;this.placeholder.remove(),delete this.placeholder.gridstackNode;let c=f&&this.opts.animate;c&&this.setAnimation(!1);let m=a._gridstackNodeOrig;if(delete a._gridstackNodeOrig,f&&m?.grid&&m.grid!==this){let k=m.grid;k.engine.removeNodeFromLayoutCache(m),k.engine.removedNodes.push(m),k._triggerRemoveEvent()._triggerChangeEvent(),k.parentGridNode&&!k.engine.nodes.length&&k.opts.subGridDynamic&&k.removeAsSubGrid()}if(!d||(f&&(this.engine.cleanupNode(d),d.grid=this),delete d.grid?._isTemp,Pt.off(a,"drag"),l!==a?(l.remove(),a=l):a.remove(),this._removeDD(a),!f))return!1;let y=d.subGrid?.el?.gridstack;return A.copyPos(d,this._readAttr(this.placeholder)),A.removePositioningStyles(a),s&&(d.content||d.subGridOpts||r.addRemoveCB)?(delete d.el,a=this.addWidget(d)):(this._prepareElement(a,!0,d),this.el.appendChild(a),this.resizeToContentCheck(!1,d),y&&(y.parentGridNode=d,y.opts.styleInHead||y._updateStyles(!0)),this._updateContainerHeight()),this.engine.addedNodes.push(d),this._triggerAddEvent(),this._triggerChangeEvent(),this.engine.endUpdate(),this._gsEventHandler.dropped&&this._gsEventHandler.dropped(rt(K({},o),{type:"dropped"}),m&&m.grid?m:void 0,d),c&&this.setAnimation(this.opts.animate,!0),!1}),this}static _itemRemoving(e,t){if(!e)return;let i=e?e.gridstackNode:void 0;!i?.grid||e.classList.contains(i.grid.opts.removableOptions.decline)||(t?i._isAboutToRemove=!0:delete i._isAboutToRemove,t?e.classList.add("grid-stack-item-removing"):e.classList.remove("grid-stack-item-removing"))}_setupRemoveDrop(){if(typeof this.opts.removable!="string")return this;let e=document.querySelector(this.opts.removable);return e?(!this.opts.staticGrid&&!Pt.isDroppable(e)&&Pt.droppable(e,this.opts.removableOptions).on(e,"dropover",(t,i)=>r._itemRemoving(i,!0)).on(e,"dropout",(t,i)=>r._itemRemoving(i,!1)),this):this}prepareDragDrop(e,t=!1){let i=e?.gridstackNode;if(!i)return;let o=i.noMove||this.opts.disableDrag,a=i.noResize||this.opts.disableResize,l=this.opts.staticGrid||o&&a;if((t||l)&&(i._initDD&&(this._removeDD(e),delete i._initDD),l&&e.classList.add("ui-draggable-disabled","ui-resizable-disabled"),!t))return this;if(!i._initDD){let d,f,s=(y,k)=>{this._gsEventHandler[y.type]&&this._gsEventHandler[y.type](y,y.target),d=this.cellWidth(),f=this.getCellHeight(!0),this._onStartMoving(e,y,k,i,d,f)},c=(y,k)=>{this._dragOrResize(e,y,k,i,d,f)},m=y=>{this.placeholder.remove(),delete this.placeholder.gridstackNode,delete i._moving,delete i._event,delete i._lastTried;let k=i.w!==i._orig.w,x=y.target;if(!(!x.gridstackNode||x.gridstackNode.grid!==this)){if(i.el=x,i._isAboutToRemove){let D=e.gridstackNode.grid;D._gsEventHandler[y.type]&&D._gsEventHandler[y.type](y,x),D.engine.nodes.push(i),D.removeWidget(e,!0,!0)}else A.removePositioningStyles(x),i._temporaryRemoved?(A.copyPos(i,i._orig),this._writePosAttr(x,i),this.engine.addNode(i)):this._writePosAttr(x,i),this._gsEventHandler[y.type]&&this._gsEventHandler[y.type](y,x);this._extraDragRow=0,this._updateContainerHeight(),this._triggerChangeEvent(),this.engine.endUpdate(),y.type==="resizestop"&&(Number.isInteger(i.sizeToContent)&&(i.sizeToContent=i.h),this.resizeToContentCheck(k,i))}};Pt.draggable(e,{start:s,stop:m,drag:c}).resizable(e,{start:s,stop:m,resize:c}),i._initDD=!0}return Pt.draggable(e,o?"disable":"enable").resizable(e,a?"disable":"enable"),this}_onStartMoving(e,t,i,o,a,l){if(this.engine.cleanNodes().beginUpdate(o),this._writePosAttr(this.placeholder,o),this.el.appendChild(this.placeholder),this.placeholder.gridstackNode=o,o.grid?.el)this.dragTransform=A.getValuesFromTransformedElement(e);else if(this.placeholder&&this.placeholder.closest(".grid-stack")){let d=this.placeholder.closest(".grid-stack");this.dragTransform=A.getValuesFromTransformedElement(d)}else this.dragTransform={xScale:1,xOffset:0,yScale:1,yOffset:0};if(o.el=this.placeholder,o._lastUiPosition=i.position,o._prevYPix=i.position.top,o._moving=t.type==="dragstart",delete o._lastTried,t.type==="dropover"&&o._temporaryRemoved&&(this.engine.addNode(o),o._moving=!0),this.engine.cacheRects(a,l,this.opts.marginTop,this.opts.marginRight,this.opts.marginBottom,this.opts.marginLeft),t.type==="resizestart"){let d=this.getColumn()-o.x,f=(this.opts.maxRow||Number.MAX_SAFE_INTEGER)-o.y;Pt.resizable(e,"option","minWidth",a*Math.min(o.minW||1,d)).resizable(e,"option","minHeight",l*Math.min(o.minH||1,f)).resizable(e,"option","maxWidth",a*Math.min(o.maxW||Number.MAX_SAFE_INTEGER,d)).resizable(e,"option","maxWidthMoveLeft",a*Math.min(o.maxW||Number.MAX_SAFE_INTEGER,o.x+o.w)).resizable(e,"option","maxHeight",l*Math.min(o.maxH||Number.MAX_SAFE_INTEGER,f)).resizable(e,"option","maxHeightMoveUp",l*Math.min(o.maxH||Number.MAX_SAFE_INTEGER,o.y+o.h))}}_dragOrResize(e,t,i,o,a,l){let d=K({},o._orig),f,s=this.opts.marginLeft,c=this.opts.marginRight,m=this.opts.marginTop,y=this.opts.marginBottom,k=Math.round(l*.1),x=Math.round(a*.1);if(s=Math.min(s,x),c=Math.min(c,x),m=Math.min(m,k),y=Math.min(y,k),t.type==="drag"){if(o._temporaryRemoved)return;let F=i.position.top-o._prevYPix;o._prevYPix=i.position.top,this.opts.draggable.scroll!==!1&&A.updateScrollPosition(e,i.position,F);let $=i.position.left+(i.position.left>o._lastUiPosition.left?-c:s),se=i.position.top+(i.position.top>o._lastUiPosition.top?-y:m);d.x=Math.round($/a),d.y=Math.round(se/l);let ke=this._extraDragRow;if(this.engine.collide(o,d)){let Ye=this.getRow(),Ke=Math.max(0,d.y+o.h-Ye);this.opts.maxRow&&Ye+Ke>this.opts.maxRow&&(Ke=Math.max(0,this.opts.maxRow-Ye)),this._extraDragRow=Ke}else this._extraDragRow=0;if(this._extraDragRow!==ke&&this._updateContainerHeight(),o.x===d.x&&o.y===d.y)return}else if(t.type==="resize"){if(d.x<0||(A.updateScrollResize(t,e,l),d.w=Math.round((i.size.width-s)/a),d.h=Math.round((i.size.height-m)/l),o.w===d.w&&o.h===d.h)||o._lastTried&&o._lastTried.w===d.w&&o._lastTried.h===d.h)return;let F=i.position.left+s,$=i.position.top+m;d.x=Math.round(F/a),d.y=Math.round($/l),f=!0}o._event=t,o._lastTried=d;let D={x:i.position.left+s,y:i.position.top+m,w:(i.size?i.size.width:o.w*a)-s-c,h:(i.size?i.size.height:o.h*l)-m-y};if(this.engine.moveNodeCheck(o,rt(K({},d),{cellWidth:a,cellHeight:l,rect:D,resizing:f}))){o._lastUiPosition=i.position,this.engine.cacheRects(a,l,m,c,y,s),delete o._skipDown,f&&o.subGrid&&o.subGrid.onResize(),this._extraDragRow=0,this._updateContainerHeight();let F=t.target;o._sidebarOrig||this._writePosAttr(F,o),this._gsEventHandler[t.type]&&this._gsEventHandler[t.type](t,F)}}_leave(e,t){t=t||e;let i=t.gridstackNode;if(!i||(t.style.transform=t.style.transformOrigin=null,Pt.off(e,"drag"),i._temporaryRemoved))return;i._temporaryRemoved=!0,this.engine.removeNode(i),i.el=i._isExternal&&t?t:e;let o=i._sidebarOrig;i._isExternal&&this.engine.cleanupNode(i),i._sidebarOrig=o,this.opts.removable===!0&&r._itemRemoving(e,!0),e._gridstackNodeOrig?(e.gridstackNode=e._gridstackNodeOrig,delete e._gridstackNodeOrig):i._isExternal&&this.engine.restoreInitial()}commit(){return zd(this,this.batchUpdate(!1),"commit","batchUpdate","5.2"),this}}return r.renderCB=(n,e)=>{n&&e?.content&&(n.textContent=e.content)},r.resizeToContentParent=".grid-stack-item-content",r.Utils=A,r.Engine=ko,r.GDRev="11.5.1",r})();var Ud=["container"],Hu=["*"];function Uu(r,n){}var Gu=["*",[["","empty-content",""]]],ju=["*","[empty-content]"];function qu(r,n){r&1&&Ct(0,1,["*ngIf","isEmpty"])}function Yu(r,n){}var Gd=(()=>{class r{serialize(){}deserialize(e){this.widgetItem=e,e&&e.input&&Object.assign(this,e.input)}}return r.\u0275fac=function(e){return new(e||r)},r.\u0275prov=ot({token:r,factory:r.\u0275fac}),r})(),$a=(()=>{class r{constructor(e){this.elementRef=e,this.el._gridItemComp=this}set options(e){let t=this.el.gridstackNode?.grid;t?t.update(this.el,e):this._options=rt(K({},e),{el:this.el})}get options(){return this.el.gridstackNode||this._options||{el:this.el}}get el(){return this.elementRef.nativeElement}clearOptions(){delete this._options}ngOnDestroy(){this.clearOptions(),delete this.childWidget,delete this.el._gridItemComp,delete this.container,delete this.ref}}return r.\u0275fac=function(e){return new(e||r)(Rt(Me))},r.\u0275cmp=U({type:r,selectors:[["gridstack-item"]],viewQuery:function(e,t){if(e&1&&Je(Ud,7,Ra),e&2){let i;Ge(i=je())&&(t.container=i.first)}},inputs:{options:"options"},ngContentSelectors:Hu,decls:5,vars:1,consts:[["container",""],[1,"grid-stack-item-content"]],template:function(e,t){e&1&&(Jt(),v(0,"div",1),Te(1,Uu,0,0,"ng-template",null,0,Na),Ct(3),T(4),_()),e&2&&(P(4),ut(" ",t.options.content," "))},styles:["[_nghost-%COMP%]{display:block}"]}),r})(),hn=(()=>{class r{constructor(e){this.elementRef=e,this.addedCB=new at,this.changeCB=new at,this.disableCB=new at,this.dragCB=new at,this.dragStartCB=new at,this.dragStopCB=new at,this.droppedCB=new at,this.enableCB=new at,this.removedCB=new at,this.resizeCB=new at,this.resizeStartCB=new at,this.resizeStopCB=new at,ir.addRemoveCB||(ir.addRemoveCB=$u),ir.saveCB||(ir.saveCB=Qu),this.el._gridComp=this}set options(e){this._grid?this._grid.updateOptions(e):this._options=e}get options(){return this._grid?.opts||this._options||{}}get el(){return this.elementRef.nativeElement}get grid(){return this._grid}static addComponentToSelectorType(e){e.forEach(t=>r.selectorToType[r.getSelector(t)]=t)}static getSelector(e){return Dl(e).selector}ngOnInit(){this.loaded=!!this.options?.children?.length,this._grid=ir.init(this._options,this.el),delete this._options,this.checkEmpty()}ngAfterContentInit(){this._sub=this.gridstackItems?.changes.subscribe(()=>this.updateAll()),this.loaded||this.updateAll(),this.hookEvents(this.grid)}ngOnDestroy(){this.unhookEvents(this._grid),this._sub?.unsubscribe(),this._grid?.destroy(),delete this._grid,delete this.el._gridComp,delete this.container,delete this.ref}updateAll(){if(!this.grid)return;let e=[];this.gridstackItems?.forEach(t=>{e.push(t.options),t.clearOptions()}),this.grid.load(e)}checkEmpty(){this.grid&&(this.isEmpty=!this.grid.engine.nodes.length)}hookEvents(e){e&&e.on("added",(t,i)=>{this.checkEmpty(),this.addedCB.emit({event:t,nodes:i})}).on("change",(t,i)=>this.changeCB.emit({event:t,nodes:i})).on("disable",t=>this.disableCB.emit({event:t})).on("drag",(t,i)=>this.dragCB.emit({event:t,el:i})).on("dragstart",(t,i)=>this.dragStartCB.emit({event:t,el:i})).on("dragstop",(t,i)=>this.dragStopCB.emit({event:t,el:i})).on("dropped",(t,i,o)=>this.droppedCB.emit({event:t,previousNode:i,newNode:o})).on("enable",t=>this.enableCB.emit({event:t})).on("removed",(t,i)=>{this.checkEmpty(),this.removedCB.emit({event:t,nodes:i})}).on("resize",(t,i)=>this.resizeCB.emit({event:t,el:i})).on("resizestart",(t,i)=>this.resizeStartCB.emit({event:t,el:i})).on("resizestop",(t,i)=>this.resizeStopCB.emit({event:t,el:i}))}unhookEvents(e){e&&e.off("added change disable drag dragstart dragstop dropped enable removed resize resizestart resizestop")}}return r.selectorToType={},r.\u0275fac=function(e){return new(e||r)(Rt(Me))},r.\u0275cmp=U({type:r,selectors:[["gridstack"]],contentQueries:function(e,t,i){if(e&1&&an(i,$a,4),e&2){let o;Ge(o=je())&&(t.gridstackItems=o)}},viewQuery:function(e,t){if(e&1&&Je(Ud,7,Ra),e&2){let i;Ge(i=je())&&(t.container=i.first)}},inputs:{options:"options",isEmpty:"isEmpty"},outputs:{addedCB:"addedCB",changeCB:"changeCB",disableCB:"disableCB",dragCB:"dragCB",dragStartCB:"dragStartCB",dragStopCB:"dragStopCB",droppedCB:"droppedCB",enableCB:"enableCB",removedCB:"removedCB",resizeCB:"resizeCB",resizeStartCB:"resizeStartCB",resizeStopCB:"resizeStopCB"},ngContentSelectors:ju,decls:4,vars:1,consts:[["container",""],[4,"ngIf"]],template:function(e,t){e&1&&(Jt(Gu),Te(0,qu,1,0,"ng-content",1)(1,Yu,0,0,"ng-template",null,0,Na),Ct(3)),e&2&&G("ngIf",t.isEmpty)},dependencies:[Li],styles:["[_nghost-%COMP%]{display:block}"]}),r})();function $u(r,n,e,t){if(e){if(!r)return;if(t){let i=r.parentElement?._gridItemComp;if(!i)return;let a=(i.childWidget?.container||i.container)?.createComponent(hn),l=a?.instance;return l?(l.ref=a,l.options=n,l.el):void 0}else{let o=r._gridComp?.container?.createComponent($a),a=o?.instance;if(!a)return;a.ref=o;let l=n.selector,d=l?hn.selectorToType[l]:void 0;if(d){let f=()=>{let c=a.container?.createComponent(d)?.instance;c&&typeof c.serialize=="function"&&typeof c.deserialize=="function"&&(a.childWidget=c,c.deserialize(n))};n.lazyLoad||n.grid?.opts?.lazyLoad&&n.lazyLoad!==!1?n.visibleObservable||(n.visibleObservable=new IntersectionObserver(([c])=>{c.isIntersecting&&(n.visibleObservable?.disconnect(),delete n.visibleObservable,f())}),window.setTimeout(()=>n.visibleObservable?.observe(a.el))):f()}return a.el}}else if(t){let i=n.el?._gridComp;i?.ref?i.ref.destroy():i?.ngOnDestroy()}else{let i=n.el?._gridItemComp;i?.ref?i.ref.destroy():i?.ngOnDestroy()}}function Qu(r,n){let e=r.el?._gridItemComp;if(e){let i=e.childWidget?.serialize();i&&(n.input=i);return}let t=r.el?._gridComp}var jd=(()=>{class r{}return r.\u0275fac=function(e){return new(e||r)},r.\u0275mod=Zt({type:r}),r.\u0275inj=Kt({imports:[$a,hn]}),r})();var we=function(r){return r[r.State=0]="State",r[r.Transition=1]="Transition",r[r.Sequence=2]="Sequence",r[r.Group=3]="Group",r[r.Animate=4]="Animate",r[r.Keyframes=5]="Keyframes",r[r.Style=6]="Style",r[r.Trigger=7]="Trigger",r[r.Reference=8]="Reference",r[r.AnimateChild=9]="AnimateChild",r[r.AnimateRef=10]="AnimateRef",r[r.Query=11]="Query",r[r.Stagger=12]="Stagger",r}(we||{}),ri="*";function Ar(r,n){return{type:we.Trigger,name:r,definitions:n,options:{}}}function nr(r,n=null){return{type:we.Animate,styles:n,timings:r}}function qd(r,n=null){return{type:we.Sequence,steps:r,options:n}}function oi(r){return{type:we.Style,styles:r,offset:null}}function Eo(r,n,e){return{type:we.State,name:r,styles:n,options:e}}function Pr(r,n,e=null){return{type:we.Transition,expr:r,animation:n,options:e}}var ki=class{_onDoneFns=[];_onStartFns=[];_onDestroyFns=[];_originalOnDoneFns=[];_originalOnStartFns=[];_started=!1;_destroyed=!1;_finished=!1;_position=0;parentPlayer=null;totalTime;constructor(n=0,e=0){this.totalTime=n+e}_onFinish(){this._finished||(this._finished=!0,this._onDoneFns.forEach(n=>n()),this._onDoneFns=[])}onStart(n){this._originalOnStartFns.push(n),this._onStartFns.push(n)}onDone(n){this._originalOnDoneFns.push(n),this._onDoneFns.push(n)}onDestroy(n){this._onDestroyFns.push(n)}hasStarted(){return this._started}init(){}play(){this.hasStarted()||(this._onStart(),this.triggerMicrotask()),this._started=!0}triggerMicrotask(){queueMicrotask(()=>this._onFinish())}_onStart(){this._onStartFns.forEach(n=>n()),this._onStartFns=[]}pause(){}restart(){}finish(){this._onFinish()}destroy(){this._destroyed||(this._destroyed=!0,this.hasStarted()||this._onStart(),this.finish(),this._onDestroyFns.forEach(n=>n()),this._onDestroyFns=[])}reset(){this._started=!1,this._finished=!1,this._onStartFns=this._originalOnStartFns,this._onDoneFns=this._originalOnDoneFns}setPosition(n){this._position=this.totalTime?n*this.totalTime:1}getPosition(){return this.totalTime?this._position/this.totalTime:1}triggerCallback(n){let e=n=="start"?this._onStartFns:this._onDoneFns;e.forEach(t=>t()),e.length=0}},un=class{_onDoneFns=[];_onStartFns=[];_finished=!1;_started=!1;_destroyed=!1;_onDestroyFns=[];parentPlayer=null;totalTime=0;players;constructor(n){this.players=n;let e=0,t=0,i=0,o=this.players.length;o==0?queueMicrotask(()=>this._onFinish()):this.players.forEach(a=>{a.onDone(()=>{++e==o&&this._onFinish()}),a.onDestroy(()=>{++t==o&&this._onDestroy()}),a.onStart(()=>{++i==o&&this._onStart()})}),this.totalTime=this.players.reduce((a,l)=>Math.max(a,l.totalTime),0)}_onFinish(){this._finished||(this._finished=!0,this._onDoneFns.forEach(n=>n()),this._onDoneFns=[])}init(){this.players.forEach(n=>n.init())}onStart(n){this._onStartFns.push(n)}_onStart(){this.hasStarted()||(this._started=!0,this._onStartFns.forEach(n=>n()),this._onStartFns=[])}onDone(n){this._onDoneFns.push(n)}onDestroy(n){this._onDestroyFns.push(n)}hasStarted(){return this._started}play(){this.parentPlayer||this.init(),this._onStart(),this.players.forEach(n=>n.play())}pause(){this.players.forEach(n=>n.pause())}restart(){this.players.forEach(n=>n.restart())}finish(){this._onFinish(),this.players.forEach(n=>n.finish())}destroy(){this._onDestroy()}_onDestroy(){this._destroyed||(this._destroyed=!0,this._onFinish(),this.players.forEach(n=>n.destroy()),this._onDestroyFns.forEach(n=>n()),this._onDestroyFns=[])}reset(){this.players.forEach(n=>n.reset()),this._destroyed=!1,this._finished=!1,this._started=!1}setPosition(n){let e=n*this.totalTime;this.players.forEach(t=>{let i=t.totalTime?Math.min(1,e/t.totalTime):1;t.setPosition(i)})}getPosition(){let n=this.players.reduce((e,t)=>e===null||t.totalTime>e.totalTime?t:e,null);return n!=null?n.getPosition():0}beforeDestroy(){this.players.forEach(n=>{n.beforeDestroy&&n.beforeDestroy()})}triggerCallback(n){let e=n=="start"?this._onStartFns:this._onDoneFns;e.forEach(t=>t()),e.length=0}},rr="!";var Ku=(r,n)=>n.id;function Zu(r,n){if(r&1&&B(0,"div",4),r&2){let e=n.$index;ge();let t=xl(1);He("background-color",t===e?"var(--mat-sys-on-surface)":"var(--mat-sys-inverse-on-surface)")}}var Yd=(()=>{class r{activePage=Y();dashboards=Y();static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["dashboard-scroller"]],inputs:{activePage:[1,"activePage"],dashboards:[1,"dashboards"]},decls:8,vars:4,consts:[[1,"page-scroll-title","page-scroll-container"],[1,"page-label"],[1,"page-scroll-page-number","page-scroll-container"],[1,"page-marker",3,"background-color"],[1,"page-marker"]],template:function(t,i){if(t&1&&(Sl(0)(1),v(2,"div",0)(3,"span",1),T(4),_()(),v(5,"div",2),Wi(6,Zu,1,2,"div",3,Ku),_()),t&2){let o=i.dashboards();P();let a=Cl(i.activePage());P(),G("@fadeInOut",a),P(2),lt(o[a].name),P(),G("@fadeInOut",a),P(),Bi(o)}},styles:["[_nghost-%COMP%]{pointer-events:none}.page-scroll-title[_ngcontent-%COMP%]{position:absolute;top:50%;right:54px;transform:translateY(-50%);z-index:100;cursor:default;text-align:center;padding:10px;color:var(--mat-sys-inverse-surface)}.page-scroll-page-number[_ngcontent-%COMP%]{position:absolute;top:50%;right:15px;transform:translateY(-50%);z-index:100;cursor:default;display:grid;padding:0}.page-scroll-container[_ngcontent-%COMP%]{opacity:0;background-color:var(--mat-sys-tertiary-fixed-dim);border-radius:10px;border:1px solid var(--mat-sys-inverse-surface)}.page-label[_ngcontent-%COMP%]{color:var(--mat-sys-on-surface);text-shadow:1px 1px 0 var(--mat-sys-outline),-1px 1px 0 var(--mat-sys-outline),-1px -1px 0 var(--mat-sys-outline),1px -1px 0 var(--mat-sys-outline);font-size:x-large}.page-marker[_ngcontent-%COMP%]{height:20px;width:20px;margin:4px;border-radius:50%;border:1px solid var(--mat-sys-outline)}"],data:{animation:[Ar("fadeInOut",[Pr(":increment, :decrement",[oi({opacity:0}),nr(100,oi({opacity:1})),oi({opacity:1}),nr("250ms 1000ms",oi({opacity:0}))])])]}})}return r})();var $d="mat-badge-content",Ju=(()=>{class r{static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["ng-component"]],decls:0,vars:0,template:function(t,i){},styles:[`.mat-badge{position:relative}.mat-badge.mat-badge{overflow:visible}.mat-badge-content{position:absolute;text-align:center;display:inline-block;transition:transform 200ms ease-in-out;transform:scale(0.6);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;box-sizing:border-box;pointer-events:none;background-color:var(--mat-badge-background-color, var(--mat-sys-error));color:var(--mat-badge-text-color, var(--mat-sys-on-error));font-family:var(--mat-badge-text-font, var(--mat-sys-label-small-font));font-weight:var(--mat-badge-text-weight, var(--mat-sys-label-small-weight));border-radius:var(--mat-badge-container-shape, var(--mat-sys-corner-full))}.mat-badge-above .mat-badge-content{bottom:100%}.mat-badge-below .mat-badge-content{top:100%}.mat-badge-before .mat-badge-content{right:100%}[dir=rtl] .mat-badge-before .mat-badge-content{right:auto;left:100%}.mat-badge-after .mat-badge-content{left:100%}[dir=rtl] .mat-badge-after .mat-badge-content{left:auto;right:100%}@media(forced-colors: active){.mat-badge-content{outline:solid 1px;border-radius:0}}.mat-badge-disabled .mat-badge-content{background-color:var(--mat-badge-disabled-state-background-color, color-mix(in srgb, var(--mat-sys-error) 38%, transparent));color:var(--mat-badge-disabled-state-text-color, var(--mat-sys-on-error))}.mat-badge-hidden .mat-badge-content{display:none}.ng-animate-disabled .mat-badge-content,.mat-badge-content._mat-animation-noopable{transition:none}.mat-badge-content.mat-badge-active{transform:none}.mat-badge-small .mat-badge-content{width:var(--mat-badge-legacy-small-size-container-size, unset);height:var(--mat-badge-legacy-small-size-container-size, unset);min-width:var(--mat-badge-small-size-container-size, 6px);min-height:var(--mat-badge-small-size-container-size, 6px);line-height:var(--mat-badge-small-size-line-height, 6px);padding:var(--mat-badge-small-size-container-padding, 0);font-size:var(--mat-badge-small-size-text-size, 0);margin:var(--mat-badge-small-size-container-offset, -6px 0)}.mat-badge-small.mat-badge-overlap .mat-badge-content{margin:var(--mat-badge-small-size-container-overlap-offset, -6px)}.mat-badge-medium .mat-badge-content{width:var(--mat-badge-legacy-container-size, unset);height:var(--mat-badge-legacy-container-size, unset);min-width:var(--mat-badge-container-size, 16px);min-height:var(--mat-badge-container-size, 16px);line-height:var(--mat-badge-line-height, 16px);padding:var(--mat-badge-container-padding, 0 4px);font-size:var(--mat-badge-text-size, var(--mat-sys-label-small-size));margin:var(--mat-badge-container-offset, -12px 0)}.mat-badge-medium.mat-badge-overlap .mat-badge-content{margin:var(--mat-badge-container-overlap-offset, -12px)}.mat-badge-large .mat-badge-content{width:var(--mat-badge-legacy-large-size-container-size, unset);height:var(--mat-badge-legacy-large-size-container-size, unset);min-width:var(--mat-badge-large-size-container-size, 16px);min-height:var(--mat-badge-large-size-container-size, 16px);line-height:var(--mat-badge-large-size-line-height, 16px);padding:var(--mat-badge-large-size-container-padding, 0 4px);font-size:var(--mat-badge-large-size-text-size, var(--mat-sys-label-small-size));margin:var(--mat-badge-large-size-container-offset, -12px 0)}.mat-badge-large.mat-badge-overlap .mat-badge-content{margin:var(--mat-badge-large-size-container-overlap-offset, -12px)}
|
|
6
|
+
`],encapsulation:2,changeDetection:0})}return r})(),Do=(()=>{class r{_ngZone=M(ht);_elementRef=M(Me);_ariaDescriber=M(td);_renderer=M(Zr);_animationMode=M(Ei,{optional:!0});_idGenerator=M(lo);get color(){return this._color}set color(e){this._setColor(e),this._color=e}_color="primary";overlap=!0;disabled;position="above after";get content(){return this._content}set content(e){this._updateRenderedContent(e)}_content;get description(){return this._description}set description(e){this._updateDescription(e)}_description;size="medium";hidden;_badgeElement;_inlineBadgeDescription;_isInitialized=!1;_interactivityChecker=M(so);_document=M(zi);constructor(){let e=M(Ql);e.load(Ju),e.load(Xl)}isAbove(){return this.position.indexOf("below")===-1}isAfter(){return this.position.indexOf("before")===-1}getBadgeElement(){return this._badgeElement}ngOnInit(){this._clearExistingBadges(),this.content&&!this._badgeElement&&(this._badgeElement=this._createBadgeElement(),this._updateRenderedContent(this.content)),this._isInitialized=!0}ngOnDestroy(){this._renderer.destroyNode&&(this._renderer.destroyNode(this._badgeElement),this._inlineBadgeDescription?.remove()),this._ariaDescriber.removeDescription(this._elementRef.nativeElement,this.description)}_isHostInteractive(){return this._interactivityChecker.isFocusable(this._elementRef.nativeElement,{ignoreVisibility:!0})}_createBadgeElement(){let e=this._renderer.createElement("span"),t="mat-badge-active";return e.setAttribute("id",this._idGenerator.getId("mat-badge-content-")),e.setAttribute("aria-hidden","true"),e.classList.add($d),this._animationMode==="NoopAnimations"&&e.classList.add("_mat-animation-noopable"),this._elementRef.nativeElement.appendChild(e),typeof requestAnimationFrame=="function"&&this._animationMode!=="NoopAnimations"?this._ngZone.runOutsideAngular(()=>{requestAnimationFrame(()=>{e.classList.add(t)})}):e.classList.add(t),e}_updateRenderedContent(e){let t=`${e??""}`.trim();this._isInitialized&&t&&!this._badgeElement&&(this._badgeElement=this._createBadgeElement()),this._badgeElement&&(this._badgeElement.textContent=t),this._content=t}_updateDescription(e){this._ariaDescriber.removeDescription(this._elementRef.nativeElement,this.description),(!e||this._isHostInteractive())&&this._removeInlineDescription(),this._description=e,this._isHostInteractive()?this._ariaDescriber.describe(this._elementRef.nativeElement,e):this._updateInlineDescription()}_updateInlineDescription(){this._inlineBadgeDescription||(this._inlineBadgeDescription=this._document.createElement("span"),this._inlineBadgeDescription.classList.add("cdk-visually-hidden")),this._inlineBadgeDescription.textContent=this.description,this._badgeElement?.appendChild(this._inlineBadgeDescription)}_removeInlineDescription(){this._inlineBadgeDescription?.remove(),this._inlineBadgeDescription=void 0}_setColor(e){let t=this._elementRef.nativeElement.classList;t.remove(`mat-badge-${this._color}`),e&&t.add(`mat-badge-${e}`)}_clearExistingBadges(){let e=this._elementRef.nativeElement.querySelectorAll(`:scope > .${$d}`);for(let t of Array.from(e))t!==this._badgeElement&&t.remove()}static \u0275fac=function(t){return new(t||r)};static \u0275dir=bi({type:r,selectors:[["","matBadge",""]],hostAttrs:[1,"mat-badge"],hostVars:20,hostBindings:function(t,i){t&2&&Nt("mat-badge-overlap",i.overlap)("mat-badge-above",i.isAbove())("mat-badge-below",!i.isAbove())("mat-badge-before",!i.isAfter())("mat-badge-after",i.isAfter())("mat-badge-small",i.size==="small")("mat-badge-medium",i.size==="medium")("mat-badge-large",i.size==="large")("mat-badge-hidden",i.hidden||!i.content)("mat-badge-disabled",i.disabled)},inputs:{color:[0,"matBadgeColor","color"],overlap:[2,"matBadgeOverlap","overlap",to],disabled:[2,"matBadgeDisabled","disabled",to],position:[0,"matBadgePosition","position"],content:[0,"matBadge","content"],description:[0,"matBadgeDescription","description"],size:[0,"matBadgeSize","size"],hidden:[2,"matBadgeHidden","hidden",to]}})}return r})(),Ao=(()=>{class r{static \u0275fac=function(t){return new(t||r)};static \u0275mod=Zt({type:r});static \u0275inj=Kt({imports:[Jl,jn,jn]})}return r})();var Qd=wr(Qa());var tm={1e3:"notification",1001:"alert",1002:"warn",1003:"alarm",1004:"emergency"},Yi=(()=>{class r{settings=M(ei);data=M(Vi);requests=M(Fi);static ALARM_SEVERITIES={normal:{sound:0,visual:0},nominal:{sound:0,visual:0},alert:{sound:1,visual:0},warn:{sound:2,visual:1},alarm:{sound:3,visual:2},emergency:{sound:4,visual:2}};_notificationSettingsSubscription=null;_notificationDataStreamSubscription=null;_notificationMetaStreamSubscription=null;_resetServiceSubscription=null;_notificationConfig;_notificationConfig$=new Ri(Ml);_notifications=[];_notifications$=new Ri([]);_alarmsInfo$=new Ri({audioSev:0,visualSev:0,alarmCount:0,isMuted:!1});_howlPlayer;_activeAlarmSoundtrack=null;_activeHowlId=null;_isHowlIdMuted=!1;_lastEmittedValue=null;constructor(){this._notificationSettingsSubscription=this.settings.getNotificationServiceConfigAsO().subscribe(e=>{this._notificationConfig=e,this.reset(),this._notificationConfig$.next(e),this._notificationConfig.disableNotifications&&!this._notificationDataStreamSubscription?.closed&&this.stopNotificationStream(),!this._notificationConfig.disableNotifications&&(this._notificationDataStreamSubscription===null||this._notificationDataStreamSubscription?.closed)&&this.startNotificationStream(),this._notificationConfig.sound.disableSound?this.playAlarm(1e3):this.updateNotificationsState()}),this._resetServiceSubscription=this.data.isResetService().subscribe(e=>{e&&this.reset()}),this._howlPlayer=this.getPlayer(1e3)}startNotificationStream(){this._notificationDataStreamSubscription=this.data.getNotificationMsgObservable().subscribe(e=>{this.processNotificationDeltaMsg(e)}),this._notificationMetaStreamSubscription=this.data.getNotificationMetaObservable().subscribe(e=>{this.processNotificationDeltaMeta(e)})}stopNotificationStream(){this._notificationDataStreamSubscription?.unsubscribe(),this._notificationMetaStreamSubscription?.unsubscribe(),this.reset()}reset(){this._notificationConfig.disableNotifications&&(this._notifications=[],this._notifications$.next([])),this.updateNotificationsState()}observeNotifications(){return this._notifications$}addValue(e){this._notifications.push({path:e.path,value:e.value}),this.updateNotificationsState(),this._notifications$.next(this._notifications)}updateValue(e){let t=this._notifications.find(i=>i.path==e.path);t?(t.value=K({},e.value),this.updateNotificationsState(),this._notifications$.next(this._notifications)):console.log("[Notification Service] Update path not found for: "+e.path)}deleteValue(e){let t=this._notifications.find(i=>i.path==e);t?(delete t.value,this.updateNotificationsState(),this._notifications$.next(this._notifications)):console.log("[Notification Service] Notification to delete not found for: "+e)}updateNotificationsState(){let e=0,t=0,i=0;for(let a of this._notifications){if(!a.value||!("method"in a.value)||a.value.method.length===0||a.value.state===te.Normal&&!this._notificationConfig.devices.showNormalState||a.value.state===te.Nominal&&!this._notificationConfig.devices.showNominalState)continue;i++;let{aSev:l,vSev:d}=this.getNotificationSeverity(a);e=Math.max(e,l),t=Math.max(t,d)}this._notificationConfig.sound.disableSound||this.playAlarm(1e3+e);let o={audioSev:e,visualSev:t,alarmCount:i,isMuted:this._isHowlIdMuted};xr(o,this._lastEmittedValue)||(this._alarmsInfo$.next(o),this._lastEmittedValue=o)}processNotificationDeltaMsg(e){if(!e.path.startsWith("notifications.security"))if(e.value===null)this.deleteValue(e.path);else{let t=this._notifications.find(i=>i.path==e.path);t?t.value?(t.value.state!==e.value.state||t.value.message!==e.value.message||!xr(t.value.method,e.value.method))&&this.updateValue(e):this.updateValue(e):this.addValue(e)}}processNotificationDeltaMeta(e){let t=this._notifications.find(i=>i.path==e.path);t?t.meta=e.meta:this._notifications.push({path:e.path,meta:e.meta}),this._notifications$.next(this._notifications)}getNotificationSeverity(e){let t=e.value.state,i=r.ALARM_SEVERITIES[t];if(!i)return console.log(`[Notification Service] Unknown Notification State received from Signal K
|
|
7
|
+
`+JSON.stringify(e)),{aSev:0,vSev:0};let o=i.sound,a=i.visual;return(!e.value.method.includes(Hn.Sound)||this._notificationConfig.sound[`mute${t.charAt(0).toUpperCase()+t.slice(1)}`]||this._isHowlIdMuted)&&(o=0),e.value.method.includes(Hn.Visual)||(a=0),{aSev:o,vSev:a}}setSkMethod(e,t){this.requests.putRequest(`${e}.method`,t,Ln.create())}setSkState(e,t){this.requests.putRequest(`${e}.state`,t,Ln.create())}observerNotificationsInfo(){return this._alarmsInfo$.pipe(Ht(t=>{let i=!1,o=!1;switch(t.visualSev){case 1:i=!0;break;case 2:o=!0;break}return rt(K({},t),{isWarn:i,isAlarmEmergency:o})}))}getPlayer(e){return this._activeAlarmSoundtrack=e,new Qd.Howl({src:["assets/"+tm[e]+".mp3"],autoplay:!1,preload:!0,loop:!0,onend:function(){},onloaderror:function(){console.log("player onload error")},onplayerror:function(){console.log("player locked"),this._howlPlayer.once("unlock",function(){this._howlPlayer.play()})}})}mutePlayer(e){this._howlPlayer.mute(e,this._activeHowlId),this._isHowlIdMuted=e,this.updateNotificationsState()}playAlarm(e){if(this._activeAlarmSoundtrack!=e){if(e==1e3){this._howlPlayer&&this._howlPlayer.stop(),this._activeAlarmSoundtrack=1e3;return}this._howlPlayer.stop(),this._howlPlayer=this.getPlayer(e),this._activeHowlId=this._howlPlayer.play()}}observeNotificationConfiguration(){return this._notificationConfig$.asObservable()}ngOnDestroy(){this._notificationSettingsSubscription?.unsubscribe(),this._resetServiceSubscription?.unsubscribe(),this._notificationConfig$.complete(),this._notifications$.complete(),this._alarmsInfo$.complete()}static \u0275fac=function(t){return new(t||r)};static \u0275prov=ot({token:r,factory:r.\u0275fac,providedIn:"root"})}return r})();var Xd=(()=>{class r{_notifications=M(Yi);hasNotifications=Ni();notificationsInfo=Wt(this._notifications.observerNotificationsInfo());openNotificationMenu(){let e=new Event("openRightSidenav",{bubbles:!0,cancelable:!0});window.document.dispatchEvent(e)}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["notification-badge"]],outputs:{hasNotifications:"hasNotifications"},decls:4,vars:6,consts:[["mat-fab","",1,"layout-action-btn",3,"click"],["aria-hidden","false","matBadgeSize","large","matBadgePosition","after","matBadgeOverlap","true",1,"icon-alert-color",3,"matBadgeHidden","matBadge"]],template:function(t,i){t&1&&(v(0,"div")(1,"button",0),V("click",function(){return i.openNotificationMenu()}),v(2,"mat-icon",1),T(3,"notifications "),_()()()),t&2&&(P(),Nt("warn",i.notificationsInfo().isWarn)("alarm-emergency-blink",i.notificationsInfo().isAlarmEmergency),P(),G("matBadgeHidden",!i.notificationsInfo().alarmCount)("matBadge",i.notificationsInfo().alarmCount))},dependencies:[ci,co,Bt,wi,Ao,Do],styles:["[_nghost-%COMP%]{z-index:102;position:absolute;display:block;bottom:20px;left:20px;height:56px;width:56px;text-align:center;align-content:center}.layout-action-btn[_ngcontent-%COMP%]{color:var(--mat-sys-on-primary);background-color:var(--mat-sys-primary)}.icon-alert-color[_ngcontent-%COMP%]{--mdc-list-list-item-leading-icon-color: var(--kip-zone-alert-color)}.icon-warn-color[_ngcontent-%COMP%]{--mdc-list-list-item-leading-icon-color: var(--kip-zone-warn-color)}.icon-alarm-color[_ngcontent-%COMP%]{--mdc-list-list-item-leading-icon-color: var(--kip-zone-alarm-color)}.icon-emergency-color[_ngcontent-%COMP%]{--mdc-list-list-item-leading-icon-color: var(--kip-zone-emergency-color)}.alarm-emergency-blink[_ngcontent-%COMP%]{animation:_ngcontent-%COMP%_blinking-emergency 1.5s infinite}@keyframes _ngcontent-%COMP%_blinking-emergency{0%{background-color:var(--kip-zone-alarm-color)}50%{background-color:var(--mat-sys-primary)}to{background-color:var(--kip-zone-alarm-color)}}.warn[_ngcontent-%COMP%]{color:var(--kip-zone-warn-color)}"]})}return r})();var Re=(()=>{class r extends Gd{widgetProperties;zones$=new Ri([]);DataService=M(Vi);unitsService=M(Yn);app=M(ti);theme=Wt(this.app.cssThemeColorRoles$,{requireSync:!0});defaultConfig=void 0;dataStream=void 0;dataSubscriptions=void 0;metaSubscriptions=void 0;constructor(){super()}serialize(){return{widgetProperties:this.widgetProperties}}observeMetaStream(){if(this.widgetProperties&&this.widgetProperties.config.paths&&Object.keys(this.widgetProperties.config.paths).length>0){let e=Object.keys(this.widgetProperties.config.paths)[0],t=this.widgetProperties.config.paths[e].path;this.metaSubscriptions=this.DataService.getPathMetaObservable(t).subscribe(i=>{i?i.zones?this.zones$.next(i.zones):this.zones$.next([]):this.zones$.next([])})}}unsubscribeMetaStream(){this.metaSubscriptions?.unsubscribe(),this.metaSubscriptions=void 0}validateConfig(){this.widgetProperties.config=Fn(ql(this.defaultConfig,this.widgetProperties.config))}createDataObservable(){if(this.widgetProperties!==void 0){if(Object.keys(this.widgetProperties.config.paths).length==0){this.dataStream=void 0;return}else this.dataStream=[];Object.keys(this.widgetProperties.config.paths).forEach(e=>{typeof this.widgetProperties.config.paths[e].path!="string"||this.widgetProperties.config.paths[e].path==""||this.widgetProperties.config.paths[e].path==null||this.dataStream.push({pathName:e,observable:this.DataService.subscribePath(this.widgetProperties.config.paths[e].path,this.widgetProperties.config.paths[e].source)})})}}observeDataStream(e,t){(this.dataStream===void 0||this.dataStream.length==0)&&this.createDataObservable();let i=this.widgetProperties.config.paths[e].pathType,o=this.widgetProperties.config.paths[e].path,a=this.widgetProperties.config.paths[e].convertUnitTo,l=this.widgetProperties.config.paths[e].sampleTime,d=this.widgetProperties.config.dataTimeout*1e3,f=5e3,s=`[Widget] ${this.widgetProperties.config.displayName} - ${d/1e3} second data update timeout reached for `,c=`[Widget] ${this.widgetProperties.config.displayName} - Retrying in ${f/1e3} secondes`,m=this.buildObserver(e,t),y=this.dataStream.find(x=>x.pathName===e);if(y===void 0)return;let k;i=="number"?this.widgetProperties.config.enableTimeout?k=y.observable.pipe(Ht(x=>({data:{value:this.unitsService.convertToUnit(a,x.data.value),timestamp:x.data.timestamp},state:x.state})),On(l),Ta({each:d,with:()=>xa(()=>{console.log(s+o),this.DataService.timeoutPathObservable(o,i)})}),Pa(x=>x.pipe(Oa(()=>console.log(c)),Aa(()=>Ea(f))))):k=y.observable.pipe(Ht(x=>({data:{value:this.unitsService.convertToUnit(a,x.data.value),timestamp:x.data.timestamp},state:x.state})),On(l)):i=="string"||i=="Date"?this.widgetProperties.config.enableTimeout?k=y.observable.pipe(On(l),Ta({each:d,with:()=>xa(()=>{console.log(s+o),this.DataService.timeoutPathObservable(o,i)})}),Pa(x=>x.pipe(Oa(()=>console.log(c)),Aa(()=>Ea(f))))):k=y.observable.pipe(On(l)):k=y.observable.pipe(On(l)),this.dataSubscriptions===void 0?this.dataSubscriptions=k.subscribe(m):this.dataSubscriptions.add(k.subscribe(m))}unsubscribeDataStream(){this.dataSubscriptions?.unsubscribe(),this.dataSubscriptions=void 0,this.dataStream=void 0}buildObserver(e,t){return{next:o=>t(o),error:o=>console.error("[Widget] Observer got an error: "+o),complete:()=>console.log("[Widget] Observer got a complete notification: "+e)}}formatWidgetNumberValue(e){return typeof e!="number"||e==null?"":(e=Math.min(Math.max(e,this.widgetProperties.config.displayScale.lower),this.widgetProperties.config.displayScale.upper),e.toFixed(this.widgetProperties.config.numDecimal))}destroyDataStreams(){this.unsubscribeDataStream(),this.unsubscribeMetaStream(),this.zones$.complete()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["ng-component"]],inputs:{widgetProperties:"widgetProperties"},features:[pe],decls:0,vars:0,template:function(t,i){},encapsulation:2})}return r})();var Kd=(()=>{class r{_bottomSheetRef=M(fd);clickAction(e){this._bottomSheetRef.dismiss(e)}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-host-bottom-sheet"]],decls:11,vars:0,consts:[["mat-list-item","",3,"click"],["matListItemIcon",""]],template:function(t,i){t&1&&(v(0,"mat-action-list")(1,"button",0),V("click",function(){return i.clickAction("duplicate")}),v(2,"mat-icon",1),T(3,"content_copy"),_(),v(4,"span"),T(5,"Duplicate"),_()(),v(6,"button",0),V("click",function(){return i.clickAction("delete")}),v(7,"mat-icon",1),T(8,"delete_forever"),_(),v(9,"span"),T(10,"Delete"),_()()())},dependencies:[fo,_d,po,bd,Bt,wi],encapsulation:2})}return r})();var nm=["*"],Ne=(()=>{class r{config=Cr.required();id=Y.required();_dialog=M($n);_dashboard=M(st);_bottomSheet=M(gd);constructor(){}openWidgetOptions(e){this._dashboard.isDashboardStatic()||this._dialog.openWidgetOptions({title:"Widget Options",config:this.config(),confirmBtnText:"Save",cancelBtnText:"Cancel"}).afterClosed().subscribe(t=>{t&&this.config.set(t)})}openBottomSheet(){this._dashboard.isDashboardStatic()||this._bottomSheet.open(Kd).afterDismissed().subscribe(t=>{switch(t){case"delete":this._dashboard.deleteWidget(this.id());break;case"duplicate":this._dashboard.duplicateWidget(this.id());break;default:break}})}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-host"]],inputs:{config:[1,"config"],id:[1,"id"]},outputs:{config:"configChange"},ngContentSelectors:nm,decls:2,vars:2,consts:[["appearance","raised",1,"widget-container","kip-widget-card-colors",3,"doubletap","press"]],template:function(t,i){t&1&&(Jt(),v(0,"mat-card",0),V("doubletap",function(a){return i.openWidgetOptions(a)})("press",function(){return i.openBottomSheet()}),Ct(1),_()),t&2&&He("border",i._dashboard.isDashboardStatic()?"":"1px dashed var(--mat-sys-outline)")},dependencies:[uo,pd,vd],styles:["[_nghost-%COMP%]{width:100%;height:100%;display:block}.widget-container[_ngcontent-%COMP%]{display:block;width:100%;height:100%;margin:0;padding:0}.kip-widget-card-colors[_ngcontent-%COMP%]{background-color:var(--kip-widget-card-background-color)}"]})}return r})();var Zd=(()=>{class r{constructor(e){this.ngZone=e,this.count=0,this.elementMap=new Map,this.observer=null}ngOnDestroy(){this.observer&&this.clearObserver()}observe(e,t,i){this.observer||(this.observer=new ResizeObserver(o=>{for(let a of o){let l=this.elementMap.get(a.target);l&&this.ngZone.run(()=>{l(a)})}})),i==="border-box"?this.observer.observe(e,{box:"border-box"}):this.observer.observe(e),this.count+=1,this.elementMap.set(e,t)}unobserve(e){this.elementMap.get(e)&&this.observer&&(this.observer.unobserve(e),this.elementMap.delete(e),this.count-=1,this.count===0&&this.clearObserver())}clearObserver(){this.observer&&this.observer.disconnect(),this.observer=null,this.count=0,this.elementMap=new Map}static{this.\u0275fac=function(t){return new(t||r)(Rn(ht))}}static{this.\u0275prov=ot({token:r,factory:r.\u0275fac})}}return r})(),et=(()=>{class r{constructor(e,t,i){this.elementRef=e,this.ngxResizeObserverService=t,this.ngZone=i,this.resizeBoxModel="",this.onResize=new at,this.observing=!1,Sr(()=>{this.observe()})}ngOnChanges(e){this.observing&&(e.resizeBoxModel||e.onResize)&&(this.unobserve(),this.observe())}ngOnDestroy(){this.unobserve()}observe(){this.observing||(this.ngxResizeObserverService.observe(this.elementRef.nativeElement,e=>{this.ngZone.run(()=>{this.onResize.emit(e)})},this.resizeBoxModel),this.observing=!0)}unobserve(){this.observing&&(this.ngxResizeObserverService.unobserve(this.elementRef.nativeElement),this.observing=!1)}static{this.\u0275fac=function(t){return new(t||r)(Rt(Me),Rt(Zd),Rt(ht))}}static{this.\u0275dir=bi({type:r,selectors:[["","onResize",""]],inputs:{resizeBoxModel:"resizeBoxModel"},outputs:{onResize:"onResize"},features:[yi]})}}return r})(),tt=(()=>{class r{static{this.\u0275fac=function(t){return new(t||r)}}static{this.\u0275mod=Zt({type:r})}static{this.\u0275inj=Kt({providers:[Zd]})}}return r})();var xt=(()=>{class r{DEFAULT_FONT="Arial";EDGE_BUFFER=10;scaleFactor=window.devicePixelRatio||1;fontsReadyPromise;constructor(){this.fontsReadyPromise=document.fonts.ready}setHighDPISize(e,t){let i=Math.floor(t.width),o=Math.floor(t.height);e.width=i*this.scaleFactor,e.height=o*this.scaleFactor,e.style.width=`${i}px`,e.style.height=`${o}px`}drawTitle(e,t,i,o="normal",a,l){e&&this.fontsReadyPromise.then(()=>{requestAnimationFrame(()=>{this.drawTitleInternal(e,t,i,o,a,l)})}).catch(d=>{console.warn("[Canvas Service] Font readiness failed:"),this.drawTitleInternal(e,t,i,o,a,l)})}drawTitleInternal(e,t,i,o="normal",a,l){if(!e)return;let d=a-2*this.EDGE_BUFFER,f=Math.floor(l*.1),s=this.calculateOptimalFontSize(e,t,d,f,o);e.clearRect(0,0,a,l),e.font=`${o} ${s}px ${this.DEFAULT_FONT}`,e.fillStyle=i,e.textAlign="left",e.textBaseline="top",e.fillText(t,this.EDGE_BUFFER*this.scaleFactor,this.EDGE_BUFFER*this.scaleFactor,d)}clearCanvas(e,t,i){e.clearRect(0,0,t,i)}drawText(e,t,i=this.EDGE_BUFFER,o=this.EDGE_BUFFER,a,l,d="normal",f="#000",s="center",c="middle"){e&&this.fontsReadyPromise.then(()=>{requestAnimationFrame(()=>{this.drawTextInternal(e,t,i,o,a,l,d,f,s,c)})}).catch(m=>{console.warn("[Canvas Service] Font readiness failed:"),this.drawTextInternal(e,t,i,o,a,l,d,f,s,c)})}drawTextInternal(e,t,i=this.EDGE_BUFFER,o=this.EDGE_BUFFER,a,l,d="normal",f="#000",s="center",c="middle"){a=a,l=l;let m=this.calculateOptimalFontSize(e,t,a,l,d);e.font=`${d} ${m}px ${this.DEFAULT_FONT}`,e.fillStyle=f,e.textAlign=s,e.textBaseline=c,e.fillText(t,i,o,a)}calculateOptimalFontSize(e,t,i,o,a="normal"){let l=1,d=o,f=d;for(;l<=d;)f=Math.floor((l+d)/2),e.font=`${a} ${f}px ${this.DEFAULT_FONT}`,e.measureText(t).width>i?d=f-1:l=f+1;return d}drawRectangle(e,t,i,o,a,l){e.fillStyle=l,e.fillRect(t,i,o,a)}static \u0275fac=function(t){return new(t||r)};static \u0275prov=ot({token:r,factory:r.\u0275fac,providedIn:"root"})}return r})();var rm=["canvas"],ai=(()=>{class r{text=Y.required();color=Y.required();canvasRef=le.required("canvas");canvas=M(xt);canvasElement;canvasCtx;isReady=!1;constructor(){}ngAfterViewInit(){this.canvasElement=this.canvasRef().nativeElement,this.canvasElement&&(this.canvasCtx=this.canvasElement.getContext("2d"),this.canvas.setHighDPISize(this.canvasElement,this.canvasElement.parentElement.getBoundingClientRect())),this.isReady=!0,this.drawTitle()}ngOnChanges(e){(e.text||e.color)&&this.drawTitle()}onResized(e){this.canvas.setHighDPISize(this.canvasElement,e.contentRect),this.drawTitle()}drawTitle(){this.isReady&&this.canvas.drawTitle(this.canvasCtx,this.text(),this.color(),"normal",this.canvasElement.width,this.canvasElement.height)}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-title"]],viewQuery:function(t,i){t&1&&de(i.canvasRef,rm,5),t&2&&Qe()},inputs:{text:[1,"text"],color:[1,"color"]},features:[yi],decls:3,vars:0,consts:[["canvas",""],[1,"textGenericWrapper",3,"onResize"]],template:function(t,i){if(t&1){let o=ee();v(0,"div",1),V("onResize",function(l){return z(o),L(i.onResized(l))}),B(1,"canvas",null,0),_()}},dependencies:[tt,et],styles:["[_nghost-%COMP%]{position:absolute;display:block;width:100%;height:100%;z-index:10}canvas[_ngcontent-%COMP%]{display:block}.textGenericWrapper[_ngcontent-%COMP%]{position:relative;width:100%;height:100%}"]})}return r})();var om=["canvasValue"],Jd=(()=>{class r extends Re{canvasValue=le.required("canvasValue");canvas=M(xt);dataValue=null;canvasCtx;labelColor=void 0;valueColor=void 0;isDestroyed=!1;maxTextWidth=0;maxTextHeight=0;constructor(){super(),this.defaultConfig={displayName:"Gauge Label",filterSelfPaths:!0,paths:{stringPath:{description:"String Data",path:null,source:null,pathType:"string",isPathConfigurable:!0,sampleTime:500}},color:"contrast",enableTimeout:!1,dataTimeout:5},Pe(()=>{this.theme()&&(this.getColors(this.widgetProperties.config.color),this.drawValue())})}ngOnInit(){this.validateConfig()}ngAfterViewInit(){let e=this.canvasValue().nativeElement;this.canvas.setHighDPISize(this.canvasValue().nativeElement,e.parentElement.getBoundingClientRect()),this.canvasCtx=this.canvasValue().nativeElement.getContext("2d"),this.maxTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.maxTextHeight=Math.floor(this.canvasValue().nativeElement.height*.8),!this.isDestroyed&&this.startWidget()}startWidget(){this.unsubscribeDataStream(),this.observeDataStream("stringPath",e=>{this.dataValue=e.data.value,this.drawValue()})}updateConfig(e){this.widgetProperties.config=e,this.startWidget(),this.getColors(this.widgetProperties.config.color),this.drawValue()}ngOnDestroy(){this.isDestroyed=!0,this.destroyDataStreams(),this.canvas.clearCanvas(this.canvasCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),this.canvasValue().nativeElement.remove()}getColors(e){switch(e){case"contrast":this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break;case"blue":this.labelColor=this.theme().blueDim,this.valueColor=this.theme().blue;break;case"green":this.labelColor=this.theme().greenDim,this.valueColor=this.theme().green;break;case"pink":this.labelColor=this.theme().pinkDim,this.valueColor=this.theme().pink;break;case"orange":this.labelColor=this.theme().orangeDim,this.valueColor=this.theme().orange;break;case"purple":this.labelColor=this.theme().purpleDim,this.valueColor=this.theme().purple;break;case"grey":this.labelColor=this.theme().greyDim,this.valueColor=this.theme().grey;break;case"yellow":this.labelColor=this.theme().yellowDim,this.valueColor=this.theme().yellow;break;default:this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break}}onResized(e){e.contentRect.height<25||e.contentRect.width<25||(this.canvas.setHighDPISize(this.canvasValue().nativeElement,e.contentRect),this.maxTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.maxTextHeight=Math.floor(this.canvasValue().nativeElement.height*.7),!this.isDestroyed&&this.drawValue())}drawValue(){if(!this.canvasCtx)return;this.canvas.clearCanvas(this.canvasCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height);let e=this.dataValue===null?"--":this.dataValue;this.canvas.drawText(this.canvasCtx,e,Math.floor(this.canvasValue().nativeElement.width/2),Math.floor(this.canvasValue().nativeElement.height/2*1.15),this.maxTextWidth,this.maxTextHeight,"bold",this.valueColor,"center","middle")}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-text"]],viewQuery:function(t,i){t&1&&de(i.canvasValue,om,5),t&2&&Qe()},features:[pe],decls:5,vars:4,consts:[["canvasValue",""],[3,"configChange","config","id"],[1,"textGenericWrapper",3,"onResize"],[2,"z-index","inherit"],[3,"text","color"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"div",2),V("onResize",function(l){return z(o),L(i.onResized(l))}),B(2,"canvas",3,0)(4,"widget-title",4),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(4),G("text",i.widgetProperties.config.displayName)("color",i.labelColor))},dependencies:[Ne,tt,et,ai],styles:["canvas[_ngcontent-%COMP%]{display:block;position:absolute;top:0;left:0}.textGenericWrapper[_ngcontent-%COMP%]{position:relative;width:100%;height:100%}"]})}return r})();var am=["canvasUnit"],sm=["canvasMinMax"],lm=["canvasValue"],ec=(()=>{class r extends Re{canvasUnit=le.required("canvasUnit");canvasMinMax=le.required("canvasMinMax");canvasValue=le.required("canvasValue");canvas=M(xt);dataValue=null;maxValue=null;minValue=null;labelColor=void 0;valueColor=void 0;valueStateColor=void 0;maxValueTextWidth=0;maxValueTextHeight=0;maxMinMaxTextWidth=0;maxMinMaxTextHeight=0;flashInterval=null;isDestroyed=!1;canvasValCtx;canvasMinMaxCtx;canvasUnitCtx;constructor(){super(),this.defaultConfig={displayName:"Gauge Label",filterSelfPaths:!0,paths:{numericPath:{description:"Numeric Data",path:null,source:null,pathType:"number",isPathConfigurable:!0,convertUnitTo:"unitless",showPathSkUnitsFilter:!0,pathSkUnitsFilter:null,sampleTime:500}},showMax:!1,showMin:!1,numDecimal:1,numInt:1,color:"contrast",enableTimeout:!1,dataTimeout:5,ignoreZones:!1},Pe(()=>{this.theme()&&(this.getColors(this.widgetProperties.config.color),this.updateCanvas(),this.updateCanvasUnit())})}ngOnInit(){this.validateConfig()}ngAfterViewInit(){let e=this.canvasValue().nativeElement;this.canvas.setHighDPISize(this.canvasValue().nativeElement,e.parentElement.getBoundingClientRect()),this.canvas.setHighDPISize(this.canvasUnit().nativeElement,e.parentElement.getBoundingClientRect()),this.canvas.setHighDPISize(this.canvasMinMax().nativeElement,e.parentElement.getBoundingClientRect()),this.canvasValCtx=this.canvasValue().nativeElement.getContext("2d"),this.canvasMinMaxCtx=this.canvasMinMax().nativeElement.getContext("2d"),this.canvasUnitCtx=this.canvasUnit().nativeElement.getContext("2d"),this.maxValueTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.maxValueTextHeight=Math.floor(this.canvasValue().nativeElement.height*.7),this.maxMinMaxTextWidth=Math.floor(this.canvasMinMax().nativeElement.width*.57),this.maxMinMaxTextHeight=Math.floor(this.canvasMinMax().nativeElement.height*.1),!this.isDestroyed&&(this.startWidget(),this.updateCanvasUnit())}startWidget(){this.unsubscribeDataStream(),this.minValue=null,this.maxValue=null,this.dataValue=null,this.getColors(this.widgetProperties.config.color),this.observeDataStream("numericPath",e=>{if(this.dataValue=e.data.value,this.minValue===null||this.dataValue<this.minValue?this.minValue=this.dataValue:(this.maxValue===null||this.dataValue>this.maxValue)&&(this.maxValue=this.dataValue),!this.widgetProperties.config.ignoreZones)switch(e.state){case te.Alarm:this.valueStateColor=this.theme().zoneAlarm;break;case te.Warn:this.valueStateColor=this.theme().zoneWarn;break;case te.Alert:this.valueStateColor=this.theme().zoneAlert;break;default:this.valueStateColor=this.valueColor;break}this.updateCanvas()})}updateConfig(e){this.widgetProperties.config=e,this.startWidget(),this.updateCanvas(),this.updateCanvasUnit()}onResized(e){e.contentRect.height<25||e.contentRect.width<25||(this.canvas.setHighDPISize(this.canvasValue().nativeElement,e.contentRect),this.canvas.setHighDPISize(this.canvasUnit().nativeElement,e.contentRect),this.canvas.setHighDPISize(this.canvasMinMax().nativeElement,e.contentRect),this.maxValueTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.maxValueTextHeight=Math.floor(this.canvasValue().nativeElement.height*.7),this.maxMinMaxTextWidth=Math.floor(this.canvasMinMax().nativeElement.width*.57),this.maxMinMaxTextHeight=Math.floor(this.canvasMinMax().nativeElement.height*.1),!this.isDestroyed&&(this.updateCanvas(),this.updateCanvasUnit()))}getColors(e){switch(e){case"contrast":this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break;case"blue":this.labelColor=this.theme().blueDim,this.valueColor=this.theme().blue;break;case"green":this.labelColor=this.theme().greenDim,this.valueColor=this.theme().green;break;case"pink":this.labelColor=this.theme().pinkDim,this.valueColor=this.theme().pink;break;case"orange":this.labelColor=this.theme().orangeDim,this.valueColor=this.theme().orange;break;case"purple":this.labelColor=this.theme().purpleDim,this.valueColor=this.theme().purple;break;case"grey":this.labelColor=this.theme().greyDim,this.valueColor=this.theme().grey;break;case"yellow":this.labelColor=this.theme().yellowDim,this.valueColor=this.theme().yellow;break;default:this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break}this.valueStateColor=this.valueColor}ngOnDestroy(){this.isDestroyed=!0,this.destroyDataStreams(),this.flashInterval&&(clearInterval(this.flashInterval),this.flashInterval=null),this.canvas.clearCanvas(this.canvasValCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),this.canvas.clearCanvas(this.canvasMinMaxCtx,this.canvasMinMax().nativeElement.width,this.canvasMinMax().nativeElement.height),this.canvas.clearCanvas(this.canvasUnitCtx,this.canvasUnit().nativeElement.width,this.canvasUnit().nativeElement.height)}updateCanvas(){this.canvasValCtx&&(this.canvas.clearCanvas(this.canvasValCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),this.drawValue(),(this.widgetProperties.config.showMax||this.widgetProperties.config.showMin)&&(this.canvas.clearCanvas(this.canvasMinMaxCtx,this.canvasMinMax().nativeElement.width,this.canvasMinMax().nativeElement.height),this.drawMinMax()))}updateCanvasUnit(){this.canvasUnitCtx&&(this.canvas.clearCanvas(this.canvasUnitCtx,this.canvasUnit().nativeElement.width,this.canvasUnit().nativeElement.height),this.drawUnit())}drawValue(){let e=this.getValueText();this.canvas.clearCanvas(this.canvasValCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),this.canvas.drawText(this.canvasValCtx,e,Math.floor(this.canvasValue().nativeElement.width/2),Math.floor(this.canvasValue().nativeElement.height/2*1.15),this.maxValueTextWidth,this.maxValueTextHeight,"bold",this.valueStateColor)}getValueText(){if(this.dataValue===null)return"--";let e=this.widgetProperties.config.paths.numericPath.convertUnitTo;return["latitudeSec","latitudeMin","longitudeSec","longitudeMin","HH:MM:SS"].includes(e)?this.dataValue.toString():this.applyDecorations(this.dataValue.toFixed(this.widgetProperties.config.numDecimal))}drawUnit(){let e=this.widgetProperties.config.paths.numericPath.convertUnitTo;["unitless","percent","ratio","latitudeSec","latitudeMin","longitudeSec","longitudeMin"].includes(e)||this.canvas.drawText(this.canvasUnitCtx,e,Math.floor(this.canvasUnit().nativeElement.width-10*this.canvas.scaleFactor),Math.floor(this.canvasUnit().nativeElement.height-10*this.canvas.scaleFactor),Math.floor(this.canvasUnit().nativeElement.width*.25),Math.floor(this.canvasUnit().nativeElement.height*.15),"bold",this.valueColor,"end","alphabetic")}drawMinMax(){if(!this.widgetProperties.config.showMin&&!this.widgetProperties.config.showMax)return;let e="";this.widgetProperties.config.showMin&&(e=this.minValue!=null?` Min: ${this.applyDecorations(this.minValue.toFixed(this.widgetProperties.config.numDecimal))}`:" Min: --"),this.widgetProperties.config.showMax&&(e+=this.maxValue!=null?` Max: ${this.applyDecorations(this.maxValue.toFixed(this.widgetProperties.config.numDecimal))}`:" Max: --"),e=e.trim(),this.canvas.drawText(this.canvasMinMaxCtx,e,10*this.canvas.scaleFactor,Math.floor(this.canvasMinMax().nativeElement.height-10*this.canvas.scaleFactor),this.maxMinMaxTextWidth,this.maxMinMaxTextHeight,"normal",this.valueColor,"start","alphabetic")}applyDecorations(e){switch(this.widgetProperties.config.paths.numericPath.convertUnitTo){case"percent":case"percentraw":e+="%";break;default:break}return e}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-numeric"]],viewQuery:function(t,i){t&1&&(de(i.canvasUnit,am,5),de(i.canvasMinMax,sm,5),de(i.canvasValue,lm,5)),t&2&&Qe(3)},features:[pe],decls:9,vars:4,consts:[["canvasUnit",""],["canvasValue",""],["canvasMinMax",""],[3,"configChange","config","id"],[1,"textGenericWrapper",3,"onResize"],[3,"text","color"],[1,"canvas"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",3),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"div",4),V("onResize",function(l){return z(o),L(i.onResized(l))}),B(2,"widget-title",5)(3,"canvas",6,0)(5,"canvas",6,1)(7,"canvas",6,2),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(2),G("text",i.widgetProperties.config.displayName)("color",i.labelColor))},dependencies:[Ne,tt,et,ai],styles:[".textGenericWrapper[_ngcontent-%COMP%]{position:absolute;display:block;width:100%;height:100%;z-index:inherit}.canvas[_ngcontent-%COMP%]{display:block;position:absolute;top:0;left:0}"]})}return r})();var dm=["canvasValue"],tc=(()=>{class r extends Re{canvasValue=le.required("canvasValue");canvas=M(xt);dataValue=null;_timeZoneGTM="";_valueFontSize=1;isDestroyed=!1;canvasCtx;labelColor=void 0;valueColor=void 0;maxTextWidth=0;maxTextHeight=0;constructor(){super(),this.defaultConfig={displayName:"Time Label",filterSelfPaths:!0,paths:{gaugePath:{description:"String Data",path:null,source:null,pathType:"Date",isPathConfigurable:!0,sampleTime:500}},dateFormat:"dd/MM/yyyy HH:mm:ss",dateTimezone:"Atlantic/Azores",color:"contrast",enableTimeout:!1,dataTimeout:5},Pe(()=>{this.theme()&&(this.getColors(this.widgetProperties.config.color),this.drawValue())})}ngOnInit(){this.validateConfig()}ngAfterViewInit(){this.canvas.setHighDPISize(this.canvasValue().nativeElement,this.canvasValue().nativeElement.parentElement.getBoundingClientRect()),this.canvasCtx=this.canvasValue().nativeElement.getContext("2d"),this.maxTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.maxTextHeight=Math.floor(this.canvasValue().nativeElement.height*.7),!this.isDestroyed&&(this.getColors(this.widgetProperties.config.color),this.startWidget())}startWidget(){this._timeZoneGTM=this.getGMTOffset(this.widgetProperties.config.dateTimezone),this.unsubscribeDataStream(),this.observeDataStream("gaugePath",e=>{this.dataValue=e.data.value,this.drawValue()})}updateConfig(e){this.widgetProperties.config=e,this.getColors(this.widgetProperties.config.color),this.startWidget(),this.drawValue()}ngOnDestroy(){this.isDestroyed=!0,this.destroyDataStreams(),this.canvas.clearCanvas(this.canvasCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),this.canvasValue().nativeElement.remove()}getGMTOffset(e){try{let o=new Intl.DateTimeFormat("en-US",{timeZone:e,timeZoneName:"short"}).formatToParts(new Date).find(a=>a.type==="timeZoneName");return o?o.value:"GMT"}catch(t){return console.error(`Error getting GMT offset for timezone "${e}":`,t),"GMT"}}getColors(e){switch(e){case"contrast":this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break;case"blue":this.labelColor=this.theme().blueDim,this.valueColor=this.theme().blue;break;case"green":this.labelColor=this.theme().greenDim,this.valueColor=this.theme().green;break;case"pink":this.labelColor=this.theme().pinkDim,this.valueColor=this.theme().pink;break;case"orange":this.labelColor=this.theme().orangeDim,this.valueColor=this.theme().orange;break;case"purple":this.labelColor=this.theme().purpleDim,this.valueColor=this.theme().purple;break;case"grey":this.labelColor=this.theme().greyDim,this.valueColor=this.theme().grey;break;case"yellow":this.labelColor=this.theme().yellowDim,this.valueColor=this.theme().yellow;break;default:this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break}}onResized(e){e.contentRect.height<25||e.contentRect.width<25||(this.canvas.setHighDPISize(this.canvasValue().nativeElement,e.contentRect),this.canvasCtx=this.canvasValue().nativeElement.getContext("2d"),this.maxTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.maxTextHeight=Math.floor(this.canvasValue().nativeElement.height*.7),!this.isDestroyed&&this.drawValue())}drawValue(){if(!this.canvasCtx)return;let e;if(this.canvas.clearCanvas(this.canvasCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),isNaN(Date.parse(this.dataValue)))e="--";else try{e=Al(this.dataValue,this.widgetProperties.config.dateFormat,"en-US",this._timeZoneGTM)}catch(t){e=t,console.log("[Date Time Widget]: "+t)}this.canvas.drawText(this.canvasCtx,e,Math.floor(this.canvasValue().nativeElement.width/2),Math.floor(this.canvasValue().nativeElement.height/2*1.15),this.maxTextWidth,this.maxTextHeight,"bold",this.valueColor)}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-datetime"]],viewQuery:function(t,i){t&1&&de(i.canvasValue,dm,5),t&2&&Qe()},features:[pe],decls:5,vars:4,consts:[["canvasValue",""],[3,"configChange","config","id"],[1,"dateGenericWrapper",3,"onResize"],[2,"z-index","inherit"],[3,"text","color"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"div",2),V("onResize",function(l){return z(o),L(i.onResized(l))}),B(2,"canvas",3,0)(4,"widget-title",4),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(4),G("text",i.widgetProperties.config.displayName)("color",i.labelColor))},dependencies:[Ne,tt,et,ai],styles:["canvas[_ngcontent-%COMP%]{position:absolute;display:block;top:0;left:0}.dateGenericWrapper[_ngcontent-%COMP%]{position:relative;width:100%;height:100%}"]})}return r})();var ic=(()=>{class r{data=Y(null,{alias:"controlData"});theme=Y(null);dimensions=Y.required();toggleClick=Ni();toggleOff="0 35 180 35";toggleOn="0 0 180 35";ctrlState=null;ctrlColor="";oldTheme=null;viewBox=this.toggleOff;labelColor=null;valueColor=null;constructor(){}ngDoCheck(){let e=this.data();e.value!=this.ctrlState&&(this.ctrlState=e.value,this.viewBox=e.value?this.toggleOn:this.toggleOff),e.color!=this.ctrlColor&&(this.ctrlColor=e.color,this.getColors(e.color));let t=this.theme();this.oldTheme!=t&&(this.oldTheme=t,this.getColors(e.color))}toggle(e){let t=this.data();t.value=e,this.toggleClick.emit(t)}getColors(e){switch(e){case"contrast":this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break;case"blue":this.labelColor=this.theme().blueDim,this.valueColor=this.theme().blue;break;case"green":this.labelColor=this.theme().greenDim,this.valueColor=this.theme().green;break;case"pink":this.labelColor=this.theme().pinkDim,this.valueColor=this.theme().pink;break;case"orange":this.labelColor=this.theme().orangeDim,this.valueColor=this.theme().orange;break;case"purple":this.labelColor=this.theme().purpleDim,this.valueColor=this.theme().purple;break;case"grey":this.labelColor=this.theme().greyDim,this.valueColor=this.theme().grey;break;case"yellow":this.labelColor=this.theme().yellowDim,this.valueColor=this.theme().yellow;break;default:this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break}}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["app-svg-boolean-light"]],inputs:{data:[1,"controlData","data"],theme:[1,"theme"],dimensions:[1,"dimensions"]},outputs:{toggleClick:"toggleClick"},decls:20,vars:8,consts:[["version","1.1","id","svg9","xmlns","http://www.w3.org/2000/svg",0,"xmlns","svg","http://www.w3.org/2000/svg"],["id","defs1"],["id","linearGradient32"],["offset","0","id","stop32",2,"stop-color","#000000","stop-opacity","0.88486844"],["offset","1","id","stop33",2,"stop-color","#f7f7f7","stop-opacity","0.17763157"],[0,"xlink","href","#linearGradient32","id","linearGradient33","x1","7.0431595","y1","17.869596","x2","39.043159","y2","17.869596","gradientUnits","userSpaceOnUse"],["id","disabled","transform","translate(0,35)"],["width","180","height","35","id","rect1-5","x","0","y","0",2,"display","inline","opacity","1","fill","black","fill-opacity","0","stroke","none","stroke-width","0","stroke-dasharray","none","stroke-opacity","1"],["x","0","y","0","width","175","height","35","viewBox","0 0 175 35"],["id","text1-5","x","47.083984","y","22.636719",2,"text-align","center","font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","14px","font-family","arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"],["transform","translate(6,2)","id","disabledToogleControl"],["cx","18","cy","16","fill","#9f9f9f","id","circle3-7","r","13.5",2,"stroke-width","5","stroke","url(#linearGradient33)","stroke-opacity","0.2","stroke-dasharray","none"],["id","enabled"],["width","180","height","35","id","rect1","x","0","y","0",2,"display","inline","opacity","1","fill","black","fill-opacity","0","stroke","none","stroke-width","0","stroke-dasharray","none","stroke-opacity","1"],["id","text1","x","47.083984","y","22.636719",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","14px","font-family","arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"],["transform","translate(6,2)","id","enabledToogleControl"],["cx","18","cy","16","id","circle3","r","13.5",2,"stroke","url(#linearGradient33)","stroke-width","5","stroke-opacity","0.2","stroke-dasharray","none"]],template:function(t,i){t&1&&(Dt(),v(0,"svg",0)(1,"defs",1)(2,"linearGradient",2),B(3,"stop",3)(4,"stop",4),_(),B(5,"linearGradient",5),_(),v(6,"g",6),B(7,"rect",7),v(8,"svg",8)(9,"text",9),T(10),_()(),v(11,"g",10),B(12,"circle",11),_()(),v(13,"g",12),B(14,"rect",13),v(15,"svg",8)(16,"text",14),T(17),_()(),v(18,"g",15),B(19,"circle",16),_()()()),t&2&&(fe("height",i.dimensions().height)("width",i.dimensions().width)("viewBox",i.viewBox),P(9),fe("fill",i.labelColor),P(),ut(" ",i.data().ctrlLabel," "),P(6),fe("fill",i.valueColor),P(),ut("",i.data().ctrlLabel," "),P(2),fe("fill",i.valueColor))},encapsulation:2})}return r})();var nc=(()=>{class r{data=Y(null,{alias:"controlData"});theme=Y(null);dimensions=Y.required();toggleClick=Ni();toggleOff="0 35 180 35";toggleOn="0 0 180 35";oldTheme=null;timeoutHandler=null;pressed=!1;isSwiping=!1;pointerStartX=0;pointerStartY=0;viewBox=this.toggleOff;labelColorEnabled=null;labelColorDisabled=null;valueColor=null;ctrlColor="";constructor(){}ngOnInit(){}ngDoCheck(){this.viewBox=this.pressed?this.toggleOn:this.toggleOff;let e=this.data();e.color!=this.ctrlColor&&(this.ctrlColor=e.color,this.getColors(e.color));let t=this.theme();this.oldTheme!=t&&(this.oldTheme=t,this.getColors(this.data().color))}handleClickDown(e){this.isSwiping=!1,this.pointerStartX=e.clientX,this.pointerStartY=e.clientY,this.timeoutHandler=setTimeout(()=>{if(!this.isSwiping){this.pressed=!0;let t=Fn(this.data());t.value=this.pressed,this.toggleClick.emit(t),this.timeoutHandler=setInterval(()=>{this.toggleClick.emit(t)},100)}},200)}handlePointerMove(e){let t=Math.abs(e.clientX-this.pointerStartX),i=Math.abs(e.clientY-this.pointerStartY);(t>30||i>30)&&(this.isSwiping=!0,this.timeoutHandler&&(clearTimeout(this.timeoutHandler),this.timeoutHandler=null))}handleClickUp(){if(this.isSwiping){this.isSwiping=!1;return}this.pressed=!1,this.timeoutHandler&&(clearInterval(this.timeoutHandler),this.timeoutHandler=null)}getColors(e){switch(e){case"contrast":this.labelColorEnabled="black",this.labelColorDisabled=this.theme().contrastDim,this.valueColor=this.theme().contrast;break;case"blue":this.labelColorEnabled=this.theme().contrast,this.labelColorDisabled=this.theme().blueDim,this.valueColor=this.theme().blue;break;case"green":this.labelColorEnabled=this.theme().contrast,this.labelColorDisabled=this.theme().greenDim,this.valueColor=this.theme().green;break;case"pink":this.labelColorEnabled=this.theme().contrast,this.labelColorDisabled=this.theme().pinkDim,this.valueColor=this.theme().pink;break;case"orange":this.labelColorEnabled=this.theme().contrast,this.labelColorDisabled=this.theme().orangeDim,this.valueColor=this.theme().orange;break;case"purple":this.labelColorEnabled=this.theme().contrast,this.labelColorDisabled=this.theme().purpleDim,this.valueColor=this.theme().purple;break;case"grey":this.labelColorEnabled=this.theme().contrast,this.labelColorDisabled=this.theme().greyDim,this.valueColor=this.theme().grey;break;case"yellow":this.labelColorEnabled=this.theme().contrast,this.labelColorDisabled=this.theme().yellowDim,this.valueColor=this.theme().yellow;break;default:this.labelColorEnabled="black",this.labelColorDisabled=this.theme().contrastDim,this.valueColor=this.theme().contrast;break}}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["app-svg-boolean-button"]],inputs:{data:[1,"controlData","data"],theme:[1,"theme"],dimensions:[1,"dimensions"]},outputs:{toggleClick:"toggleClick"},decls:15,vars:8,consts:[["version","1.1","id","svg9","xmlns","http://www.w3.org/2000/svg",0,"xmlns","svg","http://www.w3.org/2000/svg"],["id","defs9"],[3,"pointerup","pointerleave","pointerdown","pointermove"],["id","disabled","transform","translate(0,35)"],["id","clickRecDisabled","width","180","height","35","x","0","y","0",2,"display","inline","opacity","1","fill","black","fill-opacity","0","stroke","none","stroke-width","0","stroke-dasharray","none","stroke-opacity","1"],["id","buttonDisabled","width","165.02518","height","25.025183","rx","3.6672263","x","7.4874101","y","4.9874086",2,"display","inline","mix-blend-mode","normal","fill","#9f9f9f","fill-opacity","0.972549","stroke","#ffffff","stroke-width","1.5","stroke-dasharray","none","stroke-opacity","0.2"],["x","12","y","0","width","156","height","35","viewBox","0 0 156 35"],["id","textDisabled","x","77.968102","y","22",2,"text-anchor","middle","text-align","center","font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","14px","font-family","arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"],["id","enabled"],["width","180","height","35","id","rect1","x","0","y","0",2,"display","inline","opacity","1","fill","black","fill-opacity","0","stroke","none","stroke-width","0","stroke-dasharray","none","stroke-opacity","1"],["id","buttonEnabled","width","165.02518","height","25.025183","rx","3.6672263","x","5.9874086","y","4.9874086","transform","translate(1.5)",2,"display","inline","opacity","1","mix-blend-mode","normal","stroke","#000000","stroke-width","1.5","stroke-dasharray","none","stroke-opacity","0.2"],["id","textEnabled","x","77.968102","y","22",2,"text-anchor","middle","text-align","center","font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","14px","font-family","arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"]],template:function(t,i){t&1&&(Dt(),v(0,"svg",0),B(1,"defs",1),v(2,"g",2),V("pointerup",function(){return i.handleClickUp()})("pointerleave",function(){return i.handleClickUp()})("pointerdown",function(a){return i.handleClickDown(a)})("pointermove",function(a){return i.handlePointerMove(a)}),v(3,"g",3),B(4,"rect",4)(5,"rect",5),v(6,"svg",6)(7,"text",7),T(8),_()()(),v(9,"g",8),B(10,"rect",9)(11,"rect",10),v(12,"svg",6)(13,"text",11),T(14),_()()()()()),t&2&&(fe("height",i.dimensions().height)("width",i.dimensions().width)("viewBox",i.viewBox),P(7),fe("fill",i.labelColorDisabled),P(),ut(" ",i.data().ctrlLabel," "),P(3),fe("fill",i.valueColor),P(2),fe("fill",i.labelColorEnabled),P(),ut(" ",i.data().ctrlLabel," "))},encapsulation:2})}return r})();var rc=(()=>{class r{data=Y(null,{alias:"controlData"});theme=Y(null);dimensions=Y.required();toggleClick=Ni();toggleOff="0 35 180 35";toggleOn="0 0 180 35";ctrlState=null;oldTheme=null;isSwiping=!1;pointerStartX=0;pointerStartY=0;viewBox=this.toggleOff;labelColor=null;valueColor=null;ctrlColor="";constructor(){}ngOnInit(){}ngDoCheck(){let e=this.data();e.value!=this.ctrlState&&(this.ctrlState=e.value,this.viewBox=e.value?this.toggleOn:this.toggleOff),e.color!=this.ctrlColor&&(this.ctrlColor=e.color,this.getColors(e.color));let t=this.theme();this.oldTheme!=t&&(this.oldTheme=t,this.getColors(e.color))}onPointerDown(e){this.isSwiping=!1,this.pointerStartX=e.clientX,this.pointerStartY=e.clientY}onPointerMove(e){let t=Math.abs(e.clientX-this.pointerStartX),i=Math.abs(e.clientY-this.pointerStartY);(t>30||i>30)&&(this.isSwiping=!0)}onPointerUp(e,t){if(this.isSwiping){this.isSwiping=!1;return}this.toggle(t)}toggle(e){let t=this.data();t.value=e,this.toggleClick.emit(t)}getColors(e){switch(e){case"contrast":this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break;case"blue":this.labelColor=this.theme().blueDim,this.valueColor=this.theme().blue;break;case"green":this.labelColor=this.theme().greenDim,this.valueColor=this.theme().green;break;case"pink":this.labelColor=this.theme().pinkDim,this.valueColor=this.theme().pink;break;case"orange":this.labelColor=this.theme().orangeDim,this.valueColor=this.theme().orange;break;case"purple":this.labelColor=this.theme().purpleDim,this.valueColor=this.theme().purple;break;case"grey":this.labelColor=this.theme().greyDim,this.valueColor=this.theme().grey;break;case"yellow":this.labelColor=this.theme().yellowDim,this.valueColor=this.theme().yellow;break;default:this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break}}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["app-svg-boolean-switch"]],inputs:{data:[1,"controlData","data"],theme:[1,"theme"],dimensions:[1,"dimensions"]},outputs:{toggleClick:"toggleClick"},decls:18,vars:8,consts:[["version","1.1","id","svg9","xmlns","http://www.w3.org/2000/svg",0,"xmlns","svg","http://www.w3.org/2000/svg"],["id","defs9"],["id","disabled","transform","translate(0,35)",3,"pointerdown","pointermove","pointerup"],["width","180","height","35","id","rect1-5","x","0","y","0",2,"display","inline","opacity","1","fill","black","fill-opacity","0","stroke","none","stroke-width","0","stroke-dasharray","none","stroke-opacity","1"],["x","0","y","0","width","175","height","35","viewBox","0 0 175 35"],["id","text1-5","x","47.083984","y","22.636719",2,"text-align","center","font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","14px","font-family","arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"],["transform","translate(6,2)","id","disabledToogleControl"],["width","37.714306","height","22","rx","10.999999","id","rect3-4","x","0","y","5",2,"stroke-width","1.57144","fill","#9f9f9f","fill-opacity","0.97216702"],["cx","11.5","cy","16","fill","#ffffff","id","circle3-7","r","10",2,"stroke-width","1.5","stroke","black","stroke-opacity","0.2","stroke-dasharray","none"],["id","enabled",3,"pointerdown","pointermove","pointerup"],["width","180","height","35","id","rect1","x","0","y","0",2,"display","inline","opacity","1","fill","black","fill-opacity","0","stroke","none","stroke-width","0","stroke-dasharray","none","stroke-opacity","1"],["id","text1","x","47.083984","y","22.636719",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","14px","font-family","arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"],["transform","translate(6,2)","id","enabledToogleControl"],["width","37.714306","height","22","rx","10.999999","id","rect3","x","0","y","5",2,"stroke-width","1.57144"],["cx","26.5","cy","16","fill","#ffffff","id","circle3","r","10",2,"stroke-width","1.5","stroke","black","stroke-opacity","0.2","stroke-dasharray","none"]],template:function(t,i){t&1&&(Dt(),v(0,"svg",0),B(1,"defs",1),v(2,"g",2),V("pointerdown",function(a){return i.onPointerDown(a)})("pointermove",function(a){return i.onPointerMove(a)})("pointerup",function(a){return i.onPointerUp(a,!0)}),B(3,"rect",3),v(4,"svg",4)(5,"text",5),T(6),_()(),v(7,"g",6),B(8,"rect",7)(9,"circle",8),_()(),v(10,"g",9),V("pointerdown",function(a){return i.onPointerDown(a)})("pointermove",function(a){return i.onPointerMove(a)})("pointerup",function(a){return i.onPointerUp(a,!1)}),B(11,"rect",10),v(12,"svg",4)(13,"text",11),T(14),_()(),v(15,"g",12),B(16,"rect",13)(17,"circle",14),_()()()),t&2&&(fe("height",i.dimensions().height)("width",i.dimensions().width)("viewBox",i.viewBox),P(5),fe("fill",i.labelColor),P(),ut(" ",i.data().ctrlLabel," "),P(7),fe("fill",i.valueColor),P(),ut("",i.data().ctrlLabel," "),P(2),fe("fill",i.valueColor))},encapsulation:2})}return r})();function cm(r,n){if(r&1){let e=ee();v(0,"app-svg-boolean-switch",6),V("toggleClick",function(i){z(e);let o=ge(2);return L(o.toggle(i))}),_()}if(r&2){let e=ge().$implicit,t=ge();G("controlData",e)("theme",t.theme())("dimensions",t.ctrlDimensions)}}function hm(r,n){if(r&1){let e=ee();v(0,"app-svg-boolean-button",6),V("toggleClick",function(i){z(e);let o=ge(2);return L(o.toggle(i))}),_()}if(r&2){let e=ge().$implicit,t=ge();G("controlData",e)("theme",t.theme())("dimensions",t.ctrlDimensions)}}function um(r,n){if(r&1){let e=ee();v(0,"app-svg-boolean-light",6),V("toggleClick",function(i){z(e);let o=ge(2);return L(o.toggle(i))}),_()}if(r&2){let e=ge().$implicit,t=ge();G("controlData",e)("theme",t.theme())("dimensions",t.ctrlDimensions)}}function mm(r,n){if(r&1&&(_l(0),Te(1,cm,1,3,"app-svg-boolean-switch",5)(2,hm,1,3,"app-svg-boolean-button",5)(3,um,1,3,"app-svg-boolean-light",5),wl()),r&2){let e,t=n.$implicit;P(),Ue((e=t.type)==="1"?1:e==="2"?2:e==="3"?3:-1)}}function pm(r,n){r&1&&B(0,"div",4)}var oc=(()=>{class r extends Re{dashboard=M(st);signalkRequestsService=M(Fi);appService=M(ti);switchControls=Wn([]);skRequestSub=new rn;labelColor=void 0;nbCtrl=null;ctrlDimensions={width:0,height:0};constructor(){super(),this.defaultConfig={displayName:"Switch Panel Label",filterSelfPaths:!0,paths:[],enableTimeout:!1,dataTimeout:5,color:"contrast",putEnable:!0,putMomentary:!1,multiChildCtrls:[]},Pe(()=>{this.theme()&&this.getColors(this.widgetProperties.config.color)})}ngOnInit(){this.validateConfig()}ngAfterViewInit(){this.startWidget()}startWidget(){this.nbCtrl=this.widgetProperties.config.multiChildCtrls.length,this.switchControls.set([]),this.widgetProperties.config.multiChildCtrls.forEach(e=>{e.isNumeric||(e.isNumeric=!1),this.switchControls().push(K({},e))}),this.unsubscribeDataStream();for(let e in this.switchControls())if(Object.prototype.hasOwnProperty.call(this.switchControls(),e)){let t=this.switchControls()[e];this.observeDataStream(e,i=>{t.isNumeric?[0,1,null].includes(i.data.value)&&(t.value=!!i.data.value):t.value=i.data.value})}this.skRequestSub?.unsubscribe(),this.subscribeSKRequest()}updateConfig(e){this.widgetProperties.config=e,this.getColors(this.widgetProperties.config.color),this.startWidget()}onResized(e){let t=e.contentRect.height/this.nbCtrl,i=35*e.contentRect.width/180,o=i<t?i:t;this.ctrlDimensions={width:e.contentRect.width,height:o}}subscribeSKRequest(){this.skRequestSub=this.signalkRequestsService.subscribeRequest().subscribe(e=>{if(e.widgetUUID==this.widgetProperties.uuid){let t=`Toggle Widget ${this.widgetProperties.config.displayName}: `;e.statusCode!=200&&(e.message?t+=e.message:t+=e.statusCode+" - "+e.statusCodeDescription,this.appService.sendSnackbarNotification(t,0))}})}toggle(e){let i=this.widgetProperties.config.paths.findIndex(o=>o.pathID==e.pathID);e.isNumeric?this.signalkRequestsService.putRequest(this.widgetProperties.config.paths[i].path,e.value?1:0,this.widgetProperties.uuid):this.signalkRequestsService.putRequest(this.widgetProperties.config.paths[i].path,e.value,this.widgetProperties.uuid)}getColors(e){switch(e){case"contrast":this.labelColor=this.theme().contrastDim;break;case"blue":this.labelColor=this.theme().blueDim;break;case"green":this.labelColor=this.theme().greenDim;break;case"pink":this.labelColor=this.theme().pinkDim;break;case"orange":this.labelColor=this.theme().orangeDim;break;case"purple":this.labelColor=this.theme().purpleDim;break;case"grey":this.labelColor=this.theme().greyDim;break;case"yellow":this.labelColor=this.theme().yellowDim;break;default:this.labelColor=this.theme().contrastDim;break}}ngOnDestroy(){this.destroyDataStreams(),this.skRequestSub?.unsubscribe()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-boolean-switch"]],features:[pe],decls:7,vars:5,consts:[["widgetContainer",""],[3,"configChange","config","id"],[3,"text","color"],[1,"widgets-container",3,"onResize"],[1,"widgetOverlay"],[1,"svg-widget",3,"controlData","theme","dimensions"],[1,"svg-widget",3,"toggleClick","controlData","theme","dimensions"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),B(1,"widget-title",2),v(2,"div",3,0),V("onResize",function(l){return z(o),L(i.onResized(l))}),Wi(4,mm,4,1,"ng-container",null,Jr),_(),Te(6,pm,1,0,"div",4),_()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),G("text",i.widgetProperties.config.displayName)("color",i.labelColor),P(3),Bi(i.switchControls()),P(2),Ue(i.dashboard.isDashboardStatic()?-1:6))},dependencies:[Ne,tt,et,rc,nc,ic,ai],styles:[".widgets-container[_ngcontent-%COMP%]{display:block;position:absolute;left:0;right:0;top:15%;height:85%;width:100%;overflow:hidden;z-index:20}.svg-widget[_ngcontent-%COMP%]{display:flex}.widgetOverlay[_ngcontent-%COMP%]{position:absolute;width:100%;height:100%;right:0;bottom:0;color:transparent;z-index:21}"]})}return r})();var fm=["apStencil"],gm=["countDown"],vm=["compassAnimate"],ym=["appWindAnimate"],bm=["rudderPrtAnimate"],_m=["rudderStbAnimate"];function wm(r,n){if(r&1&&(Dt(),v(0,"tspan",203),T(1),_()),r&2){let e=ge();P(),ut("Wind: ",e.apTargetAppWindAngle,"\xB0")}}var ac=(()=>{class r{ApStencil=le.required("apStencil");countDown=le.required("countDown");compassAnimate=le.required("compassAnimate");appWindAnimate=le.required("appWindAnimate");rudderPrtAnimate=le.required("rudderPrtAnimate");rudderStbAnimate=le.required("rudderStbAnimate");compassHeading=Y.required();appWindAngle=Y.required();rudderAngle=Y.required();apState;apTargetAppWindAngle;isApConnected=Y.required();compassFaceplate={oldDegreeIndicator:"0",newDegreeIndicator:"0",animationElement:null};appWind={oldDegreeIndicator:"0",newDegreeIndicator:"0",animationElement:null};headingValue="--";oldRudderPrtAngle=0;newRudderPrtAngle=0;oldRudderStbAngle=0;newRudderStbAngle=0;activityIconVisibility="hidden;";errorIconVisibility="hidden";msgStencilVisibility="hidden";msgStencilInnerHTML="Empty Message Stencil";errorStencilVisibility="hidden";errorStencilInnerText="Empty Error Stencil";messageVisibility="hidden";messageInnerText="";ngAfterViewInit(){this.compassFaceplate.animationElement=this.compassAnimate(),this.appWind.animationElement=this.appWindAnimate()}ngOnDestroy(){this.compassFaceplate.animationElement=null,this.appWind.animationElement=null}ngOnChanges(e){e.compassHeading&&!e.compassHeading.firstChange&&this.updateRotation(this.compassFaceplate,e.compassHeading.currentValue),e.apState&&!e.apState.firstChange&&(this.apState=this.apState.toUpperCase()),e.apTargetAppWindAngle&&!e.apTargetAppWindAngle.firstChange&&(this.apTargetAppWindAngle=parseFloat(e.apTargetAppWindAngle.currentValue.toFixed(0))),e.appWindAngle&&!e.appWindAngle.firstChange&&this.updateRotation(this.appWind,e.appWindAngle.currentValue),e.rudderAngle&&!e.rudderAngle.firstChange&&this.updateRudderAngle(e.rudderAngle.currentValue)}updateRotation(e,t){e.oldDegreeIndicator=e.newDegreeIndicator,e.newDegreeIndicator=t.toFixed(0),this.smoothCircularRotation(e)}updateRudderAngle(e){e<=0?(this.oldRudderPrtAngle=this.newRudderPrtAngle=0,this.oldRudderStbAngle=this.newRudderStbAngle,this.newRudderStbAngle=Math.round(e*-7.16)):(this.oldRudderStbAngle=this.newRudderStbAngle=0,this.oldRudderPrtAngle=this.newRudderPrtAngle,this.newRudderPrtAngle=Math.round(e*7.16)),this.animateRudder()}animateRudder(){this.rudderPrtAnimate()?.nativeElement?.beginElement(),this.rudderStbAnimate()?.nativeElement?.beginElement()}smoothCircularRotation(e){if(!e.animationElement)return;let t=Number(e.oldDegreeIndicator),i=Number(e.newDegreeIndicator),o=t-i;if(o!==0)if(Math.abs(o)>180){let a=[{condition:t===359,oldVal:"0"},{condition:t===0,oldVal:"359"}];for(let{condition:l,oldVal:d}of a)if(l){e.oldDegreeIndicator=d,e.animationElement.nativeElement.beginElement();return}e.newDegreeIndicator=o>0?"359":"0",e.animationElement.nativeElement.beginElement(),e.oldDegreeIndicator=o>0?"0":"359",e.newDegreeIndicator=i.toFixed(0),e.animationElement.nativeElement.beginElement()}else e.animationElement.nativeElement.beginElement()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["app-svg-autopilot"]],viewQuery:function(t,i){t&1&&(de(i.ApStencil,fm,5),de(i.countDown,gm,5),de(i.compassAnimate,vm,5),de(i.appWindAnimate,ym,5),de(i.rudderPrtAnimate,bm,5),de(i.rudderStbAnimate,_m,5)),t&2&&Qe(6)},inputs:{compassHeading:[1,"compassHeading"],appWindAngle:[1,"appWindAngle"],rudderAngle:[1,"rudderAngle"],apState:"apState",apTargetAppWindAngle:"apTargetAppWindAngle",isApConnected:[1,"isApConnected"]},features:[yi],decls:254,vars:25,consts:[["compassAnimate",""],["rudderStbAnimate",""],["rudderPrtAnimate",""],["appWindAnimate",""],["apStatusBar",""],["apStencil",""],[1,"apScreen"],[1,"apCompass"],[0,"xmlns","osb","http://www.openswatchbook.org/uri/2009/osb",0,"xmlns","dc","http://purl.org/dc/elements/1.1/",0,"xmlns","cc","http://creativecommons.org/ns#",0,"xmlns","rdf","http://www.w3.org/1999/02/22-rdf-syntax-ns#",0,"xmlns","svg","http://www.w3.org/2000/svg","xmlns","http://www.w3.org/2000/svg","id","svg8","version","1.1","viewBox","0 0 452 255","height","100%","width","100%"],["id","defs2"],[0,"osb","paint","solid","id","linearGradient7155"],["id","stop7153","offset","0",2,"stop-color","#6d6d6d","stop-opacity","1"],["id","layerCompassDial",2,"display","inline"],["transform","translate(-49,76)","id","gDial"],["id","path4584","cx","275","cy","200","rx","203.96022","ry","204.07419",1,"compass-outer-ring",2,"display","inline","fill","none","stroke-width","30.60257721","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["cy","200.00005","cx","275","id","circle4732","rx","181.16154","ry","181.26276",1,"compass-inner-ring",2,"display","inline","fill","none","stroke-width","15.7575798","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6608","d","m 307.7114,14.150798 -2.65629,15.073051",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6610","d","m 339.4192,22.709418 -5.23189,14.382504",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6614","d","m 396.02992,55.540321 -9.83269,11.72475",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6616","d","m 419.21273,78.815041 -11.71816,9.83821",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6620","d","m 451.8328,135.56858 -14.37454,5.23479",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6622","d","m 460.27887,167.32298 -15.06464,2.65782",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6626","d","m 460.16769,232.79216 -15.06465,-2.6578",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6628","d","m 451.61385,264.51765 -14.3745,-5.23482",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6632","d","m 419.44142,321.67543 -11.71819,-9.83826",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6634","d","m 396.17966,344.87121 -9.83274,-11.72477",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6638","d","m 339.45779,377.50944 -5.23188,-14.38252",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6640","d","m 307.72114,385.96028 -2.65629,-15.07307",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6644","d","m 242.28854,385.84901 2.65631,-15.07302",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6646","d","m 210.58075,377.29047 5.23187,-14.38255",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6650","d","m 153.97004,344.45952 9.83272,-11.72471",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6652","d","m 130.7872,321.1848 11.71819,-9.83825",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6656","d","m 98.167138,264.43125 14.374482,-5.23482",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6658","d","m 89.72108,232.67686 15.06461,-2.6578",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6662","d","m 89.832242,167.20768 15.064608,2.6578",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6664","d","m 98.386053,135.48218 14.374497,5.23484",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6668","d","m 130.55856,78.324441 11.71817,9.83821",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6670","d","m 153.82027,55.128641 9.83276,11.72475",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6674","d","m 210.54215,22.49037 5.23189,14.382551",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","use6676","d","m 242.27883,14.039615 2.65629,15.073018",1,"apCompassOrnaments",2,"display","inline","fill-opacity","1","stroke-width","2.04017186","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],[0,"xml","space","preserve","x","261.23273","y","7.5849795","id","text4588","transform","scale(0.99972065,1.0002794)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","32.64274979px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40172005","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4586","x","261.23273","y","7.5849795",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","32.64274979px","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40172005","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],[0,"xml","space","preserve","x","-288.64084","y","-391.88641","id","text4588-7","transform","scale(-0.99972065,-1.0002794)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","32.64274979px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40172005","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4608","x","-288.64084","y","-391.88641",2,"stroke-width","20.40172005"],[0,"xml","space","preserve","x","188.83127","y","-467.20248","id","text4588-0","transform","matrix(0,1.0002794,-0.99972065,0,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","32.64274979px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40172005","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4628","x","188.83127","y","-467.20248",2,"stroke-width","20.40172005"],[0,"xml","space","preserve","x","-220.33897","y","83.127594","id","text4588-79","transform","matrix(0,-1.0002794,0.99972065,0,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","32.64274979px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40172005","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4648","x","-220.33897","y","83.127594",2,"stroke-width","20.40172005"],["id","text4656","y","-249.69855","x","319.23901",0,"xml","space","preserve","transform","matrix(0.70690928,0.70730433,-0.70690928,0.70730433,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","21.76183891px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171623","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4658","x","319.23901","y","-249.69855",2,"stroke-width","20.40171623"],[0,"xml","space","preserve","x","37.022793","y","141.15974","id","text4664","transform","matrix(0.70690928,-0.70730433,0.70690928,0.70730433,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","21.76183891px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171623","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4666","x","37.022793","y","141.15974",2,"stroke-width","20.40171623"],["transform","matrix(-0.70690928,-0.70730433,0.70690928,-0.70730433,0,0)","id","text4670","y","-142.26419","x","-351.17065",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","21.76183891px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171623","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4672","x","-351.17065","y","-142.26419",2,"stroke-width","20.40171623"],[0,"xml","space","preserve","x","-68.111122","y","-532.27917","id","text4676","transform","matrix(-0.70690928,0.70730433,-0.70690928,-0.70730433,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","21.76183891px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171623","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4678","x","-68.111122","y","-532.27917",2,"stroke-width","20.40171623"],[0,"xml","space","preserve","x","318.18405","y","-119.23701","id","text4684","transform","matrix(0.92362146,0.38279035,-0.38257655,0.92413768,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4686","x","318.18405","y","-119.23701",2,"stroke-width","20.40171814"],["transform","matrix(0.38257655,0.92413768,-0.92362146,0.38279035,0,0)","id","text4690","y","-377.56421","x","278.92706",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4694","x","278.92706","y","-377.56421",2,"stroke-width","20.40171814"],[0,"xml","space","preserve","x","69.223236","y","-529.73126","id","text4698","transform","matrix(-0.38257655,0.92413768,-0.92362146,-0.38279035,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4700","x","69.223236","y","-529.73126",2,"stroke-width","20.40171814"],["transform","matrix(-0.92362146,0.38279035,-0.38257655,-0.92413768,0,0)","id","text4704","y","-489.35358","x","-188.60149",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4706","x","-188.60149","y","-489.35358",2,"stroke-width","20.40171814"],[0,"xml","space","preserve","x","-341.82956","y","-279.7951","id","text4710","transform","matrix(-0.92362146,-0.38279035,0.38257655,-0.92413768,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4712","x","-341.82956","y","-279.7951",2,"stroke-width","20.40171814"],["transform","matrix(-0.38257655,-0.92413768,0.92362146,-0.38279035,0,0)","id","text4716","y","-22.359142","x","-304.323",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4718","x","-304.323","y","-22.359142",2,"stroke-width","20.40171814"],[0,"xml","space","preserve","x","-93.375298","y","130.60631","id","text4722","transform","matrix(0.38257655,-0.92413768,0.92362146,0.38279035,0,0)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4724","x","-93.375298","y","130.60631",2,"stroke-width","20.40171814"],["transform","matrix(0.92362146,-0.38279035,0.38257655,0.92413768,0,0)","id","text4728","y","89.936447","x","165.05888",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.88091946px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none","stroke-width","20.40171814","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.85427091"],["id","tspan4730","x","165.05888","y","89.936447",2,"stroke-width","20.40171814"],["id","use7029","y","25.345657","x","269.16998",0,"xml","space","preserve","transform","scale(0.99972065,1.0002794)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.04160881px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["y","25.345657","x","269.16998","id","tspan7053",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.04160881px","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","writing-mode","lr-tb","text-anchor","start","stroke-width","1.02008593"],["id","use7031","y","-138.13023","x","326.06656",0,"xml","space","preserve","transform","matrix(0.86578352,0.50013971,-0.49986031,0.86626737,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7101","x","326.06656","y","-138.13023",2,"stroke-width","1.02008593"],["id","use7033","y","-311.27252","x","298.64697",0,"xml","space","preserve","transform","matrix(0.49986031,0.86626737,-0.86578352,0.50013971,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7103","x","298.64697","y","-311.27252",2,"stroke-width","1.02008593"],["id","use7035","y","-448.97495","x","188.02534",0,"xml","space","preserve","transform","matrix(0,1.0002794,-0.99972065,0,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.04160881px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7105","x","188.02534","y","-448.97495",2,"stroke-width","1.02008593"],["id","use7037","y","-511.58801","x","18.152977",0,"xml","space","preserve","transform","matrix(-0.49986031,0.86626737,-0.86578352,-0.50013971,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7109","x","18.152977","y","-511.58801",2,"stroke-width","1.02008593"],["id","use7039","y","-485.03159","x","-157.02438",0,"xml","space","preserve","transform","matrix(-0.86578352,0.50013971,-0.49986031,-0.86626737,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7111","x","-157.02438","y","-485.03159",2,"stroke-width","1.02008593"],["id","use7041","y","-374.19531","x","-293.47723",0,"xml","space","preserve","transform","scale(-0.99972065,-1.0002794)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.04160881px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7113","x","-293.47723","y","-374.19531",2,"stroke-width","1.02008593"],["id","use7043","y","-210.0593","x","-356.61142",0,"xml","space","preserve","transform","matrix(-0.86578352,-0.50013971,0.49986031,-0.86626737,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7115","x","-356.61142","y","-210.0593",2,"stroke-width","1.02008593"],["id","use7045","y","-35.933571","x","-328.77301",0,"xml","space","preserve","transform","matrix(-0.49986031,-0.86626737,0.86578352,-0.50013971,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7117","x","-328.77301","y","-35.933571",2,"stroke-width","1.02008593"],["id","use7047","y","101.6399","x","-217.66704",0,"xml","space","preserve","transform","matrix(0,-1.0002794,0.99972065,0,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.04160881px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7119","x","-217.66704","y","101.6399",2,"stroke-width","1.02008593"],["id","use7049","y","163.86317","x","-52.594109",0,"xml","space","preserve","transform","matrix(0.49986031,-0.86626737,0.86578352,0.50013971,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7121","x","-52.594109","y","163.86317",2,"stroke-width","1.02008593"],["id","use7051","y","136.26141","x","120.06727",0,"xml","space","preserve","transform","matrix(0.86578352,-0.50013971,0.49986031,0.86626737,0,0)",1,"apCompassOrnaments",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","19.0416069px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none","stroke-width","1.02008593"],["id","tspan7125","x","120.06727","y","136.26141",2,"stroke-width","1.02008593"],["attributeName","transform","type","rotate","begin","indefinite","dur","0.1s","additive","replace","fill","freeze"],["transform","translate(-48.447528,53.7796)","id","layerAPModes",2,"display","inline"],["id","textHeadingUnits","y","195.59286","x","375.5509",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","16px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none"],["y","195.59286","x","375.5509","id","tspan7332"],["id","textPilotMode","y","-5.9288187","x","53.518887",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","21.33333397px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none"],["y","-5.9288187","x","53.518887","id","tspan7336"],["id","textLockedWindAngle","y","-5.63585","x","388.37534",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","21.33333397px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none"],["y","-5.63585","x","388.37534","id","tspan7340",4,"ngIf"],["transform","translate(-48.447528,53.7796)","id","layerHeading",2,"display","inline"],["transform","translate(7.0707071,-37.373737)","id","textHeadingValue"],[0,"xml","space","preserve","x","261.90826","y","230.58067","id","text7163","transform","scale(0.98289846,1.0173991)",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","124.02593231px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","center","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","middle","stroke","none","stroke-width","3.24648261"],["id","tspan7406","x","261.90826","y","230.58067",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","124.02593231px","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","center","writing-mode","lr-tb","text-anchor","middle","stroke-width","3.24648261"],["x","350.04529",0,"xml","space","preserve","y","192.68625","id","text5715",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","64px","line-height","1.25","font-family","sans-serif","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none"],["id","tspan5713","x","350.04529","y","192.68625"],["transform","translate(-48.447528,53.7796)","id","layerRudder",2,"display","inline"],["y","-53.399956","x","274.99667","height","14.987642","width","0","id","rudderAnglePrt",1,"rudderStarboard",2,"display","inline","opacity","1","stroke","none","stroke-width","2","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["attributeType","XML","attributeName","width","dur","0.5s","begin","indefinite","additive","replace","fill","freeze"],["transform","scale(-1,1)","y","-53.399956","x","-274.44928","height","14.987642","width","0","id","rudderAngleStb",1,"rudderPort",2,"display","inline","opacity","1","stroke","none","stroke-width","2","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","translate(-48.447528,-110.9287)","id","layerBackground",2,"display","inline"],["id","g276"],["id","g7471","transform","translate(24.722982,-28.057562)"],["transform","translate(721.94867,-290.57106)","id","g5688"],["id","path4652-4","d","m -472.47775,871.67124 a 165.94029,166.38596 0 0 1 -165.5669,-166.3216 165.94029,166.38596 0 0 1 165.43938,-166.44913",1,"port",2,"display","inline","fill","none","stroke-width","14.82046986","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path4652-4-2","d","M 472.647,871.67236 A 165.94029,166.38596 0 0 1 328.86191,788.52051 165.94029,166.38596 0 0 1 328.84104,622.0886 165.94029,166.38596 0 0 1 472.60527,538.90049","transform","scale(-1,1)",1,"starboard",2,"display","inline","fill","none","stroke-width","14.82046986","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","g5754",1,"apCompassOrnaments"],["d","m 99.32582,328.14958 12.77685,7.39357","id","path7189",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7191","d","m 162.64238,264.41753 7.37674,12.80605",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["d","m 335.9953,264.04783 -7.37672,12.80611","id","path7193",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7195","d","m 399.58188,327.50924 -12.77686,7.39366",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["d","m 422.9912,414.33449 -14.75348,3e-5","id","path7197",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7199","d","m 399.95073,501.2588 -12.77692,-7.3936",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["d","m 336.63416,564.99087 -7.37678,-12.80612","id","path7201",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7203","d","m 250.0071,588.45375 -3e-5,-14.78727",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["d","m 163.28122,565.36054 7.37672,-12.80615","id","path7205",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7207","d","m 99.694636,501.89912 12.776874,-7.39367",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["d","m 76.28531,415.07387 14.753506,-6e-5","id","path7209",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7211","d","m 249.26941,240.95462 6e-5,14.78725",2,"fill","none","stroke-width","2.95406151","stroke-linecap","butt","stroke-linejoin","miter","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7213","cx","317.2731","cy","198.57274","transform","matrix(0.98473974,0.17403345,-0.1732637,0.98487547,0,0)","rx","1.4684811","ry","1.4716377",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(0.93944096,0.3427108,-0.34133044,0.93994337,0,0)","cy","137.78685","cx","375.78641","id","circle7219","rx","1.4687726","ry","1.4713458",2,"fill-opacity","1","stroke-width","2.95406342","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7221","cx","457.31314","cy","-9.3075047","transform","matrix(0.7653205,0.64364938,-0.64192532,0.76676716,0,0)","rx","1.4697686","ry","1.4703517",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(0.64192538,0.76676711,-0.76532046,0.64364943,0,0)","cy","-91.100418","cx","477.8157","id","circle7223","rx","1.4703517","ry","1.4697686",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7225","cx","475.04779","cy","-258.81723","transform","matrix(0.34133049,0.93994335,-0.93944093,0.34271086,0,0)","rx","1.4713458","ry","1.4687726",2,"fill-opacity","1","stroke-width","2.95406318","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(0.1732637,0.98487547,-0.98473974,0.17403346,0,0)","cy","-339.68927","cx","451.80542","id","circle7227","rx","1.4716377","ry","1.4684812",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7229","cx","365.07513","cy","-483.41837","transform","matrix(-0.1732637,0.98487547,-0.98473974,-0.17403346,0,0)","rx","1.4716377","ry","1.4684812",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(-0.34133048,0.93994335,-0.93944094,-0.34271083,0,0)","cy","-541.96466","cx","304.2561","id","circle7231","rx","1.4713457","ry","1.4687726",2,"fill-opacity","1","stroke-width","2.95406294","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7233","cx","157.04932","cy","-623.60413","transform","matrix(-0.64192535,0.76676714,-0.7653205,-0.64364938,0,0)","rx","1.4703517","ry","1.4697688",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(-0.7653205,0.64364938,-0.64192535,-0.76676714,0,0)","cy","-644.17261","cx","75.19046","id","circle7235","rx","1.4697688","ry","1.4703517",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7237","cx","-92.639015","cy","-641.51727","transform","matrix(-0.93944094,0.34271083,-0.34133048,-0.93994335,0,0)","rx","1.4687726","ry","1.4713457",2,"fill-opacity","1","stroke-width","2.95406294","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(-0.98473974,0.17403346,-0.1732637,-0.98487547,0,0)","cy","-618.30792","cx","-173.54405","id","circle7239","rx","1.4684812","ry","1.4716377",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7241","cx","-317.2731","cy","-531.57745","transform","matrix(-0.98473974,-0.17403346,0.1732637,-0.98487547,0,0)","rx","1.4684812","ry","1.4716377",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(-0.93944094,-0.34271083,0.34133048,-0.93994335,0,0)","cy","-470.72552","cx","-375.78641","id","circle7243","rx","1.4687726","ry","1.4713457",2,"fill-opacity","1","stroke-width","2.95406294","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7245","cx","-457.3132","cy","-323.40628","transform","matrix(-0.7653205,-0.64364938,0.64192535,-0.76676714,0,0)","rx","1.4697688","ry","1.4703517",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(-0.64192535,-0.76676714,0.7653205,-0.64364938,0,0)","cy","-241.48129","cx","-477.81573","id","circle7247","rx","1.4703517","ry","1.4697688",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7249","cx","-475.04776","cy","-73.539139","transform","matrix(-0.34133048,-0.93994335,0.93944094,-0.34271083,0,0)","rx","1.4713457","ry","1.4687726",2,"fill-opacity","1","stroke-width","2.95406294","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(-0.1732637,-0.98487547,0.98473974,-0.17403346,0,0)","cy","7.3989258","cx","-451.80542","id","circle7251","rx","1.4716377","ry","1.4684812",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7253","cx","-365.07513","cy","151.12804","transform","matrix(0.1732637,-0.98487547,0.98473974,0.17403346,0,0)","rx","1.4716377","ry","1.4684812",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(0.34133049,-0.93994335,0.93944093,0.34271086,0,0)","cy","209.60825","cx","-304.2561","id","circle7255","rx","1.4713458","ry","1.4687726",2,"fill-opacity","1","stroke-width","2.95406318","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7257","cx","-157.04932","cy","291.0224","transform","matrix(0.64192538,-0.76676711,0.76532046,0.64364943,0,0)","rx","1.4703517","ry","1.4697686",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(0.7653205,-0.64364938,0.64192532,0.76676716,0,0)","cy","311.45892","cx","-75.19046","id","circle7259","rx","1.4697686","ry","1.4703517",2,"fill-opacity","1","stroke-width","2.95406508","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7261","cx","92.639","cy","308.57849","transform","matrix(0.93944096,-0.3427108,0.34133044,0.93994337,0,0)","rx","1.4687726","ry","1.4713458",2,"fill-opacity","1","stroke-width","2.95406342","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["transform","matrix(0.98473974,-0.17403345,0.1732637,0.98487547,0,0)","cy","285.3031","cx","173.54404","id","circle7263","rx","1.4684811","ry","1.4716377",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","circle7265","cx","173.54404","cy","285.3031","transform","matrix(0.98473974,-0.17403345,0.1732637,0.98487547,0,0)","rx","1.4684811","ry","1.4716377",2,"fill-opacity","1","stroke-width","2.95406199","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["r","221.99022","cy","414.70831","cx","250","id","path7341",2,"display","inline","fill","none","fill-opacity","0.80952382","stroke","#000000","stroke-width","6.01955366","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","0.71794876"],["id","path4120","d","m 249.26947,259.74187 -25.47864,22.43141 h 51.40958 z",2,"display","inline","opacity","0.5","fill","#000000","stroke","none","stroke-width","2.18676066px","stroke-linecap","butt","stroke-linejoin","miter","stroke-opacity","1"],["id","g7661","transform","matrix(1,0,0,0.40619912,-0.01308156,81.255803)"],["y","73.984749","x","49.443867","height","36.007324","width","450.58438","id","rect7491",2,"display","inline","opacity","1","fill","none","fill-opacity","1","stroke","#000000","stroke-width","1.99267745","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["y","74.014343","x","275.45538","height","35.807354","width","142.73141","id","rect7491-8-1-1",2,"display","inline","opacity","1","fill","none","fill-opacity","1","stroke","#000000","stroke-width","2.21205759","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["y","74.014343","x","132.72397","height","35.807354","width","142.73141","id","rect7491-8-1-1-1",2,"display","inline","opacity","1","fill","none","fill-opacity","1","stroke","#000000","stroke-width","2.21205759","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["y","74.014343","x","59.762901","height","35.807354","width","142.73141","id","rect7491-8-1-1-1-0",2,"display","inline","opacity","1","fill","none","fill-opacity","1","stroke","#000000","stroke-width","2.21205759","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["y","74.014343","x","346.97778","height","35.807354","width","142.73141","id","rect7491-8-1-1-1-6",2,"display","inline","opacity","1","fill","none","fill-opacity","1","stroke","#000000","stroke-width","2.21205759","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],[0,"xml","space","preserve","x","196.81769","y","135.53325","id","text7612",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.66666698px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none"],["id","tspan7610","x","196.81769","y","135.53325"],[0,"xml","space","preserve","x","126.64516","y","135.53325","id","text7616",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.66666698px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none"],["id","tspan7614","x","126.64516","y","135.53325"],[0,"xml","space","preserve","x","54.179352","y","135.53325","id","text7620",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.66666698px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","stroke","none"],["id","tspan7618","x","54.179352","y","135.53325"],[0,"xml","space","preserve","x","341.181","y","135.53325","id","text7612-4",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.66666698px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none"],["id","tspan7610-0","x","341.181","y","135.53325"],[0,"xml","space","preserve","x","413.27536","y","135.53325","id","text7616-8",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.66666698px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none"],["id","tspan7614-7","x","413.27536","y","135.53325"],[0,"xml","space","preserve","x","484.21832","y","135.53325","id","text7620-7",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.66666698px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none"],["id","tspan7618-0","x","484.21832","y","135.53325"],[0,"xml","space","preserve","x","257.13232","y","135.12598","id","text7612-7",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","10.66666698px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none"],["id","tspan7610-08","x","257.13232","y","135.12598"],[0,"xml","space","preserve","x","131.37558","y","360.30118","id","text7334-7",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","16px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","start","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","start","display","inline","stroke","none"],["id","tspan7332-3","x","131.37558","y","360.30118"],["id","layerWindAngle",2,"display","inline"],["transform","rotate(179.60924,237.62275,95.469746)","id","windAngleIndicator",2,"display","inline"],["transform","matrix(-5.1082345,0,0,-4.5354333,587.61946,139.05361)","id","g7361",1,"app-wind",2,"display","inline","fill-opacity","1"],["d","M 62.243972,4.0584953 A 3.9408352,3.9073367 0 0 1 66.184807,0.15115881 3.9408352,3.9073367 0 0 1 70.125642,4.0584955","id","path7357",1,"app-wind",2,"fill-opacity","1","stroke","#000000","stroke-width","0.30782673","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","path7359","d","m 62.177083,3.96875 3.968749,6.614583 3.96875,-6.614583",1,"app-wind",2,"fill-opacity","1","stroke","#000000","stroke-width","0.26458332px","stroke-linecap","butt","stroke-linejoin","miter","stroke-opacity","1"],["transform","scale(-1.0096233,-0.99046843)","id","text7365","y","-117.71236","x","-247.47594",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","13.33333302px","line-height","1.25","font-family","Arial","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-feature-settings","normal","text-align","center","letter-spacing","0px","word-spacing","0px","writing-mode","lr-tb","text-anchor","middle","stroke","none","stroke-width","1.02742887"],["id","tspan7417","x","-247.47594","y","-117.71236"],["id","tspan184","x","-247.47594","y","-101.04569"],["transform","rotate(-179.60924)","id","text188","y","-125.73083","x","-374.62845",0,"xml","space","preserve",1,"apText",2,"font-style","normal","font-weight","normal","font-size","40px","line-height","1.25","font-family","sans-serif","letter-spacing","0px","word-spacing","0px","stroke","none"],["y","-89.237617","x","-374.62845","id","tspan186"],[1,"apStatusBar"],[2,"display","inline-block","width","calc(100% - 50px)",3,"innerText"],[2,"display","inline-block"],[1,"material-icons"],[1,"apStencil"],[2,"font-weight","bold","opacity","75%"],[2,"opacity","75%"],[1,"apStencil","confirmCommand",3,"innerHTML"],[1,"apStencil","error"],[1,"material-icons",2,"color","darkgoldenrod","padding-top","15px"],[3,"innerHTML"],["y","-5.63585","x","388.37534","id","tspan7340"]],template:function(t,i){t&1&&(v(0,"div",6)(1,"div",7),Dt(),v(2,"svg",8)(3,"defs",9)(4,"linearGradient",10),B(5,"stop",11),_()(),v(6,"g",12)(7,"g",13),B(8,"ellipse",14)(9,"ellipse",15)(10,"path",16)(11,"path",17)(12,"path",18)(13,"path",19)(14,"path",20)(15,"path",21)(16,"path",22)(17,"path",23)(18,"path",24)(19,"path",25)(20,"path",26)(21,"path",27)(22,"path",28)(23,"path",29)(24,"path",30)(25,"path",31)(26,"path",32)(27,"path",33)(28,"path",34)(29,"path",35)(30,"path",36)(31,"path",37)(32,"path",38)(33,"path",39),v(34,"text",40)(35,"tspan",41),T(36,"N"),_()(),v(37,"text",42)(38,"tspan",43),T(39,"S"),_()(),v(40,"text",44)(41,"tspan",45),T(42,"E"),_()(),v(43,"text",46)(44,"tspan",47),T(45,"W"),_()(),v(46,"text",48)(47,"tspan",49),T(48,"NE"),_()(),v(49,"text",50)(50,"tspan",51),T(51,"NW"),_()(),v(52,"text",52)(53,"tspan",53),T(54,"SW"),_()(),v(55,"text",54)(56,"tspan",55),T(57,"SE"),_()(),v(58,"text",56)(59,"tspan",57),T(60,"NNE"),_()(),v(61,"text",58)(62,"tspan",59),T(63,"ENE"),_()(),v(64,"text",60)(65,"tspan",61),T(66,"ESE"),_()(),v(67,"text",62)(68,"tspan",63),T(69,"SSE"),_()(),v(70,"text",64)(71,"tspan",65),T(72,"SSW"),_()(),v(73,"text",66)(74,"tspan",67),T(75,"WSW"),_()(),v(76,"text",68)(77,"tspan",69),T(78,"WNW"),_()(),v(79,"text",70)(80,"tspan",71),T(81,"NNW"),_()(),v(82,"text",72)(83,"tspan",73),T(84,"0"),_()(),v(85,"text",74)(86,"tspan",75),T(87,"30"),_()(),v(88,"text",76)(89,"tspan",77),T(90,"60"),_()(),v(91,"text",78)(92,"tspan",79),T(93,"90"),_()(),v(94,"text",80)(95,"tspan",81),T(96,"120"),_()(),v(97,"text",82)(98,"tspan",83),T(99,"150"),_()(),v(100,"text",84)(101,"tspan",85),T(102,"180"),_()(),v(103,"text",86)(104,"tspan",87),T(105,"210"),_()(),v(106,"text",88)(107,"tspan",89),T(108,"240"),_()(),v(109,"text",90)(110,"tspan",91),T(111,"270"),_()(),v(112,"text",92)(113,"tspan",93),T(114,"300"),_()(),v(115,"text",94)(116,"tspan",95),T(117,"330"),_()()(),B(118,"animateTransform",96,0),_(),v(120,"g",97)(121,"text",98)(122,"tspan",99),T(123,"Mag"),_()(),v(124,"text",100)(125,"tspan",101),T(126),_()(),v(127,"text",102),Te(128,wm,2,1,"tspan",103),_()(),v(129,"g",104)(130,"g",105)(131,"text",106)(132,"tspan",107),T(133),_()(),v(134,"text",108)(135,"tspan",109),T(136,"\xB0"),_()()()(),v(137,"g",110)(138,"rect",111),B(139,"animate",112,1),_(),v(141,"rect",113),B(142,"animate",112,2),_()(),v(144,"g",114)(145,"g",115)(146,"g",116)(147,"g",117),B(148,"path",118)(149,"path",119),_(),v(150,"g",120),B(151,"path",121)(152,"path",122)(153,"path",123)(154,"path",124)(155,"path",125)(156,"path",126)(157,"path",127)(158,"path",128)(159,"path",129)(160,"path",130)(161,"path",131)(162,"path",132)(163,"ellipse",133)(164,"ellipse",134)(165,"ellipse",135)(166,"ellipse",136)(167,"ellipse",137)(168,"ellipse",138)(169,"ellipse",139)(170,"ellipse",140)(171,"ellipse",141)(172,"ellipse",142)(173,"ellipse",143)(174,"ellipse",144)(175,"ellipse",145)(176,"ellipse",146)(177,"ellipse",147)(178,"ellipse",148)(179,"ellipse",149)(180,"ellipse",150)(181,"ellipse",151)(182,"ellipse",152)(183,"ellipse",153)(184,"ellipse",154)(185,"ellipse",155)(186,"ellipse",156)(187,"ellipse",157),_(),B(188,"circle",158)(189,"path",159),_(),v(190,"g",160),B(191,"rect",161)(192,"rect",162)(193,"rect",163)(194,"rect",164)(195,"rect",165),_(),v(196,"text",166)(197,"tspan",167),T(198,"10\xB0"),_()(),v(199,"text",168)(200,"tspan",169),T(201,"20\xB0"),_()(),v(202,"text",170)(203,"tspan",171),T(204,"30\xB0"),_()(),v(205,"text",172)(206,"tspan",173),T(207,"10\xB0"),_()(),v(208,"text",174)(209,"tspan",175),T(210,"20\xB0"),_()(),v(211,"text",176)(212,"tspan",177),T(213,"30\xB0"),_()(),v(214,"text",178)(215,"tspan",179),T(216,"Rudder"),_()(),v(217,"text",180)(218,"tspan",181),T(219,"Hdg"),_()()()(),v(220,"g",182)(221,"g",183)(222,"g",184),B(223,"path",185)(224,"path",186),_(),v(225,"text",187)(226,"tspan",188),T(227,"Wind"),_(),v(228,"tspan",189),T(229,"A"),_()(),v(230,"text",190),B(231,"tspan",191),_()(),B(232,"animateTransform",96,3),_()()(),cl(),v(234,"div",192,4),B(236,"div",193),v(237,"div",194)(238,"span",195),T(239," sync_alt "),_()()(),v(240,"div",196,5)(242,"p",197),T(243,"OFFLINE"),_(),v(244,"p",198),T(245,"Press "),v(246,"span",195),T(247,"power_settings_new"),_(),T(248," to connect to Signal K server"),_()(),B(249,"div",199),v(250,"div",200)(251,"span",201),T(252,"warning"),_(),B(253,"p",202),_()()),t&2&&(P(118),fe("from","-"+i.compassFaceplate.oldDegreeIndicator+" 226 276")("to","-"+i.compassFaceplate.newDegreeIndicator+" 226 276"),P(8),ut(" ",i.apState," "),P(2),G("ngIf",i.apState=="Wind"),P(5),lt(i.headingValue),P(6),fe("from",i.oldRudderStbAngle)("to",i.newRudderStbAngle),P(3),fe("from",i.oldRudderPrtAngle)("to",i.newRudderPrtAngle),P(90),fe("from",i.appWind.oldDegreeIndicator+" 226 276")("to",i.appWind.newDegreeIndicator+" 226 276"),P(4),He("visibility",i.messageVisibility),G("innerText",i.messageInnerText),P(),He("visibility",i.activityIconVisibility),P(),He("visibility",i.activityIconVisibility),P(2),G("@fadeInOut",i.isApConnected()?"connected":"disconnected"),P(9),He("visibility",i.msgStencilVisibility),G("innerHTML",i.msgStencilInnerHTML,Ia),P(),He("visibility",i.errorStencilVisibility),P(3),G("innerHTML",i.errorStencilInnerText,Ia))},dependencies:[Li],styles:[".apScreen[_ngcontent-%COMP%] .apStencil[_ngcontent-%COMP%]{position:absolute;top:0;left:0;width:100%;height:100%;margin:auto;border-radius:5px;z-index:10;vertical-align:middle;background-color:var(--mat-sys-background)}.apScreen[_ngcontent-%COMP%]{display:block;position:relative;width:360px;height:240.5px;margin:auto;text-align:center;border-radius:5px;border:1px solid var(--kip-grey-dim-color);background-color:var(--mat-sys-background)}.compass-inner-ring[_ngcontent-%COMP%]{stroke:var(--kip-contrast-color);fill:var(--kip-contrast-color)}.compass-outer-ring[_ngcontent-%COMP%]{stroke:var(--kip-grey-color)}.apCompassOrnaments[_ngcontent-%COMP%]{fill:var(--kip-kip-widget-card-background-color);stroke:var(--mat-sys-background)}.rudderPort[_ngcontent-%COMP%]{fill:var(--kip-port-color)}.rudderStarboard[_ngcontent-%COMP%]{fill:var(--kip-starboard-color)}.starboard[_ngcontent-%COMP%]{stop-color:var(--kip-starboard-color)}.port[_ngcontent-%COMP%]{stop-color:var(--kip-port-color)}.app-wind[_ngcontent-%COMP%]{fill:var(--kip-blue-color)}.apText[_ngcontent-%COMP%]{fill:var(--kip-contrast-color)}"],data:{animation:[Ar("fadeInOut",[Eo("connected",oi({opacity:0})),Eo("disconnected",oi({opacity:1})),Pr("connected <=> disconnected",nr(".3s"))])]}})}return r})();var km=["powerBtn"],Sm=["stbTackBtn"],Cm=["plus1Btn"],xm=["minus1Btn"],Tm=["prtTackBtn"],Em=["standbyBtn"],Dm=["plus10Btn"],Am=["minus10Btn"],Pm=["autoBtn"],Mm=["windModeBtn"],Om=["trackModeBtn"],Im=["muteBtn"],Rm=["messageBtn"],Nm=["appSvgAutopilot"];function Wm(r,n){r&1&&(v(0,"span",21),T(1,"notifications_off"),_())}function Bm(r,n){r&1&&(v(0,"span",21),T(1,"notifications"),_())}function zm(r,n){if(r&1&&B(0,"span",50),r&2){let e=ge();di("matBadge",e.alarmsCount)}}var sc={auto:{path:"self.steering.autopilot.state",value:"auto"},wind:{path:"self.steering.autopilot.state",value:"wind"},route:{path:"self.steering.autopilot.state",value:"route"},standby:{path:"self.steering.autopilot.state",value:"standby"},"+1":{path:"self.steering.autopilot.actions.adjustHeading",value:1},"+10":{path:"self.steering.autopilot.actions.adjustHeading",value:10},"-1":{path:"self.steering.autopilot.actions.adjustHeading",value:-1},"-10":{path:"self.steering.autopilot.actions.adjustHeading",value:-10},tackToPort:{path:"self.steering.autopilot.actions.tack",value:"port"},tackToStarboard:{path:"self.steering.autopilot.actions.tack",value:"starboard"},advanceWaypoint:{path:"self.steering.autopilot.actions.advanceWaypoint",value:"1"}};var Lm=5,Ka=250,lc=(()=>{class r extends Re{signalkRequestsService=M(Fi);powerBtn=le("powerBtn");stbTackBtn=le("stbTackBtn");plus1Btn=le("plus1Btn");minus1Btn=le("minus1Btn");prtTackBtn=le("prtTackBtn");standbyBtn=le("standbyBtn");plus10Btn=le("plus10Btn");minus10Btn=le("minus10Btn");autoBtn=le("autoBtn");windModeBtn=le("windModeBtn");trackModeBtn=le("trackModeBtn");muteBtn=le("muteBtn");messageBtn=le("messageBtn");apScreen=le("appSvgAutopilot");displayName;currentAPState=null;currentAPTargetAppWind=0;currentHeading=0;currentAppWindAngle=null;currentRudder=null;skApNotificationSub=new rn;skRequestSub=new rn;handleCountDownCounterTimeout=null;handleConfirmActionTimeout=null;handleMessageTimeout=null;handleReceiveTimeout=null;handleDisplayErrorTimeout=null;countDownValue=0;actionToBeConfirmed="";skPathToAck="";isWChecked=!1;isTChecked=!1;isApConnected=!1;notificationsArray={};alarmsCount=0;notificationTest={};constructor(){super(),this.defaultConfig={displayName:"N2k Autopilot",filterSelfPaths:!0,paths:{apState:{description:"Autopilot State",path:"self.steering.autopilot.state",source:"default",pathType:"string",isPathConfigurable:!0,showPathSkUnitsFilter:!1,convertUnitTo:"",sampleTime:500},apTargetHeadingMag:{description:"Autopilot Target Heading Mag",path:"self.steering.autopilot.target.headingMagnetic",source:"default",pathType:"number",convertUnitTo:"deg",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",sampleTime:500},apTargetWindAngleApp:{description:"Autopilot Target Wind Angle Apparent",path:"self.steering.autopilot.target.windAngleApparent",source:"default",pathType:"number",convertUnitTo:"deg",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",sampleTime:500},headingMag:{description:"Heading Magnetic",path:"self.navigation.headingMagnetic",source:"default",pathType:"number",convertUnitTo:"deg",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",sampleTime:500},headingTrue:{description:"Heading True",path:"self.navigation.headingTrue",source:"default",pathType:"number",convertUnitTo:"deg",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",sampleTime:500},windAngleApparent:{description:"Wind Angle Apparent",path:"self.environment.wind.angleApparent",source:"default",pathType:"number",convertUnitTo:"deg",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",sampleTime:500},windAngleTrueWater:{description:"Wind Angle True Water",path:"self.environment.wind.angleTrueWater",source:"default",pathType:"number",convertUnitTo:"deg",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",sampleTime:500},rudderAngle:{description:"Rudder Angle",path:"self.steering.rudderAngle",source:"default",pathType:"number",convertUnitTo:"deg",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",sampleTime:500}},usage:{headingMag:["wind","route","auto","standby"],headingTrue:["wind","route","auto","standby"],windAngleApparent:["wind"],windAngleTrueWater:["wind"]},typeVal:{headingMag:"Mag",headingTrue:"True",windAngleApparent:"AWA",windAngleTrueWater:"TWA"},barColor:"accent",autoStart:!1,invertRudder:!0,enableTimeout:!1,dataTimeout:5}}ngOnInit(){this.validateConfig(),this.widgetProperties.config.autoStart&&setTimeout(()=>{this.startApHead()})}startWidget(){}updateConfig(e){this.widgetProperties.config=e}demoMode(){}ngOnDestroy(){this.destroyDataStreams(),this.unsubscribeSKRequest(),console.log("Autopilot Subs Stopped")}startAllSubscriptions(){this.observeDataStream("apState",e=>{this.currentAPState=e.data.value,this.SetKeyboardMode(this.currentAPState)}),this.observeDataStream("headingMag",e=>{e.data.value===null?this.currentHeading=0:this.currentHeading=e.data.value}),this.observeDataStream("windAngleApparent",e=>{if(e.data.value===null){this.currentAppWindAngle=null;return}e.data.value<0?this.currentAppWindAngle=360+e.data.value:this.currentAppWindAngle=e.data.value}),this.observeDataStream("rudderAngle",e=>{e.data.value===null?this.currentRudder=0:this.currentRudder=this.widgetProperties.config.invertRudder?-e.data.value:e.data.value}),this.observeDataStream("apTargetWindAngleApp",e=>{e.data.value===null?this.currentAPTargetAppWind=0:this.currentAPTargetAppWind=e.data.value}),this.subscribeSKRequest(),console.log("Autopilot Subs Started")}stopAllSubscriptions(){this.unsubscribeDataStream(),this.unsubscribeSKRequest(),console.log("Autopilot Subs Stopped")}subscribeSKRequest(){this.skRequestSub=this.signalkRequestsService.subscribeRequest().subscribe(e=>{e.widgetUUID==this.widgetProperties.uuid&&this.commandReceived(e)})}unsubscribeSKRequest(){this.skRequestSub!==null&&(this.skRequestSub.unsubscribe(),this.skRequestSub=null)}addHeading(e,t){let i=e+t;for(;i>359;)i=i-359;for(;i<0;)i=i+359;return i}powerBtnClick(e){this.isApConnected?this.stopApHead():this.startApHead()}startApHead(){this.startAllSubscriptions(),this.widgetProperties.config.autoStart=!0,this.isApConnected=!0,this.muteBtn().disabled=!0,this.messageBtn().disabled=!1}stopApHead(){this.muteBtn().disabled=!0,this.messageBtn().disabled=!0,this.windModeBtn().disabled=!0,this.trackModeBtn().disabled=!0,this.autoBtn().disabled=!0,this.standbyBtn().disabled=!0,this.plus1Btn().disabled=!0,this.plus10Btn().disabled=!0,this.minus1Btn().disabled=!0,this.minus10Btn().disabled=!0,this.prtTackBtn().disabled=!0,this.stbTackBtn().disabled=!0,this.apScreen().errorIconVisibility="hidden",this.isApConnected=!1,this.stopAllSubscriptions(),this.widgetProperties.config.autoStart=!1}SetKeyboardMode(e){switch(e){case"standby":this.trackModeBtn().disabled=!0,this.autoBtn().disabled=!1,this.standbyBtn().disabled=!1,this.windModeBtn().disabled=!1,this.plus1Btn().disabled=!0,this.plus10Btn().disabled=!0,this.minus1Btn().disabled=!0,this.minus10Btn().disabled=!0,this.prtTackBtn().disabled=!0,this.stbTackBtn().disabled=!0;break;case"auto":this.trackModeBtn().disabled=!1,this.autoBtn().disabled=!1,this.standbyBtn().disabled=!1,this.windModeBtn().disabled=!1,this.plus1Btn().disabled=!1,this.plus10Btn().disabled=!1,this.minus1Btn().disabled=!1,this.minus10Btn().disabled=!1,this.prtTackBtn().disabled=!0,this.stbTackBtn().disabled=!0;break;case"wind":this.trackModeBtn().disabled=!0,this.autoBtn().disabled=!1,this.standbyBtn().disabled=!1,this.windModeBtn().disabled=!1,this.plus1Btn().disabled=!1,this.plus10Btn().disabled=!1,this.minus1Btn().disabled=!1,this.minus10Btn().disabled=!1,this.prtTackBtn().disabled=!1,this.stbTackBtn().disabled=!1;break;case"route":this.trackModeBtn().disabled=!1,this.autoBtn().disabled=!1,this.standbyBtn().disabled=!1,this.windModeBtn().disabled=!0,this.plus1Btn().disabled=!0,this.plus10Btn().disabled=!0,this.minus1Btn().disabled=!0,this.minus10Btn().disabled=!0,this.prtTackBtn().disabled=!0,this.stbTackBtn().disabled=!0;break;default:break}}buildAndSendCommand(e){let t=sc[e];if(typeof t>"u")return alert("Unknown Autopilot command: "+e),null;if(this.actionToBeConfirmed!==""&&this.actionToBeConfirmed!==e&&this.clearConfirmCmd(),(e==="tackToPort"||e==="tackToStarboard")&&this.actionToBeConfirmed==="")return this.confirmTack(e),null;if(e==="route"&&this.currentAPState==="route"&&this.actionToBeConfirmed==="")return this.confirmAdvanceWaypoint(e),null;if(this.actionToBeConfirmed===e)return this.clearConfirmCmd(),(e==="tackToPort"||e==="tackToStarboard")&&this.sendCommand(t),e==="route"&&this.currentAPState==="route"&&this.sendCommand(sc.advanceWaypoint),null;this.sendCommand(t)}confirmAdvanceWaypoint(e){this.startConfirmCmd(e,"Repeat key <b>[Next Wpt]</b><br>to confirm<br>Advance Waypoint")}confirmTack(e){let t="Repeat same key<br>to confirm<br>tack to ";if(e==="tackToPort")t+="port",this.actionToBeConfirmed=e;else if(e==="tackToStarboard")t+="starboard",this.actionToBeConfirmed=e;else return this.actionToBeConfirmed="",null;this.startConfirmCmd(e,t)}sendCommand(e){let t=this.signalkRequestsService.putRequest(e.path,e.value,this.widgetProperties.uuid);this.apScreen().activityIconVisibility="visible",setTimeout(()=>{this.apScreen().activityIconVisibility="hidden"},Ka),console.log(`AP Action:
|
|
8
|
+
`+JSON.stringify(e))}commandReceived(e){this.apScreen().activityIconVisibility="visible",clearTimeout(this.handleReceiveTimeout),this.handleReceiveTimeout=setTimeout(()=>{this.apScreen().activityIconVisibility="hidden"},Ka),e.statusCode!=200?this.displayApError(e):console.log(`AP Received:
|
|
9
|
+
`+JSON.stringify(e))}startConfirmCmd(e,t){this.countDownValue=Lm,this.actionToBeConfirmed=e;let i=this.apScreen();i.msgStencilInnerHTML="<p>"+t+"</p>",i.msgStencilVisibility="visible",this.updateCountDownCounter(t),clearTimeout(this.handleConfirmActionTimeout),this.handleConfirmActionTimeout=setTimeout(()=>{let o=this.apScreen();o.msgStencilVisibility="hidden",o.msgStencilInnerHTML="",this.actionToBeConfirmed=""},5e3)}clearConfirmCmd(){clearTimeout(this.handleConfirmActionTimeout),clearTimeout(this.handleCountDownCounterTimeout),this.countDownValue=-1;let e=this.apScreen();return e.msgStencilVisibility="hidden",e.msgStencilInnerHTML="",this.actionToBeConfirmed="",null}updateCountDownCounter(e){this.countDownValue>0?(clearTimeout(this.handleCountDownCounterTimeout),this.apScreen().msgStencilInnerHTML="<p>"+e+"</p><h1 class='counterText'>"+this.countDownValue.toString()+"</h1>",this.countDownValue-=1,this.handleCountDownCounterTimeout=setTimeout(()=>{this.updateCountDownCounter(e)},1e3)):clearTimeout(this.handleCountDownCounterTimeout)}displayApError(e){let t=e.statusCode+" - "+e.statusCodeDescription;e.message&&(t=t+" Server Message: "+e.message);let i=this.apScreen();i.errorStencilInnerText=t,i.errorStencilVisibility="visible",clearTimeout(this.handleDisplayErrorTimeout),this.handleDisplayErrorTimeout=setTimeout(()=>{let o=this.apScreen();o.errorStencilVisibility="hidden",o.errorStencilInnerText=""},6e3),i.errorIconVisibility="visible"}getNextNotification(e){let t=Object.keys(this.notificationsArray),i="",o=0;return t.length>0&&(typeof e<"u"?o=t.indexOf(e)+1:o=0,t.length<=o&&(o=0),i=t[o]),i}setNotificationMessage(e){let t=this.apScreen();t.activityIconVisibility="visible",clearTimeout(this.handleReceiveTimeout),this.handleReceiveTimeout=setTimeout(()=>{this.apScreen().activityIconVisibility="hidden"},Ka),typeof e.path<"u"&&(e.path=e.path.replace("notifications.",""),typeof e.value<"u"&&(e.value.state==="normal"?(t.messageInnerText===this.notificationsArray[e.path]&&(t.messageInnerText=""),delete this.notificationsArray[e.path]):(this.notificationsArray[e.path]=e.value.message.replace("Pilot",""),t.messageInnerText=this.notificationsArray[e.path]))),this.alarmsCount=Object.keys(this.notificationsArray).length,this.alarmsCount>0?(this.muteBtn().disabled=!1,t.messageInnerText==""&&(t.messageInnerText=Object.keys(this.notificationsArray)[0])):(this.muteBtn().disabled=!0,this.alarmsCount=0,t.messageInnerText="")}notificationToValue(e){let t=this.notificationsArray[e];return typeof t>"u"&&(t="No alarm present..."),t}notificationScroll(){Object.keys(this.notificationsArray).length>0&&this.skPathToAck==""&&(this.skPathToAck=Object.keys(this.notificationsArray)[0]),this.skPathToAck=this.getNextNotification(this.skPathToAck);let e=this.apScreen();e.messageInnerText=this.notificationToValue(this.skPathToAck),e.messageVisibility="visible",clearTimeout(this.handleMessageTimeout),this.handleMessageTimeout=setTimeout(()=>{let t=this.apScreen();t.messageInnerText="",t.messageVisibility="hidden"},2e3)}sendSilence(){let e=this.apScreen();e.messageVisibility!="visible"?(e.messageVisibility="visible",Object.keys(this.notificationsArray).length>0&&this.skPathToAck==""&&(this.skPathToAck=Object.keys(this.notificationsArray)[0])):(this.skPathToAck!==""&&this.sendCommand({path:"notifications."+this.skPathToAck+".state",value:"normal"}),e.messageVisibility="hidden"),e.messageInnerText=this.notificationToValue(this.skPathToAck)}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-autopilot"]],viewQuery:function(t,i){t&1&&(de(i.powerBtn,km,5),de(i.stbTackBtn,Sm,5),de(i.plus1Btn,Cm,5),de(i.minus1Btn,xm,5),de(i.prtTackBtn,Tm,5),de(i.standbyBtn,Em,5),de(i.plus10Btn,Dm,5),de(i.minus10Btn,Am,5),de(i.autoBtn,Pm,5),de(i.windModeBtn,Mm,5),de(i.trackModeBtn,Om,5),de(i.muteBtn,Im,5),de(i.messageBtn,Rm,5),de(i.apScreen,Nm,5)),t&2&&Qe(14)},features:[pe],decls:66,vars:13,consts:[["autopilot",""],["powerBtn",""],["appSvgAutopilot",""],["stbTackBtn",""],["plus1Btn",""],["minus1Btn",""],["prtTackBtn",""],["standbyBtn",""],["plus10Btn",""],["minus10Btn",""],["autoBtn",""],["windModeBtn",""],["trackModeBtn",""],["muteBtn",""],["messageBtn",""],[3,"configChange","config","id"],[1,"autopilotWidget",3,"id"],[1,"headerAutopilot"],[1,"apTitle"],[1,"apPower"],["mat-flat-button","","id","powerBtn","disabled","false",1,"powerBtn",3,"click"],[1,"material-icons"],[3,"compassHeading","appWindAngle","rudderAngle","apState","apTargetAppWindAngle","isApConnected"],[1,"autopilotGridBtnContainer"],[1,"itemStbTack"],["type","button","mat-flat-button","","id","stbTackBtn","disabled","true",1,"auto-pilot-btn-width",3,"click"],[1,"itemPlus1"],["type","button","mat-flat-button","","id","plus1Btn","disabled","true",1,"auto-pilot-btn-width",3,"click"],[1,"itemMinus1"],["type","button","mat-flat-button","","id","minus1Btn","disabled","true",1,"auto-pilot-btn-width",3,"click"],[1,"itemPrtTack"],["type","button","mat-flat-button","","id","prtTackBtn","disabled","true",1,"auto-pilot-btn-width",3,"click"],[1,"itemStandby"],["type","button","mat-flat-button","","id","standbyBtn","disabled","true",1,"auto-pilot-btn-width","button-color-red",3,"click"],[1,"itemPlus10"],["type","button","mat-flat-button","","id","plus10Btn","disabled","true",1,"auto-pilot-btn-width",3,"click"],[1,"itemMinus10"],["type","button","mat-flat-button","","id","minus10Btn","disabled","true",1,"auto-pilot-btn-width",3,"click"],[1,"itemAuto"],["type","button","mat-flat-button","","id","autoBtn","disabled","true",1,"auto-pilot-btn-width","button-color-red",3,"click"],[1,"itemWindmode"],["type","button","mat-flat-button","","id","windModeBtn","disabled","true",1,"auto-pilot-btn-width","button-color-red",3,"click"],[1,"itemTrackmode"],["type","button","mat-flat-button","","id","trackModeBtn","disabled","true",1,"auto-pilot-btn-width",3,"click"],[1,"itemMute"],["type","button","mat-mini-fab","","id","muteBtn","disabled","true",1,"auto-pilot-btn-widthCtrl",3,"click"],["class","material-icons",4,"ngIf"],[1,"itemMessage"],["type","button","mat-mini-fab","","id","messageBtn","disabled","true",1,"auto-pilot-btn-widthCtrl",3,"click"],["matBadgeColor","warn","matBadgeSize","medium","matBadgeHidden","false","matBadgeOverlap","false",3,"matBadge",4,"ngIf"],["matBadgeColor","warn","matBadgeSize","medium","matBadgeHidden","false","matBadgeOverlap","false",3,"matBadge"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",15),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"div",16,0)(3,"div",17)(4,"div",18)(5,"span"),T(6),_()(),v(7,"div",19)(8,"button",20,1),V("click",function(l){return z(o),L(i.powerBtnClick(l))}),v(10,"span",21),T(11," power_settings_new "),_()()()(),B(12,"app-svg-autopilot",22,2),v(14,"div",23)(15,"div",24)(16,"button",25,3),V("click",function(){return z(o),L(i.buildAndSendCommand("tackToStarboard"))}),T(18,"Std Tack"),_()(),v(19,"div",26)(20,"button",27,4),V("click",function(){return z(o),L(i.buildAndSendCommand("+1"))}),T(22,"+1\xB0"),_()(),v(23,"div",28)(24,"button",29,5),V("click",function(){return z(o),L(i.buildAndSendCommand("-1"))}),T(26,"-1\xB0"),_()(),v(27,"div",30)(28,"button",31,6),V("click",function(){return z(o),L(i.buildAndSendCommand("tackToPort"))}),T(30,"Prt Tack"),_()(),v(31,"div",32)(32,"button",33,7),V("click",function(){return z(o),L(i.buildAndSendCommand("standby"))}),T(34,"Standby"),_()(),v(35,"div",34)(36,"button",35,8),V("click",function(){return z(o),L(i.buildAndSendCommand("+10"))}),T(38,"+10\xB0"),_()(),v(39,"div",36)(40,"button",37,9),V("click",function(){return z(o),L(i.buildAndSendCommand("-10"))}),T(42,"-10\xB0"),_()(),v(43,"div",38)(44,"button",39,10),V("click",function(){return z(o),L(i.buildAndSendCommand("auto"))}),T(46,"Auto"),_()(),v(47,"div",40)(48,"button",41,11),V("click",function(){return z(o),L(i.buildAndSendCommand("wind"))}),T(50,"Wind"),_()(),v(51,"div",42)(52,"button",43,12),V("click",function(){return z(o),L(i.buildAndSendCommand("route"))}),T(54,"Route"),_()(),v(55,"div",44)(56,"button",45,13),V("click",function(){return z(o),L(i.sendSilence())}),Te(58,Wm,2,0,"span",46)(59,Bm,2,0,"span",46),_()(),v(60,"div",47)(61,"button",48,14),V("click",function(){return z(o),L(i.notificationScroll())}),v(63,"span",21),T(64,"mail"),_(),Te(65,zm,1,1,"span",49),_()()()()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),di("id",i.widgetProperties.uuid),P(5),lt(i.widgetProperties.config.displayName),P(6),G("compassHeading",i.currentHeading)("appWindAngle",i.currentAppWindAngle)("rudderAngle",i.currentRudder)("apState",i.currentAPState)("apTargetAppWindAngle",i.currentAPTargetAppWind)("isApConnected",i.isApConnected),P(46),G("ngIf",i.alarmsCount),P(),G("ngIf",!i.alarmsCount),P(6),G("ngIf",i.alarmsCount))},dependencies:[Ne,ii,ac,rd,Li,Do],styles:['[_ngcontent-%COMP%]:root{display:block;height:100%;width:100%}.apStencil.confirmCommand[_ngcontent-%COMP%]{z-index:5;visibility:hidden}.apStencil.error[_ngcontent-%COMP%]{z-index:6;visibility:hidden}.apCompass[_ngcontent-%COMP%]{position:relative;width:360px;height:202px;margin:auto;border-radius:5px}div.apStatusBar[_ngcontent-%COMP%]{width:360px;height:18.5px;border-bottom-left-radius:5px;border-bottom-right-radius:5px;background-color:red}.apStatusBar[_ngcontent-%COMP%], .apStatusBar[_ngcontent-%COMP%] DIV[_ngcontent-%COMP%]{display:inline-block;position:relative}div.autopilotWidget[_ngcontent-%COMP%]{display:block;position:relative;border:none;margin:0;padding:5px 0;width:100%;height:calc(100% - 10px)}.headerAutopilot[_ngcontent-%COMP%]{display:block;position:relative;width:346px;margin:auto auto 5px}.headerAutopilot[_ngcontent-%COMP%] .apTitle[_ngcontent-%COMP%]{display:inline-block;font-weight:700;width:calc(100% - 64px);margin:0}.headerAutopilot[_ngcontent-%COMP%] .apPower[_ngcontent-%COMP%]{display:inline-block;width:64px;margin:0}.auto-pilot-btn-width[_ngcontent-%COMP%]{width:85px}.button-color-red[_ngcontent-%COMP%]{--mdc-filled-button-container-color: var(--kip-port-color);--mdc-filled-button-label-text-color: var(--kip-contrast-color)}.activityIcon[_ngcontent-%COMP%]{opacity:40%;color:red;width:25px}.autopilotGridBtnContainer[_ngcontent-%COMP%]{display:grid;width:fit-content;margin:5px auto auto;height:160px;grid-template-columns:[col-start] 25% [col1-end] 25% [col2-end] 25% [col3-end] 25% [col-End];grid-template-rows:[row-start] 25% [row1-end] 25% [row2-end] 25% [row3-end] 25% [row-end];grid-template-areas:". mute message ." "port minus1 plus1 starboard" "windmode minus10 plus10 trackmode" "standby . . auto1";row-gap:6px;column-gap:4px;justify-items:center;align-items:center;justify-content:center;align-content:start;--mdc-filled-button-container-shape: 5px}.itemStbTack[_ngcontent-%COMP%]{grid-area:starboard}.itemMute[_ngcontent-%COMP%]{grid-area:mute}.itemMessage[_ngcontent-%COMP%]{grid-area:message}.itemPrtTack[_ngcontent-%COMP%]{grid-area:port}.itemPlus1[_ngcontent-%COMP%]{grid-area:plus1}.itemMinus1[_ngcontent-%COMP%]{grid-area:minus1}.itemStandby[_ngcontent-%COMP%]{grid-area:standby}.itemPlus10[_ngcontent-%COMP%]{grid-area:plus10}.itemMinus10[_ngcontent-%COMP%]{grid-area:minus10}.itemAuto[_ngcontent-%COMP%]{grid-area:auto1}.itemWindmode[_ngcontent-%COMP%]{grid-area:windmode}.itemTrackmode[_ngcontent-%COMP%]{grid-area:trackmode}.itemNxtWp[_ngcontent-%COMP%]{grid-area:nxtWp}.counterText[_ngcontent-%COMP%]{font-weight:700;font-size:7em;margin-top:0;margin-bottom:0}']})}return r})();var dc={modes:{point(r,n){return Oo(r,n,{intersect:!0})},nearest(r,n,e){return Hm(r,n,e)},x(r,n,e){return Oo(r,n,{intersect:e.intersect,axis:"x"})},y(r,n,e){return Oo(r,n,{intersect:e.intersect,axis:"y"})}}};function as(r,n,e){return(dc.modes[e.mode]||dc.modes.nearest)(r,n,e)}function Vm(r,n,e){return e!=="x"&&e!=="y"?r.inRange(n.x,n.y,"x",!0)||r.inRange(n.x,n.y,"y",!0):r.inRange(n.x,n.y,e,!0)}function Fm(r,n,e){return e==="x"?{x:r.x,y:n.y}:e==="y"?{x:n.x,y:r.y}:n}function Oo(r,n,e){return r.filter(t=>e.intersect?t.inRange(n.x,n.y):Vm(t,n,e.axis))}function Hm(r,n,e){let t=Number.POSITIVE_INFINITY;return Oo(r,n,e).reduce((i,o)=>{let a=o.getCenterPoint(),l=Fm(n,a,e.axis),d=Er(n,l);return d<t?(i=[o],t=d):d===t&&i.push(o),i},[]).sort((i,o)=>i._index-o._index).slice(0,1)}function vn(r,n,e){let t=Math.cos(e),i=Math.sin(e),o=n.x,a=n.y;return{x:o+t*(r.x-o)-i*(r.y-a),y:a+i*(r.x-o)+t*(r.y-a)}}var Um=(r,n)=>n>r||r.length>n.length&&r.slice(0,n.length)===n,mn=.001,Ro=(r,n,e)=>Math.min(e,Math.max(n,r)),Ac=(r,n)=>r.value>=r.start-n&&r.value<=r.end+n;function Gm(r,n,e){for(let t of Object.keys(r))r[t]=Ro(r[t],n,e);return r}function jm(r,n,e,t){return!r||!n||e<=0?!1:Math.pow(r.x-n.x,2)+Math.pow(r.y-n.y,2)<=Math.pow(e+t,2)}function Pc(r,{x:n,y:e,x2:t,y2:i},o,{borderWidth:a,hitTolerance:l}){let d=(a+l)/2,f=r.x>=n-d-mn&&r.x<=t+d+mn,s=r.y>=e-d-mn&&r.y<=i+d+mn;return o==="x"?f:(o==="y"||f)&&s}function Mc(r,{rect:n,center:e},t,{rotation:i,borderWidth:o,hitTolerance:a}){let l=vn(r,e,ui(-i));return Pc(l,n,t,{borderWidth:o,hitTolerance:a})}function yn(r,n){let{centerX:e,centerY:t}=r.getProps(["centerX","centerY"],n);return{x:e,y:t}}function qm(r,n,e,t=!0){let i=e.split("."),o=0;for(let a of n.split(".")){let l=i[o++];if(parseInt(a,10)<parseInt(l,10))break;if(Um(l,a)){if(t)throw new Error(`${r} v${e} is not supported. v${n} or newer is required.`);return!1}}return!0}var Oc=r=>typeof r=="string"&&r.endsWith("%"),Ic=r=>parseFloat(r)/100,Rc=r=>Ro(Ic(r),0,1),Mr=(r,n)=>({x:r,y:n,x2:r,y2:n,width:0,height:0}),Ym={box:r=>Mr(r.centerX,r.centerY),doughnutLabel:r=>Mr(r.centerX,r.centerY),ellipse:r=>({centerX:r.centerX,centerY:r.centerX,radius:0,width:0,height:0}),label:r=>Mr(r.centerX,r.centerY),line:r=>Mr(r.x,r.y),point:r=>({centerX:r.centerX,centerY:r.centerY,radius:0,width:0,height:0}),polygon:r=>Mr(r.centerX,r.centerY)};function ss(r,n){return n==="start"?0:n==="end"?r:Oc(n)?Rc(n)*r:r/2}function Xi(r,n,e=!0){return typeof n=="number"?n:Oc(n)?(e?Rc(n):Ic(n))*r:r}function $m(r,n){let{x:e,width:t}=r,i=n.textAlign;return i==="center"?e+t/2:i==="end"||i==="right"?e+t:e}function Nc(r,n,{borderWidth:e,position:t,xAdjust:i,yAdjust:o},a){let l=Ui(a),d=n.width+(l?a.width:0)+e,f=n.height+(l?a.height:0)+e,s=ls(t),c=cc(r.x,d,i,s.x),m=cc(r.y,f,o,s.y);return{x:c,y:m,x2:c+d,y2:m+f,width:d,height:f,centerX:c+d/2,centerY:m+f/2}}function ls(r,n="center"){return Ui(r)?{x:ln(r.x,n),y:ln(r.y,n)}:(r=ln(r,n),{x:r,y:r})}var Wc=(r,n)=>r&&r.autoFit&&n<1;function Bc(r,n){let e=r.font,t=Hi(e)?e:[e];return Wc(r,n)?t.map(function(i){let o=Dr(i);return o.size=Math.floor(i.size*n),o.lineHeight=i.lineHeight,Dr(o)}):t.map(i=>Dr(i))}function zc(r){return r&&(hi(r.xValue)||hi(r.yValue))}function cc(r,n,e=0,t){return r-ss(n,t)+e}function dr(r,n,e){let t=e.init;if(t){if(t===!0)return Vc(n,e)}else return;return Qm(r,n,e)}function Lc(r,n,e){let t=!1;return n.forEach(i=>{Gi(r[i])?(t=!0,e[i]=r[i]):hi(e[i])&&delete e[i]}),t}function Vc(r,n){let e=n.type||"line";return Ym[e](r)}function Qm(r,n,e){let t=Tr(e.init,[{chart:r,properties:n,options:e}]);if(t===!0)return Vc(n,e);if(Ui(t))return t}var Za=new Map,Xm=r=>isNaN(r)||r<=0,Km=r=>r.reduce(function(n,e){return n+=e.string,n},"");function No(r){if(r&&typeof r=="object"){let n=r.toString();return n==="[object HTMLImageElement]"||n==="[object HTMLCanvasElement]"}}function Wo(r,{x:n,y:e},t){t&&(r.translate(n,e),r.rotate(ui(t)),r.translate(-n,-e))}function Di(r,n){if(n&&n.borderWidth)return r.lineCap=n.borderCapStyle||"butt",r.setLineDash(n.borderDash),r.lineDashOffset=n.borderDashOffset,r.lineJoin=n.borderJoinStyle||"miter",r.lineWidth=n.borderWidth,r.strokeStyle=n.borderColor,!0}function cr(r,n){r.shadowColor=n.backgroundShadowColor,r.shadowBlur=n.shadowBlur,r.shadowOffsetX=n.shadowOffsetX,r.shadowOffsetY=n.shadowOffsetY}function Bo(r,n){let e=n.content;if(No(e))return{width:Xi(e.width,n.width),height:Xi(e.height,n.height)};let t=Bc(n),i=n.textStrokeWidth,o=Hi(e)?e:[e],a=o.join()+Km(t)+i+(r._measureText?"-spriting":"");return Za.has(a)||Za.set(a,tp(r,o,t,i)),Za.get(a)}function Fc(r,n,e){let{x:t,y:i,width:o,height:a}=n;r.save(),cr(r,e);let l=Di(r,e);r.fillStyle=e.backgroundColor,r.beginPath(),Ga(r,{x:t,y:i,w:o,h:a,radius:Gm(ja(e.borderRadius),0,Math.min(o,a)/2)}),r.closePath(),r.fill(),l&&(r.shadowColor=e.borderShadowColor,r.stroke()),r.restore()}function Hc(r,n,e,t){let i=e.content;if(No(i)){r.save(),r.globalAlpha=rp(e.opacity,i.style.opacity),r.drawImage(i,n.x,n.y,n.width,n.height),r.restore();return}let o=Hi(i)?i:[i],a=Bc(e,t),l=e.color,d=Hi(l)?l:[l],f=$m(n,e),s=n.y+e.textStrokeWidth/2;r.save(),r.textBaseline="middle",r.textAlign=e.textAlign,Zm(r,e)&&ip(r,{x:f,y:s},o,a),np(r,{x:f,y:s},o,{fonts:a,colors:d}),r.restore()}function Zm(r,n){if(n.textStrokeWidth>0)return r.lineJoin="round",r.miterLimit=2,r.lineWidth=n.textStrokeWidth,r.strokeStyle=n.textStrokeColor,!0}function Jm(r,n,e,t){let{radius:i,options:o}=n,a=o.pointStyle,l=o.rotation,d=(l||0)*yo;if(No(a)){r.save(),r.translate(e,t),r.rotate(d),r.drawImage(a,-a.width/2,-a.height/2,a.width,a.height),r.restore();return}Xm(i)||ep(r,{x:e,y:t,radius:i,rotation:l,style:a,rad:d})}function ep(r,{x:n,y:e,radius:t,rotation:i,style:o,rad:a}){let l,d,f,s;switch(r.beginPath(),o){default:r.arc(n,e,t,0,vo),r.closePath();break;case"triangle":r.moveTo(n+Math.sin(a)*t,e-Math.cos(a)*t),a+=bo,r.lineTo(n+Math.sin(a)*t,e-Math.cos(a)*t),a+=bo,r.lineTo(n+Math.sin(a)*t,e-Math.cos(a)*t),r.closePath();break;case"rectRounded":s=t*.516,f=t-s,l=Math.cos(a+dn)*f,d=Math.sin(a+dn)*f,r.arc(n-l,e-d,s,a-Gt,a-Xn),r.arc(n+d,e-l,s,a-Xn,a),r.arc(n+l,e+d,s,a,a+Xn),r.arc(n-d,e+l,s,a+Xn,a+Gt),r.closePath();break;case"rect":if(!i){f=Math.SQRT1_2*t,r.rect(n-f,e-f,2*f,2*f);break}a+=dn;case"rectRot":l=Math.cos(a)*t,d=Math.sin(a)*t,r.moveTo(n-l,e-d),r.lineTo(n+d,e-l),r.lineTo(n+l,e+d),r.lineTo(n-d,e+l),r.closePath();break;case"crossRot":a+=dn;case"cross":l=Math.cos(a)*t,d=Math.sin(a)*t,r.moveTo(n-l,e-d),r.lineTo(n+l,e+d),r.moveTo(n+d,e-l),r.lineTo(n-d,e+l);break;case"star":l=Math.cos(a)*t,d=Math.sin(a)*t,r.moveTo(n-l,e-d),r.lineTo(n+l,e+d),r.moveTo(n+d,e-l),r.lineTo(n-d,e+l),a+=dn,l=Math.cos(a)*t,d=Math.sin(a)*t,r.moveTo(n-l,e-d),r.lineTo(n+l,e+d),r.moveTo(n+d,e-l),r.lineTo(n-d,e+l);break;case"line":l=Math.cos(a)*t,d=Math.sin(a)*t,r.moveTo(n-l,e-d),r.lineTo(n+l,e+d);break;case"dash":r.moveTo(n,e),r.lineTo(n+Math.cos(a)*t,e+Math.sin(a)*t);break}r.fill()}function tp(r,n,e,t){r.save();let i=n.length,o=0,a=t;for(let l=0;l<i;l++){let d=e[Math.min(l,e.length-1)];r.font=d.string;let f=n[l];o=Math.max(o,r.measureText(f).width+t),a+=d.lineHeight}return r.restore(),{width:o,height:a}}function ip(r,{x:n,y:e},t,i){r.beginPath();let o=0;t.forEach(function(a,l){let d=i[Math.min(l,i.length-1)],f=d.lineHeight;r.font=d.string,r.strokeText(a,n,e+f/2+o),o+=f}),r.stroke()}function np(r,{x:n,y:e},t,{fonts:i,colors:o}){let a=0;t.forEach(function(l,d){let f=o[Math.min(d,o.length-1)],s=i[Math.min(d,i.length-1)],c=s.lineHeight;r.beginPath(),r.font=s.string,r.fillStyle=f,r.fillText(l,n,e+c/2+a),a+=c,r.fill()})}function rp(r,n){let e=_o(r)?r:n;return _o(e)?Ro(e,0,1):1}var Uc=["left","bottom","top","right"];function op(r,n){let{pointX:e,pointY:t,options:i}=n,o=i.callout,a=o&&o.display&&cp(n,o);if(!a||up(n,o,a))return;if(r.save(),r.beginPath(),!Di(r,o))return r.restore();let{separatorStart:d,separatorEnd:f}=ap(n,a),{sideStart:s,sideEnd:c}=lp(n,a,d);(o.margin>0||i.borderWidth===0)&&(r.moveTo(d.x,d.y),r.lineTo(f.x,f.y)),r.moveTo(s.x,s.y),r.lineTo(c.x,c.y);let m=vn({x:e,y:t},n.getCenterPoint(),ui(-n.rotation));r.lineTo(m.x,m.y),r.stroke(),r.restore()}function ap(r,n){let{x:e,y:t,x2:i,y2:o}=r,a=sp(r,n),l,d;return n==="left"||n==="right"?(l={x:e+a,y:t},d={x:l.x,y:o}):(l={x:e,y:t+a},d={x:i,y:l.y}),{separatorStart:l,separatorEnd:d}}function sp(r,n){let{width:e,height:t,options:i}=r,o=i.callout.margin+i.borderWidth/2;return n==="right"?e+o:n==="bottom"?t+o:-o}function lp(r,n,e){let{y:t,width:i,height:o,options:a}=r,l=a.callout.start,d=dp(n,a.callout),f,s;return n==="left"||n==="right"?(f={x:e.x,y:t+Xi(o,l)},s={x:f.x+d,y:f.y}):(f={x:e.x+Xi(i,l),y:e.y},s={x:f.x,y:f.y+d}),{sideStart:f,sideEnd:s}}function dp(r,n){let e=n.side;return r==="left"||r==="top"?-e:e}function cp(r,n){let e=n.position;return Uc.includes(e)?e:hp(r,n)}function hp(r,n){let{x:e,y:t,x2:i,y2:o,width:a,height:l,pointX:d,pointY:f,centerX:s,centerY:c,rotation:m}=r,y={x:s,y:c},k=n.start,x=Xi(a,k),D=Xi(l,k),F=[e,e+x,e+x,i],$=[t+D,o,t,o],se=[];for(let ke=0;ke<4;ke++){let Ye=vn({x:F[ke],y:$[ke]},y,ui(m));se.push({position:Uc[ke],distance:Er(Ye,{x:d,y:f})})}return se.sort((ke,Ye)=>ke.distance-Ye.distance)[0].position}function up(r,n,e){let{pointX:t,pointY:i}=r,o=n.margin,a=t,l=i;return e==="left"?a+=o:e==="right"?a-=o:e==="top"?l+=o:e==="bottom"&&(l-=o),r.inRange(a,l)}var hc={xScaleID:{min:"xMin",max:"xMax",start:"left",end:"right",startProp:"x",endProp:"x2"},yScaleID:{min:"yMin",max:"yMax",start:"bottom",end:"top",startProp:"y",endProp:"y2"}};function or(r,n,e){return n=typeof n=="number"?n:r.parse(n),go(n)?r.getPixelForValue(n):e}function pn(r,n,e){let t=n[e];if(t||e==="scaleID")return t;let i=e.charAt(0),o=Object.values(r).filter(a=>a.axis&&a.axis===i);return o.length?o[0].id:i}function Gc(r,n){if(r){let e=r.options.reverse,t=or(r,n.min,e?n.end:n.start),i=or(r,n.max,e?n.start:n.end);return{start:t,end:i}}}function jc(r,n){let{chartArea:e,scales:t}=r,i=t[pn(t,n,"xScaleID")],o=t[pn(t,n,"yScaleID")],a=e.width/2,l=e.height/2;return i&&(a=or(i,n.xValue,i.left+i.width/2)),o&&(l=or(o,n.yValue,o.top+o.height/2)),{x:a,y:l}}function ds(r,n){let e=r.scales,t=e[pn(e,n,"xScaleID")],i=e[pn(e,n,"yScaleID")];if(!t&&!i)return{};let{left:o,right:a}=t||r.chartArea,{top:l,bottom:d}=i||r.chartArea,f=uc(t,{min:n.xMin,max:n.xMax,start:o,end:a});o=f.start,a=f.end;let s=uc(i,{min:n.yMin,max:n.yMax,start:d,end:l});return l=s.start,d=s.end,{x:o,y:l,x2:a,y2:d,width:a-o,height:d-l,centerX:o+(a-o)/2,centerY:l+(d-l)/2}}function qc(r,n){if(!zc(n)){let e=ds(r,n),t=n.radius;(!t||isNaN(t))&&(t=Math.min(e.width,e.height)/2,n.radius=t);let i=t*2,o=e.centerX+n.xAdjust,a=e.centerY+n.yAdjust;return{x:o-t,y:a-t,x2:o+t,y2:a+t,centerX:o,centerY:a,width:i,height:i,radius:t}}return pp(r,n)}function mp(r,n){let{scales:e,chartArea:t}=r,i=e[n.scaleID],o={x:t.left,y:t.top,x2:t.right,y2:t.bottom};return i?fp(i,o,n):gp(e,o,n),o}function Yc(r,n){let e=ds(r,n);return e.initProperties=dr(r,e,n),e.elements=[{type:"label",optionScope:"label",properties:bp(r,e,n),initProperties:e.initProperties}],e}function pp(r,n){let e=jc(r,n),t=n.radius*2;return{x:e.x-n.radius+n.xAdjust,y:e.y-n.radius+n.yAdjust,x2:e.x+n.radius+n.xAdjust,y2:e.y+n.radius+n.yAdjust,centerX:e.x+n.xAdjust,centerY:e.y+n.yAdjust,radius:n.radius,width:t,height:t}}function uc(r,n){let e=Gc(r,n)||n;return{start:Math.min(e.start,e.end),end:Math.max(e.start,e.end)}}function fp(r,n,e){let t=or(r,e.value,NaN),i=or(r,e.endValue,t);r.isHorizontal()?(n.x=t,n.x2=i):(n.y=t,n.y2=i)}function gp(r,n,e){for(let t of Object.keys(hc)){let i=r[pn(r,e,t)];if(i){let{min:o,max:a,start:l,end:d,startProp:f,endProp:s}=hc[t],c=Gc(i,{min:e[o],max:e[a],start:i[l],end:i[d]});n[f]=c.start,n[s]=c.end}}}function vp({properties:r,options:n},e,t,i){let{x:o,x2:a,width:l}=r;return $c({start:o,end:a,size:l,borderWidth:n.borderWidth},{position:t.x,padding:{start:i.left,end:i.right},adjust:n.label.xAdjust,size:e.width})}function yp({properties:r,options:n},e,t,i){let{y:o,y2:a,height:l}=r;return $c({start:o,end:a,size:l,borderWidth:n.borderWidth},{position:t.y,padding:{start:i.top,end:i.bottom},adjust:n.label.yAdjust,size:e.height})}function $c(r,n){let{start:e,end:t,borderWidth:i}=r,{position:o,padding:{start:a,end:l},adjust:d}=n,f=t-i-e-a-l-n.size;return e+i/2+d+ss(f,o)}function bp(r,n,e){let t=e.label;t.backgroundColor="transparent",t.callout.display=!1;let i=ls(t.position),o=Kn(t.padding),a=Bo(r.ctx,t),l=vp({properties:n,options:e},a,i,o),d=yp({properties:n,options:e},a,i,o),f=a.width+o.width,s=a.height+o.height;return{x:l,y:d,x2:l+f,y2:d+s,width:f,height:s,centerX:l+f/2,centerY:d+s/2,rotation:t.rotation}}var Ja=["enter","leave"],cs=Ja.concat("click");function _p(r,n,e){n.listened=Lc(e,cs,n.listeners),n.moveListened=!1,Ja.forEach(t=>{Gi(e[t])&&(n.moveListened=!0)}),(!n.listened||!n.moveListened)&&n.annotations.forEach(t=>{!n.listened&&Gi(t.click)&&(n.listened=!0),n.moveListened||Ja.forEach(i=>{Gi(t[i])&&(n.listened=!0,n.moveListened=!0)})})}function wp(r,n,e){if(r.listened)switch(n.type){case"mousemove":case"mouseout":return kp(r,n,e);case"click":return Sp(r,n,e)}}function kp(r,n,e){if(!r.moveListened)return;let t;n.type==="mousemove"?t=as(r.visibleElements,n,e.interaction):t=[];let i=r.hovered;r.hovered=t;let o={state:r,event:n},a=mc(o,"leave",i,t);return mc(o,"enter",t,i)||a}function mc({state:r,event:n},e,t,i){let o;for(let a of t)i.indexOf(a)<0&&(o=Qc(a.options[e]||r.listeners[e],a,n)||o);return o}function Sp(r,n,e){let t=r.listeners,i=as(r.visibleElements,n,e.interaction),o;for(let a of i)o=Qc(a.options.click||t.click,a,n)||o;return o}function Qc(r,n,e){return Tr(r,[n.$context,e])===!0}var Io=["afterDraw","beforeDraw"];function Cp(r,n,e){let t=n.visibleElements;n.hooked=Lc(e,Io,n.hooks),n.hooked||t.forEach(i=>{n.hooked||Io.forEach(o=>{Gi(i.options[o])&&(n.hooked=!0)})})}function pc(r,n,e){if(r.hooked){let t=n.options[e]||r.hooks[e];return Tr(t,[n.$context])}}function xp(r,n,e){let t=Pp(r.scales,n,e),i=fc(n,t,"min","suggestedMin");i=fc(n,t,"max","suggestedMax")||i,i&&Gi(n.handleTickRangeOptions)&&n.handleTickRangeOptions()}function Tp(r,n){for(let e of r)Dp(e,n)}function fc(r,n,e,t){if(go(n[e])&&!Ep(r.options,e,t)){let i=r[e]!==n[e];return r[e]=n[e],i}}function Ep(r,n,e){return hi(r[n])||hi(r[e])}function Dp(r,n){for(let e of["scaleID","xScaleID","yScaleID"]){let t=pn(n,r,e);t&&!n[t]&&Ap(r,e)&&console.warn(`No scale found with id '${t}' for annotation '${r.id}'`)}}function Ap(r,n){if(n==="scaleID")return!0;let e=n.charAt(0);for(let t of["Min","Max","Value"])if(hi(r[e+t]))return!0;return!1}function Pp(r,n,e){let t=n.axis,i=n.id,o=t+"ScaleID",a={min:ln(n.min,Number.NEGATIVE_INFINITY),max:ln(n.max,Number.POSITIVE_INFINITY)};for(let l of e)l.scaleID===i?gc(l,n,["value","endValue"],a):pn(r,l,o)===i&&gc(l,n,[t+"Min",t+"Max",t+"Value"],a);return a}function gc(r,n,e,t){for(let i of e){let o=r[i];if(hi(o)){let a=n.parse(o);t.min=Math.min(t.min,a),t.max=Math.max(t.max,a)}}}var Ki=class extends ji{inRange(n,e,t,i){let{x:o,y:a}=vn({x:n,y:e},this.getCenterPoint(i),ui(-this.options.rotation));return Pc({x:o,y:a},this.getProps(["x","y","x2","y2"],i),t,this.options)}getCenterPoint(n){return yn(this,n)}draw(n){n.save(),Wo(n,this.getCenterPoint(),this.options.rotation),Fc(n,this,this.options),n.restore()}get label(){return this.elements&&this.elements[0]}resolveElementProperties(n,e){return Yc(n,e)}};Ki.id="boxAnnotation";Ki.defaults={adjustScaleRange:!0,backgroundShadowColor:"transparent",borderCapStyle:"butt",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderRadius:0,borderShadowColor:"transparent",borderWidth:1,display:!0,init:void 0,hitTolerance:0,label:{backgroundColor:"transparent",borderWidth:0,callout:{display:!1},color:"black",content:null,display:!1,drawTime:void 0,font:{family:void 0,lineHeight:void 0,size:void 0,style:void 0,weight:"bold"},height:void 0,hitTolerance:void 0,opacity:void 0,padding:6,position:"center",rotation:void 0,textAlign:"start",textStrokeColor:void 0,textStrokeWidth:0,width:void 0,xAdjust:0,yAdjust:0,z:void 0},rotation:0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,xMax:void 0,xMin:void 0,xScaleID:void 0,yMax:void 0,yMin:void 0,yScaleID:void 0,z:0};Ki.defaultRoutes={borderColor:"color",backgroundColor:"color"};Ki.descriptors={label:{_fallback:!0}};var ar=class extends ji{inRange(n,e,t,i){return Mc({x:n,y:e},{rect:this.getProps(["x","y","x2","y2"],i),center:this.getCenterPoint(i)},t,{rotation:this.rotation,borderWidth:0,hitTolerance:this.options.hitTolerance})}getCenterPoint(n){return yn(this,n)}draw(n){let e=this.options;!e.display||!e.content||(Wp(n,this),n.save(),Wo(n,this.getCenterPoint(),this.rotation),Hc(n,this,e,this._fitRatio),n.restore())}resolveElementProperties(n,e){let t=Mp(n,e);if(!t)return{};let{controllerMeta:i,point:o,radius:a}=Ip(n,e,t),l=Bo(n.ctx,e),d=Rp(l,a);Wc(e,d)&&(l={width:l.width*d,height:l.height*d});let{position:f,xAdjust:s,yAdjust:c}=e,m=Nc(o,l,{borderWidth:0,position:f,xAdjust:s,yAdjust:c});return rt(K(K({initProperties:dr(n,m,e)},m),i),{rotation:e.rotation,_fitRatio:d})}};ar.id="doughnutLabelAnnotation";ar.defaults={autoFit:!0,autoHide:!0,backgroundColor:"transparent",backgroundShadowColor:"transparent",borderColor:"transparent",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderShadowColor:"transparent",borderWidth:0,color:"black",content:null,display:!0,font:{family:void 0,lineHeight:void 0,size:void 0,style:void 0,weight:void 0},height:void 0,hitTolerance:0,init:void 0,opacity:void 0,position:"center",rotation:0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,spacing:1,textAlign:"center",textStrokeColor:void 0,textStrokeWidth:0,width:void 0,xAdjust:0,yAdjust:0};ar.defaultRoutes={};function Mp(r,n){return r.getSortedVisibleDatasetMetas().reduce(function(e,t){let i=t.controller;return i instanceof Cd&&Op(r,n,t.data)&&(!e||i.innerRadius<e.controller.innerRadius)&&i.options.circumference>=90?t:e},void 0)}function Op(r,n,e){if(!n.autoHide)return!0;for(let t=0;t<e.length;t++)if(!e[t].hidden&&r.getDataVisibility(t))return!0}function Ip({chartArea:r},n,e){let{left:t,top:i,right:o,bottom:a}=r,{innerRadius:l,offsetX:d,offsetY:f}=e.controller,s=(t+o)/2+d,c=(i+a)/2+f,m={left:Math.max(s-l,t),right:Math.min(s+l,o),top:Math.max(c-l,i),bottom:Math.min(c+l,a)},y={x:(m.left+m.right)/2,y:(m.top+m.bottom)/2},k=n.spacing+n.borderWidth/2,x=l-k,D=y.y>c,F=D?i+k:a-k,$=Np(F,s,c,x);return{controllerMeta:K({_centerX:s,_centerY:c,_radius:x,_counterclockwise:D},$),point:y,radius:Math.min(l,Math.min(m.right-m.left,m.bottom-m.top)/2)}}function Rp({width:r,height:n},e){let t=Math.sqrt(Math.pow(r,2)+Math.pow(n,2));return e*2/t}function Np(r,n,e,t){let i=Math.pow(e-r,2),o=Math.pow(t,2),a=n*-2,l=Math.pow(n,2)+i-o,d=Math.pow(a,2)-4*l;if(d<=0)return{_startAngle:0,_endAngle:vo};let f=(-a-Math.sqrt(d))/2,s=(-a+Math.sqrt(d))/2;return{_startAngle:wo({x:n,y:e},{x:f,y:r}).angle,_endAngle:wo({x:n,y:e},{x:s,y:r}).angle}}function Wp(r,n){let{_centerX:e,_centerY:t,_radius:i,_startAngle:o,_endAngle:a,_counterclockwise:l,options:d}=n;r.save();let f=Di(r,d);r.fillStyle=d.backgroundColor,r.beginPath(),r.arc(e,t,i,o,a,l),r.closePath(),r.fill(),f&&r.stroke(),r.restore()}var fn=class extends ji{inRange(n,e,t,i){return Mc({x:n,y:e},{rect:this.getProps(["x","y","x2","y2"],i),center:this.getCenterPoint(i)},t,{rotation:this.rotation,borderWidth:this.options.borderWidth,hitTolerance:this.options.hitTolerance})}getCenterPoint(n){return yn(this,n)}draw(n){let e=this.options,t=!hi(this._visible)||this._visible;!e.display||!e.content||!t||(n.save(),Wo(n,this.getCenterPoint(),this.rotation),op(n,this),Fc(n,this,e),Hc(n,Bp(this),e),n.restore())}resolveElementProperties(n,e){let t;if(zc(e))t=jc(n,e);else{let{centerX:l,centerY:d}=ds(n,e);t={x:l,y:d}}let i=Kn(e.padding),o=Bo(n.ctx,e),a=Nc(t,o,e,i);return rt(K({initProperties:dr(n,a,e),pointX:t.x,pointY:t.y},a),{rotation:e.rotation})}};fn.id="labelAnnotation";fn.defaults={adjustScaleRange:!0,backgroundColor:"transparent",backgroundShadowColor:"transparent",borderCapStyle:"butt",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderRadius:0,borderShadowColor:"transparent",borderWidth:0,callout:{borderCapStyle:"butt",borderColor:void 0,borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderWidth:1,display:!1,margin:5,position:"auto",side:5,start:"50%"},color:"black",content:null,display:!0,font:{family:void 0,lineHeight:void 0,size:void 0,style:void 0,weight:void 0},height:void 0,hitTolerance:0,init:void 0,opacity:void 0,padding:6,position:"center",rotation:0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,textAlign:"center",textStrokeColor:void 0,textStrokeWidth:0,width:void 0,xAdjust:0,xMax:void 0,xMin:void 0,xScaleID:void 0,xValue:void 0,yAdjust:0,yMax:void 0,yMin:void 0,yScaleID:void 0,yValue:void 0,z:0};fn.defaultRoutes={borderColor:"color"};function Bp({x:r,y:n,width:e,height:t,options:i}){let o=i.borderWidth/2,a=Kn(i.padding);return{x:r+a.left+o,y:n+a.top+o,width:e-a.left-a.right-i.borderWidth,height:t-a.top-a.bottom-i.borderWidth}}var hs=(r,n,e)=>({x:r.x+e*(n.x-r.x),y:r.y+e*(n.y-r.y)}),es=(r,n,e)=>hs(n,e,Math.abs((r-n.y)/(e.y-n.y))).x,vc=(r,n,e)=>hs(n,e,Math.abs((r-n.x)/(e.x-n.x))).y,Ir=r=>r*r,zp=(r,n,{x:e,y:t,x2:i,y2:o},a)=>a==="y"?{start:Math.min(t,o),end:Math.max(t,o),value:n}:{start:Math.min(e,i),end:Math.max(e,i),value:r},yc=(r,n,e,t)=>(1-t)*(1-t)*r+2*(1-t)*t*n+t*t*e,ts=(r,n,e,t)=>({x:yc(r.x,n.x,e.x,t),y:yc(r.y,n.y,e.y,t)}),bc=(r,n,e,t)=>2*(1-t)*(n-r)+2*t*(e-n),_c=(r,n,e,t)=>-Math.atan2(bc(r.x,n.x,e.x,t),bc(r.y,n.y,e.y,t))+.5*Gt,zo=(()=>{class r extends ji{inRange(e,t,i,o){let a=(this.options.borderWidth+this.options.hitTolerance)/2;if(i!=="x"&&i!=="y"){let l={mouseX:e,mouseY:t},{path:d,ctx:f}=this;if(d){Di(f,this.options),f.lineWidth+=this.options.hitTolerance;let{chart:c}=this.$context,m=e*c.currentDevicePixelRatio,y=t*c.currentDevicePixelRatio,k=f.isPointInStroke(d,m,y)||is(this,l,o);return f.restore(),k}let s=Ir(a);return Hp(this,l,s,o)||is(this,l,o)}return Lp(this,{mouseX:e,mouseY:t},i,{hitSize:a,useFinalPosition:o})}getCenterPoint(e){return yn(this,e)}draw(e){let{x:t,y:i,x2:o,y2:a,cp:l,options:d}=this;if(e.save(),!Di(e,d))return e.restore();cr(e,d);let f=Math.sqrt(Math.pow(o-t,2)+Math.pow(a-i,2));if(d.curve&&l)return Xp(e,this,l,f),e.restore();let{startOpts:s,endOpts:c,startAdjust:m,endAdjust:y}=Xc(this),k=Math.atan2(a-i,o-t);e.translate(t,i),e.rotate(k),e.beginPath(),e.moveTo(0+m,0),e.lineTo(f-y,0),e.shadowColor=d.borderShadowColor,e.stroke(),ns(e,0,m,s),ns(e,f,-y,c),e.restore()}get label(){return this.elements&&this.elements[0]}resolveElementProperties(e,t){let i=mp(e,t),{x:o,y:a,x2:l,y2:d}=i,f=Vp(i,e.chartArea),s=f?Fp({x:o,y:a},{x:l,y:d},e.chartArea):{x:o,y:a,x2:l,y2:d,width:Math.abs(l-o),height:Math.abs(d-a)};if(s.centerX=(l+o)/2,s.centerY=(d+a)/2,s.initProperties=dr(e,s,t),t.curve){let m={x:s.x,y:s.y},y={x:s.x2,y:s.y2};s.cp=Qp(s,t,Er(m,y))}let c=Up(e,s,t.label);return c._visible=f,s.elements=[{type:"label",optionScope:"label",properties:c,initProperties:s.initProperties}],s}}return r.id="lineAnnotation",r})(),wc={backgroundColor:void 0,backgroundShadowColor:void 0,borderColor:void 0,borderDash:void 0,borderDashOffset:void 0,borderShadowColor:void 0,borderWidth:void 0,display:void 0,fill:void 0,length:void 0,shadowBlur:void 0,shadowOffsetX:void 0,shadowOffsetY:void 0,width:void 0};zo.defaults={adjustScaleRange:!0,arrowHeads:{display:!1,end:Object.assign({},wc),fill:!1,length:12,start:Object.assign({},wc),width:6},borderDash:[],borderDashOffset:0,borderShadowColor:"transparent",borderWidth:2,curve:!1,controlPoint:{y:"-50%"},display:!0,endValue:void 0,init:void 0,hitTolerance:0,label:{backgroundColor:"rgba(0,0,0,0.8)",backgroundShadowColor:"transparent",borderCapStyle:"butt",borderColor:"black",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderRadius:6,borderShadowColor:"transparent",borderWidth:0,callout:Object.assign({},fn.defaults.callout),color:"#fff",content:null,display:!1,drawTime:void 0,font:{family:void 0,lineHeight:void 0,size:void 0,style:void 0,weight:"bold"},height:void 0,hitTolerance:void 0,opacity:void 0,padding:6,position:"center",rotation:0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,textAlign:"center",textStrokeColor:void 0,textStrokeWidth:0,width:void 0,xAdjust:0,yAdjust:0,z:void 0},scaleID:void 0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,value:void 0,xMax:void 0,xMin:void 0,xScaleID:void 0,yMax:void 0,yMin:void 0,yScaleID:void 0,z:0};zo.descriptors={arrowHeads:{start:{_fallback:!0},end:{_fallback:!0},_fallback:!0}};zo.defaultRoutes={borderColor:"color"};function Lp(r,{mouseX:n,mouseY:e},t,{hitSize:i,useFinalPosition:o}){let a=zp(n,e,r.getProps(["x","y","x2","y2"],o),t);return Ac(a,i)||is(r,{mouseX:n,mouseY:e},o,t)}function Vp({x:r,y:n,x2:e,y2:t},{top:i,right:o,bottom:a,left:l}){return!(r<l&&e<l||r>o&&e>o||n<i&&t<i||n>a&&t>a)}function kc({x:r,y:n},e,{top:t,right:i,bottom:o,left:a}){return r<a&&(n=vc(a,{x:r,y:n},e),r=a),r>i&&(n=vc(i,{x:r,y:n},e),r=i),n<t&&(r=es(t,{x:r,y:n},e),n=t),n>o&&(r=es(o,{x:r,y:n},e),n=o),{x:r,y:n}}function Fp(r,n,e){let{x:t,y:i}=kc(r,n,e),{x:o,y:a}=kc(n,r,e);return{x:t,y:i,x2:o,y2:a,width:Math.abs(o-t),height:Math.abs(a-i)}}function Hp(r,{mouseX:n,mouseY:e},t=mn,i){let{x:o,y:a,x2:l,y2:d}=r.getProps(["x","y","x2","y2"],i),f=l-o,s=d-a,c=Ir(f)+Ir(s),m=c===0?-1:((n-o)*f+(e-a)*s)/c,y,k;return m<0?(y=o,k=a):m>1?(y=l,k=d):(y=o+m*f,k=a+m*s),Ir(n-y)+Ir(e-k)<=t}function is(r,{mouseX:n,mouseY:e},t,i){let o=r.label;return o.options.display&&o.inRange(n,e,i,t)}function Up(r,n,e){let t=e.borderWidth,i=Kn(e.padding),o=Bo(r.ctx,e),a=o.width+i.width+t,l=o.height+i.height+t;return jp(n,e,{width:a,height:l,padding:i},r.chartArea)}function Gp(r){let{x:n,y:e,x2:t,y2:i}=r,o=Math.atan2(i-e,t-n);return o>Gt/2?o-Gt:o<Gt/-2?o+Gt:o}function jp(r,n,e,t){let{width:i,height:o,padding:a}=e,{xAdjust:l,yAdjust:d}=n,f={x:r.x,y:r.y},s={x:r.x2,y:r.y2},c=n.rotation==="auto"?Gp(r):ui(n.rotation),m=qp(i,o,c),y=Yp(r,n,{labelSize:m,padding:a},t),k=r.cp?ts(f,r.cp,s,y):hs(f,s,y),x={size:m.w,min:t.left,max:t.right,padding:a.left},D={size:m.h,min:t.top,max:t.bottom,padding:a.top},F=Cc(k.x,x)+l,$=Cc(k.y,D)+d;return{x:F-i/2,y:$-o/2,x2:F+i/2,y2:$+o/2,centerX:F,centerY:$,pointX:k.x,pointY:k.y,width:i,height:o,rotation:Fa(c)}}function qp(r,n,e){let t=Math.cos(e),i=Math.sin(e);return{w:Math.abs(r*t)+Math.abs(n*i),h:Math.abs(r*i)+Math.abs(n*t)}}function Yp(r,n,e,t){let i,o=$p(r,t);return n.position==="start"?i=Sc({w:r.x2-r.x,h:r.y2-r.y},e,n,o):n.position==="end"?i=1-Sc({w:r.x-r.x2,h:r.y-r.y2},e,n,o):i=ss(1,n.position),i}function Sc(r,n,e,t){let{labelSize:i,padding:o}=n,a=r.w*t.dx,l=r.h*t.dy,d=a>0&&(i.w/2+o.left-t.x)/a,f=l>0&&(i.h/2+o.top-t.y)/l;return Ro(Math.max(d,f),0,.25)}function $p(r,n){let{x:e,x2:t,y:i,y2:o}=r,a=Math.min(i,o)-n.top,l=Math.min(e,t)-n.left,d=n.bottom-Math.max(i,o),f=n.right-Math.max(e,t);return{x:Math.min(l,f),y:Math.min(a,d),dx:l<=f?1:-1,dy:a<=d?1:-1}}function Cc(r,n){let{size:e,min:t,max:i,padding:o}=n,a=e/2;return e>i-t?(i+t)/2:(t>=r-o-a&&(r=t+o+a),i<=r+o+a&&(r=i-o-a),r)}function Xc(r){let n=r.options,e=n.arrowHeads&&n.arrowHeads.start,t=n.arrowHeads&&n.arrowHeads.end;return{startOpts:e,endOpts:t,startAdjust:xc(r,e),endAdjust:xc(r,t)}}function xc(r,n){if(!n||!n.display)return 0;let{length:e,width:t}=n,i=r.options.borderWidth/2,o={x:e,y:t+i};return Math.abs(es(0,o,{x:0,y:i}))}function ns(r,n,e,t){if(!t||!t.display)return;let{length:i,width:o,fill:a,backgroundColor:l,borderColor:d}=t,f=Math.abs(n-i)+e;r.beginPath(),cr(r,t),Di(r,t),r.moveTo(f,-o),r.lineTo(n+e,0),r.lineTo(f,o),a===!0?(r.fillStyle=l||d,r.closePath(),r.fill(),r.shadowColor="transparent"):r.shadowColor=t.borderShadowColor,r.stroke()}function Qp(r,n,e){let{x:t,y:i,x2:o,y2:a,centerX:l,centerY:d}=r,f=Math.atan2(a-i,o-t),s=ls(n.controlPoint,0),c={x:l+Xi(e,s.x,!1),y:d+Xi(e,s.y,!1)};return vn(c,{x:l,y:d},f)}function Tc(r,{x:n,y:e},{angle:t,adjust:i},o){!o||!o.display||(r.save(),r.translate(n,e),r.rotate(t),ns(r,0,-i,o),r.restore())}function Xp(r,n,e,t){let{x:i,y:o,x2:a,y2:l,options:d}=n,{startOpts:f,endOpts:s,startAdjust:c,endAdjust:m}=Xc(n),y={x:i,y:o},k={x:a,y:l},x=_c(y,e,k,0),D=_c(y,e,k,1)-Gt,F=ts(y,e,k,c/t),$=ts(y,e,k,1-m/t),se=new Path2D;r.beginPath(),se.moveTo(F.x,F.y),se.quadraticCurveTo(e.x,e.y,$.x,$.y),r.shadowColor=d.borderShadowColor,r.stroke(se),n.path=se,n.ctx=r,Tc(r,F,{angle:x,adjust:c},f),Tc(r,$,{angle:D,adjust:m},s)}var gn=class extends ji{inRange(n,e,t,i){let o=this.options.rotation,a=(this.options.borderWidth+this.options.hitTolerance)/2;if(t!=="x"&&t!=="y")return Kp({x:n,y:e},this.getProps(["width","height","centerX","centerY"],i),o,a);let{x:l,y:d,x2:f,y2:s}=this.getProps(["x","y","x2","y2"],i),c=t==="y"?{start:d,end:s}:{start:l,end:f},m=vn({x:n,y:e},this.getCenterPoint(i),ui(-o));return m[t]>=c.start-a-mn&&m[t]<=c.end+a+mn}getCenterPoint(n){return yn(this,n)}draw(n){let{width:e,height:t,centerX:i,centerY:o,options:a}=this;n.save(),Wo(n,this.getCenterPoint(),a.rotation),cr(n,this.options),n.beginPath(),n.fillStyle=a.backgroundColor;let l=Di(n,a);n.ellipse(i,o,t/2,e/2,Gt/2,0,2*Gt),n.fill(),l&&(n.shadowColor=a.borderShadowColor,n.stroke()),n.restore()}get label(){return this.elements&&this.elements[0]}resolveElementProperties(n,e){return Yc(n,e)}};gn.id="ellipseAnnotation";gn.defaults={adjustScaleRange:!0,backgroundShadowColor:"transparent",borderDash:[],borderDashOffset:0,borderShadowColor:"transparent",borderWidth:1,display:!0,hitTolerance:0,init:void 0,label:Object.assign({},Ki.defaults.label),rotation:0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,xMax:void 0,xMin:void 0,xScaleID:void 0,yMax:void 0,yMin:void 0,yScaleID:void 0,z:0};gn.defaultRoutes={borderColor:"color",backgroundColor:"color"};gn.descriptors={label:{_fallback:!0}};function Kp(r,n,e,t){let{width:i,height:o,centerX:a,centerY:l}=n,d=i/2,f=o/2;if(d<=0||f<=0)return!1;let s=ui(e||0),c=Math.cos(s),m=Math.sin(s),y=Math.pow(c*(r.x-a)+m*(r.y-l),2),k=Math.pow(m*(r.x-a)-c*(r.y-l),2);return y/Math.pow(d+t,2)+k/Math.pow(f+t,2)<=1.0001}var sr=class extends ji{inRange(n,e,t,i){let{x:o,y:a,x2:l,y2:d,width:f}=this.getProps(["x","y","x2","y2","width"],i),s=(this.options.borderWidth+this.options.hitTolerance)/2;return t!=="x"&&t!=="y"?jm({x:n,y:e},this.getCenterPoint(i),f/2,s):Ac(t==="y"?{start:a,end:d,value:e}:{start:o,end:l,value:n},s)}getCenterPoint(n){return yn(this,n)}draw(n){let e=this.options,t=e.borderWidth;if(e.radius<.1)return;n.save(),n.fillStyle=e.backgroundColor,cr(n,e);let i=Di(n,e);Jm(n,this,this.centerX,this.centerY),i&&!No(e.pointStyle)&&(n.shadowColor=e.borderShadowColor,n.stroke()),n.restore(),e.borderWidth=t}resolveElementProperties(n,e){let t=qc(n,e);return t.initProperties=dr(n,t,e),t}};sr.id="pointAnnotation";sr.defaults={adjustScaleRange:!0,backgroundShadowColor:"transparent",borderDash:[],borderDashOffset:0,borderShadowColor:"transparent",borderWidth:1,display:!0,hitTolerance:0,init:void 0,pointStyle:"circle",radius:10,rotation:0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,xAdjust:0,xMax:void 0,xMin:void 0,xScaleID:void 0,xValue:void 0,yAdjust:0,yMax:void 0,yMin:void 0,yScaleID:void 0,yValue:void 0,z:0};sr.defaultRoutes={borderColor:"color",backgroundColor:"color"};var lr=class extends ji{inRange(n,e,t,i){if(t!=="x"&&t!=="y")return this.options.radius>=.1&&this.elements.length>1&&Jp(this.elements,n,e,i);let o=vn({x:n,y:e},this.getCenterPoint(i),ui(-this.options.rotation)),a=this.elements.map(f=>t==="y"?f.bY:f.bX),l=Math.min(...a),d=Math.max(...a);return o[t]>=l&&o[t]<=d}getCenterPoint(n){return yn(this,n)}draw(n){let{elements:e,options:t}=this;n.save(),n.beginPath(),n.fillStyle=t.backgroundColor,cr(n,t);let i=Di(n,t),o=!0;for(let a of e)o?(n.moveTo(a.x,a.y),o=!1):n.lineTo(a.x,a.y);n.closePath(),n.fill(),i&&(n.shadowColor=t.borderShadowColor,n.stroke()),n.restore()}resolveElementProperties(n,e){let t=qc(n,e),{sides:i,rotation:o}=e,a=[],l=2*Gt/i,d=o*yo;for(let f=0;f<i;f++,d+=l){let s=Zp(t,e,d);s.initProperties=dr(n,t,e),a.push(s)}return t.elements=a,t}};lr.id="polygonAnnotation";lr.defaults={adjustScaleRange:!0,backgroundShadowColor:"transparent",borderCapStyle:"butt",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderShadowColor:"transparent",borderWidth:1,display:!0,hitTolerance:0,init:void 0,point:{radius:0},radius:10,rotation:0,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,sides:3,xAdjust:0,xMax:void 0,xMin:void 0,xScaleID:void 0,xValue:void 0,yAdjust:0,yMax:void 0,yMin:void 0,yScaleID:void 0,yValue:void 0,z:0};lr.defaultRoutes={borderColor:"color",backgroundColor:"color"};function Zp({centerX:r,centerY:n},{radius:e,borderWidth:t,hitTolerance:i},o){let a=(t+i)/2,l=Math.sin(o),d=Math.cos(o),f={x:r+l*e,y:n-d*e};return{type:"point",optionScope:"point",properties:{x:f.x,y:f.y,centerX:f.x,centerY:f.y,bX:r+l*(e+a),bY:n-d*(e+a)}}}function Jp(r,n,e,t){let i=!1,o=r[r.length-1].getProps(["bX","bY"],t);for(let a of r){let l=a.getProps(["bX","bY"],t);l.bY>e!=o.bY>e&&n<(o.bX-l.bX)*(e-l.bY)/(o.bY-l.bY)+l.bX&&(i=!i),o=l}return i}var Qi={box:Ki,doughnutLabel:ar,ellipse:gn,label:fn,line:zo,point:sr,polygon:lr};Object.keys(Qi).forEach(r=>{kd.describe(`elements.${Qi[r].id}`,{_fallback:"plugins.annotation.common"})});var ef={update:Object.assign},tf=cs.concat(Io),Ec=(r,n)=>Ui(n)?os(r,n):r,rs=r=>r==="color"||r==="font";function us(r="line"){return Qi[r]?r:(console.warn(`Unknown annotation type: '${r}', defaulting to 'line'`),"line")}function nf(r,n,e,t){let i=of(r,e.animations,t),o=n.annotations,a=lf(n.elements,o);for(let l=0;l<o.length;l++){let d=o[l],f=Kc(a,l,d.type),s=d.setContext(sf(r,f,a,d)),c=f.resolveElementProperties(r,s);c.skip=rf(c),"elements"in c&&(af(f,c.elements,s,i),delete c.elements),hi(f.x)||Object.assign(f,c),Object.assign(f,c.initProperties),c.options=Zc(s),i.update(f,c)}}function rf(r){return isNaN(r.x)||isNaN(r.y)}function of(r,n,e){return e==="reset"||e==="none"||e==="resize"?ef:new Sd(r,n)}function af(r,n,e,t){let i=r.elements||(r.elements=[]);i.length=n.length;for(let o=0;o<n.length;o++){let a=n[o],l=a.properties,d=Kc(i,o,a.type,a.initProperties),f=e[a.optionScope].override(a);l.options=Zc(f),t.update(d,l)}}function Kc(r,n,e,t){let i=Qi[us(e)],o=r[n];return(!o||!(o instanceof i))&&(o=r[n]=new i,Object.assign(o,t)),o}function Zc(r){let n=Qi[us(r.type)],e={};e.id=r.id,e.type=r.type,e.drawTime=r.drawTime,Object.assign(e,os(r,n.defaults),os(r,n.defaultRoutes));for(let t of tf)e[t]=r[t];return e}function os(r,n){let e={};for(let t of Object.keys(n)){let i=n[t],o=r[t];rs(t)&&Hi(o)?e[t]=o.map(a=>Ec(a,i)):e[t]=Ec(o,i)}return e}function sf(r,n,e,t){return n.$context||(n.$context=Object.assign(Object.create(r.getContext()),{element:n,get elements(){return e.filter(i=>i&&i.options)},id:t.id,type:"annotation"}))}function lf(r,n){let e=n.length,t=r.length;if(t<e){let i=e-t;r.splice(t,0,...new Array(i))}else t>e&&r.splice(e,t-e);return r}var df="3.1.0",$i=new Map,Dc=r=>r.type!=="doughnutLabel",cf=cs.concat(Io),Jc={id:"annotation",version:df,beforeRegister(){qm("chart.js","4.0",cn.version)},afterRegister(){cn.register(Qi)},afterUnregister(){cn.unregister(Qi)},beforeInit(r){$i.set(r,{annotations:[],elements:[],visibleElements:[],listeners:{},listened:!1,moveListened:!1,hooks:{},hooked:!1,hovered:[]})},beforeUpdate(r,n,e){let t=$i.get(r),i=t.annotations=[],o=e.annotations;Ui(o)?Object.keys(o).forEach(a=>{let l=o[a];Ui(l)&&(l.id=a,i.push(l))}):Hi(o)&&i.push(...o),Tp(i.filter(Dc),r.scales)},afterDataLimits(r,n){let e=$i.get(r);xp(r,n.scale,e.annotations.filter(Dc).filter(t=>t.display&&t.adjustScaleRange))},afterUpdate(r,n,e){let t=$i.get(r);_p(r,t,e),nf(r,t,e,n.mode),t.visibleElements=t.elements.filter(i=>!i.skip&&i.options.display),Cp(r,t,e)},beforeDatasetsDraw(r,n,e){Or(r,"beforeDatasetsDraw",e.clip)},afterDatasetsDraw(r,n,e){Or(r,"afterDatasetsDraw",e.clip)},beforeDatasetDraw(r,n,e){Or(r,n.index,e.clip)},beforeDraw(r,n,e){Or(r,"beforeDraw",e.clip)},afterDraw(r,n,e){Or(r,"afterDraw",e.clip)},beforeEvent(r,n,e){let t=$i.get(r);wp(t,n.event,e)&&(n.changed=!0)},afterDestroy(r){$i.delete(r)},getAnnotations(r){let n=$i.get(r);return n?n.elements:[]},_getAnnotationElementsAtEventForMode(r,n,e){return as(r,n,e)},defaults:{animations:{numbers:{properties:["x","y","x2","y2","width","height","centerX","centerY","pointX","pointY","radius"],type:"number"},colors:{properties:["backgroundColor","borderColor"],type:"color"}},clip:!0,interaction:{mode:void 0,axis:void 0,intersect:void 0},common:{drawTime:"afterDatasetsDraw",init:!1,label:{}}},descriptors:{_indexable:!1,_scriptable:r=>!cf.includes(r)&&r!=="init",annotations:{_allKeys:!1,_fallback:(r,n)=>`elements.${Qi[us(n.type)].id}`},interaction:{_fallback:!0},common:{label:{_indexable:rs,_fallback:!0},_indexable:rs}},additionalOptionScopes:[""]};function Or(r,n,e){let{ctx:t,chartArea:i}=r,o=$i.get(r);e&&Ha(t,i);let a=hf(o.visibleElements,n).sort((l,d)=>l.element.options.z-d.element.options.z);for(let l of a)uf(t,i,o,l);e&&Ua(t)}function hf(r,n){let e=[];for(let t of r)if(t.options.drawTime===n&&e.push({element:t,main:!0}),t.elements&&t.elements.length)for(let i of t.elements)i.options.display&&i.options.drawTime===n&&e.push({element:i});return e}function uf(r,n,e,t){let i=t.element;t.main?(pc(e,i,"beforeDraw"),i.draw(r,n),pc(e,i,"afterDraw")):i.draw(r,n)}var mf=["widgetDataChart"];cn.register(Jc,Od,Md,xd,Ed,Td,Dd,Ad,Pd);var eh=(()=>{class r extends Re{dsService=M(ho);widgetDataChart=le("widgetDataChart",{read:Me});lineChartData={datasets:[]};lineChartOptions={parsing:!1,datasets:{line:{pointRadius:0,pointHoverRadius:0,tension:.4}},animations:{tension:{easing:"easeInOutCubic"}}};lineChartType="line";chart;dsServiceSub=null;datasetConfig=null;dataSourceInfo=null;constructor(){super(),this.defaultConfig={displayName:"Chart Label",filterSelfPaths:!0,convertUnitTo:"unitless",datasetUUID:null,invertData:!1,datasetAverageArray:"sma",showAverageData:!0,trackAgainstAverage:!1,showDatasetMinimumValueLine:!1,showDatasetMaximumValueLine:!1,showDatasetAverageValueLine:!0,showDatasetAngleAverageValueLine:!1,showLabel:!1,showTimeScale:!1,startScaleAtZero:!1,verticalGraph:!1,showYScale:!1,yScaleSuggestedMin:null,yScaleSuggestedMax:null,enableMinMaxScaleLimit:!1,yScaleMin:null,yScaleMax:null,numDecimal:1,color:"contrast"},Pe(()=>{this.theme()&&this.datasetConfig&&(this.setChartOptions(),this.chart.config.options=this.lineChartOptions)})}ngOnInit(){this.validateConfig()}ngAfterViewInit(){this.startWidget()}startWidget(){this.datasetConfig=this.dsService.getDatasetConfig(this.widgetProperties.config.datasetUUID),this.dataSourceInfo=this.dsService.getDataSourceInfo(this.widgetProperties.config.datasetUUID),this.datasetConfig&&(this.setChartOptions(),this.chart?this.chart.update():this.chart=new cn(this.widgetDataChart().nativeElement.getContext("2d"),{type:this.lineChartType,data:this.lineChartData,options:this.lineChartOptions}),this.startStreaming())}updateConfig(e){this.widgetProperties.config=e,this.startWidget()}setChartOptions(){this.lineChartOptions.maintainAspectRatio=!1,this.lineChartOptions.animation=!1,this.lineChartData.datasets=[],this.lineChartData.datasets.push({label:"Value",data:[],order:this.widgetProperties.config.trackAgainstAverage?1:0,parsing:!1,tension:0,pointRadius:0,pointHoverRadius:0,pointHitRadius:0,borderColor:this.getThemeColors().valueLine,borderWidth:this.widgetProperties.config.trackAgainstAverage?0:3,fill:!!this.widgetProperties.config.trackAgainstAverage,backgroundColor:this.getThemeColors().valueFill}),this.lineChartData.datasets.push({label:"Average",data:[],order:this.widgetProperties.config.trackAgainstAverage?0:1,parsing:!1,tension:.4,pointRadius:0,pointHoverRadius:0,pointHitRadius:0,borderColor:this.getThemeColors().averageLine,borderWidth:this.widgetProperties.config.trackAgainstAverage?3:0,fill:!this.widgetProperties.config.trackAgainstAverage,backgroundColor:this.getThemeColors().averageFill}),this.lineChartOptions.scales={x:{type:"time",display:this.widgetProperties.config.showTimeScale,title:{display:!0,text:`Last ${this.datasetConfig.period} ${this.datasetConfig.timeScaleFormat}`,align:"center"},time:{unit:this.datasetConfig.timeScaleFormat,minUnit:"second",round:"second",displayFormats:{hour:"k:mm''",minute:"mm''",second:'ss"',millisecond:"SSS"}},ticks:{autoSkip:!1,color:this.getThemeColors().averageChartLine,major:{enabled:!0}},grid:{display:!0,color:this.theme().contrastDimmer}},y:{display:this.widgetProperties.config.showYScale,position:"right",suggestedMin:this.widgetProperties.config.enableMinMaxScaleLimit?null:this.widgetProperties.config.yScaleSuggestedMin,suggestedMax:this.widgetProperties.config.enableMinMaxScaleLimit?null:this.widgetProperties.config.yScaleSuggestedMax,min:this.widgetProperties.config.enableMinMaxScaleLimit?this.widgetProperties.config.yScaleMin:null,max:this.widgetProperties.config.enableMinMaxScaleLimit?this.widgetProperties.config.yScaleMax:null,beginAtZero:this.widgetProperties.config.startScaleAtZero,title:{display:!1,text:"Value Axis",align:"center"},ticks:{maxTicksLimit:8,precision:this.widgetProperties.config.numDecimal,color:this.getThemeColors().averageChartLine,major:{enabled:!0}},grid:{display:!0,color:this.theme().contrastDimmer}}},this.lineChartOptions.plugins={subtitle:{display:this.widgetProperties.config.showLabel,align:"start",padding:{top:-31,bottom:4},text:` ${this.widgetProperties.config.displayName}`,font:{size:14},color:this.getThemeColors().chartLabel},title:{display:!0,align:"end",padding:{top:6,bottom:10},text:"",font:{size:22},color:this.getThemeColors().chartValue},annotation:{annotations:{minimumLine:{type:"line",scaleID:"y",display:this.widgetProperties.config.showDatasetMinimumValueLine,value:null,drawTime:"afterDatasetsDraw",label:{display:!0,position:"start",yAdjust:12,padding:4,color:this.getThemeColors().averageChartLine,backgroundColor:"rgba(63,63,63,0.0)"}},maximumLine:{type:"line",scaleID:"y",display:this.widgetProperties.config.showDatasetMaximumValueLine,value:null,drawTime:"afterDatasetsDraw",label:{display:!0,position:"start",yAdjust:-12,padding:4,color:this.getThemeColors().averageChartLine,backgroundColor:"rgba(63,63,63,0.0)"}},averageLine:{type:"line",scaleID:"y",display:this.widgetProperties.config.showDatasetAverageValueLine,value:null,borderDash:[6,6],borderColor:this.getThemeColors().averageChartLine,drawTime:"afterDatasetsDraw",label:{display:!0,position:"start",padding:4,color:this.getThemeColors().chartValue,backgroundColor:"rgba(63,63,63,0.7)"}}}},legend:{display:!1}}}getThemeColors(){let e=this.widgetProperties.config.color,t={valueLine:null,valueFill:null,averageLine:null,averageFill:null,averageChartLine:null,chartLabel:null,chartValue:null};switch(e){case"contrast":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().contrastDimmer,t.valueFill=this.theme().contrastDimmer,t.averageLine=this.theme().contrast,t.averageFill=this.theme().contrast,t.chartValue=t.averageLine):(t.valueLine=this.theme().contrast,t.valueFill=this.theme().contrast,t.averageLine=this.theme().contrastDimmer,t.averageFill=this.theme().contrastDimmer,t.chartValue=this.theme().contrast),t.averageChartLine=this.theme().contrastDim,t.chartLabel=this.theme().contrastDim;break;case"blue":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().blueDimmer,t.valueFill=this.theme().blueDimmer,t.averageLine=this.theme().blue,t.averageFill=this.theme().blue,t.chartValue=t.averageLine):(t.valueLine=this.theme().blue,t.valueFill=this.theme().blue,t.averageLine=this.theme().blueDimmer,t.averageFill=this.theme().blueDimmer,t.chartValue=t.valueFill),t.averageChartLine=this.theme().blueDim,t.chartLabel=this.theme().contrastDim;break;case"green":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().greenDimmer,t.valueFill=this.theme().greenDimmer,t.averageLine=this.theme().green,t.averageFill=this.theme().green,t.chartValue=t.averageLine):(t.valueLine=this.theme().green,t.valueFill=this.theme().green,t.averageLine=this.theme().greenDimmer,t.averageFill=this.theme().greenDimmer,t.chartValue=t.valueFill),t.averageChartLine=this.theme().greenDim,t.chartLabel=this.theme().contrastDim;break;case"pink":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().pinkDimmer,t.valueFill=this.theme().pinkDimmer,t.averageLine=this.theme().pink,t.averageFill=this.theme().pink,t.chartValue=t.averageLine):(t.valueLine=this.theme().pink,t.valueFill=this.theme().pink,t.averageLine=this.theme().pinkDimmer,t.averageFill=this.theme().pinkDimmer,t.chartValue=t.valueFill),t.averageChartLine=this.theme().pinkDim,t.chartLabel=this.theme().contrastDim;break;case"orange":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().orangeDimmer,t.valueFill=this.theme().orangeDimmer,t.averageLine=this.theme().orange,t.averageFill=this.theme().orange,t.chartValue=t.averageLine):(t.valueLine=this.theme().orange,t.valueFill=this.theme().orange,t.averageLine=this.theme().orangeDimmer,t.averageFill=this.theme().orangeDimmer,t.chartValue=t.valueFill),t.averageChartLine=this.theme().orangeDim,t.chartLabel=this.theme().contrastDim;break;case"purple":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().purpleDimmer,t.valueFill=this.theme().purpleDimmer,t.averageLine=this.theme().purple,t.averageFill=this.theme().purple,t.chartValue=t.averageLine):(t.valueLine=this.theme().purple,t.valueFill=this.theme().purple,t.averageLine=this.theme().purpleDimmer,t.averageFill=this.theme().purpleDimmer,t.chartValue=t.valueFill),t.averageChartLine=this.theme().purpleDim,t.chartLabel=this.theme().contrastDim;break;case"grey":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().greyDimmer,t.valueFill=this.theme().greyDimmer,t.averageLine=this.theme().grey,t.averageFill=this.theme().grey,t.chartValue=t.averageLine):(t.valueLine=this.theme().grey,t.valueFill=this.theme().grey,t.averageLine=this.theme().greyDimmer,t.averageFill=this.theme().greyDimmer,t.chartValue=t.valueFill),t.averageChartLine=this.theme().greyDim,t.chartLabel=this.theme().contrastDim;break;case"yellow":this.widgetProperties.config.trackAgainstAverage?(t.valueLine=this.theme().yellowDimmer,t.valueFill=this.theme().yellowDimmer,t.averageLine=this.theme().yellow,t.averageFill=this.theme().yellow,t.chartValue=t.averageLine):(t.valueLine=this.theme().yellow,t.valueFill=this.theme().yellow,t.averageLine=this.theme().yellowDimmer,t.averageFill=this.theme().yellowDimmer,t.chartValue=t.valueFill),t.averageChartLine=this.theme().yellowDim,t.chartLabel=this.theme().contrastDim;break}return t}getUnitsLabel(){let e=null;switch(this.widgetProperties.config.convertUnitTo){case"percent":case"percentraw":e="%";break;case"latitudeMin":e="latitude in minutes";break;case"latitudeSec":e="latitude in secondes";break;case"longitudeMin":e="longitude in minutes";break;case"longitudeSec":e="longitude in secondes";break;default:e=this.widgetProperties.config.convertUnitTo;break}return e}startStreaming(){this.dsServiceSub?.unsubscribe(),this.dsServiceSub=this.dsService.getDatasetObservable(this.widgetProperties.config.datasetUUID).subscribe(e=>{this.chart.data.datasets[0].data.push(this.transformDatasetRow(e,0)),this.chart.data.datasets[0].data.length>this.dataSourceInfo.maxDataPoints&&this.chart.data.datasets[0].data.shift(),this.widgetProperties.config.showAverageData&&(this.chart.data.datasets[1].data.push(this.transformDatasetRow(e,this.widgetProperties.config.datasetAverageArray)),this.chart.data.datasets[1].data.length>this.dataSourceInfo.maxDataPoints&&this.chart.data.datasets[1].data.shift());let t=this.widgetProperties.config.trackAgainstAverage?e.data.sma:e.data.value;this.chart.options.plugins.title.text=`${this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,t).toFixed(this.widgetProperties.config.numDecimal)} ${this.getUnitsLabel()} `;let i=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.lastAverage),o=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.lastMinimum),a=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.lastMaximum);this.chart.options.plugins.annotation.annotations.averageLine.value!=i&&(this.chart.options.plugins.annotation.annotations.averageLine.value=i,this.chart.options.plugins.annotation.annotations.averageLine.label.content=`${i.toFixed(this.widgetProperties.config.numDecimal)}`),this.chart.options.plugins.annotation.annotations.minimumLine.value!=o&&(this.chart.options.plugins.annotation.annotations.minimumLine.value=o,this.chart.options.plugins.annotation.annotations.minimumLine.label.content=`${o.toFixed(this.widgetProperties.config.numDecimal)}`),this.chart.options.plugins.annotation.annotations.maximumLine.value!=a&&(this.chart.options.plugins.annotation.annotations.maximumLine.value=a,this.chart.options.plugins.annotation.annotations.maximumLine.label.content=`${a.toFixed(this.widgetProperties.config.numDecimal)}`),this.chart?.update("quiet")})}transformDatasetRow(e,t){let i={x:e.timestamp,y:null};if(t===0)i.y=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.value);else switch(this.widgetProperties.config.datasetAverageArray){case"sma":i.y=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.sma);break;case"ema":i.y=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.ema);break;case"dema":i.y=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.doubleEma);break;case"avg":i.y=this.unitsService.convertToUnit(this.widgetProperties.config.convertUnitTo,e.data.lastAverage);break}return i}ngOnDestroy(){this.destroyDataStreams(),this.dsServiceSub?.unsubscribe(),this.chart?.destroy()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-data-chart"]],viewQuery:function(t,i){t&1&&de(i.widgetDataChart,mf,5,Me),t&2&&Qe()},features:[pe],decls:3,vars:2,consts:[["widgetDataChart",""],[3,"configChange","config","id"],[2,"z-index","inherit"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),B(1,"canvas",2,0),_()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid))},dependencies:[Ne],encapsulation:2})}return r})();var th=(()=>{class r{sanitizer=M(Vn);transform(e){return this.sanitizer.bypassSecurityTrustResourceUrl(e)}static \u0275fac=function(t){return new(t||r)};static \u0275pipe=yl({name:"safe",type:r,pure:!0})}return r})();var pf=["freeboardSkIframe"];function ff(r,n){r&1&&B(0,"div",3)}var ih=(()=>{class r extends Re{appSettings=M(ei);auth=M(_i);_dashboard=M(st);iframe=le.required("freeboardSkIframe");widgetUrl=null;_authTokenSubscription=null;dashboard=M(st);constructor(){super()}ngOnInit(){let e=null;this._authTokenSubscription=this.auth.authToken$.subscribe(t=>{e=t?.token}),this.widgetUrl=e?`${this.appSettings.signalkUrl.url}/@signalk/freeboard-sk/?token=${e}`:`${this.appSettings.signalkUrl.url}/@signalk/freeboard-sk/`,window.addEventListener("message",this.handleIframeGesture)}ngAfterViewInit(){this.iframe&&(this.iframe().nativeElement.onload=()=>this.injectHammerJS())}startWidget(){}updateConfig(e){}handleIframeGesture=e=>{if(e.data){if(e.data.gesture&&e.data.eventData.instanceId===this.widgetProperties.uuid)switch(e.data.gesture){case"swipeup":this.dashboard.isDashboardStatic()&&this.dashboard.previousDashboard();break;case"swipedown":this.dashboard.isDashboardStatic()&&this.dashboard.nextDashboard();break;case"swipeleft":let t=new Event("openLeftSidenav",{bubbles:!0,cancelable:!0});window.document.dispatchEvent(t);break;case"swiperight":let i=new Event("openRightSidenav",{bubbles:!0,cancelable:!0});window.document.dispatchEvent(i);break;default:break}if(e.data.type==="keydown"&&e.data.keyEventData.instanceId===this.widgetProperties.uuid){let{key:t,ctrlKey:i,shiftKey:o}=e.data.keyEventData,a=new KeyboardEvent("keydown",{key:t,ctrlKey:i,shiftKey:o,bubbles:!0,cancelable:!0});document.dispatchEvent(a)}}};injectHammerJS(){let e=document.getElementsByTagName("base")[0]?.href||"/",t=this.iframe().nativeElement.contentWindow,i=this.iframe().nativeElement.contentDocument;if(!i||!t){console.error("[FSK Widget] Iframe contentDocument or contentWindow is undefined. Possible cross-origin issue or iframe not fully loaded.");return}if(t.Hammer){console.log("[FSK Widget] HammerJS already loaded in iframe");return}let o=i.createElement("script");o.src=`${e}assets/hammer.min.js`,o.onload=()=>this.injectSwipeHandler(),i.body.appendChild(o)}injectSwipeHandler(){let e=this.iframe().nativeElement.contentDocument;if(!e){console.error("[FSK Widget] Iframe contentDocument is undefined. Possible cross-origin issue or iframe not fully loaded.");return}let t=e.createElement("script");t.textContent=`
|
|
10
|
+
if (!window.hammerInstance) {
|
|
11
|
+
const hammer = new Hammer(document.body);
|
|
12
|
+
hammer.get('swipe').set({ direction: Hammer.DIRECTION_ALL, velocity: 1.5, threshold: 200, domEvents: true });
|
|
13
|
+
|
|
14
|
+
const instanceId = '${this.widgetProperties.uuid}'; // Include the instance ID in the script to prevent multiple listeners
|
|
15
|
+
|
|
16
|
+
hammer.on('swipeleft', (ev) => {
|
|
17
|
+
ev.preventDefault();
|
|
18
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
19
|
+
const eventData = {
|
|
20
|
+
type: ev.type,
|
|
21
|
+
deltaX: ev.deltaX,
|
|
22
|
+
deltaY: ev.deltaY,
|
|
23
|
+
velocityX: ev.velocityX,
|
|
24
|
+
velocityY: ev.velocityY,
|
|
25
|
+
direction: ev.direction,
|
|
26
|
+
distance: ev.distance,
|
|
27
|
+
angle: ev.angle,
|
|
28
|
+
center: ev.center,
|
|
29
|
+
offsetDirection: ev.offsetDirection,
|
|
30
|
+
scale: ev.scale,
|
|
31
|
+
rotation: ev.rotation,
|
|
32
|
+
isFinal: ev.isFinal,
|
|
33
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
34
|
+
};
|
|
35
|
+
window.parent.postMessage({ gesture: 'swipeleft', eventData: eventData }, '*');
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
hammer.on('swiperight', (ev) => {
|
|
39
|
+
ev.preventDefault();
|
|
40
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
41
|
+
const eventData = {
|
|
42
|
+
type: ev.type,
|
|
43
|
+
deltaX: ev.deltaX,
|
|
44
|
+
deltaY: ev.deltaY,
|
|
45
|
+
velocityX: ev.velocityX,
|
|
46
|
+
velocityY: ev.velocityY,
|
|
47
|
+
direction: ev.direction,
|
|
48
|
+
distance: ev.distance,
|
|
49
|
+
angle: ev.angle,
|
|
50
|
+
center: ev.center,
|
|
51
|
+
offsetDirection: ev.offsetDirection,
|
|
52
|
+
scale: ev.scale,
|
|
53
|
+
rotation: ev.rotation,
|
|
54
|
+
isFinal: ev.isFinal,
|
|
55
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
56
|
+
};
|
|
57
|
+
window.parent.postMessage({ gesture: 'swiperight', eventData: eventData }, '*');
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
hammer.on('swipeup', (ev) => {
|
|
61
|
+
ev.preventDefault();
|
|
62
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
63
|
+
const eventData = {
|
|
64
|
+
type: ev.type,
|
|
65
|
+
deltaX: ev.deltaX,
|
|
66
|
+
deltaY: ev.deltaY,
|
|
67
|
+
velocityX: ev.velocityX,
|
|
68
|
+
velocityY: ev.velocityY,
|
|
69
|
+
direction: ev.direction,
|
|
70
|
+
distance: ev.distance,
|
|
71
|
+
angle: ev.angle,
|
|
72
|
+
center: ev.center,
|
|
73
|
+
offsetDirection: ev.offsetDirection,
|
|
74
|
+
scale: ev.scale,
|
|
75
|
+
rotation: ev.rotation,
|
|
76
|
+
isFinal: ev.isFinal,
|
|
77
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
78
|
+
};
|
|
79
|
+
window.parent.postMessage({ gesture: 'swipeup', eventData: eventData }, '*');
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
hammer.on('swipedown', (ev) => {
|
|
83
|
+
ev.preventDefault();
|
|
84
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
85
|
+
const eventData = {
|
|
86
|
+
type: ev.type,
|
|
87
|
+
deltaX: ev.deltaX,
|
|
88
|
+
deltaY: ev.deltaY,
|
|
89
|
+
velocityX: ev.velocityX,
|
|
90
|
+
velocityY: ev.velocityY,
|
|
91
|
+
direction: ev.direction,
|
|
92
|
+
distance: ev.distance,
|
|
93
|
+
angle: ev.angle,
|
|
94
|
+
center: ev.center,
|
|
95
|
+
offsetDirection: ev.offsetDirection,
|
|
96
|
+
scale: ev.scale,
|
|
97
|
+
rotation: ev.rotation,
|
|
98
|
+
isFinal: ev.isFinal,
|
|
99
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
100
|
+
};
|
|
101
|
+
window.parent.postMessage({ gesture: 'swipedown', eventData: eventData }, '*');
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
// Add keydown listener
|
|
105
|
+
document.addEventListener('keydown', (event) => {
|
|
106
|
+
if (event.ctrlKey && event.shiftKey && ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown', 'E', 'F', 'N'].includes(event.key)) {
|
|
107
|
+
const keyEventData = {
|
|
108
|
+
key: event.key,
|
|
109
|
+
ctrlKey: event.ctrlKey,
|
|
110
|
+
shiftKey: event.shiftKey,
|
|
111
|
+
instanceId: instanceId
|
|
112
|
+
};
|
|
113
|
+
window.parent.postMessage({ type: 'keydown', keyEventData: keyEventData }, '*');
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
window.hammerInstance = hammer; // Store the instance to prevent multiple listeners
|
|
118
|
+
}
|
|
119
|
+
`,e.body.appendChild(t)}ngOnDestroy(){window.removeEventListener("message",this.handleIframeGesture),this._authTokenSubscription?.unsubscribe(),this.destroyDataStreams()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-freeboardsk"]],viewQuery:function(t,i){t&1&&de(i.iframe,pf,5),t&2&&Qe()},features:[pe],decls:5,vars:6,consts:[["freeboardSkIframe",""],[3,"configChange","config","id"],["width","100%","height","100%","frameborder","0","sandbox","allow-same-origin allow-scripts allow-forms",3,"src"],[1,"widgetOverlay"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),B(1,"iframe",2,0),eo(3,"safe"),Te(4,ff,1,0,"div",3),_()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),G("src",Tl(3,4,i.widgetUrl),Kr),P(3),Ue(i.dashboard.isDashboardStatic()?-1:4))},dependencies:[Ne,th],styles:[".widgetOverlay[_ngcontent-%COMP%]{position:absolute;width:100%;height:100%;right:0;bottom:0;color:transparent}"]})}return r})();var Zi=wr(ms(),1),oh=wr(ms(),1);var gf=["gauge"],vf=r=>r.replace(/(\-\w)/g,n=>n[1].toUpperCase()),yf=r=>r.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase(),nh=r=>vf(r),rh=(()=>{class r{el;zone;canvas;gauge;isInited=!1;preInitValue;preInitOptions;domListener;constructor(e,t){this.el=e,this.zone=t}get options(){let e={};e.renderTo=this.canvas.nativeElement;for(let t of this.el.nativeElement.attributes){let i=nh(t.name);e[i]=Zi.DomObserver.parse(t.value)}for(let t in this.preInitOptions)e[t]=this.preInitOptions[t];return this.isInited&&(this.preInitOptions=null),e}set options(e){if(!this.isInited){this.preInitOptions=e;return}this.update(e)}set value(e){if(!this.isInited){this.preInitValue=e;return}this.zone.runOutsideAngular(()=>{this.gauge.value=e})}update(e){if(e)for(let t in e){let i=e[t].toString();if(t==="value")this.value=Zi.DomObserver.parse(i);else{let o=yf(t);this.el.nativeElement.setAttribute(o,i)}}}ngOnDestroy(){this.destroy(),this.cleanup()}cleanup(){}destroy(){this.stopListeningForDOMEvents(),this.gauge.destroy()}ngAfterViewInit(){this.initGauge(),this.listenForDOMEvents(),this.isInited=!0,this.preInitValue&&(this.value=this.preInitValue)}listenForDOMEvents(){this.domListener=new MutationObserver(e=>{let t={};e.forEach(i=>{i.type==="attributes"&&(t[nh(i.attributeName)]=Zi.DomObserver.parse(this.el.nativeElement.getAttribute(i.attributeName)))}),this.basicUpdate(t)}),this.domListener.observe(this.el.nativeElement,{attributes:!0})}stopListeningForDOMEvents(){this.domListener&&(this.domListener.disconnect(),this.domListener=null)}initGauge(){let e=this.options;(!e.hasOwnProperty("renderTo")||!e.renderTo)&&(e.renderTo=this.canvas.nativeElement),this.basicUpdate(e)}basicUpdate(e){typeof e.value=="number"&&(this.value=e.value,delete e.value),Object.keys(e).length&&this.gauge.update(e)}static \u0275fac=function(t){return new(t||r)(Rt(Me),Rt(ht))};static \u0275dir=bi({type:r,viewQuery:function(t,i){if(t&1&&Je(gf,7),t&2){let o;Ge(o=je())&&(i.canvas=o.first)}},inputs:{options:"options",value:"value"}})}return r})();var Vo=(()=>{class r extends rh{constructor(e,t){super(e,t)}ngOnInit(){this.gauge=new Zi.LinearGauge(this.options).draw()}static \u0275fac=function(t){return new(t||r)(Rt(Me),Rt(ht))};static \u0275cmp=U({type:r,selectors:[["linear-gauge"]],features:[pe],decls:2,vars:0,consts:[["gauge",""]],template:function(t,i){t&1&&B(0,"canvas",null,0)},encapsulation:2})}return r})();var Fo=(()=>{class r extends rh{constructor(e,t){super(e,t)}ngOnInit(){this.gauge=new Zi.RadialGauge(this.options).draw()}static \u0275fac=function(t){return new(t||r)(Rt(Me),Rt(ht))};static \u0275cmp=U({type:r,selectors:[["radial-gauge"]],features:[pe],decls:2,vars:0,consts:[["gauge",""]],template:function(t,i){t&1&&B(0,"canvas",null,0)},encapsulation:2})}return r})(),hr=(()=>{class r{static \u0275fac=function(t){return new(t||r)};static \u0275mod=Zt({type:r});static \u0275inj=Kt({})}return r})();var ah=["compassGauge"];function fs(r){let n=r.match(/(\d+(\.\d+)?|\.\d+)/g);if(!n||n.length<3)throw new Error("Invalid RGBA format");let[e,t,i,o=1]=n.map(Number),a=o===1?"":Math.round(o*255).toString(16).padStart(2,"0").toUpperCase();return"#"+((1<<24)+(e<<16)+(t<<8)+i).toString(16).slice(1).toUpperCase()+a}function bf(r){return r<0&&(r=360+r),r}var sh=(()=>{class r extends Re{DEG="deg";LINE="line";NEEDLE_START=40;NEEDLE_END=100;NEEDLE_CIRCLE_SIZE=15;BORDER_MIDDLE_WIDTH=2;BORDER_INNER_WIDTH=2;ANIMATION_TARGET_PLATE="plate";ANIMATION_TARGET_NEEDLE="needle";textValue="--";value=0;ngGauge;gauge;gaugeOptions={};colorStrokeTicks="";unitName=null;state=te.Normal;negToPortPaths=["self.environment.wind.angleApparent","self.environment.wind.angleTrueGround","self.environment.wind.angleTrueWater"];constructor(){super(),this.defaultConfig={displayName:"Gauge Label",filterSelfPaths:!0,paths:{gaugePath:{description:"Numeric Data",path:null,source:null,pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",isConvertUnitToConfigurable:!1,convertUnitTo:this.DEG,sampleTime:500}},gauge:{type:"ngRadial",subType:"baseplateCompass",enableTicks:!0,compassUseNumbers:!1,showValueBox:!1},enableTimeout:!1,color:"contrast",dataTimeout:5},Pe(()=>{this.theme()&&this.startWidget()})}ngOnInit(){this.validateConfig(),this.setGaugeConfig()}startWidget(){this.setGaugeConfig(),this.ngGauge.update(this.gaugeOptions),this.unsubscribeDataStream(),this.observeDataStream("gaugePath",e=>{(!e||!e.data)&&(e={data:{value:0,timestamp:new Date},state:te.Normal},this.textValue="--",this.value=0),e.state==null&&(e.state=te.Normal);let t=this.negToPortPaths.includes(this.widgetProperties.config.paths.gaugePath.path)?bf(e.data.value):e.data.value;if(this.value=Math.min(Math.max(t,0),360),this.textValue=this.value.toFixed(0),this.state!==e.state){this.state=e.state;let i={};switch(e.state){case te.Emergency:i.colorValueText=this.theme().zoneEmergency;break;case te.Alarm:i.colorValueText=this.theme().zoneAlarm;break;case te.Warn:i.colorValueText=this.theme().zoneWarn;break;case te.Alert:i.colorValueText=this.theme().zoneAlert;break;default:i.colorValueText=this.theme().contrast}this.ngGauge.update(i)}})}updateConfig(e){this.widgetProperties.config=e,this.setCanvasHight(),this.startWidget()}setCanvasHight(){let e=this.gauge.nativeElement.getBoundingClientRect(),t={};t.height=e.height,t.width=e.width,this.ngGauge.update(t)}ngAfterViewInit(){this.setCanvasHight(),this.startWidget()}onResized(e){let t={};t.height=e.contentRect.height,t.width=e.contentRect.width,this.ngGauge.update(t)}setGaugeConfig(){this.gaugeOptions.title=this.widgetProperties.config.displayName?this.widgetProperties.config.displayName:"",this.gaugeOptions.minValue=0,this.gaugeOptions.maxValue=360,this.gaugeOptions.valueDec=0,this.gaugeOptions.valueInt=1,this.gaugeOptions.units="",this.gaugeOptions.barProgress=!1,this.gaugeOptions.barWidth=0,this.gaugeOptions.valueBox=this.widgetProperties.config.gauge.showValueBox,this.gaugeOptions.fontValueSize=60,this.gaugeOptions.valueBoxWidth=26,this.gaugeOptions.valueBoxBorderRadius=10,this.gaugeOptions.valueBoxStroke=0,this.gaugeOptions.ticksAngle=360,this.gaugeOptions.startAngle=180,this.gaugeOptions.exactTicks=!1,this.gaugeOptions.strokeTicks="",this.gaugeOptions.majorTicks=this.widgetProperties.config.gauge.compassUseNumbers?["N","30","60","E","120","150","S","210","240","W","300","330","N"]:["N","NE","E","SE","S","SW","W","NW","N"],this.gaugeOptions.majorTicksDec=0,this.gaugeOptions.majorTicksInt=1,this.gaugeOptions.numbersMargin=5,this.gaugeOptions.fontNumbersSize=25,this.gaugeOptions.minorTicks=this.widgetProperties.config.gauge.compassUseNumbers?3:2,this.gaugeOptions.needle=!0,this.gaugeOptions.needleType=this.LINE,this.gaugeOptions.needleStart=this.NEEDLE_START,this.gaugeOptions.needleEnd=this.NEEDLE_END,this.gaugeOptions.needleCircleSize=this.NEEDLE_CIRCLE_SIZE,this.gaugeOptions.needleWidth=4,this.gaugeOptions.needleShadow=!1,this.gaugeOptions.needleCircleInner=!1,this.gaugeOptions.needleCircleOuter=!1,this.gaugeOptions.borders=!0,this.gaugeOptions.borderOuterWidth=0,this.gaugeOptions.borderMiddleWidth=this.BORDER_MIDDLE_WIDTH,this.gaugeOptions.borderInnerWidth=this.BORDER_INNER_WIDTH,this.gaugeOptions.borderShadowWidth=0,this.gaugeOptions.highlights=[],this.gaugeOptions.fontTitle="Roboto",this.gaugeOptions.fontTitleWeight="normal",this.gaugeOptions.fontTitleSize=25,this.gaugeOptions.fontUnits="Roboto",this.gaugeOptions.fontUnitsSize=25,this.gaugeOptions.fontUnitsWeight="normal",this.gaugeOptions.barStrokeWidth=0,this.gaugeOptions.barShadow=0,this.gaugeOptions.fontValue="Roboto",this.gaugeOptions.fontValueWeight="bold",this.gaugeOptions.valueTextShadow=!1,this.gaugeOptions.colorValueBoxShadow="",this.gaugeOptions.fontNumbers="Roboto",this.gaugeOptions.fontNumbersWeight="bold",this.gaugeOptions.highlightsWidth=0,this.widgetProperties.config.gauge.subType==="marineCompass"?(this.gaugeOptions.animationTarget=this.ANIMATION_TARGET_PLATE,this.gaugeOptions.useMinPath=!0):this.widgetProperties.config.gauge.subType==="baseplateCompass"&&(this.gaugeOptions.animationTarget=this.ANIMATION_TARGET_NEEDLE,this.gaugeOptions.useMinPath=!0),this.gaugeOptions.animation=!0,this.gaugeOptions.animateOnInit=!0,this.gaugeOptions.animatedValue=!0,this.gaugeOptions.animationRule="linear",this.gaugeOptions.animationDuration=this.widgetProperties.config.paths.gaugePath.sampleTime-50,this.setGaugeOptions(this.getColors(this.widgetProperties.config.color).color,fs(this.getColors(this.widgetProperties.config.color).dim),fs(this.getColors(this.widgetProperties.config.color).dimmer))}setGaugeOptions(e,t,i){let o=fs(this.getColors("contrast").dim);this.gaugeOptions.colorBarProgress=e,this.gaugeOptions.colorBorderMiddle=t,this.gaugeOptions.colorBorderMiddleEnd=t,this.gaugeOptions.colorNeedle=e,this.gaugeOptions.colorNeedleEnd=e,this.gaugeOptions.colorTitle=o,this.gaugeOptions.colorUnits=o,this.gaugeOptions.colorValueText=e,this.gaugeOptions.colorMinorTicks=o,this.gaugeOptions.colorNumbers=this.widgetProperties.config.gauge.compassUseNumbers?[this.theme().port,o,o,t,o,o,t,o,o,t,o,o,this.theme().port]:[this.theme().port,t,t,t,t,t,t,t,this.theme().port],this.gaugeOptions.colorMajorTicks=this.widgetProperties.config.gauge.compassUseNumbers?[this.theme().port,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().port]:[this.theme().port,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().contrast,this.theme().port],this.gaugeOptions.colorPlate=this.gaugeOptions.colorPlateEnd=this.gaugeOptions.colorBorderInner=this.gaugeOptions.colorBorderInnerEnd=this.theme().cardColor,this.gaugeOptions.colorBar=this.theme().background,this.gaugeOptions.colorBarStroke="",this.gaugeOptions.colorValueBoxBackground=this.theme().background,this.gaugeOptions.colorNeedleShadowUp="",this.gaugeOptions.colorNeedleShadowDown="",this.gaugeOptions.colorNeedleCircleInner=this.gaugeOptions.colorPlate,this.gaugeOptions.colorNeedleCircleInnerEnd=this.gaugeOptions.colorPlate,this.gaugeOptions.colorNeedleCircleOuter=this.gaugeOptions.colorPlate,this.gaugeOptions.colorNeedleCircleOuterEnd=this.gaugeOptions.colorPlate}getColors(e){return{contrast:{color:this.theme().contrast,dim:this.theme().contrastDim,dimmer:this.theme().contrastDimmer},blue:{color:this.theme().blue,dim:this.theme().blueDim,dimmer:this.theme().blueDimmer},green:{color:this.theme().green,dim:this.theme().greenDim,dimmer:this.theme().greenDimmer},pink:{color:this.theme().pink,dim:this.theme().pinkDim,dimmer:this.theme().pinkDimmer},orange:{color:this.theme().orange,dim:this.theme().orangeDim,dimmer:this.theme().orangeDimmer},purple:{color:this.theme().purple,dim:this.theme().purpleDim,dimmer:this.theme().purpleDimmer},yellow:{color:this.theme().yellow,dim:this.theme().yellowDim,dimmer:this.theme().yellowDimmer},grey:{color:this.theme().grey,dim:this.theme().greyDim,dimmer:this.theme().yellowDimmer}}[e]}ngOnDestroy(){this.destroyDataStreams(),this.ngGauge=null,this.gauge=null}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-gauge-ng-compass"]],viewQuery:function(t,i){if(t&1&&(Je(ah,7),Je(ah,7,Me)),t&2){let o;Ge(o=je())&&(i.ngGauge=o.first),Ge(o=je())&&(i.gauge=o.first)}},features:[pe],decls:3,vars:7,consts:[["compassGauge",""],[3,"configChange","config","id"],[3,"onResize","id","options","value"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"radial-gauge",2,0),V("onResize",function(l){return z(o),L(i.onResized(l))}),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),di("id",i.widgetProperties.uuid),G("options",i.gaugeOptions)("value",i.value),fe("value-text",i.textValue)("color-stroke-ticks",i.colorStrokeTicks))},dependencies:[Ne,tt,et,hr,Fo],styles:["radial-gauge{display:block;position:relative;width:100%;height:100%} radial-gauge>canvas{display:block;position:absolute;height:100%;width:100%;left:50%;top:50%;transform:translate(-50%,-50%);padding:10px}"]})}return r})();function Ho(r,n){let e=[],t=n-r,i=0,o=10;t=lh(n-r,!1),i=lh(t/(o-1),!0);let a=Math.floor(r/i)*i,l=Math.ceil(n/i)*i;e.push(a);let d=t/i;for(let f=0;f<d;f++)if(e[f]<l){let s=(Number(e[f].toFixed(2))*100+Number(i.toFixed(2))*100)/100;e.push(s)}return{min:a,max:l,majorTicks:e}}function lh(r,n){let e=Math.floor(Math.log10(r)),t=r/Math.pow(10,e),i=null;return n?1.5>t?i=1:3>t?i=2:7>t?i=5:i=10:1>=t?i=1:2>=t?i=2:5>=t?i=5:i=10,i*Math.pow(10,e)}var dh=["linearGauge"],ch=(()=>{class r extends Re{ngGauge;gauge;textValue="--";value=0;gaugeOptions={};isGaugeVertical=!0;metaSub;state=te.Normal;constructor(){super(),this.defaultConfig={displayName:"Gauge Label",filterSelfPaths:!0,paths:{gaugePath:{description:"Numeric Data",path:null,source:null,pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!0,pathSkUnitsFilter:null,convertUnitTo:"unitless",sampleTime:500}},displayScale:{lower:0,upper:100,type:"linear"},gauge:{type:"ngLinear",subType:"vertical",enableTicks:!1,highlightsWidth:5,useNeedle:!1},numInt:1,numDecimal:0,color:"contrast",enableTimeout:!1,dataTimeout:5,ignoreZones:!1},Pe(()=>{this.theme()&&this.startWidget()})}ngOnInit(){this.validateConfig()}startWidget(){this.setGaugeConfig(),this.ngGauge.update(this.gaugeOptions),this.unsubscribeDataStream(),this.unsubscribeMetaStream(),this.metaSub?.unsubscribe(),this.observeDataStream("gaugePath",e=>{if((!e||!e.data)&&(e={data:{value:0,timestamp:new Date},state:te.Normal}),e.state==null&&(e.state=te.Normal),this.value=Math.min(Math.max(e.data.value,this.widgetProperties.config.displayScale.lower),this.widgetProperties.config.displayScale.upper),this.state!==e.state){this.state=e.state;let t={};if(!this.widgetProperties.config.ignoreZones)switch(e.state){case te.Emergency:this.widgetProperties.config.gauge.useNeedle?(t.colorNeedle=this.theme().zoneEmergency,t.colorValueText=this.theme().zoneEmergency):(t.colorBarProgress=this.theme().zoneEmergency,t.colorValueText=this.theme().zoneEmergency);break;case te.Alarm:this.widgetProperties.config.gauge.useNeedle?(t.colorNeedle=this.theme().zoneAlarm,t.colorValueText=this.theme().zoneAlarm):(t.colorBarProgress=this.theme().zoneAlarm,t.colorValueText=this.theme().zoneAlarm);break;case te.Warn:this.widgetProperties.config.gauge.useNeedle?(t.colorNeedle=this.theme().zoneWarn,t.colorValueText=this.theme().zoneWarn):(t.colorBarProgress=this.theme().zoneWarn,t.colorValueText=this.theme().zoneWarn);break;case te.Alert:this.widgetProperties.config.gauge.useNeedle?(t.colorNeedle=this.theme().zoneAlert,t.colorValueText=this.theme().zoneAlert):(t.colorBarProgress=this.theme().zoneAlert,t.colorValueText=this.theme().zoneAlert);break;default:this.widgetProperties.config.gauge.useNeedle?(t.colorNeedle=this.getColors(this.widgetProperties.config.color).color,t.colorValueText=this.getColors(this.widgetProperties.config.color).color):(t.colorBarProgress=this.getColors(this.widgetProperties.config.color).color,t.colorValueText=this.getColors(this.widgetProperties.config.color).color)}this.ngGauge.update(t)}}),this.widgetProperties.config.ignoreZones||(this.observeMetaStream(),this.metaSub=this.zones$.subscribe(e=>{e&&e.length>0&&this.setHighlights(e)}))}updateConfig(e){this.widgetProperties.config=e,this.startWidget()}ngAfterViewInit(){this.setCanvasHight,this.startWidget()}onResized(e){let t={};this.widgetProperties.config.gauge.subType==="vertical"?(t.height=e.contentRect.height,t.width=t.height*.3,t.width>e.contentRect.width&&(t.width=e.contentRect.width,t.height=t.width/.3)):(t.width=e.contentRect.width,t.height=t.width*.3,t.height>e.contentRect.height&&(t.height=e.contentRect.height,t.width=t.height/.3)),t.height-=10,this.ngGauge.update(t)}setCanvasHight(){let e=this.gauge.nativeElement.getBoundingClientRect(),t={};t.height=e.height,t.width=e.width,this.ngGauge.update(t)}setGaugeConfig(){let e=this.widgetProperties.config.gauge.subType==="vertical",t=this.widgetProperties.config.gauge.useNeedle,i=this.widgetProperties.config.gauge.enableTicks,o={min:this.widgetProperties.config.displayScale.lower,max:this.widgetProperties.config.displayScale.upper,majorTicks:[]},a=this.gauge.nativeElement.getBoundingClientRect(),l=null,d=null;this.widgetProperties.config.gauge.subType==="vertical"?(l=a.height,d=a.height*.3):(l=a.width*.3,d=a.width),i&&(o=Ho(this.widgetProperties.config.displayScale.lower,this.widgetProperties.config.displayScale.upper));let f={height:l,width:d,minValue:o.min,maxValue:o.max,valueInt:this.widgetProperties.config.numInt!==void 0&&this.widgetProperties.config.numInt!==null?this.widgetProperties.config.numInt:1,valueDec:this.widgetProperties.config.numDecimal!==void 0&&this.widgetProperties.config.numDecimal!==null?this.widgetProperties.config.numDecimal:2,title:this.widgetProperties.config.displayName,fontTitleSize:40,fontTitle:"Roboto",fontTitleWeight:"bold",barLength:e?80:90,barWidth:i?30:60,barProgress:!0,barBeginCircle:0,barStrokeWidth:0,barShadow:0,needle:t,needleType:this.widgetProperties.config.gauge.useNeedle?"arrow":"line",needleShadow:!1,needleSide:"both",needleStart:this.widgetProperties.config.gauge.useNeedle?22:-45,needleEnd:this.widgetProperties.config.gauge.useNeedle?120:55,colorNeedleEnd:"",colorNeedleShadowUp:"",colorNeedleShadowDown:"black",units:this.widgetProperties.config.paths.gaugePath.convertUnitTo,fontUnits:"Roboto",fontUnitsWeight:"normal",borders:!1,borderOuterWidth:0,colorBorderOuter:"red",colorBorderOuterEnd:"red",borderMiddleWidth:0,colorBorderMiddle:"#63afdf",colorBorderMiddleEnd:"#63afdf",borderInnerWidth:0,colorBorderInner:"red",colorBorderInnerEnd:"#121212",borderShadowWidth:0,borderRadius:0,colorBarEnd:"",colorBarStroke:"0",valueBoxStroke:0,colorValueBoxRect:"",colorValueBoxRectEnd:"",colorValueBoxBackground:this.theme().background,fontValueSize:50,fontValue:"Roboto",fontValueWeight:"bold",valueTextShadow:!1,colorValueBoxShadow:"",fontNumbers:"Roboto",fontNumbersWeight:"normal",fontUnitsSize:this.isGaugeVertical?40:35,colorTitle:this.getColors("contrast").dim,colorUnits:this.getColors("contrast").dim,colorValueText:this.getColors(this.widgetProperties.config.color).color,colorPlate:this.theme().cardColor,colorBar:this.theme().background,colorMajorTicks:this.getColors("contrast").dim,colorMinorTicks:this.getColors("contrast").dim,colorNumbers:this.getColors("contrast").dim,majorTicks:i?o.majorTicks:[],majorTicksInt:this.widgetProperties.config.numInt!==void 0&&this.widgetProperties.config.numInt!==null?this.widgetProperties.config.numInt:1,majorTicksDec:this.widgetProperties.config.numDecimal!==void 0&&this.widgetProperties.config.numDecimal!==null?this.widgetProperties.config.numDecimal:2,numberSide:"left",fontNumbersSize:i?25:0,numbersMargin:e?-3:-5,tickSide:"left",ticksWidth:i?10:0,ticksPadding:i?e?5:8:0,strokeTicks:i,minorTicks:i?2:0,ticksWidthMinor:i?6:0,valueBox:!0,valueBoxWidth:35,valueBoxBorderRadius:10,highlights:[],highlightsWidth:this.widgetProperties.config.gauge.highlightsWidth,animation:!0,animationRule:"linear",animatedValue:!1,animateOnInit:!1,animationDuration:this.widgetProperties.config.paths.gaugePath.sampleTime-25};Object.assign(this.gaugeOptions,f),this.setThemePaletteColor()}setThemePaletteColor(){let e="",t="";switch(this.widgetProperties.config.color){case"contrast":e=this.theme().contrast,t=this.theme().contrastDim;break;case"blue":e=this.theme().blue,t=this.theme().blueDim;break;case"green":e=this.theme().green,t=this.theme().greenDim;break;case"pink":e=this.theme().pink,t=this.theme().pinkDim;break;case"orange":e=this.theme().orange,t=this.theme().orangeDim;break;case"purple":e=this.theme().purple,t=this.theme().purpleDim;break;case"grey":e=this.theme().grey,t=this.theme().greyDim;break;case"yellow":e=this.theme().yellow,t=this.theme().yellowDim;break;default:e=this.theme().contrast,t=this.theme().contrastDim;break}Object.assign(this.gaugeOptions,{colorBarProgress:this.widgetProperties.config.gauge.useNeedle?"":e,colorBarProgressEnd:"",colorNeedle:this.widgetProperties.config.gauge.useNeedle?e:t,needleWidth:this.widgetProperties.config.gauge.useNeedle?20:0})}getColors(e){return{contrast:{color:this.theme().contrast,dim:this.theme().contrastDim,dimmer:this.theme().contrastDimmer},blue:{color:this.theme().blue,dim:this.theme().blueDim,dimmer:this.theme().blueDimmer},green:{color:this.theme().green,dim:this.theme().greenDim,dimmer:this.theme().greenDimmer},pink:{color:this.theme().pink,dim:this.theme().pinkDim,dimmer:this.theme().pinkDimmer},orange:{color:this.theme().orange,dim:this.theme().orangeDim,dimmer:this.theme().orangeDimmer},purple:{color:this.theme().purple,dim:this.theme().purpleDim,dimmer:this.theme().purpleDimmer},yellow:{color:this.theme().yellow,dim:this.theme().yellowDim,dimmer:this.theme().yellowDimmer},grey:{color:this.theme().grey,dim:this.theme().greyDim,dimmer:this.theme().yellowDimmer}}[e]}setHighlights(e){let t=[],i=[...e].sort((a,l)=>a.lower-l.lower);for(let a of i){let l=null,d=null,f;switch(a.state){case te.Emergency:f=this.theme().zoneEmergency;break;case te.Alarm:f=this.theme().zoneAlarm;break;case te.Warn:f=this.theme().zoneWarn;break;case te.Alert:f=this.theme().zoneAlert;break;case te.Nominal:f=this.theme().zoneNominal;break;default:f="rgba(0,0,0,0)"}if(l=this.unitsService.convertToUnit(this.widgetProperties.config.paths.gaugePath.convertUnitTo,a.lower),d=this.unitsService.convertToUnit(this.widgetProperties.config.paths.gaugePath.convertUnitTo,a.upper),!(d<this.widgetProperties.config.displayScale.lower||l>this.widgetProperties.config.displayScale.upper)){if(l=l!==null?l:this.widgetProperties.config.displayScale.lower,d=d!==null?d:this.widgetProperties.config.displayScale.upper,l=Math.max(l,this.widgetProperties.config.displayScale.lower),d>this.widgetProperties.config.displayScale.upper){d=this.widgetProperties.config.displayScale.upper,t.push({from:l,to:d,color:f});break}t.push({from:l,to:d,color:f})}}let o={};o.highlightsWidth=this.widgetProperties.config.gauge.highlightsWidth,o.highlights=JSON.stringify(t,null,1),this.ngGauge.update(o)}ngOnDestroy(){this.destroyDataStreams(),this.metaSub?.unsubscribe(),this.ngGauge=null,this.gauge=null}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-gauge-ng-linear"]],viewQuery:function(t,i){if(t&1&&(Je(dh,7,Vo),Je(dh,7,Me)),t&2){let o;Ge(o=je())&&(i.ngGauge=o.first),Ge(o=je())&&(i.gauge=o.first)}},features:[pe],decls:4,vars:5,consts:[["host",""],["linearGauge",""],[3,"configChange","config","id"],[1,"linearGauge",3,"onResize","id","options","value"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",2,0),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(2,"linear-gauge",3,1),V("onResize",function(l){return z(o),L(i.onResized(l))}),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(2),di("id",i.widgetProperties.uuid),G("options",i.gaugeOptions)("value",i.value))},dependencies:[Ne,tt,et,hr,Vo],styles:["linear-gauge{display:block;position:relative;width:100%;height:100%} linear-gauge>canvas{display:block;position:absolute;height:100%;width:100%;left:50%;top:50%;transform:translate(-50%,-50%);margin-top:5px}"]})}return r})();var hh=["radialGauge"],uh=(()=>{class r extends Re{LINE="line";ANIMATION_TARGET_NEEDLE="needle";ngGauge;gauge;textValue="--";value=0;gaugeOptions={};colorStrokeTicks="";unitName=null;metaSub;state=te.Normal;constructor(){super(),this.defaultConfig={displayName:"Gauge Label",filterSelfPaths:!0,paths:{gaugePath:{description:"Numeric Data",path:null,source:null,pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!0,pathSkUnitsFilter:null,convertUnitTo:"unitless",sampleTime:500}},displayScale:{lower:0,upper:100,type:"linear"},gauge:{type:"ngRadial",subType:"measuring",enableTicks:!0,compassUseNumbers:!1,highlightsWidth:5},numInt:1,numDecimal:0,enableTimeout:!1,color:"contrast",dataTimeout:5,ignoreZones:!1},Pe(()=>{this.theme()&&this.startWidget()})}ngOnInit(){this.validateConfig(),this.setGaugeConfig()}startWidget(){this.setGaugeConfig(),this.ngGauge.update(this.gaugeOptions),this.unsubscribeDataStream(),this.unsubscribeMetaStream(),this.metaSub?.unsubscribe(),this.observeDataStream("gaugePath",e=>{if((!e||!e.data)&&(e={data:{value:0,timestamp:new Date},state:te.Normal}),e.state==null&&(e.state=te.Normal),this.value=Math.min(Math.max(e.data.value,this.widgetProperties.config.displayScale.lower),this.widgetProperties.config.displayScale.upper),this.state!==e.state){this.state=e.state;let t={};if(!this.widgetProperties.config.ignoreZones)switch(e.state){case te.Alarm:t.colorBorderMiddle=this.theme().cardColor,t.colorBarProgress=this.theme().zoneAlarm,t.colorValueText=this.theme().zoneAlarm;break;case te.Warn:t.colorBorderMiddle=this.theme().cardColor,t.colorBarProgress=this.theme().zoneWarn,t.colorValueText=this.theme().zoneWarn;break;case te.Alert:t.colorBorderMiddle=this.theme().cardColor,t.colorBarProgress=this.theme().zoneAlert,t.colorValueText=this.theme().zoneAlert;break;default:t.colorBorderMiddle=this.theme().cardColor,t.colorBarProgress=this.widgetProperties.config.gauge.subType=="measuring"?this.getColors(this.widgetProperties.config.color).color:this.getColors(this.widgetProperties.config.color).dim,t.colorValueText=this.getColors(this.widgetProperties.config.color).color}this.ngGauge.update(t)}}),this.widgetProperties.config.ignoreZones||(this.observeMetaStream(),this.metaSub=this.zones$.subscribe(e=>{e&&e.length>0&&this.widgetProperties.config.gauge.subType=="measuring"&&this.setHighlights(e)}))}updateConfig(e){this.widgetProperties.config=e,this.setCanvasHight(),this.startWidget()}setCanvasHight(){let e=this.gauge.nativeElement.getBoundingClientRect(),t={};t.height=e.height,t.width=e.width,this.ngGauge.update(t)}ngAfterViewInit(){this.setCanvasHight(),this.startWidget()}onResized(e){let t={};t.height=e.contentRect.height,t.width=e.contentRect.width,this.ngGauge.update(t)}setGaugeConfig(){switch(this.gaugeOptions.title=this.widgetProperties.config.displayName?this.widgetProperties.config.displayName:"",this.gaugeOptions.highlights=[],this.gaugeOptions.fontTitle="Roboto",this.gaugeOptions.fontTitleWeight="bold",this.gaugeOptions.fontUnits="Roboto",this.gaugeOptions.fontUnitsSize=25,this.gaugeOptions.fontUnitsWeight="normal",this.gaugeOptions.barStrokeWidth=0,this.gaugeOptions.barShadow=0,this.gaugeOptions.colorBarStroke="",this.gaugeOptions.fontValue="Roboto",this.gaugeOptions.fontValueWeight="bold",this.gaugeOptions.valueTextShadow=!1,this.gaugeOptions.colorValueBoxShadow="",this.gaugeOptions.fontNumbers="Roboto",this.gaugeOptions.fontNumbersWeight="bold",this.gaugeOptions.valueInt=this.widgetProperties.config.numInt!==void 0&&this.widgetProperties.config.numInt!==null?this.widgetProperties.config.numInt:1,this.gaugeOptions.valueDec=this.widgetProperties.config.numDecimal!==void 0&&this.widgetProperties.config.numDecimal!==null?this.widgetProperties.config.numDecimal:2,this.gaugeOptions.majorTicksInt=this.widgetProperties.config.numInt!==void 0&&this.widgetProperties.config.numInt!==null?this.widgetProperties.config.numInt:1,this.gaugeOptions.majorTicksDec=this.widgetProperties.config.numDecimal!==void 0&&this.widgetProperties.config.numDecimal!==null?this.widgetProperties.config.numDecimal:2,this.gaugeOptions.highlightsWidth=this.widgetProperties.config.gauge.highlightsWidth,this.gaugeOptions.animation=!0,this.gaugeOptions.animateOnInit=!1,this.gaugeOptions.animatedValue=!1,this.gaugeOptions.animationRule="linear",this.gaugeOptions.animationDuration=this.widgetProperties.config.paths.gaugePath.sampleTime-25,this.gaugeOptions.colorBorderShadow=!1,this.gaugeOptions.colorBorderOuter=this.theme().cardColor,this.gaugeOptions.colorBorderOuterEnd="",this.gaugeOptions.colorBorderMiddle=this.theme().cardColor,this.gaugeOptions.colorBorderMiddleEnd="",this.gaugeOptions.colorBarProgress=this.getColors(this.widgetProperties.config.color).color,this.gaugeOptions.colorNeedle=this.getColors(this.widgetProperties.config.color).dim,this.gaugeOptions.colorNeedleEnd=this.getColors(this.widgetProperties.config.color).dim,this.gaugeOptions.colorTitle=this.theme().contrastDim,this.gaugeOptions.colorUnits=this.theme().contrastDim,this.gaugeOptions.colorValueText=this.getColors(this.widgetProperties.config.color).color,this.colorStrokeTicks=this.theme().contrastDim,this.gaugeOptions.colorMinorTicks=this.theme().contrastDim,this.gaugeOptions.colorNumbers=this.theme().contrastDim,this.gaugeOptions.colorMajorTicks=this.theme().contrastDim,this.gaugeOptions.colorPlate=this.gaugeOptions.colorPlateEnd=this.theme().cardColor,this.gaugeOptions.colorBar=this.theme().background,this.gaugeOptions.colorNeedleShadowUp="",this.gaugeOptions.colorNeedleShadowDown="black",this.gaugeOptions.colorNeedleCircleInner=this.gaugeOptions.colorPlate,this.gaugeOptions.colorNeedleCircleInnerEnd=this.gaugeOptions.colorPlate,this.gaugeOptions.colorNeedleCircleOuter=this.gaugeOptions.colorPlate,this.gaugeOptions.colorNeedleCircleOuterEnd=this.gaugeOptions.colorPlate,this.widgetProperties.config.gauge.subType){case"capacity":this.configureCapacityGauge();break;case"measuring":this.configureMeasuringGauge();break;default:}}getColors(e){return{contrast:{color:this.theme().contrast,dim:this.theme().contrastDim,dimmer:this.theme().contrastDimmer},blue:{color:this.theme().blue,dim:this.theme().blueDim,dimmer:this.theme().blueDimmer},green:{color:this.theme().green,dim:this.theme().greenDim,dimmer:this.theme().greenDimmer},pink:{color:this.theme().pink,dim:this.theme().pinkDim,dimmer:this.theme().pinkDimmer},orange:{color:this.theme().orange,dim:this.theme().orangeDim,dimmer:this.theme().orangeDimmer},purple:{color:this.theme().purple,dim:this.theme().purpleDim,dimmer:this.theme().purpleDimmer},yellow:{color:this.theme().yellow,dim:this.theme().yellowDim,dimmer:this.theme().yellowDimmer},grey:{color:this.theme().grey,dim:this.theme().greyDim,dimmer:this.theme().yellowDimmer}}[e]}configureCapacityGauge(){this.gaugeOptions.minValue=this.widgetProperties.config.displayScale.lower,this.gaugeOptions.maxValue=this.widgetProperties.config.displayScale.upper,this.gaugeOptions.units=this.widgetProperties.config.paths.gaugePath.convertUnitTo,this.gaugeOptions.fontTitleSize=40,this.gaugeOptions.barProgress=!0,this.gaugeOptions.barWidth=20,this.gaugeOptions.colorBarProgress=this.getColors(this.widgetProperties.config.color).dim,this.gaugeOptions.valueBox=!0,this.gaugeOptions.fontValueSize=60,this.gaugeOptions.valueBoxWidth=10,this.gaugeOptions.valueBoxBorderRadius=5,this.gaugeOptions.valueBoxStroke=0,this.gaugeOptions.colorValueBoxBackground="",this.gaugeOptions.colorValueBoxRect="",this.gaugeOptions.colorValueBoxRectEnd="",this.gaugeOptions.ticksAngle=360,this.gaugeOptions.startAngle=180,this.gaugeOptions.majorTicks=0,this.gaugeOptions.exactTicks=!0,this.gaugeOptions.strokeTicks=!1,this.gaugeOptions.minorTicks=0,this.gaugeOptions.numbersMargin=0,this.gaugeOptions.fontNumbersSize=0,this.gaugeOptions.colorMajorTicks=this.gaugeOptions.colorPlate,this.gaugeOptions.colorNumbers=this.gaugeOptions.colorMinorTicks="",this.gaugeOptions.needle=!0,this.gaugeOptions.needleType=this.LINE,this.gaugeOptions.needleWidth=2,this.gaugeOptions.needleShadow=!1,this.gaugeOptions.needleStart=75,this.gaugeOptions.needleEnd=95,this.gaugeOptions.needleCircleSize=1,this.gaugeOptions.needleCircleInner=!1,this.gaugeOptions.needleCircleOuter=!1,this.gaugeOptions.borders=!0,this.gaugeOptions.borderOuterWidth=2,this.gaugeOptions.borderMiddleWidth=1,this.gaugeOptions.borderInnerWidth=0,this.gaugeOptions.borderShadowWidth=0,this.gaugeOptions.animationTarget=this.ANIMATION_TARGET_NEEDLE,this.gaugeOptions.useMinPath=!1}configureMeasuringGauge(){let e=this.widgetProperties.config.paths.gaugePath.convertUnitTo,t=Ho(this.widgetProperties.config.displayScale.lower,this.widgetProperties.config.displayScale.upper);this.gaugeOptions.minValue=t.min,this.gaugeOptions.maxValue=t.max,this.gaugeOptions.units=this.widgetProperties.config.paths.gaugePath.convertUnitTo,this.gaugeOptions.fontTitleSize=24,this.gaugeOptions.barProgress=!0,this.gaugeOptions.barWidth=15,this.gaugeOptions.valueBox=!0,this.gaugeOptions.fontValueSize=60,this.gaugeOptions.valueBoxWidth=100,this.gaugeOptions.valueBoxBorderRadius=0,this.gaugeOptions.valueBoxStroke=0,this.gaugeOptions.colorValueBoxBackground="",this.gaugeOptions.exactTicks=!1,this.gaugeOptions.majorTicks=t.majorTicks,this.gaugeOptions.minorTicks=2,this.gaugeOptions.ticksAngle=270,this.gaugeOptions.startAngle=45,this.gaugeOptions.strokeTicks=!0,this.gaugeOptions.numbersMargin=3,this.gaugeOptions.fontNumbersSize=15,this.gaugeOptions.needle=!0,this.gaugeOptions.needleType=this.LINE,this.gaugeOptions.needleWidth=2,this.gaugeOptions.needleShadow=!1,this.gaugeOptions.needleStart=0,this.gaugeOptions.needleEnd=95,this.gaugeOptions.needleCircleSize=10,this.gaugeOptions.needleCircleInner=!1,this.gaugeOptions.needleCircleOuter=!1,this.gaugeOptions.borders=!0,this.gaugeOptions.borderOuterWidth=2,this.gaugeOptions.borderMiddleWidth=1,this.gaugeOptions.borderInnerWidth=0,this.gaugeOptions.borderShadowWidth=0,this.gaugeOptions.animationTarget=this.ANIMATION_TARGET_NEEDLE,this.gaugeOptions.useMinPath=!1}setHighlights(e){let t=[],i=[...e].sort((a,l)=>a.lower-l.lower);for(let a of i){let l=null,d=null,f;switch(a.state){case te.Emergency:f=this.theme().zoneEmergency;break;case te.Alarm:f=this.theme().zoneAlarm;break;case te.Warn:f=this.theme().zoneWarn;break;case te.Alert:f=this.theme().zoneAlert;break;case te.Nominal:f=this.theme().zoneNominal;break;default:f="rgba(0,0,0,0)"}if(l=this.unitsService.convertToUnit(this.widgetProperties.config.paths.gaugePath.convertUnitTo,a.lower),d=this.unitsService.convertToUnit(this.widgetProperties.config.paths.gaugePath.convertUnitTo,a.upper),!(d<this.widgetProperties.config.displayScale.lower||l>this.widgetProperties.config.displayScale.upper)){if(l=l!==null?l:this.widgetProperties.config.displayScale.lower,d=d!==null?d:this.widgetProperties.config.displayScale.upper,l=Math.max(l,this.widgetProperties.config.displayScale.lower),d>this.widgetProperties.config.displayScale.upper){d=this.widgetProperties.config.displayScale.upper,t.push({from:l,to:d,color:f});break}t.push({from:l,to:d,color:f})}}let o={};o.highlightsWidth=this.widgetProperties.config.gauge.highlightsWidth,o.highlights=JSON.stringify(t,null,1),this.ngGauge.update(o)}ngOnDestroy(){this.destroyDataStreams(),this.metaSub?.unsubscribe(),this.ngGauge=null,this.gauge=null}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-gauge-ng-radial"]],viewQuery:function(t,i){if(t&1&&(Je(hh,7),Je(hh,7,Me)),t&2){let o;Ge(o=je())&&(i.ngGauge=o.first),Ge(o=je())&&(i.gauge=o.first)}},features:[pe],decls:3,vars:5,consts:[["radialGauge",""],[3,"configChange","config","id"],[3,"onResize","id","options","value"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"radial-gauge",2,0),V("onResize",function(l){return z(o),L(i.onResized(l))}),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),di("id",i.widgetProperties.uuid),G("options",i.gaugeOptions)("value",i.value))},dependencies:[Ne,tt,et,hr,Fo],styles:["radial-gauge{display:block;position:relative;width:100%;height:100%} radial-gauge>canvas{display:block;position:absolute;height:100%;width:100%;left:50%;top:50%;transform:translate(-50%,-50%);padding:0}"]})}return r})();var gs={darkGray:steelseries.BackgroundColor.DARK_GRAY,satinGray:steelseries.BackgroundColor.SATIN_GRAY,lightGray:steelseries.BackgroundColor.LIGHT_GRAY,white:steelseries.BackgroundColor.WHITE,black:steelseries.BackgroundColor.BLACK,beige:steelseries.BackgroundColor.BEIGE,brown:steelseries.BackgroundColor.BROWN,red:steelseries.BackgroundColor.RED,green:steelseries.BackgroundColor.GREEN,blue:steelseries.BackgroundColor.BLUE,anthracite:steelseries.BackgroundColor.ANTHRACITE,mud:steelseries.BackgroundColor.MUD,punchedSheet:steelseries.BackgroundColor.PUNCHED_SHEET,carbon:steelseries.BackgroundColor.CARBON,stainless:steelseries.BackgroundColor.STAINLESS,brushedMetal:steelseries.BackgroundColor.BRUSHED_METAL,brushedStainless:steelseries.BackgroundColor.BRUSHED_STAINLESS,turned:steelseries.BackgroundColor.TURNED},vs={blackMetal:steelseries.FrameDesign.BLACK_METAL,metal:steelseries.FrameDesign.METAL,shinyMetal:steelseries.FrameDesign.SHINY_METAL,brass:steelseries.FrameDesign.BRASS,steel:steelseries.FrameDesign.STEEL,chrome:steelseries.FrameDesign.CHROME,gold:steelseries.FrameDesign.GOLD,anthracite:steelseries.FrameDesign.ANTHRACITE,tiltedGray:steelseries.FrameDesign.TILTED_GRAY,tiltedBlack:steelseries.FrameDesign.TILTED_BLACK,glossyMetal:steelseries.FrameDesign.GLOSSY_METAL},mh=(()=>{class r{unitsService=M(Yn);widgetUUID=Y(void 0);subType=Y(void 0);barGauge=Y(void 0);radialSize=Y(void 0);backgroundColor=Y(void 0);frameColor=Y(void 0);minValue=Y(void 0);maxValue=Y(void 0);decimals=Y(void 0);zones=Y(void 0);title=Y(void 0);units=Y(void 0);value=Y(void 0);theme=Y(void 0,{alias:"themeColors"});gaugeStarted=!1;gauge;gaugeOptions={};paddingTop=0;ngOnInit(){this.buildOptions()}buildOptions(){this.gaugeOptions.minValue=this.minValue(),this.gaugeOptions.maxValue=this.maxValue();let e=this.decimals();this.gaugeOptions.lcdDecimals=e??2,this.gaugeOptions.titleString=this.title(),this.gaugeOptions.unitString=this.units(),this.subType()=="radial"&&(this.gaugeOptions.gaugeType=this.setGaugeType(this.radialSize()));let t=this.zones();if(t){let i=[],o=[],a=[...t].sort((l,d)=>l.lower-d.lower);for(let l of a){let d=null,f=null,s;switch(l.state){case te.Emergency:s=this.theme().zoneEmergency;break;case te.Alarm:s=this.theme().zoneAlarm;break;case te.Warn:s=this.theme().zoneWarn;break;case te.Alert:s=this.theme().zoneAlert;break;case te.Nominal:s=this.theme().zoneNominal;break;default:s="rgba(0,0,0,0)"}let c=this.units();if(c=="ratio"?(d=l.lower,f=l.upper):(d=this.unitsService.convertToUnit(c,l.lower),f=this.unitsService.convertToUnit(c,l.upper)),!(f<this.minValue()||d>this.maxValue())){if(d=d!==null?d:this.minValue(),f=f!==null?f:this.maxValue(),d=Math.max(d,this.minValue()),f>this.maxValue()){f=this.maxValue(),i.push(steelseries.Section(d,f,s));break}i.push(steelseries.Section(d,f,s))}}this.gaugeOptions.section=i,this.gaugeOptions.area=o,this.gaugeOptions.useSectionColors=!0}gs[this.backgroundColor()]&&(this.gaugeOptions.backgroundColor=gs[this.backgroundColor()]),vs[this.frameColor()]&&(this.gaugeOptions.frameDesign=vs[this.frameColor()]),this.barGauge()&&(this.gaugeOptions.valueColor=steelseries.ColorDef.GREEN),this.gaugeOptions.lcdVisible=!0,this.gaugeOptions.thresholdVisible=!1,this.gaugeOptions.threshold=this.maxValue(),this.gaugeOptions.ledVisible=!1}setGaugeType(e){switch(e){case"quarter":return steelseries.GaugeType.TYPE1;case"half":return steelseries.GaugeType.TYPE2;case"three-quarter":return steelseries.GaugeType.TYPE3;case"full":default:return steelseries.GaugeType.TYPE4}}startGauge(){this.gaugeStarted=!0,this.buildOptions();let e=this.subType();e=="radial"?this.gauge=new steelseries.Radial(this.widgetUUID(),this.gaugeOptions):e=="linear"&&(this.barGauge()?this.gauge=new steelseries.LinearBargraph(this.widgetUUID(),this.gaugeOptions):this.gauge=new steelseries.Linear(this.widgetUUID(),this.gaugeOptions))}onResized(e){if(!(e.contentRect.height<50||e.contentRect.width<50)){if(this.subType()=="radial"){let t=Math.min(e.contentRect.height,e.contentRect.width);this.gaugeOptions.size=t}else this.gaugeOptions.width=e.contentRect.width,this.gaugeOptions.height=e.contentRect.height;this.startGauge()}}ngOnChanges(e){this.gaugeStarted&&(e.value&&!e.value.firstChange&&this.gauge.setValueAnimated(e.value.currentValue),e.zones&&this.startGauge(),e.title&&this.gauge.setTitleString(e.title.currentValue),e.backgroundColor&&this.gauge.setBackgroundColor(gs[e.backgroundColor.currentValue]),e.frameColor&&this.gauge.setFrameDesign(vs[e.frameColor.currentValue]),e.radialSize&&this.startGauge(),e.minValue&&this.gauge.setMinValue(e.minValue.currentValue),e.maxValue&&this.gauge.setMaxValue(e.maxValue.currentValue))}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["gauge-steel"]],inputs:{widgetUUID:[1,"widgetUUID"],subType:[1,"subType"],barGauge:[1,"barGauge"],radialSize:[1,"radialSize"],backgroundColor:[1,"backgroundColor"],frameColor:[1,"frameColor"],minValue:[1,"minValue"],maxValue:[1,"maxValue"],decimals:[1,"decimals"],zones:[1,"zones"],title:[1,"title"],units:[1,"units"],value:[1,"value"],theme:[1,"themeColors","theme"]},features:[yi],decls:4,vars:1,consts:[["gauge",""],[1,"wrapper",3,"onResize"],[2,"z-index","inherit",3,"id"]],template:function(t,i){if(t&1){let o=ee();v(0,"div",1),V("onResize",function(l){return z(o),L(i.onResized(l))}),v(1,"canvas",2,0),T(3," Browser does not support canvas element. "),_()()}t&2&&(P(),di("id",i.widgetUUID()))},dependencies:[tt,et],styles:[".sgWrapper[_ngcontent-%COMP%]{height:100%;width:100%;text-align:center}"]})}return r})();var ph=(()=>{class r extends Re{dataValue=0;zones=[];metaSub;constructor(){super(),this.defaultConfig={displayName:"Gauge Label",filterSelfPaths:!0,paths:{gaugePath:{description:"Numeric Data",path:null,source:null,pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!0,pathSkUnitsFilter:null,convertUnitTo:"unitless",sampleTime:500}},displayScale:{type:"linear",lower:0,upper:100},gauge:{type:"steel",subType:"radial",backgroundColor:"carbon",faceColor:"anthracite",radialSize:"full",rotateFace:!1,digitalMeter:!1},numDecimal:2,enableTimeout:!1,dataTimeout:5,ignoreZones:!1}}ngOnInit(){this.validateConfig(),this.startWidget()}startWidget(){this.unsubscribeDataStream(),this.unsubscribeMetaStream(),this.metaSub?.unsubscribe(),this.observeDataStream("gaugePath",e=>{(!e||!e.data)&&(e={data:{value:0,timestamp:new Date},state:"normal"}),this.dataValue=Math.min(Math.max(e.data.value,this.widgetProperties.config.displayScale.lower),this.widgetProperties.config.displayScale.upper)}),this.widgetProperties.config.ignoreZones?this.zones=[]:(this.observeMetaStream(),this.metaSub=this.zones$.subscribe(e=>{e?e.length>0?this.zones=e:this.zones=[]:this.zones=[]}))}updateConfig(e){this.widgetProperties.config=e,this.startWidget()}ngOnDestroy(){this.destroyDataStreams(),this.metaSub?.unsubscribe()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-gauge-steel"]],features:[pe],decls:2,vars:16,consts:[[3,"configChange","config","id"],[3,"widgetUUID","subType","barGauge","radialSize","backgroundColor","frameColor","minValue","maxValue","decimals","zones","title","units","value","themeColors"]],template:function(t,i){t&1&&(v(0,"widget-host",0),Ae("configChange",function(a){return De(i.widgetProperties.config,a)||(i.widgetProperties.config=a),a}),V("configChange",function(a){return i.updateConfig(a)}),B(1,"gauge-steel",1),_()),t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),G("widgetUUID",i.widgetProperties.uuid)("subType",i.widgetProperties.config.gauge.subType)("barGauge",i.widgetProperties.config.gauge.digitalMeter)("radialSize",i.widgetProperties.config.gauge.radialSize)("backgroundColor",i.widgetProperties.config.gauge.backgroundColor)("frameColor",i.widgetProperties.config.gauge.faceColor)("minValue",i.widgetProperties.config.displayScale.lower)("maxValue",i.widgetProperties.config.displayScale.upper)("decimals",i.widgetProperties.config.numDecimal)("zones",i.zones)("title",i.widgetProperties.config.displayName)("units",i.widgetProperties.config.paths.gaugePath.convertUnitTo)("value",i.dataValue)("themeColors",i.theme()))},dependencies:[Ne,mh],styles:["[_nghost-%COMP%]{display:block;width:100%;height:100%}gauge-steel[_ngcontent-%COMP%]{display:block;position:relative;width:100%;height:100%} .wrapper{display:block;position:relative;width:100%;height:100%;padding:10px} .wrapper>canvas{display:block;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}"]})}return r})();var _f=["plainIframe"];function wf(r,n){if(r&1&&B(0,"iframe",2,0),r&2){let e=ge();G("src",e.widgetUrl,Kr)}}function kf(r,n){r&1&&(v(0,"div",3)(1,"h2"),T(2,"Empty or bad URL"),_(),v(3,"p"),T(4," IMPORTANT: cross-domain security rules (CORS) apply to this widget. "),_(),v(5,"p"),T(6,"Typically, you can load Grafana graphs, Signal K apps or other related tools. "),_()())}var fh=(()=>{class r extends Re{_sanitizer=M(Vn);_dashboard=M(st);iframe;widgetUrl=null;displayTransparentOverlay=Wn("block");constructor(){super(),this.defaultConfig={widgetUrl:null,allowInput:!1},Pe(()=>{this._dashboard.isDashboardStatic()?this.displayTransparentOverlay.set(this.widgetProperties.config.allowInput?"none":"block"):this.displayTransparentOverlay.set("block")})}ngOnInit(){this.validateConfig(),window.addEventListener("message",this.handleIframeGesture),this.displayTransparentOverlay.set(this.widgetProperties.config.allowInput?"none":"block"),this.widgetUrl=this.resolveUrl(this.widgetProperties.config.widgetUrl)}ngAfterViewInit(){this.iframe&&(this.iframe.nativeElement.onload=()=>this.injectHammerJS())}startWidget(){}ngOnDestroy(){window.removeEventListener("message",this.handleIframeGesture)}handleIframeGesture=e=>{if(e.data){if(e.data.gesture&&e.data.eventData.instanceId===this.widgetProperties.uuid)switch(e.data.gesture){case"swipeup":this._dashboard.previousDashboard();break;case"swipedown":this._dashboard.nextDashboard();break;case"swipeleft":let t=new Event("openLeftSidenav",{bubbles:!0,cancelable:!0});window.document.dispatchEvent(t);break;case"swiperight":let i=new Event("openRightSidenav",{bubbles:!0,cancelable:!0});window.document.dispatchEvent(i);break;default:break}if(e.data.type==="keydown"&&e.data.keyEventData.instanceId===this.widgetProperties.uuid){let{key:t,ctrlKey:i,shiftKey:o}=e.data.keyEventData,a=new KeyboardEvent("keydown",{key:t,ctrlKey:i,shiftKey:o,bubbles:!0,cancelable:!0});document.dispatchEvent(a)}}};injectHammerJS(){let e=document.getElementsByTagName("base")[0]?.href||"/",t=this.iframe.nativeElement.contentWindow,i=this.iframe.nativeElement.contentDocument;if(!i||!t){console.error("[WidgetIframe] Iframe contentDocument or contentWindow is undefined. Possible cross-origin issue or iframe not fully loaded.");return}if(t.Hammer){console.log("[WidgetIframe] HammerJS already loaded in iframe");return}let o=i.createElement("script");o.src=`${e}assets/hammer.min.js`,o.onload=()=>this.injectSwipeHandler(),i.body.appendChild(o)}injectSwipeHandler(){let e=this.iframe.nativeElement.contentDocument;if(!e){console.error("[WidgetIframe] Iframe contentDocument is undefined. Possible cross-origin issue or iframe not fully loaded.");return}let t=e.createElement("script");t.textContent=`
|
|
120
|
+
if (!window.hammerInstance) {
|
|
121
|
+
const hammer = new Hammer(document.body);
|
|
122
|
+
hammer.get('swipe').set({ direction: Hammer.DIRECTION_ALL, velocity: 1.5, threshold: 200, domEvents: true });
|
|
123
|
+
|
|
124
|
+
const instanceId = '${this.widgetProperties.uuid}'; // Include the instance ID in the script to prevent multiple listeners
|
|
125
|
+
|
|
126
|
+
hammer.on('swipeleft', (ev) => {
|
|
127
|
+
ev.preventDefault();
|
|
128
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
129
|
+
const eventData = {
|
|
130
|
+
type: ev.type,
|
|
131
|
+
deltaX: ev.deltaX,
|
|
132
|
+
deltaY: ev.deltaY,
|
|
133
|
+
velocityX: ev.velocityX,
|
|
134
|
+
velocityY: ev.velocityY,
|
|
135
|
+
direction: ev.direction,
|
|
136
|
+
distance: ev.distance,
|
|
137
|
+
angle: ev.angle,
|
|
138
|
+
center: ev.center,
|
|
139
|
+
offsetDirection: ev.offsetDirection,
|
|
140
|
+
scale: ev.scale,
|
|
141
|
+
rotation: ev.rotation,
|
|
142
|
+
isFinal: ev.isFinal,
|
|
143
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
144
|
+
};
|
|
145
|
+
window.parent.postMessage({ gesture: 'swipeleft', eventData: eventData }, '*');
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
hammer.on('swiperight', (ev) => {
|
|
149
|
+
ev.preventDefault();
|
|
150
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
151
|
+
const eventData = {
|
|
152
|
+
type: ev.type,
|
|
153
|
+
deltaX: ev.deltaX,
|
|
154
|
+
deltaY: ev.deltaY,
|
|
155
|
+
velocityX: ev.velocityX,
|
|
156
|
+
velocityY: ev.velocityY,
|
|
157
|
+
direction: ev.direction,
|
|
158
|
+
distance: ev.distance,
|
|
159
|
+
angle: ev.angle,
|
|
160
|
+
center: ev.center,
|
|
161
|
+
offsetDirection: ev.offsetDirection,
|
|
162
|
+
scale: ev.scale,
|
|
163
|
+
rotation: ev.rotation,
|
|
164
|
+
isFinal: ev.isFinal,
|
|
165
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
166
|
+
};
|
|
167
|
+
window.parent.postMessage({ gesture: 'swiperight', eventData: eventData }, '*');
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
hammer.on('swipeup', (ev) => {
|
|
171
|
+
ev.preventDefault();
|
|
172
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
173
|
+
const eventData = {
|
|
174
|
+
type: ev.type,
|
|
175
|
+
deltaX: ev.deltaX,
|
|
176
|
+
deltaY: ev.deltaY,
|
|
177
|
+
velocityX: ev.velocityX,
|
|
178
|
+
velocityY: ev.velocityY,
|
|
179
|
+
direction: ev.direction,
|
|
180
|
+
distance: ev.distance,
|
|
181
|
+
angle: ev.angle,
|
|
182
|
+
center: ev.center,
|
|
183
|
+
offsetDirection: ev.offsetDirection,
|
|
184
|
+
scale: ev.scale,
|
|
185
|
+
rotation: ev.rotation,
|
|
186
|
+
isFinal: ev.isFinal,
|
|
187
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
188
|
+
};
|
|
189
|
+
window.parent.postMessage({ gesture: 'swipeup', eventData: eventData }, '*');
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
hammer.on('swipedown', (ev) => {
|
|
193
|
+
ev.preventDefault();
|
|
194
|
+
ev.srcEvent.stopPropagation(); // Stop propagation to prevent FSK from handling the gesture
|
|
195
|
+
const eventData = {
|
|
196
|
+
type: ev.type,
|
|
197
|
+
deltaX: ev.deltaX,
|
|
198
|
+
deltaY: ev.deltaY,
|
|
199
|
+
velocityX: ev.velocityX,
|
|
200
|
+
velocityY: ev.velocityY,
|
|
201
|
+
direction: ev.direction,
|
|
202
|
+
distance: ev.distance,
|
|
203
|
+
angle: ev.angle,
|
|
204
|
+
center: ev.center,
|
|
205
|
+
offsetDirection: ev.offsetDirection,
|
|
206
|
+
scale: ev.scale,
|
|
207
|
+
rotation: ev.rotation,
|
|
208
|
+
isFinal: ev.isFinal,
|
|
209
|
+
instanceId: instanceId // Include the instance ID in the event data
|
|
210
|
+
};
|
|
211
|
+
window.parent.postMessage({ gesture: 'swipedown', eventData: eventData }, '*');
|
|
212
|
+
});
|
|
213
|
+
|
|
214
|
+
// Add keydown listener
|
|
215
|
+
document.addEventListener('keydown', (event) => {
|
|
216
|
+
if (event.ctrlKey && event.shiftKey && ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown', 'E', 'F', 'N'].includes(event.key)) {
|
|
217
|
+
const keyEventData = {
|
|
218
|
+
key: event.key,
|
|
219
|
+
ctrlKey: event.ctrlKey,
|
|
220
|
+
shiftKey: event.shiftKey,
|
|
221
|
+
instanceId: instanceId
|
|
222
|
+
};
|
|
223
|
+
window.parent.postMessage({ type: 'keydown', keyEventData: keyEventData }, '*');
|
|
224
|
+
}
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
window.hammerInstance = hammer; // Store the instance to prevent multiple listeners
|
|
228
|
+
}
|
|
229
|
+
`,e.body.appendChild(t)}updateConfig(e){this.widgetUrl=this.resolveUrl(e.widgetUrl)}isValidProtocol(e){try{let t=new URL(e);return t.protocol==="http:"||t.protocol==="https:"}catch{return console.warn("[Embed Widget] isValidUrl: Invalid URL:",e),!1}}resolveUrl(e){if(!e)return null;try{let t=new URL(e,window.location.origin);return this.isValidProtocol(t.href)?this._sanitizer.bypassSecurityTrustResourceUrl(t.href):null}catch{return console.warn("[Embed Widget] Invalid URL:",e),null}}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-iframe"]],viewQuery:function(t,i){if(t&1&&Je(_f,5),t&2){let o;Ge(o=je())&&(i.iframe=o.first)}},features:[pe],decls:4,vars:5,consts:[["plainIframe",""],[2,"overflow","hidden",3,"configChange","config","id"],["width","100%","height","100%","frameborder","0",1,"widgetIframe",3,"src"],[2,"padding","15px"],[1,"widgetOverlay"]],template:function(t,i){t&1&&(v(0,"widget-host",1),Ae("configChange",function(a){return De(i.widgetProperties.config,a)||(i.widgetProperties.config=a),a}),V("configChange",function(a){return i.updateConfig(a)}),Te(1,wf,2,1,"iframe",2)(2,kf,7,0,"div",3),B(3,"div",4),_()),t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),Ue(i.widgetUrl?1:2),P(2),He("display",i.displayTransparentOverlay()))},dependencies:[Ne],styles:[".widgetIframe[_ngcontent-%COMP%]{background-color:#fff;border-radius:var(--mdc-elevated-card-container-shape, var(--mat-sys-corner-medium))}.widgetOverlay[_ngcontent-%COMP%]{position:absolute;width:100%;height:100%;right:0;bottom:0;color:transparent}"]})}return r})();var Sf=["canvasValue"],gh=(()=>{class r extends Re{canvasValue=le.required("canvasValue");canvas=M(xt);latPos="";longPos="";labelColor=void 0;valueColor=void 0;maxTextWidth=0;maxTextHeight=0;middle=0;center=0;fontSizeOffset=0;canvasValCtx;isDestroyed=!1;constructor(){super(),this.defaultConfig={displayName:"Position",filterSelfPaths:!0,paths:{longPath:{description:"Longitude",path:"self.navigation.position.longitude",source:"default",pathType:"number",isPathConfigurable:!0,convertUnitTo:"longitudeMin",showPathSkUnitsFilter:!0,pathSkUnitsFilter:null,sampleTime:500},latPath:{description:"Latitude",path:"self.navigation.position.latitude",source:"default",pathType:"number",isPathConfigurable:!0,convertUnitTo:"latitudeMin",showPathSkUnitsFilter:!0,pathSkUnitsFilter:null,sampleTime:500}},color:"contrast",enableTimeout:!1,dataTimeout:5},Pe(()=>{this.theme()&&(this.getColors(this.widgetProperties.config.color),this.drawValue())})}ngOnInit(){this.validateConfig()}ngAfterViewInit(){this.canvas.setHighDPISize(this.canvasValue().nativeElement,this.canvasValue().nativeElement.parentElement.getBoundingClientRect()),this.maxTextHeight=Math.floor(this.canvasValue().nativeElement.height*.6/2),this.maxTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.canvasValCtx=this.canvasValue().nativeElement.getContext("2d"),this.calculateFontSizeAndPositions(),!this.isDestroyed&&this.startWidget()}startWidget(){this.unsubscribeDataStream(),this.observeDataStream("longPath",e=>{this.longPos=e.data.value?e.data.value.toString():"",this.drawValue()}),this.observeDataStream("latPath",e=>{this.latPos=e.data.value?e.data.value.toString():"",this.drawValue()})}ngOnDestroy(){this.isDestroyed=!0,this.unsubscribeDataStream(),this.canvas.clearCanvas(this.canvasValCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),this.canvasValue().nativeElement.remove()}updateConfig(e){this.widgetProperties.config=e,this.getColors(this.widgetProperties.config.color),this.startWidget()}onResized(e){e.contentRect.height<25||e.contentRect.width<25||(this.canvas.setHighDPISize(this.canvasValue().nativeElement,this.canvasValue().nativeElement.parentElement.getBoundingClientRect()),this.maxTextHeight=Math.floor(this.canvasValue().nativeElement.height*.6/2),this.maxTextWidth=Math.floor(this.canvasValue().nativeElement.width*.85),this.calculateFontSizeAndPositions(),this.drawValue())}getColors(e){switch(e){case"white":this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break;case"blue":this.labelColor=this.theme().blueDim,this.valueColor=this.theme().blue;break;case"green":this.labelColor=this.theme().greenDim,this.valueColor=this.theme().green;break;case"pink":this.labelColor=this.theme().pinkDim,this.valueColor=this.theme().pink;break;case"orange":this.labelColor=this.theme().orangeDim,this.valueColor=this.theme().orange;break;case"purple":this.labelColor=this.theme().purpleDim,this.valueColor=this.theme().purple;break;case"grey":this.labelColor=this.theme().greyDim,this.valueColor=this.theme().grey;break;case"yellow":this.labelColor=this.theme().yellowDim,this.valueColor=this.theme().yellow;break;default:this.labelColor=this.theme().contrastDim,this.valueColor=this.theme().contrast;break}}calculateFontSizeAndPositions(){this.center=this.canvasValue().nativeElement.width/2,this.middle=this.canvasValue().nativeElement.height*.57;let e=this.latPos.length>this.longPos.length?this.latPos:this.longPos,t=this.canvas.calculateOptimalFontSize(this.canvasValCtx,e,this.maxTextWidth,this.maxTextHeight,"bold");this.fontSizeOffset=Math.floor(t*5e-4)}drawValue(){this.canvasValCtx&&(this.canvas.clearCanvas(this.canvasValCtx,this.canvasValue().nativeElement.width,this.canvasValue().nativeElement.height),this.canvas.drawText(this.canvasValCtx,this.latPos,this.center,this.middle-this.fontSizeOffset,this.maxTextWidth,this.maxTextHeight,"bold",this.valueColor,"center","bottom"),this.canvas.drawText(this.canvasValCtx,this.longPos,this.center,this.middle+this.fontSizeOffset,this.maxTextWidth,this.maxTextHeight,"bold",this.valueColor,"center","top"))}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-position"]],viewQuery:function(t,i){t&1&&de(i.canvasValue,Sf,5),t&2&&Qe()},features:[pe],decls:5,vars:4,consts:[["canvasValue",""],[3,"configChange","config","id"],[3,"text","color"],[1,"textGenericWrapper",3,"onResize"],[1,"canvas"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),B(1,"widget-title",2),v(2,"div",3),V("onResize",function(l){return z(o),L(i.onResized(l))}),B(3,"canvas",4,0),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),G("text",i.widgetProperties.config.displayName)("color",i.labelColor))},dependencies:[Ne,tt,et,ai],styles:[".textGenericWrapper[_ngcontent-%COMP%]{position:relative;width:100%;height:100%}.canvas[_ngcontent-%COMP%]{position:absolute;top:0;left:0;z-index:inherit}"]})}return r})();var Uo=(()=>{class r{kipTimers={};constructor(){}createTimer(e,t,i){return e in this.kipTimers?this.kipTimers[e].currentValue.asObservable():(this.kipTimers[e]={currentValue:new Ri(t),timeoutID:null,intervalMS:i},this.kipTimers[e].currentValue.asObservable())}startTimer(e){this.kipTimers.hasOwnProperty(e)&&this.kipTimers[e].timeoutID===null&&(this.kipTimers[e].timeoutID=setInterval(()=>{this.kipTimers[e].currentValue.next(this.kipTimers[e].currentValue.value+1)},this.kipTimers[e].intervalMS))}stopTimer(e){this.kipTimers.hasOwnProperty(e)&&this.kipTimers[e].timeoutID!==null&&(clearInterval(this.kipTimers[e].timeoutID),this.kipTimers[e].timeoutID=null)}setTimer(e,t){this.kipTimers.hasOwnProperty(e)&&this.kipTimers[e].currentValue.next(t)}deleteTimer(e){this.kipTimers.hasOwnProperty(e)&&(this.stopTimer(e),this.kipTimers[e].currentValue.complete(),delete this.kipTimers[e])}isRunning(e){let t=!1;return e in this.kipTimers&&(t=this.kipTimers[e].timeoutID!==null),t}static \u0275fac=function(t){return new(t||r)};static \u0275prov=ot({token:r,factory:r.\u0275fac,providedIn:"root"})}return r})();var Cf=["canvasEl"];function xf(r,n){if(r&1){let e=ee();v(0,"button",12),V("click",function(){z(e);let i=ge();return L(i.startTimer())}),T(1," Start "),_()}}function Tf(r,n){if(r&1){let e=ee();v(0,"button",13),V("click",function(){z(e);let i=ge();return L(i.pauseTimer())}),T(1," Pause "),_()}}var vh=(()=>{class r extends Re{TimersService=M(Uo);canvas=M(xt);canvasEl=le("canvasEl");dataValue=null;zoneState=null;currentValueLength=0;valueFontSize=1;flashOn=!1;flashInterval=null;timerRunning=!1;timeName="race";warnColor=null;warmContrast=null;textColor=null;timerSub=null;canvasCtx=null;constructor(){super(),this.defaultConfig={timerLength:300,color:"contrast"},Pe(()=>{this.theme()&&(this.getColors(this.widgetProperties.config.color),this.updateCanvas())})}ngOnInit(){this.validateConfig(),this.subscribeTimer(),this.startWidget()}startWidget(){this.getColors(this.widgetProperties.config.color),this.canvasCtx=this.canvasEl().nativeElement.getContext("2d")}updateConfig(e){this.widgetProperties.config=e,this.startWidget(),this.updateCanvas()}onResized(e){e.contentRect.height<50||e.contentRect.width<50||(this.canvasEl().nativeElement.width!=Math.floor(e.contentRect.width)||this.canvasEl().nativeElement.height!=Math.floor(e.contentRect.height))&&(this.canvasEl().nativeElement.width=Math.floor(e.contentRect.width),this.canvasEl().nativeElement.height=Math.floor(e.contentRect.height/2),this.currentValueLength=0,this.updateCanvas())}subscribeTimer(){this.timerRunning=this.TimersService.isRunning(this.timeName);let e=this.widgetProperties.config.timerLength*-1*10;this.timerSub=this.TimersService.createTimer(this.timeName,-3e3,100).subscribe(t=>{this.dataValue=t,t>0?this.zoneState=te.Normal:t>-100?this.zoneState=te.Alarm:t>-300?this.zoneState=te.Warn:this.zoneState=te.Normal,this.zoneState==te.Alarm&&!this.flashInterval?this.flashInterval=setInterval(()=>{this.flashOn=!this.flashOn,this.updateCanvas()},500):this.zoneState!=te.Alarm&&clearInterval(this.flashInterval),this.updateCanvas()})}startTimer(){this.TimersService.startTimer(this.timeName),this.timerRunning=!0}resetTimer(){this.unsubscribeTimer(),this.TimersService.deleteTimer(this.timeName),this.timerRunning=!1,this.subscribeTimer()}pauseTimer(){this.TimersService.stopTimer(this.timeName),this.timerRunning=!1}roundToMin(){let e=this.dataValue;this.dataValue<0&&(e=e*-1);let t=e%600;this.dataValue>0?t>300?this.TimersService.setTimer(this.timeName,this.dataValue+(600-t)):this.TimersService.setTimer(this.timeName,this.dataValue-t):t>300?this.TimersService.setTimer(this.timeName,this.dataValue-(600-t)):this.TimersService.setTimer(this.timeName,this.dataValue+t)}addOneMin(){this.TimersService.setTimer(this.timeName,this.dataValue+600)}remOneMin(){this.TimersService.setTimer(this.timeName,this.dataValue-600)}getColors(e){switch(e){case"contrast":this.textColor=this.theme().contrast,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;case"blue":this.textColor=this.theme().blue,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;case"green":this.textColor=this.theme().green,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;case"pink":this.textColor=this.theme().pink,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;case"orange":this.textColor=this.theme().orange,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;case"purple":this.textColor=this.theme().purple,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;case"grey":this.textColor=this.theme().grey,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;case"yellow":this.textColor=this.theme().yellow,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break;default:this.textColor=this.theme().contrast,this.warnColor=this.theme().zoneAlarm,this.warmContrast=this.theme().zoneAlarm;break}}unsubscribeTimer(){this.timerSub?.unsubscribe()}ngOnDestroy(){this.timerSub?.unsubscribe(),this.canvasCtx&&this.canvas.clearCanvas(this.canvasCtx,this.canvasEl().nativeElement.width,this.canvasEl().nativeElement.height),clearInterval(this.flashInterval),this.destroyDataStreams()}updateCanvas(){this.canvasCtx&&(this.canvas.clearCanvas(this.canvasCtx,this.canvasEl().nativeElement.width,this.canvasEl().nativeElement.height),this.drawValue())}drawValue(){let e=this.canvasEl().nativeElement,t=Math.floor(e.width*.95),i=Math.floor(e.height),o;if(this.dataValue!=null){let a=Math.abs(this.dataValue),l=Math.floor(a/600),d=Math.floor(a%600/10),f=Math.floor(a%10);o=`${l}:${("0"+d).slice(-2)}.${f}`,this.dataValue<0&&(o=`-${o}`)}else o="--";switch(this.currentValueLength!==o.length&&(this.currentValueLength=o.length,this.valueFontSize=this.canvas.calculateOptimalFontSize(this.canvasCtx,o,t,i,"bold")),this.zoneState){case te.Alarm:this.flashOn?this.canvasCtx.fillStyle=this.textColor:(this.canvas.drawRectangle(this.canvasCtx,0,0,e.width,e.height,this.warnColor),this.canvasCtx.fillStyle=this.textColor);break;case te.Warn:this.canvasCtx.fillStyle=this.warnColor;break;default:this.canvasCtx.fillStyle=this.textColor}this.canvas.drawText(this.canvasCtx,o,e.width/2,e.height/2,t,i,"bold",this.canvasCtx.fillStyle,"center","middle")}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-racetimer"]],viewQuery:function(t,i){t&1&&de(i.canvasEl,Cf,5),t&2&&Qe()},features:[pe],decls:17,vars:4,consts:[["canvasEl",""],[3,"configChange","config","id"],[1,"raceWrapper",3,"onResize"],["id","canvasValue",1,"canvas-size"],[1,"timerBarContainer"],[1,"timer-button-groups","timer-adjusters-group"],["mat-flat-button","",1,"timer-adjust-buttons",3,"click"],["mat-flat-button","",1,"timer-reset-button",3,"click"],[1,"timer-button-groups","timer-countdown-group"],["mat-flat-button","","class","timer-start-button button-color-red",3,"click",4,"ngIf"],["mat-flat-button","","class","timer-start-button",3,"click",4,"ngIf"],["mat-flat-button","",1,"timer-synch-button","button-color-red",3,"click"],["mat-flat-button","",1,"timer-start-button","button-color-red",3,"click"],["mat-flat-button","",1,"timer-start-button",3,"click"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"div",2),V("onResize",function(l){return z(o),L(i.onResized(l))}),B(2,"canvas",3,0),v(4,"div",4)(5,"div",5)(6,"button",6),V("click",function(){return z(o),L(i.remOneMin())}),T(7," -1 "),_(),v(8,"button",7),V("click",function(){return z(o),L(i.resetTimer())}),T(9," Reset "),_(),v(10,"button",6),V("click",function(){return z(o),L(i.addOneMin())}),T(11," +1 "),_()(),v(12,"div",8),Te(13,xf,2,0,"button",9)(14,Tf,2,0,"button",10),v(15,"button",11),V("click",function(){return z(o),L(i.roundToMin())}),T(16," Synch "),_()()()()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(13),G("ngIf",!i.timerRunning),P(),G("ngIf",i.timerRunning))},dependencies:[Ne,tt,et,ii,Li],styles:[".raceWrapper[_ngcontent-%COMP%]{height:100%;width:100%}.canvas-size[_ngcontent-%COMP%]{position:absolute;width:100%;height:50%;top:0;left:0;z-index:inherit}.button-color-red[_ngcontent-%COMP%]{--mdc-filled-button-container-color: var(--kip-port-color);--mdc-filled-button-label-text-color: var(--kip-contrast-color)}.timerBarContainer[_ngcontent-%COMP%]{position:absolute;left:0;bottom:8%;height:auto;width:calc(100% - 20px);margin:0 10px;display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:stretch;align-content:stretch;gap:20px}.timer-button-groups[_ngcontent-%COMP%]{min-width:247px;max-width:100%;--mdc-filled-button-container-shape: 5px}.timer-adjusters-group[_ngcontent-%COMP%]{flex-grow:1;flex-shrink:1}.timer-countdown-group[_ngcontent-%COMP%]{flex-grow:3;flex-shrink:3}.timer-synch-button[_ngcontent-%COMP%]{width:calc(50% - 5px);margin-left:5px}.timer-start-button[_ngcontent-%COMP%]{width:calc(50% - 5px);margin-right:5px}.timer-reset-button[_ngcontent-%COMP%]{width:calc(40% + -0px);margin:0 10px}.timer-adjust-buttons[_ngcontent-%COMP%]{width:calc(30% - 10px)}"]})}return r})();var Ef=["gaugeBarAnimate"],yh=(()=>{class r{gaugeBarAnimate;displayName=Y.required();displayNameColor=Y.required();dataValue=Y.required();unitLabel=Y.required();barColor=Y.required();barColorGradient=Y.required();barColorBackground=Y.required();gaugeValue=Y.required();gaugeMinValue=Y.required();gaugeMaxValue=Y.required();newGaugeValue=1;oldGaugeValue=1;constructor(){}ngOnChanges(e){if(e.gaugeValue&&!e.gaugeValue.firstChange){let t=this.gaugeMaxValue()-this.gaugeMinValue(),i=t!==0?195/t:0;this.oldGaugeValue=this.newGaugeValue,this.newGaugeValue=(e.gaugeValue.currentValue-this.gaugeMinValue())*i,this.gaugeBarAnimate?.nativeElement&&requestAnimationFrame(()=>{this.gaugeBarAnimate?.nativeElement&&this.gaugeBarAnimate.nativeElement.beginElement()})}}ngOnDestroy(){this.gaugeBarAnimate=null}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["svg-simple-linear-gauge"]],viewQuery:function(t,i){if(t&1&&Je(Ef,5),t&2){let o;Ge(o=je())&&(i.gaugeBarAnimate=o.first)}},inputs:{displayName:[1,"displayName"],displayNameColor:[1,"displayNameColor"],dataValue:[1,"dataValue"],unitLabel:[1,"unitLabel"],barColor:[1,"barColor"],barColorGradient:[1,"barColorGradient"],barColorBackground:[1,"barColorBackground"],gaugeValue:[1,"gaugeValue"],gaugeMinValue:[1,"gaugeMinValue"],gaugeMaxValue:[1,"gaugeMaxValue"]},features:[yi],decls:24,vars:11,consts:[["gaugeBarAnimate",""],[0,"xmlns","osb","http://www.openswatchbook.org/uri/2009/osb",0,"xmlns","dc","http://purl.org/dc/elements/1.1/",0,"xmlns","cc","http://creativecommons.org/ns#",0,"xmlns","rdf","http://www.w3.org/1999/02/22-rdf-syntax-ns#",0,"xmlns","svg","http://www.w3.org/2000/svg","xmlns","http://www.w3.org/2000/svg",0,"xmlns","xlink","http://www.w3.org/1999/xlink","viewBox","0 0 205 50","preserveAspectRatio","xMidYMid","version","1.1","id","svg8",1,"svg-simple-linear"],["id","defs2"],["id","gaugeBarGradient"],["id","stop849","offset","0",2,"stop-opacity","1"],["id","stop851","offset","0.40",2,"stop-opacity","0"],["id","linearGradient855","gradientTransform","translate(5,-30)","gradientUnits","userSpaceOnUse","y2","34.5","x2","-5","y1","34.5","x1","-6","href","#gaugeBarGradient"],["id","layer1",2,"display","inline"],["id","GaugeBackground","width","195","height","9","x","5","y","30","ry","0",2,"opacity","1","fill-opacity","1","stroke","none","stroke-width","0.265899","stroke-miterlimit","4","stroke-dasharray","none","stroke-opacity","1"],["id","gaugeBar"],["id","gaugeValue","width","1","height","9","x","0","y","0","ry","0",2,"mix-blend-mode","normal","fill-opacity","1","stroke-width","0.0864229"],["id","gaugeValueGradient","transform","scale(-1,1)","width","1","height","9","x","-1","y","0","ry","0",2,"display","inline","opacity","1","mix-blend-mode","multiply","fill","url(#linearGradient855)","stroke-width","0.0864229"],[0,"xlink","href","#gaugeBar","transform","translate(5,30)"],["attributeName","transform","type","scale","begin","indefinite","dur","0.5s","additive","sum","fill","freeze"],["id","layer2",2,"display","inline"],[0,"xml","space","preserve","x","4.1731763","y","25.413595","id","displayNameText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","12.7px","line-height","1.25","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","letter-spacing","0px","word-spacing","0px"],["id","tspan1945","x","4.1731763","y","25.413595",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","12.7px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"],["text-anchor","end","id","gaugeTexts","y","25.293016","x","200.37138",0,"xml","space","preserve",1,"simpleLinear-text",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","22.5778px","line-height","1.25","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","letter-spacing","0px","word-spacing","0px"],["y","25.293016","x","200.37138","id","valueText",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","22.5778px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal"],["dy","-9","id","unitText",2,"text-transform","capitalize","font-size","9.87778px"]],template:function(t,i){t&1&&(Dt(),v(0,"svg",1)(1,"defs",2)(2,"linearGradient",3),B(3,"stop",4)(4,"stop",5),_(),B(5,"linearGradient",6),_(),v(6,"g",7),B(7,"rect",8),v(8,"defs")(9,"g",9),B(10,"rect",10)(11,"rect",11),_()(),v(12,"use",12),B(13,"animateTransform",13,0),_()(),v(15,"g",14)(16,"text",15)(17,"tspan",16),T(18),_()(),v(19,"text",17)(20,"tspan",18),T(21),_(),v(22,"tspan",19),T(23),_()()()()),t&2&&(P(3),fe("stop-color",i.barColorGradient()),P(),fe("stop-color",i.barColorGradient()),P(3),fe("fill",i.barColorBackground()),P(5),He("fill",i.barColor()),P(),fe("from",i.oldGaugeValue+" 1")("to",i.newGaugeValue+" 1"),P(4),fe("fill",i.displayNameColor()),P(),ut(" ",i.displayName(),""),P(3),lt(i.dataValue()),P(2),lt(i.unitLabel()))},styles:["svg[_ngcontent-%COMP%]{position:absolute;height:100%;width:100%;left:0;top:0}.simpleLinear-text[_ngcontent-%COMP%]{fill:var(--kip-contrast-color)}"]})}return r})();var bh=(()=>{class r extends Re{unitsLabel="";dataLabelValue="0";dataValue=0;barColor="";barColorGradient="";barColorBackground="";constructor(){super(),this.defaultConfig={displayName:"Gauge Label",filterSelfPaths:!0,paths:{gaugePath:{description:"Numeric Data",path:null,source:null,pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!0,pathSkUnitsFilter:"V",convertUnitTo:"V",sampleTime:500}},displayScale:{lower:0,upper:15,type:"linear"},gauge:{type:"simpleLinear",unitLabelFormat:"full"},numInt:1,numDecimal:2,color:"contrast",enableTimeout:!1,dataTimeout:5},Pe(()=>{this.theme()&&this.updateGaugeSettings()})}ngOnInit(){this.validateConfig(),this.startWidget()}startWidget(){this.widgetProperties.config.gauge.unitLabelFormat=="abr"?this.unitsLabel=this.widgetProperties.config.paths.gaugePath.convertUnitTo.substr(0,1):this.unitsLabel=this.widgetProperties.config.paths.gaugePath.convertUnitTo,this.unsubscribeDataStream(),this.observeDataStream("gaugePath",e=>{e.data.value==null?(this.dataValue=0,this.dataLabelValue="--"):(this.dataValue=Math.min(Math.max(e.data.value,this.widgetProperties.config.displayScale.lower),this.widgetProperties.config.displayScale.upper),this.dataLabelValue=this.dataValue.toFixed(this.widgetProperties.config.numDecimal))})}updateConfig(e){this.widgetProperties.config=e,this.startWidget(),this.updateGaugeSettings()}updateGaugeSettings(){switch(this.barColorBackground=this.theme().background,this.widgetProperties.config.color){case"contrast":this.barColor=this.theme().contrast,this.barColorGradient=this.theme().contrastDimmer;break;case"blue":this.barColor=this.theme().blue,this.barColorGradient=this.theme().blueDimmer;break;case"green":this.barColor=this.theme().green,this.barColorGradient=this.theme().greenDimmer;break;case"pink":this.barColor=this.theme().pink,this.barColorGradient=this.theme().pinkDimmer;break;case"orange":this.barColor=this.theme().orange,this.barColorGradient=this.theme().orangeDimmer;break;case"purple":this.barColor=this.theme().purple,this.barColorGradient=this.theme().purpleDimmer;break;case"grey":this.barColor=this.theme().grey,this.barColorGradient=this.theme().greyDimmer;break;case"yellow":this.barColor=this.theme().yellow,this.barColorGradient=this.theme().yellowDimmer;break;default:this.barColor=this.theme().contrast,this.barColorGradient=this.theme().contrastDimmer}}ngOnDestroy(){this.destroyDataStreams()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-simple-linear"]],features:[pe],decls:2,vars:12,consts:[[3,"configChange","config","id"],[1,"simpleLinearGaugeContainer",3,"displayName","displayNameColor","unitLabel","dataValue","barColor","barColorGradient","barColorBackground","gaugeValue","gaugeMaxValue","gaugeMinValue"]],template:function(t,i){t&1&&(v(0,"widget-host",0),Ae("configChange",function(a){return De(i.widgetProperties.config,a)||(i.widgetProperties.config=a),a}),V("configChange",function(a){return i.updateConfig(a)}),B(1,"svg-simple-linear-gauge",1),_()),t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),G("displayName",i.widgetProperties.config.displayName)("displayNameColor",i.theme().contrastDim)("unitLabel",i.unitsLabel)("dataValue",i.dataLabelValue)("barColor",i.barColor)("barColorGradient",i.barColorGradient)("barColorBackground",i.barColorBackground)("gaugeValue",i.dataLabelValue)("gaugeMaxValue",i.widgetProperties.config.displayScale.upper)("gaugeMinValue",i.widgetProperties.config.displayScale.lower))},dependencies:[Ne,yh],styles:[".simpleLinearGaugeContainer[_ngcontent-%COMP%]{display:block;position:relative;height:100%;width:100%;padding:0}"]})}return r})();function Df(r,n){if(r&1){let e=ee();v(0,"h3"),T(1,"Getting Started"),_(),v(2,"p"),T(3,"Welcome to KIP! Here are some basic gestures to help you navigate the application:"),_(),v(4,"table")(5,"tr")(6,"th"),T(7,"Actions"),_(),v(8,"th"),T(9,"Gestures"),_(),v(10,"th"),T(11,"Keyboard Shortcuts"),_()(),v(12,"tr")(13,"td"),T(14,"Cycle through dashboards"),_(),v(15,"td"),T(16,"Swipe Up/Down"),_(),v(17,"td"),T(18,"Shift + Ctrl + Up/Down Arrow"),_()(),v(19,"tr")(20,"td"),T(21,"Open Actions menu"),_(),v(22,"td"),T(23,"Swipe left"),_(),v(24,"td"),T(25,"Shift + Ctrl + Right Arrow"),_()(),v(26,"tr")(27,"td"),T(28,"Open Notification menu"),_(),v(29,"td"),T(30,"Swipe right"),_(),v(31,"td"),T(32,"Shift + Ctrl + Left Arrow"),_()()(),v(33,"h3"),T(34,"Log in to Signal K"),_(),v(35,"p"),T(36," The first step is to configure Signal K server authentication ("),v(37,"i"),T(38,"a pre-existing Signal K server user/password is required"),_(),T(39,"). Swipe left to open the Actions menu, hit Settings, toggle Login to server and enter you pre-existing Signal K credentials. "),_(),v(40,"h3"),T(41,"Option 1: Load Demonstration Dashboards"),_(),v(42,"p"),T(43," Try the sample dashboards using data from your server. : "),B(44,"br"),v(45,"button",2),V("click",function(){z(e);let i=ge();return L(i.loadDemoConfig())}),T(46,"Load Demo"),_()(),v(47,"h3"),T(48,"Option 2: Create Your Own Layout"),_(),v(49,"p"),T(50,' The text you are reading is actually a full screen widget in a dashboard. Dashboards are "Locked" by default to prevent accidental modifications. To edit a dashboard, swipe left and hit the bottom unlock menu button. You can later add and manage dashboards using the Dashboards page from the Actions menu. '),_(),v(51,"p")(52,"strong"),T(53,"Try editing the Dashboard now to receive further instructions!"),_()()}}function Af(r,n){r&1&&(v(0,"h3"),T(1,"Build Your Layout"),_(),v(2,"p"),T(3," First, resize this Tutorial widget using the now visible dashed borders so it does not take up all the screen. You can delete this Tutorial widget later when you are done with the instructions. Then, to add a widget: in an empty dashboard area, press and hold. This will open the widget selection panel. Here you can choose from a variety of widgets. "),_(),v(4,"p"),T(5,"To manage widgets, you can:"),_(),v(6,"ul")(7,"li")(8,"strong"),T(9,"Touch and drag"),_(),T(10," to move widgets"),_(),v(11,"li")(12,"strong"),T(13,"Drag corners and sides"),_(),T(14," to resize widgets"),_(),v(15,"li")(16,"strong"),T(17,"Double Tap"),_(),T(18," on a widget to configure it"),_(),v(19,"li")(20,"strong"),T(21,"Press and Hold"),_(),T(22," on a widget to delete or duplicate widgets"),_()(),v(23,"h3"),T(24,"Exit Dashboard Edit Mode"),_(),v(25,"p"),T(26,"Use the Save or Cancel buttons in the lower right corner to either persist your changes or revert changes."),_(),v(27,"h3"),T(28,"Add More Dashboards"),_(),v(29,"p"),T(30,"Swipe left and hit the Dashboards button. From this page you can add, rename, position and duplicate dashboards."),_())}var _h=(()=>{class r extends Re{dashboard=M(st);settings=M(ei);constructor(){super()}loadDemoConfig(){this.settings.loadDemoConfig()}startWidget(){}updateConfig(e){}ngOnDestroy(){this.destroyDataStreams()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-tutorial"]],features:[pe],decls:4,vars:3,consts:[[3,"configChange","config","id"],[1,"tutorial-container"],["mat-raised-button","",2,"margin-left","15px",3,"click"]],template:function(t,i){t&1&&(v(0,"widget-host",0),Ae("configChange",function(a){return De(i.widgetProperties.config,a)||(i.widgetProperties.config=a),a}),V("configChange",function(a){return i.updateConfig(a)}),v(1,"div",1),Te(2,Df,54,0)(3,Af,31,0),_()()),t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(2),Ue(i.dashboard.isDashboardStatic()?2:3))},dependencies:[Ne,ii],styles:[".tutorial-container[_ngcontent-%COMP%]{position:absolute;top:0;left:0;display:block;height:100%;width:100%;overflow:none}.tutorial-container[_ngcontent-%COMP%]{padding:0 15px}table[_ngcontent-%COMP%], th[_ngcontent-%COMP%], td[_ngcontent-%COMP%]{border:1px solid var(--mat-sys-on-background);border-collapse:collapse}tr[_ngcontent-%COMP%]:nth-child(2n){background-color:var(--mat-sys-surface-container-high)}"]})}return r})();var Pf=["compassAnimate"],Mf=["appWindAnimate"],Of=["trueWindAnimate"],If=["waypointAnimate"],Rf=["driftAnimate"],Nf=["courseOverGroundAnimate"],wh=([r,n],[e,t],[i,o])=>(Math.atan2(o-t,i-e)-Math.atan2(n-t,r-e)+3*Math.PI)%(2*Math.PI)-Math.PI,kh=(()=>{class r{compassAnimate=le.required("compassAnimate",{read:Me});appWindAnimate=le.required("appWindAnimate",{read:Me});trueWindAnimate=le.required("trueWindAnimate",{read:Me});waypointAnimate=le.required("waypointAnimate",{read:Me});driftAnimate=le.required("driftAnimate",{read:Me});courseOverGroundAnimate=le.required("courseOverGroundAnimate",{read:Me});compassHeading=Y.required();courseOverGroundAngle=Y(void 0);courseOverGroundEnabled=Y.required();trueWindAngle=Y.required();twsEnabled=Y.required();trueWindSpeed=Y.required();appWindAngle=Y.required();awsEnabled=Y.required();appWindSpeed=Y.required();laylineAngle=Y(void 0);closeHauledLineEnabled=Y.required();sailSetupEnabled=Y.required();windSectorEnabled=Y.required();driftEnabled=Y.required();driftSet=Y(void 0);driftFlow=Y(void 0);waypointAngle=Y(void 0);waypointEnabled=Y.required();trueWindMinHistoric=Y(void 0);trueWindMidHistoric=Y(void 0);trueWindMaxHistoric=Y(void 0);compassFaceplate={oldDegreeIndicator:0,newDegreeIndicator:0,animationElement:void 0};headingValue="--";appWind={oldDegreeIndicator:0,newDegreeIndicator:0,animationElement:void 0};appWindSpeedDisplay=io(()=>{let e=this.appWindSpeed();return e==null?"--":e.toFixed(1)});trueWind={oldDegreeIndicator:0,newDegreeIndicator:0,animationElement:void 0};trueWindSpeedDisplay=io(()=>{let e=this.trueWindSpeed();return e==null?"--":e.toFixed(1)});trueWindHeading=0;waypoint={oldDegreeIndicator:0,newDegreeIndicator:0,animationElement:void 0};waypointActive=Wn(!1);courseOverGround={oldDegreeIndicator:0,newDegreeIndicator:0,animationElement:void 0};set={oldDegreeIndicator:0,newDegreeIndicator:0,animationElement:void 0};flow=io(()=>{let e=this.driftFlow();return e==null?"--":e.toFixed(1)});CENTER=500;RADIUS=350;closeHauledLinePortPath="M 500,500 500,500";closeHauledLineStbdPath="M 500,500 500,500";portWindSectorPath="M 500,500 V 150";stbdWindSectorPath="M 500,500 V 150";constructor(){Pe(()=>{this.waypointEnabled()?this.waypointActive.set(!0):this.waypointActive.set(!1)}),Pe(()=>{let e=this.compassHeading();e!=null&&(this.compassFaceplate.oldDegreeIndicator=this.compassFaceplate.newDegreeIndicator,this.compassFaceplate.newDegreeIndicator=e,this.headingValue=e.toFixed(0),this.smoothCircularRotation(this.compassFaceplate),this.updateClauseHauledLines(),this.updateWindSectors())}),Pe(()=>{let e=this.courseOverGroundAngle();e!=null&&(this.courseOverGround.oldDegreeIndicator=this.courseOverGround.newDegreeIndicator,this.courseOverGround.newDegreeIndicator=e-this.compassFaceplate.newDegreeIndicator,this.smoothCircularRotation(this.courseOverGround))}),Pe(()=>{let e=this.waypointAngle();if(!e){this.waypointActive.set(!1);return}this.waypointEnabled()?this.waypointActive.set(!0):this.waypointActive.set(!1),this.waypoint.oldDegreeIndicator=this.waypoint.newDegreeIndicator,this.waypoint.newDegreeIndicator=e,this.smoothCircularRotation(this.waypoint)}),Pe(()=>{let e=this.appWindAngle();e!=null&&(this.appWind.oldDegreeIndicator=this.appWind.newDegreeIndicator,this.appWind.newDegreeIndicator=e,this.smoothCircularRotation(this.appWind))}),Pe(()=>{let e=this.trueWindAngle();e!=null&&(this.trueWind.oldDegreeIndicator=this.trueWind.newDegreeIndicator,this.trueWindHeading=e,this.trueWind.newDegreeIndicator=this.addHeading(this.trueWindHeading,this.compassFaceplate.newDegreeIndicator*-1),this.smoothCircularRotation(this.trueWind),this.updateClauseHauledLines())}),Pe(()=>{let e=this.driftSet();e!=null&&(this.set.oldDegreeIndicator=this.set.newDegreeIndicator,this.set.newDegreeIndicator=e,this.smoothCircularRotation(this.set))})}ngAfterViewInit(){this.compassFaceplate.animationElement=this.compassAnimate(),this.appWind.animationElement=this.appWindAnimate(),this.trueWind.animationElement=this.trueWindAnimate(),this.waypoint.animationElement=this.waypointAnimate(),this.courseOverGround.animationElement=this.courseOverGroundAnimate(),this.set.animationElement=this.driftAnimate()}updateClauseHauledLines(){if(!this.closeHauledLineEnabled())return;let e=f=>{let s=f*Math.PI/180,c=Math.floor(this.RADIUS*Math.sin(s)+this.CENTER),m=Math.floor(this.RADIUS*Math.cos(s)*-1+this.CENTER);return{x:c,y:m}},t=this.addHeading(Number(this.trueWind.newDegreeIndicator),this.laylineAngle()*-1),{x:i,y:o}=e(t);this.closeHauledLinePortPath=`M ${this.CENTER},${this.CENTER} L ${i},${o}`;let a=this.addHeading(Number(this.trueWind.newDegreeIndicator),this.laylineAngle()),{x:l,y:d}=e(a);this.closeHauledLineStbdPath=`M ${this.CENTER},${this.CENTER} L ${l},${d}`}updateWindSectors(){if(!this.windSectorEnabled()||!this.trueWindMinHistoric()||!this.trueWindMidHistoric()||!this.trueWindMaxHistoric())return;let e=(t,i,o,a)=>{let l=this.addHeading(this.addHeading(t,Number(this.compassFaceplate.newDegreeIndicator)*-1),this.laylineAngle()*(a?-1:1)),d=this.addHeading(this.addHeading(i,Number(this.compassFaceplate.newDegreeIndicator)*-1),this.laylineAngle()*(a?-1:1)),f=this.addHeading(this.addHeading(o,Number(this.compassFaceplate.newDegreeIndicator)*-1),this.laylineAngle()*(a?-1:1)),s=this.RADIUS*Math.sin(l*Math.PI/180)+this.CENTER,c=this.RADIUS*Math.cos(l*Math.PI/180)*-1+this.CENTER,m=this.RADIUS*Math.sin(d*Math.PI/180)+this.CENTER,y=this.RADIUS*Math.cos(d*Math.PI/180)*-1+this.CENTER,k=this.RADIUS*Math.sin(f*Math.PI/180)+this.CENTER,x=this.RADIUS*Math.cos(f*Math.PI/180)*-1+this.CENTER,D=Math.abs(wh([s,c],[m,y],[k,x]))>Math.PI/2?0:1,F=wh([k,x],[s,c],[m,y])>0?0:1;return`M ${this.CENTER},${this.CENTER} L ${s},${c} A ${this.RADIUS},${this.RADIUS} 0 ${D} ${F} ${k},${x} z`};this.portWindSectorPath=e(this.trueWindMinHistoric(),this.trueWindMidHistoric(),this.trueWindMaxHistoric(),!0),this.stbdWindSectorPath=e(this.trueWindMinHistoric(),this.trueWindMidHistoric(),this.trueWindMaxHistoric(),!1)}addHeading(e=0,t=0){let i=e+t;for(;i>359;)i=i-359;for(;i<0;)i=i+359;return i}smoothCircularRotation(e,t){let i=Number(e.oldDegreeIndicator),o=Number(e.newDegreeIndicator),a=i-o;e.animationElement&&a!=0&&(Math.abs(a)>180?Math.sign(a)==1?i==359?(e.oldDegreeIndicator=0,e.animationElement.nativeElement.beginElement(),t!==void 0&&(t.oldDegreeIndicator=0,t.animationElement.nativeElement.beginElement())):(e.newDegreeIndicator=359,e.animationElement.nativeElement.beginElement(),t!==void 0&&(t.newDegreeIndicator=-359,t.animationElement.nativeElement.beginElement()),e.oldDegreeIndicator=0,e.newDegreeIndicator=o,e.animationElement.nativeElement.beginElement(),t!==void 0&&(t.oldDegreeIndicator=e.oldDegreeIndicator,t.newDegreeIndicator=0,t.animationElement.nativeElement.beginElement())):i==0?(e.oldDegreeIndicator=359,e.animationElement.nativeElement.beginElement(),t!==void 0&&(t.oldDegreeIndicator=-359,t.animationElement.nativeElement.beginElement())):(e.newDegreeIndicator=0,e.animationElement.nativeElement.beginElement(),t!==void 0&&(t.newDegreeIndicator=0,t.animationElement.nativeElement.beginElement()),e.oldDegreeIndicator=359,e.newDegreeIndicator=o,e.animationElement.nativeElement.beginElement(),t!==void 0&&(t.oldDegreeIndicator=-359,t.newDegreeIndicator=o*-1,t.animationElement.nativeElement.beginElement())):(e.animationElement.nativeElement.beginElement(),t!==void 0&&t.animationElement.nativeElement.beginElement()))}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["app-svg-wind"]],viewQuery:function(t,i){t&1&&(de(i.compassAnimate,Pf,5,Me),de(i.appWindAnimate,Mf,5,Me),de(i.trueWindAnimate,Of,5,Me),de(i.waypointAnimate,If,5,Me),de(i.driftAnimate,Rf,5,Me),de(i.courseOverGroundAnimate,Nf,5,Me)),t&2&&Qe(6)},inputs:{compassHeading:[1,"compassHeading"],courseOverGroundAngle:[1,"courseOverGroundAngle"],courseOverGroundEnabled:[1,"courseOverGroundEnabled"],trueWindAngle:[1,"trueWindAngle"],twsEnabled:[1,"twsEnabled"],trueWindSpeed:[1,"trueWindSpeed"],appWindAngle:[1,"appWindAngle"],awsEnabled:[1,"awsEnabled"],appWindSpeed:[1,"appWindSpeed"],laylineAngle:[1,"laylineAngle"],closeHauledLineEnabled:[1,"closeHauledLineEnabled"],sailSetupEnabled:[1,"sailSetupEnabled"],windSectorEnabled:[1,"windSectorEnabled"],driftEnabled:[1,"driftEnabled"],driftSet:[1,"driftSet"],driftFlow:[1,"driftFlow"],waypointAngle:[1,"waypointAngle"],waypointEnabled:[1,"waypointEnabled"],trueWindMinHistoric:[1,"trueWindMinHistoric"],trueWindMidHistoric:[1,"trueWindMidHistoric"],trueWindMaxHistoric:[1,"trueWindMaxHistoric"]},decls:161,vars:42,consts:[["waypointAnimate",""],["driftAnimate",""],["compassAnimate",""],["courseOverGroundAnimate",""],["appWindAnimate",""],["trueWindAnimate",""],["viewBox","0 0 1000 1000"],["id","defs1"],["id","linearGradient18"],["offset","0",1,"boat",2,"stop-opacity","0.71372495"],["offset","1",1,"boat",2,"stop-opacity","0"],["id","linearGradient16"],["id","linearGradient13"],["offset","0.41176471",1,"drift-arrow",2,"stop-opacity","1"],["offset","1",1,"drift-arrow",2,"stop-opacity","0"],["id","swatch4"],["offset","0","id","stop4",2,"stop-color","#000000","stop-opacity","1"],["clipPathUnits","userSpaceOnUse","id","clipPath16"],["id","ellipse16","cx","311.24539","cy","-1516.3778","rx","194.27342","ry","181.83022",2,"display","inline","fill","#9a9300","fill-opacity","1","stroke","none","stroke-width","55","stroke-miterlimit","0","stroke-dasharray","none","stroke-opacity","1"],[0,"xlink","href","#linearGradient13","id","linearGradient14","x1","453.48047","y1","583.62891","x2","638.11328","y2","583.62891","gradientUnits","userSpaceOnUse","gradientTransform","matrix(0.00723393,1.2388183,-1.0538241,0.00615367,1111.2051,-179.73465)"],[0,"xlink","href","#linearGradient16","id","linearGradient17","x1","-502.04896","y1","439.35551","x2","-316","y2","439.35551","gradientUnits","userSpaceOnUse","gradientTransform","translate(0,49.000266)"],[0,"xlink","href","#linearGradient18","id","linearGradient19","x1","495.83999","y1","439.35551","x2","681.88895","y2","439.35551","gradientUnits","userSpaceOnUse","gradientTransform","translate(0,49.000266)"],["id","layerBackground",2,"display","inline"],["id","boat",2,"display","inline"],["id","portSide","d","M 498.75049,208.89453 A 267.09439,554.67401 0 0 1 678.45974,767.81661",2,"fill","none","fill-opacity","1","stroke","url(#linearGradient19)","stroke-width","5.821","stroke-linecap","round","stroke-miterlimit","0","stroke-dasharray","none"],["id","starboardSide","d","m -499.13846,208.89453 a 267.09439,554.67401 0 0 1 179.70925,558.92208","transform","scale(-1,1)",2,"fill","none","fill-opacity","1","stroke","url(#linearGradient17)","stroke-width","5.821","stroke-linecap","round","stroke-miterlimit","0","stroke-dasharray","none"],["id","layerCompass"],["id","fixedDial"],["id","portStarboardBackground","d","M 499.99997,10.520805 A 489.47916,489.47916 0 0 0 10.520805,499.99997 489.47916,489.47916 0 0 0 499.99997,989.47913 489.47916,489.47916 0 0 0 989.47913,499.99997 489.47916,489.47916 0 0 0 499.99997,10.520805 Z m 0,132.291665 a 357.1875,357.1875 0 0 1 357.18749,357.1875 357.1875,357.1875 0 0 1 -357.18749,357.18749 357.1875,357.1875 0 0 1 -357.1875,-357.18749 357.1875,357.1875 0 0 1 357.1875,-357.1875 z",1,"fixed-dial-background",2,"display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","port","d","M 93.283801,265.18231 A 469.63541,469.63541 0 0 1 339.37522,58.687079",1,"port",2,"display","inline","fill","none","stroke-width","39.6875","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","0"],["id","starboard","d","M 660.62476,58.687069 A 469.63541,469.63541 0 0 1 906.71619,265.18228",1,"starboard",2,"display","inline","fill","none","stroke-width","39.6875","stroke-linecap","butt","stroke-linejoin","round","stroke-miterlimit","0"],["id","rotatingDial"],["id","g201",1,"contrast-stroke",2,"display","inline"],["d","m 416.35095,19.837399 2.78142,15.77426","id","path199",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 334.23173,41.658798 5.47834,15.051615","id","path200",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 260.27336,81.806174 12.55151,21.739856","id","path37",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 187.44581,126.00035 10.29591,12.2702","id","path197",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 127.23918,185.95785 12.27019,10.29591","id","path198",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 83.252815,257.66724 21.739865,12.55151","id","path166",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 42.289518,332.39273 15.05162,5.47835","id","path195",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 20.127799,414.42077 15.774251,2.78142","id","path196",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 17.879075,498.47765 H 42.982096","id","path167",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 19.776759,583.71187 15.77426,-2.78142","id","path193",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 41.598167,665.8311 15.051615,-5.47834","id","path194",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 81.668963,739.71246 103.40883,727.16095","id","path168",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 125.93981,812.61701 12.2702,-10.29591","id","path191",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 185.89732,872.82365 10.29591,-12.27019","id","path192",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 257.53004,916.73298 12.55151,-21.73985","id","path169",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 332.33219,957.7732 5.47835,-15.05162","id","path189",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 414.36024,979.93493 2.78142,-15.77425","id","path190",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 498.34046,982.10672 V 957.0037","id","path170",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 583.65133,980.28596 580.86991,964.5117","id","path187",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 665.77057,958.46456 -5.47834,-15.05161","id","path188",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 739.57526,918.31683 727.02375,896.57698","id","path171",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 812.55647,874.12301 802.26056,861.85282","id","path185",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 872.76312,814.16551 860.49293,803.8696","id","path186",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 916.59579,742.45577 894.85593,729.90426","id","path172",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 957.71266,667.73063 -15.05161,-5.47834","id","path183",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 979.8744,585.70259 -15.77425,-2.78142","id","path184",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 981.96954,501.64535 -25.10304,10e-6","id","path173",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 980.22542,416.41149 -15.77425,2.78143","id","path181",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 958.40403,334.29226 -15.05161,5.47834","id","path182",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 918.17964,260.41055 -21.73986,12.55151","id","path174",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 874.06247,187.50636 -12.27018,10.29591","id","path180",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 817.34594,130.05494 -10.40259,12.17987","id","path179",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 742.31857,83.390025 729.76706,105.12988","id","path175",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 667.6701,42.350172 -5.47834,15.051615","id","path178",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","m 585.64206,20.188432 -2.78142,15.77425","id","path176",2,"fill","none","fill-opacity","0","stroke-width","4.18042","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["d","M 501.50816,18.016286 V 43.119307","id","path177",2,"fill","none","fill-opacity","0","stroke-width","15","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0","stroke-dasharray","none"],["id","rotatingDialBackplate","d","M 499.99997,50.208304 A 449.79166,449.79166 0 0 0 50.208304,499.99997 449.79166,449.79166 0 0 0 499.99997,949.79163 449.79166,449.79166 0 0 0 949.79163,499.99997 449.79166,449.79166 0 0 0 499.99997,50.208304 Z m 0,92.604166 a 357.1875,357.1875 0 0 1 357.18749,357.1875 357.1875,357.1875 0 0 1 -357.18749,357.18749 357.1875,357.1875 0 0 1 -357.1875,-357.18749 357.1875,357.1875 0 0 1 357.1875,-357.1875 z",1,"rotating-dial-Backplate",2,"display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],[0,"xml","space","preserve","x","181.91386","y","284.25186","id","text3","transform","rotate(-30)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan3","x","181.91386","y","284.25186",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","-183.53558","y","283.74811","id","text14","transform","rotate(-60)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan14","x","-183.53558","y","283.74811",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","-499.70761","y","100.95312","id","text15","transform","rotate(-90)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan15","x","-499.70761","y","100.95312",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","-681.66119","y","-216.36243","id","text16","transform","rotate(-120)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["x","-681.66119","y","-216.36243","id","tspan25",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","-681.06616","y","-581.71271","id","text17","transform","rotate(-150)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan17","x","-681.06616","y","-581.71271",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","-498.3313","y","-897.40875","id","text18","transform","scale(-1)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan18","x","-498.3313","y","-897.40875",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","-184.41313","y","-1080.8452","id","text19","transform","rotate(150)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan19","x","-184.41313","y","-1080.8452",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","181.57225","y","-1080.8853","id","text20","transform","rotate(120)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan20","x","181.57225","y","-1080.8853",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","501.42661","y","-896.93701","id","text21","transform","rotate(90)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan21","x","501.42661","y","-896.93701",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","682.35815","y","-579.63336","id","text22","transform","rotate(60)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan22","x","682.35815","y","-579.63336",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","681.81525","y","-214.27321","id","text23","transform","rotate(30)",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan23","x","681.81525","y","-214.27321",2,"font-style","normal","font-variant","normal","font-weight","normal","font-stretch","normal","font-size","44.0972px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],[0,"xml","space","preserve","x","500.15503","y","101.96342","id","text24",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","display","inline","stroke","none","stroke-width","0.47625","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0"],["id","tspan24","x","500.15503","y","101.96342",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","52.9167px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke-width","0.47625"],["id","waypoint"],["clip-path","url(#clipPath16)","d","m 416.36313,-1521.3937 c 371.15015,24.6522 731.95257,192.9774 983.98757,467.456 227.2972,244.24389 363.1732,572.3808 369.4045,906.42978 15.9331,499.10271 -269.2071,986.17861 -700.5178,1232.88522 -485.08308,290.4843 -1134.555606,269.7346 -1599.2788,-52.7169 -404.5062,-269.24461 -653.2224,-759.35388 -614.1746,-1245.84043 30.2148,-487.61814 344.18931,-937.89997 780.52695,-1152.15867 176.96718,-89.2092 371.8823084,-142.3103 569.54914,-156.0363","transform","matrix(0.28310615,0,0,0.32000828,411.88452,661.64815)",1,"next-waypoint-bar",2,"display","inline","fill","none","stroke-width","30","stroke-miterlimit","0"],["id","path6341","cx","500","cy","175.00002","rx","17.361122","ry","17.361118",1,"next-waypoint",2,"display","inline","fill","none","fill-opacity","1","stroke-width","15.2778","stroke-dasharray","none"],["attributeName","transform","type","rotate","begin","indefinite","dur","0.5s","keySplines","0.25 0.1 0.25 1","keyTimes","0;1","calcMode","spline","additive","replace","fill","freeze"],["id","setCurrentArrow"],["id","setArrow","d","m 563.93337,480.60403 -64.4901,-94.9673 -63.37665,95.71396 58.48691,-30.71299 0.77713,133.08346 c 0.0992,16.99331 2.52916,30.65913 5.44822,30.64209 2.91911,-0.0171 5.18926,-13.71032 5.09001,-30.70362 l -0.77782,-133.20444 z",2,"fill","url(#linearGradient14)","stroke","none","stroke-width","1.18648"],["id","layerCounter"],["id","twsCounter"],[0,"xml","space","preserve","x","904.27722","y","150.88913","id","text43",1,"true-wind-label",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","34.6667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],[0,"xml","space","preserve","x","903.84814","y","114.73512","id","text42",1,"true-wind",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","66.6667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],[0,"xml","space","preserve","x","905.25897","y","52.894646","id","text41",1,"true-wind-label",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","34.6667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],["id","awsCounter"],[0,"xml","space","preserve","x","94.554222","y","150.88913","id","text39",1,"app-wind-label",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","34.6667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],[0,"xml","space","preserve","x","94.580925","y","114.63747","id","text40",1,"app-wind",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","66.6667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],[0,"xml","space","preserve","x","95.967644","y","52.894646","id","text39-7",1,"app-wind-label",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","34.6667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],["id","LayerLayline"],["id","PortLayline",1,"laylines",2,"fill","none","stroke-width","5","stroke-dasharray","40, 20","stroke-dashoffset","0","stroke-opacity","0.6"],["id","StbdLayline",1,"laylines",2,"fill","none","stroke-width","5","stroke-dasharray","40, 20","stroke-dashoffset","0","stroke-opacity","0.6"],["id","LayerWindShift"],["id","portSectorShift",1,"wind-sector-port",2,"fill-opacity","0.5","stroke","none"],["id","StbdSectorShift",1,"wind-sector-stbd",2,"fill-opacity","0.5","stroke","none"],["id","layerCurrent"],["id","text11",0,"xml","space","preserve","x","499.78842","y","523.55145",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-stretch","normal","font-size","66.6667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none"],["id","layerIndicators",2,"display","inline"],["id","COGIndicator"],["d","m 506.20767,172.99458 a 6.3888631,8.8250643 0 0 1 -6.38888,8.82508 6.3888631,8.8250643 0 0 1 -6.38888,-8.82508 6.3888631,8.8250643 0 0 1 6.38888,-8.82509 6.3888631,8.8250643 0 0 1 6.38888,8.82509 z M 476.25472,30.811298 493.47058,13.265068 c 3.6173,-3.6867571 9.44162,-3.6867571 13.05892,0 l 17.21586,17.546106 c 3.6173,3.686743 3.6173,9.622786 0,13.309544 l -17.21595,17.54623 c -3.61721,3.686757 -9.44153,3.686757 -13.05893,0 L 476.25472,44.120841 c -3.6174,-3.686743 -3.6174,-9.622924 0,-13.309543 z m 17.20533,-16.510116 h 12.77766 V 173.26408 h -12.77766 z",1,"course-over-ground",2,"stroke-width","14.7329","stroke-linecap","square"],["id","ApparentWindIndicator"],["d","m 451.77021,55.078207 42.08541,-33.202814 a 12.555638,12.555638 0.26446337 0 1 15.64423,0.07221 l 42.20046,33.930296 a 15.557694,15.557694 71.53185 0 1 5.32954,15.957795 L 504.17034,279.76529 a 2.5373267,2.5373267 0.02614114 0 1 -4.91879,-0.002 L 446.37431,70.966036 a 15.416336,15.416336 108.75875 0 1 5.3959,-15.887829 z","transform","matrix(0.7935953,0,0,0.92686935,101.84848,11.000842)",1,"app-wind",2,"display","inline","stroke-width","5.8876","stroke-miterlimit","0"],[0,"xml","space","preserve","x","474.16168","y","109.42192","id","text8",1,"card-color",2,"font-weight","bold","font-size","52.9167px","font-family","Roboto","display","inline","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],["id","trueWindIndicator"],["d","m 451.77021,55.078207 42.08541,-33.202814 a 12.555638,12.555638 0.26446337 0 1 15.64423,0.07221 l 42.20046,33.930296 a 15.557694,15.557694 71.53185 0 1 5.32954,15.957795 L 504.17034,279.76529 a 2.5373267,2.5373267 0.02614114 0 1 -4.91879,-0.002 L 446.37431,70.966036 a 15.416336,15.416336 108.75875 0 1 5.3959,-15.887829 z","transform","matrix(0.60410307,0,0,0.70555435,196.91787,21.152867)",1,"true-wind",2,"display","inline","stroke","none","stroke-width","5.8876","stroke-miterlimit","0"],[0,"xml","space","preserve","x","478.41647","y","109.42194","id","text10",1,"card-color",2,"font-weight","bold","font-size","52.9167px","font-family","Roboto","display","inline","stroke","none","stroke-width","14.5521","stroke-miterlimit","0"],["id","layerHeading",2,"display","inline"],["id","rect1","width","256.47919","height","108.5428","x","371.76041","y","10.805443","rx","23.757372",1,"heading-background",2,"stroke-width","4.43107","stroke-linejoin","bevel","stroke-miterlimit","0","stroke-dasharray","none","stroke-opacity","0.509946"],["x","511.29395","y","102.86786",1,"contrast-text",2,"font-style","normal","font-variant","normal","font-weight","bold","font-stretch","normal","font-size","106.667px","font-family","Roboto","font-variant-ligatures","normal","font-variant-caps","normal","font-variant-numeric","normal","font-variant-east-asian","normal","text-align","center","text-anchor","middle","stroke","none","stroke-width","5","stroke-linejoin","bevel","stroke-miterlimit","0","stroke-dasharray","none","stroke-opacity","1"]],template:function(t,i){t&1&&(Dt(),v(0,"svg",6)(1,"defs",7)(2,"linearGradient",8),B(3,"stop",9)(4,"stop",10),_(),v(5,"linearGradient",11),B(6,"stop",9)(7,"stop",10),_(),v(8,"linearGradient",12),B(9,"stop",13)(10,"stop",14),_(),v(11,"linearGradient",15),B(12,"stop",16),_(),v(13,"clipPath",17),B(14,"ellipse",18),_(),B(15,"linearGradient",19)(16,"linearGradient",20)(17,"linearGradient",21),_(),v(18,"g",22)(19,"g",23),B(20,"path",24)(21,"path",25),_()(),v(22,"g",26)(23,"g",27),B(24,"path",28)(25,"path",29)(26,"path",30),_(),v(27,"g",31)(28,"g",32),B(29,"path",33)(30,"path",34)(31,"path",35)(32,"path",36)(33,"path",37)(34,"path",38)(35,"path",39)(36,"path",40)(37,"path",41)(38,"path",42)(39,"path",43)(40,"path",44)(41,"path",45)(42,"path",46)(43,"path",47)(44,"path",48)(45,"path",49)(46,"path",50)(47,"path",51)(48,"path",52)(49,"path",53)(50,"path",54)(51,"path",55)(52,"path",56)(53,"path",57)(54,"path",58)(55,"path",59)(56,"path",60)(57,"path",61)(58,"path",62)(59,"path",63)(60,"path",64)(61,"path",65)(62,"path",66)(63,"path",67)(64,"path",68)(65,"path",69),v(66,"text",70)(67,"tspan",71),T(68,"330"),_()(),v(69,"text",72)(70,"tspan",73),T(71,"300"),_()(),v(72,"text",74)(73,"tspan",75),T(74,"W"),_()(),v(75,"text",76)(76,"tspan",77),T(77,"240"),_()(),v(78,"text",78)(79,"tspan",79),T(80,"210"),_()(),v(81,"text",80)(82,"tspan",81),T(83,"S"),_()(),v(84,"text",82)(85,"tspan",83),T(86,"150"),_()(),v(87,"text",84)(88,"tspan",85),T(89,"120"),_()(),v(90,"text",86)(91,"tspan",87),T(92,"E"),_()(),v(93,"text",88)(94,"tspan",89),T(95,"60"),_()(),v(96,"text",90)(97,"tspan",91),T(98,"30"),_()(),v(99,"text",92)(100,"tspan",93),T(101,"N"),_()()(),v(102,"g",94),B(103,"path",95)(104,"ellipse",96)(105,"animateTransform",97,0),_(),v(107,"g",98),B(108,"path",99)(109,"animateTransform",97,1),_(),B(111,"animateTransform",97,2),_()(),v(113,"g",100)(114,"g",101)(115,"text",102),T(116,"kts"),_(),v(117,"text",103),T(118),_(),v(119,"text",104),T(120,"TWS"),_()(),v(121,"g",105)(122,"text",106),T(123,"kts"),_(),v(124,"text",107),T(125),_(),v(126,"text",108),T(127,"AWS"),_()()(),v(128,"g",109),B(129,"path",110)(130,"path",111),_(),v(131,"g",112),B(132,"path",113)(133,"path",114),_(),v(134,"g",115)(135,"text",116),T(136),_()(),v(137,"g",117)(138,"g",118),B(139,"path",119)(140,"animateTransform",97,3),_(),v(142,"g",120),B(143,"path",121),v(144,"text",122),T(145,"A"),_(),B(146,"animateTransform",97,4),_(),v(148,"g",123),B(149,"path",124),v(150,"text",125),T(151,"T"),_(),B(152,"animateTransform",97,5),_()(),v(154,"g",126),B(155,"rect",127),v(156,"text",128)(157,"tspan"),T(158),v(159,"tspan"),T(160,"\xB0"),_()()()()()),t&2&&(P(102),fe("display",i.waypointActive()?"inline":"none"),P(3),fe("from",i.waypoint.oldDegreeIndicator+" 500 500")("to",i.waypoint.newDegreeIndicator+" 500 500"),P(2),He("display",i.driftEnabled()?"inline":"none"),P(2),fe("from",i.set.oldDegreeIndicator+" 500 500")("to",i.set.newDegreeIndicator+" 500 500"),P(2),fe("from","-"+i.compassFaceplate.oldDegreeIndicator+" 500 500")("to","-"+i.compassFaceplate.newDegreeIndicator+" 500 500"),P(3),He("display",i.twsEnabled()?"inline":"none"),P(4),lt(i.trueWindSpeedDisplay()),P(3),He("display",i.awsEnabled()?"inline":"none"),P(4),lt(i.appWindSpeedDisplay()),P(3),He("display",i.closeHauledLineEnabled()?"inline":"none"),P(),He("display",i.trueWindAngle()!=null?"inline":"none"),fe("d",i.closeHauledLineStbdPath),P(),He("display",i.trueWindAngle()!=null?"inline":"none"),fe("d",i.closeHauledLinePortPath),P(),He("display",i.windSectorEnabled()?"inline":"none"),P(),He("display",i.portWindSectorPath!="none"?"inline":"none"),fe("d",i.portWindSectorPath),P(),He("display",i.portWindSectorPath!="none"?"inline":"none"),fe("d",i.stbdWindSectorPath),P(),He("display",i.driftEnabled()?"inline":"none"),P(2),lt(i.flow()),P(2),fe("display",i.courseOverGroundEnabled()?"inline":"none"),P(2),fe("from",i.courseOverGround.oldDegreeIndicator+" 500 500")("to",i.courseOverGround.newDegreeIndicator+" 500 500"),P(6),fe("from",i.appWind.oldDegreeIndicator+" 500 500")("to",i.appWind.newDegreeIndicator+" 500 500"),P(6),fe("from",i.trueWind.oldDegreeIndicator+" 500 500")("to",i.trueWind.newDegreeIndicator+" 500 500"),P(6),lt(i.headingValue))},styles:["svg[_ngcontent-%COMP%]{position:absolute;height:100%;width:100%;left:0;top:0}.fixed-dial-background[_ngcontent-%COMP%]{fill:var(--kip-grey-color)}.rotating-dial-Backplate[_ngcontent-%COMP%]{fill:var(--mat-sys-background)}.starboard[_ngcontent-%COMP%]{stroke:var(--kip-starboard-color)}.port[_ngcontent-%COMP%]{stroke:var(--kip-port-color)}.heading-background[_ngcontent-%COMP%]{stroke:var(--kip-grey-color);fill:var(--kip-widget-card-background-color)}.boat[_ngcontent-%COMP%]{stop-color:var(--kip-grey-color)!important}.contrast-text[_ngcontent-%COMP%]{fill:var(--kip-contrast-color)}.contrast-stroke[_ngcontent-%COMP%]{stroke:var(--kip-contrast-color)}.card-color[_ngcontent-%COMP%]{fill:var(--kip-widget-card-background-color)}.true-wind[_ngcontent-%COMP%]{fill:var(--kip-yellow-color)}.true-wind-label[_ngcontent-%COMP%]{fill:var(--kip-yellow-dim-color)}.app-wind[_ngcontent-%COMP%]{fill:var(--kip-orange-color)}.app-wind-label[_ngcontent-%COMP%]{fill:var(--kip-orange-dim-color)}.course-over-ground[_ngcontent-%COMP%]{fill:var(--kip-pink-color)}.next-waypoint[_ngcontent-%COMP%]{stroke:var(--kip-green-color)}.next-waypoint-bar[_ngcontent-%COMP%]{stroke:var(--kip-grey-color)}.laylines[_ngcontent-%COMP%]{stroke:var(--kip-contrast-color)}.wind-sector-port[_ngcontent-%COMP%]{fill:var(--kip-port-color)}.wind-sector-stbd[_ngcontent-%COMP%]{fill:var(--kip-starboard-color)}.drift-arrow[_ngcontent-%COMP%]{stop-color:var(--kip-blue-color)}"]})}return r})();var Sh=(()=>{class r extends Re{zones=M(ht);currentHeading=0;courseOverGroundAngle=0;appWindAngle=0;appWindSpeed=0;trueWindAngle=0;trueWindSpeed=0;driftFlow=0;driftSet=0;waypointAngle=0;trueWindHistoric=[];trueWindMinHistoric;trueWindMidHistoric;trueWindMaxHistoric;windSectorObservableSub=null;constructor(){super(),this.defaultConfig={filterSelfPaths:!0,paths:{headingPath:{description:"Heading True",path:"self.navigation.headingTrue",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",convertUnitTo:"deg",sampleTime:500},courseOverGround:{description:"Course Over Ground True",path:"self.navigation.courseOverGroundTrue",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",convertUnitTo:"deg",sampleTime:500},trueWindAngle:{description:"True Wind Angle",path:"self.environment.wind.angleTrueWater",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",convertUnitTo:"deg",sampleTime:500},trueWindSpeed:{description:"Wind Speed True",path:"self.environment.wind.speedTrue",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"m/s",convertUnitTo:"knots",sampleTime:500},appWindAngle:{description:"Apparent Wind Angle",path:"self.environment.wind.angleApparent",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",convertUnitTo:"deg",sampleTime:500},appWindSpeed:{description:"Apparent Wind Speed",path:"self.environment.wind.speedApparent",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"m/s",convertUnitTo:"knots",sampleTime:500},set:{description:"Drift Set True",path:"self.environment.current.setTrue",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",convertUnitTo:"deg",sampleTime:500},drift:{description:"Drift Speed Impact",path:"self.environment.current.drift",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"m/s",convertUnitTo:"knots",sampleTime:500},nextWaypointBearing:{description:"Next Waypoint Bearing",path:"self.navigation.courseGreatCircle.nextPoint.bearingTrue",source:"default",pathType:"number",isPathConfigurable:!0,showPathSkUnitsFilter:!1,pathSkUnitsFilter:"rad",convertUnitTo:"deg",sampleTime:500}},windSectorEnable:!0,windSectorWindowSeconds:5,laylineEnable:!0,laylineAngle:40,waypointEnable:!0,courseOverGroundEnable:!0,driftEnable:!0,awsEnable:!0,twsEnable:!0,sailSetupEnable:!1,enableTimeout:!1,dataTimeout:5}}ngOnInit(){this.validateConfig(),this.startWidget()}startWidget(){this.unsubscribeDataStream(),this.stopWindSectors(),this.observeDataStream("headingPath",e=>{e.data.value==null&&(e.data.value=0),this.currentHeading=e.data.value}),this.observeDataStream("courseOverGround",e=>{e.data.value==null&&(e.data.value=0),this.courseOverGroundAngle=e.data.value}),this.observeDataStream("drift",e=>{e.data.value==null&&(e.data.value=0),this.driftFlow=e.data.value}),this.observeDataStream("set",e=>{e.data.value==null&&(e.data.value=0),this.driftSet=e.data.value}),this.observeDataStream("nextWaypointBearing",e=>{e.data.value<0?this.waypointAngle=360+e.data.value:this.waypointAngle=e.data.value}),this.observeDataStream("appWindAngle",e=>{e.data.value==null&&(e.data.value=0),e.data.value<0?this.appWindAngle=360+e.data.value:this.appWindAngle=e.data.value}),this.observeDataStream("appWindSpeed",e=>{e.data.value==null&&(e.data.value=0),this.appWindSpeed=e.data.value}),this.observeDataStream("trueWindSpeed",e=>{e.data.value==null&&(e.data.value=0),this.trueWindSpeed=e.data.value}),this.observeDataStream("trueWindAngle",e=>{e.data.value==null&&(e.data.value=0),this.widgetProperties.config.paths.trueWindAngle.path.match("angleTrueWater")||this.widgetProperties.config.paths.trueWindAngle.path.match("angleTrueGround")?this.trueWindAngle=this.addHeading(this.currentHeading,e.data.value):this.widgetProperties.config.paths.trueWindAngle.path.match("direction")?this.trueWindAngle=e.data.value:this.trueWindAngle=e.data.value,this.widgetProperties.config.windSectorEnable&&this.addHistoricalTrue(this.trueWindAngle)}),this.startWindSectors()}updateConfig(e){this.widgetProperties.config=e,this.startWidget()}ngOnDestroy(){this.destroyDataStreams(),this.stopWindSectors()}startWindSectors(){this.zones.runOutsideAngular(()=>{this.windSectorObservableSub=al(500).subscribe(e=>{this.historicalCleanup()})})}addHistoricalTrue(e){this.trueWindHistoric.push({timestamp:Date.now(),heading:e});let t=this.arcForAngles(this.trueWindHistoric.map(i=>i.heading));this.trueWindMinHistoric=t[0],this.trueWindMaxHistoric=t[1],this.trueWindMidHistoric=t[2]}arcForAngles(e){return e.slice(1).reduce((t,i)=>{let o=i;for(;o<t[0]-180;)o+=360;for(;o>t[1]+180;)o-=360;return t[0]=Math.min(t[0],o),t[1]=Math.max(t[1],o),t[2]=(t[1]-t[0])/2+t[0],t},[e[0],e[0]])}historicalCleanup(){let e=Date.now()-this.widgetProperties.config.windSectorWindowSeconds*1e3;for(let t=this.trueWindHistoric.length-1;t>=0;--t)this.trueWindHistoric[t].timestamp<e&&this.trueWindHistoric.splice(t,1)}stopWindSectors(){this.windSectorObservableSub?.unsubscribe()}addHeading(e,t){let i=e+t;for(;i>359;)i=i-359;for(;i<0;)i=i+359;return i}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-wind-steer"]],features:[pe],decls:2,vars:23,consts:[[3,"configChange","config","id"],[3,"compassHeading","courseOverGroundAngle","courseOverGroundEnabled","trueWindAngle","twsEnabled","trueWindSpeed","appWindAngle","awsEnabled","appWindSpeed","laylineAngle","closeHauledLineEnabled","windSectorEnabled","driftEnabled","driftFlow","driftSet","waypointAngle","waypointEnabled","trueWindMinHistoric","trueWindMidHistoric","trueWindMaxHistoric","sailSetupEnabled"]],template:function(t,i){t&1&&(v(0,"widget-host",0),Ae("configChange",function(a){return De(i.widgetProperties.config,a)||(i.widgetProperties.config=a),a}),V("configChange",function(a){return i.updateConfig(a)}),B(1,"app-svg-wind",1),_()),t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),G("compassHeading",i.currentHeading)("courseOverGroundAngle",i.courseOverGroundAngle)("courseOverGroundEnabled",i.widgetProperties.config.courseOverGroundEnable)("trueWindAngle",i.trueWindAngle)("twsEnabled",i.widgetProperties.config.twsEnable)("trueWindSpeed",i.trueWindSpeed)("appWindAngle",i.appWindAngle)("awsEnabled",i.widgetProperties.config.awsEnable)("appWindSpeed",i.appWindSpeed)("laylineAngle",i.widgetProperties.config.laylineAngle)("closeHauledLineEnabled",i.widgetProperties.config.laylineEnable)("windSectorEnabled",i.widgetProperties.config.windSectorEnable)("driftEnabled",i.widgetProperties.config.driftEnable)("driftFlow",i.driftFlow)("driftSet",i.driftSet)("waypointAngle",i.waypointAngle)("waypointEnabled",i.widgetProperties.config.waypointEnable)("trueWindMinHistoric",i.trueWindMinHistoric)("trueWindMidHistoric",i.trueWindMidHistoric)("trueWindMaxHistoric",i.trueWindMaxHistoric)("sailSetupEnabled",i.defaultConfig.sailSetupEnable))},dependencies:[kh,Ne],encapsulation:2})}return r})();var Wf=["canvasEl"],Ch=(()=>{class r extends Re{canvasEl=le("canvasEl");canvas=M(xt);canvasCtx=null;isDestroyed=!1;maxTextWidth=0;maxTextHeight=0;constructor(){super(),this.defaultConfig={displayName:"Static Label",color:"green",bgColor:"grey",noColor:!1,noBgColor:!0},Pe(()=>{this.theme()&&(this.getColors(this.widgetProperties.config.color),this.updateCanvas())})}ngOnInit(){this.validateConfig()}ngAfterViewInit(){this.canvas.setHighDPISize(this.canvasEl().nativeElement,this.canvasEl().nativeElement.parentElement.getBoundingClientRect()),this.canvasCtx=this.canvasEl().nativeElement.getContext("2d"),this.maxTextWidth=this.canvasEl().nativeElement.width-40,this.maxTextHeight=this.canvasEl().nativeElement.height-40,!this.isDestroyed&&this.updateCanvas()}ngOnDestroy(){this.isDestroyed=!0,this.canvas.clearCanvas(this.canvasCtx,this.canvasEl().nativeElement.width,this.canvasEl().nativeElement.height),this.canvasEl().nativeElement.remove()}startWidget(){}updateConfig(e){e.displayName?this.widgetProperties.config.displayName=e.displayName:this.widgetProperties.config.displayName="",this.updateCanvas()}onResized(e){this.canvas.setHighDPISize(this.canvasEl().nativeElement,e.contentRect),this.maxTextWidth=Math.floor(this.canvasEl().nativeElement.width-40),this.maxTextHeight=Math.floor(this.canvasEl().nativeElement.height-40),this.updateCanvas()}getColors(e){switch(e){case"contrast":return this.theme().contrast;case"blue":return this.theme().blue;case"green":return this.theme().green;case"pink":return this.theme().pink;case"orange":return this.theme().orange;case"purple":return this.theme().purple;case"grey":return this.theme().grey;case"yellow":return this.theme().yellow;default:return this.theme().contrast}}updateCanvas(){this.canvasCtx&&(this.canvas.clearCanvas(this.canvasCtx,this.canvasEl().nativeElement.width,this.canvasEl().nativeElement.height),this.widgetProperties.config.noBgColor||this.canvas.drawRectangle(this.canvasCtx,0,0,this.canvasEl().nativeElement.width,this.canvasEl().nativeElement.height,this.getColors(this.widgetProperties.config.bgColor)),this.drawValue())}drawValue(){this.canvas.drawText(this.canvasCtx,this.widgetProperties.config.displayName,Math.floor(this.canvasEl().nativeElement.width/2),Math.floor(this.canvasEl().nativeElement.height/2+10),this.maxTextWidth,this.maxTextHeight,"bold",this.getColors(this.widgetProperties.config.color))}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-label"]],viewQuery:function(t,i){t&1&&de(i.canvasEl,Wf,5),t&2&&Qe()},features:[pe],decls:4,vars:2,consts:[["canvasEl",""],[3,"configChange","config","id"],[1,"wrapper",3,"onResize"],[1,"canvas",2,"z-index","inherit"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),v(1,"div",2),V("onResize",function(l){return z(o),L(i.onResized(l))}),B(2,"canvas",3,0),_()()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid))},dependencies:[Ne,tt,et],styles:["[_nghost-%COMP%]{display:block;position:relative;width:100%;height:100%}.wrapper[_ngcontent-%COMP%]{position:relative;display:block;width:100%;height:100%}.canvas[_ngcontent-%COMP%]{display:block;z-index:inherit;border-radius:var(--mdc-elevated-card-container-shape, var(--mat-sys-corner-medium))}"]})}return r})();var Bf=["svgSlider"];function zf(r,n){r&1&&B(0,"div",11)}var xh=(()=>{class r extends Re{svgElement=le.required("svgSlider");canvas=M(xt);dashboard=M(st);signalkRequestsService=M(Fi);appService=M(ti);labelColor=void 0;barColor=void 0;skRequestSub=new rn;lineStartPx;lineWidthPx;lineEndPx;resizeTimeout;debounceTimeout;handlePosition=20;pathValue=0;lineStart=this.handlePosition;isDragStarted=!1;lineWidth="0px";VIEWBOX_WIDTH=200;LINE_START=20;LINE_WIDTH=160;colorMap=new Map([["contrast",{label:this.theme().contrastDim,bar:this.theme().contrast}],["blue",{label:this.theme().blueDim,bar:this.theme().blue}],["green",{label:this.theme().greenDim,bar:this.theme().green}],["pink",{label:this.theme().pinkDim,bar:this.theme().pink}],["orange",{label:this.theme().orangeDim,bar:this.theme().orange}],["purple",{label:this.theme().purpleDim,bar:this.theme().purple}],["grey",{label:this.theme().greyDim,bar:this.theme().grey}],["yellow",{label:this.theme().yellowDim,bar:this.theme().yellow}]]);valueChange$=new bt;constructor(){super(),this.defaultConfig={displayName:"Slider Label",filterSelfPaths:!0,paths:{gaugePath:{description:"Numeric PUT path",path:null,source:null,pathType:"number",isPathConfigurable:!0,convertUnitTo:"unitless",showPathSkUnitsFilter:!1,pathSkUnitsFilter:"unitless",supportsPut:!0,sampleTime:500}},displayScale:{lower:0,upper:1,type:"linear"},enableTimeout:!1,dataTimeout:5,color:"contrast"},Pe(()=>{this.theme()&&this.getColors(this.widgetProperties.config.color)})}ngOnInit(){this.validateConfig(),this.valueChange$.pipe(Ht(e=>this.isWithinMargin(e,this.widgetProperties.config.displayScale.lower)?this.widgetProperties.config.displayScale.lower:this.isWithinMargin(e,this.widgetProperties.config.displayScale.upper)?this.widgetProperties.config.displayScale.upper:parseFloat(e.toFixed(2))),Xr(200),ll()).subscribe(e=>{this.sendValue(e)})}ngAfterViewInit(){this.startWidget()}startWidget(){this.unsubscribeDataStream(),this.observeDataStream("gaugePath",e=>{if(!e||!e.data){this.handlePosition=this.mapValueToPosition(this.widgetProperties.config.displayScale.lower);return}this.updateHandlePosition(this.mapValueToPosition(e.data.value))}),this.skRequestSub?.unsubscribe(),this.subscribeSKRequest()}mapValueToPosition(e){let t=this.widgetProperties.config.displayScale.upper-this.widgetProperties.config.displayScale.lower,i=this.LINE_WIDTH;return(e-this.widgetProperties.config.displayScale.lower)/t*i+this.LINE_START}mapPositionToValue(e){let t=this.widgetProperties.config.displayScale.upper-this.widgetProperties.config.displayScale.lower,i=this.LINE_WIDTH;return(e-this.LINE_START)/i*t+this.widgetProperties.config.displayScale.lower}isWithinMargin(e,t){let i=(this.widgetProperties.config.displayScale.upper-this.widgetProperties.config.displayScale.lower)*.01;return Math.abs(e-t)<=i}subscribeSKRequest(){this.skRequestSub=this.signalkRequestsService.subscribeRequest().subscribe(e=>{if(e.widgetUUID==this.widgetProperties.uuid){let t=`Toggle Widget ${this.widgetProperties.config.displayName}: `;e.statusCode!=200&&(e.message?t+=e.message:t+=e.statusCode+" - "+e.statusCodeDescription,this.appService.sendSnackbarNotification(t,0))}})}sendValue(e){let t=this.widgetProperties.config.paths.gaugePath.path;this.signalkRequestsService.putRequest(t,e,this.widgetProperties.uuid)}updateConfig(e){this.widgetProperties.config=e,this.getColors(this.widgetProperties.config.color),this.calculateLineBounds(),this.startWidget()}onResized(e){clearTimeout(this.resizeTimeout),this.resizeTimeout=setTimeout(()=>{this.calculateLineBounds()},200)}calculateLineBounds(){if(!this.svgElement()?.nativeElement){console.warn("[Slider Widget] SVG element is not initialized yet.");return}let e=this.svgElement().nativeElement.getBoundingClientRect(),t=this.LINE_START/this.VIEWBOX_WIDTH*e.width,i=this.LINE_WIDTH/this.VIEWBOX_WIDTH*e.width;this.lineStartPx=t,this.lineWidthPx=i,this.lineEndPx=this.lineStartPx+this.lineWidthPx}updateHandlePosition(e){this.handlePosition=e,this.lineWidth=`${e-this.lineStart}px`}getPointerX(e){return e.clientX-this.svgElement().nativeElement.getBoundingClientRect().left}onPointerDown(e){this.isDragStarted=!0,this.onPointerMove(e),e.stopPropagation(),e.preventDefault()}onPointerMove(e){if(this.isDragStarted){let t=this.getPointerX(e);if(t>=this.lineStartPx&&t<=this.lineEndPx){let i=(t-this.lineStartPx)/this.lineWidthPx*this.LINE_WIDTH+this.LINE_START;this.updateHandlePosition(i),this.handlePosition<=this.LINE_START?this.pathValue=this.widgetProperties.config.displayScale.lower:this.handlePosition>=this.LINE_START+this.LINE_WIDTH?this.pathValue=this.widgetProperties.config.displayScale.upper:this.pathValue=this.mapPositionToValue(this.handlePosition),this.valueChange$.next(this.pathValue)}}}onPointerUp(e){this.isDragStarted=!1,this.valueChange$.next(this.pathValue)}onPointerLeave(e){this.isDragStarted&&(this.isDragStarted=!1,this.valueChange$.next(this.pathValue))}getColors(e){let t=this.colorMap.get(e)||this.colorMap.get("contrast");this.labelColor=t.label,this.barColor=t.bar}ngOnDestroy(){this.destroyDataStreams(),this.skRequestSub?.unsubscribe(),this.valueChange$.complete(),clearTimeout(this.debounceTimeout),clearTimeout(this.resizeTimeout)}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["widget-slider"]],viewQuery:function(t,i){t&1&&de(i.svgElement,Bf,5),t&2&&Qe()},features:[pe],decls:12,vars:9,consts:[["svgSlider",""],[3,"configChange","config","id"],[3,"text","color"],[1,"widgets-container",3,"onResize"],["width","100%","height","100%","viewBox","0 40 200 40"],["width","160","height","8","rx","4.5","id","rect3","x","20","y","56",1,"slider-bg-bar",2,"display","inline","stroke-width","1.57144"],["height","8","rx","4.5","id","rect3","x","20","y","56",2,"display","inline","stroke-width","1.57144"],["id","g22"],["cy","60","fill","#ffffff","id","circle3","r","19.549999",2,"display","inline","fill","#4d4d4d","fill-opacity","1","stroke","#8c8c8c","stroke-width","0.9","stroke-dasharray","none","stroke-opacity","1"],["cy","60","fill","#ffffff","id","circle3-3","r","17.950001",2,"display","inline","fill","#ffffff","fill-opacity","1","stroke","#e6e6e6","stroke-width","1.8","stroke-dasharray","none","stroke-opacity","0.97"],["cursor","pointer","width","200","height","40","x","0","y","40",2,"display","inline","fill","rgba(0, 0, 0, 0)","stroke","none","stroke-width","0.3","stroke-linecap","square","stroke-linejoin","round","stroke-miterlimit","0",3,"pointerdown","pointerup","pointermove","pointerleave"],[1,"widgetOverlay"]],template:function(t,i){if(t&1){let o=ee();v(0,"widget-host",1),Ae("configChange",function(l){return z(o),De(i.widgetProperties.config,l)||(i.widgetProperties.config=l),L(l)}),V("configChange",function(l){return z(o),L(i.updateConfig(l))}),B(1,"widget-title",2),v(2,"div",3),V("onResize",function(l){return z(o),L(i.onResized(l))}),Dt(),v(3,"svg",4),B(4,"rect",5)(5,"rect",6),v(6,"g",7),B(7,"circle",8)(8,"circle",9),_(),v(9,"rect",10,0),V("pointerdown",function(l){return z(o),L(i.onPointerDown(l))})("pointerup",function(l){return z(o),L(i.onPointerUp(l))})("pointermove",function(l){return z(o),L(i.onPointerMove(l))})("pointerleave",function(l){return z(o),L(i.onPointerLeave(l))}),_()()(),Te(11,zf,1,0,"div",11),_()}t&2&&(Ee("config",i.widgetProperties.config),G("id",i.widgetProperties.uuid),P(),G("text",i.widgetProperties.config.displayName)("color",i.labelColor),P(4),fe("width",i.lineWidth)("fill",i.barColor),P(2),fe("cx",i.handlePosition),P(),fe("cx",i.handlePosition),P(3),Ue(i.dashboard.isDashboardStatic()?-1:11))},dependencies:[Ne,tt,et,ai],styles:[".widgets-container[_ngcontent-%COMP%]{display:block;position:absolute;left:0;right:0;top:15%;height:85%;width:100%;overflow:hidden;z-index:20;padding:0 20px}.widgetOverlay[_ngcontent-%COMP%]{position:absolute;width:100%;height:100%;right:0;bottom:0;color:transparent;z-index:21}.slider-bg-bar[_ngcontent-%COMP%]{fill:var(--mat-sys-inverse-on-surface)}"]})}return r})();var Lf=["grid"];function Vf(r,n){if(r&1){let e=ee();v(0,"div",2)(1,"button",3),V("click",function(){z(e);let i=ge();return L(i.saveLayoutChanges())}),v(2,"mat-icon"),T(3,"done"),_()(),v(4,"button",4),V("click",function(){z(e);let i=ge();return L(i.cancelLayoutChanges())}),v(5,"mat-icon"),T(6,"close"),_()()()}}function Ff(r,n){r&1&&B(0,"notification-badge")}function Hf(r,n){if(r&1&&(B(0,"dashboard-scroller",5),Te(1,Ff,1,0,"notification-badge")),r&2){let e=ge();G("activePage",e.dashboard.activeDashboard())("dashboards",e.dashboard.dashboards()),P(),Ue(e.notificationsInfo().alarmCount>0?1:-1)}}var ys=(()=>{class r{_app=M(ti);_dialog=M($n);dashboard=M(st);_notifications=M(Yi);_destroyRef=M(hl);_uiEvent=M(Qn);notificationsInfo=Wt(this._notifications.observerNotificationsInfo());isDashboardStatic=Wt(this.dashboard.isDashboardStatic$);_gridstack;_previousIsStaticState=!0;gridOptions={margin:4,minRow:12,maxRow:12,float:!0,acceptWidgets:!1,resizable:{handles:"all"}};constructor(){hn.addComponentToSelectorType([ec,Jd,tc,oc,bh,ch,uh,sh,ph,ih,lc,eh,vh,fh,_h,Sh,gh,Ch,xh]),Pe(()=>{this.loadDashboard(this.dashboard.activeDashboard())})}ngAfterViewInit(){this.dashboard.isDashboardStatic$.pipe(Wa(this._destroyRef)).subscribe(e=>{e?(this._gridstack.grid.setStatic(e),e!==this._previousIsStaticState&&(this.saveDashboard(),this._previousIsStaticState=e)):(this._gridstack.grid.setStatic(e),this._previousIsStaticState=e)}),this.dashboard.widgetAction$.pipe(Wa(this._destroyRef)).subscribe(e=>{e&&this._gridstack.grid.getGridItems().forEach(t=>{if(t.gridstackNode.id===e.id)switch(e.operation){case"delete":this.deleteWidget(t);break;case"duplicate":this.duplicateWidget(t);break;default:break}})}),this.resizeGridColumns(),this._uiEvent.addHotkeyListener((e,t)=>this.handleKeyDown(e,t),{ctrlKey:!0,keys:["arrowdown","arrowup"]}),setTimeout(()=>{this.loadDashboard(this.dashboard.activeDashboard())})}ngOnDestroy(){this._gridstack?.grid&&this._gridstack.grid.destroy(!0),this._gridstack=null,this._uiEvent.removeHotkeyListener(this.handleKeyDown.bind(this))}handleKeyDown(e,t){e==="arrowdown"?this.previousDashboard(t):e==="arrowup"&&this.nextDashboard(t)}resizeGridColumns(){this._gridstack.grid.cellHeight(window.innerHeight/this._gridstack.grid.getRow())}loadDashboard(e){let t=this.dashboard.dashboards()[e];this._gridstack.grid?.load(t.configuration)}saveDashboard(){let e=this._gridstack.grid.save(!1,!1)||null;this.dashboard.updateConfiguration(this.dashboard.activeDashboard(),e)}saveLayoutChanges(){this.dashboard.setStaticDashboard(!0)}cancelLayoutChanges(){this.loadDashboard(this.dashboard.activeDashboard()),this.dashboard.setStaticDashboard(!0)}addNewWidget(e){if(!this.dashboard.isDashboardStatic()){let t=e.center.x,i=e.center.y,o=this._gridstack.grid.getCellFromPixel({left:t,top:i});this._gridstack.grid.isAreaEmpty(o.x,o.y,1,1)&&(this._gridstack.grid.willItFit({x:o.x,y:o.y,w:2,h:3})?this._dialog.openFrameDialog({title:"Add Widget",component:"select-widget"},!0).subscribe(l=>{if(!l)return;let d=Ln.create(),f={x:o.x,y:o.y,w:2,h:3,id:d,selector:l,input:{widgetProperties:{type:l,uuid:d}}};this._gridstack.grid.addWidget(f)}):this._app.sendSnackbarNotification("Add Widget Error: Not enough space at the selected location. Please reorganize the dashboard to free up space or choose a larger empty area.",0))}}duplicateWidget(e){let t=Ln.create(),i=e.gridstackNode,o={w:i.w,h:i.h,id:t,selector:i.selector,input:{widgetProperties:{type:i.input.widgetProperties.type,uuid:t,config:Fn(i.input.widgetProperties.config)}}};this._gridstack.grid.willItFit(o)?this._gridstack.grid.addWidget(o):(o.h=2,o.w=2,this._gridstack.grid.willItFit(o)?this._gridstack.grid.addWidget(o):this._app.sendSnackbarNotification("Duplication failed: Insufficient space on the dashboard. Please reorganize to free up space.",0))}deleteWidget(e){this._gridstack.grid.removeWidget(e)}nextDashboard(e){e.preventDefault(),this.dashboard.isDashboardStatic()&&this.dashboard.nextDashboard()}previousDashboard(e){e.preventDefault(),this.dashboard.isDashboardStatic()&&this.dashboard.previousDashboard()}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["dashboard"]],viewQuery:function(t,i){if(t&1&&Je(Lf,7),t&2){let o;Ge(o=je())&&(i._gridstack=o.first)}},decls:4,vars:2,consts:[["grid",""],[3,"swipeup","swipedown","press","resize","options"],[1,"edit-layout-close-icon"],["mat-fab","",1,"layout-action-btn",2,"margin-right","10px",3,"click"],["mat-fab","",1,"layout-action-btn",3,"click"],[3,"activePage","dashboards"]],template:function(t,i){if(t&1){let o=ee();v(0,"gridstack",1,0),V("swipeup",function(l){return z(o),L(i.previousDashboard(l))})("swipedown",function(l){return z(o),L(i.nextDashboard(l))})("press",function(l){return z(o),L(i.addNewWidget(l))})("resize",function(){return z(o),L(i.resizeGridColumns())},!1,fl),_(),Te(2,Vf,7,0,"div",2)(3,Hf,2,3)}t&2&&(G("options",i.gridOptions),P(2),Ue(i.dashboard.isDashboardStatic()?3:2))},dependencies:[jd,hn,Yd,Bt,wi,ci,co,Xd],styles:["[_nghost-%COMP%]{display:flex;flex-direction:row;flex-wrap:nowrap;height:100%;width:100%;overflow:hidden}.grid-stack[_ngcontent-%COMP%]{width:100%}.edit-layout-close-icon[_ngcontent-%COMP%]{position:absolute;bottom:20px;right:20px;cursor:pointer;z-index:100}.layout-action-btn[_ngcontent-%COMP%]{color:var(--mat-sys-on-primary);background-color:var(--mat-sys-primary)}"]})}return r})();var Th=[{path:"dashboard",component:ys},{path:"settings",loadComponent:()=>import("./chunk-TFGDG5I5.js").then(r=>r.AppSettingsComponent)},{path:"help",loadComponent:()=>import("./chunk-JSBINEAH.js").then(r=>r.AppHelpComponent)},{path:"data",loadComponent:()=>import("./chunk-R3627Y4G.js").then(r=>r.DataInspectorComponent)},{path:"dashboards",loadComponent:()=>import("./chunk-YZ6RJSLE.js").then(r=>r.DashboardsEditorComponent)},{path:"datasets",loadComponent:()=>import("./chunk-C3SKHG6H.js").then(r=>r.SettingsDatasetsComponent)},{path:"configurations",loadComponent:()=>import("./chunk-YUK2NVZK.js").then(r=>r.SettingsConfigComponent)},{path:"login",loadComponent:()=>import("./chunk-UQ35FIC4.js").then(r=>r.WidgetLoginComponent)},{path:"**",component:ys}];var Eh={production:!0};var Nh=wr(Qa());function Uf(r,n){if(r&1){let e=ee();v(0,"div",1)(1,"button",2),V("click",function(){z(e);let i=ge();return L(i.action())}),T(2),_()()}if(r&2){let e=ge();P(2),ut(" ",e.data.action," ")}}var Gf=["label"];function jf(r,n){}var qf=Math.pow(2,31)-1,Rr=class{_overlayRef;instance;containerInstance;_afterDismissed=new bt;_afterOpened=new bt;_onAction=new bt;_durationTimeoutId;_dismissedByAction=!1;constructor(n,e){this._overlayRef=e,this.containerInstance=n,n._onExit.subscribe(()=>this._finishDismiss())}dismiss(){this._afterDismissed.closed||this.containerInstance.exit(),clearTimeout(this._durationTimeoutId)}dismissWithAction(){this._onAction.closed||(this._dismissedByAction=!0,this._onAction.next(),this._onAction.complete(),this.dismiss()),clearTimeout(this._durationTimeoutId)}closeWithAction(){this.dismissWithAction()}_dismissAfter(n){this._durationTimeoutId=setTimeout(()=>this.dismiss(),Math.min(n,qf))}_open(){this._afterOpened.closed||(this._afterOpened.next(),this._afterOpened.complete())}_finishDismiss(){this._overlayRef.dispose(),this._onAction.closed||this._onAction.complete(),this._afterDismissed.next({dismissedByAction:this._dismissedByAction}),this._afterDismissed.complete(),this._dismissedByAction=!1}afterDismissed(){return this._afterDismissed}afterOpened(){return this.containerInstance._onEnter}onAction(){return this._onAction}},Dh=new In("MatSnackBarData"),ur=class{politeness="assertive";announcementMessage="";viewContainerRef;duration=0;panelClass;direction;data=null;horizontalPosition="center";verticalPosition="bottom"},Yf=(()=>{class r{static \u0275fac=function(t){return new(t||r)};static \u0275dir=bi({type:r,selectors:[["","matSnackBarLabel",""]],hostAttrs:[1,"mat-mdc-snack-bar-label","mdc-snackbar__label"]})}return r})(),$f=(()=>{class r{static \u0275fac=function(t){return new(t||r)};static \u0275dir=bi({type:r,selectors:[["","matSnackBarActions",""]],hostAttrs:[1,"mat-mdc-snack-bar-actions","mdc-snackbar__actions"]})}return r})(),Qf=(()=>{class r{static \u0275fac=function(t){return new(t||r)};static \u0275dir=bi({type:r,selectors:[["","matSnackBarAction",""]],hostAttrs:[1,"mat-mdc-snack-bar-action","mdc-snackbar__action"]})}return r})(),Xf=(()=>{class r{snackBarRef=M(Rr);data=M(Dh);constructor(){}action(){this.snackBarRef.dismissWithAction()}get hasAction(){return!!this.data.action}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["simple-snack-bar"]],hostAttrs:[1,"mat-mdc-simple-snack-bar"],exportAs:["matSnackBar"],decls:3,vars:2,consts:[["matSnackBarLabel",""],["matSnackBarActions",""],["mat-button","","matSnackBarAction","",3,"click"]],template:function(t,i){t&1&&(v(0,"div",0),T(1),_(),Te(2,Uf,3,1,"div",1)),t&2&&(P(),ut(" ",i.data.message,`
|
|
230
|
+
`),P(),Ue(i.hasAction?2:-1))},dependencies:[ii,Yf,$f,Qf],styles:[`.mat-mdc-simple-snack-bar{display:flex}
|
|
231
|
+
`],encapsulation:2,changeDetection:0})}return r})(),bs="_mat-snack-bar-enter",_s="_mat-snack-bar-exit",Kf=(()=>{class r extends ad{_ngZone=M(ht);_elementRef=M(Me);_changeDetectorRef=M(zn);_platform=M(Gn);_rendersRef;_animationsDisabled=M(Ei,{optional:!0})==="NoopAnimations";snackBarConfig=M(ur);_document=M(zi);_trackedModals=new Set;_enterFallback;_exitFallback;_renders=new bt;_announceDelay=150;_announceTimeoutId;_destroyed=!1;_portalOutlet;_onAnnounce=new bt;_onExit=new bt;_onEnter=new bt;_animationState="void";_live;_label;_role;_liveElementId=M(lo).getId("mat-snack-bar-container-live-");constructor(){super();let e=this.snackBarConfig;e.politeness==="assertive"&&!e.announcementMessage?this._live="assertive":e.politeness==="off"?this._live="off":this._live="polite",this._platform.FIREFOX&&(this._live==="polite"&&(this._role="status"),this._live==="assertive"&&(this._role="alert")),this._rendersRef=pl(()=>this._renders.next(),{manualCleanup:!0})}attachComponentPortal(e){this._assertNotAttached();let t=this._portalOutlet.attachComponentPortal(e);return this._afterPortalAttached(),t}attachTemplatePortal(e){this._assertNotAttached();let t=this._portalOutlet.attachTemplatePortal(e);return this._afterPortalAttached(),t}attachDomPortal=e=>{this._assertNotAttached();let t=this._portalOutlet.attachDomPortal(e);return this._afterPortalAttached(),t};onAnimationEnd(e){e===_s?this._completeExit():e===bs&&(clearTimeout(this._enterFallback),this._ngZone.run(()=>{this._onEnter.next(),this._onEnter.complete()}))}enter(){this._destroyed||(this._animationState="visible",this._changeDetectorRef.markForCheck(),this._changeDetectorRef.detectChanges(),this._screenReaderAnnounce(),this._animationsDisabled?this._renders.pipe(kr(1)).subscribe(()=>{this._ngZone.run(()=>queueMicrotask(()=>this.onAnimationEnd(bs)))}):(clearTimeout(this._enterFallback),this._enterFallback=setTimeout(()=>{this._elementRef.nativeElement.classList.add("mat-snack-bar-fallback-visible"),this.onAnimationEnd(bs)},200)))}exit(){return this._destroyed?rl(void 0):(this._ngZone.run(()=>{this._animationState="hidden",this._changeDetectorRef.markForCheck(),this._elementRef.nativeElement.setAttribute("mat-exit",""),clearTimeout(this._announceTimeoutId),this._animationsDisabled?this._renders.pipe(kr(1)).subscribe(()=>{this._ngZone.run(()=>queueMicrotask(()=>this.onAnimationEnd(_s)))}):(clearTimeout(this._exitFallback),this._exitFallback=setTimeout(()=>this.onAnimationEnd(_s),200))}),this._onExit)}ngOnDestroy(){this._destroyed=!0,this._clearFromModals(),this._completeExit(),this._renders.complete(),this._rendersRef.destroy()}_completeExit(){clearTimeout(this._exitFallback),queueMicrotask(()=>{this._onExit.next(),this._onExit.complete()})}_afterPortalAttached(){let e=this._elementRef.nativeElement,t=this.snackBarConfig.panelClass;t&&(Array.isArray(t)?t.forEach(a=>e.classList.add(a)):e.classList.add(t)),this._exposeToModals();let i=this._label.nativeElement,o="mdc-snackbar__label";i.classList.toggle(o,!i.querySelector(`.${o}`))}_exposeToModals(){let e=this._liveElementId,t=this._document.querySelectorAll('body > .cdk-overlay-container [aria-modal="true"]');for(let i=0;i<t.length;i++){let o=t[i],a=o.getAttribute("aria-owns");this._trackedModals.add(o),a?a.indexOf(e)===-1&&o.setAttribute("aria-owns",a+" "+e):o.setAttribute("aria-owns",e)}}_clearFromModals(){this._trackedModals.forEach(e=>{let t=e.getAttribute("aria-owns");if(t){let i=t.replace(this._liveElementId,"").trim();i.length>0?e.setAttribute("aria-owns",i):e.removeAttribute("aria-owns")}}),this._trackedModals.clear()}_assertNotAttached(){this._portalOutlet.hasAttached()}_screenReaderAnnounce(){this._announceTimeoutId||this._ngZone.runOutsideAngular(()=>{this._announceTimeoutId=setTimeout(()=>{if(this._destroyed)return;let e=this._elementRef.nativeElement,t=e.querySelector("[aria-hidden]"),i=e.querySelector("[aria-live]");if(t&&i){let o=null;this._platform.isBrowser&&document.activeElement instanceof HTMLElement&&t.contains(document.activeElement)&&(o=document.activeElement),t.removeAttribute("aria-hidden"),i.appendChild(t),o?.focus(),this._onAnnounce.next(),this._onAnnounce.complete()}},this._announceDelay)})}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["mat-snack-bar-container"]],viewQuery:function(t,i){if(t&1&&(Je(La,7),Je(Gf,7)),t&2){let o;Ge(o=je())&&(i._portalOutlet=o.first),Ge(o=je())&&(i._label=o.first)}},hostAttrs:[1,"mdc-snackbar","mat-mdc-snack-bar-container"],hostVars:6,hostBindings:function(t,i){t&1&&V("animationend",function(a){return i.onAnimationEnd(a.animationName)})("animationcancel",function(a){return i.onAnimationEnd(a.animationName)}),t&2&&Nt("mat-snack-bar-container-enter",i._animationState==="visible")("mat-snack-bar-container-exit",i._animationState==="hidden")("mat-snack-bar-container-animations-enabled",!i._animationsDisabled)},features:[pe],decls:6,vars:3,consts:[["label",""],[1,"mdc-snackbar__surface","mat-mdc-snackbar-surface"],[1,"mat-mdc-snack-bar-label"],["aria-hidden","true"],["cdkPortalOutlet",""]],template:function(t,i){t&1&&(v(0,"div",1)(1,"div",2,0)(3,"div",3),Te(4,jf,0,0,"ng-template",4),_(),B(5,"div"),_()()),t&2&&(P(5),fe("aria-live",i._live)("role",i._role)("id",i._liveElementId))},dependencies:[La],styles:[`@keyframes _mat-snack-bar-enter{from{transform:scale(0.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes _mat-snack-bar-exit{from{opacity:1}to{opacity:0}}.mat-mdc-snack-bar-container{display:flex;align-items:center;justify-content:center;box-sizing:border-box;-webkit-tap-highlight-color:rgba(0,0,0,0);margin:8px}.mat-mdc-snack-bar-handset .mat-mdc-snack-bar-container{width:100vw}.mat-snack-bar-container-animations-enabled{opacity:0}.mat-snack-bar-container-animations-enabled.mat-snack-bar-fallback-visible{opacity:1}.mat-snack-bar-container-animations-enabled.mat-snack-bar-container-enter{animation:_mat-snack-bar-enter 150ms cubic-bezier(0, 0, 0.2, 1) forwards}.mat-snack-bar-container-animations-enabled.mat-snack-bar-container-exit{animation:_mat-snack-bar-exit 75ms cubic-bezier(0.4, 0, 1, 1) forwards}.mat-mdc-snackbar-surface{box-shadow:0px 3px 5px -1px rgba(0, 0, 0, 0.2), 0px 6px 10px 0px rgba(0, 0, 0, 0.14), 0px 1px 18px 0px rgba(0, 0, 0, 0.12);display:flex;align-items:center;justify-content:flex-start;box-sizing:border-box;padding-left:0;padding-right:8px}[dir=rtl] .mat-mdc-snackbar-surface{padding-right:0;padding-left:8px}.mat-mdc-snack-bar-container .mat-mdc-snackbar-surface{min-width:344px;max-width:672px}.mat-mdc-snack-bar-handset .mat-mdc-snackbar-surface{width:100%;min-width:0}@media(forced-colors: active){.mat-mdc-snackbar-surface{outline:solid 1px}}.mat-mdc-snack-bar-container .mat-mdc-snackbar-surface{color:var(--mdc-snackbar-supporting-text-color, var(--mat-sys-inverse-on-surface));border-radius:var(--mdc-snackbar-container-shape, var(--mat-sys-corner-extra-small));background-color:var(--mdc-snackbar-container-color, var(--mat-sys-inverse-surface))}.mdc-snackbar__label{width:100%;flex-grow:1;box-sizing:border-box;margin:0;padding:14px 8px 14px 16px}[dir=rtl] .mdc-snackbar__label{padding-left:8px;padding-right:16px}.mat-mdc-snack-bar-container .mdc-snackbar__label{font-family:var(--mdc-snackbar-supporting-text-font, var(--mat-sys-body-medium-font));font-size:var(--mdc-snackbar-supporting-text-size, var(--mat-sys-body-medium-size));font-weight:var(--mdc-snackbar-supporting-text-weight, var(--mat-sys-body-medium-weight));line-height:var(--mdc-snackbar-supporting-text-line-height, var(--mat-sys-body-medium-line-height))}.mat-mdc-snack-bar-actions{display:flex;flex-shrink:0;align-items:center;box-sizing:border-box}.mat-mdc-snack-bar-handset,.mat-mdc-snack-bar-container,.mat-mdc-snack-bar-label{flex:1 1 auto}.mat-mdc-snack-bar-container .mat-mdc-button.mat-mdc-snack-bar-action:not(:disabled).mat-unthemed{color:var(--mat-snack-bar-button-color, var(--mat-sys-inverse-primary))}.mat-mdc-snack-bar-container .mat-mdc-button.mat-mdc-snack-bar-action:not(:disabled){--mat-text-button-state-layer-color:currentColor;--mat-text-button-ripple-color:currentColor}.mat-mdc-snack-bar-container .mat-mdc-button.mat-mdc-snack-bar-action:not(:disabled) .mat-ripple-element{opacity:.1}
|
|
232
|
+
`],encapsulation:2})}return r})();function Zf(){return new ur}var Jf=new In("mat-snack-bar-default-options",{providedIn:"root",factory:Zf}),Ah=(()=>{class r{_overlay=M(cd);_live=M(Zl);_injector=M(on);_breakpointObserver=M(ao);_parentSnackBar=M(r,{optional:!0,skipSelf:!0});_defaultConfig=M(Jf);_snackBarRefAtThisLevel=null;simpleSnackBarComponent=Xf;snackBarContainerComponent=Kf;handsetCssClass="mat-mdc-snack-bar-handset";get _openedSnackBarRef(){let e=this._parentSnackBar;return e?e._openedSnackBarRef:this._snackBarRefAtThisLevel}set _openedSnackBarRef(e){this._parentSnackBar?this._parentSnackBar._openedSnackBarRef=e:this._snackBarRefAtThisLevel=e}constructor(){}openFromComponent(e,t){return this._attach(e,t)}openFromTemplate(e,t){return this._attach(e,t)}open(e,t="",i){let o=K(K({},this._defaultConfig),i);return o.data={message:e,action:t},o.announcementMessage===e&&(o.announcementMessage=void 0),this.openFromComponent(this.simpleSnackBarComponent,o)}dismiss(){this._openedSnackBarRef&&this._openedSnackBarRef.dismiss()}ngOnDestroy(){this._snackBarRefAtThisLevel&&this._snackBarRefAtThisLevel.dismiss()}_attachSnackBarContainer(e,t){let i=t&&t.viewContainerRef&&t.viewContainerRef.injector,o=on.create({parent:i||this._injector,providers:[{provide:ur,useValue:t}]}),a=new za(this.snackBarContainerComponent,t.viewContainerRef,o),l=e.attach(a);return l.instance.snackBarConfig=t,l.instance}_attach(e,t){let i=K(K(K({},new ur),this._defaultConfig),t),o=this._createOverlay(i),a=this._attachSnackBarContainer(o,i),l=new Rr(a,o);if(e instanceof gl){let d=new od(e,null,{$implicit:i.data,snackBarRef:l});l.instance=a.attachTemplatePortal(d)}else{let d=this._createInjector(i,l),f=new za(e,void 0,d),s=a.attachComponentPortal(f);l.instance=s.instance}return this._breakpointObserver.observe(mo.HandsetPortrait).pipe(Ut(o.detachments())).subscribe(d=>{o.overlayElement.classList.toggle(this.handsetCssClass,d.matches)}),i.announcementMessage&&a._onAnnounce.subscribe(()=>{this._live.announce(i.announcementMessage,i.politeness)}),this._animateSnackBar(l,i),this._openedSnackBarRef=l,this._openedSnackBarRef}_animateSnackBar(e,t){e.afterDismissed().subscribe(()=>{this._openedSnackBarRef==e&&(this._openedSnackBarRef=null),t.announcementMessage&&this._live.clear()}),t.duration&&t.duration>0&&e.afterOpened().subscribe(()=>e._dismissAfter(t.duration)),this._openedSnackBarRef?(this._openedSnackBarRef.afterDismissed().subscribe(()=>{e.containerInstance.enter()}),this._openedSnackBarRef.dismiss()):e.containerInstance.enter()}_createOverlay(e){let t=new dd;t.direction=e.direction;let i=this._overlay.position().global(),o=e.direction==="rtl",a=e.horizontalPosition==="left"||e.horizontalPosition==="start"&&!o||e.horizontalPosition==="end"&&o,l=!a&&e.horizontalPosition!=="center";return a?i.left("0"):l?i.right("0"):i.centerHorizontally(),e.verticalPosition==="top"?i.top("0"):i.bottom("0"),t.positionStrategy=i,this._overlay.create(t)}_createInjector(e,t){let i=e&&e.viewContainerRef&&e.viewContainerRef.injector;return on.create({parent:i||this._injector,providers:[{provide:Rr,useValue:t},{provide:Dh,useValue:e.data}]})}static \u0275fac=function(t){return new(t||r)};static \u0275prov=ot({token:r,factory:r.\u0275fac,providedIn:"root"})}return r})();var eg=(r,n)=>n.path;function tg(r,n){r&1&&(v(0,"mat-icon"),T(1,"info"),_())}function ig(r,n){r&1&&(v(0,"mat-icon"),T(1,"info"),_())}function ng(r,n){r&1&&(v(0,"mat-icon",3),T(1,"report"),_())}function rg(r,n){r&1&&(v(0,"mat-icon",4),T(1,"warning"),_())}function og(r,n){r&1&&(v(0,"mat-icon",5),T(1,"error"),_())}function ag(r,n){r&1&&(v(0,"mat-icon",6),T(1,"emergency_home"),_())}function sg(r,n){if(r&1){let e=ee();v(0,"div",2),Te(1,tg,2,0,"mat-icon")(2,ig,2,0,"mat-icon")(3,ng,2,0,"mat-icon",3)(4,rg,2,0,"mat-icon",4)(5,og,2,0,"mat-icon",5)(6,ag,2,0,"mat-icon",6),v(7,"div",7),T(8),_(),v(9,"div",8),T(10),eo(11,"slice"),_(),v(12,"div",9),T(13),_(),v(14,"button",10),V("click",function(){let i=z(e).$implicit,o=ge();return L(o.silence(i.path))}),v(15,"mat-icon"),T(16,"music_off"),_()(),v(17,"button",11),V("click",function(){let i=z(e).$implicit,o=ge();return L(o.clear(i.path))}),v(18,"mat-icon"),T(19,"published_with_changes"),_()()(),B(20,"mat-divider",12)}if(r&2){let e,t=n.$implicit;P(),Ue((e=t.value.state)==="nominal"?1:e==="normal"?2:e==="alert"?3:e==="warn"?4:e==="alarm"?5:e==="emergency"?6:-1),P(7),lt(t.value.state),P(2),lt(El(11,5,t.path,14)),P(3),lt(t.value.message),P(),G("disabled",!t.value.method.includes("sound"))}}function lg(r,n){r&1&&(v(0,"mat-list-item",13)(1,"span",15),T(2,"Notifications Disabled"),_(),v(3,"span")(4,"i"),T(5,"*Enable notifications in Settings."),_()()())}function dg(r,n){r&1&&(v(0,"mat-list-item",14)(1,"i"),T(2,'"No Notification"'),_()())}function cg(r,n){if(r&1&&Te(0,lg,6,0,"mat-list-item",13)(1,dg,3,0,"mat-list-item",14),r&2){let e=ge();Ue(e.notificationConfig().disableNotifications?0:1)}}function hg(r,n){if(r&1){let e=ee();v(0,"button",17),V("click",function(){z(e);let i=ge(2);return L(i.mutePlayer(!i.isMuted))}),v(1,"span",18),T(2,"volume_up"),_(),T(3," Unmute Audio "),_()}}function ug(r,n){if(r&1){let e=ee();v(0,"button",17),V("click",function(){z(e);let i=ge(2);return L(i.mutePlayer(!i.isMuted))}),v(1,"span",18),T(2,"volume_off"),_(),T(3," Mute Audio "),_()}}function mg(r,n){if(r&1&&Te(0,hg,4,0,"button",16)(1,ug,4,0,"button",16),r&2){let e=ge();Ue(e.isMuted?0:1)}}var Ph=(()=>{class r{_notificationsService=M(Yi);_notifications$=this._notificationsService.observeNotifications();notificationConfig=Wt(this._notificationsService.observeNotificationConfiguration(),{requireSync:!0});menuNotifications=Wt(this._notifications$.pipe(Ht(e=>{let t=[];return this.notificationConfig().devices.showNormalState||t.push(te.Normal),this.notificationConfig().devices.showNominalState||t.push(te.Nominal),e.filter(i=>i.value&&i.value.state&&!t.includes(i.value.state))}),Ht(e=>e.filter(t=>t.value&&t.value.method&&t.value.method.includes(Hn.Visual)))),{requireSync:!0,equal:xr});isMuted=!1;mutePlayer(e){this.isMuted=e,this._notificationsService.mutePlayer(e)}silence(e){this._notificationsService.setSkMethod(e,[Hn.Visual])}clear(e){this._notificationsService.setSkState(e,te.Normal)}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["menu-notifications"]],decls:6,vars:2,consts:[[1,"menu-item-container"],[1,"actions-container","actions-bottom-container"],[1,"notification-container"],[1,"icon-alert-color"],[1,"icon-warn-color"],[1,"icon-alarm-color"],[1,"icon-emergency-color"],[1,"notification-title"],[1,"notification-path","scrollable-text"],[1,"notification-text"],["mat-icon-button","",1,"notification-action-btn",3,"click","disabled"],["mat-icon-button","",1,"notification-action-btn",3,"click"],[1,"notification-divider"],["lines","3","disabled","true",2,"text-align","center"],["disabled","true",2,"text-align","center"],["matListItemTitle",""],["mat-flat-button","","matTooltip","Temporally toggle all notification audio. To permanently disable/enable notification audio, use the configuration settings option",1,"action-button"],["mat-flat-button","","matTooltip","Temporally toggle all notification audio. To permanently disable/enable notification audio, use the configuration settings option",1,"action-button",3,"click"],[1,"material-icons"]],template:function(t,i){t&1&&(v(0,"mat-list",0),Wi(1,sg,21,8,null,null,eg,!1,cg,2,1),_(),v(4,"div",1),Te(5,mg,2,1),_()),t&2&&(P(),Bi(i.menuNotifications()),P(4),Ue(i.notificationConfig().disableNotifications?-1:5))},dependencies:[fo,wd,po,md,yd,ci,ii,nd,Ao,Nd,Rd,Bt,wi,Pl],styles:[".notification-container[_ngcontent-%COMP%]{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-evenly;padding:2px 10px 7px;overflow-y:scroll;overflow-x:hidden;scroll-behavior:smooth}mat-icon[_ngcontent-%COMP%]{margin-right:10px}.scrollable-text[_ngcontent-%COMP%]{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.scrollable-text[_ngcontent-%COMP%]:hover{overflow:auto;white-space:normal;word-wrap:break-word}.notification-title[_ngcontent-%COMP%]{text-transform:capitalize;font-size:var(--mat-sys-headline-small-size);width:calc(100% - 34px)}.notification-path[_ngcontent-%COMP%]{font-size:var(--mat-sys-body-small-size);word-break:break-all;width:100%}.notification-text[_ngcontent-%COMP%]{font-size:var(--mat-sys-body-small-line-height);font-style:italic;width:100%;overflow:auto;white-space:normal;word-wrap:break-word}.notification-action-btn[_ngcontent-%COMP%]{background-color:var(--mat-sys-surface-container)}.notification-btn-container[_ngcontent-%COMP%]{display:inline-block;width:50%;height:48px;text-align:center}.menu-item-container[_ngcontent-%COMP%]{width:230px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;height:calc(100% - 48px)}.notification-bottom-container[_ngcontent-%COMP%]{position:absolute;bottom:0;width:100%;background-color:var(--mat-sys-surface-container)}.actions-container[_ngcontent-%COMP%]{display:grid;grid-auto-flow:column}.actions-bottom-container[_ngcontent-%COMP%]{position:absolute;bottom:0;width:100%;height:48px}.action-button[_ngcontent-%COMP%]{border-radius:0;height:48px;border-bottom-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large))}.icon-alert-color[_ngcontent-%COMP%]{color:var(--kip-zone-alert-color)}.icon-warn-color[_ngcontent-%COMP%]{color:var(--kip-zone-warn-color)}.icon-alarm-color[_ngcontent-%COMP%]{color:var(--kip-zone-alarm-color)}.icon-emergency-color[_ngcontent-%COMP%]{color:var(--kip-zone-emergency-color)}.alarm-emergency-blink[_ngcontent-%COMP%]{animation:_ngcontent-%COMP%_blinking-emergency 1.5s infinite}@keyframes _ngcontent-%COMP%_blinking-emergency{0%{background-color:var(--kip-zone-alarm-color)}50%{background-color:transparent}to{background-color:var(--kip-zone-alarm-color)}}.warn[_ngcontent-%COMP%]{color:var(--kip-zone-warn-color)}.notification-divider[_ngcontent-%COMP%]{padding-top:10px}"]})}return r})();var qo=["*"],fg=["content"],gg=[[["mat-drawer"]],[["mat-drawer-content"]],"*"],vg=["mat-drawer","mat-drawer-content","*"];function yg(r,n){if(r&1){let e=ee();v(0,"div",1),V("click",function(){z(e);let i=ge();return L(i._onBackdropClicked())}),_()}if(r&2){let e=ge();Nt("mat-drawer-shown",e._isShowingBackdrop())}}function bg(r,n){r&1&&(v(0,"mat-drawer-content"),Ct(1,2),_())}var _g=[[["mat-sidenav"]],[["mat-sidenav-content"]],"*"],wg=["mat-sidenav","mat-sidenav-content","*"];function kg(r,n){if(r&1){let e=ee();v(0,"div",1),V("click",function(){z(e);let i=ge();return L(i._onBackdropClicked())}),_()}if(r&2){let e=ge();Nt("mat-drawer-shown",e._isShowingBackdrop())}}function Sg(r,n){r&1&&(v(0,"mat-sidenav-content"),Ct(1,2),_())}var Cg=`.mat-drawer-container{position:relative;z-index:1;color:var(--mat-sidenav-content-text-color, var(--mat-sys-on-background));background-color:var(--mat-sidenav-content-background-color, var(--mat-sys-background));box-sizing:border-box;display:block;overflow:hidden}.mat-drawer-container[fullscreen]{top:0;left:0;right:0;bottom:0;position:absolute}.mat-drawer-container[fullscreen].mat-drawer-container-has-open{overflow:hidden}.mat-drawer-container.mat-drawer-container-explicit-backdrop .mat-drawer-side{z-index:3}.mat-drawer-container.ng-animate-disabled .mat-drawer-backdrop,.mat-drawer-container.ng-animate-disabled .mat-drawer-content,.ng-animate-disabled .mat-drawer-container .mat-drawer-backdrop,.ng-animate-disabled .mat-drawer-container .mat-drawer-content{transition:none}.mat-drawer-backdrop{top:0;left:0;right:0;bottom:0;position:absolute;display:block;z-index:3;visibility:hidden}.mat-drawer-backdrop.mat-drawer-shown{visibility:visible;background-color:var(--mat-sidenav-scrim-color, color-mix(in srgb, var(--mat-sys-neutral-variant20) 40%, transparent))}.mat-drawer-transition .mat-drawer-backdrop{transition-duration:400ms;transition-timing-function:cubic-bezier(0.25, 0.8, 0.25, 1);transition-property:background-color,visibility}@media(forced-colors: active){.mat-drawer-backdrop{opacity:.5}}.mat-drawer-content{position:relative;z-index:1;display:block;height:100%;overflow:auto}.mat-drawer-content.mat-drawer-content-hidden{opacity:0}.mat-drawer-transition .mat-drawer-content{transition-duration:400ms;transition-timing-function:cubic-bezier(0.25, 0.8, 0.25, 1);transition-property:transform,margin-left,margin-right}.mat-drawer{position:relative;z-index:4;color:var(--mat-sidenav-container-text-color, var(--mat-sys-on-surface-variant));box-shadow:var(--mat-sidenav-container-elevation-shadow, none);background-color:var(--mat-sidenav-container-background-color, var(--mat-sys-surface));border-top-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));width:var(--mat-sidenav-container-width, 360px);display:block;position:absolute;top:0;bottom:0;z-index:3;outline:0;box-sizing:border-box;overflow-y:auto;transform:translate3d(-100%, 0, 0)}@media(forced-colors: active){.mat-drawer,[dir=rtl] .mat-drawer.mat-drawer-end{border-right:solid 1px currentColor}}@media(forced-colors: active){[dir=rtl] .mat-drawer,.mat-drawer.mat-drawer-end{border-left:solid 1px currentColor;border-right:none}}.mat-drawer.mat-drawer-side{z-index:2}.mat-drawer.mat-drawer-end{right:0;transform:translate3d(100%, 0, 0);border-top-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-top-right-radius:0;border-bottom-right-radius:0}[dir=rtl] .mat-drawer{border-top-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-top-right-radius:0;border-bottom-right-radius:0;transform:translate3d(100%, 0, 0)}[dir=rtl] .mat-drawer.mat-drawer-end{border-top-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-top-left-radius:0;border-bottom-left-radius:0;left:0;right:auto;transform:translate3d(-100%, 0, 0)}.mat-drawer-transition .mat-drawer{transition:transform 400ms cubic-bezier(0.25, 0.8, 0.25, 1)}.mat-drawer:not(.mat-drawer-opened):not(.mat-drawer-animating){visibility:hidden;box-shadow:none}.mat-drawer:not(.mat-drawer-opened):not(.mat-drawer-animating) .mat-drawer-inner-container{display:none}.mat-drawer.mat-drawer-opened.mat-drawer-opened{transform:none}.mat-drawer-side{box-shadow:none;border-right-color:var(--mat-sidenav-container-divider-color, transparent);border-right-width:1px;border-right-style:solid}.mat-drawer-side.mat-drawer-end{border-left-color:var(--mat-sidenav-container-divider-color, transparent);border-left-width:1px;border-left-style:solid;border-right:none}[dir=rtl] .mat-drawer-side{border-left-color:var(--mat-sidenav-container-divider-color, transparent);border-left-width:1px;border-left-style:solid;border-right:none}[dir=rtl] .mat-drawer-side.mat-drawer-end{border-right-color:var(--mat-sidenav-container-divider-color, transparent);border-right-width:1px;border-right-style:solid;border-left:none}.mat-drawer-inner-container{width:100%;height:100%;overflow:auto}.mat-sidenav-fixed{position:fixed}
|
|
233
|
+
`;var xg=new In("MAT_DRAWER_DEFAULT_AUTOSIZE",{providedIn:"root",factory:Tg}),Ss=new In("MAT_DRAWER_CONTAINER");function Tg(){return!1}var Go=(()=>{class r extends qn{_platform=M(Gn);_changeDetectorRef=M(zn);_container=M(ks);constructor(){let e=M(Me),t=M(sd),i=M(ht);super(e,t,i)}ngAfterContentInit(){this._container._contentMarginChanges.subscribe(()=>{this._changeDetectorRef.markForCheck()})}_shouldBeHidden(){if(this._platform.isBrowser)return!1;let{start:e,end:t}=this._container;return e!=null&&e.mode!=="over"&&e.opened||t!=null&&t.mode!=="over"&&t.opened}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["mat-drawer-content"]],hostAttrs:[1,"mat-drawer-content"],hostVars:6,hostBindings:function(t,i){t&2&&(He("margin-left",i._container._contentMargins.left,"px")("margin-right",i._container._contentMargins.right,"px"),Nt("mat-drawer-content-hidden",i._shouldBeHidden()))},features:[Bn([{provide:qn,useExisting:r}]),pe],ngContentSelectors:qo,decls:1,vars:0,template:function(t,i){t&1&&(Jt(),Ct(0))},encapsulation:2,changeDetection:0})}return r})(),ws=(()=>{class r{_elementRef=M(Me);_focusTrapFactory=M(Kl);_focusMonitor=M($l);_platform=M(Gn);_ngZone=M(ht);_renderer=M(Zr);_interactivityChecker=M(so);_doc=M(zi,{optional:!0});_container=M(Ss,{optional:!0});_focusTrap=null;_elementFocusedBeforeDrawerWasOpened=null;_eventCleanups;_isAttached;_anchor;get position(){return this._position}set position(e){e=e==="end"?"end":"start",e!==this._position&&(this._isAttached&&this._updatePositionInParent(e),this._position=e,this.onPositionChanged.emit())}_position="start";get mode(){return this._mode}set mode(e){this._mode=e,this._updateFocusTrapState(),this._modeChanged.next()}_mode="over";get disableClose(){return this._disableClose}set disableClose(e){this._disableClose=sn(e)}_disableClose=!1;get autoFocus(){let e=this._autoFocus;return e??(this.mode==="side"?"dialog":"first-tabbable")}set autoFocus(e){(e==="true"||e==="false"||e==null)&&(e=sn(e)),this._autoFocus=e}_autoFocus;get opened(){return this._opened}set opened(e){this.toggle(sn(e))}_opened=!1;_openedVia;_animationStarted=new bt;_animationEnd=new bt;openedChange=new at(!0);_openedStream=this.openedChange.pipe(Mn(e=>e),Ht(()=>{}));openedStart=this._animationStarted.pipe(Mn(()=>this.opened),Da(void 0));_closedStream=this.openedChange.pipe(Mn(e=>!e),Ht(()=>{}));closedStart=this._animationStarted.pipe(Mn(()=>!this.opened),Da(void 0));_destroyed=new bt;onPositionChanged=new at;_content;_modeChanged=new bt;_injector=M(on);_changeDetectorRef=M(zn);constructor(){this.openedChange.pipe(Ut(this._destroyed)).subscribe(e=>{e?(this._doc&&(this._elementFocusedBeforeDrawerWasOpened=this._doc.activeElement),this._takeFocus()):this._isFocusWithinDrawer()&&this._restoreFocus(this._openedVia||"program")}),this._ngZone.runOutsideAngular(()=>{let e=this._elementRef.nativeElement;ol(e,"keydown").pipe(Mn(t=>t.keyCode===27&&!this.disableClose&&!ed(t)),Ut(this._destroyed)).subscribe(t=>this._ngZone.run(()=>{this.close(),t.stopPropagation(),t.preventDefault()})),this._eventCleanups=[this._renderer.listen(e,"transitionrun",this._handleTransitionEvent),this._renderer.listen(e,"transitionend",this._handleTransitionEvent),this._renderer.listen(e,"transitioncancel",this._handleTransitionEvent)]}),this._animationEnd.subscribe(()=>{this.openedChange.emit(this._opened)})}_forceFocus(e,t){this._interactivityChecker.isFocusable(e)||(e.tabIndex=-1,this._ngZone.runOutsideAngular(()=>{let i=()=>{o(),a(),e.removeAttribute("tabindex")},o=this._renderer.listen(e,"blur",i),a=this._renderer.listen(e,"mousedown",i)})),e.focus(t)}_focusByCssSelector(e,t){let i=this._elementRef.nativeElement.querySelector(e);i&&this._forceFocus(i,t)}_takeFocus(){if(!this._focusTrap)return;let e=this._elementRef.nativeElement;switch(this.autoFocus){case!1:case"dialog":return;case!0:case"first-tabbable":Sr(()=>{!this._focusTrap.focusInitialElement()&&typeof e.focus=="function"&&e.focus()},{injector:this._injector});break;case"first-heading":this._focusByCssSelector('h1, h2, h3, h4, h5, h6, [role="heading"]');break;default:this._focusByCssSelector(this.autoFocus);break}}_restoreFocus(e){this.autoFocus!=="dialog"&&(this._elementFocusedBeforeDrawerWasOpened?this._focusMonitor.focusVia(this._elementFocusedBeforeDrawerWasOpened,e):this._elementRef.nativeElement.blur(),this._elementFocusedBeforeDrawerWasOpened=null)}_isFocusWithinDrawer(){let e=this._doc.activeElement;return!!e&&this._elementRef.nativeElement.contains(e)}ngAfterViewInit(){this._isAttached=!0,this._position==="end"&&this._updatePositionInParent("end"),this._platform.isBrowser&&(this._focusTrap=this._focusTrapFactory.create(this._elementRef.nativeElement),this._updateFocusTrapState())}ngOnDestroy(){this._eventCleanups.forEach(e=>e()),this._focusTrap?.destroy(),this._anchor?.remove(),this._anchor=null,this._animationStarted.complete(),this._animationEnd.complete(),this._modeChanged.complete(),this._destroyed.next(),this._destroyed.complete()}open(e){return this.toggle(!0,e)}close(){return this.toggle(!1)}_closeViaBackdropClick(){return this._setOpen(!1,!0,"mouse")}toggle(e=!this.opened,t){e&&t&&(this._openedVia=t);let i=this._setOpen(e,!e&&this._isFocusWithinDrawer(),this._openedVia||"program");return e||(this._openedVia=null),i}_setOpen(e,t,i){return e===this._opened?Promise.resolve(e?"open":"close"):(this._opened=e,this._container?._transitionsEnabled?this._setIsAnimating(!0):setTimeout(()=>{this._animationStarted.next(),this._animationEnd.next()}),this._elementRef.nativeElement.classList.toggle("mat-drawer-opened",e),!e&&t&&this._restoreFocus(i),this._changeDetectorRef.markForCheck(),this._updateFocusTrapState(),new Promise(o=>{this.openedChange.pipe(kr(1)).subscribe(a=>o(a?"open":"close"))}))}_setIsAnimating(e){this._elementRef.nativeElement.classList.toggle("mat-drawer-animating",e)}_getWidth(){return this._elementRef.nativeElement.offsetWidth||0}_updateFocusTrapState(){this._focusTrap&&(this._focusTrap.enabled=!!this._container?.hasBackdrop&&this.opened)}_updatePositionInParent(e){if(!this._platform.isBrowser)return;let t=this._elementRef.nativeElement,i=t.parentNode;e==="end"?(this._anchor||(this._anchor=this._doc.createComment("mat-drawer-anchor"),i.insertBefore(this._anchor,t)),i.appendChild(t)):this._anchor&&this._anchor.parentNode.insertBefore(t,this._anchor)}_handleTransitionEvent=e=>{let t=this._elementRef.nativeElement;e.target===t&&this._ngZone.run(()=>{e.type==="transitionrun"?this._animationStarted.next(e):(e.type==="transitionend"&&this._setIsAnimating(!1),this._animationEnd.next(e))})};static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["mat-drawer"]],viewQuery:function(t,i){if(t&1&&Je(fg,5),t&2){let o;Ge(o=je())&&(i._content=o.first)}},hostAttrs:["tabIndex","-1",1,"mat-drawer"],hostVars:11,hostBindings:function(t,i){t&2&&(fe("align",null),He("visibility",!i._container&&!i.opened?"hidden":null),Nt("mat-drawer-end",i.position==="end")("mat-drawer-over",i.mode==="over")("mat-drawer-push",i.mode==="push")("mat-drawer-side",i.mode==="side"))},inputs:{position:"position",mode:"mode",disableClose:"disableClose",autoFocus:"autoFocus",opened:"opened"},outputs:{openedChange:"openedChange",_openedStream:"opened",openedStart:"openedStart",_closedStream:"closed",closedStart:"closedStart",onPositionChanged:"positionChanged"},exportAs:["matDrawer"],ngContentSelectors:qo,decls:3,vars:0,consts:[["content",""],["cdkScrollable","",1,"mat-drawer-inner-container"]],template:function(t,i){t&1&&(Jt(),v(0,"div",1,0),Ct(2),_())},dependencies:[qn],encapsulation:2,changeDetection:0})}return r})(),ks=(()=>{class r{_dir=M(id,{optional:!0});_element=M(Me);_ngZone=M(ht);_changeDetectorRef=M(zn);_animationMode=M(Ei,{optional:!0});_transitionsEnabled=!1;_allDrawers;_drawers=new ul;_content;_userContent;get start(){return this._start}get end(){return this._end}get autosize(){return this._autosize}set autosize(e){this._autosize=sn(e)}_autosize=M(xg);get hasBackdrop(){return this._drawerHasBackdrop(this._start)||this._drawerHasBackdrop(this._end)}set hasBackdrop(e){this._backdropOverride=e==null?null:sn(e)}_backdropOverride;backdropClick=new at;_start;_end;_left;_right;_destroyed=new bt;_doCheckSubject=new bt;_contentMargins={left:null,right:null};_contentMarginChanges=new bt;get scrollable(){return this._userContent||this._content}_injector=M(on);constructor(){let e=M(Gn),t=M(ld);this._dir?.change.pipe(Ut(this._destroyed)).subscribe(()=>{this._validateDrawers(),this.updateContentMargins()}),t.change().pipe(Ut(this._destroyed)).subscribe(()=>this.updateContentMargins()),this._animationMode!=="NoopAnimations"&&e.isBrowser&&this._ngZone.runOutsideAngular(()=>{setTimeout(()=>{this._element.nativeElement.classList.add("mat-drawer-transition"),this._transitionsEnabled=!0},200)})}ngAfterContentInit(){this._allDrawers.changes.pipe(Ma(this._allDrawers),Ut(this._destroyed)).subscribe(e=>{this._drawers.reset(e.filter(t=>!t._container||t._container===this)),this._drawers.notifyOnChanges()}),this._drawers.changes.pipe(Ma(null)).subscribe(()=>{this._validateDrawers(),this._drawers.forEach(e=>{this._watchDrawerToggle(e),this._watchDrawerPosition(e),this._watchDrawerMode(e)}),(!this._drawers.length||this._isDrawerOpen(this._start)||this._isDrawerOpen(this._end))&&this.updateContentMargins(),this._changeDetectorRef.markForCheck()}),this._ngZone.runOutsideAngular(()=>{this._doCheckSubject.pipe(Xr(10),Ut(this._destroyed)).subscribe(()=>this.updateContentMargins())})}ngOnDestroy(){this._contentMarginChanges.complete(),this._doCheckSubject.complete(),this._drawers.destroy(),this._destroyed.next(),this._destroyed.complete()}open(){this._drawers.forEach(e=>e.open())}close(){this._drawers.forEach(e=>e.close())}updateContentMargins(){let e=0,t=0;if(this._left&&this._left.opened){if(this._left.mode=="side")e+=this._left._getWidth();else if(this._left.mode=="push"){let i=this._left._getWidth();e+=i,t-=i}}if(this._right&&this._right.opened){if(this._right.mode=="side")t+=this._right._getWidth();else if(this._right.mode=="push"){let i=this._right._getWidth();t+=i,e-=i}}e=e||null,t=t||null,(e!==this._contentMargins.left||t!==this._contentMargins.right)&&(this._contentMargins={left:e,right:t},this._ngZone.run(()=>this._contentMarginChanges.next(this._contentMargins)))}ngDoCheck(){this._autosize&&this._isPushed()&&this._ngZone.runOutsideAngular(()=>this._doCheckSubject.next())}_watchDrawerToggle(e){e._animationStarted.pipe(Ut(this._drawers.changes)).subscribe(()=>{this.updateContentMargins(),this._changeDetectorRef.markForCheck()}),e.mode!=="side"&&e.openedChange.pipe(Ut(this._drawers.changes)).subscribe(()=>this._setContainerClass(e.opened))}_watchDrawerPosition(e){e.onPositionChanged.pipe(Ut(this._drawers.changes)).subscribe(()=>{Sr({read:()=>this._validateDrawers()},{injector:this._injector})})}_watchDrawerMode(e){e._modeChanged.pipe(Ut(sl(this._drawers.changes,this._destroyed))).subscribe(()=>{this.updateContentMargins(),this._changeDetectorRef.markForCheck()})}_setContainerClass(e){let t=this._element.nativeElement.classList,i="mat-drawer-container-has-open";e?t.add(i):t.remove(i)}_validateDrawers(){this._start=this._end=null,this._drawers.forEach(e=>{e.position=="end"?(this._end!=null,this._end=e):(this._start!=null,this._start=e)}),this._right=this._left=null,this._dir&&this._dir.value==="rtl"?(this._left=this._end,this._right=this._start):(this._left=this._start,this._right=this._end)}_isPushed(){return this._isDrawerOpen(this._start)&&this._start.mode!="over"||this._isDrawerOpen(this._end)&&this._end.mode!="over"}_onBackdropClicked(){this.backdropClick.emit(),this._closeModalDrawersViaBackdrop()}_closeModalDrawersViaBackdrop(){[this._start,this._end].filter(e=>e&&!e.disableClose&&this._drawerHasBackdrop(e)).forEach(e=>e._closeViaBackdropClick())}_isShowingBackdrop(){return this._isDrawerOpen(this._start)&&this._drawerHasBackdrop(this._start)||this._isDrawerOpen(this._end)&&this._drawerHasBackdrop(this._end)}_isDrawerOpen(e){return e!=null&&e.opened}_drawerHasBackdrop(e){return this._backdropOverride==null?!!e&&e.mode!=="side":this._backdropOverride}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["mat-drawer-container"]],contentQueries:function(t,i,o){if(t&1&&(an(o,Go,5),an(o,ws,5)),t&2){let a;Ge(a=je())&&(i._content=a.first),Ge(a=je())&&(i._allDrawers=a)}},viewQuery:function(t,i){if(t&1&&Je(Go,5),t&2){let o;Ge(o=je())&&(i._userContent=o.first)}},hostAttrs:[1,"mat-drawer-container"],hostVars:2,hostBindings:function(t,i){t&2&&Nt("mat-drawer-container-explicit-backdrop",i._backdropOverride)},inputs:{autosize:"autosize",hasBackdrop:"hasBackdrop"},outputs:{backdropClick:"backdropClick"},exportAs:["matDrawerContainer"],features:[Bn([{provide:Ss,useExisting:r}])],ngContentSelectors:vg,decls:4,vars:2,consts:[[1,"mat-drawer-backdrop",3,"mat-drawer-shown"],[1,"mat-drawer-backdrop",3,"click"]],template:function(t,i){t&1&&(Jt(gg),Te(0,yg,1,2,"div",0),Ct(1),Ct(2,1),Te(3,bg,2,0,"mat-drawer-content")),t&2&&(Ue(i.hasBackdrop?0:-1),P(3),Ue(i._content?-1:3))},dependencies:[Go],styles:[`.mat-drawer-container{position:relative;z-index:1;color:var(--mat-sidenav-content-text-color, var(--mat-sys-on-background));background-color:var(--mat-sidenav-content-background-color, var(--mat-sys-background));box-sizing:border-box;display:block;overflow:hidden}.mat-drawer-container[fullscreen]{top:0;left:0;right:0;bottom:0;position:absolute}.mat-drawer-container[fullscreen].mat-drawer-container-has-open{overflow:hidden}.mat-drawer-container.mat-drawer-container-explicit-backdrop .mat-drawer-side{z-index:3}.mat-drawer-container.ng-animate-disabled .mat-drawer-backdrop,.mat-drawer-container.ng-animate-disabled .mat-drawer-content,.ng-animate-disabled .mat-drawer-container .mat-drawer-backdrop,.ng-animate-disabled .mat-drawer-container .mat-drawer-content{transition:none}.mat-drawer-backdrop{top:0;left:0;right:0;bottom:0;position:absolute;display:block;z-index:3;visibility:hidden}.mat-drawer-backdrop.mat-drawer-shown{visibility:visible;background-color:var(--mat-sidenav-scrim-color, color-mix(in srgb, var(--mat-sys-neutral-variant20) 40%, transparent))}.mat-drawer-transition .mat-drawer-backdrop{transition-duration:400ms;transition-timing-function:cubic-bezier(0.25, 0.8, 0.25, 1);transition-property:background-color,visibility}@media(forced-colors: active){.mat-drawer-backdrop{opacity:.5}}.mat-drawer-content{position:relative;z-index:1;display:block;height:100%;overflow:auto}.mat-drawer-content.mat-drawer-content-hidden{opacity:0}.mat-drawer-transition .mat-drawer-content{transition-duration:400ms;transition-timing-function:cubic-bezier(0.25, 0.8, 0.25, 1);transition-property:transform,margin-left,margin-right}.mat-drawer{position:relative;z-index:4;color:var(--mat-sidenav-container-text-color, var(--mat-sys-on-surface-variant));box-shadow:var(--mat-sidenav-container-elevation-shadow, none);background-color:var(--mat-sidenav-container-background-color, var(--mat-sys-surface));border-top-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));width:var(--mat-sidenav-container-width, 360px);display:block;position:absolute;top:0;bottom:0;z-index:3;outline:0;box-sizing:border-box;overflow-y:auto;transform:translate3d(-100%, 0, 0)}@media(forced-colors: active){.mat-drawer,[dir=rtl] .mat-drawer.mat-drawer-end{border-right:solid 1px currentColor}}@media(forced-colors: active){[dir=rtl] .mat-drawer,.mat-drawer.mat-drawer-end{border-left:solid 1px currentColor;border-right:none}}.mat-drawer.mat-drawer-side{z-index:2}.mat-drawer.mat-drawer-end{right:0;transform:translate3d(100%, 0, 0);border-top-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-top-right-radius:0;border-bottom-right-radius:0}[dir=rtl] .mat-drawer{border-top-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-left-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-top-right-radius:0;border-bottom-right-radius:0;transform:translate3d(100%, 0, 0)}[dir=rtl] .mat-drawer.mat-drawer-end{border-top-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-bottom-right-radius:var(--mat-sidenav-container-shape, var(--mat-sys-corner-large));border-top-left-radius:0;border-bottom-left-radius:0;left:0;right:auto;transform:translate3d(-100%, 0, 0)}.mat-drawer-transition .mat-drawer{transition:transform 400ms cubic-bezier(0.25, 0.8, 0.25, 1)}.mat-drawer:not(.mat-drawer-opened):not(.mat-drawer-animating){visibility:hidden;box-shadow:none}.mat-drawer:not(.mat-drawer-opened):not(.mat-drawer-animating) .mat-drawer-inner-container{display:none}.mat-drawer.mat-drawer-opened.mat-drawer-opened{transform:none}.mat-drawer-side{box-shadow:none;border-right-color:var(--mat-sidenav-container-divider-color, transparent);border-right-width:1px;border-right-style:solid}.mat-drawer-side.mat-drawer-end{border-left-color:var(--mat-sidenav-container-divider-color, transparent);border-left-width:1px;border-left-style:solid;border-right:none}[dir=rtl] .mat-drawer-side{border-left-color:var(--mat-sidenav-container-divider-color, transparent);border-left-width:1px;border-left-style:solid;border-right:none}[dir=rtl] .mat-drawer-side.mat-drawer-end{border-right-color:var(--mat-sidenav-container-divider-color, transparent);border-right-width:1px;border-right-style:solid;border-left:none}.mat-drawer-inner-container{width:100%;height:100%;overflow:auto}.mat-sidenav-fixed{position:fixed}
|
|
234
|
+
`],encapsulation:2,changeDetection:0})}return r})(),jo=(()=>{class r extends Go{static \u0275fac=(()=>{let e;return function(i){return(e||(e=Nn(r)))(i||r)}})();static \u0275cmp=U({type:r,selectors:[["mat-sidenav-content"]],hostAttrs:[1,"mat-drawer-content","mat-sidenav-content"],features:[Bn([{provide:qn,useExisting:r}]),pe],ngContentSelectors:qo,decls:1,vars:0,template:function(t,i){t&1&&(Jt(),Ct(0))},encapsulation:2,changeDetection:0})}return r})(),Cs=(()=>{class r extends ws{get fixedInViewport(){return this._fixedInViewport}set fixedInViewport(e){this._fixedInViewport=sn(e)}_fixedInViewport=!1;get fixedTopGap(){return this._fixedTopGap}set fixedTopGap(e){this._fixedTopGap=Ba(e)}_fixedTopGap=0;get fixedBottomGap(){return this._fixedBottomGap}set fixedBottomGap(e){this._fixedBottomGap=Ba(e)}_fixedBottomGap=0;static \u0275fac=(()=>{let e;return function(i){return(e||(e=Nn(r)))(i||r)}})();static \u0275cmp=U({type:r,selectors:[["mat-sidenav"]],hostAttrs:["tabIndex","-1",1,"mat-drawer","mat-sidenav"],hostVars:15,hostBindings:function(t,i){t&2&&(fe("align",null),He("top",i.fixedInViewport?i.fixedTopGap:null,"px")("bottom",i.fixedInViewport?i.fixedBottomGap:null,"px"),Nt("mat-drawer-end",i.position==="end")("mat-drawer-over",i.mode==="over")("mat-drawer-push",i.mode==="push")("mat-drawer-side",i.mode==="side")("mat-sidenav-fixed",i.fixedInViewport))},inputs:{fixedInViewport:"fixedInViewport",fixedTopGap:"fixedTopGap",fixedBottomGap:"fixedBottomGap"},exportAs:["matSidenav"],features:[Bn([{provide:ws,useExisting:r}]),pe],ngContentSelectors:qo,decls:3,vars:0,consts:[["content",""],["cdkScrollable","",1,"mat-drawer-inner-container"]],template:function(t,i){t&1&&(Jt(),v(0,"div",1,0),Ct(2),_())},dependencies:[qn],encapsulation:2,changeDetection:0})}return r})(),Mh=(()=>{class r extends ks{_allDrawers=void 0;_content=void 0;static \u0275fac=(()=>{let e;return function(i){return(e||(e=Nn(r)))(i||r)}})();static \u0275cmp=U({type:r,selectors:[["mat-sidenav-container"]],contentQueries:function(t,i,o){if(t&1&&(an(o,jo,5),an(o,Cs,5)),t&2){let a;Ge(a=je())&&(i._content=a.first),Ge(a=je())&&(i._allDrawers=a)}},hostAttrs:[1,"mat-drawer-container","mat-sidenav-container"],hostVars:2,hostBindings:function(t,i){t&2&&Nt("mat-drawer-container-explicit-backdrop",i._backdropOverride)},exportAs:["matSidenavContainer"],features:[Bn([{provide:Ss,useExisting:r},{provide:ks,useExisting:r}]),pe],ngContentSelectors:wg,decls:4,vars:2,consts:[[1,"mat-drawer-backdrop",3,"mat-drawer-shown"],[1,"mat-drawer-backdrop",3,"click"]],template:function(t,i){t&1&&(Jt(_g),Te(0,kg,1,2,"div",0),Ct(1),Ct(2,1),Te(3,Sg,2,0,"mat-sidenav-content")),t&2&&(Ue(i.hasBackdrop?0:-1),P(3),Ue(i._content?-1:3))},dependencies:[jo],styles:[Cg],encapsulation:2,changeDetection:0})}return r})(),Oh=(()=>{class r{static \u0275fac=function(t){return new(t||r)};static \u0275mod=Zt({type:r});static \u0275inj=Kt({imports:[jn,Va,Va,jn]})}return r})();var Ih=(()=>{class r{svgIcon=Y.required();iconSize=Y.required();label=Y.required();constructor(){let e=M(Yl),t=M(Vn);e.addSvgIconSet(t.bypassSecurityTrustResourceUrl("assets/svg/icons.svg"))}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["tile-large-icon"]],inputs:{svgIcon:[1,"svgIcon"],iconSize:[1,"iconSize"],label:[1,"label"]},decls:3,vars:6,consts:[["aria-hidden","false",3,"svgIcon"],[1,"large-icon-tile-label"]],template:function(t,i){t&1&&(B(0,"mat-icon",0),v(1,"p",1),T(2),_()),t&2&&(He("width",i.iconSize(),"px")("height",i.iconSize(),"px"),G("svgIcon",i.svgIcon()),P(2),lt(i.label()))},dependencies:[Bt,wi,uo],styles:["[_nghost-%COMP%]{display:block;text-align:center;-webkit-tap-highlight-color:rgba(0,0,0,0);cursor:pointer;padding:10px}[_nghost-%COMP%]:hover{background-color:var(--mat-sys-inverse-on-surface)}[_nghost-%COMP%]:focus-visible{background-color:var(--mat-sys-surface-bright);outline:-webkit-focus-ring-color auto 0px}.large-icon-tile-label[_ngcontent-%COMP%]{cursor:pointer;color:var(--mat-sys-outline)}"]})}return r})();function Dg(r,n){if(r&1){let e=ee();v(0,"button",7),V("click",function(){z(e);let i=ge(2);return L(i.onActionItem("toggleFullScreen"))}),v(1,"span",5),T(2,"fullscreen"),_()()}}function Ag(r,n){if(r&1){let e=ee();v(0,"button",7),V("click",function(){z(e);let i=ge(2);return L(i.onActionItem("toggleFullScreen"))}),v(1,"span",5),T(2,"close_fullscreen"),_()()}}function Pg(r,n){if(r&1&&Te(0,Dg,3,0,"button",6)(1,Ag,3,0,"button",6),r&2){let e=ge();Ue(e.uiEvent.fullscreenStatus()?1:0)}}function Mg(r,n){if(r&1){let e=ee();v(0,"button",4),V("click",function(){z(e);let i=ge(2);return L(i.onActionItem("nightMode"))}),v(1,"span",5),T(2,"mode_night"),_()()}}function Og(r,n){if(r&1){let e=ee();v(0,"button",4),V("click",function(){z(e);let i=ge(2);return L(i.onActionItem("nightMode"))}),v(1,"span",5),T(2,"light_mode"),_()()}}function Ig(r,n){if(r&1&&Te(0,Mg,3,0,"button",8)(1,Og,3,0,"button",8),r&2){let e=ge();Ue(e.app.isNightMode()?1:0)}}function Rg(r,n){if(r&1){let e=ee();v(0,"tile-large-icon",9),V("click",function(){let i=z(e).$implicit,o=ge();return L(o.onActionItem(i.action))}),_()}if(r&2){let e=n.$implicit;G("svgIcon",e.svgIcon)("iconSize",e.iconSize)("label",e.label)}}var Rh=(()=>{class r{actionsSidenav=Y.required();_router=M(oo);uiEvent=M(Qn);dashboard=M(st);app=M(ti);_settings=M(ei);isAutoNightMode=Wt(this._settings.getAutoNightModeAsO(),{requireSync:!0});menuItems=[{svgIcon:"dashboard",iconSize:48,label:"Dashboards",action:"dashboards"},{svgIcon:"troubleshoot",iconSize:48,label:"Data Inspector",action:"datainspector"},{svgIcon:"dataset",iconSize:48,label:"Datasets",action:"datasets"},{svgIcon:"configuration",iconSize:48,label:"Configurations",action:"configurations"},{svgIcon:"settings",iconSize:48,label:"Settings",action:"settings"},{svgIcon:"help-center",iconSize:48,label:"Help",action:"help"}];constructor(){}ngAfterViewInit(){this.uiEvent.addHotkeyListener((e,t)=>this.handleKeyDown(e,t),{ctrlKey:!0,shiftKey:!0,keys:["e","f","n"]})}ngOnDestroy(){this.uiEvent.removeHotkeyListener(this.handleKeyDown.bind(this))}handleKeyDown(e,t){switch(e){case"e":this.onActionItem("layout");break;case"f":this.onActionItem("toggleFullScreen");break;case"n":this.onActionItem("nightMode");break;default:break}}onActionItem(e){switch(this.actionsSidenav().close(),e){case"help":this._router.navigate(["/help"]);break;case"dashboards":this._router.navigate(["/dashboards"]);break;case"datainspector":this._router.navigate(["/data"]);break;case"datasets":this._router.navigate(["/datasets"]);break;case"configurations":this._router.navigate(["/configurations"]);break;case"toggleFullScreen":this.uiEvent.toggleFullScreen();break;case"settings":this._router.navigate(["/settings"]);break;case"layout":this.dashboard.toggleStaticDashboard();break;case"nightMode":this.app.isNightMode.set(!this.app.isNightMode()),this.app.toggleDayNightMode();break;default:break}}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["menu-actions"]],inputs:{actionsSidenav:[1,"actionsSidenav"]},decls:10,vars:2,consts:[[1,"actions-container","actions-top-container"],[1,"menu-item-container"],["tabindex","0",3,"svgIcon","iconSize","label"],[1,"actions-container","actions-bottom-container"],["mat-flat-button","",1,"action-button",3,"click"],[1,"material-icons"],["mat-flat-button","","tabindex","0",1,"action-button"],["mat-flat-button","","tabindex","0",1,"action-button",3,"click"],["mat-flat-button","",1,"action-button"],["tabindex","0",3,"click","svgIcon","iconSize","label"]],template:function(t,i){t&1&&(v(0,"div",0),Te(1,Pg,2,1)(2,Ig,2,1),_(),v(3,"div",1),Wi(4,Rg,1,3,"tile-large-icon",2,Jr),_(),v(6,"div",3)(7,"button",4),V("click",function(){return i.onActionItem("layout")}),v(8,"span",5),T(9,"lock_open"),_()()()),t&2&&(P(),Ue(i.uiEvent.fullscreenSupported()?1:-1),P(),Ue(i.isAutoNightMode()?-1:2),P(2),Bi(i.menuItems))},dependencies:[Bt,ci,ii,Ih],styles:[".actions-container[_ngcontent-%COMP%]{display:grid;grid-auto-flow:column}.actions-top-container[_ngcontent-%COMP%]{position:absolute;top:0;width:100%}.actions-bottom-container[_ngcontent-%COMP%]{position:absolute;bottom:0;width:100%}.action-button[_ngcontent-%COMP%]{border-radius:0;height:48px}.menu-item-container[_ngcontent-%COMP%]{position:absolute;top:48px;width:135px;overflow-y:scroll;overflow-x:hidden;scroll-behavior:smooth;height:calc(100% - 96px)}"]})}return r})();var Ng=["actionsSidenav"],Wh=(()=>{class r{_snackBar=M(Ah);_deltaService=M(Un);_app=M(ti);_dashboard=M(st);_uiEvent=M(Qn);_dialog=M($n);appSettingsService=M(ei);authenticationService=M(_i);_responsive=M(ao);openSidenavEvent=new at;actionsSidenav=le("actionsSidenav");actionsSidenavOpen=Cr(!1);notificationsSidenavOpened=Cr(!1);isPhonePortrait;notificationsVisibility="hidden";themeName;themeNameSub;appNotificationSub;connectionStatusSub;constructor(){Pe(()=>{this.appSettingsService.configUpgrade()&&this._dialog.openFrameDialog({title:"Configuration Upgrade",component:"upgrade-config"},!0).subscribe(e=>{})}),this.isPhonePortrait=Wt(this._responsive.observe(mo.HandsetPortrait))}ngOnInit(){this.connectionStatusSub=this._deltaService.getDataStreamStatusAsO().subscribe(e=>{this.displayConnectionsStatusNotification(e)}),this.appNotificationSub=this._app.getSnackbarAppNotifications().subscribe(e=>{this._snackBar.open(e.message,"dismiss",{duration:e.duration,verticalPosition:"top"}),!this.appSettingsService.getNotificationConfig().sound.disableSound&&!e.silent&&(new Nh.Howl({src:["assets/notification.mp3"],autoplay:!0,preload:!0,loop:!1,volume:.3,onend:function(){},onloaderror:function(){console.log("snackbar: player onload error")},onplayerror:function(){console.log("snackbar: player locked"),this.howlPlayer.once("unlock",function(){this.howlPlayer.play()})}}).play(),Howler.autoUnlock=!0,Howler.autoSuspend=!1)}),this._uiEvent.addGestureListeners(this.onSwipeLeft.bind(this),this.onSwipeRight.bind(this))}ngAfterViewInit(){this._uiEvent.addHotkeyListener((e,t)=>this.handleKeyDown(e,t),{ctrlKey:!0,keys:["arrowright","arrowleft"]})}handleKeyDown(e,t){e==="arrowright"?this.onSwipeRight(t):e==="arrowleft"&&this.onSwipeLeft(t)}displayConnectionsStatusNotification(e){switch(e.operation){case 0:this._app.sendSnackbarNotification("Not connected to server.",5e3,!0);break;case 1:this._app.sendSnackbarNotification("Connecting to server.",2e3,!0);break;case 2:this._app.sendSnackbarNotification("Connection successful.",2e3,!1);break;case 3:this._app.sendSnackbarNotification("Error connecting to server.",0,!1);break;default:this._app.sendSnackbarNotification("Unknown stream connection status.",0,!1);break}}onSwipeRight(e){this._dashboard.isDashboardStatic()&&!this._uiEvent.isDragging()&&(e.preventDefault(),this.isPhonePortrait().matches?(this.actionsSidenavOpen.set(!1),this.notificationsSidenavOpened.set(!0)):this.notificationsSidenavOpened.set(!0))}onSwipeLeft(e){this._dashboard.isDashboardStatic()&&!this._uiEvent.isDragging()&&(e.preventDefault(),this.isPhonePortrait().matches?(this.notificationsSidenavOpened.set(!1),this.actionsSidenavOpen.set(!0)):this.actionsSidenavOpen.set(!0))}ngOnDestroy(){this.themeNameSub.unsubscribe(),this.appNotificationSub.unsubscribe(),this.connectionStatusSub.unsubscribe(),this._uiEvent.removeGestureListeners(this.onSwipeLeft.bind(this),this.onSwipeRight.bind(this)),this._uiEvent.removeHotkeyListener(this.handleKeyDown.bind(this))}static \u0275fac=function(t){return new(t||r)};static \u0275cmp=U({type:r,selectors:[["app-root"]],viewQuery:function(t,i){t&1&&de(i.actionsSidenav,Ng,5),t&2&&Qe()},inputs:{actionsSidenavOpen:[1,"actionsSidenavOpen"],notificationsSidenavOpened:[1,"notificationsSidenavOpened"]},outputs:{actionsSidenavOpen:"actionsSidenavOpenChange",notificationsSidenavOpened:"notificationsSidenavOpenedChange"},decls:9,vars:3,consts:[["notificationsSidenav",""],["actionsSidenav",""],[1,"sidenav-container",3,"swipeleft","swiperight"],["mode","over","position","start","autoFocus","true",1,"sidenav-notifications",3,"openedChange","opened"],["mode","over","position","end","autoFocus","true",1,"sidenav-actions",3,"openedChange","opened"],[3,"actionsSidenav"],[1,"router-outlet-container"]],template:function(t,i){if(t&1){let o=ee();v(0,"mat-sidenav-container",2),V("swipeleft",function(l){return z(o),L(i.onSwipeLeft(l))})("swiperight",function(l){return z(o),L(i.onSwipeRight(l))}),v(1,"mat-sidenav",3,0),Ae("openedChange",function(l){return z(o),De(i.notificationsSidenavOpened,l)||(i.notificationsSidenavOpened=l),L(l)}),B(3,"menu-notifications"),_(),v(4,"mat-sidenav",4,1),Ae("openedChange",function(l){return z(o),De(i.actionsSidenavOpen,l)||(i.actionsSidenavOpen=l),L(l)}),B(6,"menu-actions",5),_(),v(7,"mat-sidenav-content"),B(8,"router-outlet",6),_()()}if(t&2){let o=kl(5);P(),Ee("opened",i.notificationsSidenavOpened),P(3),Ee("opened",i.actionsSidenavOpen),P(2),G("actionsSidenav",o)}},dependencies:[Ph,Rh,ci,Bd,Bt,jl,Hl,Oh,Cs,Mh,jo],styles:[".sidenav-container[_ngcontent-%COMP%]{height:100%;width:100%}mat-sidenav.sidenav-notifications[_ngcontent-%COMP%]{width:230px}mat-sidenav.sidenav-actions[_ngcontent-%COMP%]{width:135px}"]})}return r})();function Bh(r){return new Ve(3e3,!1)}function Wg(){return new Ve(3100,!1)}function Bg(){return new Ve(3101,!1)}function zg(r){return new Ve(3001,!1)}function Lg(r){return new Ve(3003,!1)}function Vg(r){return new Ve(3004,!1)}function Lh(r,n){return new Ve(3005,!1)}function Vh(){return new Ve(3006,!1)}function Fh(){return new Ve(3007,!1)}function Hh(r,n){return new Ve(3008,!1)}function Uh(r){return new Ve(3002,!1)}function Gh(r,n,e,t,i){return new Ve(3010,!1)}function jh(){return new Ve(3011,!1)}function qh(){return new Ve(3012,!1)}function Yh(){return new Ve(3200,!1)}function $h(){return new Ve(3202,!1)}function Qh(){return new Ve(3013,!1)}function Xh(r){return new Ve(3014,!1)}function Kh(r){return new Ve(3015,!1)}function Zh(r){return new Ve(3016,!1)}function Jh(r,n){return new Ve(3404,!1)}function Fg(r){return new Ve(3502,!1)}function eu(r){return new Ve(3503,!1)}function tu(){return new Ve(3300,!1)}function iu(r){return new Ve(3504,!1)}function nu(r){return new Ve(3301,!1)}function ru(r,n){return new Ve(3302,!1)}function ou(r){return new Ve(3303,!1)}function au(r,n){return new Ve(3400,!1)}function su(r){return new Ve(3401,!1)}function lu(r){return new Ve(3402,!1)}function du(r,n){return new Ve(3505,!1)}function Ai(r){switch(r.length){case 0:return new ki;case 1:return r[0];default:return new un(r)}}function Ds(r,n,e=new Map,t=new Map){let i=[],o=[],a=-1,l=null;if(n.forEach(d=>{let f=d.get("offset"),s=f==a,c=s&&l||new Map;d.forEach((m,y)=>{let k=y,x=m;if(y!=="offset")switch(k=r.normalizePropertyName(k,i),x){case rr:x=e.get(y);break;case ri:x=t.get(y);break;default:x=r.normalizeStyleValue(y,k,x,i);break}c.set(k,x)}),s||o.push(c),l=c,a=f}),i.length)throw Fg(i);return o}function Yo(r,n,e,t){switch(n){case"start":r.onStart(()=>t(e&&xs(e,"start",r)));break;case"done":r.onDone(()=>t(e&&xs(e,"done",r)));break;case"destroy":r.onDestroy(()=>t(e&&xs(e,"destroy",r)));break}}function xs(r,n,e){let t=e.totalTime,i=!!e.disabled,o=$o(r.element,r.triggerName,r.fromState,r.toState,n||r.phaseName,t??r.totalTime,i),a=r._data;return a!=null&&(o._data=a),o}function $o(r,n,e,t,i="",o=0,a){return{element:r,triggerName:n,fromState:e,toState:t,phaseName:i,totalTime:o,disabled:!!a}}function Lt(r,n,e){let t=r.get(n);return t||r.set(n,t=e),t}function As(r){let n=r.indexOf(":"),e=r.substring(1,n),t=r.slice(n+1);return[e,t]}var Hg=typeof document>"u"?null:document.documentElement;function Qo(r){let n=r.parentNode||r.host||null;return n===Hg?null:n}function Ug(r){return r.substring(1,6)=="ebkit"}var bn=null,zh=!1;function cu(r){bn||(bn=Gg()||{},zh=bn.style?"WebkitAppearance"in bn.style:!1);let n=!0;return bn.style&&!Ug(r)&&(n=r in bn.style,!n&&zh&&(n="Webkit"+r.charAt(0).toUpperCase()+r.slice(1)in bn.style)),n}function Gg(){return typeof document<"u"?document.body:null}function Ps(r,n){for(;n;){if(n===r)return!0;n=Qo(n)}return!1}function Ms(r,n,e){if(e)return Array.from(r.querySelectorAll(n));let t=r.querySelector(n);return t?[t]:[]}var jg=1e3,Os="{{",qg="}}",Is="ng-enter",Xo="ng-leave",Nr="ng-trigger",Wr=".ng-trigger",Rs="ng-animating",Ko=".ng-animating";function Si(r){if(typeof r=="number")return r;let n=r.match(/^(-?[\.\d]+)(m?s)/);return!n||n.length<2?0:Ts(parseFloat(n[1]),n[2])}function Ts(r,n){switch(n){case"s":return r*jg;default:return r}}function Br(r,n,e){return r.hasOwnProperty("duration")?r:Yg(r,n,e)}function Yg(r,n,e){let t=/^(-?[\.\d]+)(m?s)(?:\s+(-?[\.\d]+)(m?s))?(?:\s+([-a-z]+(?:\(.+?\))?))?$/i,i,o=0,a="";if(typeof r=="string"){let l=r.match(t);if(l===null)return n.push(Bh(r)),{duration:0,delay:0,easing:""};i=Ts(parseFloat(l[1]),l[2]);let d=l[3];d!=null&&(o=Ts(parseFloat(d),l[4]));let f=l[5];f&&(a=f)}else i=r;if(!e){let l=!1,d=n.length;i<0&&(n.push(Wg()),l=!0),o<0&&(n.push(Bg()),l=!0),l&&n.splice(d,0,Bh(r))}return{duration:i,delay:o,easing:a}}function hu(r){return r.length?r[0]instanceof Map?r:r.map(n=>new Map(Object.entries(n))):[]}function mi(r,n,e){n.forEach((t,i)=>{let o=Zo(i);e&&!e.has(i)&&e.set(i,r.style[o]),r.style[o]=t})}function Ji(r,n){n.forEach((e,t)=>{let i=Zo(t);r.style[i]=""})}function mr(r){return Array.isArray(r)?r.length==1?r[0]:qd(r):r}function uu(r,n,e){let t=n.params||{},i=Ns(r);i.length&&i.forEach(o=>{t.hasOwnProperty(o)||e.push(zg(o))})}var Es=new RegExp(`${Os}\\s*(.+?)\\s*${qg}`,"g");function Ns(r){let n=[];if(typeof r=="string"){let e;for(;e=Es.exec(r);)n.push(e[1]);Es.lastIndex=0}return n}function pr(r,n,e){let t=`${r}`,i=t.replace(Es,(o,a)=>{let l=n[a];return l==null&&(e.push(Lg(a)),l=""),l.toString()});return i==t?r:i}var $g=/-+([a-z0-9])/g;function Zo(r){return r.replace($g,(...n)=>n[1].toUpperCase())}function mu(r,n){return r===0||n===0}function pu(r,n,e){if(e.size&&n.length){let t=n[0],i=[];if(e.forEach((o,a)=>{t.has(a)||i.push(a),t.set(a,o)}),i.length)for(let o=1;o<n.length;o++){let a=n[o];i.forEach(l=>a.set(l,Jo(r,l)))}}return n}function Vt(r,n,e){switch(n.type){case we.Trigger:return r.visitTrigger(n,e);case we.State:return r.visitState(n,e);case we.Transition:return r.visitTransition(n,e);case we.Sequence:return r.visitSequence(n,e);case we.Group:return r.visitGroup(n,e);case we.Animate:return r.visitAnimate(n,e);case we.Keyframes:return r.visitKeyframes(n,e);case we.Style:return r.visitStyle(n,e);case we.Reference:return r.visitReference(n,e);case we.AnimateChild:return r.visitAnimateChild(n,e);case we.AnimateRef:return r.visitAnimateRef(n,e);case we.Query:return r.visitQuery(n,e);case we.Stagger:return r.visitStagger(n,e);default:throw Vg(n.type)}}function Jo(r,n){return window.getComputedStyle(r)[n]}var Zs=(()=>{class r{validateStyleProperty(e){return cu(e)}containsElement(e,t){return Ps(e,t)}getParentElement(e){return Qo(e)}query(e,t,i){return Ms(e,t,i)}computeStyle(e,t,i){return i||""}animate(e,t,i,o,a,l=[],d){return new ki(i,o)}static \u0275fac=function(t){return new(t||r)};static \u0275prov=ot({token:r,factory:r.\u0275fac})}return r})(),wn=class{static NOOP=new Zs},kn=class{};var Qg=new Set(["width","height","minWidth","minHeight","maxWidth","maxHeight","left","top","bottom","right","fontSize","outlineWidth","outlineOffset","paddingTop","paddingLeft","paddingBottom","paddingRight","marginTop","marginLeft","marginBottom","marginRight","borderRadius","borderWidth","borderTopWidth","borderLeftWidth","borderRightWidth","borderBottomWidth","textIndent","perspective"]),ra=class extends kn{normalizePropertyName(n,e){return Zo(n)}normalizeStyleValue(n,e,t,i){let o="",a=t.toString().trim();if(Qg.has(e)&&t!==0&&t!=="0")if(typeof t=="number")o="px";else{let l=t.match(/^[+-]?[\d\.]+([a-z]*)$/);l&&l[1].length==0&&i.push(Lh(n,t))}return a+o}};var oa="*";function Xg(r,n){let e=[];return typeof r=="string"?r.split(/\s*,\s*/).forEach(t=>Kg(t,e,n)):e.push(r),e}function Kg(r,n,e){if(r[0]==":"){let d=Zg(r,e);if(typeof d=="function"){n.push(d);return}r=d}let t=r.match(/^(\*|[-\w]+)\s*(<?[=-]>)\s*(\*|[-\w]+)$/);if(t==null||t.length<4)return e.push(Kh(r)),n;let i=t[1],o=t[2],a=t[3];n.push(fu(i,a));let l=i==oa&&a==oa;o[0]=="<"&&!l&&n.push(fu(a,i))}function Zg(r,n){switch(r){case":enter":return"void => *";case":leave":return"* => void";case":increment":return(e,t)=>parseFloat(t)>parseFloat(e);case":decrement":return(e,t)=>parseFloat(t)<parseFloat(e);default:return n.push(Zh(r)),"* => *"}}var ea=new Set(["true","1"]),ta=new Set(["false","0"]);function fu(r,n){let e=ea.has(r)||ta.has(r),t=ea.has(n)||ta.has(n);return(i,o)=>{let a=r==oa||r==i,l=n==oa||n==o;return!a&&e&&typeof i=="boolean"&&(a=i?ea.has(r):ta.has(r)),!l&&t&&typeof o=="boolean"&&(l=o?ea.has(n):ta.has(n)),a&&l}}var xu=":self",Jg=new RegExp(`s*${xu}s*,?`,"g");function Tu(r,n,e,t){return new Fs(r).build(n,e,t)}var gu="",Fs=class{_driver;constructor(n){this._driver=n}build(n,e,t){let i=new Hs(e);return this._resetContextStyleTimingState(i),Vt(this,mr(n),i)}_resetContextStyleTimingState(n){n.currentQuerySelector=gu,n.collectedStyles=new Map,n.collectedStyles.set(gu,new Map),n.currentTime=0}visitTrigger(n,e){let t=e.queryCount=0,i=e.depCount=0,o=[],a=[];return n.name.charAt(0)=="@"&&e.errors.push(Vh()),n.definitions.forEach(l=>{if(this._resetContextStyleTimingState(e),l.type==we.State){let d=l,f=d.name;f.toString().split(/\s*,\s*/).forEach(s=>{d.name=s,o.push(this.visitState(d,e))}),d.name=f}else if(l.type==we.Transition){let d=this.visitTransition(l,e);t+=d.queryCount,i+=d.depCount,a.push(d)}else e.errors.push(Fh())}),{type:we.Trigger,name:n.name,states:o,transitions:a,queryCount:t,depCount:i,options:null}}visitState(n,e){let t=this.visitStyle(n.styles,e),i=n.options&&n.options.params||null;if(t.containsDynamicStyles){let o=new Set,a=i||{};t.styles.forEach(l=>{l instanceof Map&&l.forEach(d=>{Ns(d).forEach(f=>{a.hasOwnProperty(f)||o.add(f)})})}),o.size&&e.errors.push(Hh(n.name,[...o.values()]))}return{type:we.State,name:n.name,style:t,options:i?{params:i}:null}}visitTransition(n,e){e.queryCount=0,e.depCount=0;let t=Vt(this,mr(n.animation),e),i=Xg(n.expr,e.errors);return{type:we.Transition,matchers:i,animation:t,queryCount:e.queryCount,depCount:e.depCount,options:_n(n.options)}}visitSequence(n,e){return{type:we.Sequence,steps:n.steps.map(t=>Vt(this,t,e)),options:_n(n.options)}}visitGroup(n,e){let t=e.currentTime,i=0,o=n.steps.map(a=>{e.currentTime=t;let l=Vt(this,a,e);return i=Math.max(i,e.currentTime),l});return e.currentTime=i,{type:we.Group,steps:o,options:_n(n.options)}}visitAnimate(n,e){let t=n0(n.timings,e.errors);e.currentAnimateTimings=t;let i,o=n.styles?n.styles:oi({});if(o.type==we.Keyframes)i=this.visitKeyframes(o,e);else{let a=n.styles,l=!1;if(!a){l=!0;let f={};t.easing&&(f.easing=t.easing),a=oi(f)}e.currentTime+=t.duration+t.delay;let d=this.visitStyle(a,e);d.isEmptyStep=l,i=d}return e.currentAnimateTimings=null,{type:we.Animate,timings:t,style:i,options:null}}visitStyle(n,e){let t=this._makeStyleAst(n,e);return this._validateStyleAst(t,e),t}_makeStyleAst(n,e){let t=[],i=Array.isArray(n.styles)?n.styles:[n.styles];for(let l of i)typeof l=="string"?l===ri?t.push(l):e.errors.push(Uh(l)):t.push(new Map(Object.entries(l)));let o=!1,a=null;return t.forEach(l=>{if(l instanceof Map&&(l.has("easing")&&(a=l.get("easing"),l.delete("easing")),!o)){for(let d of l.values())if(d.toString().indexOf(Os)>=0){o=!0;break}}}),{type:we.Style,styles:t,easing:a,offset:n.offset,containsDynamicStyles:o,options:null}}_validateStyleAst(n,e){let t=e.currentAnimateTimings,i=e.currentTime,o=e.currentTime;t&&o>0&&(o-=t.duration+t.delay),n.styles.forEach(a=>{typeof a!="string"&&a.forEach((l,d)=>{let f=e.collectedStyles.get(e.currentQuerySelector),s=f.get(d),c=!0;s&&(o!=i&&o>=s.startTime&&i<=s.endTime&&(e.errors.push(Gh(d,s.startTime,s.endTime,o,i)),c=!1),o=s.startTime),c&&f.set(d,{startTime:o,endTime:i}),e.options&&uu(l,e.options,e.errors)})})}visitKeyframes(n,e){let t={type:we.Keyframes,styles:[],options:null};if(!e.currentAnimateTimings)return e.errors.push(jh()),t;let i=1,o=0,a=[],l=!1,d=!1,f=0,s=n.steps.map(F=>{let $=this._makeStyleAst(F,e),se=$.offset!=null?$.offset:i0($.styles),ke=0;return se!=null&&(o++,ke=$.offset=se),d=d||ke<0||ke>1,l=l||ke<f,f=ke,a.push(ke),$});d&&e.errors.push(qh()),l&&e.errors.push(Yh());let c=n.steps.length,m=0;o>0&&o<c?e.errors.push($h()):o==0&&(m=i/(c-1));let y=c-1,k=e.currentTime,x=e.currentAnimateTimings,D=x.duration;return s.forEach((F,$)=>{let se=m>0?$==y?1:m*$:a[$],ke=se*D;e.currentTime=k+x.delay+ke,x.duration=ke,this._validateStyleAst(F,e),F.offset=se,t.styles.push(F)}),t}visitReference(n,e){return{type:we.Reference,animation:Vt(this,mr(n.animation),e),options:_n(n.options)}}visitAnimateChild(n,e){return e.depCount++,{type:we.AnimateChild,options:_n(n.options)}}visitAnimateRef(n,e){return{type:we.AnimateRef,animation:this.visitReference(n.animation,e),options:_n(n.options)}}visitQuery(n,e){let t=e.currentQuerySelector,i=n.options||{};e.queryCount++,e.currentQuery=n;let[o,a]=e0(n.selector);e.currentQuerySelector=t.length?t+" "+o:o,Lt(e.collectedStyles,e.currentQuerySelector,new Map);let l=Vt(this,mr(n.animation),e);return e.currentQuery=null,e.currentQuerySelector=t,{type:we.Query,selector:o,limit:i.limit||0,optional:!!i.optional,includeSelf:a,animation:l,originalSelector:n.selector,options:_n(n.options)}}visitStagger(n,e){e.currentQuery||e.errors.push(Qh());let t=n.timings==="full"?{duration:0,delay:0,easing:"full"}:Br(n.timings,e.errors,!0);return{type:we.Stagger,animation:Vt(this,mr(n.animation),e),timings:t,options:null}}};function e0(r){let n=!!r.split(/\s*,\s*/).find(e=>e==xu);return n&&(r=r.replace(Jg,"")),r=r.replace(/@\*/g,Wr).replace(/@\w+/g,e=>Wr+"-"+e.slice(1)).replace(/:animating/g,Ko),[r,n]}function t0(r){return r?K({},r):null}var Hs=class{errors;queryCount=0;depCount=0;currentTransition=null;currentQuery=null;currentQuerySelector=null;currentAnimateTimings=null;currentTime=0;collectedStyles=new Map;options=null;unsupportedCSSPropertiesFound=new Set;constructor(n){this.errors=n}};function i0(r){if(typeof r=="string")return null;let n=null;if(Array.isArray(r))r.forEach(e=>{if(e instanceof Map&&e.has("offset")){let t=e;n=parseFloat(t.get("offset")),t.delete("offset")}});else if(r instanceof Map&&r.has("offset")){let e=r;n=parseFloat(e.get("offset")),e.delete("offset")}return n}function n0(r,n){if(r.hasOwnProperty("duration"))return r;if(typeof r=="number"){let o=Br(r,n).duration;return Ws(o,0,"")}let e=r;if(e.split(/\s+/).some(o=>o.charAt(0)=="{"&&o.charAt(1)=="{")){let o=Ws(0,0,"");return o.dynamic=!0,o.strValue=e,o}let i=Br(e,n);return Ws(i.duration,i.delay,i.easing)}function _n(r){return r?(r=K({},r),r.params&&(r.params=t0(r.params))):r={},r}function Ws(r,n,e){return{duration:r,delay:n,easing:e}}function Js(r,n,e,t,i,o,a=null,l=!1){return{type:1,element:r,keyframes:n,preStyleProps:e,postStyleProps:t,duration:i,delay:o,totalTime:i+o,easing:a,subTimeline:l}}var Lr=class{_map=new Map;get(n){return this._map.get(n)||[]}append(n,e){let t=this._map.get(n);t||this._map.set(n,t=[]),t.push(...e)}has(n){return this._map.has(n)}clear(){this._map.clear()}},r0=1,o0=":enter",a0=new RegExp(o0,"g"),s0=":leave",l0=new RegExp(s0,"g");function Eu(r,n,e,t,i,o=new Map,a=new Map,l,d,f=[]){return new Us().buildKeyframes(r,n,e,t,i,o,a,l,d,f)}var Us=class{buildKeyframes(n,e,t,i,o,a,l,d,f,s=[]){f=f||new Lr;let c=new Gs(n,e,f,i,o,s,[]);c.options=d;let m=d.delay?Si(d.delay):0;c.currentTimeline.delayNextStep(m),c.currentTimeline.setStyles([a],null,c.errors,d),Vt(this,t,c);let y=c.timelines.filter(k=>k.containsAnimation());if(y.length&&l.size){let k;for(let x=y.length-1;x>=0;x--){let D=y[x];if(D.element===e){k=D;break}}k&&!k.allowOnlyTimelineStyles()&&k.setStyles([l],null,c.errors,d)}return y.length?y.map(k=>k.buildKeyframes()):[Js(e,[],[],[],0,m,"",!1)]}visitTrigger(n,e){}visitState(n,e){}visitTransition(n,e){}visitAnimateChild(n,e){let t=e.subInstructions.get(e.element);if(t){let i=e.createSubContext(n.options),o=e.currentTimeline.currentTime,a=this._visitSubInstructions(t,i,i.options);o!=a&&e.transformIntoNewTimeline(a)}e.previousNode=n}visitAnimateRef(n,e){let t=e.createSubContext(n.options);t.transformIntoNewTimeline(),this._applyAnimationRefDelays([n.options,n.animation.options],e,t),this.visitReference(n.animation,t),e.transformIntoNewTimeline(t.currentTimeline.currentTime),e.previousNode=n}_applyAnimationRefDelays(n,e,t){for(let i of n){let o=i?.delay;if(o){let a=typeof o=="number"?o:Si(pr(o,i?.params??{},e.errors));t.delayNextStep(a)}}}_visitSubInstructions(n,e,t){let o=e.currentTimeline.currentTime,a=t.duration!=null?Si(t.duration):null,l=t.delay!=null?Si(t.delay):null;return a!==0&&n.forEach(d=>{let f=e.appendInstructionToTimeline(d,a,l);o=Math.max(o,f.duration+f.delay)}),o}visitReference(n,e){e.updateOptions(n.options,!0),Vt(this,n.animation,e),e.previousNode=n}visitSequence(n,e){let t=e.subContextCount,i=e,o=n.options;if(o&&(o.params||o.delay)&&(i=e.createSubContext(o),i.transformIntoNewTimeline(),o.delay!=null)){i.previousNode.type==we.Style&&(i.currentTimeline.snapshotCurrentStyles(),i.previousNode=aa);let a=Si(o.delay);i.delayNextStep(a)}n.steps.length&&(n.steps.forEach(a=>Vt(this,a,i)),i.currentTimeline.applyStylesToKeyframe(),i.subContextCount>t&&i.transformIntoNewTimeline()),e.previousNode=n}visitGroup(n,e){let t=[],i=e.currentTimeline.currentTime,o=n.options&&n.options.delay?Si(n.options.delay):0;n.steps.forEach(a=>{let l=e.createSubContext(n.options);o&&l.delayNextStep(o),Vt(this,a,l),i=Math.max(i,l.currentTimeline.currentTime),t.push(l.currentTimeline)}),t.forEach(a=>e.currentTimeline.mergeTimelineCollectedStyles(a)),e.transformIntoNewTimeline(i),e.previousNode=n}_visitTiming(n,e){if(n.dynamic){let t=n.strValue,i=e.params?pr(t,e.params,e.errors):t;return Br(i,e.errors)}else return{duration:n.duration,delay:n.delay,easing:n.easing}}visitAnimate(n,e){let t=e.currentAnimateTimings=this._visitTiming(n.timings,e),i=e.currentTimeline;t.delay&&(e.incrementTime(t.delay),i.snapshotCurrentStyles());let o=n.style;o.type==we.Keyframes?this.visitKeyframes(o,e):(e.incrementTime(t.duration),this.visitStyle(o,e),i.applyStylesToKeyframe()),e.currentAnimateTimings=null,e.previousNode=n}visitStyle(n,e){let t=e.currentTimeline,i=e.currentAnimateTimings;!i&&t.hasCurrentStyleProperties()&&t.forwardFrame();let o=i&&i.easing||n.easing;n.isEmptyStep?t.applyEmptyStep(o):t.setStyles(n.styles,o,e.errors,e.options),e.previousNode=n}visitKeyframes(n,e){let t=e.currentAnimateTimings,i=e.currentTimeline.duration,o=t.duration,l=e.createSubContext().currentTimeline;l.easing=t.easing,n.styles.forEach(d=>{let f=d.offset||0;l.forwardTime(f*o),l.setStyles(d.styles,d.easing,e.errors,e.options),l.applyStylesToKeyframe()}),e.currentTimeline.mergeTimelineCollectedStyles(l),e.transformIntoNewTimeline(i+o),e.previousNode=n}visitQuery(n,e){let t=e.currentTimeline.currentTime,i=n.options||{},o=i.delay?Si(i.delay):0;o&&(e.previousNode.type===we.Style||t==0&&e.currentTimeline.hasCurrentStyleProperties())&&(e.currentTimeline.snapshotCurrentStyles(),e.previousNode=aa);let a=t,l=e.invokeQuery(n.selector,n.originalSelector,n.limit,n.includeSelf,!!i.optional,e.errors);e.currentQueryTotal=l.length;let d=null;l.forEach((f,s)=>{e.currentQueryIndex=s;let c=e.createSubContext(n.options,f);o&&c.delayNextStep(o),f===e.element&&(d=c.currentTimeline),Vt(this,n.animation,c),c.currentTimeline.applyStylesToKeyframe();let m=c.currentTimeline.currentTime;a=Math.max(a,m)}),e.currentQueryIndex=0,e.currentQueryTotal=0,e.transformIntoNewTimeline(a),d&&(e.currentTimeline.mergeTimelineCollectedStyles(d),e.currentTimeline.snapshotCurrentStyles()),e.previousNode=n}visitStagger(n,e){let t=e.parentContext,i=e.currentTimeline,o=n.timings,a=Math.abs(o.duration),l=a*(e.currentQueryTotal-1),d=a*e.currentQueryIndex;switch(o.duration<0?"reverse":o.easing){case"reverse":d=l-d;break;case"full":d=t.currentStaggerTime;break}let s=e.currentTimeline;d&&s.delayNextStep(d);let c=s.currentTime;Vt(this,n.animation,e),e.previousNode=n,t.currentStaggerTime=i.currentTime-c+(i.startTime-t.currentTimeline.startTime)}},aa={},Gs=class r{_driver;element;subInstructions;_enterClassName;_leaveClassName;errors;timelines;parentContext=null;currentTimeline;currentAnimateTimings=null;previousNode=aa;subContextCount=0;options={};currentQueryIndex=0;currentQueryTotal=0;currentStaggerTime=0;constructor(n,e,t,i,o,a,l,d){this._driver=n,this.element=e,this.subInstructions=t,this._enterClassName=i,this._leaveClassName=o,this.errors=a,this.timelines=l,this.currentTimeline=d||new sa(this._driver,e,0),l.push(this.currentTimeline)}get params(){return this.options.params}updateOptions(n,e){if(!n)return;let t=n,i=this.options;t.duration!=null&&(i.duration=Si(t.duration)),t.delay!=null&&(i.delay=Si(t.delay));let o=t.params;if(o){let a=i.params;a||(a=this.options.params={}),Object.keys(o).forEach(l=>{(!e||!a.hasOwnProperty(l))&&(a[l]=pr(o[l],a,this.errors))})}}_copyOptions(){let n={};if(this.options){let e=this.options.params;if(e){let t=n.params={};Object.keys(e).forEach(i=>{t[i]=e[i]})}}return n}createSubContext(n=null,e,t){let i=e||this.element,o=new r(this._driver,i,this.subInstructions,this._enterClassName,this._leaveClassName,this.errors,this.timelines,this.currentTimeline.fork(i,t||0));return o.previousNode=this.previousNode,o.currentAnimateTimings=this.currentAnimateTimings,o.options=this._copyOptions(),o.updateOptions(n),o.currentQueryIndex=this.currentQueryIndex,o.currentQueryTotal=this.currentQueryTotal,o.parentContext=this,this.subContextCount++,o}transformIntoNewTimeline(n){return this.previousNode=aa,this.currentTimeline=this.currentTimeline.fork(this.element,n),this.timelines.push(this.currentTimeline),this.currentTimeline}appendInstructionToTimeline(n,e,t){let i={duration:e??n.duration,delay:this.currentTimeline.currentTime+(t??0)+n.delay,easing:""},o=new js(this._driver,n.element,n.keyframes,n.preStyleProps,n.postStyleProps,i,n.stretchStartingKeyframe);return this.timelines.push(o),i}incrementTime(n){this.currentTimeline.forwardTime(this.currentTimeline.duration+n)}delayNextStep(n){n>0&&this.currentTimeline.delayNextStep(n)}invokeQuery(n,e,t,i,o,a){let l=[];if(i&&l.push(this.element),n.length>0){n=n.replace(a0,"."+this._enterClassName),n=n.replace(l0,"."+this._leaveClassName);let d=t!=1,f=this._driver.query(this.element,n,d);t!==0&&(f=t<0?f.slice(f.length+t,f.length):f.slice(0,t)),l.push(...f)}return!o&&l.length==0&&a.push(Xh(e)),l}},sa=class r{_driver;element;startTime;_elementTimelineStylesLookup;duration=0;easing=null;_previousKeyframe=new Map;_currentKeyframe=new Map;_keyframes=new Map;_styleSummary=new Map;_localTimelineStyles=new Map;_globalTimelineStyles;_pendingStyles=new Map;_backFill=new Map;_currentEmptyStepKeyframe=null;constructor(n,e,t,i){this._driver=n,this.element=e,this.startTime=t,this._elementTimelineStylesLookup=i,this._elementTimelineStylesLookup||(this._elementTimelineStylesLookup=new Map),this._globalTimelineStyles=this._elementTimelineStylesLookup.get(e),this._globalTimelineStyles||(this._globalTimelineStyles=this._localTimelineStyles,this._elementTimelineStylesLookup.set(e,this._localTimelineStyles)),this._loadKeyframe()}containsAnimation(){switch(this._keyframes.size){case 0:return!1;case 1:return this.hasCurrentStyleProperties();default:return!0}}hasCurrentStyleProperties(){return this._currentKeyframe.size>0}get currentTime(){return this.startTime+this.duration}delayNextStep(n){let e=this._keyframes.size===1&&this._pendingStyles.size;this.duration||e?(this.forwardTime(this.currentTime+n),e&&this.snapshotCurrentStyles()):this.startTime+=n}fork(n,e){return this.applyStylesToKeyframe(),new r(this._driver,n,e||this.currentTime,this._elementTimelineStylesLookup)}_loadKeyframe(){this._currentKeyframe&&(this._previousKeyframe=this._currentKeyframe),this._currentKeyframe=this._keyframes.get(this.duration),this._currentKeyframe||(this._currentKeyframe=new Map,this._keyframes.set(this.duration,this._currentKeyframe))}forwardFrame(){this.duration+=r0,this._loadKeyframe()}forwardTime(n){this.applyStylesToKeyframe(),this.duration=n,this._loadKeyframe()}_updateStyle(n,e){this._localTimelineStyles.set(n,e),this._globalTimelineStyles.set(n,e),this._styleSummary.set(n,{time:this.currentTime,value:e})}allowOnlyTimelineStyles(){return this._currentEmptyStepKeyframe!==this._currentKeyframe}applyEmptyStep(n){n&&this._previousKeyframe.set("easing",n);for(let[e,t]of this._globalTimelineStyles)this._backFill.set(e,t||ri),this._currentKeyframe.set(e,ri);this._currentEmptyStepKeyframe=this._currentKeyframe}setStyles(n,e,t,i){e&&this._previousKeyframe.set("easing",e);let o=i&&i.params||{},a=d0(n,this._globalTimelineStyles);for(let[l,d]of a){let f=pr(d,o,t);this._pendingStyles.set(l,f),this._localTimelineStyles.has(l)||this._backFill.set(l,this._globalTimelineStyles.get(l)??ri),this._updateStyle(l,f)}}applyStylesToKeyframe(){this._pendingStyles.size!=0&&(this._pendingStyles.forEach((n,e)=>{this._currentKeyframe.set(e,n)}),this._pendingStyles.clear(),this._localTimelineStyles.forEach((n,e)=>{this._currentKeyframe.has(e)||this._currentKeyframe.set(e,n)}))}snapshotCurrentStyles(){for(let[n,e]of this._localTimelineStyles)this._pendingStyles.set(n,e),this._updateStyle(n,e)}getFinalKeyframe(){return this._keyframes.get(this.duration)}get properties(){let n=[];for(let e in this._currentKeyframe)n.push(e);return n}mergeTimelineCollectedStyles(n){n._styleSummary.forEach((e,t)=>{let i=this._styleSummary.get(t);(!i||e.time>i.time)&&this._updateStyle(t,e.value)})}buildKeyframes(){this.applyStylesToKeyframe();let n=new Set,e=new Set,t=this._keyframes.size===1&&this.duration===0,i=[];this._keyframes.forEach((l,d)=>{let f=new Map([...this._backFill,...l]);f.forEach((s,c)=>{s===rr?n.add(c):s===ri&&e.add(c)}),t||f.set("offset",d/this.duration),i.push(f)});let o=[...n.values()],a=[...e.values()];if(t){let l=i[0],d=new Map(l);l.set("offset",0),d.set("offset",1),i=[l,d]}return Js(this.element,i,o,a,this.duration,this.startTime,this.easing,!1)}},js=class extends sa{keyframes;preStyleProps;postStyleProps;_stretchStartingKeyframe;timings;constructor(n,e,t,i,o,a,l=!1){super(n,e,a.delay),this.keyframes=t,this.preStyleProps=i,this.postStyleProps=o,this._stretchStartingKeyframe=l,this.timings={duration:a.duration,delay:a.delay,easing:a.easing}}containsAnimation(){return this.keyframes.length>1}buildKeyframes(){let n=this.keyframes,{delay:e,duration:t,easing:i}=this.timings;if(this._stretchStartingKeyframe&&e){let o=[],a=t+e,l=e/a,d=new Map(n[0]);d.set("offset",0),o.push(d);let f=new Map(n[0]);f.set("offset",vu(l)),o.push(f);let s=n.length-1;for(let c=1;c<=s;c++){let m=new Map(n[c]),y=m.get("offset"),k=e+y*t;m.set("offset",vu(k/a)),o.push(m)}t=a,e=0,i="",n=o}return Js(this.element,n,this.preStyleProps,this.postStyleProps,t,e,i,!0)}};function vu(r,n=3){let e=Math.pow(10,n-1);return Math.round(r*e)/e}function d0(r,n){let e=new Map,t;return r.forEach(i=>{if(i==="*"){t??=n.keys();for(let o of t)e.set(o,ri)}else for(let[o,a]of i)e.set(o,a)}),e}function yu(r,n,e,t,i,o,a,l,d,f,s,c,m){return{type:0,element:r,triggerName:n,isRemovalTransition:i,fromState:e,fromStyles:o,toState:t,toStyles:a,timelines:l,queriedElements:d,preStyleProps:f,postStyleProps:s,totalTime:c,errors:m}}var Bs={},la=class{_triggerName;ast;_stateStyles;constructor(n,e,t){this._triggerName=n,this.ast=e,this._stateStyles=t}match(n,e,t,i){return c0(this.ast.matchers,n,e,t,i)}buildStyles(n,e,t){let i=this._stateStyles.get("*");return n!==void 0&&(i=this._stateStyles.get(n?.toString())||i),i?i.buildStyles(e,t):new Map}build(n,e,t,i,o,a,l,d,f,s){let c=[],m=this.ast.options&&this.ast.options.params||Bs,y=l&&l.params||Bs,k=this.buildStyles(t,y,c),x=d&&d.params||Bs,D=this.buildStyles(i,x,c),F=new Set,$=new Map,se=new Map,ke=i==="void",Ye={params:Du(x,m),delay:this.ast.options?.delay},Ke=s?[]:Eu(n,e,this.ast.animation,o,a,k,D,Ye,f,c),it=0;return Ke.forEach(ce=>{it=Math.max(ce.duration+ce.delay,it)}),c.length?yu(e,this._triggerName,t,i,ke,k,D,[],[],$,se,it,c):(Ke.forEach(ce=>{let mt=ce.element,dt=Lt($,mt,new Set);ce.preStyleProps.forEach(pt=>dt.add(pt));let qt=Lt(se,mt,new Set);ce.postStyleProps.forEach(pt=>qt.add(pt)),mt!==e&&F.add(mt)}),yu(e,this._triggerName,t,i,ke,k,D,Ke,[...F.values()],$,se,it))}};function c0(r,n,e,t,i){return r.some(o=>o(n,e,t,i))}function Du(r,n){let e=K({},n);return Object.entries(r).forEach(([t,i])=>{i!=null&&(e[t]=i)}),e}var qs=class{styles;defaultParams;normalizer;constructor(n,e,t){this.styles=n,this.defaultParams=e,this.normalizer=t}buildStyles(n,e){let t=new Map,i=Du(n,this.defaultParams);return this.styles.styles.forEach(o=>{typeof o!="string"&&o.forEach((a,l)=>{a&&(a=pr(a,i,e));let d=this.normalizer.normalizePropertyName(l,e);a=this.normalizer.normalizeStyleValue(l,d,a,e),t.set(l,a)})}),t}};function h0(r,n,e){return new Ys(r,n,e)}var Ys=class{name;ast;_normalizer;transitionFactories=[];fallbackTransition;states=new Map;constructor(n,e,t){this.name=n,this.ast=e,this._normalizer=t,e.states.forEach(i=>{let o=i.options&&i.options.params||{};this.states.set(i.name,new qs(i.style,o,t))}),bu(this.states,"true","1"),bu(this.states,"false","0"),e.transitions.forEach(i=>{this.transitionFactories.push(new la(n,i,this.states))}),this.fallbackTransition=u0(n,this.states)}get containsQueries(){return this.ast.queryCount>0}matchTransition(n,e,t,i){return this.transitionFactories.find(a=>a.match(n,e,t,i))||null}matchStyles(n,e,t){return this.fallbackTransition.buildStyles(n,e,t)}};function u0(r,n,e){let t=[(a,l)=>!0],i={type:we.Sequence,steps:[],options:null},o={type:we.Transition,animation:i,matchers:t,options:null,queryCount:0,depCount:0};return new la(r,o,n)}function bu(r,n,e){r.has(n)?r.has(e)||r.set(e,r.get(n)):r.has(e)&&r.set(n,r.get(e))}var m0=new Lr,$s=class{bodyNode;_driver;_normalizer;_animations=new Map;_playersById=new Map;players=[];constructor(n,e,t){this.bodyNode=n,this._driver=e,this._normalizer=t}register(n,e){let t=[],i=[],o=Tu(this._driver,e,t,i);if(t.length)throw eu(t);this._animations.set(n,o)}_buildPlayer(n,e,t){let i=n.element,o=Ds(this._normalizer,n.keyframes,e,t);return this._driver.animate(i,o,n.duration,n.delay,n.easing,[],!0)}create(n,e,t={}){let i=[],o=this._animations.get(n),a,l=new Map;if(o?(a=Eu(this._driver,e,o,Is,Xo,new Map,new Map,t,m0,i),a.forEach(s=>{let c=Lt(l,s.element,new Map);s.postStyleProps.forEach(m=>c.set(m,null))})):(i.push(tu()),a=[]),i.length)throw iu(i);l.forEach((s,c)=>{s.forEach((m,y)=>{s.set(y,this._driver.computeStyle(c,y,ri))})});let d=a.map(s=>{let c=l.get(s.element);return this._buildPlayer(s,new Map,c)}),f=Ai(d);return this._playersById.set(n,f),f.onDestroy(()=>this.destroy(n)),this.players.push(f),f}destroy(n){let e=this._getPlayer(n);e.destroy(),this._playersById.delete(n);let t=this.players.indexOf(e);t>=0&&this.players.splice(t,1)}_getPlayer(n){let e=this._playersById.get(n);if(!e)throw nu(n);return e}listen(n,e,t,i){let o=$o(e,"","","");return Yo(this._getPlayer(n),t,o,i),()=>{}}command(n,e,t,i){if(t=="register"){this.register(n,i[0]);return}if(t=="create"){let a=i[0]||{};this.create(n,e,a);return}let o=this._getPlayer(n);switch(t){case"play":o.play();break;case"pause":o.pause();break;case"reset":o.reset();break;case"restart":o.restart();break;case"finish":o.finish();break;case"init":o.init();break;case"setPosition":o.setPosition(parseFloat(i[0]));break;case"destroy":this.destroy(n);break}}},_u="ng-animate-queued",p0=".ng-animate-queued",zs="ng-animate-disabled",f0=".ng-animate-disabled",g0="ng-star-inserted",v0=".ng-star-inserted",y0=[],Au={namespaceId:"",setForRemoval:!1,setForMove:!1,hasAnimation:!1,removedBeforeQueried:!1},b0={namespaceId:"",setForMove:!1,setForRemoval:!1,hasAnimation:!1,removedBeforeQueried:!0},pi="__ng_removed",Vr=class{namespaceId;value;options;get params(){return this.options.params}constructor(n,e=""){this.namespaceId=e;let t=n&&n.hasOwnProperty("value"),i=t?n.value:n;if(this.value=w0(i),t){let o=n,{value:a}=o,l=nl(o,["value"]);this.options=l}else this.options={};this.options.params||(this.options.params={})}absorbOptions(n){let e=n.params;if(e){let t=this.options.params;Object.keys(e).forEach(i=>{t[i]==null&&(t[i]=e[i])})}}},zr="void",Ls=new Vr(zr),Qs=class{id;hostElement;_engine;players=[];_triggers=new Map;_queue=[];_elementListeners=new Map;_hostClassName;constructor(n,e,t){this.id=n,this.hostElement=e,this._engine=t,this._hostClassName="ng-tns-"+n,si(e,this._hostClassName)}listen(n,e,t,i){if(!this._triggers.has(e))throw ru(t,e);if(t==null||t.length==0)throw ou(e);if(!k0(t))throw au(t,e);let o=Lt(this._elementListeners,n,[]),a={name:e,phase:t,callback:i};o.push(a);let l=Lt(this._engine.statesByElement,n,new Map);return l.has(e)||(si(n,Nr),si(n,Nr+"-"+e),l.set(e,Ls)),()=>{this._engine.afterFlush(()=>{let d=o.indexOf(a);d>=0&&o.splice(d,1),this._triggers.has(e)||l.delete(e)})}}register(n,e){return this._triggers.has(n)?!1:(this._triggers.set(n,e),!0)}_getTrigger(n){let e=this._triggers.get(n);if(!e)throw su(n);return e}trigger(n,e,t,i=!0){let o=this._getTrigger(e),a=new Fr(this.id,e,n),l=this._engine.statesByElement.get(n);l||(si(n,Nr),si(n,Nr+"-"+e),this._engine.statesByElement.set(n,l=new Map));let d=l.get(e),f=new Vr(t,this.id);if(!(t&&t.hasOwnProperty("value"))&&d&&f.absorbOptions(d.options),l.set(e,f),d||(d=Ls),!(f.value===zr)&&d.value===f.value){if(!x0(d.params,f.params)){let x=[],D=o.matchStyles(d.value,d.params,x),F=o.matchStyles(f.value,f.params,x);x.length?this._engine.reportError(x):this._engine.afterFlush(()=>{Ji(n,D),mi(n,F)})}return}let m=Lt(this._engine.playersByElement,n,[]);m.forEach(x=>{x.namespaceId==this.id&&x.triggerName==e&&x.queued&&x.destroy()});let y=o.matchTransition(d.value,f.value,n,f.params),k=!1;if(!y){if(!i)return;y=o.fallbackTransition,k=!0}return this._engine.totalQueuedPlayers++,this._queue.push({element:n,triggerName:e,transition:y,fromState:d,toState:f,player:a,isFallbackTransition:k}),k||(si(n,_u),a.onStart(()=>{fr(n,_u)})),a.onDone(()=>{let x=this.players.indexOf(a);x>=0&&this.players.splice(x,1);let D=this._engine.playersByElement.get(n);if(D){let F=D.indexOf(a);F>=0&&D.splice(F,1)}}),this.players.push(a),m.push(a),a}deregister(n){this._triggers.delete(n),this._engine.statesByElement.forEach(e=>e.delete(n)),this._elementListeners.forEach((e,t)=>{this._elementListeners.set(t,e.filter(i=>i.name!=n))})}clearElementCache(n){this._engine.statesByElement.delete(n),this._elementListeners.delete(n);let e=this._engine.playersByElement.get(n);e&&(e.forEach(t=>t.destroy()),this._engine.playersByElement.delete(n))}_signalRemovalForInnerTriggers(n,e){let t=this._engine.driver.query(n,Wr,!0);t.forEach(i=>{if(i[pi])return;let o=this._engine.fetchNamespacesByElement(i);o.size?o.forEach(a=>a.triggerLeaveAnimation(i,e,!1,!0)):this.clearElementCache(i)}),this._engine.afterFlushAnimationsDone(()=>t.forEach(i=>this.clearElementCache(i)))}triggerLeaveAnimation(n,e,t,i){let o=this._engine.statesByElement.get(n),a=new Map;if(o){let l=[];if(o.forEach((d,f)=>{if(a.set(f,d.value),this._triggers.has(f)){let s=this.trigger(n,f,zr,i);s&&l.push(s)}}),l.length)return this._engine.markElementAsRemoved(this.id,n,!0,e,a),t&&Ai(l).onDone(()=>this._engine.processLeaveNode(n)),!0}return!1}prepareLeaveAnimationListeners(n){let e=this._elementListeners.get(n),t=this._engine.statesByElement.get(n);if(e&&t){let i=new Set;e.forEach(o=>{let a=o.name;if(i.has(a))return;i.add(a);let d=this._triggers.get(a).fallbackTransition,f=t.get(a)||Ls,s=new Vr(zr),c=new Fr(this.id,a,n);this._engine.totalQueuedPlayers++,this._queue.push({element:n,triggerName:a,transition:d,fromState:f,toState:s,player:c,isFallbackTransition:!0})})}}removeNode(n,e){let t=this._engine;if(n.childElementCount&&this._signalRemovalForInnerTriggers(n,e),this.triggerLeaveAnimation(n,e,!0))return;let i=!1;if(t.totalAnimations){let o=t.players.length?t.playersByQueriedElement.get(n):[];if(o&&o.length)i=!0;else{let a=n;for(;a=a.parentNode;)if(t.statesByElement.get(a)){i=!0;break}}}if(this.prepareLeaveAnimationListeners(n),i)t.markElementAsRemoved(this.id,n,!1,e);else{let o=n[pi];(!o||o===Au)&&(t.afterFlush(()=>this.clearElementCache(n)),t.destroyInnerAnimations(n),t._onRemovalComplete(n,e))}}insertNode(n,e){si(n,this._hostClassName)}drainQueuedTransitions(n){let e=[];return this._queue.forEach(t=>{let i=t.player;if(i.destroyed)return;let o=t.element,a=this._elementListeners.get(o);a&&a.forEach(l=>{if(l.name==t.triggerName){let d=$o(o,t.triggerName,t.fromState.value,t.toState.value);d._data=n,Yo(t.player,l.phase,d,l.callback)}}),i.markedForDestroy?this._engine.afterFlush(()=>{i.destroy()}):e.push(t)}),this._queue=[],e.sort((t,i)=>{let o=t.transition.ast.depCount,a=i.transition.ast.depCount;return o==0||a==0?o-a:this._engine.driver.containsElement(t.element,i.element)?1:-1})}destroy(n){this.players.forEach(e=>e.destroy()),this._signalRemovalForInnerTriggers(this.hostElement,n)}},Xs=class{bodyNode;driver;_normalizer;players=[];newHostElements=new Map;playersByElement=new Map;playersByQueriedElement=new Map;statesByElement=new Map;disabledNodes=new Set;totalAnimations=0;totalQueuedPlayers=0;_namespaceLookup={};_namespaceList=[];_flushFns=[];_whenQuietFns=[];namespacesByHostElement=new Map;collectedEnterElements=[];collectedLeaveElements=[];onRemovalComplete=(n,e)=>{};_onRemovalComplete(n,e){this.onRemovalComplete(n,e)}constructor(n,e,t){this.bodyNode=n,this.driver=e,this._normalizer=t}get queuedPlayers(){let n=[];return this._namespaceList.forEach(e=>{e.players.forEach(t=>{t.queued&&n.push(t)})}),n}createNamespace(n,e){let t=new Qs(n,e,this);return this.bodyNode&&this.driver.containsElement(this.bodyNode,e)?this._balanceNamespaceList(t,e):(this.newHostElements.set(e,t),this.collectEnterElement(e)),this._namespaceLookup[n]=t}_balanceNamespaceList(n,e){let t=this._namespaceList,i=this.namespacesByHostElement;if(t.length-1>=0){let a=!1,l=this.driver.getParentElement(e);for(;l;){let d=i.get(l);if(d){let f=t.indexOf(d);t.splice(f+1,0,n),a=!0;break}l=this.driver.getParentElement(l)}a||t.unshift(n)}else t.push(n);return i.set(e,n),n}register(n,e){let t=this._namespaceLookup[n];return t||(t=this.createNamespace(n,e)),t}registerTrigger(n,e,t){let i=this._namespaceLookup[n];i&&i.register(e,t)&&this.totalAnimations++}destroy(n,e){n&&(this.afterFlush(()=>{}),this.afterFlushAnimationsDone(()=>{let t=this._fetchNamespace(n);this.namespacesByHostElement.delete(t.hostElement);let i=this._namespaceList.indexOf(t);i>=0&&this._namespaceList.splice(i,1),t.destroy(e),delete this._namespaceLookup[n]}))}_fetchNamespace(n){return this._namespaceLookup[n]}fetchNamespacesByElement(n){let e=new Set,t=this.statesByElement.get(n);if(t){for(let i of t.values())if(i.namespaceId){let o=this._fetchNamespace(i.namespaceId);o&&e.add(o)}}return e}trigger(n,e,t,i){if(ia(e)){let o=this._fetchNamespace(n);if(o)return o.trigger(e,t,i),!0}return!1}insertNode(n,e,t,i){if(!ia(e))return;let o=e[pi];if(o&&o.setForRemoval){o.setForRemoval=!1,o.setForMove=!0;let a=this.collectedLeaveElements.indexOf(e);a>=0&&this.collectedLeaveElements.splice(a,1)}if(n){let a=this._fetchNamespace(n);a&&a.insertNode(e,t)}i&&this.collectEnterElement(e)}collectEnterElement(n){this.collectedEnterElements.push(n)}markElementAsDisabled(n,e){e?this.disabledNodes.has(n)||(this.disabledNodes.add(n),si(n,zs)):this.disabledNodes.has(n)&&(this.disabledNodes.delete(n),fr(n,zs))}removeNode(n,e,t){if(ia(e)){let i=n?this._fetchNamespace(n):null;i?i.removeNode(e,t):this.markElementAsRemoved(n,e,!1,t);let o=this.namespacesByHostElement.get(e);o&&o.id!==n&&o.removeNode(e,t)}else this._onRemovalComplete(e,t)}markElementAsRemoved(n,e,t,i,o){this.collectedLeaveElements.push(e),e[pi]={namespaceId:n,setForRemoval:i,hasAnimation:t,removedBeforeQueried:!1,previousTriggersValues:o}}listen(n,e,t,i,o){return ia(e)?this._fetchNamespace(n).listen(e,t,i,o):()=>{}}_buildInstruction(n,e,t,i,o){return n.transition.build(this.driver,n.element,n.fromState.value,n.toState.value,t,i,n.fromState.options,n.toState.options,e,o)}destroyInnerAnimations(n){let e=this.driver.query(n,Wr,!0);e.forEach(t=>this.destroyActiveAnimationsForElement(t)),this.playersByQueriedElement.size!=0&&(e=this.driver.query(n,Ko,!0),e.forEach(t=>this.finishActiveQueriedAnimationOnElement(t)))}destroyActiveAnimationsForElement(n){let e=this.playersByElement.get(n);e&&e.forEach(t=>{t.queued?t.markedForDestroy=!0:t.destroy()})}finishActiveQueriedAnimationOnElement(n){let e=this.playersByQueriedElement.get(n);e&&e.forEach(t=>t.finish())}whenRenderingDone(){return new Promise(n=>{if(this.players.length)return Ai(this.players).onDone(()=>n());n()})}processLeaveNode(n){let e=n[pi];if(e&&e.setForRemoval){if(n[pi]=Au,e.namespaceId){this.destroyInnerAnimations(n);let t=this._fetchNamespace(e.namespaceId);t&&t.clearElementCache(n)}this._onRemovalComplete(n,e.setForRemoval)}n.classList?.contains(zs)&&this.markElementAsDisabled(n,!1),this.driver.query(n,f0,!0).forEach(t=>{this.markElementAsDisabled(t,!1)})}flush(n=-1){let e=[];if(this.newHostElements.size&&(this.newHostElements.forEach((t,i)=>this._balanceNamespaceList(t,i)),this.newHostElements.clear()),this.totalAnimations&&this.collectedEnterElements.length)for(let t=0;t<this.collectedEnterElements.length;t++){let i=this.collectedEnterElements[t];si(i,g0)}if(this._namespaceList.length&&(this.totalQueuedPlayers||this.collectedLeaveElements.length)){let t=[];try{e=this._flushAnimations(t,n)}finally{for(let i=0;i<t.length;i++)t[i]()}}else for(let t=0;t<this.collectedLeaveElements.length;t++){let i=this.collectedLeaveElements[t];this.processLeaveNode(i)}if(this.totalQueuedPlayers=0,this.collectedEnterElements.length=0,this.collectedLeaveElements.length=0,this._flushFns.forEach(t=>t()),this._flushFns=[],this._whenQuietFns.length){let t=this._whenQuietFns;this._whenQuietFns=[],e.length?Ai(e).onDone(()=>{t.forEach(i=>i())}):t.forEach(i=>i())}}reportError(n){throw lu(n)}_flushAnimations(n,e){let t=new Lr,i=[],o=new Map,a=[],l=new Map,d=new Map,f=new Map,s=new Set;this.disabledNodes.forEach(Q=>{s.add(Q);let ie=this.driver.query(Q,p0,!0);for(let oe=0;oe<ie.length;oe++)s.add(ie[oe])});let c=this.bodyNode,m=Array.from(this.statesByElement.keys()),y=Su(m,this.collectedEnterElements),k=new Map,x=0;y.forEach((Q,ie)=>{let oe=Is+x++;k.set(ie,oe),Q.forEach(Oe=>si(Oe,oe))});let D=[],F=new Set,$=new Set;for(let Q=0;Q<this.collectedLeaveElements.length;Q++){let ie=this.collectedLeaveElements[Q],oe=ie[pi];oe&&oe.setForRemoval&&(D.push(ie),F.add(ie),oe.hasAnimation?this.driver.query(ie,v0,!0).forEach(Oe=>F.add(Oe)):$.add(ie))}let se=new Map,ke=Su(m,Array.from(F));ke.forEach((Q,ie)=>{let oe=Xo+x++;se.set(ie,oe),Q.forEach(Oe=>si(Oe,oe))}),n.push(()=>{y.forEach((Q,ie)=>{let oe=k.get(ie);Q.forEach(Oe=>fr(Oe,oe))}),ke.forEach((Q,ie)=>{let oe=se.get(ie);Q.forEach(Oe=>fr(Oe,oe))}),D.forEach(Q=>{this.processLeaveNode(Q)})});let Ye=[],Ke=[];for(let Q=this._namespaceList.length-1;Q>=0;Q--)this._namespaceList[Q].drainQueuedTransitions(e).forEach(oe=>{let Oe=oe.player,nt=oe.element;if(Ye.push(Oe),this.collectedEnterElements.length){let Ze=nt[pi];if(Ze&&Ze.setForMove){if(Ze.previousTriggersValues&&Ze.previousTriggersValues.has(oe.triggerName)){let Fe=Ze.previousTriggersValues.get(oe.triggerName),qe=this.statesByElement.get(oe.element);if(qe&&qe.has(oe.triggerName)){let Yt=qe.get(oe.triggerName);Yt.value=Fe,qe.set(oe.triggerName,Yt)}}Oe.destroy();return}}let gt=!c||!this.driver.containsElement(c,nt),vt=se.get(nt),Tt=k.get(nt),Xe=this._buildInstruction(oe,t,Tt,vt,gt);if(Xe.errors&&Xe.errors.length){Ke.push(Xe);return}if(gt){Oe.onStart(()=>Ji(nt,Xe.fromStyles)),Oe.onDestroy(()=>mi(nt,Xe.toStyles)),i.push(Oe);return}if(oe.isFallbackTransition){Oe.onStart(()=>Ji(nt,Xe.fromStyles)),Oe.onDestroy(()=>mi(nt,Xe.toStyles)),i.push(Oe);return}let Cn=[];Xe.timelines.forEach(Ze=>{Ze.stretchStartingKeyframe=!0,this.disabledNodes.has(Ze.element)||Cn.push(Ze)}),Xe.timelines=Cn,t.append(nt,Xe.timelines);let ct={instruction:Xe,player:Oe,element:nt};a.push(ct),Xe.queriedElements.forEach(Ze=>Lt(l,Ze,[]).push(Oe)),Xe.preStyleProps.forEach((Ze,Fe)=>{if(Ze.size){let qe=d.get(Fe);qe||d.set(Fe,qe=new Set),Ze.forEach((Yt,li)=>qe.add(li))}}),Xe.postStyleProps.forEach((Ze,Fe)=>{let qe=f.get(Fe);qe||f.set(Fe,qe=new Set),Ze.forEach((Yt,li)=>qe.add(li))})});if(Ke.length){let Q=[];Ke.forEach(ie=>{Q.push(du(ie.triggerName,ie.errors))}),Ye.forEach(ie=>ie.destroy()),this.reportError(Q)}let it=new Map,ce=new Map;a.forEach(Q=>{let ie=Q.element;t.has(ie)&&(ce.set(ie,ie),this._beforeAnimationBuild(Q.player.namespaceId,Q.instruction,it))}),i.forEach(Q=>{let ie=Q.element;this._getPreviousPlayers(ie,!1,Q.namespaceId,Q.triggerName,null).forEach(Oe=>{Lt(it,ie,[]).push(Oe),Oe.destroy()})});let mt=D.filter(Q=>Cu(Q,d,f)),dt=new Map;ku(dt,this.driver,$,f,ri).forEach(Q=>{Cu(Q,d,f)&&mt.push(Q)});let pt=new Map;y.forEach((Q,ie)=>{ku(pt,this.driver,new Set(Q),d,rr)}),mt.forEach(Q=>{let ie=dt.get(Q),oe=pt.get(Q);dt.set(Q,new Map([...ie?.entries()??[],...oe?.entries()??[]]))});let ft=[],Ci=[],Sn={};a.forEach(Q=>{let{element:ie,player:oe,instruction:Oe}=Q;if(t.has(ie)){if(s.has(ie)){oe.onDestroy(()=>mi(ie,Oe.toStyles)),oe.disabled=!0,oe.overrideTotalTime(Oe.totalTime),i.push(oe);return}let nt=Sn;if(ce.size>1){let vt=ie,Tt=[];for(;vt=vt.parentNode;){let Xe=ce.get(vt);if(Xe){nt=Xe;break}Tt.push(vt)}Tt.forEach(Xe=>ce.set(Xe,nt))}let gt=this._buildAnimation(oe.namespaceId,Oe,it,o,pt,dt);if(oe.setRealPlayer(gt),nt===Sn)ft.push(oe);else{let vt=this.playersByElement.get(nt);vt&&vt.length&&(oe.parentPlayer=Ai(vt)),i.push(oe)}}else Ji(ie,Oe.fromStyles),oe.onDestroy(()=>mi(ie,Oe.toStyles)),Ci.push(oe),s.has(ie)&&i.push(oe)}),Ci.forEach(Q=>{let ie=o.get(Q.element);if(ie&&ie.length){let oe=Ai(ie);Q.setRealPlayer(oe)}}),i.forEach(Q=>{Q.parentPlayer?Q.syncPlayerEvents(Q.parentPlayer):Q.destroy()});for(let Q=0;Q<D.length;Q++){let ie=D[Q],oe=ie[pi];if(fr(ie,Xo),oe&&oe.hasAnimation)continue;let Oe=[];if(l.size){let gt=l.get(ie);gt&>.length&&Oe.push(...gt);let vt=this.driver.query(ie,Ko,!0);for(let Tt=0;Tt<vt.length;Tt++){let Xe=l.get(vt[Tt]);Xe&&Xe.length&&Oe.push(...Xe)}}let nt=Oe.filter(gt=>!gt.destroyed);nt.length?S0(this,ie,nt):this.processLeaveNode(ie)}return D.length=0,ft.forEach(Q=>{this.players.push(Q),Q.onDone(()=>{Q.destroy();let ie=this.players.indexOf(Q);this.players.splice(ie,1)}),Q.play()}),ft}afterFlush(n){this._flushFns.push(n)}afterFlushAnimationsDone(n){this._whenQuietFns.push(n)}_getPreviousPlayers(n,e,t,i,o){let a=[];if(e){let l=this.playersByQueriedElement.get(n);l&&(a=l)}else{let l=this.playersByElement.get(n);if(l){let d=!o||o==zr;l.forEach(f=>{f.queued||!d&&f.triggerName!=i||a.push(f)})}}return(t||i)&&(a=a.filter(l=>!(t&&t!=l.namespaceId||i&&i!=l.triggerName))),a}_beforeAnimationBuild(n,e,t){let i=e.triggerName,o=e.element,a=e.isRemovalTransition?void 0:n,l=e.isRemovalTransition?void 0:i;for(let d of e.timelines){let f=d.element,s=f!==o,c=Lt(t,f,[]);this._getPreviousPlayers(f,s,a,l,e.toState).forEach(y=>{let k=y.getRealPlayer();k.beforeDestroy&&k.beforeDestroy(),y.destroy(),c.push(y)})}Ji(o,e.fromStyles)}_buildAnimation(n,e,t,i,o,a){let l=e.triggerName,d=e.element,f=[],s=new Set,c=new Set,m=e.timelines.map(k=>{let x=k.element;s.add(x);let D=x[pi];if(D&&D.removedBeforeQueried)return new ki(k.duration,k.delay);let F=x!==d,$=C0((t.get(x)||y0).map(it=>it.getRealPlayer())).filter(it=>{let ce=it;return ce.element?ce.element===x:!1}),se=o.get(x),ke=a.get(x),Ye=Ds(this._normalizer,k.keyframes,se,ke),Ke=this._buildPlayer(k,Ye,$);if(k.subTimeline&&i&&c.add(x),F){let it=new Fr(n,l,x);it.setRealPlayer(Ke),f.push(it)}return Ke});f.forEach(k=>{Lt(this.playersByQueriedElement,k.element,[]).push(k),k.onDone(()=>_0(this.playersByQueriedElement,k.element,k))}),s.forEach(k=>si(k,Rs));let y=Ai(m);return y.onDestroy(()=>{s.forEach(k=>fr(k,Rs)),mi(d,e.toStyles)}),c.forEach(k=>{Lt(i,k,[]).push(y)}),y}_buildPlayer(n,e,t){return e.length>0?this.driver.animate(n.element,e,n.duration,n.delay,n.easing,t):new ki(n.duration,n.delay)}},Fr=class{namespaceId;triggerName;element;_player=new ki;_containsRealPlayer=!1;_queuedCallbacks=new Map;destroyed=!1;parentPlayer=null;markedForDestroy=!1;disabled=!1;queued=!0;totalTime=0;constructor(n,e,t){this.namespaceId=n,this.triggerName=e,this.element=t}setRealPlayer(n){this._containsRealPlayer||(this._player=n,this._queuedCallbacks.forEach((e,t)=>{e.forEach(i=>Yo(n,t,void 0,i))}),this._queuedCallbacks.clear(),this._containsRealPlayer=!0,this.overrideTotalTime(n.totalTime),this.queued=!1)}getRealPlayer(){return this._player}overrideTotalTime(n){this.totalTime=n}syncPlayerEvents(n){let e=this._player;e.triggerCallback&&n.onStart(()=>e.triggerCallback("start")),n.onDone(()=>this.finish()),n.onDestroy(()=>this.destroy())}_queueEvent(n,e){Lt(this._queuedCallbacks,n,[]).push(e)}onDone(n){this.queued&&this._queueEvent("done",n),this._player.onDone(n)}onStart(n){this.queued&&this._queueEvent("start",n),this._player.onStart(n)}onDestroy(n){this.queued&&this._queueEvent("destroy",n),this._player.onDestroy(n)}init(){this._player.init()}hasStarted(){return this.queued?!1:this._player.hasStarted()}play(){!this.queued&&this._player.play()}pause(){!this.queued&&this._player.pause()}restart(){!this.queued&&this._player.restart()}finish(){this._player.finish()}destroy(){this.destroyed=!0,this._player.destroy()}reset(){!this.queued&&this._player.reset()}setPosition(n){this.queued||this._player.setPosition(n)}getPosition(){return this.queued?0:this._player.getPosition()}triggerCallback(n){let e=this._player;e.triggerCallback&&e.triggerCallback(n)}};function _0(r,n,e){let t=r.get(n);if(t){if(t.length){let i=t.indexOf(e);t.splice(i,1)}t.length==0&&r.delete(n)}return t}function w0(r){return r??null}function ia(r){return r&&r.nodeType===1}function k0(r){return r=="start"||r=="done"}function wu(r,n){let e=r.style.display;return r.style.display=n??"none",e}function ku(r,n,e,t,i){let o=[];e.forEach(d=>o.push(wu(d)));let a=[];t.forEach((d,f)=>{let s=new Map;d.forEach(c=>{let m=n.computeStyle(f,c,i);s.set(c,m),(!m||m.length==0)&&(f[pi]=b0,a.push(f))}),r.set(f,s)});let l=0;return e.forEach(d=>wu(d,o[l++])),a}function Su(r,n){let e=new Map;if(r.forEach(l=>e.set(l,[])),n.length==0)return e;let t=1,i=new Set(n),o=new Map;function a(l){if(!l)return t;let d=o.get(l);if(d)return d;let f=l.parentNode;return e.has(f)?d=f:i.has(f)?d=t:d=a(f),o.set(l,d),d}return n.forEach(l=>{let d=a(l);d!==t&&e.get(d).push(l)}),e}function si(r,n){r.classList?.add(n)}function fr(r,n){r.classList?.remove(n)}function S0(r,n,e){Ai(e).onDone(()=>r.processLeaveNode(n))}function C0(r){let n=[];return Pu(r,n),n}function Pu(r,n){for(let e=0;e<r.length;e++){let t=r[e];t instanceof un?Pu(t.players,n):n.push(t)}}function x0(r,n){let e=Object.keys(r),t=Object.keys(n);if(e.length!=t.length)return!1;for(let i=0;i<e.length;i++){let o=e[i];if(!n.hasOwnProperty(o)||r[o]!==n[o])return!1}return!0}function Cu(r,n,e){let t=e.get(r);if(!t)return!1;let i=n.get(r);return i?t.forEach(o=>i.add(o)):n.set(r,t),e.delete(r),!0}var gr=class{_driver;_normalizer;_transitionEngine;_timelineEngine;_triggerCache={};onRemovalComplete=(n,e)=>{};constructor(n,e,t){this._driver=e,this._normalizer=t,this._transitionEngine=new Xs(n.body,e,t),this._timelineEngine=new $s(n.body,e,t),this._transitionEngine.onRemovalComplete=(i,o)=>this.onRemovalComplete(i,o)}registerTrigger(n,e,t,i,o){let a=n+"-"+i,l=this._triggerCache[a];if(!l){let d=[],f=[],s=Tu(this._driver,o,d,f);if(d.length)throw Jh(i,d);l=h0(i,s,this._normalizer),this._triggerCache[a]=l}this._transitionEngine.registerTrigger(e,i,l)}register(n,e){this._transitionEngine.register(n,e)}destroy(n,e){this._transitionEngine.destroy(n,e)}onInsert(n,e,t,i){this._transitionEngine.insertNode(n,e,t,i)}onRemove(n,e,t){this._transitionEngine.removeNode(n,e,t)}disableAnimations(n,e){this._transitionEngine.markElementAsDisabled(n,e)}process(n,e,t,i){if(t.charAt(0)=="@"){let[o,a]=As(t),l=i;this._timelineEngine.command(o,e,a,l)}else this._transitionEngine.trigger(n,e,t,i)}listen(n,e,t,i,o){if(t.charAt(0)=="@"){let[a,l]=As(t);return this._timelineEngine.listen(a,e,l,o)}return this._transitionEngine.listen(n,e,t,i,o)}flush(n=-1){this._transitionEngine.flush(n)}get players(){return[...this._transitionEngine.players,...this._timelineEngine.players]}whenRenderingDone(){return this._transitionEngine.whenRenderingDone()}afterFlushAnimationsDone(n){this._transitionEngine.afterFlushAnimationsDone(n)}};function T0(r,n){let e=null,t=null;return Array.isArray(n)&&n.length?(e=Vs(n[0]),n.length>1&&(t=Vs(n[n.length-1]))):n instanceof Map&&(e=Vs(n)),e||t?new E0(r,e,t):null}var E0=(()=>{class r{_element;_startStyles;_endStyles;static initialStylesByElement=new WeakMap;_state=0;_initialStyles;constructor(e,t,i){this._element=e,this._startStyles=t,this._endStyles=i;let o=r.initialStylesByElement.get(e);o||r.initialStylesByElement.set(e,o=new Map),this._initialStyles=o}start(){this._state<1&&(this._startStyles&&mi(this._element,this._startStyles,this._initialStyles),this._state=1)}finish(){this.start(),this._state<2&&(mi(this._element,this._initialStyles),this._endStyles&&(mi(this._element,this._endStyles),this._endStyles=null),this._state=1)}destroy(){this.finish(),this._state<3&&(r.initialStylesByElement.delete(this._element),this._startStyles&&(Ji(this._element,this._startStyles),this._endStyles=null),this._endStyles&&(Ji(this._element,this._endStyles),this._endStyles=null),mi(this._element,this._initialStyles),this._state=3)}}return r})();function Vs(r){let n=null;return r.forEach((e,t)=>{D0(t)&&(n=n||new Map,n.set(t,e))}),n}function D0(r){return r==="display"||r==="position"}var da=class{element;keyframes;options;_specialStyles;_onDoneFns=[];_onStartFns=[];_onDestroyFns=[];_duration;_delay;_initialized=!1;_finished=!1;_started=!1;_destroyed=!1;_finalKeyframe;_originalOnDoneFns=[];_originalOnStartFns=[];domPlayer;time=0;parentPlayer=null;currentSnapshot=new Map;constructor(n,e,t,i){this.element=n,this.keyframes=e,this.options=t,this._specialStyles=i,this._duration=t.duration,this._delay=t.delay||0,this.time=this._duration+this._delay}_onFinish(){this._finished||(this._finished=!0,this._onDoneFns.forEach(n=>n()),this._onDoneFns=[])}init(){this._buildPlayer(),this._preparePlayerBeforeStart()}_buildPlayer(){if(this._initialized)return;this._initialized=!0;let n=this.keyframes;this.domPlayer=this._triggerWebAnimation(this.element,n,this.options),this._finalKeyframe=n.length?n[n.length-1]:new Map;let e=()=>this._onFinish();this.domPlayer.addEventListener("finish",e),this.onDestroy(()=>{this.domPlayer.removeEventListener("finish",e)})}_preparePlayerBeforeStart(){this._delay?this._resetDomPlayerState():this.domPlayer.pause()}_convertKeyframesToObject(n){let e=[];return n.forEach(t=>{e.push(Object.fromEntries(t))}),e}_triggerWebAnimation(n,e,t){return n.animate(this._convertKeyframesToObject(e),t)}onStart(n){this._originalOnStartFns.push(n),this._onStartFns.push(n)}onDone(n){this._originalOnDoneFns.push(n),this._onDoneFns.push(n)}onDestroy(n){this._onDestroyFns.push(n)}play(){this._buildPlayer(),this.hasStarted()||(this._onStartFns.forEach(n=>n()),this._onStartFns=[],this._started=!0,this._specialStyles&&this._specialStyles.start()),this.domPlayer.play()}pause(){this.init(),this.domPlayer.pause()}finish(){this.init(),this._specialStyles&&this._specialStyles.finish(),this._onFinish(),this.domPlayer.finish()}reset(){this._resetDomPlayerState(),this._destroyed=!1,this._finished=!1,this._started=!1,this._onStartFns=this._originalOnStartFns,this._onDoneFns=this._originalOnDoneFns}_resetDomPlayerState(){this.domPlayer&&this.domPlayer.cancel()}restart(){this.reset(),this.play()}hasStarted(){return this._started}destroy(){this._destroyed||(this._destroyed=!0,this._resetDomPlayerState(),this._onFinish(),this._specialStyles&&this._specialStyles.destroy(),this._onDestroyFns.forEach(n=>n()),this._onDestroyFns=[])}setPosition(n){this.domPlayer===void 0&&this.init(),this.domPlayer.currentTime=n*this.time}getPosition(){return+(this.domPlayer.currentTime??0)/this.time}get totalTime(){return this._delay+this._duration}beforeDestroy(){let n=new Map;this.hasStarted()&&this._finalKeyframe.forEach((t,i)=>{i!=="offset"&&n.set(i,this._finished?t:Jo(this.element,i))}),this.currentSnapshot=n}triggerCallback(n){let e=n==="start"?this._onStartFns:this._onDoneFns;e.forEach(t=>t()),e.length=0}},ca=class{validateStyleProperty(n){return!0}validateAnimatableStyleProperty(n){return!0}containsElement(n,e){return Ps(n,e)}getParentElement(n){return Qo(n)}query(n,e,t){return Ms(n,e,t)}computeStyle(n,e,t){return Jo(n,e)}animate(n,e,t,i,o,a=[]){let l=i==0?"both":"forwards",d={duration:t,delay:i,fill:l};o&&(d.easing=o);let f=new Map,s=a.filter(y=>y instanceof da);mu(t,i)&&s.forEach(y=>{y.currentSnapshot.forEach((k,x)=>f.set(x,k))});let c=hu(e).map(y=>new Map(y));c=pu(n,c,f);let m=T0(n,c);return new da(n,c,d,m)}};var na="@",Mu="@.disabled",ha=class{namespaceId;delegate;engine;_onDestroy;\u0275type=0;constructor(n,e,t,i){this.namespaceId=n,this.delegate=e,this.engine=t,this._onDestroy=i}get data(){return this.delegate.data}destroyNode(n){this.delegate.destroyNode?.(n)}destroy(){this.engine.destroy(this.namespaceId,this.delegate),this.engine.afterFlushAnimationsDone(()=>{queueMicrotask(()=>{this.delegate.destroy()})}),this._onDestroy?.()}createElement(n,e){return this.delegate.createElement(n,e)}createComment(n){return this.delegate.createComment(n)}createText(n){return this.delegate.createText(n)}appendChild(n,e){this.delegate.appendChild(n,e),this.engine.onInsert(this.namespaceId,e,n,!1)}insertBefore(n,e,t,i=!0){this.delegate.insertBefore(n,e,t),this.engine.onInsert(this.namespaceId,e,n,i)}removeChild(n,e,t){this.parentNode(e)&&this.engine.onRemove(this.namespaceId,e,this.delegate)}selectRootElement(n,e){return this.delegate.selectRootElement(n,e)}parentNode(n){return this.delegate.parentNode(n)}nextSibling(n){return this.delegate.nextSibling(n)}setAttribute(n,e,t,i){this.delegate.setAttribute(n,e,t,i)}removeAttribute(n,e,t){this.delegate.removeAttribute(n,e,t)}addClass(n,e){this.delegate.addClass(n,e)}removeClass(n,e){this.delegate.removeClass(n,e)}setStyle(n,e,t,i){this.delegate.setStyle(n,e,t,i)}removeStyle(n,e,t){this.delegate.removeStyle(n,e,t)}setProperty(n,e,t){e.charAt(0)==na&&e==Mu?this.disableAnimations(n,!!t):this.delegate.setProperty(n,e,t)}setValue(n,e){this.delegate.setValue(n,e)}listen(n,e,t,i){return this.delegate.listen(n,e,t,i)}disableAnimations(n,e){this.engine.disableAnimations(n,e)}},Ks=class extends ha{factory;constructor(n,e,t,i,o){super(e,t,i,o),this.factory=n,this.namespaceId=e}setProperty(n,e,t){e.charAt(0)==na?e.charAt(1)=="."&&e==Mu?(t=t===void 0?!0:!!t,this.disableAnimations(n,t)):this.engine.process(this.namespaceId,n,e.slice(1),t):this.delegate.setProperty(n,e,t)}listen(n,e,t,i){if(e.charAt(0)==na){let o=A0(n),a=e.slice(1),l="";return a.charAt(0)!=na&&([a,l]=P0(a)),this.engine.listen(this.namespaceId,o,a,l,d=>{let f=d._data||-1;this.factory.scheduleListenerCallback(f,t,d)})}return this.delegate.listen(n,e,t,i)}};function A0(r){switch(r){case"body":return document.body;case"document":return document;case"window":return window;default:return r}}function P0(r){let n=r.indexOf("."),e=r.substring(0,n),t=r.slice(n+1);return[e,t]}var ua=class{delegate;engine;_zone;_currentId=0;_microtaskId=1;_animationCallbacksBuffer=[];_rendererCache=new Map;_cdRecurDepth=0;constructor(n,e,t){this.delegate=n,this.engine=e,this._zone=t,e.onRemovalComplete=(i,o)=>{o?.removeChild(null,i)}}createRenderer(n,e){let t="",i=this.delegate.createRenderer(n,e);if(!n||!e?.data?.animation){let f=this._rendererCache,s=f.get(i);if(!s){let c=()=>f.delete(i);s=new ha(t,i,this.engine,c),f.set(i,s)}return s}let o=e.id,a=e.id+"-"+this._currentId;this._currentId++,this.engine.register(a,n);let l=f=>{Array.isArray(f)?f.forEach(l):this.engine.registerTrigger(o,a,n,f.name,f)};return e.data.animation.forEach(l),new Ks(this,a,i,this.engine)}begin(){this._cdRecurDepth++,this.delegate.begin&&this.delegate.begin()}_scheduleCountTask(){queueMicrotask(()=>{this._microtaskId++})}scheduleListenerCallback(n,e,t){if(n>=0&&n<this._microtaskId){this._zone.run(()=>e(t));return}let i=this._animationCallbacksBuffer;i.length==0&&queueMicrotask(()=>{this._zone.run(()=>{i.forEach(o=>{let[a,l]=o;a(l)}),this._animationCallbacksBuffer=[]})}),i.push([e,t])}end(){this._cdRecurDepth--,this._cdRecurDepth==0&&this._zone.runOutsideAngular(()=>{this._scheduleCountTask(),this.engine.flush(this._microtaskId)}),this.delegate.end&&this.delegate.end()}whenRenderingDone(){return this.engine.whenRenderingDone()}componentReplaced(n){this.engine.flush(),this.delegate.componentReplaced?.(n)}};var O0=(()=>{class r extends gr{constructor(e,t,i){super(e,t,i)}ngOnDestroy(){this.flush()}static \u0275fac=function(t){return new(t||r)(Rn(zi),Rn(wn),Rn(kn))};static \u0275prov=ot({token:r,factory:r.\u0275fac})}return r})();function I0(){return new ra}function R0(r,n,e){return new ua(r,n,e)}var Ou=[{provide:kn,useFactory:I0},{provide:gr,useClass:O0},{provide:vl,useFactory:R0,deps:[Wl,gr,ht]}],sT=[{provide:wn,useClass:Zs},{provide:Ei,useValue:"NoopAnimations"},...Ou],N0=[{provide:wn,useFactory:()=>new ca},{provide:Ei,useFactory:()=>"BrowserAnimations"},...Ou];function Iu(){return ml("NgEagerAnimations"),[...N0]}var Ru=11,Nu="connectionConfig",el=(()=>{class r{config;isLoggedIn=null;loggedInSubscription=null;connection=M(no);auth=M(_i);router=M(oo);delta=M(Un);data=M(Vi);storage=M(ro);constructor(){this.loggedInSubscription=this.auth.isLoggedIn$.subscribe(e=>{this.isLoggedIn=e})}initNetworkServices(){return Ca(this,null,function*(){this.loadLocalStorageConfig(),this.preloadFonts();try{this.config?.signalKUrl!==void 0&&this.config.signalKUrl!==null&&(yield this.connection.resetSignalK({url:this.config.signalKUrl,new:!1},this.config.proxyEnabled,this.config.signalKSubscribeAll)),!this.isLoggedIn&&this.config?.signalKUrl&&this.config?.useSharedConfig&&this.config?.loginName&&this.config?.loginPassword&&(yield this.login()),this.isLoggedIn&&this.config?.useSharedConfig&&(this.storage.activeConfigFileVersion=Ru,this.storage.sharedConfigName=this.config.sharedConfigName,yield this.storage.getConfig("user",this.config.sharedConfigName,Ru,!0)),!this.isLoggedIn&&this.config?.signalKUrl&&this.config?.useSharedConfig&&this.router.navigate(["/login"])}catch(e){return console.warn("[AppInit Network Service] Services loaded. Connection attempt unsuccessful"),console.error(e),Promise.reject("[AppInit Network Service] Services loaded. Connection issue")}finally{console.log("[AppInit Network Service] Initialization completed")}})}login(){return Ca(this,null,function*(){if(!this.isLoggedIn&&this.config.useSharedConfig&&this.config.loginName&&this.config.loginPassword)try{yield this.auth.login({usr:this.config.loginName,pwd:this.config.loginPassword})}catch(e){e.status===0?this.router.navigate(["/settings"]):e.status===401&&this.router.navigate(["/login"]),console.error("[AppInit Network Service] Login failure. Server returned: "+JSON.stringify(e.error))}})}setLocalStorageConfig(){localStorage.setItem(Nu,JSON.stringify(this.config))}loadLocalStorageConfig(){this.config=JSON.parse(localStorage.getItem(Nu)),this.config?this.config.signalKUrl||(this.config.signalKUrl=window.location.origin,this.setLocalStorageConfig(),console.log(`[AppInit Network Service] Config found with no server URL. Setting Auto-Discovery URL: ${this.config.signalKUrl}`)):(this.config=Ol,this.config.signalKUrl=window.location.origin,console.log(`[AppInit Network Service] Connection Configuration not found. Creating configuration using Auto-Discovery URL: ${this.config.signalKUrl}`),this.setLocalStorageConfig()),this.config.configVersion==9&&(this.config.configVersion=10,this.setLocalStorageConfig(),console.log("[AppInit Network Service] Upgrading Connection version from 9 to 10")),this.config.configVersion==10&&(this.config.configVersion=11,this.setLocalStorageConfig(),console.log("[AppInit Network Service] Upgrading Connection version from 10 to 11"))}preloadFonts(){let e=[{family:"Roboto",src:"url(./assets/google-fonts/KFOlCnqEu92Fr1MmSU5fChc4AMP6lbBP.woff2)",options:{weight:"300",style:"normal"}},{family:"Roboto",src:"url(./assets/google-fonts/KFOlCnqEu92Fr1MmSU5fBBc4AMP6lQ.woff2)",options:{weight:"300",style:"normal"}},{family:"Roboto",src:"url(./assets/google-fonts/KFOmCnqEu92Fr1Mu7GxKKTU1Kvnz.woff2)",options:{weight:"400",style:"normal"}},{family:"Roboto",src:"url(./assets/google-fonts/KFOmCnqEu92Fr1Mu4mxKKTU1Kg.woff2)",options:{weight:"400",style:"normal"}},{family:"Roboto",src:"url(./assets/google-fonts/KFOlCnqEu92Fr1MmEU9fChc4AMP6lbBP.woff2)",options:{weight:"500",style:"normal"}},{family:"Roboto",src:"url(./assets/google-fonts/KFOlCnqEu92Fr1MmEU9fBBc4AMP6lQ.woff2)",options:{weight:"500",style:"normal"}}];for(let{family:t,src:i,options:o}of e){let a=new FontFace(t,i,o);a.load().then(()=>document.fonts.add(a)).catch(l=>console.log(`[AppInit Network Service] Error loading fonts: ${l}`))}}ngOnDestroy(){this.loggedInSubscription?.unsubscribe()}static \u0275fac=function(t){return new(t||r)};static \u0275prov=ot({token:r,factory:r.\u0275fac})}return r})();var Wu=(()=>{class r{auth=M(_i);authToken=null;authTokenSubscription=null;constructor(){this.authTokenSubscription=this.auth.authToken$.subscribe(e=>{this.authToken=e})}intercept(e,t){let i=e.clone();return this.authToken&&(i=e.clone({headers:e.headers.set("authorization","JWT "+this.authToken.token)})),t.handle(i)}ngOnDestroy(){this.authTokenSubscription?.unsubscribe()}static \u0275fac=function(t){return new(t||r)};static \u0275prov=ot({token:r,factory:r.\u0275fac})}return r})();var ZT=wr(Bu());var W0=r=>()=>r.initNetworkServices().then(n=>{}).catch(n=>{}),B0=(()=>{class r extends Vl{overrides={swipe:{direction:Hammer.DIRECTION_ALL,velocity:.3,threshold:10,domEvents:!0},press:{time:500,domEvents:!0}};options={domEvents:!0};static \u0275fac=(()=>{let e;return function(i){return(e||(e=Nn(r)))(i||r)}})();static \u0275prov=ot({token:r,factory:r.\u0275fac})}return r})();Eh.production&&void 0;Bl(Wh,{providers:[dl(zl,Fl),{provide:Il,useClass:Wu,multi:!0},el,{provide:bl,useFactory:W0,deps:[el],multi:!0},{provide:Ll,useClass:B0},{provide:hd,useValue:{hasBackdrop:!0,disableClose:!1,autoFocus:"first-tabbable",delayFocusTrap:!0,backdropClass:"dialogBackdrop"}},{provide:ud,useValue:{appearance:"outline",floatLabel:"always",subscriptSizing:"dynamic"}},{provide:Id,useValue:{showDelay:1500,hideDelay:0}},_i,Vi,no,Un,ho,st,Yn,ei,Yi,Uo,ro,Wd(),Rl(Nl()),Ul(Th,Gl()),Iu()]});export{B0 as kipHammerConfig};
|