(()=>{var Y=Object.defineProperty;var A=Object.getOwnPropertySymbols;var W=Object.prototype.hasOwnProperty,G=Object.prototype.propertyIsEnumerable;var H=(r,e,t)=>e in r?Y(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,g=(r,e)=>{for(var t in e||(e={}))W.call(e,t)&&H(r,t,e[t]);if(A)for(var t of A(e))G.call(e,t)&&H(r,t,e[t]);return r};var N=(r,e,t)=>new Promise((s,i)=>{var a=o=>{try{c(t.next(o))}catch(u){i(u)}},n=o=>{try{c(t.throw(o))}catch(u){i(u)}},c=o=>o.done?s(o.value):Promise.resolve(o.value).then(a,n);c((t=t.apply(r,e)).next())});var v,y;function K(){v.dataset.navState="displayed",v.classList.remove("state-off"),v.classList.add("state-on"),y.classList.add("a-show")}function R(){v.dataset.navState="hidden",v.classList.remove("state-on"),v.classList.add("state-off"),y.classList.add("a-hide"),y.classList.remove("a-show"),setTimeout(()=>{y.classList.remove("a-hide")},300)}function M(){console.log("HUD init"),v=document.querySelector(".hud .nav-toggle"),y=document.querySelector(".hud .navigation"),v.addEventListener("click",r=>{r.currentTarget.dataset.navState!="displayed"?K():R()})}var w=class{constructor(e,t,s){this.screens={},this.routesMap={},this.currentScreen=null,this.eventsHandlers={switch:[]},this.screensContainer=document.querySelector(e),this.loader=document.querySelector(t),this.errorScreen=document.querySelector(s),console.log("Screens Init")}add(e,t){if(typeof t!="object")return console.error("Screens: screens must be object");if(typeof(t==null?void 0:t.alias)=="undefined")return console.error("Screens: undefined alias");if(typeof(t==null?void 0:t.renderer)!="function")return console.error("Screens: renderer must be function");this.screens[t.alias]=g({route:e},t),this.routesMap[e]=t.alias}switch(e){var s;if(this.runSwitchHandlers(e),this.hideErrorScreen(),this.showLoader(),(s=this.currentScreen)==null||s.DOMObject.remove(),typeof this.screens[e]=="undefined"){console.error(`Screens: "${e}" not found`);return}this.currentScreen=this.screens[e];let t=document.createElement("div");t.classList.add("screen"),t.id=e,t.dataset.alias=e,t.innerHTML=this.currentScreen.renderer(),this.currentScreen.DOMObject=t,this.screensContainer.append(this.currentScreen.DOMObject),this.currentScreen.initer(this)}routing(){setInterval(()=>{let e=document.location.hash.split("#!")[1];if(typeof e=="undefined"||e=="")return;let t=typeof this.routesMap[e]=="undefined"?"not-found-screen":this.routesMap[e];(!this.currentScreen||this.currentScreen.alias!=t)&&this.switch(t)},50)}ready(){this.currentScreen!=null&&(this.currentScreen.DOMObject||(this.currentScreen.DOMObject=document.getElementsById(this.currentScreen.alias)),this.hideLoader(),this.currentScreen.DOMObject.classList.add("a-show"))}error(e,t){var s;(s=this.currentScreen)==null||s.DOMObject.remove(),this.errorScreen.querySelector(".error-title").innerHTML=e,this.errorScreen.querySelector(".error-text").innerHTML=t,this.showErrorScreen()}hideLoader(){this.loader.classList.remove("a-show")}showLoader(){this.loader.classList.add("a-show")}showErrorScreen(){this.errorScreen.classList.add("a-show")}hideErrorScreen(){this.errorScreen.classList.remove("a-show")}getScreens(){return this.screens}getRoutesMap(){return this.routesMap}onSwitch(e){this.eventsHandlers.switch.push(e)}runSwitchHandlers(e){for(let t of this.eventsHandlers.switch)t(this,e)}};function Q(r,e,t,s){return`
<div class="toast toast-${r}" role="alert">
<div class="toast-content">
<h4 class="toast-title">${e} ${t}</h4>
<p class="toast-text">${s}</p>
</div>
<button class="btn-icon toast-close" type="button" aria-label="Close">\u2715</button>
</div>
`}function V(r){return r.close=function(){this.classList.add("a-hide"),setTimeout(()=>{this.remove()},300)},r.querySelector(".toast-close").addEventListener("click",e=>{r.close()}),r.show=function(){document.querySelector("body").append(r),setTimeout(()=>{r.classList.add("a-show")},10)},r}function S(r,e,t,s){let i=document.createElement("div");return i.innerHTML=Q(r,e,t,s),V(i.childNodes[1])}function X(r,e){return S("success",'<i class="ph ph-check-circle"></i>',r,e)}function Z(r,e){return S("info",'<i class="ph ph-info"></i>',r,e)}function ee(r,e){return S("warning",'<i class="ph ph-warning"></i>',r,e)}function q(r,e){return S("danger",'<i class="ph ph-warning-octagon"></i>',r,e)}var x={create:S,createInfo:Z,createSuccess:X,createWarning:ee,createError:q,createDanger:q};function te(r){let e="";for(let t of r){let s="",i="";t.route&&(s=`<a class="list-action" href="${t.route}">`,i="</a>"),e+=`
<li class="list-item ${t.is_active?"list-item-active":""}">
${s}${t.content}${i}
</li>
`}return`
<div class="sidebar block">
<ul class="list list-nav">
${e}
</ul>
</div>
`}function se(r,e,t,s){let i='<tr class="table-row">';for(let c in e)i+=`<th scope="col">${e[c]}</th>`;i+="</tr>";let a="";for(let c of t){a+='<tr class="table-row">';for(let o in e)a+=`<td>${c[o]}</td>`;a+="</tr>"}let n="";return typeof s!="undefined"&&(n=`
<tfoot class="table-foot">
<tr class="table-row">
<td colspan="${e.length}">
${s}
</td>
</tr>
</tfoot>
`),`
<table class="table devices-lists">
<caption class="table-caption">${r}</caption>
<thead class="table-head">${i}</thead>
<tbody class="table-body">${a}</tbody>
${n}
</table>
`}function C(r,e,t){let s=document.createElement(r);for(let[i,a]of Object.entries(e))i==="class"?s.className=a:i==="dataset"?Object.assign(s.dataset,a):s.setAttribute(i,a);return s.innerHTML=typeof t!="undefined"?t:"",s}function re(r,e){return["primary","success","secondary","info","warning","error","danger"].indexOf(r)<0?console.error("createAlert()","Error of type: "+r):C("div",{class:`alert alert-${r}`},e)}function ie(r){let e={device_name:"name",device_hard_id:"device_id",device_ip:"ip",device_type:"type",ip_address:"ip",mac_address:"mac",device_mac:"mac",core_version:"firmware_core_version"},t={};for(let s in r){if(typeof e[s]!="undefined"){t[e[s]]=r[s];continue}t[s]=r[s]}return t}var U={template:{sidebarNav:te,table:se,createElement:C,createAlert:re},unification:{deviceFieldsUnification:ie}};var $=class{constructor(e){this.core=e}actions_list(e){return this.core.api_get("/api/v1/scripts/actions/list",e)}scopes_list(e){return this.core.api_get("/api/v1/scripts/scopes/list",e)}regular_list(e){return this.core.api_get("/api/v1/scripts/regular/list",e)}scope_get_by_filename(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/scopes/name/${s}`,t,{})}scope_create(e,t){return this.core.api_post("/api/v1/scripts/scopes/new",e,t)}scope_update(e,t){return this.core.api_post("/api/v1/scripts/scopes/update",e,t)}action_enable(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/actions/alias/${s}/enable`,t)}action_disable(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/actions/alias/${s}/disable`,t)}regular_enable(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/actions/regular/${s}/enable`,t)}regular_disable(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/actions/regular/${s}/disable`,t)}scope_enable(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/actions/scope/${s}/enable`,t)}scope_disable(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/actions/scope/${s}/disable`,t)}scope_remove(e,t){let s=encodeURIComponent(String(e||""));return this.core.api_get(`/api/v1/scripts/scopes/name/${s}/remove`,t)}run(e,t){return this.core.api_post("/api/v1/scripts/actions/run",e,t)}};var E=class{constructor(e){this.core=e}list(e){return this.core.api_get("/api/v1/devices/list",e)}scanning_setup(e){return this.core.api_get("/api/v1/devices/scanning/setup",e)}scanning_all(e){return this.core.api_get("/api/v1/devices/scanning/all",e)}setup_new_device(e,t){return this.core.api_post("/api/v1/devices/setup/new-device",e,t)}info(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/devices/id/${s}/info`,t)}get(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/devices/id/${s}`,t)}status(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/devices/id/${s}/status`,t)}action(e,t){return this.core.api_post("/api/v1/devices/action",e,t)}remove(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/devices/id/${s}/remove`,t)}reboot(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/devices/id/${s}/reboot`,t)}};var T=class{constructor(e){this.core=e}list(e){return this.core.api_get("/api/v1/areas/list",e)}inner_list(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/areas/id/${s}/list`,t)}new_area(e,t){return this.core.api_post("/api/v1/areas/new-area",e,t)}remove(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/areas/id/${s}/remove`,t)}place_in_area(e,t){return this.core.api_post("/api/v1/areas/place-in-area",e,t)}update_display_name(e,t){return this.core.api_post("/api/v1/areas/update-display-name",e,t)}update_alias(e,t){return this.core.api_post("/api/v1/areas/update-alias",e,t)}devices(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/areas/id/${s}/devices`,t)}unassign_from_area(e,t){let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/areas/id/${s}/unassign-from-area`,t)}types_list(e){return this.core.api_get("/api/v1/areas/types/list",e)}reboot_devices(e,t){if(e==null)return this.core.api_get("/api/v1/areas/reboot_devices",t);let s=encodeURIComponent(String(e));return this.core.api_get(`/api/v1/areas/id/${s}/reboot_devices`,t)}};function j(r){if(!r||typeof r!="object")return"";let e=new URLSearchParams;Object.entries(r).forEach(([s,i])=>{i!=null&&e.append(s,String(i))});let t=e.toString();return t?`?${t}`:""}function ne(r,e){let t=String(r||"").replace(/\/+$/,""),s=String(e||"").replace(/^\/+/,"");return`${t}/${s}`}function ae(r){try{return{ok:!0,data:JSON.parse(r)}}catch(e){return{ok:!1,error:e}}}var L=class{constructor(e){this.base_url=(e==null?void 0:e.base_url)||"",this.token=(e==null?void 0:e.token)||"",this.timeout_ms=Number.isFinite(e==null?void 0:e.timeout_ms)?e.timeout_ms:15e3,this.default_headers=(e==null?void 0:e.default_headers)||{},this.on_unauthorized=typeof(e==null?void 0:e.on_unauthorized)=="function"?e.on_unauthorized:null,this.proxy_path=(e==null?void 0:e.proxy_path)||"",this.scripts=new $(this),this.devices=new E(this),this.areas=new T(this)}set_base_url(e){this.base_url=e||""}set_token(e){this.token=e||""}set_proxy_path(e){this.proxy_path=e||""}_wrap_path(e,t){if(!this.proxy_path)return t?`${e}${j(t)}`:e;let s=g({path:e},t||{});return`${this.proxy_path}${j(s)}`}request(e,t,s,i,a){let n=typeof i=="function"?i:()=>{},c=ne(this.base_url,t),o=new AbortController,u=Number.isFinite(a==null?void 0:a.timeout_ms)?a.timeout_ms:this.timeout_ms,d=setTimeout(()=>o.abort(),u),m=g(g({},this.default_headers),(a==null?void 0:a.headers)||{});this.token&&(m.Authorization=`Bearer ${this.token}`);let b;s!=null&&(m["Content-Type"]="application/json",b=JSON.stringify(s)),fetch(c,{method:e,headers:m,body:b,signal:o.signal}).then(l=>N(this,null,function*(){clearTimeout(d);let h={url:c,method:e,status_code:l.status,headers:l.headers},p=yield l.text(),O=ae(p),f=O.ok?O.data:p;if(!l.ok){let _={type:"http_error",message:`HTTP ${l.status}`,status_code:l.status,raw:f};if((l.status===401||l.status===403)&&this.on_unauthorized)try{this.on_unauthorized({error:_,meta:h})}catch(D){}return n(_,null,h)}if(O.ok&&f&&typeof f=="object"){let _=f.status;if(_===!1||_==="error"){let D={type:"api_error",message:f.message||"API error",status_code:l.status,raw:f,field:f.field};return n(D,null,h)}}return n(null,f,h)})).catch(l=>{clearTimeout(d);let p=l&&(l.name==="AbortError"||String(l).includes("AbortError"))?{type:"timeout",message:`Timeout after ${u}ms`}:{type:"network_error",message:(l==null?void 0:l.message)||"Network error",details:l};return n(p,null,{url:c,method:e,status_code:0,headers:null})})}get(e,t,s){return this.request("GET",e,null,t,s)}post(e,t,s,i){return this.request("POST",e,t,s,i)}api_get(e,t,s,i){return this.get(this._wrap_path(e,s),t,i)}api_post(e,t,s,i,a){return this.post(this._wrap_path(e,i),t,s,a)}};function P(r,e){return console.log(r),Modals.create("device-popup",{title:`Device ${r.name}`,body:t=>{let s="";for(let i in r)s+=`
<tr class="table-row">
<th>${i}: </th>
<td>${r[i]}</td>
</tr>
`;return`
<div class="block">
<table class="table" style="border: 0">
<tbody class="table-body">
${s}
</tbody>
</table>
</div>
`},actions:t=>{let s=Helper.template.createElement("button",{class:"btn btn-primary"},"Close"),i=Helper.template.createElement("button",{class:"btn btn-warning with-icon"},'<i class="ph ph-arrow-clockwise"></i> Reboot'),a=Helper.template.createElement("button",{class:"btn btn-danger with-icon"},'<i class="ph ph-trash"></i> Remove');return s.addEventListener("click",n=>{t.close()}),i.addEventListener("click",n=>{e.devices.reboot(r.id,(c,o,u)=>{console.log("Reboot done"),t.close(),setTimeout(()=>{o?Toasts.createSuccess("Reboot successful",`Device: ${r.name}<br>
Alias: <b>${r.alias}</b>`).show():Toasts.createError("Reboot failed",`Device: ${r.name}<br>
Alias: <b>${r.alias}</b>`).show()},300)})}),a.addEventListener("click",n=>{confirmPopup("Are you sure you want to remove this device?",()=>{e.devices.remove(r.id,(c,o,u)=>{console.log("Was removed"),t.close(),setTimeout(()=>{Toasts.createSuccess("Removed",`
Device: ${r.name}<br>
Alias: <b>${r.alias}</b><br>
IP: <b>${r.ip}</b>
`).show()},300)})},()=>{console.log("CANCELED")})}),[s,i,a]}})}function F(r,e){return r=Helper.unification.deviceFieldsUnification(r),Modals.create("device-setup",{title:`Setup new device ${r.ip}`,body:t=>{let s="";for(let a in r)a[0]!="_"&&(s+=`
<tr class="table-row">
<th>${a}: </th>
<td>${r[a]}</td>
</tr>
`);return`
<div class="row g-6">
<div class="col device-info">
${`
<div class="block">
<table class="table" style="border: 0">
<tbody class="table-body">
${s}
</tbody>
</table>
</div>
`}
</div>
<div class="col setup-form w-100">
<div class="block form-group">
<label class="label">
Device alias
<i class="ph ph-asterisk"></i>
<input type="text" name="alias" class="input" placeholder="Input alias">
</label>
</div>
<div class="block form-group">
<label class="label">
Device name
<i class="ph ph-asterisk"></i>
<input type="text" name="name" class="input" placeholder="Input name">
</label>
</div>
<div class="block form-group">
<label class="label">
About device
<i class="ph ph-note-pencil"></i>
<textarea class="input" name="description" placeholder="Input description"></textarea>
</label>
</div>
<div class="alert-container"></div>
</div>
</div>
`},actions:t=>{let s=Helper.template.createElement("button",{class:"btn btn-primary"},"Cancel");s.addEventListener("click",a=>{t.close()});let i=Helper.template.createElement("button",{class:"btn btn-success with-icon"},'<i class="ph ph-gear"></i> Setup');return i.addEventListener("click",a=>{if(a.currentTarget.getAttribute("disabled"))return!1;let n={device_ip:r.ip},c=document.querySelector("#device-setup .setup-form");if(c.querySelectorAll("input[type='text']").forEach(d=>{d.dispatchEvent(new Event("input",{bubbles:!0}))}),c.querySelectorAll(".label.error").length)return!1;let o=c.querySelectorAll("input"),u=c.querySelector("textarea");for(let d of o)n[d.getAttribute("name")]=d.value;n[u.getAttribute("name")]=u.value,i.setAttribute("disabled","disabled"),i.classList.add("loading"),e.devices.setup_new_device(n,(d,m,b)=>{var l,h;if(i.removeAttribute("disabled"),i.classList.remove("loading"),(d==null?void 0:d.type)=="api_error"){if(console.error("ERR! sh_api.devices.setup_new_device",d.raw),(l=d.raw)!=null&&l.failed_fields)for(let p of d.raw.failed_fields)t.querySelector(`[name="${p}"]`).parentNode.classList.add("error");if((h=d.raw)!=null&&h.msg){let p=t.querySelector(".setup-form .alert-container");p.innerHTML="",p==null||p.append(Helper.template.createAlert("error",d.raw.msg))}return!1}if(!m)return!1;o.forEach(p=>p.value=""),u.value="",t.close(),setTimeout(()=>{Toasts.createSuccess("Setup successful",`Added new device <b>ID ${r.device_id}</b>`).show()},300)})}),[s,i]},onready:t=>{t.querySelector(".setup-form").querySelectorAll("input").forEach(i=>{i.addEventListener("input",a=>{var n;a.currentTarget.value.length?(a.currentTarget.parentNode.classList.remove("error"),(n=a.currentTarget.parentNode.parentNode.querySelector(".input-info.error"))==null||n.remove()):(a.currentTarget.parentNode.classList.add("error"),a.currentTarget.parentNode.parentNode.querySelector(".input-info.error")||a.currentTarget.parentNode.parentNode.append(Helper.template.createElement("div",{class:"input-info error"},'<i class="ph ph-warning-circle"></i> Field cannot be empty')))})})}})}function z(r){return Helper.template.sidebarNav([{content:'<span class="list-label"><i class="ph ph-cpu"></i> Devices</span>',route:"/#!/devices",is_active:r=="devices"},{content:'<span class="list-label"><i class="ph ph-magnifying-glass"></i> Scanning</span>',route:"/#!/devices/scanning",is_active:r=="scanning"}])}function oe(r){return{alias:"devices",renderer:()=>`
<div class="container">
<div class="row g-6">
<div class="col sidebar-container">
${z("devices")}
</div>
<div class="col devices-container"></div>
</div>
</div>
`,initer:e=>{r.devices.list((t,s,i)=>{if(console.log("sh_api.devices.list",t,s,i),i.status_code!=200)return e.error("Server API ERROR","");let a=[];for(let n of s.data.devices){n=Helper.unification.deviceFieldsUnification(n);let c=n.connection_state=="active"?'<span class="badge badge-success">Online</span>':'<span class="badge badge-warning">Offline</span>';a.push({deviceName:n.name,alias:n.alias,status:c,ip:`<code class="code">${n.ip}</code>`,actions:`
<button
class="btn btn-secondary btn-small details-btn"
data-device='${JSON.stringify(n)}'
type="button"
>Details</button>
<button
class="btn btn-warning btn-small reboot-btn"
data-device-id="${n.id}"
data-device-name="${n.name}"
data-device-alias="${n.alias}"
type="button"
>Reboot</button>
`})}e.currentScreen.DOMObject.querySelector(".devices-container").innerHTML=Helper.template.table("Devices list",{deviceName:"Device name",alias:"Device alias",status:"Status",ip:"IP",actions:"Actions"},a,`<span class="table-meta">Total: <span class="total">${s.data.total}</span> devices</span>`),e.currentScreen.DOMObject.querySelectorAll(".reboot-btn").forEach(n=>{n.addEventListener("click",c=>{let o=c.currentTarget.dataset.deviceId,u=c.currentTarget.dataset.deviceName,d=c.currentTarget.dataset.deviceAlias;r.devices.reboot(o,(m,b,l)=>{console.log("Reboot done",m,b,l),b?Toasts.createSuccess("Reboot successful",`Device: ${u}<br>
Alias: <b>${d}</b>`).show():Toasts.createError("Reboot failed",`Device: ${u}<br>
Alias: <b>${d}</b>`).show()})})}),e.currentScreen.DOMObject.querySelectorAll(".details-btn").forEach(n=>{n.addEventListener("click",c=>{let o=JSON.parse(c.currentTarget.dataset.device);P(o,r).show()})}),e.ready()})}}}function ce(r){return{alias:"devices-scanning",renderer:()=>`
<div class="container">
<div class="row g-6">
<div class="col sidebar-container">
${z("scanning")}
</div>
<div class="col devices-container"></div>
</div>
</div>
`,initer:e=>{r.devices.scanning_all((t,s,i)=>{if(console.log("sh_api.devices.scanning_all",t,s),i.status_code!=200)return e.error("Server API ERROR","");let a=[];for(let n of s.data.devices)n=Helper.unification.deviceFieldsUnification(n),a.push({deviceId:n.device_id,deviceName:n.name,deviceType:n.type,status:`<span class="badge badge-primary">${n.status}</span>`,ip:`<code class="code">${n.ip}</code>`,mac:`<code class="code">${n.mac}</code>`,wifiSignal:n.wifi_signal,actions:n.status=="setup"?`
<button
class="btn btn-secondary btn-small setup-btn"
data-device='${JSON.stringify(n)}'
type="button"
>Setup</button>
`:""});e.currentScreen.DOMObject.querySelector(".devices-container").innerHTML=Helper.template.table("Found devices",{deviceId:"Device ID",deviceName:"Device name",deviceType:"Type",status:"Status",ip:"IP",mac:"Mac",wifiSignal:"Signal",actions:"Actions"},a,`<span class="table-meta">Total: <span class="total">${s.data.devices.length}</span> devices</span>`),e.currentScreen.DOMObject.querySelectorAll(".setup-btn").forEach(n=>{n.addEventListener("click",c=>{let o=JSON.parse(c.currentTarget.dataset.device);F(o,r).show()})}),e.ready()})}}}var k={list:oe,scanning:ce};function J(r,e){r.add("/",{alias:"home",renderer:()=>'<h2 class="mt-4">Hello world</h2>',initer:t=>{setTimeout(()=>t.ready(),1e3),setTimeout(()=>t.error("Error","Just testing"),2e3)}}),r.add("-",{alias:"not-found-screen",renderer:()=>'<h2 class="mt-4">404 NOT FOUND</h2>',initer:t=>{t.ready()}}),r.add("/devices",k.list(e)),r.add("/devices/scanning",k.scanning(e))}function le(r,e,t){return`
<div class="modal" aria-hidden="true" id="${r}">
<div class="modal-backdrop"></div>
<div class="modal-panel" role="dialog" aria-modal="true" aria-labelledby="modal-title-basic">
<header class="modal-header">
<h4 class="modal-title" id="modal-title-basic">${e}</h4>
<button class="btn-icon modal-close" type="button" aria-label="Close">\u2715</button>
</header>
<div class="modal-body"></div>
<footer class="modal-footer">${t}</footer>
</div>
</div>
`}function de(r,e){return r.show=function(){document.querySelector("body").append(r),setTimeout(()=>{this.classList.add("a-show")},10)},r.close=function(){this.classList.add("a-hide"),setTimeout(()=>{this.remove()},300)},r.querySelector(".modal-close").addEventListener("click",t=>{r.close()}),typeof e=="function"&&e(r),r}function ue(r,e){let t=e.title||"",s=e.footer||"",i=document.createElement("div");i.innerHTML=le(r,t,s);let a=i.childNodes[1],n=a.querySelector(".modal-body"),c=a.querySelector(".modal-footer");if(typeof e.actions=="function"){let o=e.actions(a);if(typeof o[0]=="object"){let u=document.createElement("div");u.classList.add("actions");for(let d of o)u.append(d);c.append(u)}}if(typeof e.body=="function"){let o=e.body(a);typeof o=="object"?n.append(o):typeof o=="string"&&(n.innerHTML=o)}return de(a,e==null?void 0:e.onready)}var B={create:ue};function I(r,e,t){Modals.create("confirm-popup",{title:"Requires confirmation",body:s=>`
<p>${r}</p>
`,actions:s=>{let i=Helper.template.createElement("button",{class:"btn btn-primary"},"NO"),a=Helper.template.createElement("button",{class:"btn btn-warning"},"YES");return i.addEventListener("click",n=>{s.close(),t()}),a.addEventListener("click",n=>{s.close(),e()}),[i,a]}}).show()}document.addEventListener("DOMContentLoaded",r=>{console.log("App init"),window.Toasts=x,window.Helper=U,window.Modals=B,window.confirmPopup=I,M();let e=new L({base_url:"http://shswebclient.local",token:"YOUR_TOKEN",timeout_ms:3e3,on_unauthorized:({error:s})=>console.log("auth problem:",s),proxy_path:"/proxy.php"}),t=new w(".screens",".load-screen",".error-screen");J(t,e),console.log(t.getScreens()),t.onSwitch((s,i)=>{R()}),t.routing()});})();
//# sourceMappingURL=main.js.map