lavva.exalushome 1.1.2 → 1.1.4
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.
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(()=>{"use strict";var e,t={d:(e,n)=>{for(var o in n)t.o(n,o)&&!t.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:n[o]})}};t.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),t.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),t.d({},{V:()=>Uh});class n{constructor(){this.handlers=[]}Subscribe(e){this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(e){this.handlers.slice(0).forEach((t=>{var n;try{t(e)}catch(e){null===(n=r.Log)||void 0===n||n.Error(e)}}))}}!function(e){e[e.Debug=0]="Debug",e[e.Info=1]="Info",e[e.Warning=2]="Warning",e[e.Error=3]="Error"}(e||(e={}));class o{constructor(){this._blockedServices=[],this._logLevel=e.Debug}EnableStackTrace(){o.DoesThrowStackTrace=!0}DisableStackTrace(){o.DoesThrowStackTrace=!0}IsBlocked(e){return void 0!==e&&this._blockedServices.any((t=>t==e))}DisableLogsFrom(e){this._blockedServices.all((t=>t!=e))&&this._blockedServices.push(e),this.Debug(o.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(o.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return o.ServiceName}GetTimeStamp(){const e=new Date;return`${e.getHours()}:${e.getMinutes()}:${e.getSeconds()}.${e.getMilliseconds()} | `}Warning(t,n){switch(this._logLevel){case e.Warning:case e.Info:case e.Debug:break;default:return}void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.warn(`${this.GetTimeStamp()}[WARN] ${t}`):console.warn(`${this.GetTimeStamp()}[WARN] [${t}] ${n}`))}Error(e,t){null!=e&&(null==t?console.error(`${this.GetTimeStamp()}[ERROR] ${e}`):console.error(`${this.GetTimeStamp()}[ERROR] [${e}] ${t}`))}Info(t,n){switch(this._logLevel){case e.Info:case e.Debug:break;default:return}void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.info(`${this.GetTimeStamp()}[INFO] ${t}`):console.info(`${this.GetTimeStamp()}[INFO] [${t}] ${n}`))}Debug(t,n){this._logLevel===e.Debug&&(void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.debug(`${this.GetTimeStamp()}[DEBUG] ${t}`):o.DoesThrowStackTrace?console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n} \nstack:\n${(new Error).stack}}`):console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n}`)))}Log(e,t){void 0===e||this.IsBlocked(e)||null!=e&&(null==t?console.log(`${this.GetTimeStamp()}[LOG] ${e}`):console.log(`${this.GetTimeStamp()}[LOG] [${e}] ${t}`))}}o.ServiceName="LoggerService",o.DoesThrowStackTrace=!1;class r{constructor(){this._services={},this._serviceRegistrationEvent=new n}static get Instance(){return null!=r._instance||(r._instance=new r,this.Log=new o,this.Log.Warning("Initializing DependencyContainer"),r._instance.RegisterService(this.Log),this.IsInitialized=!0),r._instance}RegisterService(e){var t;null===(t=r.Log)||void 0===t||t.Debug("DependencyContainer",`Registering new service: ${e.GetServiceName()}`),this._services[e.GetServiceName()]=e,this._serviceRegistrationEvent.Invoke(e)}GetService(e){var t;return null===(t=r.Log)||void 0===t||t.Debug("DependencyContainer",`Getting service [${e}] by GetService<T>()`),this._services[e]}GetServiceAsync(e,t){var n,o;return null===(n=r.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service availability [${e}] by GetServiceAsync<T>()`),this._services.hasOwnProperty(e)?(null===(o=r.Log)||void 0===o||o.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,o)=>{var s=t=>{var o;(null==t?void 0:t.GetServiceName())===e&&(null===(o=r.Log)||void 0===o||o.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(s),n(t))},i=()=>{var n;null===(n=r.Log)||void 0===n||n.Debug("DependencyContainer",`Cancelled service [${e}] retrieval by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(s),null==t||t.CancellationEvent.Unsubscribe(i),o(new Error("Operation cancelled!"))};null==t||t.CancellationEvent.Subscribe(i),this._serviceRegistrationEvent.Subscribe(s)}))}GetServiceWithTimeoutAsync(e,t){var n,o;return null===(n=r.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service[${e}] availability by GetServiceWithTimeoutAsync<T>()`),this._services.hasOwnProperty(e)?(null===(o=r.Log)||void 0===o||o.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,o)=>{let s=0,i=e=>{var t;(null==e?void 0:e.GetClassName())===e&&(null===(t=r.Log)||void 0===t||t.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),window.clearTimeout(s),this._serviceRegistrationEvent.Unsubscribe(i),n(e))};s=window.setTimeout((()=>{var t;window.clearTimeout(s),this._serviceRegistrationEvent.Unsubscribe(i),null===(t=r.Log)||void 0===t||t.Error("DependencyContainer",`Failed to get service [${e}] in time by GetServiceWithTimeoutAsync<T>()`),o(new Error("Operation cancelled!"))}),t),this._serviceRegistrationEvent.Subscribe(i)}))}}r.IsInitialized=!1;class s{GetServiceName(){return s.ServiceName}GetResourceName(e,t){return`_exalus_${Uh.WorksInContextOf}_${e}_${t}`}Remove(e,t){localStorage.removeItem(this.GetResourceName(e,t))}DropStorage(e){let t=`_exalus_${e}`;for(const e in localStorage)(null==e?void 0:e.startsWith(t))&&localStorage.removeItem(e)}Save(e,t,n){localStorage.setItem(this.GetResourceName(e,t),JSON.stringify(n))}Read(e,t){var n;try{let n=this.GetResourceName(e,t),o=localStorage.getItem(n);return null==o?null:JSON.parse(o)}catch(o){return null===(n=r.Log)||void 0===n||n.Error(s.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}s.ServiceName="LocalStorageService";const i=[0,2e3,1e4,3e4,null];class a{constructor(e){this._retryDelays=void 0!==e?[...e,null]:i}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class c{}c.Authorization="Authorization",c.Cookie="Cookie";class l{constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class u{get(e,t){return this.send({...t,method:"GET",url:e})}post(e,t){return this.send({...t,method:"POST",url:e})}delete(e,t){return this.send({...t,method:"DELETE",url:e})}getCookieString(e){return""}}class d extends u{constructor(e,t){super(),this._innerClient=e,this._accessTokenFactory=t}async send(e){let t=!0;this._accessTokenFactory&&(!this._accessToken||e.url&&e.url.indexOf("/negotiate?")>0)&&(t=!1,this._accessToken=await this._accessTokenFactory()),this._setAuthorizationHeader(e);const n=await this._innerClient.send(e);return t&&401===n.statusCode&&this._accessTokenFactory?(this._accessToken=await this._accessTokenFactory(),this._setAuthorizationHeader(e),await this._innerClient.send(e)):n}_setAuthorizationHeader(e){e.headers||(e.headers={}),this._accessToken?e.headers[c.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[c.Authorization]&&delete e.headers[c.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class h extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class g extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class f extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class p extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class v extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class y extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class w extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class m extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}var S,_,C,A,D;!function(e){e[e.Trace=0]="Trace",e[e.Debug=1]="Debug",e[e.Information=2]="Information",e[e.Warning=3]="Warning",e[e.Error=4]="Error",e[e.Critical=5]="Critical",e[e.None=6]="None"}(S||(S={}));class b{constructor(){}log(e,t){}}b.instance=new b;class G{static isRequired(e,t){if(null==e)throw new Error(`The '${t}' argument is required.`)}static isNotEmpty(e,t){if(!e||e.match(/^\s*$/))throw new Error(`The '${t}' argument should not be empty.`)}static isIn(e,t,n){if(!(e in t))throw new Error(`Unknown ${n} value: ${e}.`)}}class E{static get isBrowser(){return"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return"object"==typeof self&&"importScripts"in self}static get isReactNative(){return"object"==typeof window&&void 0===window.document}static get isNode(){return!this.isBrowser&&!this.isWebWorker&&!this.isReactNative}}function I(e,t){let n="";return T(e)?(n=`Binary data of length ${e.byteLength}`,t&&(n+=`. Content: '${function(e){const t=new Uint8Array(e);let n="";return t.forEach((e=>{n+=`0x${e<16?"0":""}${e.toString(16)} `})),n.substr(0,n.length-1)}(e)}'`)):"string"==typeof e&&(n=`String data of length ${e.length}`,t&&(n+=`. Content: '${e}'`)),n}function T(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function N(e,t,n,o,r,s){const i={},[a,c]=R();i[a]=c,e.log(S.Trace,`(${t} transport) sending data. ${I(r,s.logMessageContent)}.`);const l=T(r)?"arraybuffer":"text",u=await n.post(o,{content:r,headers:{...i,...s.headers},responseType:l,timeout:s.timeout,withCredentials:s.withCredentials});e.log(S.Trace,`(${t} transport) request complete. Response status: ${u.statusCode}.`)}class P{constructor(e,t){this._subject=e,this._observer=t}dispose(){const e=this._subject.observers.indexOf(this._observer);e>-1&&this._subject.observers.splice(e,1),0===this._subject.observers.length&&this._subject.cancelCallback&&this._subject.cancelCallback().catch((e=>{}))}}class k{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${S[e]}: ${t}`;switch(e){case S.Critical:case S.Error:this.out.error(n);break;case S.Warning:this.out.warn(n);break;case S.Information:this.out.info(n);break;default:this.out.log(n)}}}}function R(){let e="X-SignalR-User-Agent";return E.isNode&&(e="User-Agent"),[e,O("7.0.0",x(),E.isNode?"NodeJS":"Browser",U())]}function O(e,t,n,o){let r="Microsoft SignalR/";const s=e.split(".");return r+=`${s[0]}.${s[1]}`,r+=` (${e}; `,r+=t&&""!==t?`${t}; `:"Unknown OS; ",r+=`${n}`,r+=o?`; ${o}`:"; Unknown Runtime Version",r+=")",r}function x(){if(!E.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function U(){if(E.isNode)return process.versions.node}function F(e){return e.stack?e.stack:e.message?e.message:`${e}`}class M extends u{constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch){const e=require;this._jar=new(e("tough-cookie").CookieJar),this._fetchType=e("node-fetch"),this._fetchType=e("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(function(){if("undefined"!=typeof globalThis)return globalThis;if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==t.g)return t.g;throw new Error("could not find global")}());if("undefined"==typeof AbortController){const e=require;this._abortControllerType=e("abort-controller")}else this._abortControllerType=AbortController}async send(e){if(e.abortSignal&&e.abortSignal.aborted)throw new f;if(!e.method)throw new Error("No method defined.");if(!e.url)throw new Error("No url defined.");const t=new this._abortControllerType;let n;e.abortSignal&&(e.abortSignal.onabort=()=>{t.abort(),n=new f});let o,r=null;if(e.timeout){const o=e.timeout;r=setTimeout((()=>{t.abort(),this._logger.log(S.Warning,"Timeout from HTTP request."),n=new g}),o)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},T(e.content)?e.headers["Content-Type"]="application/octet-stream":e.headers["Content-Type"]="text/plain;charset=UTF-8");try{o=await this._fetchType(e.url,{body:e.content,cache:"no-cache",credentials:!0===e.withCredentials?"include":"same-origin",headers:{"X-Requested-With":"XMLHttpRequest",...e.headers},method:e.method,mode:"cors",redirect:"follow",signal:t.signal})}catch(e){if(n)throw n;throw this._logger.log(S.Warning,`Error from HTTP request. ${e}.`),e}finally{r&&clearTimeout(r),e.abortSignal&&(e.abortSignal.onabort=null)}if(!o.ok){const e=await $(o,"text");throw new h(e||o.statusText,o.status)}const s=$(o,e.responseType),i=await s;return new l(o.status,o.statusText,i)}getCookieString(e){let t="";return E.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function $(e,t){let n;switch(t){case"arraybuffer":n=e.arrayBuffer();break;case"text":default:n=e.text();break;case"blob":case"document":case"json":throw new Error(`${t} is not supported.`)}return n}class L extends u{constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new f):e.method?e.url?new Promise(((t,n)=>{const o=new XMLHttpRequest;o.open(e.method,e.url,!0),o.withCredentials=void 0===e.withCredentials||e.withCredentials,o.setRequestHeader("X-Requested-With","XMLHttpRequest"),""===e.content&&(e.content=void 0),e.content&&(T(e.content)?o.setRequestHeader("Content-Type","application/octet-stream"):o.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const r=e.headers;r&&Object.keys(r).forEach((e=>{o.setRequestHeader(e,r[e])})),e.responseType&&(o.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{o.abort(),n(new f)}),e.timeout&&(o.timeout=e.timeout),o.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),o.status>=200&&o.status<300?t(new l(o.status,o.statusText,o.response||o.responseText)):n(new h(o.response||o.responseText||o.statusText,o.status))},o.onerror=()=>{this._logger.log(S.Warning,`Error from HTTP request. ${o.status}: ${o.statusText}.`),n(new h(o.statusText,o.status))},o.ontimeout=()=>{this._logger.log(S.Warning,"Timeout from HTTP request."),n(new g)},o.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class W extends u{constructor(e){if(super(),"undefined"!=typeof fetch||E.isNode)this._httpClient=new M(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new L(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new f):e.method?e.url?this._httpClient.send(e):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}getCookieString(e){return this._httpClient.getCookieString(e)}}!function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(_||(_={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(C||(C={}));class B{constructor(){this._isAborted=!1,this.onabort=null}abort(){this._isAborted||(this._isAborted=!0,this.onabort&&this.onabort())}get signal(){return this}get aborted(){return this._isAborted}}class H{constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new B,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}get pollAborted(){return this._pollAbort.aborted}async connect(e,t){if(G.isRequired(e,"url"),G.isRequired(t,"transferFormat"),G.isIn(t,C,"transferFormat"),this._url=e,this._logger.log(S.Trace,"(LongPolling transport) Connecting."),t===C.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[n,o]=R(),r={[n]:o,...this._options.headers},s={abortSignal:this._pollAbort.signal,headers:r,timeout:1e5,withCredentials:this._options.withCredentials};t===C.Binary&&(s.responseType="arraybuffer");const i=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${i}.`);const a=await this._httpClient.get(i,s);200!==a.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${a.statusCode}.`),this._closeError=new h(a.statusText||"",a.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,s)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${n}.`);const o=await this._httpClient.get(n,t);204===o.statusCode?(this._logger.log(S.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==o.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${o.statusCode}.`),this._closeError=new h(o.statusText||"",o.statusCode),this._running=!1):o.content?(this._logger.log(S.Trace,`(LongPolling transport) data received. ${I(o.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(o.content)):this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof g?this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(S.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(S.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?N(this._logger,"LongPolling",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}async stop(){this._logger.log(S.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(S.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=R();e[t]=n;const o={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};await this._httpClient.delete(this._url,o),this._logger.log(S.Trace,"(LongPolling transport) DELETE request sent.")}finally{this._logger.log(S.Trace,"(LongPolling transport) Stop finished."),this._raiseOnClose()}}_raiseOnClose(){if(this.onclose){let e="(LongPolling transport) Firing onclose event.";this._closeError&&(e+=" Error: "+this._closeError),this._logger.log(S.Trace,e),this.onclose(this._closeError)}}}class V{constructor(e,t,n,o){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=o,this.onreceive=null,this.onclose=null}async connect(e,t){return G.isRequired(e,"url"),G.isRequired(t,"transferFormat"),G.isIn(t,C,"transferFormat"),this._logger.log(S.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((n,o)=>{let r,s=!1;if(t===C.Text){if(E.isBrowser||E.isWebWorker)r=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[o,s]=R();n[o]=s,r=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{r.onmessage=e=>{if(this.onreceive)try{this._logger.log(S.Trace,`(SSE transport) data received. ${I(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},r.onerror=e=>{s?this._close():o(new Error("EventSource failed to connect. The connection could not be found on the server, either the connection ID is not present on the server, or a proxy is refusing/buffering the connection. If you have multiple servers check that sticky sessions are enabled."))},r.onopen=()=>{this._logger.log(S.Information,`SSE connected to ${this._url}`),this._eventSource=r,s=!0,n()}}catch(e){return void o(e)}}else o(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?N(this._logger,"SSE",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}stop(){return this._close(),Promise.resolve()}_close(e){this._eventSource&&(this._eventSource.close(),this._eventSource=void 0,this.onclose&&this.onclose(e))}}class j{constructor(e,t,n,o,r,s){this._logger=n,this._accessTokenFactory=t,this._logMessageContent=o,this._webSocketConstructor=r,this._httpClient=e,this.onreceive=null,this.onclose=null,this._headers=s}async connect(e,t){let n;return G.isRequired(e,"url"),G.isRequired(t,"transferFormat"),G.isIn(t,C,"transferFormat"),this._logger.log(S.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(n=await this._accessTokenFactory()),new Promise(((o,r)=>{let s;e=e.replace(/^http/,"ws");const i=this._httpClient.getCookieString(e);let a=!1;if(E.isNode||E.isReactNative){const t={},[o,r]=R();t[o]=r,n&&(t[c.Authorization]=`Bearer ${n}`),i&&(t[c.Cookie]=i),s=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else n&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(n)}`);s||(s=new this._webSocketConstructor(e)),t===C.Binary&&(s.binaryType="arraybuffer"),s.onopen=t=>{this._logger.log(S.Information,`WebSocket connected to ${e}.`),this._webSocket=s,a=!0,o()},s.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(S.Information,`(WebSockets transport) ${t}.`)},s.onmessage=e=>{if(this._logger.log(S.Trace,`(WebSockets transport) data received. ${I(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},s.onclose=e=>{if(a)this._close(e);else{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"WebSocket failed to connect. The connection could not be found on the server, either the endpoint may not be a SignalR endpoint, the connection ID is not present on the server, or there is a proxy blocking WebSockets. If you have multiple servers check that sticky sessions are enabled.",r(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(S.Trace,`(WebSockets transport) sending data. ${I(e,this._logMessageContent)}.`),this._webSocket.send(e),Promise.resolve()):Promise.reject("WebSocket is not in the OPEN state")}stop(){return this._webSocket&&this._close(void 0),Promise.resolve()}_close(e){this._webSocket&&(this._webSocket.onclose=()=>{},this._webSocket.onmessage=()=>{},this._webSocket.onerror=()=>{},this._webSocket.close(),this._webSocket=void 0),this._logger.log(S.Trace,"(WebSockets transport) socket closed."),this.onclose&&(!this._isCloseEvent(e)||!1!==e.wasClean&&1e3===e.code?e instanceof Error?this.onclose(e):this.onclose():this.onclose(new Error(`WebSocket closed with status code: ${e.code} (${e.reason||"no reason given"}).`)))}_isCloseEvent(e){return e&&"boolean"==typeof e.wasClean&&"number"==typeof e.code}}class K{constructor(e,t={}){var n;if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,G.isRequired(e,"url"),this._logger=void 0===(n=t.logger)?new k(S.Information):null===n?b.instance:void 0!==n.log?n:new k(n),this.baseUrl=this._resolveUrl(e),(t=t||{}).logMessageContent=void 0!==t.logMessageContent&&t.logMessageContent,"boolean"!=typeof t.withCredentials&&void 0!==t.withCredentials)throw new Error("withCredentials option was not a 'boolean' or 'undefined' value");t.withCredentials=void 0===t.withCredentials||t.withCredentials,t.timeout=void 0===t.timeout?1e5:t.timeout;let o=null,r=null;if(E.isNode){const e=require;o=e("ws"),r=e("eventsource")}E.isNode||"undefined"==typeof WebSocket||t.WebSocket?E.isNode&&!t.WebSocket&&o&&(t.WebSocket=o):t.WebSocket=WebSocket,E.isNode||"undefined"==typeof EventSource||t.EventSource?E.isNode&&!t.EventSource&&void 0!==r&&(t.EventSource=r):t.EventSource=EventSource,this._httpClient=new d(t.httpClient||new W(this._logger),t.accessTokenFactory),this._connectionState="Disconnected",this._connectionStarted=!1,this._options=t,this.onreceive=null,this.onclose=null}async start(e){if(e=e||C.Binary,G.isIn(e,C,"transferFormat"),this._logger.log(S.Debug,`Starting connection with transfer format '${C[e]}'.`),"Disconnected"!==this._connectionState)return Promise.reject(new Error("Cannot start an HttpConnection that is not in the 'Disconnected' state."));if(this._connectionState="Connecting",this._startInternalPromise=this._startInternal(e),await this._startInternalPromise,"Disconnecting"===this._connectionState){const e="Failed to start the HttpConnection before stop() was called.";return this._logger.log(S.Error,e),await this._stopPromise,Promise.reject(new f(e))}if("Connected"!==this._connectionState){const e="HttpConnection.startInternal completed gracefully but didn't enter the connection into the connected state!";return this._logger.log(S.Error,e),Promise.reject(new f(e))}this._connectionStarted=!0}send(e){return"Connected"!==this._connectionState?Promise.reject(new Error("Cannot send data if the connection is not in the 'Connected' State.")):(this._sendQueue||(this._sendQueue=new z(this.transport)),this._sendQueue.send(e))}async stop(e){return"Disconnected"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState="Disconnecting",this._stopPromise=new Promise((e=>{this._stopPromiseResolver=e})),await this._stopInternal(e),void await this._stopPromise)}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch(e){}if(this.transport){try{await this.transport.stop()}catch(e){this._logger.log(S.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(S.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let t=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==_.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(_.WebSockets),await this._startTransport(t,e)}else{let n=null,o=0;do{if(n=await this._getNegotiationResponse(t),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new f("The connection was stopped during negotiation.");if(n.error)throw new Error(n.error);if(n.ProtocolVersion)throw new Error("Detected a connection attempt to an ASP.NET SignalR Server. This client only supports connecting to an ASP.NET Core SignalR Server. See https://aka.ms/signalr-core-differences for details.");if(n.url&&(t=n.url),n.accessToken){const e=n.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}o++}while(n.url&&o<100);if(100===o&&n.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(t,this._options.transport,n,e)}this.transport instanceof H&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(S.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(S.Error,"Failed to start the connection: "+e),this._connectionState="Disconnected",this.transport=void 0,this._stopPromiseResolver(),Promise.reject(e)}}async _getNegotiationResponse(e){const t={},[n,o]=R();t[n]=o;const r=this._resolveNegotiateUrl(e);this._logger.log(S.Debug,`Sending negotiation request: ${r}.`);try{const e=await this._httpClient.post(r,{content:"",headers:{...t,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials});if(200!==e.statusCode)return Promise.reject(new Error(`Unexpected status code returned from negotiate '${e.statusCode}'`));const n=JSON.parse(e.content);return(!n.negotiateVersion||n.negotiateVersion<1)&&(n.connectionToken=n.connectionId),n}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof h&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(S.Error,t),Promise.reject(new w(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,t,n,o){let r=this._createConnectUrl(e,n.connectionToken);if(this._isITransport(t))return this._logger.log(S.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=t,await this._startTransport(r,o),void(this.connectionId=n.connectionId);const s=[],i=n.availableTransports||[];let a=n;for(const n of i){const i=this._resolveTransportOrError(n,t,o);if(i instanceof Error)s.push(`${n.transport} failed:`),s.push(i);else if(this._isITransport(i)){if(this.transport=i,!a){try{a=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}r=this._createConnectUrl(e,a.connectionToken)}try{return await this._startTransport(r,o),void(this.connectionId=a.connectionId)}catch(e){if(this._logger.log(S.Error,`Failed to start the transport '${n.transport}': ${e}`),a=void 0,s.push(new y(`${n.transport} failed: ${e}`,_[n.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(S.Debug,e),Promise.reject(new f(e))}}}}return s.length>0?Promise.reject(new m(`Unable to connect to the server with any of the available transports. ${s.join(" ")}`,s)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case _.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new j(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case _.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new V(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case _.LongPolling:return new H(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,t,n){const o=_[e.transport];if(null==o)return this._logger.log(S.Debug,`Skipping transport '${e.transport}' because it is not supported by this client.`),new Error(`Skipping transport '${e.transport}' because it is not supported by this client.`);if(!function(e,t){return!e||0!=(t&e)}(t,o))return this._logger.log(S.Debug,`Skipping transport '${_[o]}' because it was disabled by the client.`),new v(`'${_[o]}' is disabled by the client.`,o);if(!(e.transferFormats.map((e=>C[e])).indexOf(n)>=0))return this._logger.log(S.Debug,`Skipping transport '${_[o]}' because it does not support the requested transfer format '${C[n]}'.`),new Error(`'${_[o]}' does not support ${C[n]}.`);if(o===_.WebSockets&&!this._options.WebSocket||o===_.ServerSentEvents&&!this._options.EventSource)return this._logger.log(S.Debug,`Skipping transport '${_[o]}' because it is not supported in your environment.'`),new p(`'${_[o]}' is not supported in your environment.`,o);this._logger.log(S.Debug,`Selecting transport '${_[o]}'.`);try{return this._constructTransport(o)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(S.Debug,`HttpConnection.stopConnection(${e}) called while in state ${this._connectionState}.`),this.transport=void 0,e=this._stopError||e,this._stopError=void 0,"Disconnected"!==this._connectionState){if("Connecting"===this._connectionState)throw this._logger.log(S.Warning,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is still in the connecting state.`),new Error(`HttpConnection.stopConnection(${e}) was called while the connection is still in the connecting state.`);if("Disconnecting"===this._connectionState&&this._stopPromiseResolver(),e?this._logger.log(S.Error,`Connection disconnected with error '${e}'.`):this._logger.log(S.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(S.Error,`TransportSendQueue.stop() threw error '${e}'.`)})),this._sendQueue=void 0),this.connectionId=void 0,this._connectionState="Disconnected",this._connectionStarted){this._connectionStarted=!1;try{this.onclose&&this.onclose(e)}catch(t){this._logger.log(S.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(S.Debug,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is already in the disconnected state.`)}_resolveUrl(e){if(0===e.lastIndexOf("https://",0)||0===e.lastIndexOf("http://",0))return e;if(!E.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(S.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=e.indexOf("?");let n=e.substring(0,-1===t?e.length:t);return"/"!==n[n.length-1]&&(n+="/"),n+="negotiate",n+=-1===t?"":e.substring(t),-1===n.indexOf("negotiateVersion")&&(n+=-1===t?"?":"&",n+="negotiateVersion="+this._negotiateVersion),n}}class z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new q,this._transportResult=new q,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new q),this._transportResult.promise}stop(){return this._executing=!1,this._sendBufferedData.resolve(),this._sendLoopPromise}_bufferData(e){if(this._buffer.length&&typeof this._buffer[0]!=typeof e)throw new Error(`Expected data to be of type ${typeof this._buffer} but was of type ${typeof e}`);this._buffer.push(e),this._sendBufferedData.resolve()}async _sendLoop(){for(;;){if(await this._sendBufferedData.promise,!this._executing){this._transportResult&&this._transportResult.reject("Connection stopped.");break}this._sendBufferedData=new q;const e=this._transportResult;this._transportResult=void 0;const t="string"==typeof this._buffer[0]?this._buffer.join(""):z._concatBuffers(this._buffer);this._buffer.length=0;try{await this._transport.send(t),e.resolve()}catch(t){e.reject(t)}}}static _concatBuffers(e){const t=e.map((e=>e.byteLength)).reduce(((e,t)=>e+t)),n=new Uint8Array(t);let o=0;for(const t of e)n.set(new Uint8Array(t),o),o+=t.byteLength;return n.buffer}}class q{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class J{static write(e){return`${e}${J.RecordSeparator}`}static parse(e){if(e[e.length-1]!==J.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(J.RecordSeparator);return t.pop(),t}}J.RecordSeparatorCode=30,J.RecordSeparator=String.fromCharCode(J.RecordSeparatorCode);class Y{writeHandshakeRequest(e){return J.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(T(e)){const o=new Uint8Array(e),r=o.indexOf(J.RecordSeparatorCode);if(-1===r)throw new Error("Message is incomplete.");const s=r+1;t=String.fromCharCode.apply(null,Array.prototype.slice.call(o.slice(0,s))),n=o.byteLength>s?o.slice(s).buffer:null}else{const o=e,r=o.indexOf(J.RecordSeparator);if(-1===r)throw new Error("Message is incomplete.");const s=r+1;t=o.substring(0,s),n=o.length>s?o.substring(s):null}const o=J.parse(t),r=JSON.parse(o[0]);if(r.type)throw new Error("Expected a handshake response from the server.");return[n,r]}}!function(e){e[e.Invocation=1]="Invocation",e[e.StreamItem=2]="StreamItem",e[e.Completion=3]="Completion",e[e.StreamInvocation=4]="StreamInvocation",e[e.CancelInvocation=5]="CancelInvocation",e[e.Ping=6]="Ping",e[e.Close=7]="Close"}(A||(A={}));class X{constructor(){this.observers=[]}next(e){for(const t of this.observers)t.next(e)}error(e){for(const t of this.observers)t.error&&t.error(e)}complete(){for(const e of this.observers)e.complete&&e.complete()}subscribe(e){return this.observers.push(e),new P(this,e)}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(D||(D={}));class Q{constructor(e,t,n,o){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(S.Warning,"The page is being frozen, this will likely lead to the connection being closed and messages being lost. For more information see the docs at https://docs.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},G.isRequired(e,"connection"),G.isRequired(t,"logger"),G.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=3e4,this.keepAliveIntervalInMilliseconds=15e3,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=o,this._handshakeProtocol=new Y,this.connection.onreceive=e=>this._processIncomingData(e),this.connection.onclose=e=>this._connectionClosed(e),this._callbacks={},this._methods={},this._closedCallbacks=[],this._reconnectingCallbacks=[],this._reconnectedCallbacks=[],this._invocationId=0,this._receivedHandshakeResponse=!1,this._connectionState=D.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:A.Ping})}static create(e,t,n,o){return new Q(e,t,n,o)}get state(){return this._connectionState}get connectionId(){return this.connection&&this.connection.connectionId||null}get baseUrl(){return this.connection.baseUrl||""}set baseUrl(e){if(this._connectionState!==D.Disconnected&&this._connectionState!==D.Reconnecting)throw new Error("The HubConnection must be in the Disconnected or Reconnecting state to change the url.");if(!e)throw new Error("The HubConnection url must be a valid url.");this.connection.baseUrl=e}start(){return this._startPromise=this._startWithStateTransitions(),this._startPromise}async _startWithStateTransitions(){if(this._connectionState!==D.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=D.Connecting,this._logger.log(S.Debug,"Starting HubConnection.");try{await this._startInternal(),E.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=D.Connected,this._connectionStarted=!0,this._logger.log(S.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=D.Disconnected,this._logger.log(S.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise(((e,t)=>{this._handshakeResolver=e,this._handshakeRejecter=t}));await this.connection.start(this._protocol.transferFormat);try{const t={protocol:this._protocol.name,version:this._protocol.version};if(this._logger.log(S.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(t)),this._logger.log(S.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(S.Debug,`Hub handshake failed with error '${e}' during start(). Stopping HubConnection.`),this._cleanupTimeout(),this._cleanupPingTimer(),await this.connection.stop(e),e}}async stop(){const e=this._startPromise;this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){return this._connectionState===D.Disconnected?(this._logger.log(S.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve()):this._connectionState===D.Disconnecting?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState=D.Disconnecting,this._logger.log(S.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(S.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new f("The connection was stopped before the hub handshake could complete."),this.connection.stop(e)))}stream(e,...t){const[n,o]=this._replaceStreamingParams(t),r=this._createStreamInvocation(e,t,o);let s;const i=new X;return i.cancelCallback=()=>{const e=this._createCancelInvocation(r.invocationId);return delete this._callbacks[r.invocationId],s.then((()=>this._sendWithProtocol(e)))},this._callbacks[r.invocationId]=(e,t)=>{t?i.error(t):e&&(e.type===A.Completion?e.error?i.error(new Error(e.error)):i.complete():i.next(e.item))},s=this._sendWithProtocol(r).catch((e=>{i.error(e),delete this._callbacks[r.invocationId]})),this._launchStreams(n,s),i}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,o]=this._replaceStreamingParams(t),r=this._sendWithProtocol(this._createInvocation(e,t,!0,o));return this._launchStreams(n,r),r}invoke(e,...t){const[n,o]=this._replaceStreamingParams(t),r=this._createInvocation(e,t,!1,o);return new Promise(((e,t)=>{this._callbacks[r.invocationId]=(n,o)=>{o?t(o):n&&(n.type===A.Completion?n.error?t(new Error(n.error)):e(n.result):t(new Error(`Unexpected message type: ${n.type}`)))};const o=this._sendWithProtocol(r).catch((e=>{t(e),delete this._callbacks[r.invocationId]}));this._launchStreams(n,o)}))}on(e,t){e&&t&&(e=e.toLowerCase(),this._methods[e]||(this._methods[e]=[]),-1===this._methods[e].indexOf(t)&&this._methods[e].push(t))}off(e,t){if(!e)return;e=e.toLowerCase();const n=this._methods[e];if(n)if(t){const o=n.indexOf(t);-1!==o&&(n.splice(o,1),0===n.length&&delete this._methods[e])}else delete this._methods[e]}onclose(e){e&&this._closedCallbacks.push(e)}onreconnecting(e){e&&this._reconnectingCallbacks.push(e)}onreconnected(e){e&&this._reconnectedCallbacks.push(e)}_processIncomingData(e){if(this._cleanupTimeout(),this._receivedHandshakeResponse||(e=this._processHandshakeResponse(e),this._receivedHandshakeResponse=!0),e){const t=this._protocol.parseMessages(e,this._logger);for(const e of t)switch(e.type){case A.Invocation:this._invokeClientMethod(e);break;case A.StreamItem:case A.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===A.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(S.Error,`Stream callback threw error: ${F(e)}`)}}break}case A.Ping:break;case A.Close:{this._logger.log(S.Information,"Close message received from server.");const t=e.error?new Error("Server returned an error on close: "+e.error):void 0;!0===e.allowReconnect?this.connection.stop(t):this._stopPromise=this._stopInternal(t);break}default:this._logger.log(S.Warning,`Invalid message type: ${e.type}.`)}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let t,n;try{[n,t]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(e){const t="Error parsing handshake response: "+e;this._logger.log(S.Error,t);const n=new Error(t);throw this._handshakeRejecter(n),n}if(t.error){const e="Server returned handshake error: "+t.error;this._logger.log(S.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(S.Debug,"Server handshake complete."),this._handshakeResolver(),n}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=(new Date).getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if(!(this.connection.features&&this.connection.features.inherentKeepAlive||(this._timeoutHandle=setTimeout((()=>this.serverTimeout()),this.serverTimeoutInMilliseconds),void 0!==this._pingServerHandle))){let e=this._nextKeepAlive-(new Date).getTime();e<0&&(e=0),this._pingServerHandle=setTimeout((async()=>{if(this._connectionState===D.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}}),e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const t=e.target.toLowerCase(),n=this._methods[t];if(!n)return this._logger.log(S.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null))));const o=n.slice(),r=!!e.invocationId;let s,i,a;for(const n of o)try{const o=s;s=await n.apply(this,e.arguments),r&&s&&o&&(this._logger.log(S.Error,`Multiple results provided for '${t}'. Sending error to server.`),a=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),i=void 0}catch(e){i=e,this._logger.log(S.Error,`A callback for the method '${t}' threw error '${e}'.`)}a?await this._sendWithProtocol(a):r?(i?a=this._createCompletionMessage(e.invocationId,`${i}`,null):void 0!==s?a=this._createCompletionMessage(e.invocationId,null,s):(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),a=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(a)):s&&this._logger.log(S.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(S.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new f("The underlying connection was closed before the hub handshake could complete."),this._handshakeResolver&&this._handshakeResolver(),this._cancelCallbacksWithError(e||new Error("Invocation canceled due to the underlying connection being closed.")),this._cleanupTimeout(),this._cleanupPingTimer(),this._connectionState===D.Disconnecting?this._completeClose(e):this._connectionState===D.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===D.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=D.Disconnected,this._connectionStarted=!1,E.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onclose callback called with error '${e}' threw error '${t}'.`)}}}async _reconnect(e){const t=Date.now();let n=0,o=void 0!==e?e:new Error("Attempting to reconnect due to a unknown error."),r=this._getNextRetryDelay(n++,0,o);if(null===r)return this._logger.log(S.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=D.Reconnecting,e?this._logger.log(S.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(S.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==D.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==r;){if(this._logger.log(S.Information,`Reconnect attempt number ${n} will start in ${r} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,r)})),this._reconnectDelayHandle=void 0,this._connectionState!==D.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=D.Connected,this._logger.log(S.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(S.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(S.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==D.Reconnecting)return this._logger.log(S.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===D.Disconnecting&&this._completeClose());o=e instanceof Error?e:new Error(e.toString()),r=this._getNextRetryDelay(n++,Date.now()-t,o)}}this._logger.log(S.Information,`Reconnect retries have been exhausted after ${Date.now()-t} ms and ${n} failed attempts. Connection disconnecting.`),this._completeClose()}_getNextRetryDelay(e,t,n){try{return this._reconnectPolicy.nextRetryDelayInMilliseconds({elapsedMilliseconds:t,previousRetryCount:e,retryReason:n})}catch(n){return this._logger.log(S.Error,`IRetryPolicy.nextRetryDelayInMilliseconds(${e}, ${t}) threw error '${n}'.`),null}}_cancelCallbacksWithError(e){const t=this._callbacks;this._callbacks={},Object.keys(t).forEach((n=>{const o=t[n];try{o(null,e)}catch(t){this._logger.log(S.Error,`Stream 'error' callback called with '${e}' threw error: ${F(t)}`)}}))}_cleanupPingTimer(){this._pingServerHandle&&(clearTimeout(this._pingServerHandle),this._pingServerHandle=void 0)}_cleanupTimeout(){this._timeoutHandle&&clearTimeout(this._timeoutHandle)}_createInvocation(e,t,n,o){if(n)return 0!==o.length?{arguments:t,streamIds:o,target:e,type:A.Invocation}:{arguments:t,target:e,type:A.Invocation};{const n=this._invocationId;return this._invocationId++,0!==o.length?{arguments:t,invocationId:n.toString(),streamIds:o,target:e,type:A.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:A.Invocation}}}_launchStreams(e,t){if(0!==e.length){t||(t=Promise.resolve());for(const n in e)e[n].subscribe({complete:()=>{t=t.then((()=>this._sendWithProtocol(this._createCompletionMessage(n))))},error:e=>{let o;o=e instanceof Error?e.message:e&&e.toString?e.toString():"Unknown error",t=t.then((()=>this._sendWithProtocol(this._createCompletionMessage(n,o))))},next:e=>{t=t.then((()=>this._sendWithProtocol(this._createStreamItemMessage(n,e))))}})}}_replaceStreamingParams(e){const t=[],n=[];for(let o=0;o<e.length;o++){const r=e[o];if(this._isObservable(r)){const s=this._invocationId;this._invocationId++,t[s]=r,n.push(s.toString()),e.splice(o,1)}}return[t,n]}_isObservable(e){return e&&e.subscribe&&"function"==typeof e.subscribe}_createStreamInvocation(e,t,n){const o=this._invocationId;return this._invocationId++,0!==n.length?{arguments:t,invocationId:o.toString(),streamIds:n,target:e,type:A.StreamInvocation}:{arguments:t,invocationId:o.toString(),target:e,type:A.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:A.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:A.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:A.Completion}:{invocationId:e,result:n,type:A.Completion}}}class Z{constructor(){this.name="json",this.version=1,this.transferFormat=C.Text}parseMessages(e,t){if("string"!=typeof e)throw new Error("Invalid input for JSON hub protocol. Expected a string.");if(!e)return[];null===t&&(t=b.instance);const n=J.parse(e),o=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case A.Invocation:this._isInvocationMessage(n);break;case A.StreamItem:this._isStreamItemMessage(n);break;case A.Completion:this._isCompletionMessage(n);break;case A.Ping:case A.Close:break;default:t.log(S.Information,"Unknown message type '"+n.type+"' ignored.");continue}o.push(n)}return o}writeMessage(e){return J.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),void 0!==e.invocationId&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),void 0===e.item)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const ee={trace:S.Trace,debug:S.Debug,info:S.Information,information:S.Information,warn:S.Warning,warning:S.Warning,error:S.Error,critical:S.Critical,none:S.None};class te{configureLogging(e){if(G.isRequired(e,"logging"),void 0!==e.log)this.logger=e;else if("string"==typeof e){const t=function(e){const t=ee[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new k(t)}else this.logger=new k(e);return this}withUrl(e,t){return G.isRequired(e,"url"),G.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return G.isRequired(e,"protocol"),this.protocol=e,this}withAutomaticReconnect(e){if(this.reconnectPolicy)throw new Error("A reconnectPolicy has already been set.");return e?Array.isArray(e)?this.reconnectPolicy=new a(e):this.reconnectPolicy=e:this.reconnectPolicy=new a,this}build(){const e=this.httpConnectionOptions||{};if(void 0===e.logger&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const t=new K(this.url,e);return Q.create(t,this.logger||b.instance,this.protocol||new Z,this.reconnectPolicy)}}class ne{static GenerateUUID(){var e=(new Date).getTime(),t="undefined"!=typeof performance&&performance.now&&1e3*performance.now()||0;return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(n){var o=16*Math.random();return e>0?(o=(e+o)%16|0,e=Math.floor(e/16)):(o=(t+o)%16|0,t=Math.floor(t/16)),("x"===n?o:3&o|8).toString(16)}))}}class oe{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}class re{constructor(){this.TransactionId=ne.GenerateUUID()}}var se,ie,ae,ce,le,ue,de,he,ge,fe,pe,ve,ye,we;(ve=se||(se={}))[ve.OK=0]="OK",ve[ve.UnknownError=1]="UnknownError",ve[ve.FatalError=2]="FatalError",ve[ve.WrongData=3]="WrongData",ve[ve.ResourceDoesNotExists=4]="ResourceDoesNotExists",ve[ve.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",ve[ve.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",ve[ve.OperationNotPermitted=7]="OperationNotPermitted",ve[ve.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",ve[ve.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",ve[ve.Error=10]="Error",ve[ve.NoData=11]="NoData",ve[ve.NotSupportedMethod=12]="NotSupportedMethod",ve[ve.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",ve[ve.MultiDataResponseStart=14]="MultiDataResponseStart",ve[ve.MultiDataResponse=15]="MultiDataResponse",ve[ve.MultiDataResponseStop=16]="MultiDataResponseStop",function(e){e[e.Get=0]="Get",e[e.Post=1]="Post",e[e.Delete=2]="Delete",e[e.Put=3]="Put",e[e.Options=4]="Options",e[e.Head=5]="Head"}(ie||(ie={}));class me{constructor(e,t){this.serialNumber=e,this.pin=t,this.SerialNumber=e,this.PIN=t}}!function(e){e[e.ByCloud=0]="ByCloud",e[e.LocalNetwork=1]="LocalNetwork",e[e.P2P=2]="P2P"}(ae||(ae={})),function(e){e[e.FailedToConnect=0]="FailedToConnect",e[e.AuthorizationFailed=1]="AuthorizationFailed",e[e.FailedToConnectToServer=2]="FailedToConnectToServer",e[e.Connected=3]="Connected",e[e.ControllerIsNotConnected=4]="ControllerIsNotConnected"}(ce||(ce={})),function(e){e[e.Disconnected=0]="Disconnected",e[e.Connecting=1]="Connecting",e[e.Connected=3]="Connected",e[e.Disconnecting=4]="Disconnecting",e[e.Failed=5]="Failed",e[e.Reconnecting=6]="Reconnecting"}(le||(le={}));class Se{constructor(){this._log=Uh.Get(o.ServiceName),this.handlers=[]}Subscribe(e){this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(){this.handlers.slice(0).forEach((e=>{try{e()}catch(e){this._log.Error(e)}}))}}(we=ue||(ue={}))[we.Any=0]="Any",we[we.Guest=10]="Guest",we[we.Standard=20]="Standard",we[we.Admin=30]="Admin",we[we.Installator=40]="Installator",we[we.Support=50]="Support",(ye=de||(de={}))[ye.Unknown=0]="Unknown",ye[ye.Men=1]="Men",ye[ye.Woman=2]="Woman",ye[ye.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(he||(he={})),function(e){e[e.Unknown=0]="Unknown",e[e.WrongAuthData=1]="WrongAuthData",e[e.NoResponseFromController=2]="NoResponseFromController"}(ge||(ge={}));class _e{constructor(e,t){this._type=fe.Unknown,this._data="",this._type=e,this._data=t}get Type(){return this._type}set Type(e){this._type=e}get Data(){return this._data}set Data(e){this._data=e}}class Ce{constructor(e,t){this._type=null,this._data="",this._type=e,this._data=t}get Type(){return this._type}set Type(e){this._type=e}get Data(){return this._data}set Data(e){this._data=e}}!function(e){e[e.UnknownError=-5]="UnknownError",e[e.NoPermissions=-4]="NoPermissions",e[e.WrongData=-3]="WrongData",e[e.ControllerResponseTimeout=-2]="ControllerResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Changed=1]="Changed"}(fe||(fe={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(pe||(pe={}));class Ae{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=pe.Device,this._dateTime=""}get Guid(){return this._guid}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}get Base64Image(){return this._base64Image}get ImageType(){return this._imageType}get DateTime(){return this._dateTime}set Base64Image(e){this._base64Image=e}set Guid(e){this._guid=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}set ImageType(e){this._imageType=e}}var De=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class be{constructor(){this._imageExistsCaseNumber=0,this._connection=Uh.Get(Vt.ServiceName),this._logger=Uh.Get(o.ServiceName)}GetServiceName(){return be.ServiceName}AddPictureAsync(e){var t,n;return De(this,void 0,void 0,(function*(){try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),se.WrongData;let o=new Image;const r=new Promise(((t,n)=>{o.src=e.Base64Image,o.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield r))return this._logger.Error(be.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),se.WrongData;if(0===o.height||0===o.width)return this._logger.Error(be.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),se.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(be.ServiceName,"Cannot add picture - Guid must be empty."),se.WrongData;const s=new Ee;s.Guid=ne.GenerateUUID(),s.DateTime=(new Date).toISOString(),s.ImageType=e.ImageType,s.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`,s.Base64Image=e.Base64Image;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Te(s.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),se.UnknownError;if(i.Status==se.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new ke(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),se.UnknownError):e.Status}return i.Status==se.OK?(this._logger.Warning(be.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):se.UnknownError):(this._logger.Error(be.ServiceName,"Cannot add picture - cannot get current picture status."),se.Error)}catch(e){return this._logger.Error(be.ServiceName,`Cannot add picture! ${e}`),se.FatalError}}))}EditPictureAsync(e){var t,n;return De(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot edit picture - guid is empty."),se.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),se.WrongData;let o=new Image;const r=new Promise(((t,n)=>{o.src=e.Base64Image,o.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield r))return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),se.WrongData;if(0===o.height||0===o.width)return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),se.WrongData;const s=new Ee;s.DateTime=(new Date).toISOString(),s.ImageType=e.ImageType,s.Base64Image=e.Base64Image,s.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?s.OwnerGuid=e.OwnerGuid:s.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Te(s.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),se.UnknownError;if(i.Status==se.ResourceDoesNotExists)return this._logger.Error(be.ServiceName,"Cannot edit picture - picture not exists."),se.OperationNotPermitted;if(i.Status==se.OK){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new ke(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),se.UnknownError):e.Status}return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot get current picture status."),se.Error}catch(e){return this._logger.Error(be.ServiceName,`Cannot edit picture! ${e}`),se.FatalError}}))}DeletePictureAsync(e){var t;return De(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot delete picture - guid is empty."),se.WrongData;const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(e.Guid),8e3,!1);return null==n||null==n.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),se.UnknownError):n.Status}catch(e){return this._logger.Error(be.ServiceName,`Cannot delete picture! ${e}`),se.FatalError}}))}GetPicturesInfoAsync(){var e;return De(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ne,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures info - unknown error!"),new Ce(se.UnknownError,"NoDataInResult")):t.Status!=se.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Ce(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Ce(se.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ie;return t.DateTime=e.DateTime,t.Guid=e.Guid,t.OwnerGuid=e.OwnerGuid,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture info! ${e}`),new Ce(se.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){var t;return De(this,void 0,void 0,(function*(){try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Te(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(be.ServiceName,"Cannot get picture - unknown error!"),new Ce(se.UnknownError,"NoDataInResult");switch(n.Status){case se.ResourceDoesNotExists:return new Ce(se.ResourceDoesNotExists,"PictureNotFound");case se.OK:if(null==n.Data)return new Ce(se.Error,"RespondedWithOKButNoData");const e=new Ge;return e.Base64Image=n.Data.Base64Image,e.DateTime=n.Data.DateTime,e.ImageType=n.Data.ImageType,e.Guid=n.Data.Guid,-1!=n.Data.OwnerGuid.indexOf("_")?(e.OwnerGuid=n.Data.OwnerGuid.substring(0,n.Data.OwnerGuid.indexOf("_")),e.OwnerIdentity=n.Data.OwnerGuid.substring(n.Data.OwnerGuid.indexOf("_")+1)):n.Data.Guid.includes("profilePicture")?(e.OwnerIdentity=n.Data.Guid.substring(n.Data.Guid.indexOf("_")+1),e.OwnerGuid=n.Data.OwnerGuid):n.Data.Guid.includes("devices_group")?(e.OwnerIdentity=n.Data.Guid.substring(0,n.Data.Guid.lastIndexOf("_")),e.OwnerGuid=n.Data.OwnerGuid):(e.OwnerGuid=n.Data.OwnerGuid,e.OwnerIdentity=""),e;default:return new Ce(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture! ${e}`),new Ce(se.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){var e;return De(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Pe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures - unknown error!"),new Ce(se.UnknownError,"NoDataInResult")):t.Status!=se.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Ce(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Ce(se.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ge;return t.Base64Image=e.Base64Image,t.DateTime=e.DateTime,t.Guid=e.Guid,t.ImageType=e.ImageType,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get pictures! ${e}`),new Ce(se.FatalError,"ExceptionOccurred")}}))}}be.ServiceName="PictureService";class Ge extends Ae{set DateTime(e){this._dateTime=e}}class Ee{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=pe.Device,this.DateTime=""}}class Ie{constructor(){this._guid="",this._dateTime="",this._ownerGuid="",this._ownerIdentity=""}get Guid(){return this._guid}get DateTime(){return this._dateTime}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}set Guid(e){this._guid=e}set DateTime(e){this._dateTime=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}}class Te extends re{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ie.Get,this.Data=e}}class Ne extends re{constructor(){super(),this.Resource="/pictures/info",this.Method=ie.Get}}class Pe extends re{constructor(){super(),this.Resource="/pictures/list",this.Method=ie.Get}}class ke extends re{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ie.Put,this.Data=e}}class Re extends re{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ie.Delete,this.Data=e}}var Oe=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class xe{constructor(){this._connection=null,this._connection=Uh.Get(Vt.ServiceName),this._pictureService=Uh.Get(be.ServiceName),this._sessionService=Uh.Get(He.ServiceName)}CanEditUser(e){const t=this._sessionService.User;return e.Guid===(null==t?void 0:t.Guid)||this.CanEditUsersOfAccessLevel(e.AccessLevel)}CanEditUsersOfAccessLevel(e){var t;const n=null===(t=this._sessionService.User)||void 0===t?void 0:t.AccessLevel;if(void 0===n)return!1;switch(e){case ue.Support:return n===ue.Support;case ue.Installator:return n>=ue.Installator;case ue.Admin:return n>=ue.Admin;default:return e>=ue.Admin}}GetServiceName(){return xe.ServiceName}GetUsersAsync(){var e,t;return Oe(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new $e,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==se.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new We;n.AccessLevel=t.AccessLevel,n.Email=t.Email,n.Gender=t.Gender,n.Guid=t.Guid,n.IsAccountOnline=t.IsAccountOnline,n.Name=t.Name,n.IsActive=t.IsActive,n.IsBanned=t.IsBanned,n.Phone=t.Phone,n.Surname=t.Surname,e.push(n)})),e}return Promise.resolve([])}if((null==n?void 0:n.Status)==se.NoData)return Promise.resolve([]);throw null===(t=r.Log)||void 0===t||t.Debug(xe.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){var t,n;return Oe(this,void 0,void 0,(function*(){if(""===e)return Promise.resolve(null);null==e&&(e="");const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ue(e),2e4,!1);if(null==o||null==o.Data)return Promise.resolve(null);if(o.Status!=se.OK)return null===(n=r.Log)||void 0===n||n.Debug(xe.ServiceName,`Failed to retrieve user, error: ${o.Status}`),Promise.resolve(null);const s=new We;return s.AccessLevel=o.Data.AccessLevel,s.Email=o.Data.Email,s.Gender=o.Data.Gender,s.Guid=o.Data.Guid,s.IsAccountOnline=o.Data.IsAccountOnline,s.Name=o.Data.Name,s.IsActive=o.Data.IsActive,s.IsBanned=o.Data.IsBanned,s.Phone=o.Data.Phone,s.Surname=o.Data.Surname,s}))}CreateUserAsync(e,t){var n;return Oe(this,void 0,void 0,(function*(){if(null!=e.Guid&&""!=e.Guid)return new Ce(se.WrongData,"GuidMustBeEmpty");const o=new Fe;o.Name=e.Name.trim(),o.Surname=e.Surname.trim(),o.Email=e.Email.trim(),o.Password=t.trim(),o.Phone=e.Phone.trim(),o.Gender=e.Gender,o.AccessLevel=e.AccessLevel;const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Me(o),2e4,!1);return null==r||null==r.Status?new Ce(se.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Ce(r.Status,r.Data))}))}UpdateUserAsync(e){var t;return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");const n=new Fe;n.Guid=e.Guid,n.Name=e.Name.trim(),n.Surname=e.Surname.trim(),n.Email=e.Email.trim(),n.Phone=e.Phone.trim(),n.Gender=e.Gender,n.AccessLevel=e.AccessLevel;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Me(n),2e4,!1);return null==o||null==o.Status?new Ce(se.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Ce(o.Status,o.Data))}))}ChangePasswordAsync(e,t){var n;return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");const o=yield this.GetUserAsync(e.Guid);if(null==o)return new Ce(se.ResourceIsNotAvailable,"CannotGetUser");const r=new Fe;r.Guid=e.Guid,r.Password=t,r.AccessLevel=o.AccessLevel,r.Email=o.Email;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Me(r),2e4,!1);return null==s||null==s.Status?new Ce(se.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Ce(s.Status,s.Data))}))}DeleteUserAsync(e){var t,n;return Oe(this,void 0,void 0,(function*(){if(""===e)return se.WrongData;null==e&&(e="");const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e),2e4,!1);return null==o||null==o.Status?se.FatalError:(o.Status!=se.OK&&(null===(n=r.Log)||void 0===n||n.Debug(xe.ServiceName,`Failed to delete user, error: ${o.Status}`)),o.Status)}))}GetUserProfilePictureAsync(e){return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");const t=yield this._pictureService.GetPicturesInfoAsync();if(null!=t.Type)return t;const n=t.find((t=>"profilePicture"==t.OwnerIdentity&&t.OwnerGuid==e.Guid));if(null!=n){const e=yield this._pictureService.GetPictureAsync(n.Guid);return null!=e.Type?t:e}return new Ce(se.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");let n=new Ae;n.ImageType=pe.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const o=yield this.GetUserProfilePictureAsync(e);if(o.Type==se.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===se.OK?new Ce(se.OK,"PictureSet"):new Ce(e,"PictureServiceError")}if(null!=o.Type)return new Ce(se.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=o.Guid,n.OwnerGuid=o.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===se.OK?new Ce(se.OK,"PictureSet"):new Ce(e,"PictureServiceError")}}))}}xe.ServiceName="UsersService";class Ue extends re{constructor(e){super(),this.Resource="/users/user",this.Method=ie.Get,this.Data=e}}class Fe{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=de.Unknown,this.AccessLevel=ue.Any}}class Me extends re{constructor(e){super(),this.Resource="/users/user",this.Method=ie.Put,this.Data=e}}class $e extends re{constructor(){super(),this.Resource="/users/list",this.Method=ie.Get}}class Le extends re{constructor(e){super(),this.Resource="/users/user",this.Method=ie.Delete,this.Data=e}}class We{constructor(){this._guid="",this._cloudGuid="",this._name="",this._surname="",this._phone="",this._email="",this._isAccountOnline=!0,this._isAccountActive=!0,this._isAccountBanned=!0,this._notificationChannels=[],this._gender=de.Unknown,this._accessLevel=ue.Any,this._localization=he.En_Us}get Guid(){return this._guid}set Guid(e){this._guid=e}get CloudGuid(){return this._cloudGuid}set CloudGuid(e){this._cloudGuid=e}get Name(){return this._name}set Name(e){this._name=e}get Surname(){return this._surname}set Surname(e){this._surname=e}get Phone(){return this._phone}set Phone(e){this._phone=e}get AccessLevel(){return this._accessLevel}set AccessLevel(e){this._accessLevel=e}get Email(){return this._email}set Email(e){this._email=e}get IsAccountOnline(){return this._isAccountOnline}set IsAccountOnline(e){this._isAccountOnline=e}get IsActive(){return this._isAccountActive}set IsActive(e){this._isAccountActive=e}get IsBanned(){return this._isAccountBanned}set IsBanned(e){this._isAccountBanned=e}get NotificationChannels(){return this._notificationChannels}set NotificationChannels(e){this._notificationChannels=e}get Gender(){return this._gender}set Gender(e){this._gender=e}get Localization(){return this._localization}set Localization(e){this._localization=e}GetUserProfilePictureAsync(){return Uh.Get(xe.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return Uh.Get(xe.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var Be=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class He{constructor(){this._onUserLoggedInEvent=new n,this._onUserLoggedOutEvent=new n,this._email="",this._password="",this._loginTaskCompletionSource=this.CreateSessionCompletionSourceAsync(),this._alreadySubsribedToNetworkEvents=!1,this._user=null}CreateSessionCompletionSourceAsync(){var e;return Be(this,void 0,void 0,(function*(){null===(e=r.Log)||void 0===e||e.Debug(He.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{let t=n=>{var o;null===(o=r.Log)||void 0===o||o.Debug(He.ServiceName,`Logged in as ${n.Name}, completing CreateSessionCompletionSourceAsync()`),e(),this.OnUserLoggedInEvent().Unsubscribe(t)};this.OnUserLoggedInEvent().Subscribe(t)}))}))}Subscribe(e){}RestoreSessionAsync(){var e;return Be(this,void 0,void 0,(function*(){null===(e=r.Log)||void 0===e||e.Debug(He.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0!==this._user&&null!==this._user&&(yield this.UserLogInAsync(this._email,this._password))}))}WaitForSessionCreationAsync(){return Be(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){var e,t;return Be(this,void 0,void 0,(function*(){var n=new re;n.Resource="/users/user/logout",n.Method=ie.Put,this._email="",this._password="",(yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==se.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=r.Log)||void 0===e||e.Debug(He.ServiceName,"User has been logged out.")):null===(t=r.Log)||void 0===t||t.Debug(He.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return Be(this,void 0,void 0,(function*(){switch(e){case le.Disconnected:case le.Failed:break;case le.Connected:Uh.Get(He.ServiceName).RestoreSessionAsync()}}))}UserLogInAsync(e,t){var n,o;return Be(this,void 0,void 0,(function*(){var s=Uh.Get(Vt.ServiceName);const i=yield s.SendAndWaitForResponseAsync(new je(e,t),2e4,!1);if(i.Status==se.OK&&null!=i.Data){this._email=e,this._password=t;var a=new We;return this._user=a,a.AccessLevel=i.Data.AccessLevel,a.Email=i.Data.Email,a.Gender=i.Data.Gender,a.Guid=i.Data.Guid,a.IsAccountOnline=i.Data.IsAccountOnline,a.Name=i.Data.Name,a.IsActive=i.Data.IsActive,a.IsBanned=i.Data.IsBanned,a.Phone=i.Data.Phone,a.Surname=i.Data.Surname,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,s.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(n=r.Log)||void 0===n||n.Debug(He.ServiceName,`Did logging in succeded?: ${i.Status==se.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return null===(o=r.Log)||void 0===o||o.Debug(He.ServiceName,`User login response: ${i.Data}`),ge.WrongAuthData}))}GetServiceName(){return He.ServiceName}}He.ServiceName="SessionService";class Ve{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class je extends re{constructor(e,t){super(),this.Data=new Ve(e,t),this.Resource="/users/user/login",this.Method=ie.Put}}class Ke{constructor(){this._log=Uh.Get(o.ServiceName),Ke._localStorageService=Uh.Get(s.ServiceName)}GetServiceName(){return Ke.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===se.OK&&(this._log.Debug(Ke.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Ke._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Ke._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Ke.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Ke._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Ke.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Ke._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Ke.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Ke._localStorageService=null,Ke.ServiceName="WebApiCacheService";var ze=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class qe{constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new Se,this._onExitedConfigurationEvent=new Se,this._onConfigurationTimeCheckedEvent=new n,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{Uh.Get(He.ServiceName).OnUserLoggedInEvent().Subscribe((t=>ze(this,void 0,void 0,(function*(){this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),e()}))))})),this._connection=Uh.Get(Vt.ServiceName),this._session=Uh.Get(He.ServiceName),this._localStorage=Uh.Get(s.ServiceName),this._connection.OnDataReceivedEvent().Subscribe((e=>{"/info/configuration/mode/entry"==e.Resource?this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke():"/info/configuration/mode/exit"==e.Resource&&(this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke())}))}GetServiceName(){return qe.ServiceName}FactoryResetAsync(e){var t,n;return ze(this,void 0,void 0,(function*(){try{return null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ye,2e3,!1))||void 0===n?void 0:n.Status}catch(e){}let o=0,r=setInterval((()=>{o+=.3333333333333333,e(o)}),1e3);return yield oe.Delay(3e5),clearInterval(r),se.OK}))}RollbackLastUpdateAsync(e){var t,n;return ze(this,void 0,void 0,(function*(){try{return null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Xe,2e3,!1))||void 0===n?void 0:n.Status}catch(e){}let o=0,r=setInterval((()=>{o+=.23809523809523808,e(o)}),1e3);return yield oe.Delay(42e4),clearInterval(r),se.OK}))}RestartControllerAsync(e){var t,n;return ze(this,void 0,void 0,(function*(){try{return null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Je,2e3,!1))||void 0===n?void 0:n.Status}catch(e){}let o=0,r=setInterval((()=>{o+=.4166666666666667,e(o)}),1e3);return yield oe.Delay(24e4),clearInterval(r),se.OK}))}DidCofigurationChangeAsync(){return ze(this,void 0,void 0,(function*(){return yield this._synchronizationTaskCompletionSource,Promise.resolve(this._didConfigurationChange)}))}GetLastKnownConfigurationChangeTime(){var e;const t=null===(e=this._localStorage)||void 0===e?void 0:e.Read(this.GetServiceName(),"last_configuration_time");return null!=t?new Date(t):new Date}SaveLastConfigurationChangeTime(e){var t;null===(t=this._localStorage)||void 0===t||t.Save(this.GetServiceName(),"last_configuration_time",e.toString())}EnterConfigurationModeAsync(){var e;return ze(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Qe,2e4,!1)}))}ExitConfigurationModeAsync(){var e;return ze(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ze,2e4,!1),Uh.Get(Ke.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){var e;return ze(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new et,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=se.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return ze(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),!0)}))}}qe.ServiceName="ControllerConfigurationService";class Je extends re{constructor(){super(),this.Resource="/controller/restart",this.Method=ie.Post}}class Ye extends re{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ie.Post}}class Xe extends re{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ie.Post}}class Qe extends re{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ie.Put}}class Ze extends re{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ie.Put}}class et extends re{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ie.Get}}var tt,nt,ot,rt,st,it,at,ct,lt,ut,dt,ht,gt,ft,pt,vt,yt,wt,mt,St,_t,Ct,At,Dt,bt,Gt,Et,It,Tt,Nt,Pt,kt,Rt,Ot,xt,Ut,Ft,Mt,$t,Lt,Wt,Bt,Ht=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Vt{constructor(){this._logPackets=!1,this._pingInterval=5e3,this._disconnectedOnPurpose=!1,this._defaultPacketsBrokerAddress="br1.tr7.pl",this._serversBrokerAddress="https://broker.tr7.pl",this._address="br1.tr7.pl",this._isEstabilished=!1,this._timeout=1e4,this._dataReceivedEvent=new n,this._pongReceivedEvent=new Se,this._authorizationReceivedEvent=new n,this._registrationReceivedEvent=new n,this._connectionStateChangedEvent=new n,this._errorOccuredEvent=new n,this._log=Uh.Get(o.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._packetsBrokerServers=["br1.tr7.pl","br1.exala.pl"],this._lastReceivedPacketTime=Date.now()}GetServiceName(){return Vt.ServiceName}EnablePacketsLogging(){this._logPackets=!0}DisablePacketsLogging(){this._logPackets=!1}InitializeConnection(){if(this._controllerConfiguration=Uh.Get(qe.ServiceName),this._cache=Uh.Get(Ke.ServiceName),this._session=Uh.Get(He.ServiceName),this._connection){try{this._connection.stop()}catch(e){}this._connection=void 0}if(!this._address)throw new Error("Domain is not set");if(!this._serialId)throw new Error("SerialId is not set");if(!this._PIN)throw new Error("PIN is not set");this._connection=(new te).withUrl(`https://${this._address}/broker`).build(),this._dataReceivedEvent.Subscribe((e=>{this._lastReceivedPacketTime=Date.now()})),setInterval((()=>Ht(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval)}GetAuthorizationInfo(){return null!=this._serialId&&null!=this._PIN?new me(this._serialId,this._PIN):null}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._defaultPacketsBrokerAddress=e,this._address=e}GetServerAddressAsync(){return Ht(this,void 0,void 0,(function*(){try{let e=yield fetch(`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`);if(e.ok){let t=yield e.text();return t?(this._log.Debug(Vt.ServiceName,`Got server address: ${t}`),t):(this._log.Error(Vt.ServiceName,`Failed to get server address, status: ${e.status}`),null)}return this._log.Error(Vt.ServiceName,`Failed to get server address, status: ${e.status}`),null}catch(e){return this._log.Error(Vt.ServiceName,e),null}}))}ConnectAsync(e){return Ht(this,void 0,void 0,(function*(){return this._address=e,yield this.connectAsync()}))}AuthorizeAsync(e){return new Promise(((t,n)=>Ht(this,void 0,void 0,(function*(){var n;let o=0,r=e=>{window.clearTimeout(o),this._authorizationReceivedEvent.Unsubscribe(r),this._log.Debug(Vt.ServiceName,`Got authorization result: ${e}`),t(e)};o=window.setTimeout((()=>{window.clearTimeout(o),this._authorizationReceivedEvent.Unsubscribe(r),t(!1)}),2e3),this._log.Debug(Vt.ServiceName,`Authorizing to cloud using: ${e.SerialNumber} PIN: ${e.PIN}`),this._authorizationReceivedEvent.Subscribe(r),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)}))))}ConnectAndAuthorizeAsync(e){return Ht(this,void 0,void 0,(function*(){Uh.WorksInContextOf=e.SerialNumber,this._serialId=e.SerialNumber,this._PIN=e.PIN;var t=yield this.GetServerAddressAsync();if(t&&null!=t){this._log.Debug(Vt.ServiceName,`Got packets broker address: ${t}`),this.SetDefaultPacketsBrokerAddress(t);let n=yield this.connectAsync();return n!=ce.Connected?n:(yield this.AuthorizeAsync(e))?ce.Connected:ce.AuthorizationFailed}{let t=ce.ControllerIsNotConnected;this._log.Warning(Vt.ServiceName,"Server did not return packets broker address, trying to connect to known brokers.");for(let n of this._packetsBrokerServers){this._log.Warning(Vt.ServiceName,`Testing connection to ${n}`),this.SetDefaultPacketsBrokerAddress(n);try{yield this.DisconnectAsync()}catch(e){}this._log.Warning(Vt.ServiceName,`Connecting to server: ${n}`);let o=yield this.connectAsync();if(this._log.Warning(Vt.ServiceName,`Connection result: ${o}`),o==ce.Connected){if(yield this.AuthorizeAsync(e))return t=ce.Connected,t;this._log.Warning(Vt.ServiceName,`Failed to authorize in ${n}`)}}return t}}))}connectAsync(){var e,t,n,o,r,s,i,a,c;return Ht(this,void 0,void 0,(function*(){if(ce.FailedToConnect,!this._address)return Promise.resolve(ce.ControllerIsNotConnected);this._disconnectedOnPurpose&&(this._disconnectedOnPurpose=!1),this._connectionStateChangedEvent,this.InitializeConnection(),null===(e=this._connection)||void 0===e||e.onclose((()=>Ht(this,void 0,void 0,(function*(){var e,t;if(this._log.Error(Vt.ServiceName,"Connection closed"),Uh.Get(He.ServiceName).CreateSessionCompletionSourceAsync(),this.FireConnectionStateChanged(),(null===(e=this._connection)||void 0===e?void 0:e.state)===D.Disconnected&&!this._disconnectedOnPurpose)return yield null===(t=this._connection)||void 0===t?void 0:t.start(),null!=this._connection?(yield this.AuthorizeAsync(new me(this._serialId,this._PIN)),this._log.Info(Vt.ServiceName,"Reconnected from onClose"),this.FireConnectionStateChanged()):ce.FailedToConnect})))),null===(t=this._connection)||void 0===t||t.onreconnected((()=>Ht(this,void 0,void 0,(function*(){return yield this.AuthorizeAsync(new me(this._serialId,this._PIN)),this._log.Info(Vt.ServiceName,"Reconnected from onreconnected"),this.FireConnectionStateChanged()})))),null===(n=this._connection)||void 0===n||n.onreconnecting((()=>(this._log.Warning(Vt.ServiceName,"Reconnecting..."),this.FireConnectionStateChanged()))),yield null===(o=this._connection)||void 0===o?void 0:o.start(),null===(r=this._connection)||void 0===r||r.on("Pong",(()=>{this._log.Debug(Vt.ServiceName,"Pong received <-"),this._pongReceivedEvent.Invoke()})),null===(s=this._connection)||void 0===s||s.on("Registration",(e=>{var t;null===(t=this._registrationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(i=this._connection)||void 0===i||i.on("Authorization",(e=>{var t;null===(t=this._authorizationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(a=this._connection)||void 0===a||a.on("SendError",((e,t)=>Ht(this,void 0,void 0,(function*(){e.startsWith("NotAuthorized:")?(this._log.Error(Vt.ServiceName,"Failed to authorize!"),yield this.AuthorizeAsync(new me(this._serialId,this._PIN))):(this._log.Error(Vt.ServiceName,`Server returned error: ${e} ${t}`),this._errorOccuredEvent.Invoke([e,t]))}))));let l=this._dataReceivedEvent;return null===(c=this._connection)||void 0===c||c.on("Data",((e,t)=>{const n=JSON.parse(t);this._logPackets&&this._log.Debug(Vt.ServiceName,`Received data:\n${JSON.stringify(n,null,2)}`),l.Invoke(n)})),null!=this._connection?this.FireConnectionStateChanged():ce.FailedToConnect}))}FireConnectionStateChanged(){var e;const t=this._connectionStateChangedEvent;switch(null===(e=this._connection)||void 0===e?void 0:e.state){case D.Connected:return t.Invoke(le.Connected),ce.Connected;case D.Connecting:return t.Invoke(le.Connecting),ce.Connected;case D.Disconnected:return t.Invoke(le.Disconnected),ce.FailedToConnect;case D.Disconnecting:return t.Invoke(le.Disconnecting),ce.FailedToConnect;case D.Reconnecting:return t.Invoke(le.Reconnecting),ce.FailedToConnect}return ce.FailedToConnect}DisconnectAsync(){var e;return Ht(this,void 0,void 0,(function*(){this._disconnectedOnPurpose=!0,yield null===(e=this._connection)||void 0===e?void 0:e.stop()}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===D.Connected}SendAndWaitForResponseAsync(e,t,n,o=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,o)}SendAndWaitForResponseWithRepeatAsync(e,t,n,o=!0,r=!0){var s,i,a;return Ht(this,void 0,void 0,(function*(){if(e.Method===ie.Get&&n&&!(yield null===(s=this._controllerConfiguration)||void 0===s?void 0:s.DidCofigurationChangeAsync())){let t=null===(i=this._cache)||void 0===i?void 0:i.GetCache(e);if(null!==t)return Promise.resolve(t)}let c=0;const l=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(a=this._session)||void 0===a?void 0:a.WaitForSessionCreationAsync()),new Promise(((s,i)=>Ht(this,void 0,void 0,(function*(){let a=i=>Ht(this,void 0,void 0,(function*(){var u,d,h,g;if((null==i?void 0:i.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const f=Date.now()-l;r&&this._log.Debug(Vt.ServiceName,`Received response for: ${null==i?void 0:i.Resource} ${null==i?void 0:i.Method} id: ${null==i?void 0:i.TransactionId} in ${f}ms`),e.Method===ie.Get&&n&&(null===(u=this._cache)||void 0===u||u.Cache(i)),!n&&(null==i?void 0:i.Status)===se.UserIsNotLoggedIn&&o&&((null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(g=this._session)||void 0===g?void 0:g.RestoreSessionAsync(),s(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,r))),s(i)}}));if(this._dataReceivedEvent.Subscribe(a),c=window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(a);let t=`Response timeout, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;this._log.Error(Vt.ServiceName,t),i(new g(t))}),t),!(yield this.SendAsync(e,r))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;i(new Error(t))}}))))}))}SendAndHandleResponseAsync(e,t,n,o=!0){var r;return Ht(this,void 0,void 0,(function*(){let s=0;const i=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(r=this._session)||void 0===r?void 0:r.WaitForSessionCreationAsync()),new Promise(((r,a)=>Ht(this,void 0,void 0,(function*(){const c=()=>window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(l);let t=`Response timeout, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;this._log.Error(Vt.ServiceName,t),a(new g(t))}),t);let l=u=>Ht(this,void 0,void 0,(function*(){var d,h,g;if((null==u?void 0:u.TransactionId)==e.TransactionId){window.clearTimeout(s);const f=Date.now()-i;switch(o&&this._log.Debug(Vt.ServiceName,`Received response for: ${null==u?void 0:u.Resource} ${null==u?void 0:u.Method} id: ${null==u?void 0:u.TransactionId} in ${f}ms`),(null==u?void 0:u.Status)===se.UserIsNotLoggedIn&&(this._dataReceivedEvent.Unsubscribe(l),(null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(g=this._session)||void 0===g?void 0:g.RestoreSessionAsync(),r(yield this.SendAndHandleResponseAsync(e,t,n,o))),null==u?void 0:u.Status){case se.MultiDataResponseStart:case se.MultiDataResponse:n(u),s=c();break;case se.MultiDataResponseStop:n(u),this._dataReceivedEvent.Unsubscribe(l),r();break;default:let t=`Failed to process MultiDataResponse - recived incorrect response status: ${null==u?void 0:u.Status} method: ${e.Method} transaction id: ${e.TransactionId}\n make sure that the requested endpoint uses MultiDataResponse, otherwise use SendAndWaitForResponseAsync<T> method.`;a(new Error(t))}}}));if(this._dataReceivedEvent.Subscribe(l),s=c(),!(yield this.SendAsync(e,o))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;a(new Error(t))}}))))}))}PingControllerAsync(){var e;return Ht(this,void 0,void 0,(function*(){if((null===(e=this._connection)||void 0===e?void 0:e.state)!==D.Connected)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new re;return t.Resource="/system/ping",t.Method=ie.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SendAsync(e,t=!1){if(!this.IsConnected())throw new Error("Connection is not established");return new Promise((n=>{var o;this._logPackets?this._log.Debug(Vt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId} data:\n${JSON.stringify(e,null,2)}`):t&&this._log.Debug(Vt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId}`),null===(o=this._connection)||void 0===o||o.invoke("SendTo",this._serialId,e).then((()=>{n(!0)})).catch((e=>{this._log.Error(Vt.ServiceName,`${e}`),n(!1)}))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}}Vt.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(tt||(tt={})),(Ft=nt||(nt={}))[Ft.Default=0]="Default",Ft[Ft.Monostable=1]="Monostable",Ft[Ft.Bistable=2]="Bistable",Ft[Ft.Gate=3]="Gate",Ft[Ft.Gateway=4]="Gateway",function(e){e[e.None=0]="None",e[e.OnOff=1]="OnOff",e[e.OnOffLights=2]="OnOffLights",e[e.OnOffWithDelay=3]="OnOffWithDelay",e[e.GateSwitchState=4]="GateSwitchState",e[e.GatePulse=5]="GatePulse",e[e.GateOpenClose=6]="GateOpenClose",e[e.GatewayOpenClose=7]="GatewayOpenClose",e[e.GatewayPulse=8]="GatewayPulse",e[e.Monostable=9]="Monostable",e[e.Dimmer=10]="Dimmer",e[e.Blind=11]="Blind",e[e.Roller=12]="Roller",e[e.TemperatureSensor=13]="TemperatureSensor",e[e.BrightnessSensor=14]="BrightnessSensor",e[e.HumiditySensor=15]="HumiditySensor",e[e.PowerMeter=16]="PowerMeter",e[e.RGBLight=17]="RGBLight",e[e.RGBWLight=18]="RGBWLight",e[e.LightsWarmth=19]="LightsWarmth",e[e.TemperatureControl=20]="TemperatureControl",e[e.BlindsWithPrecisePosition=21]="BlindsWithPrecisePosition",e[e.MovementSensor=21]="MovementSensor",e[e.SimpleRemote=22]="SimpleRemote",e[e.BlindsRemote=23]="BlindsRemote",e[e.DistanceSensor=24]="DistanceSensor",e[e.Multisensor=25]="Multisensor",e[e.IOTransmitter=26]="IOTransmitter",e[e.DoorOpenClose=27]="DoorOpenClose",e[e.WindSensor=28]="WindSensor",e[e.BatterySensor=29]="BatterySensor",e[e.PressureSensor=30]="PressureSensor"}(ot||(ot={}));class jt{constructor(){this._type=rt.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Mt=rt||(rt={})).Unknown="Unknown",Mt.SetBlindPosition="IBlindPosition",Mt.SetBlindPositionSimple="IBlindPositionSimple",Mt.SetBlindMicroventilation="IMicroventilation",Mt.TurnOff="IChannelOff",Mt.TurnOn="IChannelOn",Mt.TogleState="IChannelSwitchState",Mt.SetLightBrightnessDynamicly="IDynamicLightBrightness",Mt.SetLightBrightness="ILightBrightness",Mt.SetLightColor="ILightColor",Mt.SetLightTemperature="ILightTemperature",Mt.PairDevice="IPair",Mt.UnpairDevice="IUnpair",Mt.IdentifyDevice="IIdentifyDevice",Mt.GetChannelsState="IGetDeviceState",Mt.GetPowerMeasurements="IGetPowerMeasurements",Mt.GetAvailableData="IGetAvailableData",Mt.MultipleDataRequest="IMultipleDataRequest",Mt.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",Mt.SetTemperature="IChangeTemperature",Mt.ChangeGatePositionPulse="IGatePulse",Mt.ChangeGatewayPositionPulse="IGatewayPulse",Mt.SetFacadePosition="IFacadePosition",Mt.GetFacadeType="IGetFacadeType",Mt.LightRGBW="ILightRGBW";class Kt{constructor(){this._type=st.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}!function(e){e.Unknown="Unknown",e.BatteryState="IBatteryState",e.BinarySensorState="IBinarySensor",e.BlindOpenCloseTime="IBlindOpenCloseTime",e.BlindPosition="IBlindPosition",e.BlindRemoteButtonState="IBlindsControlButton",e.MeasuredBrightness="IBrightness",e.RemoteButtonState="IButtonState",e.ChannelOnOffState="IChannelOnOff",e.DoorBellState="IDoorBell",e.FacadeRemoteButtonState="IFacadeControlButton",e.FacadePosition="IFacadeState",e.FacadeType="IFacadeType",e.FloodSensorState="IFloodSensor",e.GatePosition="IGatePosition",e.GatewayPosition="IGatewayPosition",e.HumiditySensorState="IHumiditySensor",e.LightBrightness="ILightBrightness",e.LightColor="ILightColor",e.LightWarmth="ILightTemperature",e.LightTreshold="ILightTreshold",e.MovementSensorState="IMovementSensor",e.OnlineCamera="IOnlineCamera",e.OvercurrentProtectionState="IOvercurrentProtection",e.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",e.ReedState="IReedState",e.SignalStrength="ISignalStrength",e.SmokeSensorState="ISmokeSensor",e.MeasuredTemperature="ITemperature",e.VibrationSensorState="IVibrationSensor",e.MeasuredWindSpeed="IWindSpeed",e.WindThreshold="IWindThreshold",e.MeasuredEnergy="IEnergy",e.MeasuredDistance="DistanceSensor",e.BlindCalibration="BlindCalibration",e.ConfigurationState="ConfigurationState",e.CurrentWindThreshold="CurrentWindThreshold",e.CurrentLightThreshold="CurrentLightThreshold",e.WindSpeedState="WindSpeed",e.TamperProtectionState="ITamperProtection",e.PressureSensorState="IPressureSensor",e.LightRGBWState="ILightRGBW"}(st||(st={})),(Wt=it||(it={}))[Wt.NotResponding=0]="NotResponding",Wt[Wt.Working=1]="Working",Wt[Wt.Broken=2]="Broken",Wt[Wt.FirmareUpgradeMode=3]="FirmareUpgradeMode",(Lt=at||(at={}))[Lt.TwoWay=1]="TwoWay",Lt[Lt.OneWay=2]="OneWay",Lt[Lt.ConditionalTwoWay=3]="ConditionalTwoWay",($t=ct||(ct={}))[$t.Unknown=-1]="Unknown",$t[$t.Multipurpose=0]="Multipurpose",$t[$t.Controller=1]="Controller",$t[$t.Driver=2]="Driver",$t[$t.Receiver=3]="Receiver",$t[$t.Remote=4]="Remote",$t[$t.Sensor=5]="Sensor",$t[$t.Scene=6]="Scene";class zt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=tt.NoTasksExecuting}}!function(e){e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed",e[e.ResponseTimeout=2]="ResponseTimeout",e[e.TaskRepeatedAndExecuted=3]="TaskRepeatedAndExecuted",e[e.TaskRepeatedResponseTimeout=4]="TaskRepeatedResponseTimeout",e[e.FlowControlNotAvailable=5]="FlowControlNotAvailable",e[e.ExecutionError=6]="ExecutionError"}(lt||(lt={})),function(e){e[e.ControllerResponseTimeout=-4]="ControllerResponseTimeout",e[e.DeviceNotFound=-3]="DeviceNotFound",e[e.DeviceResponseTimeout=-2]="DeviceResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed"}(ut||(ut={}));class qt{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=ut.Unknown}}class Jt{constructor(){this._type="",this._data=null,this._typeAsEnum=st.Unknown}get Data(){return this._data}set Data(e){this._data=e}get Type(){return this._type}set Type(e){this._type=e}get TypeAsEnum(){return this._typeAsEnum}set TypeAsEnum(e){this._typeAsEnum=e}}(Bt=dt||(dt={}))[Bt.Confident=0]="Confident",Bt[Bt.Unconfident=1]="Unconfident";class Yt extends Jt{constructor(e){super(),this.TypeAsEnum=st.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(ht||(ht={}));class Xt extends Jt{constructor(e){super(),this.TypeAsEnum=st.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(gt||(gt={}));class Qt extends Jt{constructor(e){super(),this.TypeAsEnum=st.ReedState,this.Type="ReedState",this.Data=e.state}}class Zt extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return ft.UnableToMove;case 201:return ft.MotorOverheatedPleaseWait;default:return ft.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(ft||(ft={}));class en extends Jt{constructor(e){super(),this.TypeAsEnum=st.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(pt||(pt={}));class tn extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightColor,this.Type="LightColorState",this.Data=e.state}}class nn extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class on extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class rn extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}!function(e){e[e.AirTemperature=0]="AirTemperature",e[e.InsideTemperature=1]="InsideTemperature",e[e.OutsideTemperature=2]="OutsideTemperature",e[e.FloorTemperature=3]="FloorTemperature",e[e.SafetyTemperature=4]="SafetyTemperature",e[e.SetTemperature=5]="SetTemperature"}(vt||(vt={}));class sn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BatteryState,this.Type="BatteryState",this.Data=e.state}}!function(e){e[e.Unknown=-1]="Unknown",e[e.Full=0]="Full",e[e.Empty=1]="Empty",e[e.Half=2]="Half",e[e.Percentage=3]="Percentage",e[e.Low=4]="Low",e[e.ExternalPower=5]="ExternalPower"}(yt||(yt={}));class an extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class cn extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state}}class ln extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(wt||(wt={}));class un extends Jt{constructor(e){super(),this.TypeAsEnum=st.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(mt||(mt={}));class dn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}!function(e){e[e.OpenPressed=1]="OpenPressed",e[e.OpenReleased=2]="OpenReleased",e[e.StopPressed=3]="StopPressed",e[e.StopReleased=4]="StopReleased",e[e.ClosePressed=5]="ClosePressed",e[e.CloseReleased=6]="CloseReleased"}(St||(St={}));class hn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}!function(e){e[e.OpenPressed=1]="OpenPressed",e[e.OpenReleased=2]="OpenReleased",e[e.StopPressed=3]="StopPressed",e[e.StopReleased=4]="StopReleased",e[e.ClosePressed=5]="ClosePressed",e[e.CloseReleased=6]="CloseReleased"}(_t||(_t={}));class gn extends Jt{constructor(e){super(),this.TypeAsEnum=st.SignalStrength,this.Type="SignalStrenghtState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Excellent=1]="Excellent",e[e.Good=2]="Good",e[e.Acceptable=3]="Acceptable",e[e.Low=4]="Low",e[e.Terrible=5]="Terrible",e[e.NoLink=6]="NoLink"}(Ct||(Ct={}));class fn extends Jt{constructor(e){super(),this.TypeAsEnum=st.GatePosition,this.Type="GatePositionState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Open=1]="Open",e[e.PartiallyOpen=2]="PartiallyOpen",e[e.Close=3]="Close"}(At||(At={}));class pn extends Jt{constructor(e){super(),this.TypeAsEnum=st.GatewayPosition,this.Type="GatewayPositionState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Open=1]="Open",e[e.PartiallyOpen=2]="PartiallyOpen",e[e.Close=3]="Close",e[e.On=4]="On",e[e.Off=5]="Off"}(Dt||(Dt={}));class vn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindCalibration,this.Type="BlindCalibrationState",this.Data=e.state}}!function(e){e[e.AutoLernIdle=0]="AutoLernIdle",e[e.AutoLernInProgress=1]="AutoLernInProgress",e[e.AutoLernSuccessfull=2]="AutoLernSuccessfull",e[e.AutoLernCancelled=4]="AutoLernCancelled"}(bt||(bt={}));class yn extends Jt{constructor(e){super(),this.TypeAsEnum=st.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}!function(e){e[e.AirHumidity=0]="AirHumidity",e[e.InsideHumidity=1]="InsideHumidity",e[e.OutsideHumidity=2]="OutsideHumidity",e[e.SafetyHumidity=3]="SafetyHumidity",e[e.SetHumidity=4]="SetHumidity"}(Gt||(Gt={}));class wn extends Jt{constructor(e){super(),this.TypeAsEnum=st.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Et||(Et={}));class mn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(It||(It={}));class Sn extends Jt{constructor(e){super(),this.TypeAsEnum=st.ConfigurationState,this.Type="ConfigurationState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.OngoingConfiguration=1]="OngoingConfiguration",e[e.NotConfigured=2]="NotConfigured",e[e.Configured=3]="Configured",e[e.PartiallyConfigured=4]="PartiallyConfigured"}(Tt||(Tt={}));class _n extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class Cn extends Jt{constructor(e){super(),this.TypeAsEnum=st.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class An extends Jt{constructor(e){super(),this.TypeAsEnum=st.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class Dn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class bn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Gn extends Jt{constructor(e){super(),this.TypeAsEnum=st.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Below=1]="Below",e[e.Exceeded=2]="Exceeded",e[e.Inactive=3]="Inactive"}(Nt||(Nt={}));class En extends Jt{constructor(e){super(),this.TypeAsEnum=st.CurrentLightThreshold,this.Type="CurrentLightThresholdState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Below=1]="Below",e[e.Exceeded=2]="Exceeded"}(Pt||(Pt={}));class In extends Jt{constructor(e){super(),this.TypeAsEnum=st.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class Tn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(kt||(kt={})),function(e){e[e.AirHumidity=0]="AirHumidity",e[e.InsideHumidity=1]="InsideHumidity",e[e.OutsideHumidity=2]="OutsideHumidity",e[e.SafetyHumidity=3]="SafetyHumidity",e[e.SetHumidity=4]="SetHumidity"}(Rt||(Rt={}));class Nn extends Jt{constructor(e){super(),this.TypeAsEnum=st.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(Ot||(Ot={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(xt||(xt={}));class Pn extends Jt{constructor(e){super(),this.TypeAsEnum=st.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(Ut||(Ut={}));class kn extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Rn{constructor(){this._onDeviceStateChangedEvent=new n,this._onDeviceTasksExecutionChangedOnChannelsEvent=new n,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=it.Working,this._deviceType=ct.Unknown,this._communicationWay=at.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,null==Rn._devicesService&&(Rn._devicesService=Uh.Get(oo.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Rn._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Rn._devicesService.OnDevicesTasksExecutionChangeEvent().Subscribe((e=>{t.Invoke(e.filter((e=>e.DeviceGuid==this._guid)).map((e=>e.Channel)))}))}get States(){return o.DoesThrowStackTrace?Uh.Get(oo.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Rn._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Rn._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Rn._devicesService.ExecuteDeviceTaskAsync(this,e)}OnDeviceTasksExecutionChangedOnChannelsEvent(){return this._onDeviceTasksExecutionChangedOnChannelsEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}get Guid(){return null==this._guid?"":this._guid}set Guid(e){this._guid=e}get Name(){return null==this._name?"":this._name}set Name(e){this._name=e}get ChannelsAmount(){return null==this._channelsAmount?0:this._channelsAmount}set ChannelsAmount(e){this._channelsAmount=e}get SerialNumber(){return this._serialNumber}set SerialNumber(e){this._serialNumber=e}get Model(){return this._model}set Model(e){this._model=e}get ModelGuid(){return this._modelGuid}set ModelGuid(e){this._modelGuid=e}get ManufacturerGuid(){return this._manufacturerGuid}set ManufacturerGuid(e){this._manufacturerGuid=e}get IsVirtual(){return this._isVirtual}set IsVirtual(e){this._isVirtual=e}get IsEnabled(){return this._isEnabled}set IsEnabled(e){this._isEnabled=e}get DeviceState(){return this._deviceState}set DeviceState(e){this._deviceState=e}get DeviceType(){return this._deviceType}set DeviceType(e){this._deviceType=e}get CommunicationWay(){return this._communicationWay}set CommunicationWay(e){this._communicationWay=e}get AvailableTaskTypes(){return this._availableTasksTypes}set AvailableTaskTypes(e){this._availableTasksTypes=e}get AvailableResponseTypes(){return this._availableResponseTypes}set AvailableResponseTypes(e){this._availableResponseTypes=e}get Channels(){return this._channels}get ProtocolGuid(){return this._protocolGuid}set ProtocolGuid(e){this._protocolGuid=e}ChangeDeviceNameAsync(e){return t=this,n=void 0,r=function*(){try{const t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new On(this,e),2e4,!1);switch(t.Status){case se.OK:return this._name=e,Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),new _e(fe.Changed,"");case se.WrongData:if("DeviceNotFound"==t.Data)return new _e(fe.Failed,"DeviceNotFound");break;case se.NoPermissionsToCallGivenResource:return new _e(fe.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new _e(fe.ControllerResponseTimeout,""):new _e(fe.UnknownError,"")}return new _e(fe.Unknown,"")},new((o=void 0)||(o=Promise))((function(e,s){function i(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(t){var n;t.done?e(t.value):(n=t.value,n instanceof o?n:new o((function(e){e(n)}))).then(i,a)}c((r=r.apply(t,n||[])).next())}));var t,n,o,r}ExecuteTaskAsync(e){return Rn._devicesService.ExecuteDeviceTaskAsync(this,e)}}class On extends re{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ie.Put;const n=new xn;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class xn{constructor(){this.DeviceGuid="",this.Name=""}}var Un,Fn,Mn,$n,Ln,Wn=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Bn{constructor(){this._device=new Rn,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=nt.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new n,null==Bn._devicesService&&(Bn._devicesService=Uh.Get(oo.ServiceName))}IsCustomDataAndRolesSupported(){return this.CustomDataAndRolesSupported}get CustomData(){return this._customData}set CustomData(e){this._customData=e}get Roles(){return this._roles}set Roles(e){this._roles=e}get ChannelId(){return this._channelId}SetDevice(e){this._device=e,this._channelId=`${e.Guid}_${this.Number}`}GetDevice(){return this._device}SetCustomDataAsync(e,t){return Wn(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t;const o=new Hn;return o.DeviceGuid=this._device.Guid,o.ChannelConfiguration=n,this.ChangeConfigurationAsync(o)}))}RemoveCustomDataAsync(e){const t=this.GetChannelConfigurationData();delete t.CustomData[e];const n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new Vn;return e.Channel=this._number,e.ChannelName=this._name,e.Configuration=this._mode,e.CustomData=this._customData,e.GroupsGuids=this._channelGroups,e.Hidden=this._isHidden,e.IconName=this._iconName,e}HideAsync(){const e=this.GetChannelConfigurationData();e.Hidden=!0;const t=new Hn;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ShowAsync(){const e=this.GetChannelConfigurationData();e.Hidden=!1;const t=new Hn;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,t.ChannelName=e,this.ChangeConfigurationAsync(n)}ChangeIconNameAsync(e){const t=this.GetChannelConfigurationData();t.IconName=e;const n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}ChangeGroupsAsync(e){const t=this.GetChannelConfigurationData();t.GroupsGuids=e;const n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){var t;return Wn(this,void 0,void 0,(function*(){try{const n=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new jn(e),2e4,!1);switch(n.Status){case se.OK:return this._name=e.ChannelConfiguration.ChannelName,this._iconName=e.ChannelConfiguration.IconName,this._channelGroups=e.ChannelConfiguration.GroupsGuids,this._isHidden=e.ChannelConfiguration.Hidden,this._mode=e.ChannelConfiguration.Configuration,this._customData=e.ChannelConfiguration.CustomData,this._roles=e.ChannelConfiguration.Roles,Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),new _e(fe.Changed,"");case se.WrongData:if("DeviceNotFound"===n.Data)return null===(t=r.Log)||void 0===t||t.Error("Failed to change channel configuration, referenced device does not exist!"),new _e(fe.WrongData,"DeviceNotFound");break;case se.FatalError:return new _e(fe.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new _e(fe.ControllerResponseTimeout,"")}return new _e(fe.Unknown,"")}))}get Number(){return this._number}set Number(e){this._number=e}get Name(){return this._name}set Name(e){this._name=e}get IconName(){return this._iconName}set IconName(e){this._iconName=e}get States(){return o.DoesThrowStackTrace?Uh.Get(oo.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Bn._devicesService.GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray()}get Mode(){return this._mode}set Mode(e){this._mode=e}get ChannelGroups(){return this._channelGroups}set ChannelGroups(e){this._channelGroups=e}get IsHidden(){return this._isHidden}set IsHidden(e){this._isHidden=e}get AvailableTaskTypes(){return this._availableTasksTypes}set AvailableTaskTypes(e){this._availableTasksTypes=e}get AvailableResponseTypes(){return this._availableResponseTypes}set AvailableResponseTypes(e){this._availableResponseTypes=e}OnTasksExecutionChangeEvent(){return this._onTasksExecutionChangedEvent}ExecuteTaskAsync(e){return null!=this._device?(e.Channel=this.Number,e.DeviceGuid=this._device.Guid,Bn._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(ut.Failed)}}Bn._devicesService=null;class Hn{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new Vn}}class Vn{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=nt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class jn extends re{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ie.Put,this.Data=e}}(Ln=Un||(Un={}))[Ln.TurnOn=0]="TurnOn",Ln[Ln.TurnOff=1]="TurnOff",Ln[Ln.ToggleState=2]="ToggleState",Ln[Ln.SetBlindPosition=3]="SetBlindPosition",Ln[Ln.SetLightColor=4]="SetLightColor",Ln[Ln.SetLightTemperature=5]="SetLightTemperature",Ln[Ln.SetLightBrightness=6]="SetLightBrightness",Ln[Ln.SetTemperature=7]="SetTemperature",Ln[Ln.GetState=8]="GetState",Ln[Ln.TurnOnWithTimeout=9]="TurnOnWithTimeout",Ln[Ln.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",Ln[Ln.IdentifyDevice=11]="IdentifyDevice",Ln[Ln.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",Ln[Ln.SetBlindMicroventilation=13]="SetBlindMicroventilation",Ln[Ln.GatewayPulse=25]="GatewayPulse",Ln[Ln.GatePulse=26]="GatePulse",Ln[Ln.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",Ln[Ln.GetFacadeType=30]="GetFacadeType",Ln[Ln.LightRGBW=31]="LightRGBW",function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Fn||(Fn={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Mn||(Mn={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage",e[e.Tilt=4]="Tilt",e[e.TiltAndPercentage=5]="TiltAndPercentage"}($n||($n={}));var Kn=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class zn{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return zn.ServiceName}RegisterManuallyPairedDevicesProtocol(e){Uh.Get(o.ServiceName).Debug(zn.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return Kn(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()],n=[];if(null!=e)if(Array.isArray(e))for(let o=0;o<t.length;o++)e.any((e=>e==t[o].ProtocolExtensionGuid))&&n.push(...yield t[o].GetDevicesForManualPairingAsync());else{const o=t.find((t=>t.ProtocolExtensionGuid==e));null!=o&&n.push(...yield o.GetDevicesForManualPairingAsync())}else for(let e=0;e<t.length;e++)n.push(...yield t[e].GetDevicesForManualPairingAsync());return n}))}AddManuallyPairedDeviceAsync(e){return Kn(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=t?t.AddManuallyPairedDeviceAsync(e):ut.Failed}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}zn.ServiceName="ManualDeviceService";class qn{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var Jn=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Yn{constructor(){this._connection=null,this._localDb=null,this._connection=Uh.Get(Vt.ServiceName),this._localDb=Uh.Get(s.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return Jn(this,void 0,void 0,(function*(){let o=new Xn(e,t,n),r=yield this._connection.SendAndWaitForResponseAsync(o,35e3,!1);if(r.Status===se.OK){const o=new eo;o.ResourceGuid=e,o.Data=JSON.stringify(n),o.IsGlobal=t,this._localDb.Save(Yn.ServiceName,this.GetLocalDbName(e,t),o)}return r.Status}))}ReadAsync(e,t,n){return Jn(this,void 0,void 0,(function*(){let o=new Qn(e,t);if(!n){const n=this._localDb.Read(Yn.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new qn;return t.Data=JSON.parse(e.Data),t.IsGlobal=e.IsGlobal,t.ResourceGuid=e.ResourceGuid,t}}let r=yield this._connection.SendAndWaitForResponseAsync(o,35e3,!1);if(r.Status===se.OK){const e=new qn;return e.ResourceGuid=r.ResourceGuid,e.Data=JSON.parse(r.Data),e.IsGlobal=r.IsGlobal,e}return r.Status}))}RemoveAsync(e,t){return Jn(this,void 0,void 0,(function*(){let n=new Zn(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return Yn.ServiceName}}Yn.ServiceName="RemoteStorageService";class Xn extends re{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ie.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class Qn extends re{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ie.Get,this.ResourceGuid=e,this.Global=t}}class Zn extends re{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ie.Delete,this.ResourceGuid=e,this.Global=t}}class eo extends re{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}var to,no=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class oo{constructor(){this._devices=[],this._onDevicesTasksChangedEvent=new n,this._onDeviceFoundEvent=new n,this._onDeviceRegisteredEvent=new n,this._onDeviceRemovedEvent=new n,this._onDeviceStateChangedEvent=new n,this._connection=null,this._session=null,this._controllerConfiguration=null,this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devicesChannelsStates=[],this._synchronizationTaskCompletionSource=null,this._deviceStatesSynchronizationTaskCompletionSource=null,this._connection=Uh.Get(Vt.ServiceName),this._session=Uh.Get(He.ServiceName),this._controllerConfiguration=Uh.Get(qe.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>no(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),this._synchronizationTaskCompletionSource=new Promise((e=>{var t;null===(t=this._session)||void 0===t||t.OnUserLoggedInEvent().Subscribe((t=>no(this,void 0,void 0,(function*(){var t;try{this._devices=yield this.GetPairedDevicesAsync()}catch(e){null===(t=r.Log)||void 0===t||t.Error(oo.ServiceName,`Failed to get paired devices: ${e}`)}this._synchronized=!0,e()}))))})),this._deviceStatesSynchronizationTaskCompletionSource=new Promise((e=>{var t;null===(t=this._session)||void 0===t||t.OnUserLoggedInEvent().Subscribe((t=>no(this,void 0,void 0,(function*(){var t;try{yield this.WaitForSynchronizationAsync(),yield this.SyncDevicesStatesAsync()}catch(e){null===(t=r.Log)||void 0===t||t.Error(oo.ServiceName,`Failed to sync devices states: ${e}`)}this._synchronizedDevicesStates=!0,e()}))))})),this._connection.OnDataReceivedEvent().Subscribe((e=>{if("/info/devices/tasks"===e.Resource)this.ParseDeviceTaskInfo(e.Data);else if("/devices/blinds/times"===e.Resource);else if("/info/devices/device/found"===e.Resource)this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=r.Log)||void 0===t||t.Debug(oo.ServiceName,`Found device: ${e.Name} guid: ${e.Guid}`),this._onDeviceFoundEvent.Invoke(e)}));else if("/info/devices/device/state/changed"===e.Resource){const t=e.Data,n=this._devices.filter((e=>e.Guid==t.DeviceGuid));if(n.length>0){const e=n[0],o=this.MapApiDeviceStateToDeviceState(e,t);null!=o&&(this._onDeviceStateChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==st.SignalStrength?e.Channels.forEach((n=>{let o=new gn(Object.assign({},t));o.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:o})})):o.TypeAsEnum==st.BatteryState&&e.Channels.forEach((n=>{let o=new sn(Object.assign({},t));o.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:o})})))}}else"/info/devices/device/registered"===e.Resource?this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=r.Log)||void 0===t||t.Debug(oo.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)})):"/info/devices/device/removed"===e.Resource&&this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=r.Log)||void 0===t||t.Debug(oo.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}CanEditDevicesInfo(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=ue.Admin}CanAddAndRemoveAndConfigureDevices(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=ue.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return Uh.Get(Yn.ServiceName).SaveAsync("FastDevicesSync",!1,!0)}DisableFastStatesSyncAsync(){return Uh.Get(Yn.ServiceName).SaveAsync("FastDevicesSync",!1,!1)}IsFastStatesSyncEnabledAsync(){return no(this,void 0,void 0,(function*(){const e=yield Uh.Get(Yn.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof qn?e.Data:e}))}GetDevicesForManualPairingAsync(e){return no(this,void 0,void 0,(function*(){let t=Uh.Get(zn.ServiceName);const n=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$");return Array.isArray(e)||n.test(e)?yield t.GetDevicesForManualPairingAsync(e):yield t.GetDevicesForManualPairingAsync()}))}AddManuallyPairedDevice(e){return no(this,void 0,void 0,(function*(){return yield Uh.Get(zn.ServiceName).AddManuallyPairedDeviceAsync(e)}))}GetDeviceChannelStates(e,t){var n,o;return null!==(o=null===(n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===n?void 0:n.ChannelsStates.filter((e=>e.Channel==t)))&&void 0!==o?o:[]}GetDeviceStates(e){var t,n;return null!==(n=null===(t=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===t?void 0:t.ChannelsStates)&&void 0!==n?n:[]}PutDeviceStateOnList(e,t){let n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid));if(null==n){let o=new ro;o.Channel=t.Data.Channel,o.States=[t],n={DeviceGuid:e.Guid,ChannelsStates:[o]},this._devicesChannelsStates.push(n)}else{let e=n.ChannelsStates.firstOrDefault((e=>e.Channel==t.Data.Channel));null==e?(e=new ro,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e)):(null!=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum))&&(e.States=e.States.where((e=>e.TypeAsEnum!=t.TypeAsEnum)).toArray()),e.States.push(t))}}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}WaitForDevicesStatesSynchronizationAsync(){return this._deviceStatesSynchronizationTaskCompletionSource}GetCurrentlyRunningTaksAsync(){var e;return no(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ho,15e3,!1);(null==t?void 0:t.Status)==se.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),o=new zt;o.DeviceGuid=n[0],o.Channel=Number(n[1]),o.Status=tt.ExecutingTasks,t.push(o)})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new Yt(t);case"DoorBell":return new Xt(t);case"ReedPosition":return new Qt(t);case"BlindPosition":return new Zt(t);case"ButtonState":return new en(t);case"LightColor":return new tn(t);case"LightTemperature":return new nn(t);case"LightBrightness":return new on(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new rn(t);case"BatteryState":return new sn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new an(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"Energy":return new cn(t);case"DistanceSensor":return new ln(t);case"MovementSensor":return new un(t);case"BlindsControlButton":return new dn(t);case"FacadeControlButton":return new hn(t);case"SignalStrength":return new gn(t);case"GatePosition":return new fn(t);case"GatewayPosition":return new pn(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new vn(t);case"HumiditySensor":case"HumidityState":return new yn(t);case"VibrationSensor":return new wn(t);case"DigitalInputSensor":return new mn(t);case"ConfigurationState":return new Sn(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new _n(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new Cn(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new An(t);case"FacadePosition":case"FacadeState":return new Dn(t);case"FacadeTypeState":return new bn(t);case"CurrentWindThreshold":return new Gn(t);case"CurrentLightThreshold":return new En(t);case"WindSpeed":return new In(t);case"FloodSensor":return new Tn(t);case"PressureState":return new Nn(t);case"ITamperProtection":case"TamperProtection":return new Pn(t);case"ILightRGBW":case"LightRGBW":return new kn(t);default:null===(n=r.Log)||void 0===n||n.Debug(oo.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return oo.ServiceName}SyncDevicesStatesAsync(){var e,t;return no(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new io,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync())return(null==n?void 0:n.Status)==se.OK;{let e=new ao;e.Data=!0;const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(e,35e3,!1);return(null==n?void 0:n.Status)==se.OK}}))}OnDevicesTasksExecutionChangeEvent(){return this._onDevicesTasksChangedEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}OnDeviceRegisteredEvent(){return this._onDeviceRegisteredEvent}OnDeviceRemovedEvent(){return this._onDeviceRemovedEvent}OnDeviceFoundEvent(){return this._onDeviceFoundEvent}MapApiDevices(e){const t=[];return null==e?[]:(e.forEach((e=>{var n,o,s,i,a=new Rn;a.Guid=e.Guid,a.Name=e.DeviceName,a.ChannelsAmount=e.ChannelsNumber,a.DeviceType=e.DeviceType,a.CommunicationWay=e.CommunicationWay,a.DeviceState=e.DeviceState,a.IsEnabled=e.IsEnabled,a.IsVirtual=e.IsVirtual,a.SerialNumber=e.DeviceSerialNumber,a.ManufacturerGuid=e.ManufacturerGuid,a.ModelGuid=e.DeviceModelGuid,a.Model=e.DeviceModel,a.Name=e.DeviceName,a.ProtocolGuid=e.ProtocolGuid;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new jt;if(a.CommunicationWay==at.OneWay)"IBlindPosition"===e&&(t.InterfaceType="IBlindPositionSimple");else switch(e){case"IGatePosition":t.InterfaceType="IGatePulse";break;case"IGatewayPosition":t.InterfaceType="IGatewayPulse";break;default:t.InterfaceType=e}a.AvailableTaskTypes.push(t)})),null===(o=e.AvailableResponses)||void 0===o||o.forEach((e=>{var t=new Kt;t.InterfaceType=e,a.AvailableResponseTypes.push(t)})),null===(s=e.ChannelsConfiguration)||void 0===s||s.forEach((e=>{var t,n,o;try{var s=new Bn;s.Number=e.Channel,a.Channels.push(s),s.SetDevice(a),s.Name=e.ChannelName,s.ChannelGroups=e.GroupsGuids,s.IconName=e.IconName,s.IsHidden=e.Hidden,s.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(s.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(s.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{var t=new Kt;t.InterfaceType=e,s.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new jt;t.InterfaceType=e,s.AvailableTaskTypes.push(t)}))}catch(e){null===(o=r.Log)||void 0===o||o.Error(e)}}))}catch(e){null===(i=r.Log)||void 0===i||i.Error(e)}t.push(a)})),t)}GetPairedDevicesAsync(e=!1){var t,n,o;return no(this,void 0,void 0,(function*(){if(this._synchronized&&!(yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync()))return Promise.resolve(this._devices);const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new so,15e3,!0);return null==s||void 0===s?[]:s.Status==se.OK&&null!=s.Data?e?this.MapApiDevices(s.Data):this.MapApiDevices(s.Data.filter((e=>e.DeviceType!=ct.Scene))):(null===(o=r.Log)||void 0===o||o.Error(oo.ServiceName,`Failed to get devices. ${s.Status} ${s.Data}`),[])}))}GetDevicesAsync(e=!1){return no(this,void 0,void 0,(function*(){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){var e,t;return no(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new uo,15e3,!1);return null==n?[]:n.Status==se.OK&&null!=n.Data?this.MapApiDevices(n.Data):(null===(t=r.Log)||void 0===t||t.Error(oo.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){var e;return no(this,void 0,void 0,(function*(){yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new co,35e3,!1)}))}StopSearchingForDevices(){var e;return no(this,void 0,void 0,(function*(){yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new lo,2e4,!1)}))}RegisterDeviceAsync(e){var t;return no(this,void 0,void 0,(function*(){const n=new go;n.Data=e.Guid;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,2e4,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==se.OK?(this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),ut.Executed):ut.Failed}))}RemoveDeviceAsync(e,t=!1){var n;return no(this,void 0,void 0,(function*(){var o=new fo;t&&(o=new po),o.Data=e.Guid;const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,35e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==r?void 0:r.Status)==se.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),ut.Executed):ut.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new wo;const o=t;switch(o.FeatureType){case Un.SetTemperature:n.Data=o.Temperature;break;case Un.SetLightBrightness:n.Data=o.Brightness;break;case Un.SetLightColor:n=new mo;const e=o;n.R=e.R,n.G=e.G,n.B=e.B;break;case Un.SetLightTemperature:n.Data=o.Temperature;break;case Un.SetBlindPosition:switch(o.Action){case Fn.Open:n.Data=101;break;case Fn.Close:n.Data=102;break;case Fn.Stop:n.Data=103;break;case Fn.Percentage:n.Data=o.Position}break;case Un.SetLightBrightnessDynamicly:n.Data=o.Brightness;break;case Un.SetBlindOpenCloseTime:n.Data=o.Data;break;case Un.SetBlindMicroventilation:n.Data=o.Position;break;case Un.SetFacadePositionAndTilt:n=new So;const t=o;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case Un.LightRGBW:n.Data=o.Data}return n.Channel=o.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=o.FeatureType,n}ExecuteDeviceTaskAsync(e,t){var n,o,s,i,a,c,l,u;return no(this,void 0,void 0,(function*(){try{null===(n=r.Log)||void 0===n||n.Debug(oo.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let u=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new vo(u);null===(o=r.Log)||void 0===o||o.Debug(oo.ServiceName,`Sending device task for execution, device: ${u.DeviceGuid} task: ${u.ControlFeature} channel: ${u.Channel} request: ${JSON.stringify(e)}`);const t=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(e,15e3,!1);switch(null==t?void 0:t.Status){case se.OK:return ut.Executed;case se.FatalError:return null===(i=r.Log)||void 0===i||i.Error(oo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),ut.Failed;case se.WrongData:if("DeviceNotFound"===t.Data)return ut.DeviceNotFound;break;case se.Error:return"DeviceResponseTimeout"===t.Data?ut.DeviceResponseTimeout:(null===(a=r.Log)||void 0===a||a.Error(oo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),ut.Failed)}}catch(e){return e.message.includes("timeout")?(null===(c=r.Log)||void 0===c||c.Error(oo.ServiceName,`Failed to get controller response in time.\n${e}`),ut.ControllerResponseTimeout):(null===(l=r.Log)||void 0===l||l.Error(oo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),ut.Failed)}return ut.Unknown}catch(e){return null===(u=r.Log)||void 0===u||u.Error(oo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),ut.Failed}}))}ExecuteDevicesTasksAsync(e){var t,n,o,s;return no(this,void 0,void 0,(function*(){let i=[],a=[],c=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=c,c++,a.push(e)}const l=new yo(a);try{const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(l,12e4,!1);let s=-1;null===(n=null==o?void 0:o.Data)||void 0===n||n.forEach((t=>{var n,a;s++;let c=ut.Unknown;switch(t.Status){case se.OK:return ut.Executed;case se.FatalError:null===(n=r.Log)||void 0===n||n.Error(oo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),c=ut.Failed;break;case se.WrongData:"DeviceNotFound"===t.Data&&(c=ut.DeviceNotFound);break;case se.Error:"DeviceResponseTimeout"===t.Data?c=ut.DeviceResponseTimeout:(null===(a=r.Log)||void 0===a||a.Error(oo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${o.Data}`),c=ut.Failed)}let l=0,u=new qt;for(const[t,n]of e){if(l==s){u.Device=t,u.Task=n,u.Channel=n.Channel,i.push(u);break}l++}}))}catch(t){if(t.message.includes("timeout")){null===(o=r.Log)||void 0===o||o.Error(oo.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new qt;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=ut.ControllerResponseTimeout}}else{null===(s=r.Log)||void 0===s||s.Error(oo.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new qt;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=ut.Failed}}}return i}))}}oo.ServiceName="DevicesService";class ro{constructor(){this.Channel=0,this.States=[]}}class so extends re{constructor(){super(),this.Resource="/devices/list",this.Method=ie.Get}}class io extends re{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ie.Get}}class ao extends re{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ie.Get}}class co extends re{constructor(){super(),this.Resource="/devices/search",this.Method=ie.Post}}class lo extends re{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ie.Post}}class uo extends re{constructor(){super(),this.Resource="/devices/found/list",this.Method=ie.Get}}class ho extends re{constructor(){super(),this.Resource="/devices/tasks",this.Method=ie.Get}}class go extends re{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ie.Put}}class fo extends re{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ie.Put}}class po extends re{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ie.Put}}class vo extends re{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ie.Post,this.Data=e}}class yo extends re{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ie.Post,this.Data=e}}class wo{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Un.GetState,this.SequnceExecutionOrder=0}}class mo extends wo{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class So extends wo{constructor(){super(...arguments),this.FacadeAction=$n.Stop,this.Tilt=0,this.Position=0}}class _o{constructor(){this.Longitude=0,this.Latitude=0}}class Co{constructor(){this.Longitude=0,this.Latitude=0,this.IsNetworkBased=!1}}!function(e){e[e.OK=0]="OK",e[e.NoPermissions=1]="NoPermissions",e[e.UserIsNotLoggedIn=2]="UserIsNotLoggedIn",e[e.UnknownError=3]="UnknownError"}(to||(to={}));var Ao=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Do{IsControllerGeolocationSetAsync(){return Ao(this,void 0,void 0,(function*(){let e=new bo,t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===se.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return Ao(this,void 0,void 0,(function*(){return new Promise(((e,t)=>Ao(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){var t,n;return Ao(this,void 0,void 0,(function*(){let o=new Eo;o.Data.Latitude=e.Latitude,o.Data.Longitude=e.Longitude,null===(t=r.Log)||void 0===t||t.Warning(Do.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(o)}`);let s=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(o,15e3,!1);switch(null===(n=r.Log)||void 0===n||n.Warning(Do.ServiceName,`${JSON.stringify(s)}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null==s?void 0:s.Status){case se.OK:return new Ce(to.OK,"");case se.NoPermissionToPerformThisOperation:case se.NoPermissionsToCallGivenResource:return new Ce(to.NoPermissions,"");case se.UserIsNotLoggedIn:return new Ce(to.UserIsNotLoggedIn,"");default:return new Ce(to.UnknownError,"")}}))}GetControlllerGeolocationAsync(){var e,t;return Ao(this,void 0,void 0,(function*(){let n=new Go;null===(e=r.Log)||void 0===e||e.Warning(Do.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let o=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=r.Log)||void 0===t||t.Warning(Do.ServiceName,`${JSON.stringify(o)}`),(null==o?void 0:o.Status)===se.OK){let e=new Co;return e.IsNetworkBased=(null==o?void 0:o.Data).IsNetworkBased,e.Latitude=(null==o?void 0:o.Data).Latitude,e.Longitude=(null==o?void 0:o.Data).Longitude,e}return null==o?void 0:o.Status}))}GetServiceName(){return Do.ServiceName}}Do.ServiceName="GeolocationService";class bo extends re{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ie.Get}}class Go extends re{constructor(){super(),this.Resource="/geolocation/get",this.Method=ie.Get}}class Eo extends re{constructor(){super(),this.Data=new _o,this.Resource="/geolocation/save",this.Method=ie.Put}}class Io extends RangeError{constructor(e){super(`${e} was out of range. Must be non-negative and less than the size of the collection.`),this.paramName=e,this.name="ArgumentOutOfRangeException",this.stack=this.stack||(new Error).stack}}const To=Object.freeze({MoreThanOneElement:"Sequence contains more than one element",MoreThanOneMatchingElement:"Sequence contains more than one matching element",NoElements:"Sequence contains no elements",NoMatch:"Sequence contains no matching element"});class No extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Po=(e,t)=>e===t;class ko extends Array{}class Ro{constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Oo{constructor(e){this.dataFunc=e}[Symbol.asyncIterator](){const{dataFunc:e}=this;return async function*(){if(1===e.type)for(const t of e.generator())yield t;else for(const t of await e.generator())yield t}()}}class xo{constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}const Uo=e=>{var t;const n=ko.prototype,o=e.prototype,r=Object.getOwnPropertyNames(n);for(const e of r)o[e]=null!==(t=o[e])&&void 0!==t?t:n[e]},Fo=(e,t,n,o)=>{if(o){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Lo(e,t,n,o)}return n?$o(e,t,n):Mo(e,t)},Mo=(e,t)=>{let n;for(const o of e)n=n?t(n,o):o;if(void 0===n)throw new No(To.NoElements);return n},$o=(e,t,n)=>{let o=t;for(const t of e)o=n(o,t);return o},Lo=(e,t,n,o)=>{let r=t;for(const t of e)r=n(r,t);return o(r)},Wo=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},Bo=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Ho=(e,t)=>t?jo(e,t):Vo(e),Vo=e=>{for(const t of e)return!0;return!1},jo=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Ko=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},zo=e=>{if(Array.isArray(e)){if(0===e.length)throw new No(To.NoElements);return new Ro((async function*(){for await(const t of e)yield t}))}return new Ro(e)},qo=e=>zo((async function*(){for(const t of e)yield t})),Jo=(e,t)=>new Oo({generator:t,type:e}),Yo=e=>Jo(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Xo=(e,t)=>{let n=0,o=0;if(t)for(const r of e)n+=t(r),o+=1;else for(const t of e)n+=t,o+=1;if(0===o)throw new No(To.NoElements);return n/o},Qo=async(e,t)=>{let n=0,o=0;for(const r of e)n+=await t(r),o+=1;if(0===o)throw new No(To.NoElements);return n/o},Zo=(e,t)=>{if(t<1)throw new Io("index");return new xo((function*(){let n=[];for(const o of e)n.push(o),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},er=(e,t)=>new xo((function*(){yield*e,yield*t})),tr=(e,t,n=Po)=>{for(const o of e)if(n(t,o))return!0;return!1},nr=async(e,t,n)=>{for(const o of e)if(await n(t,o))return!0;return!1},or=(e,t)=>t?sr(e,t):rr(e),rr=e=>{let t=0;for(const n of e)t++;return t},sr=(e,t)=>{let n=0;for(const o of e)!0===t(o)&&n++;return n},ir=async(e,t)=>{let n=0;for(const o of e)!0===await t(o)&&n++;return n},ar=(e,t)=>new xo((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),cr=(e,t=Po)=>new xo((function*(){const n=[];for(const o of e)n.find((e=>t(e,o)))||(n.push(o),yield o)})),lr=(e,t)=>zo((async function*(){const n=[];e:for(const o of e){for(const e of n)if(await t(e,o))continue e;n.push(o),yield o}})),ur=(e,t)=>new xo((function*(){for(const n of e)t(n),yield n})),dr=(e,t)=>zo((async function*(){for(const n of e)await t(n),yield n})),hr=(e,t)=>{if(t<0)throw new Io("index");let n=0;for(const o of e)if(t===n++)return o;throw new Io("index")},gr=(e,t)=>{let n=0;for(const o of e)if(t===n++)return o;return null},fr=(e,t,n=Po)=>new xo((function*(){const o=[...t];for(const t of e){let e=!1;for(let r=0;r<o.length;r++)if(!0===n(t,o[r])){e=!0;break}!1===e&&(yield t)}})),pr=(e,t,n)=>zo((async function*(){const o=[...t];for(const t of e){let e=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),vr=(e,t)=>t?wr(e,t):yr(e),yr=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new No(To.NoElements);return t.value},wr=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new No(To.NoMatch)},mr=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new No(To.NoMatch)},Sr=(e,t)=>t?Cr(e,t):_r(e),_r=e=>e[Symbol.iterator]().next().value||null,Cr=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},Ar=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class Dr extends ko{constructor(e,t){super(1),this.key=e,this[0]=t}}const br=(e,t,n)=>{let o;return o=n?((e,t,n)=>function*(){const o=new Array;for(const r of e){const e=t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})(e,t,n):((e,t)=>function*(){const n={};for(const o of e){const e=t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})(e,t),new xo(o)},Gr=(e,t,n)=>n?Ir(e,t,n):Er(e,t),Er=(e,t)=>zo((async function*(){const n={};for(const o of e){const e=await t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})),Ir=(e,t,n)=>zo((async function*(){const o=new Array;for(const r of e){const e=await t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(!0===await n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})),Tr=(e,t,n,o)=>o?((e,t,n,o)=>new xo((function*(){const r=new Array;for(const s of e){const e=t(s);let i=!1;for(let t=0;t<r.length;t++){const a=r[t];if(o(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);r.push(new Dr(e,t))}}for(const e of r)yield e})))(e,t,n,o):((e,t,n)=>new xo((function*(){const o={};for(const r of e){const e=t(r),s=o[e],i=n(r);s?s.push(i):o[e]=new Dr(e,i)}for(const e in o)yield o[e]})))(e,t,n),Nr=(e,t,n,o,r,s)=>{const i=s?Pr(e,t,n,o,r,s):kr(e,t,n,o,r);return new xo(i)},Pr=(e,t,n,o,r,s)=>function*(){var i;const a=[];for(const e of t){const t=o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},kr=(e,t,n,o,r)=>function*(){var s;const i=new Map;for(const e of t){const t=o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},Rr=(e,t,n,o,r,s)=>{const i=s?Or(e,t,n,o,r,s):xr(e,t,n,o,r);return zo(i)},Or=(e,t,n,o,r,s)=>async function*(){var i;const a=[];for(const e of t){const t=await o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=await n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},xr=(e,t,n,o,r)=>async function*(){var s;const i=new Map;for(const e of t){const t=await o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=await n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},Ur=(e,t,n=Po)=>new xo((function*(){const o=[...e.distinct(n)];if(0===o.length)return;const r=[...t];for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++)if(!0===n(t,r[e])){yield t;break}}})),Fr=(e,t,n)=>zo((async function*(){const o=[];for await(const t of e.distinctAsync(n))o.push(t);if(0===o.length)return;const r=[...t];for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===await n(t,o)){yield t;break}}}})),Mr=(e,t,n,o,r,s=Po)=>new xo((function*(){const i=[...t];for(const t of e){const e=n(t);for(const n of i){const i=o(n);!0===s(e,i)&&(yield r(t,n))}}})),$r=(e,t)=>t?Wr(e,t):Lr(e),Lr=e=>{let t;for(const n of e)t=n;if(!t)throw new No(To.NoElements);return t},Wr=(e,t)=>{let n;for(const o of e)!0===t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Br=async(e,t)=>{let n;for(const o of e)!0===await t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Hr=(e,t)=>t?jr(e,t):Vr(e),Vr=e=>{let t=null;for(const n of e)t=n;return t},jr=(e,t)=>{let n=null;for(const o of e)!0===t(o)&&(n=o);return n},Kr=async(e,t)=>{let n=null;for(const o of e)!0===await t(o)&&(n=o);return n},zr=(e,t)=>t?Jr(e,t):qr(e),qr=e=>{let t=null;for(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Jr=(e,t)=>{let n=null;for(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},Yr=async(e,t)=>{let n=null;for(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},Xr=(e,t)=>t?Zr(e,t):Qr(e),Qr=e=>{let t=null;for(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Zr=(e,t)=>{let n=null;for(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},es=async(e,t)=>{let n=null;for(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},ts=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new xo((function*(){for(const t of e)n(t)&&(yield t)}))};async function*ns(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}function*os(e,t,n,o){const r=((e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}class rs extends Ro{constructor(e){super((async function*(){for await(const t of e())yield*t})),this.orderedPairs=e}static generateAsync(e,t,n,o){let r;return r=e instanceof rs?async function*(){for await(const r of e.orderedPairs())yield*ns(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new rs(r)}static generate(e,t,n,o){let r;return r=e instanceof rs?async function*(){for await(const r of e.orderedPairs())yield*os(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new rs(r)}thenBy(e,t){return rs.generate(this,e,!0,t)}thenByAsync(e,t){return rs.generateAsync(this,e,!0,t)}thenByDescending(e,t){return rs.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return rs.generateAsync(this,e,!1,t)}}function*ss(e,t,n,o){const r=((e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}async function*is(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}class as extends xo{constructor(e){super((function*(){for(const t of e())yield*t})),this.orderedPairs=e}static generate(e,t,n,o){let r;return r=e instanceof as?function*(){for(const r of e.orderedPairs())yield*ss(r,t,n,o)}:()=>ss(e,t,n,o),new as(r)}static generateAsync(e,t,n,o){let r;return r=e instanceof as?async function*(){for(const r of e.orderedPairs())yield*is(r,t,n,o)}:()=>is(e,t,n,o),new rs(r)}thenBy(e,t){return as.generate(this,e,!0,t)}thenByAsync(e,t){return as.generateAsync(this,e,!0,t)}thenByDescending(e,t){return as.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return as.generateAsync(this,e,!1,t)}}const cs=(e,t,n)=>as.generate(e,t,!0,n),ls=(e,t,n)=>as.generateAsync(e,t,!0,n),us=(e,t,n)=>as.generate(e,t,!1,n),ds=(e,t,n)=>as.generateAsync(e,t,!1,n),hs=(e,t)=>{const n=[],o=[];for(const r of e)!0===t(r)?o.push(r):n.push(r);return[o,n]},gs=async(e,t)=>{const n=[],o=[];for(const r of e)!0===await t(r)?o.push(r):n.push(r);return[o,n]},fs=e=>new xo((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),ps=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?vs(e,t):ys(e,t)}return ws(e,t)},vs=(e,t)=>new xo((function*(){for(const n of e)yield t(n)})),ys=(e,t)=>new xo((function*(){let n=0;for(const o of e)yield t(o,n),n++})),ws=(e,t)=>new xo((function*(){for(const n of e)yield n[t]})),ms=(e,t)=>"function"==typeof t?1===t.length?Ss(e,t):_s(e,t):Cs(e,t),Ss=(e,t)=>zo((async function*(){for(const n of e)yield t(n)})),_s=(e,t)=>zo((async function*(){let n=0;for(const o of e)yield t(o,n),n++})),Cs=(e,t)=>zo((async function*(){for(const n of e)yield n[t]})),As=(e,t)=>"function"==typeof t?1===t.length?Ds(e,t):bs(e,t):Gs(e,t),Ds=(e,t)=>new xo((function*(){for(const n of e)for(const e of t(n))yield e})),bs=(e,t)=>new xo((function*(){let n=0;for(const o of e){for(const e of t(o,n))yield e;n++}})),Gs=(e,t)=>new xo((function*(){for(const n of e)for(const e of n[t])yield e})),Es=(e,t)=>1===t.length?Is(e,t):Ts(e,t),Is=(e,t)=>zo((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Ts=(e,t)=>zo((async function*(){let n=0;for(const o of e){const e=await t(o,n);for(const t of e)yield t;n++}})),Ns=(e,t,n=Po)=>{const o=e[Symbol.iterator](),r=t[Symbol.iterator]();let s=o.next(),i=r.next();for(;!s.done&&!i.done;){if(!n(s.value,i.value))return!1;s=o.next(),i=r.next()}return!0===s.done&&!0===i.done},Ps=async(e,t,n)=>{const o=e[Symbol.iterator](),r=t[Symbol.iterator]();let s=o.next(),i=r.next();for(;!s.done&&!i.done;){if(!1===await n(s.value,i.value))return!1;s=o.next(),i=r.next()}return!0===s.done&&!0===i.done},ks=(e,t)=>t?Os(e,t):Rs(e),Rs=e=>{let t=!1,n=null;for(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}if(!1===t)throw new No(To.NoElements);return n},Os=(e,t)=>{let n=!1,o=null;for(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},xs=async(e,t)=>{let n=!1,o=null;for(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},Us=(e,t)=>t?Ms(e,t):Fs(e),Fs=e=>{let t=!1,n=null;for(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}return n},Ms=(e,t)=>{let n=!1,o=null;for(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}return o},$s=async(e,t)=>{let n=!1,o=null;for(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneElement);n=!0,o=r}return o},Ls=(e,t)=>new xo((function*(){let n=0;for(const o of e)n++>=t&&(yield o)})),Ws=(e,t)=>1===t.length?Bs(e,t):Hs(e,t),Bs=(e,t)=>new xo((function*(){let n=!0;for(const o of e)!1===n?yield o:!1===t(o)&&(n=!1,yield o)})),Hs=(e,t)=>new xo((function*(){let n=0,o=!0;for(const r of e)!1===o?yield r:!1===t(r,n)&&(o=!1,yield r),n++})),Vs=(e,t)=>1===t.length?js(e,t):Ks(e,t),js=(e,t)=>zo((async function*(){let n=!0;for(const o of e)!1===n?yield o:!1===await t(o)&&(n=!1,yield o)})),Ks=(e,t)=>zo((async function*(){let n=0,o=!0;for(const r of e)!1===o?yield r:!1===await t(r,n)&&(o=!1,yield r),n++})),zs=(e,t)=>t?Js(e,t):qs(e),qs=e=>{let t=0;for(const n of e)t+=n;return t},Js=(e,t)=>{let n=0;for(const o of e)n+=t(o);return n},Ys=async(e,t)=>{let n=0;for(const o of e)n+=await t(o);return n},Xs=(e,t)=>new xo((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),Qs=(e,t)=>1===t.length?Zs(e,t):ei(e,t),Zs=(e,t)=>new xo((function*(){for(const n of e){if(!t(n))break;yield n}})),ei=(e,t)=>new xo((function*(){let n=0;for(const o of e){if(!t(o,n++))break;yield o}})),ti=(e,t)=>1===t.length?ni(e,t):oi(e,t),ni=(e,t)=>zo((async function*(){for(const n of e){if(!await t(n))break;yield n}})),oi=(e,t)=>zo((async function*(){let n=0;for(const o of e){if(!await t(o,n++))break;yield o}})),ri=e=>[...e],si=(e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},ii=async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},ai=(e,t)=>{const n={};for(const o of e)n[t(o)]=o;return n},ci=async(e,t)=>{const n={};for(const o of e)n[await t(o)]=o;return n},li=e=>new Set(e),ui=(e,t,n)=>n?hi(e,t,n):di(e,t),di=(e,t)=>new xo((function*(){const n=new Set;for(const t of e)!1===n.has(t)&&(yield t,n.add(t));for(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),hi=(e,t,n)=>new xo((function*(){const o=[];for(const r of[e,t])for(const e of r){let t=!1;for(const r of o)if(!0===n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),gi=(e,t,n)=>zo((async function*(){const o=[];for(const r of[e,t])for(const e of r){let t=!1;for(const r of o)if(!0===await n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),fi=(e,t)=>1===t.length?pi(e,t):vi(e,t),pi=(e,t)=>new xo((function*(){for(const n of e)!0===t(n)&&(yield n)})),vi=(e,t)=>new xo((function*(){let n=0;for(const o of e)!0===t(o,n++)&&(yield o)})),yi=(e,t)=>1===t.length?wi(e,t):mi(e,t),wi=(e,t)=>zo((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),mi=(e,t)=>zo((async function*(){let n=0;for(const o of e)!0===await t(o,n++)&&(yield o)})),Si=(e,t,n)=>n?Ci(e,t,n):_i(e,t),_i=(e,t)=>new xo((function*(){const n=e[Symbol.iterator](),o=t[Symbol.iterator]();for(;;){const e=n.next(),t=o.next();if(e.done||t.done)break;yield[e.value,t.value]}})),Ci=(e,t,n)=>new xo((function*(){const o=e[Symbol.iterator](),r=t[Symbol.iterator]();for(;;){const e=o.next(),t=r.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Ai=(e,t,n)=>zo((async function*(){const o=e[Symbol.iterator](),r=t[Symbol.iterator]();for(;;){const e=o.next(),t=r.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Di=e=>{const t=e.prototype,n=(e,n)=>{const o=function(...t){return e(this,...t)};Object.defineProperty(o,"length",{value:e.length-1}),t[n]=o};n(Fo,"aggregate"),n(Wo,"all"),n(Bo,"allAsync"),n(Ho,"any"),n(Ko,"anyAsync"),n(qo,"asAsync"),n(Yo,"asParallel"),n(Xo,"average"),n(Qo,"averageAsync"),n(Zo,"chunk"),n(er,"concatenate"),n(tr,"contains"),n(nr,"containsAsync"),n(or,"count"),n(ir,"countAsync"),n(ar,"defaultIfEmpty"),n(cr,"distinct"),n(lr,"distinctAsync"),n(ur,"each"),n(dr,"eachAsync"),n(hr,"elementAt"),n(gr,"elementAtOrDefault"),n(fr,"except"),n(pr,"exceptAsync"),n(vr,"first"),n(mr,"firstAsync"),n(Sr,"firstOrDefault"),n(Ar,"firstOrDefaultAsync"),n(br,"groupBy"),n(Gr,"groupByAsync"),n(Tr,"groupByWithSel"),n(Nr,"groupJoin"),n(Rr,"groupJoinAsync"),n(Ur,"intersect"),n(Fr,"intersectAsync"),n(Mr,"joinByKey"),n($r,"last"),n(Br,"lastAsync"),n(Hr,"lastOrDefault"),n(Kr,"lastOrDefaultAsync"),n(zr,"max"),n(Yr,"maxAsync"),n(Xr,"min"),n(es,"minAsync"),n(ts,"ofType"),n(cs,"orderBy"),n(ls,"orderByAsync"),n(us,"orderByDescending"),n(ds,"orderByDescendingAsync"),n(fs,"reverse"),n(ps,"select"),n(ms,"selectAsync"),n(As,"selectMany"),n(Es,"selectManyAsync"),n(Ns,"sequenceEquals"),n(Ps,"sequenceEqualsAsync"),n(ks,"single"),n(xs,"singleAsync"),n(Us,"singleOrDefault"),n($s,"singleOrDefaultAsync"),n(Ls,"skip"),n(Ws,"skipWhile"),n(Vs,"skipWhileAsync"),n(zs,"sum"),n(Ys,"sumAsync"),n(Xs,"take"),n(Qs,"takeWhile"),n(ti,"takeWhileAsync"),n(ri,"toArray"),n(si,"toMap"),n(ii,"toMapAsync"),n(ai,"toObject"),n(ci,"toObjectAsync"),n(hs,"partition"),n(gs,"partitionAsync"),n(li,"toSet"),n(ui,"union"),n(gi,"unionAsync"),n(fi,"where"),n(yi,"whereAsync"),n(Si,"zip"),n(Ai,"zipAsync")},bi=(e,t,n,o)=>{if(o){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Ii(e,t,n,o)}return n?Ei(e,t,n):Gi(e,t)},Gi=async(e,t)=>{let n;for await(const o of e)n=n?t(n,o):o;if(void 0===n)throw new No(To.NoElements);return n},Ei=async(e,t,n)=>{let o=t;for await(const t of e)o=n(o,t);return o},Ii=async(e,t,n,o)=>{let r=t;for await(const t of e)r=n(r,t);return o(r)},Ti=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Ni=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},Pi=(e,t)=>t?Ri(e,t):ki(e),ki=async e=>{for await(const t of e)return!0;return!1},Ri=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Oi=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},xi=e=>Jo(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),Ui=async(e,t)=>{let n=0,o=0;if(t)for await(const r of e)n+=t(r),o+=1;else for await(const t of e)n+=t,o+=1;if(0===o)throw new No(To.NoElements);return n/o},Fi=async(e,t)=>{let n=0,o=0;for await(const r of e)n+=await t(r),o+=1;if(0===o)throw new No(To.NoElements);return n/o},Mi=(e,t)=>{if(t<1)throw new Io("index");return new Ro((async function*(){let n=[];for await(const o of e)n.push(o),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},$i=(e,t)=>new Ro((async function*(){yield*e,yield*t})),Li=async(e,t,n=Po)=>{for await(const o of e)if(n(t,o))return!0;return!1},Wi=async(e,t,n)=>{for await(const o of e)if(await n(t,o))return!0;return!1},Bi=(e,t)=>t?Vi(e,t):Hi(e),Hi=async e=>{let t=0;for await(const n of e)t++;return t},Vi=async(e,t)=>{let n=0;for await(const o of e)!0===t(o)&&n++;return n},ji=async(e,t)=>{let n=0;for await(const o of e)!0===await t(o)&&n++;return n},Ki=(e,t)=>new Ro((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),zi=(e,t=Po)=>new Ro((async function*(){const n=[];for await(const o of e)n.find((e=>t(e,o)))||(n.push(o),yield o)})),qi=(e,t)=>new Ro((async function*(){const n=[];e:for await(const o of e){for(const e of n)if(await t(e,o))continue e;n.push(o),yield o}})),Ji=(e,t)=>new Ro((async function*(){for await(const n of e)t(n),yield n})),Yi=(e,t)=>new Ro((async function*(){for await(const n of e)await t(n),yield n})),Xi=async(e,t)=>{if(t<0)throw new Io("index");let n=0;for await(const o of e)if(t===n++)return o;throw new Io("index")},Qi=async(e,t)=>{let n=0;for await(const o of e)if(t===n++)return o;return null},Zi=(e,t,n=Po)=>new Ro((async function*(){const o=[];for await(const e of t)o.push(e);for await(const t of e){let e=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===n(t,s)){e=!0;break}}!1===e&&(yield t)}})),ea=(e,t,n)=>new Ro((async function*(){const o=[];for await(const e of t)o.push(e);for await(const t of e){let e=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),ta=(e,t)=>t?oa(e,t):na(e),na=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new No(To.NoElements);return t.value},oa=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new No(To.NoMatch)},ra=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new No(To.NoMatch)},sa=(e,t)=>t?aa(e,t):ia(e),ia=async e=>(await e[Symbol.asyncIterator]().next()).value||null,aa=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},ca=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},la=(e,t,n)=>n?ua(e,t,n):da(e,t),ua=(e,t,n)=>new Ro((async function*(){const o=new Array;for await(const r of e){const e=t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})),da=(e,t)=>new Ro((async function*(){const n={};for await(const o of e){const e=t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})),ha=(e,t,n)=>n?fa(e,t,n):ga(e,t),ga=(e,t)=>new Ro((async function*(){const n={};for await(const o of e){const e=await t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})),fa=(e,t,n)=>new Ro((async function*(){const o=new Array;for await(const r of e){const e=await t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(!0===await n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})),pa=(e,t,n,o)=>o?ya(e,t,n,o):va(e,t,n),va=(e,t,n)=>new Ro((async function*(){const o={};for await(const r of e){const e=t(r),s=o[e],i=n(r);s?s.push(i):o[e]=new Dr(e,i)}for(const e in o)yield o[e]})),ya=(e,t,n,o)=>new Ro((async function*(){const r=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<r.length;t++){const a=r[t];if(o(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);r.push(new Dr(e,t))}}for(const e of r)yield e})),wa=(e,t,n,o,r,s)=>{const i=s?ma(e,t,n,o,r,s):Sa(e,t,n,o,r);return new Ro(i)},ma=(e,t,n,o,r,s)=>async function*(){var i;const a=[];for await(const e of t){const t=o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},Sa=(e,t,n,o,r)=>async function*(){var s;const i=new Map;for await(const e of t){const t=o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},_a=(e,t,n,o,r,s)=>{const i=s?Ca(e,t,n,o,r,s):Aa(e,t,n,o,r);return new Ro(i)},Ca=(e,t,n,o,r,s)=>async function*(){var i;const a=[];for await(const e of t){const t=await o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=await n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},Aa=(e,t,n,o,r)=>async function*(){var s;const i=new Map;for await(const e of t){const t=await o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=await n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},Da=(e,t,n=Po)=>new Ro((async function*(){const o=await e.distinct(n).toArray();if(0===o.length)return;const r=await t.toArray();for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===n(t,o)){yield t;break}}}})),ba=(e,t,n)=>new Ro((async function*(){const o=await e.distinctAsync(n).toArray();if(0===o.length)return;const r=await t.toArray();for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===await n(t,o)){yield t;break}}}})),Ga=(e,t,n,o,r,s=Po)=>new Ro((async function*(){const i=[];for await(const e of t)i.push(e);for await(const t of e){const e=n(t);for(const n of i){const i=o(n);!0===s(e,i)&&(yield r(t,n))}}})),Ea=(e,t)=>t?Ta(e,t):Ia(e),Ia=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new No(To.NoElements);return t},Ta=async(e,t)=>{let n=null;for await(const o of e)!0===t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Na=async(e,t)=>{let n=null;for await(const o of e)!0===await t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Pa=(e,t)=>t?Ra(e,t):ka(e),ka=async e=>{let t=null;for await(const n of e)t=n;return t},Ra=async(e,t)=>{let n=null;for await(const o of e)!0===t(o)&&(n=o);return n},Oa=async(e,t)=>{let n=null;for await(const o of e)!0===await t(o)&&(n=o);return n},xa=(e,t)=>t?Fa(e,t):Ua(e),Ua=async e=>{let t=null;for await(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Fa=async(e,t)=>{let n=null;for await(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},Ma=async(e,t)=>{let n=null;for await(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},$a=(e,t)=>t?Wa(e,t):La(e),La=async e=>{let t=null;for await(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Wa=async(e,t)=>{let n=null;for await(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},Ba=async(e,t)=>{let n=null;for await(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},Ha=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Ro((async function*(){for await(const t of e)n(t)&&(yield t)}))},Va=(e,t,n)=>rs.generate(e,t,!0,n),ja=(e,t,n)=>rs.generateAsync(e,t,!0,n),Ka=(e,t,n)=>rs.generate(e,t,!1,n),za=(e,t,n)=>rs.generateAsync(e,t,!1,n),qa=async(e,t)=>{const n=[],o=[];for await(const r of e)!0===t(r)?o.push(r):n.push(r);return[o,n]},Ja=async(e,t)=>{const n=[],o=[];for await(const r of e)!0===await t(r)?o.push(r):n.push(r);return[o,n]},Ya=e=>new Ro((async function*(){const t=[];for await(const n of e)t.push(n);for(let e=t.length-1;e>=0;e--)yield t[e]})),Xa=(e,t)=>"function"==typeof t?1===t.length?Qa(e,t):Za(e,t):ec(e,t),Qa=(e,t)=>new Ro((async function*(){for await(const n of e)yield t(n)})),Za=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)yield t(o,n),n++})),ec=(e,t)=>new Ro((async function*(){for await(const n of e)yield n[t]})),tc=(e,t)=>"string"==typeof t?oc(e,t):nc(e,t),nc=(e,t)=>new Ro((async function*(){for await(const n of e)yield t(n)})),oc=(e,t)=>new Ro((async function*(){for await(const n of e)yield n[t]})),rc=(e,t)=>"function"==typeof t?1===t.length?sc(e,t):ic(e,t):ac(e,t),sc=(e,t)=>new Ro((async function*(){for await(const n of e)for(const e of t(n))yield e})),ic=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e){for(const e of t(o,n))yield e;n++}})),ac=(e,t)=>new Ro((async function*(){for await(const n of e)for(const e of n[t])yield e})),cc=(e,t)=>1===t.length?new Ro((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Ro((async function*(){let n=0;for await(const o of e){const e=await t(o,n);for(const t of e)yield t;n++}})),lc=async(e,t,n=Po)=>{const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();let s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1];for(;!i.done&&!a.done;){if(!n(i.value,a.value))return!1;s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},uc=async(e,t,n)=>{const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();let s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1];for(;!i.done&&!a.done;){if(!1===await n(i.value,a.value))return!1;s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},dc=(e,t)=>t?gc(e,t):hc(e),hc=async e=>{let t=!1,n=null;for await(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}if(!1===t)throw new No(To.NoElements);return n},gc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},fc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},pc=(e,t)=>t?yc(e,t):vc(e),vc=async e=>{let t=!1,n=null;for await(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}return n},yc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}return o},wc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}return o},mc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)n++>=t&&(yield o)})),Sc=(e,t)=>1===t.length?_c(e,t):Cc(e,t),_c=(e,t)=>new Ro((async function*(){let n=!0;for await(const o of e)!1===n?yield o:!1===t(o)&&(n=!1,yield o)})),Cc=(e,t)=>new Ro((async function*(){let n=0,o=!0;for await(const r of e)!1===o?yield r:!1===t(r,n)&&(o=!1,yield r),n++})),Ac=(e,t)=>1===t.length?Dc(e,t):bc(e,t),Dc=(e,t)=>new Ro((async function*(){let n=!0;for await(const o of e)!1===n?yield o:!1===await t(o)&&(n=!1,yield o)})),bc=(e,t)=>new Ro((async function*(){let n=0,o=!0;for await(const r of e)!1===o?yield r:!1===await t(r,n)&&(o=!1,yield r),n++})),Gc=(e,t)=>t?Ic(e,t):Ec(e),Ec=async e=>{let t=0;for await(const n of e)t+=n;return t},Ic=async(e,t)=>{let n=0;for await(const o of e)n+=t(o);return n},Tc=async(e,t)=>{let n=0;for await(const o of e)n+=await t(o);return n},Nc=(e,t)=>new Ro((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Pc=(e,t)=>1===t.length?kc(e,t):Rc(e,t),kc=(e,t)=>new Ro((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Rc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e){if(!t(o,n++))break;yield o}})),Oc=(e,t)=>1===t.length?xc(e,t):Uc(e,t),xc=(e,t)=>new Ro((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Uc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e){if(!await t(o,n++))break;yield o}})),Fc=async e=>{const t=[];for await(const n of e)t.push(n);return t},Mc=async(e,t)=>{const n=new Map;for await(const o of e){const e=t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},$c=async(e,t)=>{const n=new Map;for await(const o of e){const e=await t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},Lc=async(e,t)=>{const n={};for await(const o of e)n[t(o)]=o;return n},Wc=async(e,t)=>{const n={};for await(const o of e)n[await t(o)]=o;return n},Bc=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Hc=(e,t,n)=>n?jc(e,t,n):Vc(e,t),Vc=(e,t)=>new Ro((async function*(){const n=new Set;for await(const t of e)!1===n.has(t)&&(yield t,n.add(t));for await(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),jc=(e,t,n)=>new Ro((async function*(){const o=[];for(const r of[e,t])for await(const e of r){let t=!1;for(const r of o)if(!0===n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),Kc=(e,t,n)=>new Ro((async function*(){const o=[];for(const r of[e,t])for await(const e of r){let t=!1;for(const r of o)if(!0===await n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),zc=(e,t)=>1===t.length?qc(e,t):Jc(e,t),qc=(e,t)=>new Ro((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Jc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)!0===t(o,n++)&&(yield o)})),Yc=(e,t)=>1===t.length?Xc(e,t):Qc(e,t),Xc=(e,t)=>new Ro((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),Qc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)!0===await t(o,n++)&&(yield o)})),Zc=(e,t,n)=>n?tl(e,t,n):el(e,t),el=(e,t)=>new Ro((async function*(){const n=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([n.next(),o.next()]);if(e.done||t.done)break;yield[e.value,t.value]}})),tl=(e,t,n)=>new Ro((async function*(){const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([o.next(),r.next()]);if(e.done||t.done)break;yield n(e.value,t.value)}})),nl=(e,t,n)=>new Ro((async function*(){const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();for(;;){const e=await Promise.all([o.next(),r.next()]),t=e[0],s=e[1];if(t.done||s.done)break;yield n(t.value,s.value)}})),ol=(e,t,n,o)=>{if(o){if(!n)throw new ReferenceError("TAccumulate function is undefined");return il(e,t,n,o)}return n?sl(e,t,n):rl(e,t)},rl=async(e,t)=>{let n;for await(const o of e)n=n?t(n,o):o;if(void 0===n)throw new No(To.NoElements);return n},sl=async(e,t,n)=>{let o=t;for await(const t of e)o=n(o,t);return o},il=async(e,t,n,o)=>{let r=t;for await(const t of e)r=n(r,t);return o(r)},al=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:()=>n.generator().then((e=>{const n=new Array(e.length);for(let o=0;o<e.length;o++)n[o]=t(e[o]);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then(t);return o},type:1};case 2:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then(t);return o},type:2}}},cl=(e,t)=>{const n=al(e,(e=>{if(!t(e))throw new Error(String(!1));return!0}));switch(n.type){case 0:return n.generator().then((()=>!0),(()=>!1));case 1:return Promise.all(n.generator()).then((()=>!0),(()=>!1));case 2:return n.generator().then(Promise.all.bind(Promise)).then((()=>!0),(()=>!1))}},ll=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=t(e[n]);return o},type:2};case 1:return{generator:()=>n.generator().map((async e=>{const n=await e;return await t(n)})),type:1};case 2:return{generator:async()=>(await n.generator()).map((e=>e.then(t))),type:2}}},ul=(e,t)=>{const n=ll(e,(async e=>{if(!1===await t(e))throw new Error(String(!1));return!0}));switch(n.type){case 1:return Promise.all(n.generator()).then((()=>!0),(()=>!1));case 2:return n.generator().then(Promise.all.bind(Promise)).then((()=>!0),(()=>!1))}},dl=(e,t)=>t?gl(e,t):hl(e),hl=async e=>{const t=e.dataFunc;let n;switch(t.type){case 1:return n=t.generator(),0!==n.length;case 0:case 2:return n=await t.generator(),0!==n.length}},gl=async(e,t)=>{const n=al(e,t);let o;switch(n.type){case 0:return o=await n.generator(),o.includes(!0);case 1:return o=await Promise.all(n.generator()),o.includes(!0);case 2:return o=await Promise.all(await n.generator()),o.includes(!0)}},fl=async(e,t)=>{const n=ll(e,t);let o;switch(n.type){case 1:return o=n.generator(),0!==o.length&&new Promise(((e,t)=>{let n=0;for(const r of o)r.then((t=>{n++,t?e(!0):n===o.length&&e(!1)}),t)}));case 2:return o=await n.generator(),0===Promise.length?!1:(await Promise.all(o)).includes(!0)}},pl=e=>zo((async function*(){for await(const t of e)yield t})),vl=async e=>{switch(e.type){case 0:return await e.generator();case 1:return await Promise.all(e.generator());case 2:const t=await e.generator();return await Promise.all(t)}},yl=async(e,t)=>{let n;n=t?al(e,t):e.dataFunc;const o=await vl(n);if(0===o.length)throw new No(To.NoElements);let r=0;for(const e of o)r+=e;return r/o.length},wl=async(e,t)=>{const n=ll(e,t),o=await vl(n);if(0===o.length)throw new No(To.NoElements);let r=0;for(const e of o)r+=e;return r/o.length},ml=(e,t)=>{if(t<1)throw new Io("index");let n;switch(e.dataFunc.type){case 1:const o=e.dataFunc.generator;n={type:1,generator:()=>{const e=[];let n=[];for(const r of o())n.push(r),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 2:const r=e.dataFunc.generator;n={type:2,generator:async()=>{const e=[];let n=[];for(const o of await r())n.push(o),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 0:const s=e.dataFunc.generator;n={type:0,generator:async()=>{const e=[];let n=[];for(const o of await s())n.push(o),n.length===t&&(e.push(n),n=[]);return n.length&&e.push(n),e}}}return new Oo(n)},Sl=(e,t)=>new Oo({generator:async()=>{const[n,o]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...o]},type:0}),_l=async(e,t,n=Po)=>{let o;switch(o=al(e,n?e=>n(t,e):e=>e===t),o.type){case 0:return(await o.generator()).some((e=>e));case 1:return(await Promise.all(o.generator())).some((e=>e));case 2:return(await Promise.all(await o.generator())).some((e=>e))}},Cl=async(e,t,n)=>{const o=ll(e,(e=>n(t,e)));switch(o.type){case 1:return(await Promise.all(o.generator())).some((e=>e));case 2:return(await Promise.all(await o.generator())).some((e=>e))}},Al=(e,t)=>t?bl(e,t):Dl(e),Dl=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},bl=async(e,t)=>{const n=await e.toArray();let o=0;for(let e=0;e<n.length;e++)!0===t(n[e])&&o++;return o},Gl=async(e,t)=>{const n=ll(e,t);let o;switch(n.type){case 1:o=Promise.all(n.generator());break;case 2:o=Promise.all(await n.generator())}let r=0;for(const e of await o)e&&r++;return r},El=(e,t)=>{const n=e.dataFunc,o=t instanceof Promise;let r;switch(n.type){case 0:r={generator:()=>n.generator().then((e=>e.length?e:o?t.then((e=>[e])):[t])),type:n.type};break;case 1:r={generator:()=>{const e=n.generator();return e.length?e:o?[t]:[Promise.resolve(t)]},type:n.type};break;case 2:r={generator:async()=>{const e=await n.generator();return e.length?e:o?[t]:[Promise.resolve(t)]},type:n.type}}return new Oo(r)},Il=(e,t=Po)=>new Oo({generator:async()=>{const n=[];for(const o of await e.toArray())n.find((e=>t(e,o)))||n.push(o);return n},type:0}),Tl=(e,t)=>new Oo({generator:async()=>{const n=[];e:for(const o of await e.toArray()){for(const e of n)if(await t(e,o))continue e;n.push(o)}return n},type:0}),Nl=(e,t)=>new Oo(al(e,(e=>(t(e),e)))),Pl=(e,t)=>{const n=ll(e,(async e=>(await t(e),e)));return new Oo(n)},kl=async(e,t)=>{if(t<0)throw new Io("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new Io("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new Io("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new Io("index");return await e[t]}}},Rl=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();return t>=e.length?null:e[t]}case 1:{const e=n.generator();return t>=e.length?null:await e[t]}case 2:{const e=await n.generator();return t>=e.length?null:await e[t]}}},Ol=(e,t,n=Po)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of o){let t=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),xl=(e,t,n)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of o){let t=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===await n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),Ul=e=>vl(e.dataFunc),Fl=(e,t)=>t?$l(e,t):Ml(e),Ml=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new No(To.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return await e[0]}}},$l=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===t(e))return e;throw new No(To.NoMatch)},Ll=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===await t(e))return e;throw new No(To.NoMatch)},Wl=(e,t)=>t?Hl(e,t):Bl(e),Bl=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();return 0===e.length?null:e[0]}case 1:{const e=t.generator();return 0===e.length?null:await e[0]}case 2:{const e=await t.generator();return 0===e.length?null:await e[0]}}},Hl=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===t(e))return e;return null},Vl=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===await t(e))return e;return null},jl=(e,t,n)=>n?zl(e,t,n):Kl(e,t),Kl=(e,t)=>new Oo({generator:async()=>{const n={};for(const o of await e.toArray()){const e=t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}const o=new Array;for(const e in n)o.push(n[e]);return o},type:0}),zl=(e,t,n)=>new Oo({generator:async()=>{const o=new Array;for(const r of await e.toArray()){const e=t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}const r=new Array;for(const e of o)r.push(e);return r},type:0}),ql=(e,t,n)=>n?Jl(e,t,n):Yl(e,t),Jl=(e,t,n)=>new Oo({generator:async()=>{const o=ll(e,(async e=>[await t(e),e]));let r;switch(o.type){case 1:r=await Promise.all(o.generator());break;case 2:r=await Promise.all(await o.generator())}const s=new Array;for(const[e,t]of r){let o=!1;for(let r=0;r<s.length;r++){const i=s[r];if(!0===await n(i.key,e)){i.push(t),o=!0;break}}!1===o&&s.push(new Dr(e,t))}const i=new Array;for(const e of s)i.push(e);return i},type:0}),Yl=(e,t)=>new Oo({generator:async()=>{const n=ll(e,(async e=>[await t(e),e]));let o;switch(n.type){case 1:o=await Promise.all(n.generator());break;case 2:o=await Promise.all(await n.generator())}const r={};for(const[e,t]of o){const n=r[e];n?n.push(t):r[e]=new Dr(e,t)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),Xl=(e,t,n,o)=>o?Ql(e,t,n,o):Zl(e,t,n),Ql=(e,t,n,o)=>new Oo({generator:async()=>{const r=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<r.length;t++){const a=r[t];if(o(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);r.push(new Dr(e,t))}}const s=new Array;for(const e of r)s.push(e);return s},type:0}),Zl=(e,t,n)=>new Oo({generator:async()=>{const o={};for(const r of await e.toArray()){const e=t(r),s=o[e],i=n(r);s?s.push(i):o[e]=new Dr(e,i)}const r=new Array;for(const e in o)r.push(o[e]);return r},type:0}),eu=(e,t,n,o,r,s)=>{const i=s?tu(e,t,n,o,r,s):nu(e,t,n,o,r);return new Oo({generator:i,type:0})},tu=(e,t,n,o,r,s)=>async()=>{const i=[];for await(const e of t){const t=o(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}return(await e.toArray()).map((e=>{var t;const o=n(e),a=null!==(t=i.find((e=>s(e.key,o))))&&void 0!==t?t:{key:o,values:[]};return r(e,a.values)}))},nu=(e,t,n,o,r)=>async()=>{const s=new Map;for await(const e of t){const t=o(e),n=s.get(t);n?n.push(e):s.set(t,[e])}return(await e.toArray()).map((e=>{var t;const o=n(e),i=null!==(t=s.get(o))&&void 0!==t?t:[];return r(e,i)}))},ou=(e,t,n,o,r,s)=>{const i=s?ru(e,t,n,o,r,s):su(e,t,n,o,r);return new Oo({generator:i,type:0})},ru=(e,t,n,o,r,s)=>async()=>{const i=[];for await(const e of t){const t=await o(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}const a=(await e.toArray()).map((async e=>{var t;const o=await n(e),a=null!==(t=i.find((e=>s(e.key,o))))&&void 0!==t?t:{key:o,values:[]};return r(e,a.values)}));return await Promise.all(a)},su=(e,t,n,o,r)=>async()=>{const s=new Map;for await(const e of t){const t=await o(e),n=s.get(t);n?n.push(e):s.set(t,[e])}const i=(await e.toArray()).map((async e=>{var t;const o=await n(e),i=null!==(t=s.get(o))&&void 0!==t?t:[];return r(e,i)}));return await Promise.all(i)},iu=(e,t,n=Po)=>new Oo({generator:async()=>{const o=await e.distinct(n).toArray();if(0===o.length)return[];const r=await t.toArray(),s=new Array;for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===n(t,o)){s.push(t);break}}}return s},type:0}),au=(e,t,n)=>new Oo({generator:async()=>{const o=await e.distinctAsync(n).toArray();if(0===o.length)return[];const r=await t.toArray(),s=new Array;for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===await n(t,o)){s.push(t);break}}}return s},type:0}),cu=(e,t,n,o,r,s=Po)=>new Oo({generator:async()=>{const[i,a]=await Promise.all([t.toArray(),e.toArray()]),c=new Array;for(const e of a){const t=n(e);for(const n of i){const i=o(n);!0===s(t,i)&&c.push(r(e,n))}}return c},type:0}),lu=(e,t)=>t?du(e,t):uu(e),uu=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new No(To.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return await e[e.length-1]}}},du=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}}throw new No(To.NoMatch)},hu=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(!0===await t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}}throw new No(To.NoMatch)},gu=(e,t)=>t?pu(e,t):fu(e),fu=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();return 0===e.length?null:e[e.length-1]}case 1:{const e=t.generator();return 0===e.length?null:await e[e.length-1]}case 2:{const e=await t.generator();return 0===e.length?null:await e[e.length-1]}}},pu=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}}return null},vu=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(!0===await t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}}return null},yu=async(e,t)=>{let n;n=t?al(e,t):e.dataFunc;const o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.max.apply(null,o)},wu=async(e,t)=>{const n=ll(e,t),o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.max.apply(null,o)},mu=async(e,t)=>{let n;n=t?al(e,t):e.dataFunc;const o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.min.apply(null,o)},Su=async(e,t)=>{const n=ll(e,t),o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.min.apply(null,o)},_u=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Oo({generator:async()=>{const t=al(e,n),o=await vl(t),r=[];for(const[e,t]of o)e&&r.push(t);return r},type:0})};async function*Cu(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}async function*Au(e,t,n,o){const r=((e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}class Du extends Oo{constructor(e){super({generator:async()=>{const t=e(),n=[];for await(const e of t)n.push(...e);return n},type:0}),this.orderedPairs=e}static generateAsync(e,t,n,o){let r;return r=e instanceof Du?async function*(){for await(const r of e.orderedPairs())yield*Cu(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new Du(r)}static generate(e,t,n,o){let r;return r=e instanceof Du?async function*(){for await(const r of e.orderedPairs())yield*Au(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new Du(r)}thenBy(e,t){return Du.generate(this,e,!0,t)}thenByAsync(e,t){return Du.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Du.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Du.generateAsync(this,e,!1,t)}}const bu=(e,t,n)=>Du.generate(e,t,!0,n),Gu=(e,t,n)=>Du.generateAsync(e,t,!0,n),Eu=(e,t,n)=>Du.generate(e,t,!1,n),Iu=(e,t,n)=>Du.generateAsync(e,t,!1,n),Tu=async(e,t)=>{const n=al(e,(e=>[t(e),e])),o=await vl(n),r=[],s=[];for(const[e,t]of o)e?s.push(t):r.push(t);return[s,r]},Nu=async(e,t)=>{const n=ll(e,(async e=>[await t(e),e])),o=await vl(n),r=[],s=[];for(const[e,t]of o)e?s.push(t):r.push(t);return[s,r]},Pu=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Oo({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Oo({generator:async()=>(await t.generator()).reverse(),type:t.type})}},ku=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:()=>n.generator().then((e=>{const n=new Array(e.length);for(let o=0;o<e.length;o++)n[o]=t(e[o],o);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then((e=>t(e,n)));return o},type:1};case 2:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then((e=>t(e,n)));return o},type:2}}},Ru=(e,t)=>"function"==typeof t?1===t.length?new Oo(al(e,t)):new Oo(ku(e,t)):new Oo(al(e,(e=>e[t]))),Ou=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=t(e[n],n);return o},type:2};case 1:return{generator:()=>n.generator().map(((e,n)=>e.then((e=>t(e,n))))),type:1};case 2:return{generator:async()=>(await n.generator()).map(((e,n)=>e.then((e=>t(e,n))))),type:2}}},xu=(e,t)=>{let n;return n="function"==typeof t?1===t.length?ll(e,t):Ou(e,t):ll(e,(e=>e[t])),new Oo(n)},Uu=(e,t)=>new Oo({generator:async()=>{let n;n="function"==typeof t?1===t.length?al(e,t):ku(e,t):al(e,(e=>e[t]));const o=[];switch(n.type){case 0:for(const e of await n.generator())for(const t of e)o.push(t);break;case 1:for(const e of n.generator())for(const t of await e)o.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)o.push(t)}return o},type:0}),Fu=(e,t)=>new Oo({generator:async()=>{let n;n=1===t.length?ll(e,t):Ou(e,t);const o=[];switch(n.type){case 1:for(const e of n.generator())for(const t of await e)o.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)o.push(t)}return o},type:0}),Mu=async(e,t,n=Po)=>{const o=await e.toArray(),r=await t.toArray();if(o.length!==r.length)return!1;for(let e=0;e<o.length;e++)if(!1===n(o[e],r[e]))return!1;return!0},$u=async(e,t,n)=>{const o=await e.toArray(),r=await t.toArray();if(o.length!==r.length)return!1;for(let e=0;e<o.length;e++){const t=o[e],s=r[e];if(!1===await n(t,s))return!1}return!0},Lu=(e,t)=>t?Bu(e,t):Wu(e),Wu=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);if(0===e.length)throw new No(To.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);if(0===e.length)throw new No(To.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);if(0===e.length)throw new No(To.NoElements);return await e[0]}}},Bu=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(t(e)){if(!0===o)throw new No(To.MoreThanOneMatchingElement);o=!0,r=e}if(!1===o)throw new No(To.NoMatch);return r},Hu=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(!0===await t(e)){if(!0===o)throw new No(To.MoreThanOneMatchingElement);o=!0,r=e}if(!1===o)throw new No(To.NoMatch);return r},Vu=(e,t)=>t?Ku(e,t):ju(e),ju=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);return 0===e.length?null:await e[0]}}},Ku=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(t(e)){if(!0===o)throw new No(To.MoreThanOneElement);o=!0,r=e}return r},zu=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(!0===await t(e)){if(!0===o)throw new No(To.MoreThanOneElement);o=!0,r=e}return r},qu=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Oo({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Oo({generator:()=>n.generator().slice(t),type:1});case 2:return new Oo({generator:async()=>(await n.generator()).slice(t),type:2})}},Ju=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray();let o=0;for(;o<n.length;o++){const e=n[o];if(!1===t(e,o))break}const r=[];for(;o<n.length;o++)r.push(n[o]);return r},type:0}),Yu=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray();let o=0;for(;o<n.length;o++){const e=n[o];if(!1===await t(e,o))break}const r=[];for(;o<n.length;o++)r.push(n[o]);return r},type:0}),Xu=(e,t)=>t?Zu(e,t):Qu(e),Qu=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},Zu=async(e,t)=>{let n=0;for(const o of await e.toArray())n+=t(o);return n},ed=async(e,t)=>{const n=ll(e,t),o=await vl(n);let r=0;for(const e of o)r+=e;return r},td=(e,t)=>{const n=t>0?t:0,o=e.dataFunc;switch(o.type){case 1:return new Oo({generator:()=>o.generator().splice(0,n),type:1});case 2:return new Oo({generator:()=>o.generator().then((e=>e.splice(0,n))),type:2});default:return new Oo({generator:()=>o.generator().then((e=>e.splice(0,n))),type:0})}},nd=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray(),o=new Array;if(1===t.length)for(const e of n){if(!0!==t(e))break;o.push(e)}else for(let e=0;e<n.length;e++){const r=n[e];if(!0!==t(r,e))break;o.push(r)}return o},type:0}),od=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray(),o=new Array;if(1===t.length){const e=t;for(const t of n){if(!0!==await e(t))break;o.push(t)}}else for(let e=0;e<n.length;e++){const r=n[e];if(!0!==await t(r,e))break;o.push(r)}return o},type:0}),rd=async(e,t)=>{const n=new Map,o=al(e,(e=>[t(e),e])),r=await vl(o);for(const[e,t]of r){const o=n.get(e);void 0===o?n.set(e,[t]):o.push(t)}return n},sd=async(e,t)=>{const n=new Map,o=ll(e,(async e=>[await t(e),e])),r=await vl(o);for(const[e,t]of r){const o=n.get(e);void 0===o?n.set(e,[t]):o.push(t)}return n},id=async(e,t)=>{const n=e.dataFunc,o=await vl(n),r={};for(const e of o)r[t(e)]=e;return r},ad=async(e,t)=>{const n=ll(e,(async e=>[await t(e),e])),o=await vl(n),r={};for(const[e,t]of o)r[e]=t;return r},cd=async e=>{const t=e.dataFunc,n=await vl(t);return new Set(n)},ld=(e,t,n)=>n?dd(e,t,n):ud(e,t),ud=(e,t)=>new Oo({generator:async()=>{const n=new Set,o=t.toArray();for await(const t of e)!1===n.has(t)&&n.add(t);const r=await o;for(const e of r)!1===n.has(e)&&n.add(e);return[...n.keys()]},type:0}),dd=(e,t,n)=>new Oo({generator:async()=>{const o=[],r=await Promise.all([e.toArray(),t.toArray()]);for(const e of r)for(const t of e){let e=!1;for(const r of o)if(!0===n(t,r)){e=!0;break}!1===e&&o.push(t)}return o},type:0}),hd=(e,t,n)=>new Oo({generator:async()=>{const o=[],r=await Promise.all([e.toArray(),t.toArray()]);for(const e of r)for(const t of e){let e=!1;for(const r of o)if(!0===await n(t,r)){e=!0;break}!1===e&&o.push(t)}return o},type:0}),gd=(e,t)=>new Oo({generator:async()=>(await e.toArray()).filter(t),type:0}),fd=(e,t)=>new Oo({generator:async()=>{const n=Ou(e,(async(e,n)=>[await t(e,n),e])),o=await vl(n),r=[];for(const[e,t]of o)e&&r.push(t);return r},type:0}),pd=(e,t,n)=>n?yd(e,t,n):vd(e,t),vd=(e,t)=>new Oo({generator:async()=>{const[n,o]=await Promise.all([e.toArray(),t.toArray()]),r=n.length<o.length?n.length:o.length,s=new Array(r);for(let e=0;e<r;e++){const t=n[e],r=o[e];s[e]=[t,r]}return s},type:0}),yd=(e,t,n)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=o.length<r.length?o.length:r.length,i=new Array(s);for(let e=0;e<s;e++){const t=o[e],s=r[e];i[e]=n(t,s)}return i},type:0}),wd=(e,t,n)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=o.length<r.length?o.length:r.length,i=new Array(s);for(let e=0;e<s;e++){const t=o[e],s=r[e];i[e]=n(t,s)}return Promise.all(i)},type:0});Di(xo),(e=>{const t=e.prototype,n=(e,n)=>{const o=function(...t){return e(this,...t)};Object.defineProperty(o,"length",{value:e.length-1}),t[n]=o};n(bi,"aggregate"),n(Ti,"all"),n(Ni,"allAsync"),n(Pi,"any"),n(Oi,"anyAsync"),n(xi,"asParallel"),n(Ui,"average"),n(Fi,"averageAsync"),n(Mi,"chunk"),n($i,"concatenate"),n(Li,"contains"),n(Wi,"containsAsync"),n(Bi,"count"),n(ji,"countAsync"),n(Ki,"defaultIfEmpty"),n(zi,"distinct"),n(qi,"distinctAsync"),n(Ji,"each"),n(Yi,"eachAsync"),n(Xi,"elementAt"),n(Qi,"elementAtOrDefault"),n(Zi,"except"),n(ea,"exceptAsync"),n(ta,"first"),n(ra,"firstAsync"),n(sa,"firstOrDefault"),n(ca,"firstOrDefaultAsync"),n(la,"groupBy"),n(ha,"groupByAsync"),n(pa,"groupByWithSel"),n(wa,"groupJoin"),n(_a,"groupJoinAsync"),n(Da,"intersect"),n(ba,"intersectAsync"),n(Ga,"joinByKey"),n(Ea,"last"),n(Na,"lastAsync"),n(Pa,"lastOrDefault"),n(Oa,"lastOrDefaultAsync"),n(xa,"max"),n(Ma,"maxAsync"),n($a,"min"),n(Ba,"minAsync"),n(Ha,"ofType"),n(Va,"orderBy"),n(ja,"orderByAsync"),n(Ka,"orderByDescending"),n(za,"orderByDescendingAsync"),n(qa,"partition"),n(Ja,"partitionAsync"),n(Ya,"reverse"),n(Xa,"select"),n(tc,"selectAsync"),n(rc,"selectMany"),n(cc,"selectManyAsync"),n(lc,"sequenceEquals"),n(uc,"sequenceEqualsAsync"),n(dc,"single"),n(fc,"singleAsync"),n(pc,"singleOrDefault"),n(wc,"singleOrDefaultAsync"),n(mc,"skip"),n(Sc,"skipWhile"),n(Ac,"skipWhileAsync"),n(Gc,"sum"),n(Tc,"sumAsync"),n(Nc,"take"),n(Pc,"takeWhile"),n(Oc,"takeWhileAsync"),n(Fc,"toArray"),n(Mc,"toMap"),n($c,"toMapAsync"),n(Lc,"toObject"),n(Wc,"toObjectAsync"),n(Bc,"toSet"),n(Hc,"union"),n(Kc,"unionAsync"),n(zc,"where"),n(Yc,"whereAsync"),n(Zc,"zip"),n(nl,"zipAsync")})(Ro),(e=>{const t=e.prototype,n=(e,n)=>{const o=function(...t){return e(this,...t)};Object.defineProperty(o,"length",{value:e.length-1}),t[n]=o};n(ol,"aggregate"),n(cl,"all"),n(ul,"allAsync"),n(dl,"any"),n(fl,"anyAsync"),n(pl,"asAsync"),n(yl,"average"),n(wl,"averageAsync"),n(ml,"chunk"),n(Sl,"concatenate"),n(_l,"contains"),n(Cl,"containsAsync"),n(Al,"count"),n(Gl,"countAsync"),n(El,"defaultIfEmpty"),n(Il,"distinct"),n(Tl,"distinctAsync"),n(Nl,"each"),n(Pl,"eachAsync"),n(kl,"elementAt"),n(Rl,"elementAtOrDefault"),n(Ol,"except"),n(xl,"exceptAsync"),n(Fl,"first"),n(Ll,"firstAsync"),n(Wl,"firstOrDefault"),n(Vl,"firstOrDefaultAsync"),n(jl,"groupBy"),n(ql,"groupByAsync"),n(Xl,"groupByWithSel"),n(eu,"groupJoin"),n(ou,"groupJoinAsync"),n(eu,"groupJoin"),n(ou,"groupJoinAsync"),n(iu,"intersect"),n(au,"intersectAsync"),n(cu,"joinByKey"),n(lu,"last"),n(hu,"lastAsync"),n(gu,"lastOrDefault"),n(vu,"lastOrDefaultAsync"),n(yu,"max"),n(wu,"maxAsync"),n(mu,"min"),n(Su,"minAsync"),n(_u,"ofType"),n(bu,"orderBy"),n(Gu,"orderByAsync"),n(Eu,"orderByDescending"),n(Iu,"orderByDescendingAsync"),n(Tu,"partition"),n(Nu,"partitionAsync"),n(Pu,"reverse"),n(Ru,"select"),n(xu,"selectAsync"),n(Uu,"selectMany"),n(Fu,"selectManyAsync"),n(Mu,"sequenceEquals"),n($u,"sequenceEqualsAsync"),n(Lu,"single"),n(Hu,"singleAsync"),n(Vu,"singleOrDefault"),n(zu,"singleOrDefaultAsync"),n(qu,"skip"),n(Ju,"skipWhile"),n(Yu,"skipWhileAsync"),n(Xu,"sum"),n(ed,"sumAsync"),n(td,"take"),n(nd,"takeWhile"),n(od,"takeWhileAsync"),n(Ul,"toArray"),n(rd,"toMap"),n(sd,"toMapAsync"),n(id,"toObject"),n(ad,"toObjectAsync"),n(cd,"toSet"),n(ld,"union"),n(hd,"unionAsync"),n(gd,"where"),n(fd,"whereAsync"),n(pd,"zip"),n(wd,"zipAsync")})(Oo),(()=>{var e;const{prototype:t}=ko,n=Object.getOwnPropertyNames(xo.prototype);for(const o of n)t[o]=null!==(e=t[o])&&void 0!==e?e:xo.prototype[o];t.all=function(e){return this.every(e)},t.any=function(e){return e?this.some(e):0!==this.length},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Io("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new No(To.NoMatch);return t}if(0===this.length)throw new No(To.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new No(To.NoMatch)}if(0===this.length)throw new No(To.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.max=function(e){if(0===this.length)throw new No(To.NoElements);if(e){let t=Number.NEGATIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.max(e(this[n]),t);return t}return Math.max.apply(null,this)},t.min=function(e){if(0===this.length)throw new No(To.NoElements);if(e){let t=Number.POSITIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.min(e(this[n]),t);return t}return Math.min.apply(null,this)},t.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var md;!function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(md||(md={}));class Sd{constructor(){this._guid="",this._name="",this._position=0,this._objectsOrder={},null==Sd._devicesService&&(Sd._devicesService=Uh.Get(oo.ServiceName))}GetDevicesChannelsInGroupAsync(e=!1){return t=this,n=void 0,r=function*(){let t=[];for(let n of yield Uh.Get(oo.ServiceName).GetDevicesAsync(e))for(let e of n.Channels.where((e=>e.ChannelGroups.any((e=>e===this._guid)))))t.push(e);let n=[];if(void 0!==this._objectsOrder&&null!==this._objectsOrder&&Object.entries(this._objectsOrder).length>0){const e=Object.keys(this._objectsOrder).map(Number).sort(((e,t)=>e-t));for(let o of e){const e=t.firstOrDefault((e=>e.ChannelId===this._objectsOrder[o]));null!==e&&n.push(e)}return t.forEach((e=>{n.any((t=>t.ChannelId===e.ChannelId))||n.push(e)})),n}return t},new((o=void 0)||(o=Promise))((function(e,s){function i(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(t){var n;t.done?e(t.value):(n=t.value,n instanceof o?n:new o((function(e){e(n)}))).then(i,a)}c((r=r.apply(t,n||[])).next())}));var t,n,o,r}get Guid(){return this._guid}set Guid(e){this._guid=e}get Name(){return this._name}set Name(e){this._name=e}get OrderPosition(){return this._position}set OrderPosition(e){this._position=e}get ObjectsOrder(){return this._objectsOrder}set ObjectsOrder(e){this._objectsOrder=e}ChangeNameAsync(e){return Uh.Get(Ad.ServiceName).ChangeGroupNameAsync(this,e)}}var _d,Cd=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Ad{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._connection=Uh.Get(Vt.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{Uh.Get(He.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Cd(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}ChangeGroupsOrderAsync(e){var t;return Cd(this,void 0,void 0,(function*(){const n=e.select((e=>e.Guid)).toArray(),o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new bd(n),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==o?void 0:o.Status}))}ChangeObjectsPositionsInGroupAsync(e,t){var n;return Cd(this,void 0,void 0,(function*(){const o=t.select((e=>e.ChannelId)).toArray(),r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Id(e.Guid,o),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==r?void 0:r.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==r?void 0:r.Status}))}IsGroupsAndObjectsOrderingAvailable(){return!this._groups.any((e=>void 0===e.ObjectsOrder||null===e.ObjectsOrder))}MoveGroupPositionAsync(e,t){var n;return Cd(this,void 0,void 0,(function*(){const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Dd(e.Guid,t),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==o?void 0:o.Status}))}MoveObjectInGroupPositionAsync(e,t,n){var o;return Cd(this,void 0,void 0,(function*(){const r=`${t.GetDevice().Guid}_${t.Number}`,s=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Ed(e.Guid,r,n),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==s?void 0:s.Status}))}AddDeviceChannelToGroupByGuidAsync(e,t){var n,o;return Cd(this,void 0,void 0,(function*(){const r=new Od;if(r.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");r.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,r.Data.GroupGuid=t;const s=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(r,15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=s&&null!=s.Status?(s.Status==se.OK&&e.ChannelGroups.push(t),yield this.GetGroupsAsync(!1),s.Status):(yield this.GetGroupsAsync(),se.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){var n,o;return Cd(this,void 0,void 0,(function*(){const r=new xd;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");r.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,r.Data.Channel=e.Number,r.Data.GroupGuid=t;const s=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(r,15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=s&&null!=s.Status?(s.Status==se.OK&&(e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray()),yield this.GetGroupsAsync(),s.Status):(yield this.GetGroupsAsync(),se.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Cd(this,void 0,void 0,(function*(){if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupAsync(e.Name);if(!(t instanceof Sd))return t instanceof Ce?t:new Ce(md.UnknownError,"");e=t}for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`),new Ce(md.UnknownError,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`)}let n=yield Uh.Get(oo.ServiceName).GetDevicesAsync();for(let s of n)for(let n of s.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var r of n.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),new Ce(md.UnknownError,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`)}return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Cd(this,void 0,void 0,(function*(){for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),se.FatalError}let n=yield Uh.Get(oo.ServiceName).GetDevicesAsync();for(let s of n)for(let n of s.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var r of n.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),se.FatalError}return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),se.OK}))}ChangeGroupNameByGuidAsync(e,t){var n,o;return Cd(this,void 0,void 0,(function*(){let r=new Rd,s=new Ud;s.Guid=e,s.Name=t,null===(n=r.Data)||void 0===n||n.push(s);const i=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(r,15e3,!1);if(Uh.Get(Ke.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status)switch(i.Status){case se.OK:return new Ce(md.Success,"");case se.WrongData:switch(i.Data){case"NameToShort":return new Ce(md.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ce(md.NameAlreadyExists,"Group with this name already exists");default:return new Ce(md.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Ce(md.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Ce(md.UnknownError,"")}))}GetServiceName(){return Ad.ServiceName}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}GetGroupByGuid(e){return this._groups.first((t=>t.Guid===e))}ChangeGroupNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}RemoveGroupAsync(e){return this.RemoveGroupByGuidAsync(e.Guid)}RemoveGroupByGuidAsync(e){var t;return Cd(this,void 0,void 0,(function*(){let n=new Pd;n.Data=e;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync();for(let t of yield Uh.Get(oo.ServiceName).GetDevicesAsync())for(let n of t.Channels)n.ChannelGroups.any((t=>t===e))&&(n.ChannelGroups=n.ChannelGroups.except(e,((e,t)=>e===t)).toArray());return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=o&&null!=o.Status?null==o?void 0:o.Status:se.Error}))}GetGroupsAsync(e=!1){var t,n;return Cd(this,void 0,void 0,(function*(){const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new kd,15e3,e);let s=[];if((null==r?void 0:r.Status)===se.OK){let e=Uh.Get(o.ServiceName);return null===(n=r.Data)||void 0===n||n.forEach((t=>{let n=new Sd;n.Guid=t.Guid,n.Name=t.Name,n.ObjectsOrder=t.ObjectsOrder,n.OrderPosition=t.OrderPosition,e.Info(Ad.ServiceName,`Got group: ${t.Name} ${t.Guid} order: ${n.OrderPosition} objects order: ${JSON.stringify(n.ObjectsOrder)}`),s.push(n)})),this._groups=s,s}throw new Error(`Failed to get groups, API responded with status ${null==r?void 0:r.Status} data: ${null==r?void 0:r.Data}`)}))}AddDeviceChannelToGroupAsync(e,t){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid)}RemoveDeviceChannelFromGroupAsync(e,t){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid)}AddNewGroupAsync(e){var t,n;return Cd(this,void 0,void 0,(function*(){let o=new Rd,r=new Ud;r.Name=e,null===(t=o.Data)||void 0===t||t.push(r);const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,15e3,!1);if(Uh.Get(Ke.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=s&&null!=s.Status)switch(s.Status){case se.OK:return this._groups.first((t=>t.Name===e));case se.WrongData:switch(s.Data){case"NameToShort":return new Ce(md.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ce(md.NameAlreadyExists,"Group with this name already exists");default:return new Ce(md.OtherError,`Response error: ${s.Status} data: ${s.Data}`)}default:return new Ce(md.OtherError,`Response error: ${s.Status} data: ${s.Data}`)}return new Ce(md.UnknownError,"")}))}}Ad.ServiceName="ChannelsGroupsService";class Dd extends re{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ie.Post,this.Data=new Gd,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class bd extends re{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ie.Post,this.Data=e}}class Gd{constructor(){this.GroupGuid="",this.NewPosition=0}}class Ed extends re{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ie.Post,this.Data=new Td,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Id extends re{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ie.Post,this.Data=new Nd,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class Td{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Nd{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Pd extends re{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ie.Delete}}class kd extends re{constructor(){super(),this.Resource="/devices/groups/",this.Method=ie.Get}}class Rd extends re{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ie.Put,this.Data=[]}}class Od extends re{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ie.Put,this.Data=new Fd}}class xd extends re{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ie.Delete,this.Data=new Fd}}class Ud{constructor(){this.Id=0,this.Guid="",this.Name="",this.OrderPosition=0,this.ObjectsOrder={}}}class Fd{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Md{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}!function(e){e[e.Suspended=1]="Suspended",e[e.ReturnedFromSuspension=2]="ReturnedFromSuspension",e[e.EnteredLowPowerMode=3]="EnteredLowPowerMode",e[e.ExitedLowPowerMode=4]="ExitedLowPowerMode",e[e.LoggedIn=5]="LoggedIn",e[e.LoggedOut=6]="LoggedOut",e[e.Connected=7]="Connected",e[e.Disconnected=8]="Disconnected",e[e.FailedToConnect=9]="FailedToConnect",e[e.Connecting=10]="Connecting",e[e.Disconnecting=11]="Disconnecting",e[e.Reconnecting=12]="Reconnecting"}(_d||(_d={}));var $d=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Ld{constructor(){this._syncLock=new Md,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=_d.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new Se,this._onSuspendedEvent=new Se,this._onEnterLowPowerModeEvent=new Se,this._onExitLowPowerModeEvent=new Se,this._onBackButtonPressedEvent=new Se,this._onForwardButtonPressedEvent=new Se,this._onAppStateChanged=new n,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>$d(this,void 0,void 0,(function*(){yield this._syncLock.WaitForLockAsync(),this._syncLock.Lock(),this.IsHidden()?this.Suspend():this.ReturnFromSuspension(),this._syncLock.Unlock()})))):(window.addEventListener("onblur",(()=>{this._isInFouces&&(this._isInFouces=!1,this.Suspend())})),window.addEventListener("onfocus",(()=>{this._isInFouces||(this._isInFouces=!0,this.ReturnFromSuspension())}))),window.addEventListener("popstate",(e=>{var t,n,o,s;document.location,e.state&&("forward"==e.state.direction?(null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(o=r.Log)||void 0===o||o.Warning(Ld.ServiceName,"Back button pressed"),null===(s=this._onBackButtonPressedEvent)||void 0===s||s.Invoke()))}))}MonitorAppState(){return $d(this,void 0,void 0,(function*(){this._session=yield Uh.GetAsync("SessionService"),this._connection=yield Uh.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(_d.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(_d.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,o,s,i,a;switch(e){case le.Connected:null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App state changed to: connected"),this._onAppStateChanged.Invoke(_d.Connected);break;case le.Disconnected:null===(n=r.Log)||void 0===n||n.Warning(Ld.ServiceName,"App state changed to: disconnected"),this._onAppStateChanged.Invoke(_d.Disconnected);break;case le.Connecting:null===(o=r.Log)||void 0===o||o.Warning(Ld.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(_d.Connecting);break;case le.Disconnecting:null===(s=r.Log)||void 0===s||s.Warning(Ld.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(_d.Disconnecting);break;case le.Reconnecting:null===(i=r.Log)||void 0===i||i.Warning(Ld.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(_d.Reconnecting);break;case le.Failed:null===(a=r.Log)||void 0===a||a.Warning(Ld.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(_d.FailedToConnect)}}))}))}get CurrentAppState(){return this._currentAppState}OnAppStateChanged(){return this._onAppStateChanged}Suspend(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!1,this._onSuspendedEvent.Invoke(),this._onAppStateChanged.Invoke(_d.Suspended),null===(e=r.Log)||void 0===e||e.Warning(Ld.ServiceName,"App state changed to: suspended"),null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(_d.ReturnedFromSuspension),null===(e=r.Log)||void 0===e||e.Warning(Ld.ServiceName,"App state changed to: returned from suspension"),null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(_d.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(_d.ExitedLowPowerMode)}IsWorkingInWebView(){return"file:"===window.location.protocol||null!=navigator.userAgent.match(/Safari/i)&&!navigator.mediaDevices}IsHidden(){return document.hidden}IsActive(){return!this.IsHidden()}IsInBackground(){return this.IsHidden()}ReturnedFromSuspension(){return this._returnedFromSuspension}IsHibernationAllowed(){return this._canHibernate}DisallowHibernation(){this._canHibernate=!1}AllowHibernation(){this._canHibernate=!0}OnReturnedFromSuspension(){return this._onReturnedFromSuspensionEvent}OnSuspended(){return this._onSuspendedEvent}OnEnterLowPowerMode(){return this._onEnterLowPowerModeEvent}OnExitLowPowerMode(){return this._onExitLowPowerModeEvent}OnBackButtonPressed(){return this._onBackButtonPressedEvent}OnForwardButtonPressed(){return this._onForwardButtonPressedEvent}GetServiceName(){return Ld.ServiceName}}Ld.ServiceName="AppStateService";class Wd{constructor(e){if(this.initialCount=e,this._running=0,this._waiting=[],this.Take=()=>{if(this._waiting.length>0&&this._running<this.initialCount){this._running++;const e=this._waiting.shift();null==e||e.Resolve({Release:this.Release})}},this.AcquireAsync=()=>this._running<this.initialCount?(this._running++,Promise.resolve({Release:this.Release})):new Promise(((e,t)=>{this._waiting.push({Resolve:e,Reject:t})})),this.Release=()=>{this._running--,this.Take()},this.Purge=()=>{this._waiting.forEach((e=>{e.Reject(new Error("The semaphore was purged and as a result this task has been cancelled"))})),this._running=0,this._waiting=[]},e<1)throw new Error(`The semaphore was created with a max value of ${e} but the max value cannot be less than 1`)}}var Bd,Hd,Vd=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class jd{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new Wd(1)}GetServiceName(){return jd.ServiceName}GetExtensionsInfoAsync(e,t=!1){return Vd(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(jd.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);var n=yield this._semaphore.AcquireAsync();if(this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync()),n.Release(),0==[...this._extensionInfoCache.values()].length)throw new qd("Cannot get ExtensionsInfo, controler may return empty list of Extensions or other unknown error occurs!");if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new qd("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e,t=!1,n=!1){return Vd(this,void 0,void 0,(function*(){if(Uh.Get(o.ServiceName).Debug(jd.ServiceName,`Getting ProtocolInfo, data loaded from cache: ${!t}`),t&&(yield this.GetProtocolExtensionInfoFromControllerAsync()),0!=[...this._protocolInfoCache.values()].length||n){if(0==[...this._protocolInfoCache.values()].length)throw new qd("Cannot get ProtocolInfo, controler may return empty list of Extensions or other unknown error occurs!")}else yield this.GetProtocolInfoAsync(e,!0,!0);if(null!=e){const t=this._protocolInfoCache.get(e);if(null==t)throw new qd("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return Vd(this,void 0,void 0,(function*(){const e=new Kd,t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new qd("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=se.OK)throw new qd(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new qd("Cannot get ExtensionsInfo from controller, controller response does not contain data!");t.Data.forEach((e=>{this._extensionInfoCache.set(e.ExtensionGuid,e)})),0!=[...this._extensionInfoCache.values()].length&&(this._isExtensionInfoInitialized=!0)}))}GetProtocolExtensionInfoFromControllerAsync(){return Vd(this,void 0,void 0,(function*(){const e=new zd,t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new qd("Cannot get ProtocolInfo from controller, controller response does not contain data!");if(t.Status!=se.OK)throw new qd(`Cannot get ProtocolInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new qd("Cannot get ProtocolInfo from controller, controller response does not contain data!");t.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}))}))}}jd.ServiceName="StatisticsInfoService";class Kd extends re{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ie.Get}}class zd extends re{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ie.Get}}class qd extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Bd||(Bd={}));class Jd{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=Hd.Unknown,this.ResourceGuid=""}}class Yd{constructor(){this.UpdateDescription=new Map,this.Update=new Jd,this.UpdatedResourceName="",this.CurrentResourceVersion=""}}!function(e){e[e.Unknown=0]="Unknown",e[e.Container=1]="Container",e[e.RadioFirmware=2]="RadioFirmware",e[e.DeviceFirmware=3]="DeviceFirmware",e[e.Configuration=4]="Configuration",e[e.ContainerScript=5]="ContainerScript",e[e.ContainerSoftware=6]="ContainerSoftware",e[e.RuntimeSoftware=7]="RuntimeSoftware",e[e.RuntimeScript=8]="RuntimeScript",e[e.RuntimeFixingScript=9]="RuntimeFixingScript"}(Hd||(Hd={}));class Xd extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var Qd,Zd,eh,th,nh,oh,rh,sh=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class ih{constructor(){this._services=new Map,this._runtimeInfo=new ah,this._hardwareInfo=new lh,this._semaphore=new Wd(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return ih.ServiceName}RegisterUpdatesProvider(e){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const t=this._services.get(e);if(null==t)throw new Xd("Cannot get update provider! Requested update provider has not been registered.");return t}))}GetUpdatesProvidersAsync(e){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let t=[];if(t=[...this._services.values()].filter((t=>t.ProviderType==e)),0==t.length)throw new Xd("Cannot get update providers! Requested update providers has not been registered.");return t}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return sh(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update providers with protocol guid: [${e}] by GetUpdateProvidersByProtocolAsync<T>()`);let r=[];if(r=null!=n?[...this._services.values()].filter((o=>o.ProtocolGuid==e&&o.ProviderType==t&&o.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ProtocolGuid==e&&n.ProviderType==t)),0==r.length)throw new Xd("Cannot get update providers! Requested update providers has not been registered.");return r}throw new Xd("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return sh(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update providers with extension guid: [${e}] by GetUpdateProvidersByExtensionAsync<T>()`);let r=[];if(r=null!=n?[...this._services.values()].filter((o=>o.ExtensionGuid==e&&o.ProviderType==t&&o.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ExtensionGuid==e&&n.ProviderType==t)),0==r.length)throw new Xd("Cannot get update providers! Requested update providers has not been registered.");return r}throw new Xd("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(e=!1){return sh(this,void 0,void 0,(function*(){var t=yield this._semaphore.AcquireAsync();return!this._isRuntimeInfoInitialized||e?(yield this.GetRuntimeControllerInfoAsync(),t.Release(),this._runtimeInfo):(t.Release(),this._runtimeInfo)}))}GetRuntimeControllerInfoAsync(){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,"Getting runtime version info from controller.");const e=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new ch,16e3,!1);if(null==e||null==e.Status)throw new dh('Cannot get runtime info, controller response result is empty."');if(e.Status!=se.OK)throw new dh(`Cannot get runtime info, controller responded with status ${e.Status}.`);if(null==e.Data)throw new dh("Cannot get runtime info, controller responded with status OK but response does not contains data.");this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}GetHardwareInfoAsync(e=!1){return sh(this,void 0,void 0,(function*(){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,"Getting hardware info from controller.");const e=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new uh,16e3,!1);if(null==e||null==e.Status)throw new dh('Cannot get hardware info, controller response result is empty."');if(e.Status!=se.OK)throw new dh(`Cannot get hardware info, controller responded with status ${e.Status}.`);if(null==e.Data)throw new dh("Cannot get hardware info, controller responded with status OK but response does not contains data.");this._hardwareInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}}ih.ServiceName="UpdateProvider";class ah{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class ch extends re{constructor(){super(),this.Resource="/controller/software/info",this.Method=ie.Get}}class lh{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class uh extends re{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ie.Get}}class dh extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetRuntimeInfo"}}class hh{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class gh{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(Qd||(Qd={})),function(e){e[e.DownloadingFailure=-5]="DownloadingFailure",e[e.InstallationStopped=-4]="InstallationStopped",e[e.InstallationError=-3]="InstallationError",e[e.IncompatiblePackage=-2]="IncompatiblePackage",e[e.Error=-1]="Error",e[e.OK=0]="OK",e[e.DownloadingPackage=1]="DownloadingPackage",e[e.CheckingPackage=2]="CheckingPackage",e[e.PreparingForUpgrade=3]="PreparingForUpgrade",e[e.Upgrading=4]="Upgrading",e[e.MovingData=5]="MovingData",e[e.Reloading=6]="Reloading",e[e.Upgraded=7]="Upgraded"}(Zd||(Zd={})),(rh=eh||(eh={}))[rh.WaitingForUser=1]="WaitingForUser",rh[rh.Downloading=2]="Downloading",rh[rh.Unpackaging=3]="Unpackaging",rh[rh.CheckingApplicability=4]="CheckingApplicability",rh[rh.MigratingData=5]="MigratingData",rh[rh.CreatingBackup=6]="CreatingBackup",rh[rh.Deploying=7]="Deploying",rh[rh.Installing=8]="Installing",rh[rh.Removing=9]="Removing",rh[rh.Error=10]="Error",rh[rh.ReadyToDownload=11]="ReadyToDownload",rh[rh.PreparingSystem=12]="PreparingSystem",rh[rh.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",rh[rh.CheckingIntegrity=14]="CheckingIntegrity",rh[rh.UndoingInstallation=15]="UndoingInstallation",rh[rh.Installed=16]="Installed",(oh=th||(th={}))[oh.Ignore=0]="Ignore",oh[oh.Cancel=1]="Cancel",oh[oh.Install=2]="Install";class fh{constructor(){this.UpdatedResourceName="",this.Percentage=0,this.Status=Zd.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}!function(e){e[e.DeviceIsUpToDate=0]="DeviceIsUpToDate",e[e.CannotFindDevice=1]="CannotFindDevice",e[e.UnsupportedApiVersion=2]="UnsupportedApiVersion",e[e.UnsupportedDevice=3]="UnsupportedDevice",e[e.CannotGetFirmwareVersion=4]="CannotGetFirmwareVersion",e[e.CannotGetUpdates=5]="CannotGetUpdates",e[e.CannotProcessUpdate=6]="CannotProcessUpdate",e[e.UpdateActionsNotSupported=7]="UpdateActionsNotSupported",e[e.UnsupportedExtensionVersion=8]="UnsupportedExtensionVersion",e[e.UpdatesPartiallyInstalled=9]="UpdatesPartiallyInstalled"}(nh||(nh={}));var ph,vh,yh,wh,mh,Sh,_h=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Ch{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._updateProviders=Uh.Get(ih.ServiceName),this._logger=Uh.Get(o.ServiceName),this._connection=Uh.Get(Vt.ServiceName),this._appStateService=Uh.Get(Ld.ServiceName)}GetServiceName(){return Ch.ServiceName}CheckDeviceVersionAsync(e){var t;return _h(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(nh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ce(nh.UnsupportedDevice,"Device does not contains data about protocol GUID.");const o=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Bd.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return o.Type,o}))}CheckDeviceUpdateAsync(e){var t;return _h(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(nh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ce(nh.UnsupportedDevice,"Device does not contains data about protocol GUID.");const o=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Bd.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=o.Type)return o;const r=new bh;return r.CurrentResourceVersion=o.CurrentResourceVersion,r.NewResourceVersion=o.Update.Version,r.UpdatedResourceName=o.UpdatedResourceName,r.UpdateResourceGuid=o.Update.ResourceGuid,r.UpdateDescription=new Map([["pl-PL",o.Update.Description]]),r.Protocol=yield(yield Uh.Get(jd.ServiceName).GetProtocolInfoAsync(n.ProtocolGuid)).first().Name,r.ProtocolGuid=n.ProtocolGuid,(yield Uh.Get(oo.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(r.IsUpdateSafe=!1),r}))}InstallDeviceUpdateAsync(e,t,n){var o;return _h(this,void 0,void 0,(function*(){let r;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(nh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);r=t}else r=e;if(null==r.ProtocolGuid)return new Ce(nh.UnsupportedDevice,"Device does not contains data about protocol GUID.");const s=yield null===(o=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(r.ProtocolGuid,Bd.Device)).first())||void 0===o?void 0:o.GetAvailableUpdateAsync(r);if(null!=s.Type)return s;this._appStateService.DisallowHibernation();const i=yield(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(r.ProtocolGuid,Bd.Device)).first().InstallUpdateAsync(s,t,n);return null!=i.Type?(this._appStateService.AllowHibernation(),i):(this._appStateService.AllowHibernation(),se.OK)}))}CheckControllerUpdatesAsync(){return _h(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Bd.Controller),t=new hh;this._controllerUpdates=[];for(let n=0;n<e.length;n++){const o=yield e[n].GetAvailableRadioUpdateAsync();if(null!=o.Type){const r=new Ah;r.ResponseResult=o,r.UpdateType=Qd.RadioUpdate,r.UpdatedResourceName=yield(yield Uh.Get(jd.ServiceName).GetProtocolInfoAsync(e[n].ProtocolGuid)).first().Name,r.CurrentResourceVersion=yield e[n].GetCurrentRadioVersionAsync(),t.UpdatesNotAvailable.push(r)}else{const r=o,s=new Dh;s.UpdatedResourceName=r.UpdatedResourceName,s.CurrentResourceVersion=r.CurrentResourceVersion,s.NewResourceVersion=r.Update.Version,s.UpdateDescription=new Map([["pl-PL",r.Update.Description]]),s.UpdateType=Qd.RadioUpdate,s.UpdateIdentifier=ne.GenerateUUID(),t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:e[n].GetUpdateProviderName(),UpdateType:Qd.RadioUpdate}))}}const n=yield this._updateProviders.GetSoftwareRuntimeInfoAsync(),o=`https://updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const e=yield fetch(o);let r,s=new Yd;const i=new Ah;switch(i.UpdateType=Qd.SoftwareUpdate,i.UpdatedResourceName="Controller software",e.status){case 200:null!=e.body&&(r=yield e.json());break;case 404:i.ResponseResult=new Ce(nh.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Ce(nh.CannotGetUpdates,`Response status code does not indicate success. Status: ${e.status}`),t.UpdatesNotAvailable.push(i)}if(null!=r){s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdatedResourceName="Controller software",s.Update=r;const e=new Dh;e.UpdatedResourceName=s.UpdatedResourceName,e.CurrentResourceVersion=s.CurrentResourceVersion,e.NewResourceVersion=s.Update.Version,e.UpdateDescription=new Map([["pl-PL",s.Update.Description]]),e.UpdateType=Qd.SoftwareUpdate,e.UpdateIdentifier=ne.GenerateUUID(),t.UpdatesAvailable.push(e),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:e.UpdateIdentifier,ProviderName:Ch.ServiceName,UpdateType:Qd.SoftwareUpdate}))}else if(200==e.status)throw new Error(`Cannot get Update Data from response. Status: ${e.status}`)}catch(e){const n=yield this._updateProviders.GetSoftwareRuntimeInfoAsync(),o=new Ah;o.UpdateType=Qd.SoftwareUpdate,o.UpdatedResourceName="Controller software",o.ResponseResult=new Ce(nh.CannotGetUpdates,`Cannot get available updates! ${e}`),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(o)}return t}))}CheckControllerVersionAsync(){return _h(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Bd.Controller),t=[];let n;for(let o=0;o<e.length;o++)n=new gh,n.Version=yield e[o].GetCurrentRadioVersionAsync(),n.Type=Qd.RadioUpdate,n.Resource=yield(yield Uh.Get(jd.ServiceName).GetProtocolInfoAsync(e[o].ProtocolGuid)).first().Name,t.push(n);n=new gh,n.Resource="Controller software",n.Type=Qd.SoftwareUpdate;const o=yield this._updateProviders.GetSoftwareRuntimeInfoAsync();return n.Version=`${o.RuntimeVersion}.${o.SoftwareVersion}`,t.push(n),t}))}InstallControllerUpdateAsync(e,t,n){return _h(this,void 0,void 0,(function*(){const o=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),r=this._controllerUpdates.length;if(0==this._controllerUpdates.length)return new Ce(nh.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if("string"!=typeof e||!o.test(e)){const t=[1],o=n=>{n.UpdateNumber=t[0],n.AvailableUpdates=r,e(n)},s=e=>_h(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let i=this._controllerUpdates.where((e=>e.UpdateType==Qd.RadioUpdate)).toArray(),a=[];this._appStateService.DisallowHibernation();for(let e=0;e<i.length;e++){const r=yield(yield this._updateProviders.GetUpdatesProviderAsync(i[e].ProviderName)).InstallRadioUpdateAsync(i[e],o,n);yield s(5e3),r==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=i[e].UpdateIdentifier))),a.push(r),t[0]++}const c=this._controllerUpdates.find((e=>e.UpdateType==Qd.SoftwareUpdate));if(null!=c){const e=yield this.UpdateControllerAsync(c.Update,o);e==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=c.UpdateIdentifier))),a.push(e),t[0]++}const l=a.where((e=>e instanceof Ce)).toArray();if(null!=l&&0!=l.length){let e="";return l.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),new Ce(nh.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),se.OK}{let o;const r=this._controllerUpdates.find((t=>t.UpdateIdentifier==e));if(null==r)return new Ce(nh.CannotGetUpdates,`Update with requested guid (${e}) not found.`);switch(this._logger.Debug(`Installing single update type: ${r.Update.UpdateType}, resource: ${r.UpdatedResourceName}, version: ${r.Update.Version}`),this._appStateService.DisallowHibernation(),r.UpdateType){case Qd.RadioUpdate:return o=yield(yield this._updateProviders.GetUpdatesProviderAsync(r.ProviderName)).InstallRadioUpdateAsync(r,t,n),this._appStateService.AllowHibernation(),o==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=e))),o;case Qd.SoftwareUpdate:return o=yield this.UpdateControllerAsync(r.Update,t),this._appStateService.AllowHibernation(),o==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=e))),o;default:return new Ce(nh.CannotProcessUpdate,`Update with type ${r.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerAsync(e,t){var n,o,r,s,i,a;return _h(this,void 0,void 0,(function*(){switch(e.UpdateType){case Hd.Container:case Hd.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Gh(e.DownloadUri),this._updateRequestTimeout,(n=>{const o=new fh;switch(o.UpdatedResourceName="Controller software",n.Status){case se.MultiDataResponseStart:o.Status=Zd.PreparingForUpgrade;break;case se.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(Ch.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(o.Percentage=n.Data.Progress,n.Data.State){case eh.CheckingApplicability:case eh.CheckingIntegrity:case eh.CheckingPackageIntegrity:o.Status=Zd.CheckingPackage;break;case eh.CreatingBackup:case eh.MigratingData:case eh.Removing:o.Status=Zd.MovingData;break;case eh.Deploying:case eh.Installing:o.Status=Zd.Upgrading;break;case eh.Downloading:o.Status=Zd.DownloadingPackage;break;case eh.Error:o.Status=Zd.Error;break;case eh.Installed:o.Status=Zd.Upgraded;break;case eh.PreparingSystem:case eh.ReadyToDownload:o.Status=Zd.PreparingForUpgrade;break;case eh.UndoingInstallation:o.Status=Zd.InstallationStopped;break;case eh.Unpackaging:o.Status=Zd.MovingData;break;case eh.WaitingForUser:o.Status=Zd.Upgrading}break;case se.MultiDataResponseStop:o.Status=Zd.OK}t(o)}),!1),se.OK}catch(e){return new Ce(nh.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case Hd.RuntimeFixingScript:var c=10,l=(yield Uh.Get(jd.ServiceName).GetExtensionsInfoAsync()).first((e=>"f4f45dac-beda-441a-8d29-efc6dc977cd1"==e.ExtensionGuid)).ExtensionVersion,u=parseFloat((yield this._updateProviders.GetSoftwareRuntimeInfoAsync()).RuntimeVersion)>=2||parseFloat(l)>=1.2201125;try{c=(yield Uh.Get(oo.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(Ch.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(u){let n,o=new fh;o.UpdatedResourceName="Controller software",o.Percentage=1,o.Status=Zd.PreparingForUpgrade,t(o);let r=2;const s=Date.now(),i=900*c+36e4,a=i/100,l=s+i,u=new Promise(((s,c)=>_h(this,void 0,void 0,(function*(){var c;try{const u=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(u),Date.now()>l)clearInterval(n),this._logger.Debug("Update already finished!"),o.Percentage=100,o.Status=Zd.Upgraded,t(o),s(se.OK);else{var e=l-Date.now();e<i?r=80-e/a:(clearInterval(n),n=setInterval((()=>{clearInterval(n),o.Percentage=100,o.Status=Zd.Upgraded,t(o),s(se.OK)}),e))}};this._appStateService.OnReturnedFromSuspension().Subscribe(u),n=setInterval((()=>{if(r>99)clearInterval(n),o.Percentage=100,o.Status=Zd.Upgraded,t(o),s(se.OK);else{var e=r;e<99&&(o.Percentage=e,o.Status=Zd.Upgrading,t(o))}r++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Eh(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=se.OK&&(clearInterval(n),o.Percentage=0,o.Status=Zd.InstallationError,t(o),this._logger.Debug(Ch.ServiceName,`Update failed with error. Update response status: ${d.Status}`),s(new Ce(nh.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(Ch.ServiceName,`Update failed with error. ${e}`),o.Percentage=0,o.Status=Zd.Error,t(o),clearInterval(n),s(new Ce(nh.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield u}{let n=new fh;n.UpdatedResourceName="Controller software",n.Percentage=1,n.Status=Zd.PreparingForUpgrade,t(n);const l=this._connection.GetAuthorizationInfo();if(null==l)return new Ce(nh.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Ih({Email:"support@support",Password:`support@${l.SerialNumber}:${l.PIN}`}),12e3,!1)).Status===se.OK){n.Percentage=5,n.Status=Zd.PreparingForUpgrade,t(n);let o=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Th("rm /runtime/tmp/update.sh"),12e3,!1);if(o.Status==se.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=10,n.Status=Zd.PreparingForUpgrade,t(n),o=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Th(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh`),this._updateRequestTimeout,!1),o.Status==se.OK){this._logger.Debug("Downloaded update script"),n.Percentage=15,n.Status=Zd.PreparingForUpgrade,t(n);try{if(o=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Th("chmod a+x /runtime/tmp/update.sh"),12e3,!1),o.Status==se.OK){this._logger.Debug("Executed update script"),n.Percentage=20,n.Status=Zd.Upgrading,t(n);let e,o=0;const r=.8,s=Date.now(),i=900*c+2e5,a=i/80,l=s+i,u=new Promise(((s,c)=>_h(this,void 0,void 0,(function*(){var c;try{const u=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(u),Date.now()>l)clearInterval(e),this._logger.Debug("Update already finished!"),n.Percentage=100,n.Status=Zd.Upgraded,t(n),s(se.OK);else{var r=l-Date.now();r<i?o=80-r/a:(clearInterval(e),e=setInterval((()=>{clearInterval(e),n.Percentage=100,n.Status=Zd.Upgraded,t(n),s(se.OK)}),r))}};this._appStateService.OnReturnedFromSuspension().Subscribe(u),e=setInterval((()=>{if(o>99)clearInterval(e),n.Percentage=100,n.Status=Zd.Upgraded,t(n),s(se.OK);else{var i=20+o*r;i<99&&(n.Percentage=i,n.Status=Zd.Upgrading,t(n))}o++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Th("/runtime/tmp/update.sh"),12e3,!1)}catch(e){s(new Ce(nh.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield u}return n.Percentage=0,n.Status=Zd.InstallationError,t(n),new Ce(nh.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Th("/runtime/scripts/restart_all.sh"),12e3,!1),new Ce(nh.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Ce(nh.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Ce(nh.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Ce(nh.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}}Ch.ServiceName="UpdatesService";class Ah{constructor(){this.UpdatedResourceName="",this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class Dh{constructor(){this._updateIdentifier="",this._updateResourceName="",this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map}get UpdateDescription(){return this._updateDescription}set UpdateDescription(e){this._updateDescription=e}get UpdateIdentifier(){return this._updateIdentifier}get UpdatedResourceName(){return this._updateResourceName}get UpdateType(){return this._updateType}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}set UpdateIdentifier(e){this._updateIdentifier=e}set UpdatedResourceName(e){this._updateResourceName=e}set UpdateType(e){this._updateType=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}}class bh{constructor(){this._updatedResourceName="",this._updateResourceGuid="",this._protocol="",this._protocolGuid="",this._currentResourceVersion="",this._newResourceVersion="",this._isUpdateSafe=!0,this._updateDescription=new Map}get UpdateDescription(){return this._updateDescription}set UpdateDescription(e){this._updateDescription=e}get UpdatedResourceName(){return this._updatedResourceName}get UpdateResourceGuid(){return this._updateResourceGuid}get Protocol(){return this._protocol}get ProtocolGuid(){return this._protocolGuid}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}get IsUpdateSafe(){return this._isUpdateSafe}set UpdatedResourceName(e){this._updatedResourceName=e}set UpdateResourceGuid(e){this._updateResourceGuid=e}set Protocol(e){this._protocol=e}set ProtocolGuid(e){this._protocolGuid=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}set IsUpdateSafe(e){this._isUpdateSafe=e}}class Gh extends re{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=ie.Post,this.Data=e}}!function(e){e[e.Windows=0]="Windows",e[e.Linux=1]="Linux",e[e.Unix=2]="Unix",e[e.OSX=3]="OSX",e[e.Android=4]="Android",e[e.iOS=5]="iOS",e[e.WindowsMobile=6]="WindowsMobile"}(ph||(ph={})),function(e){e[e.Any=0]="Any",e[e.MIPS=1]="MIPS",e[e.ARM32=2]="ARM32",e[e.ARM64=3]="ARM64",e[e.IntelX86=4]="IntelX86",e[e.IntelX64=5]="IntelX64"}(vh||(vh={})),function(e){e[e.Unknown=0]="Unknown",e[e.Environment=1]="Environment",e[e.OperatingSystem=2]="OperatingSystem",e[e.Application=3]="Application",e[e.Extension=4]="Extension",e[e.HardwareFirmware=5]="HardwareFirmware",e[e.Script=6]="Script",e[e.Command=7]="Command"}(yh||(yh={}));class Eh extends re{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ie.Put,this.Data=e}}class Ih extends re{constructor(e){super(),this.Resource="/users/user/login",this.Method=ie.Put,this.Data=e}}class Th extends re{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ie.Post,this.Data=e}}!function(e){e.CannotFindDevice="CannotFindDevice",e.ResponseTypeNotSupported="ResponseTypeNotSupported",e.InvalidChannelNumber="InvalidChannelNumber",e.IncorrectLimitValue="IncorrectLimitValue",e.IncorrectOffsetValue="IncorrectOffsetValue",e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.FunctionalityNotSupported="FunctionalityNotSupported"}(wh||(wh={})),function(e){e[e.None=0]="None",e[e.DataRange=1]="DataRange",e[e.Hour=2]="Hour",e[e.Day=3]="Day",e[e.Week=4]="Week",e[e.Month=5]="Month",e[e.Year=6]="Year"}(mh||(mh={}));class Nh{constructor(){this._objectType="Unknown",this._stateInterfaceType="Unknown"}get StateObjectType(){return this._objectType}get StateInterfaceType(){return this._stateInterfaceType}get StateResponseType(){return this._stateInterfaceType}set StateObjectType(e){this._objectType=e}set StateInterfaceType(e){this._stateInterfaceType=e}}!function(e){e[e.Unknown=-1]="Unknown",e[e.PitchBlack=0]="PitchBlack",e[e.VeryDark=1]="VeryDark",e[e.DarkIndoors=2]="DarkIndoors",e[e.DimIndoors=3]="DimIndoors",e[e.NormalIndoors=4]="NormalIndoors",e[e.BrightIndoors=5]="BrightIndoors",e[e.DimOutdoors=6]="DimOutdoors",e[e.CloudyOutdoors=7]="CloudyOutdoors",e[e.DirectSunlight=8]="DirectSunlight"}(Sh||(Sh={}));var Ph=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class kh{constructor(){this._connection=null,this._connection=Uh.Get(Vt.ServiceName)}GetServiceName(){return kh.ServiceName}GetStatesByIntervalAsync(e,t,n,o,r,s){var i;return Ph(this,void 0,void 0,(function*(){try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Ce(wh.FunctionalityNotSupported,"State history data is not supported with this version of controller software, update software to get this functionality.");let a;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(wh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);a=t}else a=e;if(!a.Channels.any((e=>e.Number==t)))return new Ce(wh.InvalidChannelNumber,`Given channel not found in device with guid: ${a.Guid}.`);if(!a.Channels.any((e=>e.Number==t&&e.AvailableResponseTypes.any((e=>e.Type==n)))))return new Ce(wh.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const c=new Oh;c.DeviceGuid=a.Guid,c.DeviceChannel=t,c.Range=o,c.StateInterfaceType=n,c.Limit=r,c.Offset=s;const l=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Rh(c),16e3,!1);if(null==l)return new Ce(wh.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case se.WrongData:switch(l.Data){case"IncorrectLimitValue":return new Ce(wh.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ce(wh.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ce(wh.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Ce(wh.OtherError,"Cannot get state history data - unknown error!")}case se.FatalError:return new Ce(wh.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case se.ResourceDoesNotExists:return new Ce(wh.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case se.OK:return null==l.Data?new Ce(wh.NoData,"Controller responede with status OK, but response does not contain data!"):l.Data;default:return new Ce(wh.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new Ce(wh.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){var e;return Ph(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new xh,8e3,!1);return null==t?new Ce(wh.OtherError,"Cannot get available states - response is null."):t.Status!=se.OK?new Ce(wh.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Ce(wh.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Nh;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Ce(wh.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return Ph(this,void 0,void 0,(function*(){return!(parseFloat((yield Uh.Get(ih.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}}kh.ServiceName="StatesHistoryService";class Rh extends re{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ie.Get,this.Data=e}}class Oh{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=mh.Day,this.Limit=0,this.Offset=0}}class xh extends re{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ie.Get}}Di(Map),Di(Set),(()=>{var e;const t=String.prototype,n=Object.getOwnPropertyNames(xo.prototype);for(const o of n)t[o]=null!==(e=t[o])&&void 0!==e?e:xo.prototype[o];t.first=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}throw new No(To.NoMatch)}if(0===this.length)throw new No(To.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[0]},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Io("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new No(To.NoMatch)}if(0===this.length)throw new No(To.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.reverse=function(){const e=this;return new xo((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),Uo(Array),Uo(Int8Array),Uo(Int16Array),Uo(Int32Array),Uo(Uint8Array),Uo(Uint8ClampedArray),Uo(Uint16Array),Uo(Uint32Array),Uo(Float32Array),Uo(Float64Array);class Uh{static Init(){if(r.IsInitialized)return;let e=r.Instance;try{e.RegisterService(new s),e.RegisterService(new Ld),e.RegisterService(new Ke),e.RegisterService(new He),e.RegisterService(new Vt),e.RegisterService(new Yn),e.RegisterService(new Do),e.RegisterService(new qe),e.RegisterService(new zn),e.RegisterService(new jd),e.RegisterService(new be),e.RegisterService(new xe),e.RegisterService(new oo),e.RegisterService(new Ad),e.RegisterService(new ih),e.RegisterService(new Ch),e.RegisterService(new kh)}catch(e){console.error(e)}}static GetAsync(e,t){return r.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return r.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return r.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}}Uh.WorksInContextOf="",Uh.Version=1})();
|
|
1
|
+
(()=>{"use strict";var e,t={d:(e,n)=>{for(var o in n)t.o(n,o)&&!t.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:n[o]})}};t.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),t.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),t.d({},{V:()=>Uh});class n{constructor(){this.handlers=[]}Subscribe(e){this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(e){this.handlers.slice(0).forEach((t=>{var n;try{t(e)}catch(e){null===(n=r.Log)||void 0===n||n.Error(e)}}))}}!function(e){e[e.Debug=0]="Debug",e[e.Info=1]="Info",e[e.Warning=2]="Warning",e[e.Error=3]="Error"}(e||(e={}));class o{constructor(){this._blockedServices=[],this._logLevel=e.Debug}EnableStackTrace(){o.DoesThrowStackTrace=!0}DisableStackTrace(){o.DoesThrowStackTrace=!0}IsBlocked(e){return void 0!==e&&this._blockedServices.any((t=>t==e))}DisableLogsFrom(e){this._blockedServices.all((t=>t!=e))&&this._blockedServices.push(e),this.Debug(o.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(o.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return o.ServiceName}GetTimeStamp(){const e=new Date;return`${e.getHours()}:${e.getMinutes()}:${e.getSeconds()}.${e.getMilliseconds()} | `}Warning(t,n){switch(this._logLevel){case e.Warning:case e.Info:case e.Debug:break;default:return}void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.warn(`${this.GetTimeStamp()}[WARN] ${t}`):console.warn(`${this.GetTimeStamp()}[WARN] [${t}] ${n}`))}Error(e,t){null!=e&&(null==t?console.error(`${this.GetTimeStamp()}[ERROR] ${e}`):console.error(`${this.GetTimeStamp()}[ERROR] [${e}] ${t}`))}Info(t,n){switch(this._logLevel){case e.Info:case e.Debug:break;default:return}void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.info(`${this.GetTimeStamp()}[INFO] ${t}`):console.info(`${this.GetTimeStamp()}[INFO] [${t}] ${n}`))}Debug(t,n){this._logLevel===e.Debug&&(void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.debug(`${this.GetTimeStamp()}[DEBUG] ${t}`):o.DoesThrowStackTrace?console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n} \nstack:\n${(new Error).stack}}`):console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n}`)))}Log(e,t){void 0===e||this.IsBlocked(e)||null!=e&&(null==t?console.log(`${this.GetTimeStamp()}[LOG] ${e}`):console.log(`${this.GetTimeStamp()}[LOG] [${e}] ${t}`))}}o.ServiceName="LoggerService",o.DoesThrowStackTrace=!1;class r{constructor(){this._services={},this._serviceRegistrationEvent=new n}static get Instance(){return null!=r._instance||(r._instance=new r,this.Log=new o,this.Log.Warning("Initializing DependencyContainer"),r._instance.RegisterService(this.Log),this.IsInitialized=!0),r._instance}RegisterService(e){var t;null===(t=r.Log)||void 0===t||t.Debug("DependencyContainer",`Registering new service: ${e.GetServiceName()}`),this._services[e.GetServiceName()]=e,this._serviceRegistrationEvent.Invoke(e)}GetService(e){var t;return null===(t=r.Log)||void 0===t||t.Debug("DependencyContainer",`Getting service [${e}] by GetService<T>()`),this._services[e]}GetServiceAsync(e,t){var n,o;return null===(n=r.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service availability [${e}] by GetServiceAsync<T>()`),this._services.hasOwnProperty(e)?(null===(o=r.Log)||void 0===o||o.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,o)=>{var s=t=>{var o;(null==t?void 0:t.GetServiceName())===e&&(null===(o=r.Log)||void 0===o||o.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(s),n(t))},i=()=>{var n;null===(n=r.Log)||void 0===n||n.Debug("DependencyContainer",`Cancelled service [${e}] retrieval by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(s),null==t||t.CancellationEvent.Unsubscribe(i),o(new Error("Operation cancelled!"))};null==t||t.CancellationEvent.Subscribe(i),this._serviceRegistrationEvent.Subscribe(s)}))}GetServiceWithTimeoutAsync(e,t){var n,o;return null===(n=r.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service[${e}] availability by GetServiceWithTimeoutAsync<T>()`),this._services.hasOwnProperty(e)?(null===(o=r.Log)||void 0===o||o.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,o)=>{let s=0,i=e=>{var t;(null==e?void 0:e.GetClassName())===e&&(null===(t=r.Log)||void 0===t||t.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),window.clearTimeout(s),this._serviceRegistrationEvent.Unsubscribe(i),n(e))};s=window.setTimeout((()=>{var t;window.clearTimeout(s),this._serviceRegistrationEvent.Unsubscribe(i),null===(t=r.Log)||void 0===t||t.Error("DependencyContainer",`Failed to get service [${e}] in time by GetServiceWithTimeoutAsync<T>()`),o(new Error("Operation cancelled!"))}),t),this._serviceRegistrationEvent.Subscribe(i)}))}}r.IsInitialized=!1;class s{GetServiceName(){return s.ServiceName}GetResourceName(e,t){return`_exalus_${Uh.WorksInContextOf}_${e}_${t}`}Remove(e,t){localStorage.removeItem(this.GetResourceName(e,t))}DropStorage(e){let t=`_exalus_${e}`;for(const e in localStorage)(null==e?void 0:e.startsWith(t))&&localStorage.removeItem(e)}Save(e,t,n){localStorage.setItem(this.GetResourceName(e,t),JSON.stringify(n))}Read(e,t){var n;try{let n=this.GetResourceName(e,t),o=localStorage.getItem(n);return null==o?null:JSON.parse(o)}catch(o){return null===(n=r.Log)||void 0===n||n.Error(s.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}s.ServiceName="LocalStorageService";const i=[0,2e3,1e4,3e4,null];class a{constructor(e){this._retryDelays=void 0!==e?[...e,null]:i}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class c{}c.Authorization="Authorization",c.Cookie="Cookie";class l{constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class u{get(e,t){return this.send({...t,method:"GET",url:e})}post(e,t){return this.send({...t,method:"POST",url:e})}delete(e,t){return this.send({...t,method:"DELETE",url:e})}getCookieString(e){return""}}class d extends u{constructor(e,t){super(),this._innerClient=e,this._accessTokenFactory=t}async send(e){let t=!0;this._accessTokenFactory&&(!this._accessToken||e.url&&e.url.indexOf("/negotiate?")>0)&&(t=!1,this._accessToken=await this._accessTokenFactory()),this._setAuthorizationHeader(e);const n=await this._innerClient.send(e);return t&&401===n.statusCode&&this._accessTokenFactory?(this._accessToken=await this._accessTokenFactory(),this._setAuthorizationHeader(e),await this._innerClient.send(e)):n}_setAuthorizationHeader(e){e.headers||(e.headers={}),this._accessToken?e.headers[c.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[c.Authorization]&&delete e.headers[c.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class h extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class g extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class f extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class p extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class v extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class y extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class w extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class m extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}var S,_,C,A,D;!function(e){e[e.Trace=0]="Trace",e[e.Debug=1]="Debug",e[e.Information=2]="Information",e[e.Warning=3]="Warning",e[e.Error=4]="Error",e[e.Critical=5]="Critical",e[e.None=6]="None"}(S||(S={}));class b{constructor(){}log(e,t){}}b.instance=new b;class G{static isRequired(e,t){if(null==e)throw new Error(`The '${t}' argument is required.`)}static isNotEmpty(e,t){if(!e||e.match(/^\s*$/))throw new Error(`The '${t}' argument should not be empty.`)}static isIn(e,t,n){if(!(e in t))throw new Error(`Unknown ${n} value: ${e}.`)}}class E{static get isBrowser(){return"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return"object"==typeof self&&"importScripts"in self}static get isReactNative(){return"object"==typeof window&&void 0===window.document}static get isNode(){return!this.isBrowser&&!this.isWebWorker&&!this.isReactNative}}function I(e,t){let n="";return T(e)?(n=`Binary data of length ${e.byteLength}`,t&&(n+=`. Content: '${function(e){const t=new Uint8Array(e);let n="";return t.forEach((e=>{n+=`0x${e<16?"0":""}${e.toString(16)} `})),n.substr(0,n.length-1)}(e)}'`)):"string"==typeof e&&(n=`String data of length ${e.length}`,t&&(n+=`. Content: '${e}'`)),n}function T(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function N(e,t,n,o,r,s){const i={},[a,c]=R();i[a]=c,e.log(S.Trace,`(${t} transport) sending data. ${I(r,s.logMessageContent)}.`);const l=T(r)?"arraybuffer":"text",u=await n.post(o,{content:r,headers:{...i,...s.headers},responseType:l,timeout:s.timeout,withCredentials:s.withCredentials});e.log(S.Trace,`(${t} transport) request complete. Response status: ${u.statusCode}.`)}class P{constructor(e,t){this._subject=e,this._observer=t}dispose(){const e=this._subject.observers.indexOf(this._observer);e>-1&&this._subject.observers.splice(e,1),0===this._subject.observers.length&&this._subject.cancelCallback&&this._subject.cancelCallback().catch((e=>{}))}}class k{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${S[e]}: ${t}`;switch(e){case S.Critical:case S.Error:this.out.error(n);break;case S.Warning:this.out.warn(n);break;case S.Information:this.out.info(n);break;default:this.out.log(n)}}}}function R(){let e="X-SignalR-User-Agent";return E.isNode&&(e="User-Agent"),[e,O("7.0.0",x(),E.isNode?"NodeJS":"Browser",U())]}function O(e,t,n,o){let r="Microsoft SignalR/";const s=e.split(".");return r+=`${s[0]}.${s[1]}`,r+=` (${e}; `,r+=t&&""!==t?`${t}; `:"Unknown OS; ",r+=`${n}`,r+=o?`; ${o}`:"; Unknown Runtime Version",r+=")",r}function x(){if(!E.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function U(){if(E.isNode)return process.versions.node}function F(e){return e.stack?e.stack:e.message?e.message:`${e}`}class M extends u{constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch){const e=require;this._jar=new(e("tough-cookie").CookieJar),this._fetchType=e("node-fetch"),this._fetchType=e("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(function(){if("undefined"!=typeof globalThis)return globalThis;if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==t.g)return t.g;throw new Error("could not find global")}());if("undefined"==typeof AbortController){const e=require;this._abortControllerType=e("abort-controller")}else this._abortControllerType=AbortController}async send(e){if(e.abortSignal&&e.abortSignal.aborted)throw new f;if(!e.method)throw new Error("No method defined.");if(!e.url)throw new Error("No url defined.");const t=new this._abortControllerType;let n;e.abortSignal&&(e.abortSignal.onabort=()=>{t.abort(),n=new f});let o,r=null;if(e.timeout){const o=e.timeout;r=setTimeout((()=>{t.abort(),this._logger.log(S.Warning,"Timeout from HTTP request."),n=new g}),o)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},T(e.content)?e.headers["Content-Type"]="application/octet-stream":e.headers["Content-Type"]="text/plain;charset=UTF-8");try{o=await this._fetchType(e.url,{body:e.content,cache:"no-cache",credentials:!0===e.withCredentials?"include":"same-origin",headers:{"X-Requested-With":"XMLHttpRequest",...e.headers},method:e.method,mode:"cors",redirect:"follow",signal:t.signal})}catch(e){if(n)throw n;throw this._logger.log(S.Warning,`Error from HTTP request. ${e}.`),e}finally{r&&clearTimeout(r),e.abortSignal&&(e.abortSignal.onabort=null)}if(!o.ok){const e=await $(o,"text");throw new h(e||o.statusText,o.status)}const s=$(o,e.responseType),i=await s;return new l(o.status,o.statusText,i)}getCookieString(e){let t="";return E.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function $(e,t){let n;switch(t){case"arraybuffer":n=e.arrayBuffer();break;case"text":default:n=e.text();break;case"blob":case"document":case"json":throw new Error(`${t} is not supported.`)}return n}class L extends u{constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new f):e.method?e.url?new Promise(((t,n)=>{const o=new XMLHttpRequest;o.open(e.method,e.url,!0),o.withCredentials=void 0===e.withCredentials||e.withCredentials,o.setRequestHeader("X-Requested-With","XMLHttpRequest"),""===e.content&&(e.content=void 0),e.content&&(T(e.content)?o.setRequestHeader("Content-Type","application/octet-stream"):o.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const r=e.headers;r&&Object.keys(r).forEach((e=>{o.setRequestHeader(e,r[e])})),e.responseType&&(o.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{o.abort(),n(new f)}),e.timeout&&(o.timeout=e.timeout),o.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),o.status>=200&&o.status<300?t(new l(o.status,o.statusText,o.response||o.responseText)):n(new h(o.response||o.responseText||o.statusText,o.status))},o.onerror=()=>{this._logger.log(S.Warning,`Error from HTTP request. ${o.status}: ${o.statusText}.`),n(new h(o.statusText,o.status))},o.ontimeout=()=>{this._logger.log(S.Warning,"Timeout from HTTP request."),n(new g)},o.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class W extends u{constructor(e){if(super(),"undefined"!=typeof fetch||E.isNode)this._httpClient=new M(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new L(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new f):e.method?e.url?this._httpClient.send(e):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}getCookieString(e){return this._httpClient.getCookieString(e)}}!function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(_||(_={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(C||(C={}));class B{constructor(){this._isAborted=!1,this.onabort=null}abort(){this._isAborted||(this._isAborted=!0,this.onabort&&this.onabort())}get signal(){return this}get aborted(){return this._isAborted}}class H{constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new B,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}get pollAborted(){return this._pollAbort.aborted}async connect(e,t){if(G.isRequired(e,"url"),G.isRequired(t,"transferFormat"),G.isIn(t,C,"transferFormat"),this._url=e,this._logger.log(S.Trace,"(LongPolling transport) Connecting."),t===C.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[n,o]=R(),r={[n]:o,...this._options.headers},s={abortSignal:this._pollAbort.signal,headers:r,timeout:1e5,withCredentials:this._options.withCredentials};t===C.Binary&&(s.responseType="arraybuffer");const i=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${i}.`);const a=await this._httpClient.get(i,s);200!==a.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${a.statusCode}.`),this._closeError=new h(a.statusText||"",a.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,s)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${n}.`);const o=await this._httpClient.get(n,t);204===o.statusCode?(this._logger.log(S.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==o.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${o.statusCode}.`),this._closeError=new h(o.statusText||"",o.statusCode),this._running=!1):o.content?(this._logger.log(S.Trace,`(LongPolling transport) data received. ${I(o.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(o.content)):this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof g?this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(S.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(S.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?N(this._logger,"LongPolling",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}async stop(){this._logger.log(S.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(S.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=R();e[t]=n;const o={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};await this._httpClient.delete(this._url,o),this._logger.log(S.Trace,"(LongPolling transport) DELETE request sent.")}finally{this._logger.log(S.Trace,"(LongPolling transport) Stop finished."),this._raiseOnClose()}}_raiseOnClose(){if(this.onclose){let e="(LongPolling transport) Firing onclose event.";this._closeError&&(e+=" Error: "+this._closeError),this._logger.log(S.Trace,e),this.onclose(this._closeError)}}}class V{constructor(e,t,n,o){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=o,this.onreceive=null,this.onclose=null}async connect(e,t){return G.isRequired(e,"url"),G.isRequired(t,"transferFormat"),G.isIn(t,C,"transferFormat"),this._logger.log(S.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((n,o)=>{let r,s=!1;if(t===C.Text){if(E.isBrowser||E.isWebWorker)r=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[o,s]=R();n[o]=s,r=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{r.onmessage=e=>{if(this.onreceive)try{this._logger.log(S.Trace,`(SSE transport) data received. ${I(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},r.onerror=e=>{s?this._close():o(new Error("EventSource failed to connect. The connection could not be found on the server, either the connection ID is not present on the server, or a proxy is refusing/buffering the connection. If you have multiple servers check that sticky sessions are enabled."))},r.onopen=()=>{this._logger.log(S.Information,`SSE connected to ${this._url}`),this._eventSource=r,s=!0,n()}}catch(e){return void o(e)}}else o(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?N(this._logger,"SSE",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}stop(){return this._close(),Promise.resolve()}_close(e){this._eventSource&&(this._eventSource.close(),this._eventSource=void 0,this.onclose&&this.onclose(e))}}class j{constructor(e,t,n,o,r,s){this._logger=n,this._accessTokenFactory=t,this._logMessageContent=o,this._webSocketConstructor=r,this._httpClient=e,this.onreceive=null,this.onclose=null,this._headers=s}async connect(e,t){let n;return G.isRequired(e,"url"),G.isRequired(t,"transferFormat"),G.isIn(t,C,"transferFormat"),this._logger.log(S.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(n=await this._accessTokenFactory()),new Promise(((o,r)=>{let s;e=e.replace(/^http/,"ws");const i=this._httpClient.getCookieString(e);let a=!1;if(E.isNode||E.isReactNative){const t={},[o,r]=R();t[o]=r,n&&(t[c.Authorization]=`Bearer ${n}`),i&&(t[c.Cookie]=i),s=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else n&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(n)}`);s||(s=new this._webSocketConstructor(e)),t===C.Binary&&(s.binaryType="arraybuffer"),s.onopen=t=>{this._logger.log(S.Information,`WebSocket connected to ${e}.`),this._webSocket=s,a=!0,o()},s.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(S.Information,`(WebSockets transport) ${t}.`)},s.onmessage=e=>{if(this._logger.log(S.Trace,`(WebSockets transport) data received. ${I(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},s.onclose=e=>{if(a)this._close(e);else{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"WebSocket failed to connect. The connection could not be found on the server, either the endpoint may not be a SignalR endpoint, the connection ID is not present on the server, or there is a proxy blocking WebSockets. If you have multiple servers check that sticky sessions are enabled.",r(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(S.Trace,`(WebSockets transport) sending data. ${I(e,this._logMessageContent)}.`),this._webSocket.send(e),Promise.resolve()):Promise.reject("WebSocket is not in the OPEN state")}stop(){return this._webSocket&&this._close(void 0),Promise.resolve()}_close(e){this._webSocket&&(this._webSocket.onclose=()=>{},this._webSocket.onmessage=()=>{},this._webSocket.onerror=()=>{},this._webSocket.close(),this._webSocket=void 0),this._logger.log(S.Trace,"(WebSockets transport) socket closed."),this.onclose&&(!this._isCloseEvent(e)||!1!==e.wasClean&&1e3===e.code?e instanceof Error?this.onclose(e):this.onclose():this.onclose(new Error(`WebSocket closed with status code: ${e.code} (${e.reason||"no reason given"}).`)))}_isCloseEvent(e){return e&&"boolean"==typeof e.wasClean&&"number"==typeof e.code}}class K{constructor(e,t={}){var n;if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,G.isRequired(e,"url"),this._logger=void 0===(n=t.logger)?new k(S.Information):null===n?b.instance:void 0!==n.log?n:new k(n),this.baseUrl=this._resolveUrl(e),(t=t||{}).logMessageContent=void 0!==t.logMessageContent&&t.logMessageContent,"boolean"!=typeof t.withCredentials&&void 0!==t.withCredentials)throw new Error("withCredentials option was not a 'boolean' or 'undefined' value");t.withCredentials=void 0===t.withCredentials||t.withCredentials,t.timeout=void 0===t.timeout?1e5:t.timeout;let o=null,r=null;if(E.isNode){const e=require;o=e("ws"),r=e("eventsource")}E.isNode||"undefined"==typeof WebSocket||t.WebSocket?E.isNode&&!t.WebSocket&&o&&(t.WebSocket=o):t.WebSocket=WebSocket,E.isNode||"undefined"==typeof EventSource||t.EventSource?E.isNode&&!t.EventSource&&void 0!==r&&(t.EventSource=r):t.EventSource=EventSource,this._httpClient=new d(t.httpClient||new W(this._logger),t.accessTokenFactory),this._connectionState="Disconnected",this._connectionStarted=!1,this._options=t,this.onreceive=null,this.onclose=null}async start(e){if(e=e||C.Binary,G.isIn(e,C,"transferFormat"),this._logger.log(S.Debug,`Starting connection with transfer format '${C[e]}'.`),"Disconnected"!==this._connectionState)return Promise.reject(new Error("Cannot start an HttpConnection that is not in the 'Disconnected' state."));if(this._connectionState="Connecting",this._startInternalPromise=this._startInternal(e),await this._startInternalPromise,"Disconnecting"===this._connectionState){const e="Failed to start the HttpConnection before stop() was called.";return this._logger.log(S.Error,e),await this._stopPromise,Promise.reject(new f(e))}if("Connected"!==this._connectionState){const e="HttpConnection.startInternal completed gracefully but didn't enter the connection into the connected state!";return this._logger.log(S.Error,e),Promise.reject(new f(e))}this._connectionStarted=!0}send(e){return"Connected"!==this._connectionState?Promise.reject(new Error("Cannot send data if the connection is not in the 'Connected' State.")):(this._sendQueue||(this._sendQueue=new z(this.transport)),this._sendQueue.send(e))}async stop(e){return"Disconnected"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState="Disconnecting",this._stopPromise=new Promise((e=>{this._stopPromiseResolver=e})),await this._stopInternal(e),void await this._stopPromise)}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch(e){}if(this.transport){try{await this.transport.stop()}catch(e){this._logger.log(S.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(S.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let t=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==_.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(_.WebSockets),await this._startTransport(t,e)}else{let n=null,o=0;do{if(n=await this._getNegotiationResponse(t),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new f("The connection was stopped during negotiation.");if(n.error)throw new Error(n.error);if(n.ProtocolVersion)throw new Error("Detected a connection attempt to an ASP.NET SignalR Server. This client only supports connecting to an ASP.NET Core SignalR Server. See https://aka.ms/signalr-core-differences for details.");if(n.url&&(t=n.url),n.accessToken){const e=n.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}o++}while(n.url&&o<100);if(100===o&&n.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(t,this._options.transport,n,e)}this.transport instanceof H&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(S.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(S.Error,"Failed to start the connection: "+e),this._connectionState="Disconnected",this.transport=void 0,this._stopPromiseResolver(),Promise.reject(e)}}async _getNegotiationResponse(e){const t={},[n,o]=R();t[n]=o;const r=this._resolveNegotiateUrl(e);this._logger.log(S.Debug,`Sending negotiation request: ${r}.`);try{const e=await this._httpClient.post(r,{content:"",headers:{...t,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials});if(200!==e.statusCode)return Promise.reject(new Error(`Unexpected status code returned from negotiate '${e.statusCode}'`));const n=JSON.parse(e.content);return(!n.negotiateVersion||n.negotiateVersion<1)&&(n.connectionToken=n.connectionId),n}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof h&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(S.Error,t),Promise.reject(new w(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,t,n,o){let r=this._createConnectUrl(e,n.connectionToken);if(this._isITransport(t))return this._logger.log(S.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=t,await this._startTransport(r,o),void(this.connectionId=n.connectionId);const s=[],i=n.availableTransports||[];let a=n;for(const n of i){const i=this._resolveTransportOrError(n,t,o);if(i instanceof Error)s.push(`${n.transport} failed:`),s.push(i);else if(this._isITransport(i)){if(this.transport=i,!a){try{a=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}r=this._createConnectUrl(e,a.connectionToken)}try{return await this._startTransport(r,o),void(this.connectionId=a.connectionId)}catch(e){if(this._logger.log(S.Error,`Failed to start the transport '${n.transport}': ${e}`),a=void 0,s.push(new y(`${n.transport} failed: ${e}`,_[n.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(S.Debug,e),Promise.reject(new f(e))}}}}return s.length>0?Promise.reject(new m(`Unable to connect to the server with any of the available transports. ${s.join(" ")}`,s)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case _.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new j(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case _.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new V(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case _.LongPolling:return new H(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,t,n){const o=_[e.transport];if(null==o)return this._logger.log(S.Debug,`Skipping transport '${e.transport}' because it is not supported by this client.`),new Error(`Skipping transport '${e.transport}' because it is not supported by this client.`);if(!function(e,t){return!e||0!=(t&e)}(t,o))return this._logger.log(S.Debug,`Skipping transport '${_[o]}' because it was disabled by the client.`),new v(`'${_[o]}' is disabled by the client.`,o);if(!(e.transferFormats.map((e=>C[e])).indexOf(n)>=0))return this._logger.log(S.Debug,`Skipping transport '${_[o]}' because it does not support the requested transfer format '${C[n]}'.`),new Error(`'${_[o]}' does not support ${C[n]}.`);if(o===_.WebSockets&&!this._options.WebSocket||o===_.ServerSentEvents&&!this._options.EventSource)return this._logger.log(S.Debug,`Skipping transport '${_[o]}' because it is not supported in your environment.'`),new p(`'${_[o]}' is not supported in your environment.`,o);this._logger.log(S.Debug,`Selecting transport '${_[o]}'.`);try{return this._constructTransport(o)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(S.Debug,`HttpConnection.stopConnection(${e}) called while in state ${this._connectionState}.`),this.transport=void 0,e=this._stopError||e,this._stopError=void 0,"Disconnected"!==this._connectionState){if("Connecting"===this._connectionState)throw this._logger.log(S.Warning,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is still in the connecting state.`),new Error(`HttpConnection.stopConnection(${e}) was called while the connection is still in the connecting state.`);if("Disconnecting"===this._connectionState&&this._stopPromiseResolver(),e?this._logger.log(S.Error,`Connection disconnected with error '${e}'.`):this._logger.log(S.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(S.Error,`TransportSendQueue.stop() threw error '${e}'.`)})),this._sendQueue=void 0),this.connectionId=void 0,this._connectionState="Disconnected",this._connectionStarted){this._connectionStarted=!1;try{this.onclose&&this.onclose(e)}catch(t){this._logger.log(S.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(S.Debug,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is already in the disconnected state.`)}_resolveUrl(e){if(0===e.lastIndexOf("https://",0)||0===e.lastIndexOf("http://",0))return e;if(!E.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(S.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=e.indexOf("?");let n=e.substring(0,-1===t?e.length:t);return"/"!==n[n.length-1]&&(n+="/"),n+="negotiate",n+=-1===t?"":e.substring(t),-1===n.indexOf("negotiateVersion")&&(n+=-1===t?"?":"&",n+="negotiateVersion="+this._negotiateVersion),n}}class z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new q,this._transportResult=new q,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new q),this._transportResult.promise}stop(){return this._executing=!1,this._sendBufferedData.resolve(),this._sendLoopPromise}_bufferData(e){if(this._buffer.length&&typeof this._buffer[0]!=typeof e)throw new Error(`Expected data to be of type ${typeof this._buffer} but was of type ${typeof e}`);this._buffer.push(e),this._sendBufferedData.resolve()}async _sendLoop(){for(;;){if(await this._sendBufferedData.promise,!this._executing){this._transportResult&&this._transportResult.reject("Connection stopped.");break}this._sendBufferedData=new q;const e=this._transportResult;this._transportResult=void 0;const t="string"==typeof this._buffer[0]?this._buffer.join(""):z._concatBuffers(this._buffer);this._buffer.length=0;try{await this._transport.send(t),e.resolve()}catch(t){e.reject(t)}}}static _concatBuffers(e){const t=e.map((e=>e.byteLength)).reduce(((e,t)=>e+t)),n=new Uint8Array(t);let o=0;for(const t of e)n.set(new Uint8Array(t),o),o+=t.byteLength;return n.buffer}}class q{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class J{static write(e){return`${e}${J.RecordSeparator}`}static parse(e){if(e[e.length-1]!==J.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(J.RecordSeparator);return t.pop(),t}}J.RecordSeparatorCode=30,J.RecordSeparator=String.fromCharCode(J.RecordSeparatorCode);class Y{writeHandshakeRequest(e){return J.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(T(e)){const o=new Uint8Array(e),r=o.indexOf(J.RecordSeparatorCode);if(-1===r)throw new Error("Message is incomplete.");const s=r+1;t=String.fromCharCode.apply(null,Array.prototype.slice.call(o.slice(0,s))),n=o.byteLength>s?o.slice(s).buffer:null}else{const o=e,r=o.indexOf(J.RecordSeparator);if(-1===r)throw new Error("Message is incomplete.");const s=r+1;t=o.substring(0,s),n=o.length>s?o.substring(s):null}const o=J.parse(t),r=JSON.parse(o[0]);if(r.type)throw new Error("Expected a handshake response from the server.");return[n,r]}}!function(e){e[e.Invocation=1]="Invocation",e[e.StreamItem=2]="StreamItem",e[e.Completion=3]="Completion",e[e.StreamInvocation=4]="StreamInvocation",e[e.CancelInvocation=5]="CancelInvocation",e[e.Ping=6]="Ping",e[e.Close=7]="Close"}(A||(A={}));class X{constructor(){this.observers=[]}next(e){for(const t of this.observers)t.next(e)}error(e){for(const t of this.observers)t.error&&t.error(e)}complete(){for(const e of this.observers)e.complete&&e.complete()}subscribe(e){return this.observers.push(e),new P(this,e)}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(D||(D={}));class Q{constructor(e,t,n,o){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(S.Warning,"The page is being frozen, this will likely lead to the connection being closed and messages being lost. For more information see the docs at https://docs.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},G.isRequired(e,"connection"),G.isRequired(t,"logger"),G.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=3e4,this.keepAliveIntervalInMilliseconds=15e3,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=o,this._handshakeProtocol=new Y,this.connection.onreceive=e=>this._processIncomingData(e),this.connection.onclose=e=>this._connectionClosed(e),this._callbacks={},this._methods={},this._closedCallbacks=[],this._reconnectingCallbacks=[],this._reconnectedCallbacks=[],this._invocationId=0,this._receivedHandshakeResponse=!1,this._connectionState=D.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:A.Ping})}static create(e,t,n,o){return new Q(e,t,n,o)}get state(){return this._connectionState}get connectionId(){return this.connection&&this.connection.connectionId||null}get baseUrl(){return this.connection.baseUrl||""}set baseUrl(e){if(this._connectionState!==D.Disconnected&&this._connectionState!==D.Reconnecting)throw new Error("The HubConnection must be in the Disconnected or Reconnecting state to change the url.");if(!e)throw new Error("The HubConnection url must be a valid url.");this.connection.baseUrl=e}start(){return this._startPromise=this._startWithStateTransitions(),this._startPromise}async _startWithStateTransitions(){if(this._connectionState!==D.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=D.Connecting,this._logger.log(S.Debug,"Starting HubConnection.");try{await this._startInternal(),E.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=D.Connected,this._connectionStarted=!0,this._logger.log(S.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=D.Disconnected,this._logger.log(S.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise(((e,t)=>{this._handshakeResolver=e,this._handshakeRejecter=t}));await this.connection.start(this._protocol.transferFormat);try{const t={protocol:this._protocol.name,version:this._protocol.version};if(this._logger.log(S.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(t)),this._logger.log(S.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(S.Debug,`Hub handshake failed with error '${e}' during start(). Stopping HubConnection.`),this._cleanupTimeout(),this._cleanupPingTimer(),await this.connection.stop(e),e}}async stop(){const e=this._startPromise;this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){return this._connectionState===D.Disconnected?(this._logger.log(S.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve()):this._connectionState===D.Disconnecting?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState=D.Disconnecting,this._logger.log(S.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(S.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new f("The connection was stopped before the hub handshake could complete."),this.connection.stop(e)))}stream(e,...t){const[n,o]=this._replaceStreamingParams(t),r=this._createStreamInvocation(e,t,o);let s;const i=new X;return i.cancelCallback=()=>{const e=this._createCancelInvocation(r.invocationId);return delete this._callbacks[r.invocationId],s.then((()=>this._sendWithProtocol(e)))},this._callbacks[r.invocationId]=(e,t)=>{t?i.error(t):e&&(e.type===A.Completion?e.error?i.error(new Error(e.error)):i.complete():i.next(e.item))},s=this._sendWithProtocol(r).catch((e=>{i.error(e),delete this._callbacks[r.invocationId]})),this._launchStreams(n,s),i}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,o]=this._replaceStreamingParams(t),r=this._sendWithProtocol(this._createInvocation(e,t,!0,o));return this._launchStreams(n,r),r}invoke(e,...t){const[n,o]=this._replaceStreamingParams(t),r=this._createInvocation(e,t,!1,o);return new Promise(((e,t)=>{this._callbacks[r.invocationId]=(n,o)=>{o?t(o):n&&(n.type===A.Completion?n.error?t(new Error(n.error)):e(n.result):t(new Error(`Unexpected message type: ${n.type}`)))};const o=this._sendWithProtocol(r).catch((e=>{t(e),delete this._callbacks[r.invocationId]}));this._launchStreams(n,o)}))}on(e,t){e&&t&&(e=e.toLowerCase(),this._methods[e]||(this._methods[e]=[]),-1===this._methods[e].indexOf(t)&&this._methods[e].push(t))}off(e,t){if(!e)return;e=e.toLowerCase();const n=this._methods[e];if(n)if(t){const o=n.indexOf(t);-1!==o&&(n.splice(o,1),0===n.length&&delete this._methods[e])}else delete this._methods[e]}onclose(e){e&&this._closedCallbacks.push(e)}onreconnecting(e){e&&this._reconnectingCallbacks.push(e)}onreconnected(e){e&&this._reconnectedCallbacks.push(e)}_processIncomingData(e){if(this._cleanupTimeout(),this._receivedHandshakeResponse||(e=this._processHandshakeResponse(e),this._receivedHandshakeResponse=!0),e){const t=this._protocol.parseMessages(e,this._logger);for(const e of t)switch(e.type){case A.Invocation:this._invokeClientMethod(e);break;case A.StreamItem:case A.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===A.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(S.Error,`Stream callback threw error: ${F(e)}`)}}break}case A.Ping:break;case A.Close:{this._logger.log(S.Information,"Close message received from server.");const t=e.error?new Error("Server returned an error on close: "+e.error):void 0;!0===e.allowReconnect?this.connection.stop(t):this._stopPromise=this._stopInternal(t);break}default:this._logger.log(S.Warning,`Invalid message type: ${e.type}.`)}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let t,n;try{[n,t]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(e){const t="Error parsing handshake response: "+e;this._logger.log(S.Error,t);const n=new Error(t);throw this._handshakeRejecter(n),n}if(t.error){const e="Server returned handshake error: "+t.error;this._logger.log(S.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(S.Debug,"Server handshake complete."),this._handshakeResolver(),n}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=(new Date).getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if(!(this.connection.features&&this.connection.features.inherentKeepAlive||(this._timeoutHandle=setTimeout((()=>this.serverTimeout()),this.serverTimeoutInMilliseconds),void 0!==this._pingServerHandle))){let e=this._nextKeepAlive-(new Date).getTime();e<0&&(e=0),this._pingServerHandle=setTimeout((async()=>{if(this._connectionState===D.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}}),e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const t=e.target.toLowerCase(),n=this._methods[t];if(!n)return this._logger.log(S.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null))));const o=n.slice(),r=!!e.invocationId;let s,i,a;for(const n of o)try{const o=s;s=await n.apply(this,e.arguments),r&&s&&o&&(this._logger.log(S.Error,`Multiple results provided for '${t}'. Sending error to server.`),a=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),i=void 0}catch(e){i=e,this._logger.log(S.Error,`A callback for the method '${t}' threw error '${e}'.`)}a?await this._sendWithProtocol(a):r?(i?a=this._createCompletionMessage(e.invocationId,`${i}`,null):void 0!==s?a=this._createCompletionMessage(e.invocationId,null,s):(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),a=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(a)):s&&this._logger.log(S.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(S.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new f("The underlying connection was closed before the hub handshake could complete."),this._handshakeResolver&&this._handshakeResolver(),this._cancelCallbacksWithError(e||new Error("Invocation canceled due to the underlying connection being closed.")),this._cleanupTimeout(),this._cleanupPingTimer(),this._connectionState===D.Disconnecting?this._completeClose(e):this._connectionState===D.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===D.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=D.Disconnected,this._connectionStarted=!1,E.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onclose callback called with error '${e}' threw error '${t}'.`)}}}async _reconnect(e){const t=Date.now();let n=0,o=void 0!==e?e:new Error("Attempting to reconnect due to a unknown error."),r=this._getNextRetryDelay(n++,0,o);if(null===r)return this._logger.log(S.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=D.Reconnecting,e?this._logger.log(S.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(S.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==D.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==r;){if(this._logger.log(S.Information,`Reconnect attempt number ${n} will start in ${r} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,r)})),this._reconnectDelayHandle=void 0,this._connectionState!==D.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=D.Connected,this._logger.log(S.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(S.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(S.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==D.Reconnecting)return this._logger.log(S.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===D.Disconnecting&&this._completeClose());o=e instanceof Error?e:new Error(e.toString()),r=this._getNextRetryDelay(n++,Date.now()-t,o)}}this._logger.log(S.Information,`Reconnect retries have been exhausted after ${Date.now()-t} ms and ${n} failed attempts. Connection disconnecting.`),this._completeClose()}_getNextRetryDelay(e,t,n){try{return this._reconnectPolicy.nextRetryDelayInMilliseconds({elapsedMilliseconds:t,previousRetryCount:e,retryReason:n})}catch(n){return this._logger.log(S.Error,`IRetryPolicy.nextRetryDelayInMilliseconds(${e}, ${t}) threw error '${n}'.`),null}}_cancelCallbacksWithError(e){const t=this._callbacks;this._callbacks={},Object.keys(t).forEach((n=>{const o=t[n];try{o(null,e)}catch(t){this._logger.log(S.Error,`Stream 'error' callback called with '${e}' threw error: ${F(t)}`)}}))}_cleanupPingTimer(){this._pingServerHandle&&(clearTimeout(this._pingServerHandle),this._pingServerHandle=void 0)}_cleanupTimeout(){this._timeoutHandle&&clearTimeout(this._timeoutHandle)}_createInvocation(e,t,n,o){if(n)return 0!==o.length?{arguments:t,streamIds:o,target:e,type:A.Invocation}:{arguments:t,target:e,type:A.Invocation};{const n=this._invocationId;return this._invocationId++,0!==o.length?{arguments:t,invocationId:n.toString(),streamIds:o,target:e,type:A.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:A.Invocation}}}_launchStreams(e,t){if(0!==e.length){t||(t=Promise.resolve());for(const n in e)e[n].subscribe({complete:()=>{t=t.then((()=>this._sendWithProtocol(this._createCompletionMessage(n))))},error:e=>{let o;o=e instanceof Error?e.message:e&&e.toString?e.toString():"Unknown error",t=t.then((()=>this._sendWithProtocol(this._createCompletionMessage(n,o))))},next:e=>{t=t.then((()=>this._sendWithProtocol(this._createStreamItemMessage(n,e))))}})}}_replaceStreamingParams(e){const t=[],n=[];for(let o=0;o<e.length;o++){const r=e[o];if(this._isObservable(r)){const s=this._invocationId;this._invocationId++,t[s]=r,n.push(s.toString()),e.splice(o,1)}}return[t,n]}_isObservable(e){return e&&e.subscribe&&"function"==typeof e.subscribe}_createStreamInvocation(e,t,n){const o=this._invocationId;return this._invocationId++,0!==n.length?{arguments:t,invocationId:o.toString(),streamIds:n,target:e,type:A.StreamInvocation}:{arguments:t,invocationId:o.toString(),target:e,type:A.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:A.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:A.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:A.Completion}:{invocationId:e,result:n,type:A.Completion}}}class Z{constructor(){this.name="json",this.version=1,this.transferFormat=C.Text}parseMessages(e,t){if("string"!=typeof e)throw new Error("Invalid input for JSON hub protocol. Expected a string.");if(!e)return[];null===t&&(t=b.instance);const n=J.parse(e),o=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case A.Invocation:this._isInvocationMessage(n);break;case A.StreamItem:this._isStreamItemMessage(n);break;case A.Completion:this._isCompletionMessage(n);break;case A.Ping:case A.Close:break;default:t.log(S.Information,"Unknown message type '"+n.type+"' ignored.");continue}o.push(n)}return o}writeMessage(e){return J.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),void 0!==e.invocationId&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),void 0===e.item)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const ee={trace:S.Trace,debug:S.Debug,info:S.Information,information:S.Information,warn:S.Warning,warning:S.Warning,error:S.Error,critical:S.Critical,none:S.None};class te{configureLogging(e){if(G.isRequired(e,"logging"),void 0!==e.log)this.logger=e;else if("string"==typeof e){const t=function(e){const t=ee[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new k(t)}else this.logger=new k(e);return this}withUrl(e,t){return G.isRequired(e,"url"),G.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return G.isRequired(e,"protocol"),this.protocol=e,this}withAutomaticReconnect(e){if(this.reconnectPolicy)throw new Error("A reconnectPolicy has already been set.");return e?Array.isArray(e)?this.reconnectPolicy=new a(e):this.reconnectPolicy=e:this.reconnectPolicy=new a,this}build(){const e=this.httpConnectionOptions||{};if(void 0===e.logger&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const t=new K(this.url,e);return Q.create(t,this.logger||b.instance,this.protocol||new Z,this.reconnectPolicy)}}class ne{static GenerateUUID(){var e=(new Date).getTime(),t="undefined"!=typeof performance&&performance.now&&1e3*performance.now()||0;return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(n){var o=16*Math.random();return e>0?(o=(e+o)%16|0,e=Math.floor(e/16)):(o=(t+o)%16|0,t=Math.floor(t/16)),("x"===n?o:3&o|8).toString(16)}))}}class oe{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}class re{constructor(){this.TransactionId=ne.GenerateUUID()}}var se,ie,ae,ce,le,ue,de,he,ge,fe,pe,ve,ye,we;(ve=se||(se={}))[ve.OK=0]="OK",ve[ve.UnknownError=1]="UnknownError",ve[ve.FatalError=2]="FatalError",ve[ve.WrongData=3]="WrongData",ve[ve.ResourceDoesNotExists=4]="ResourceDoesNotExists",ve[ve.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",ve[ve.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",ve[ve.OperationNotPermitted=7]="OperationNotPermitted",ve[ve.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",ve[ve.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",ve[ve.Error=10]="Error",ve[ve.NoData=11]="NoData",ve[ve.NotSupportedMethod=12]="NotSupportedMethod",ve[ve.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",ve[ve.MultiDataResponseStart=14]="MultiDataResponseStart",ve[ve.MultiDataResponse=15]="MultiDataResponse",ve[ve.MultiDataResponseStop=16]="MultiDataResponseStop",function(e){e[e.Get=0]="Get",e[e.Post=1]="Post",e[e.Delete=2]="Delete",e[e.Put=3]="Put",e[e.Options=4]="Options",e[e.Head=5]="Head"}(ie||(ie={}));class me{constructor(e,t){this.serialNumber=e,this.pin=t,this.SerialNumber=e,this.PIN=t}}!function(e){e[e.ByCloud=0]="ByCloud",e[e.LocalNetwork=1]="LocalNetwork",e[e.P2P=2]="P2P"}(ae||(ae={})),function(e){e[e.FailedToConnect=0]="FailedToConnect",e[e.AuthorizationFailed=1]="AuthorizationFailed",e[e.FailedToConnectToServer=2]="FailedToConnectToServer",e[e.Connected=3]="Connected",e[e.ControllerIsNotConnected=4]="ControllerIsNotConnected"}(ce||(ce={})),function(e){e[e.Disconnected=0]="Disconnected",e[e.Connecting=1]="Connecting",e[e.Connected=3]="Connected",e[e.Disconnecting=4]="Disconnecting",e[e.Failed=5]="Failed",e[e.Reconnecting=6]="Reconnecting"}(le||(le={}));class Se{constructor(){this._log=Uh.Get(o.ServiceName),this.handlers=[]}Subscribe(e){this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(){this.handlers.slice(0).forEach((e=>{try{e()}catch(e){this._log.Error(e)}}))}}(we=ue||(ue={}))[we.Any=0]="Any",we[we.Guest=10]="Guest",we[we.Standard=20]="Standard",we[we.Admin=30]="Admin",we[we.Installator=40]="Installator",we[we.Support=50]="Support",(ye=de||(de={}))[ye.Unknown=0]="Unknown",ye[ye.Men=1]="Men",ye[ye.Woman=2]="Woman",ye[ye.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(he||(he={})),function(e){e[e.Unknown=0]="Unknown",e[e.WrongAuthData=1]="WrongAuthData",e[e.NoResponseFromController=2]="NoResponseFromController"}(ge||(ge={}));class _e{constructor(e,t){this._type=fe.Unknown,this._data="",this._type=e,this._data=t}get Type(){return this._type}set Type(e){this._type=e}get Data(){return this._data}set Data(e){this._data=e}}class Ce{constructor(e,t){this._type=null,this._data="",this._type=e,this._data=t}get Type(){return this._type}set Type(e){this._type=e}get Data(){return this._data}set Data(e){this._data=e}}!function(e){e[e.UnknownError=-5]="UnknownError",e[e.NoPermissions=-4]="NoPermissions",e[e.WrongData=-3]="WrongData",e[e.ControllerResponseTimeout=-2]="ControllerResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Changed=1]="Changed"}(fe||(fe={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(pe||(pe={}));class Ae{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=pe.Device,this._dateTime=""}get Guid(){return this._guid}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}get Base64Image(){return this._base64Image}get ImageType(){return this._imageType}get DateTime(){return this._dateTime}set Base64Image(e){this._base64Image=e}set Guid(e){this._guid=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}set ImageType(e){this._imageType=e}}var De=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class be{constructor(){this._imageExistsCaseNumber=0,this._connection=Uh.Get(Vt.ServiceName),this._logger=Uh.Get(o.ServiceName)}GetServiceName(){return be.ServiceName}AddPictureAsync(e){var t,n;return De(this,void 0,void 0,(function*(){try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),se.WrongData;let o=new Image;const r=new Promise(((t,n)=>{o.src=e.Base64Image,o.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield r))return this._logger.Error(be.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),se.WrongData;if(0===o.height||0===o.width)return this._logger.Error(be.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),se.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(be.ServiceName,"Cannot add picture - Guid must be empty."),se.WrongData;const s=new Ee;s.Guid=ne.GenerateUUID(),s.DateTime=(new Date).toISOString(),s.ImageType=e.ImageType,s.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`,s.Base64Image=e.Base64Image;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Te(s.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),se.UnknownError;if(i.Status==se.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new ke(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),se.UnknownError):e.Status}return i.Status==se.OK?(this._logger.Warning(be.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):se.UnknownError):(this._logger.Error(be.ServiceName,"Cannot add picture - cannot get current picture status."),se.Error)}catch(e){return this._logger.Error(be.ServiceName,`Cannot add picture! ${e}`),se.FatalError}}))}EditPictureAsync(e){var t,n;return De(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot edit picture - guid is empty."),se.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),se.WrongData;let o=new Image;const r=new Promise(((t,n)=>{o.src=e.Base64Image,o.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield r))return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),se.WrongData;if(0===o.height||0===o.width)return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),se.WrongData;const s=new Ee;s.DateTime=(new Date).toISOString(),s.ImageType=e.ImageType,s.Base64Image=e.Base64Image,s.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?s.OwnerGuid=e.OwnerGuid:s.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Te(s.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),se.UnknownError;if(i.Status==se.ResourceDoesNotExists)return this._logger.Error(be.ServiceName,"Cannot edit picture - picture not exists."),se.OperationNotPermitted;if(i.Status==se.OK){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new ke(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),se.UnknownError):e.Status}return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot get current picture status."),se.Error}catch(e){return this._logger.Error(be.ServiceName,`Cannot edit picture! ${e}`),se.FatalError}}))}DeletePictureAsync(e){var t;return De(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot delete picture - guid is empty."),se.WrongData;const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(e.Guid),8e3,!1);return null==n||null==n.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),se.UnknownError):n.Status}catch(e){return this._logger.Error(be.ServiceName,`Cannot delete picture! ${e}`),se.FatalError}}))}GetPicturesInfoAsync(){var e;return De(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ne,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures info - unknown error!"),new Ce(se.UnknownError,"NoDataInResult")):t.Status!=se.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Ce(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Ce(se.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ie;return t.DateTime=e.DateTime,t.Guid=e.Guid,t.OwnerGuid=e.OwnerGuid,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture info! ${e}`),new Ce(se.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){var t;return De(this,void 0,void 0,(function*(){try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Te(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(be.ServiceName,"Cannot get picture - unknown error!"),new Ce(se.UnknownError,"NoDataInResult");switch(n.Status){case se.ResourceDoesNotExists:return new Ce(se.ResourceDoesNotExists,"PictureNotFound");case se.OK:if(null==n.Data)return new Ce(se.Error,"RespondedWithOKButNoData");const e=new Ge;return e.Base64Image=n.Data.Base64Image,e.DateTime=n.Data.DateTime,e.ImageType=n.Data.ImageType,e.Guid=n.Data.Guid,-1!=n.Data.OwnerGuid.indexOf("_")?(e.OwnerGuid=n.Data.OwnerGuid.substring(0,n.Data.OwnerGuid.indexOf("_")),e.OwnerIdentity=n.Data.OwnerGuid.substring(n.Data.OwnerGuid.indexOf("_")+1)):n.Data.Guid.includes("profilePicture")?(e.OwnerIdentity=n.Data.Guid.substring(n.Data.Guid.indexOf("_")+1),e.OwnerGuid=n.Data.OwnerGuid):n.Data.Guid.includes("devices_group")?(e.OwnerIdentity=n.Data.Guid.substring(0,n.Data.Guid.lastIndexOf("_")),e.OwnerGuid=n.Data.OwnerGuid):(e.OwnerGuid=n.Data.OwnerGuid,e.OwnerIdentity=""),e;default:return new Ce(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture! ${e}`),new Ce(se.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){var e;return De(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Pe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures - unknown error!"),new Ce(se.UnknownError,"NoDataInResult")):t.Status!=se.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Ce(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Ce(se.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ge;return t.Base64Image=e.Base64Image,t.DateTime=e.DateTime,t.Guid=e.Guid,t.ImageType=e.ImageType,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get pictures! ${e}`),new Ce(se.FatalError,"ExceptionOccurred")}}))}}be.ServiceName="PictureService";class Ge extends Ae{set DateTime(e){this._dateTime=e}}class Ee{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=pe.Device,this.DateTime=""}}class Ie{constructor(){this._guid="",this._dateTime="",this._ownerGuid="",this._ownerIdentity=""}get Guid(){return this._guid}get DateTime(){return this._dateTime}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}set Guid(e){this._guid=e}set DateTime(e){this._dateTime=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}}class Te extends re{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ie.Get,this.Data=e}}class Ne extends re{constructor(){super(),this.Resource="/pictures/info",this.Method=ie.Get}}class Pe extends re{constructor(){super(),this.Resource="/pictures/list",this.Method=ie.Get}}class ke extends re{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ie.Put,this.Data=e}}class Re extends re{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ie.Delete,this.Data=e}}var Oe=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class xe{constructor(){this._connection=null,this._connection=Uh.Get(Vt.ServiceName),this._pictureService=Uh.Get(be.ServiceName),this._sessionService=Uh.Get(He.ServiceName)}CanEditUser(e){const t=this._sessionService.User;return e.Guid===(null==t?void 0:t.Guid)||this.CanEditUsersOfAccessLevel(e.AccessLevel)}CanEditUsersOfAccessLevel(e){var t;const n=null===(t=this._sessionService.User)||void 0===t?void 0:t.AccessLevel;if(void 0===n)return!1;switch(e){case ue.Support:return n===ue.Support;case ue.Installator:return n>=ue.Installator;case ue.Admin:default:return n>=ue.Admin}}GetServiceName(){return xe.ServiceName}GetUsersAsync(){var e,t;return Oe(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new $e,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==se.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new We;n.AccessLevel=t.AccessLevel,n.Email=t.Email,n.Gender=t.Gender,n.Guid=t.Guid,n.IsAccountOnline=t.IsAccountOnline,n.Name=t.Name,n.IsActive=t.IsActive,n.IsBanned=t.IsBanned,n.Phone=t.Phone,n.Surname=t.Surname,e.push(n)})),e}return Promise.resolve([])}if((null==n?void 0:n.Status)==se.NoData)return Promise.resolve([]);throw null===(t=r.Log)||void 0===t||t.Debug(xe.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){var t,n;return Oe(this,void 0,void 0,(function*(){if(""===e)return Promise.resolve(null);null==e&&(e="");const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ue(e),2e4,!1);if(null==o||null==o.Data)return Promise.resolve(null);if(o.Status!=se.OK)return null===(n=r.Log)||void 0===n||n.Debug(xe.ServiceName,`Failed to retrieve user, error: ${o.Status}`),Promise.resolve(null);const s=new We;return s.AccessLevel=o.Data.AccessLevel,s.Email=o.Data.Email,s.Gender=o.Data.Gender,s.Guid=o.Data.Guid,s.IsAccountOnline=o.Data.IsAccountOnline,s.Name=o.Data.Name,s.IsActive=o.Data.IsActive,s.IsBanned=o.Data.IsBanned,s.Phone=o.Data.Phone,s.Surname=o.Data.Surname,s}))}CreateUserAsync(e,t){var n;return Oe(this,void 0,void 0,(function*(){if(null!=e.Guid&&""!=e.Guid)return new Ce(se.WrongData,"GuidMustBeEmpty");const o=new Fe;o.Name=e.Name.trim(),o.Surname=e.Surname.trim(),o.Email=e.Email.trim(),o.Password=t.trim(),o.Phone=e.Phone.trim(),o.Gender=e.Gender,o.AccessLevel=e.AccessLevel;const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Me(o),2e4,!1);return null==r||null==r.Status?new Ce(se.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Ce(r.Status,r.Data))}))}UpdateUserAsync(e){var t;return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");const n=new Fe;n.Guid=e.Guid,n.Name=e.Name.trim(),n.Surname=e.Surname.trim(),n.Email=e.Email.trim(),n.Phone=e.Phone.trim(),n.Gender=e.Gender,n.AccessLevel=e.AccessLevel;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Me(n),2e4,!1);return null==o||null==o.Status?new Ce(se.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Ce(o.Status,o.Data))}))}ChangePasswordAsync(e,t){var n;return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");const o=yield this.GetUserAsync(e.Guid);if(null==o)return new Ce(se.ResourceIsNotAvailable,"CannotGetUser");const r=new Fe;r.Guid=e.Guid,r.Password=t,r.AccessLevel=o.AccessLevel,r.Email=o.Email;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Me(r),2e4,!1);return null==s||null==s.Status?new Ce(se.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Ce(s.Status,s.Data))}))}DeleteUserAsync(e){var t,n;return Oe(this,void 0,void 0,(function*(){if(""===e)return se.WrongData;null==e&&(e="");const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e),2e4,!1);return null==o||null==o.Status?se.FatalError:(o.Status!=se.OK&&(null===(n=r.Log)||void 0===n||n.Debug(xe.ServiceName,`Failed to delete user, error: ${o.Status}`)),o.Status)}))}GetUserProfilePictureAsync(e){return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");const t=yield this._pictureService.GetPicturesInfoAsync();if(null!=t.Type)return t;const n=t.find((t=>"profilePicture"==t.OwnerIdentity&&t.OwnerGuid==e.Guid));if(null!=n){const e=yield this._pictureService.GetPictureAsync(n.Guid);return null!=e.Type?t:e}return new Ce(se.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return Oe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ce(se.WrongData,"GuidCannotBeEmpty");let n=new Ae;n.ImageType=pe.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const o=yield this.GetUserProfilePictureAsync(e);if(o.Type==se.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===se.OK?new Ce(se.OK,"PictureSet"):new Ce(e,"PictureServiceError")}if(null!=o.Type)return new Ce(se.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=o.Guid,n.OwnerGuid=o.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===se.OK?new Ce(se.OK,"PictureSet"):new Ce(e,"PictureServiceError")}}))}}xe.ServiceName="UsersService";class Ue extends re{constructor(e){super(),this.Resource="/users/user",this.Method=ie.Get,this.Data=e}}class Fe{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=de.Unknown,this.AccessLevel=ue.Any}}class Me extends re{constructor(e){super(),this.Resource="/users/user",this.Method=ie.Put,this.Data=e}}class $e extends re{constructor(){super(),this.Resource="/users/list",this.Method=ie.Get}}class Le extends re{constructor(e){super(),this.Resource="/users/user",this.Method=ie.Delete,this.Data=e}}class We{constructor(){this._guid="",this._cloudGuid="",this._name="",this._surname="",this._phone="",this._email="",this._isAccountOnline=!0,this._isAccountActive=!0,this._isAccountBanned=!0,this._notificationChannels=[],this._gender=de.Unknown,this._accessLevel=ue.Any,this._localization=he.En_Us}get Guid(){return this._guid}set Guid(e){this._guid=e}get CloudGuid(){return this._cloudGuid}set CloudGuid(e){this._cloudGuid=e}get Name(){return this._name}set Name(e){this._name=e}get Surname(){return this._surname}set Surname(e){this._surname=e}get Phone(){return this._phone}set Phone(e){this._phone=e}get AccessLevel(){return this._accessLevel}set AccessLevel(e){this._accessLevel=e}get Email(){return this._email}set Email(e){this._email=e}get IsAccountOnline(){return this._isAccountOnline}set IsAccountOnline(e){this._isAccountOnline=e}get IsActive(){return this._isAccountActive}set IsActive(e){this._isAccountActive=e}get IsBanned(){return this._isAccountBanned}set IsBanned(e){this._isAccountBanned=e}get NotificationChannels(){return this._notificationChannels}set NotificationChannels(e){this._notificationChannels=e}get Gender(){return this._gender}set Gender(e){this._gender=e}get Localization(){return this._localization}set Localization(e){this._localization=e}GetUserProfilePictureAsync(){return Uh.Get(xe.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return Uh.Get(xe.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var Be=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class He{constructor(){this._onUserLoggedInEvent=new n,this._onUserLoggedOutEvent=new n,this._email="",this._password="",this._loginTaskCompletionSource=this.CreateSessionCompletionSourceAsync(),this._alreadySubsribedToNetworkEvents=!1,this._user=null}CreateSessionCompletionSourceAsync(){var e;return Be(this,void 0,void 0,(function*(){null===(e=r.Log)||void 0===e||e.Debug(He.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{let t=n=>{var o;null===(o=r.Log)||void 0===o||o.Debug(He.ServiceName,`Logged in as ${n.Name}, completing CreateSessionCompletionSourceAsync()`),e(),this.OnUserLoggedInEvent().Unsubscribe(t)};this.OnUserLoggedInEvent().Subscribe(t)}))}))}Subscribe(e){}RestoreSessionAsync(){var e;return Be(this,void 0,void 0,(function*(){null===(e=r.Log)||void 0===e||e.Debug(He.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0!==this._user&&null!==this._user&&(yield this.UserLogInAsync(this._email,this._password))}))}WaitForSessionCreationAsync(){return Be(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){var e,t;return Be(this,void 0,void 0,(function*(){var n=new re;n.Resource="/users/user/logout",n.Method=ie.Put,this._email="",this._password="",(yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==se.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=r.Log)||void 0===e||e.Debug(He.ServiceName,"User has been logged out.")):null===(t=r.Log)||void 0===t||t.Debug(He.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return Be(this,void 0,void 0,(function*(){switch(e){case le.Disconnected:case le.Failed:break;case le.Connected:Uh.Get(He.ServiceName).RestoreSessionAsync()}}))}UserLogInAsync(e,t){var n,o;return Be(this,void 0,void 0,(function*(){var s=Uh.Get(Vt.ServiceName);const i=yield s.SendAndWaitForResponseAsync(new je(e,t),2e4,!1);if(i.Status==se.OK&&null!=i.Data){this._email=e,this._password=t;var a=new We;return this._user=a,a.AccessLevel=i.Data.AccessLevel,a.Email=i.Data.Email,a.Gender=i.Data.Gender,a.Guid=i.Data.Guid,a.IsAccountOnline=i.Data.IsAccountOnline,a.Name=i.Data.Name,a.IsActive=i.Data.IsActive,a.IsBanned=i.Data.IsBanned,a.Phone=i.Data.Phone,a.Surname=i.Data.Surname,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,s.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(n=r.Log)||void 0===n||n.Debug(He.ServiceName,`Did logging in succeded?: ${i.Status==se.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return null===(o=r.Log)||void 0===o||o.Debug(He.ServiceName,`User login response: ${i.Data}`),ge.WrongAuthData}))}GetServiceName(){return He.ServiceName}}He.ServiceName="SessionService";class Ve{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class je extends re{constructor(e,t){super(),this.Data=new Ve(e,t),this.Resource="/users/user/login",this.Method=ie.Put}}class Ke{constructor(){this._log=Uh.Get(o.ServiceName),Ke._localStorageService=Uh.Get(s.ServiceName)}GetServiceName(){return Ke.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===se.OK&&(this._log.Debug(Ke.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Ke._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Ke._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Ke.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Ke._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Ke.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Ke._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Ke.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Ke._localStorageService=null,Ke.ServiceName="WebApiCacheService";var ze=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class qe{constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new Se,this._onExitedConfigurationEvent=new Se,this._onConfigurationTimeCheckedEvent=new n,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{Uh.Get(He.ServiceName).OnUserLoggedInEvent().Subscribe((t=>ze(this,void 0,void 0,(function*(){this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),e()}))))})),this._connection=Uh.Get(Vt.ServiceName),this._session=Uh.Get(He.ServiceName),this._localStorage=Uh.Get(s.ServiceName),this._connection.OnDataReceivedEvent().Subscribe((e=>{"/info/configuration/mode/entry"==e.Resource?this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke():"/info/configuration/mode/exit"==e.Resource&&(this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke())}))}GetServiceName(){return qe.ServiceName}FactoryResetAsync(e){var t,n;return ze(this,void 0,void 0,(function*(){try{return null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ye,2e3,!1))||void 0===n?void 0:n.Status}catch(e){}let o=0,r=setInterval((()=>{o+=.3333333333333333,e(o)}),1e3);return yield oe.Delay(3e5),clearInterval(r),se.OK}))}RollbackLastUpdateAsync(e){var t,n;return ze(this,void 0,void 0,(function*(){try{return null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Xe,2e3,!1))||void 0===n?void 0:n.Status}catch(e){}let o=0,r=setInterval((()=>{o+=.23809523809523808,e(o)}),1e3);return yield oe.Delay(42e4),clearInterval(r),se.OK}))}RestartControllerAsync(e){var t,n;return ze(this,void 0,void 0,(function*(){try{return null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Je,2e3,!1))||void 0===n?void 0:n.Status}catch(e){}let o=0,r=setInterval((()=>{o+=.4166666666666667,e(o)}),1e3);return yield oe.Delay(24e4),clearInterval(r),se.OK}))}DidCofigurationChangeAsync(){return ze(this,void 0,void 0,(function*(){return yield this._synchronizationTaskCompletionSource,Promise.resolve(this._didConfigurationChange)}))}GetLastKnownConfigurationChangeTime(){var e;const t=null===(e=this._localStorage)||void 0===e?void 0:e.Read(this.GetServiceName(),"last_configuration_time");return null!=t?new Date(t):new Date}SaveLastConfigurationChangeTime(e){var t;null===(t=this._localStorage)||void 0===t||t.Save(this.GetServiceName(),"last_configuration_time",e.toString())}EnterConfigurationModeAsync(){var e;return ze(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Qe,2e4,!1)}))}ExitConfigurationModeAsync(){var e;return ze(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ze,2e4,!1),Uh.Get(Ke.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){var e;return ze(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new et,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=se.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return ze(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),!0)}))}}qe.ServiceName="ControllerConfigurationService";class Je extends re{constructor(){super(),this.Resource="/controller/restart",this.Method=ie.Post}}class Ye extends re{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ie.Post}}class Xe extends re{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ie.Post}}class Qe extends re{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ie.Put}}class Ze extends re{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ie.Put}}class et extends re{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ie.Get}}var tt,nt,ot,rt,st,it,at,ct,lt,ut,dt,ht,gt,ft,pt,vt,yt,wt,mt,St,_t,Ct,At,Dt,bt,Gt,Et,It,Tt,Nt,Pt,kt,Rt,Ot,xt,Ut,Ft,Mt,$t,Lt,Wt,Bt,Ht=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Vt{constructor(){this._logPackets=!1,this._pingInterval=5e3,this._disconnectedOnPurpose=!1,this._defaultPacketsBrokerAddress="br1.tr7.pl",this._serversBrokerAddress="https://broker.tr7.pl",this._address="br1.tr7.pl",this._isEstabilished=!1,this._timeout=1e4,this._dataReceivedEvent=new n,this._pongReceivedEvent=new Se,this._authorizationReceivedEvent=new n,this._registrationReceivedEvent=new n,this._connectionStateChangedEvent=new n,this._errorOccuredEvent=new n,this._log=Uh.Get(o.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._packetsBrokerServers=["br1.tr7.pl","br1.exala.pl"],this._lastReceivedPacketTime=Date.now()}GetServiceName(){return Vt.ServiceName}EnablePacketsLogging(){this._logPackets=!0}DisablePacketsLogging(){this._logPackets=!1}InitializeConnection(){if(this._controllerConfiguration=Uh.Get(qe.ServiceName),this._cache=Uh.Get(Ke.ServiceName),this._session=Uh.Get(He.ServiceName),this._connection){try{this._connection.stop()}catch(e){}this._connection=void 0}if(!this._address)throw new Error("Domain is not set");if(!this._serialId)throw new Error("SerialId is not set");if(!this._PIN)throw new Error("PIN is not set");this._connection=(new te).withUrl(`https://${this._address}/broker`).build(),this._dataReceivedEvent.Subscribe((e=>{this._lastReceivedPacketTime=Date.now()})),setInterval((()=>Ht(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval)}GetAuthorizationInfo(){return null!=this._serialId&&null!=this._PIN?new me(this._serialId,this._PIN):null}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._defaultPacketsBrokerAddress=e,this._address=e}GetServerAddressAsync(){return Ht(this,void 0,void 0,(function*(){try{let e=yield fetch(`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`);if(e.ok){let t=yield e.text();return t?(this._log.Debug(Vt.ServiceName,`Got server address: ${t}`),t):(this._log.Error(Vt.ServiceName,`Failed to get server address, status: ${e.status}`),null)}return this._log.Error(Vt.ServiceName,`Failed to get server address, status: ${e.status}`),null}catch(e){return this._log.Error(Vt.ServiceName,e),null}}))}ConnectAsync(e){return Ht(this,void 0,void 0,(function*(){return this._address=e,yield this.connectAsync()}))}AuthorizeAsync(e){return new Promise(((t,n)=>Ht(this,void 0,void 0,(function*(){var n;let o=0,r=e=>{window.clearTimeout(o),this._authorizationReceivedEvent.Unsubscribe(r),this._log.Debug(Vt.ServiceName,`Got authorization result: ${e}`),t(e)};o=window.setTimeout((()=>{window.clearTimeout(o),this._authorizationReceivedEvent.Unsubscribe(r),t(!1)}),2e3),this._log.Debug(Vt.ServiceName,`Authorizing to cloud using: ${e.SerialNumber} PIN: ${e.PIN}`),this._authorizationReceivedEvent.Subscribe(r),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)}))))}ConnectAndAuthorizeAsync(e){return Ht(this,void 0,void 0,(function*(){Uh.WorksInContextOf=e.SerialNumber,this._serialId=e.SerialNumber,this._PIN=e.PIN;var t=yield this.GetServerAddressAsync();if(t&&null!=t){this._log.Debug(Vt.ServiceName,`Got packets broker address: ${t}`),this.SetDefaultPacketsBrokerAddress(t);let n=yield this.connectAsync();return n!=ce.Connected?n:(yield this.AuthorizeAsync(e))?ce.Connected:ce.AuthorizationFailed}{let t=ce.ControllerIsNotConnected;this._log.Warning(Vt.ServiceName,"Server did not return packets broker address, trying to connect to known brokers.");for(let n of this._packetsBrokerServers){this._log.Warning(Vt.ServiceName,`Testing connection to ${n}`),this.SetDefaultPacketsBrokerAddress(n);try{yield this.DisconnectAsync()}catch(e){}this._log.Warning(Vt.ServiceName,`Connecting to server: ${n}`);let o=yield this.connectAsync();if(this._log.Warning(Vt.ServiceName,`Connection result: ${o}`),o==ce.Connected){if(yield this.AuthorizeAsync(e))return t=ce.Connected,t;this._log.Warning(Vt.ServiceName,`Failed to authorize in ${n}`)}}return t}}))}connectAsync(){var e,t,n,o,r,s,i,a,c;return Ht(this,void 0,void 0,(function*(){if(ce.FailedToConnect,!this._address)return Promise.resolve(ce.ControllerIsNotConnected);this._disconnectedOnPurpose&&(this._disconnectedOnPurpose=!1),this._connectionStateChangedEvent,this.InitializeConnection(),null===(e=this._connection)||void 0===e||e.onclose((()=>Ht(this,void 0,void 0,(function*(){var e,t;if(this._log.Error(Vt.ServiceName,"Connection closed"),Uh.Get(He.ServiceName).CreateSessionCompletionSourceAsync(),this.FireConnectionStateChanged(),(null===(e=this._connection)||void 0===e?void 0:e.state)===D.Disconnected&&!this._disconnectedOnPurpose)return yield null===(t=this._connection)||void 0===t?void 0:t.start(),null!=this._connection?(yield this.AuthorizeAsync(new me(this._serialId,this._PIN)),this._log.Info(Vt.ServiceName,"Reconnected from onClose"),this.FireConnectionStateChanged()):ce.FailedToConnect})))),null===(t=this._connection)||void 0===t||t.onreconnected((()=>Ht(this,void 0,void 0,(function*(){return yield this.AuthorizeAsync(new me(this._serialId,this._PIN)),this._log.Info(Vt.ServiceName,"Reconnected from onreconnected"),this.FireConnectionStateChanged()})))),null===(n=this._connection)||void 0===n||n.onreconnecting((()=>(this._log.Warning(Vt.ServiceName,"Reconnecting..."),this.FireConnectionStateChanged()))),yield null===(o=this._connection)||void 0===o?void 0:o.start(),null===(r=this._connection)||void 0===r||r.on("Pong",(()=>{this._log.Debug(Vt.ServiceName,"Pong received <-"),this._pongReceivedEvent.Invoke()})),null===(s=this._connection)||void 0===s||s.on("Registration",(e=>{var t;null===(t=this._registrationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(i=this._connection)||void 0===i||i.on("Authorization",(e=>{var t;null===(t=this._authorizationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(a=this._connection)||void 0===a||a.on("SendError",((e,t)=>Ht(this,void 0,void 0,(function*(){e.startsWith("NotAuthorized:")?(this._log.Error(Vt.ServiceName,"Failed to authorize!"),yield this.AuthorizeAsync(new me(this._serialId,this._PIN))):(this._log.Error(Vt.ServiceName,`Server returned error: ${e} ${t}`),this._errorOccuredEvent.Invoke([e,t]))}))));let l=this._dataReceivedEvent;return null===(c=this._connection)||void 0===c||c.on("Data",((e,t)=>{const n=JSON.parse(t);this._logPackets&&this._log.Debug(Vt.ServiceName,`Received data:\n${JSON.stringify(n,null,2)}`),l.Invoke(n)})),null!=this._connection?this.FireConnectionStateChanged():ce.FailedToConnect}))}FireConnectionStateChanged(){var e;const t=this._connectionStateChangedEvent;switch(null===(e=this._connection)||void 0===e?void 0:e.state){case D.Connected:return t.Invoke(le.Connected),ce.Connected;case D.Connecting:return t.Invoke(le.Connecting),ce.Connected;case D.Disconnected:return t.Invoke(le.Disconnected),ce.FailedToConnect;case D.Disconnecting:return t.Invoke(le.Disconnecting),ce.FailedToConnect;case D.Reconnecting:return t.Invoke(le.Reconnecting),ce.FailedToConnect}return ce.FailedToConnect}DisconnectAsync(){var e;return Ht(this,void 0,void 0,(function*(){this._disconnectedOnPurpose=!0,yield null===(e=this._connection)||void 0===e?void 0:e.stop()}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===D.Connected}SendAndWaitForResponseAsync(e,t,n,o=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,o)}SendAndWaitForResponseWithRepeatAsync(e,t,n,o=!0,r=!0){var s,i,a;return Ht(this,void 0,void 0,(function*(){if(e.Method===ie.Get&&n&&!(yield null===(s=this._controllerConfiguration)||void 0===s?void 0:s.DidCofigurationChangeAsync())){let t=null===(i=this._cache)||void 0===i?void 0:i.GetCache(e);if(null!==t)return Promise.resolve(t)}let c=0;const l=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(a=this._session)||void 0===a?void 0:a.WaitForSessionCreationAsync()),new Promise(((s,i)=>Ht(this,void 0,void 0,(function*(){let a=i=>Ht(this,void 0,void 0,(function*(){var u,d,h,g;if((null==i?void 0:i.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const f=Date.now()-l;r&&this._log.Debug(Vt.ServiceName,`Received response for: ${null==i?void 0:i.Resource} ${null==i?void 0:i.Method} id: ${null==i?void 0:i.TransactionId} in ${f}ms`),e.Method===ie.Get&&n&&(null===(u=this._cache)||void 0===u||u.Cache(i)),!n&&(null==i?void 0:i.Status)===se.UserIsNotLoggedIn&&o&&((null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(g=this._session)||void 0===g?void 0:g.RestoreSessionAsync(),s(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,r))),s(i)}}));if(this._dataReceivedEvent.Subscribe(a),c=window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(a);let t=`Response timeout, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;this._log.Error(Vt.ServiceName,t),i(new g(t))}),t),!(yield this.SendAsync(e,r))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;i(new Error(t))}}))))}))}SendAndHandleResponseAsync(e,t,n,o=!0){var r;return Ht(this,void 0,void 0,(function*(){let s=0;const i=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(r=this._session)||void 0===r?void 0:r.WaitForSessionCreationAsync()),new Promise(((r,a)=>Ht(this,void 0,void 0,(function*(){const c=()=>window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(l);let t=`Response timeout, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;this._log.Error(Vt.ServiceName,t),a(new g(t))}),t);let l=u=>Ht(this,void 0,void 0,(function*(){var d,h,g;if((null==u?void 0:u.TransactionId)==e.TransactionId){window.clearTimeout(s);const f=Date.now()-i;switch(o&&this._log.Debug(Vt.ServiceName,`Received response for: ${null==u?void 0:u.Resource} ${null==u?void 0:u.Method} id: ${null==u?void 0:u.TransactionId} in ${f}ms`),(null==u?void 0:u.Status)===se.UserIsNotLoggedIn&&(this._dataReceivedEvent.Unsubscribe(l),(null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(g=this._session)||void 0===g?void 0:g.RestoreSessionAsync(),r(yield this.SendAndHandleResponseAsync(e,t,n,o))),null==u?void 0:u.Status){case se.MultiDataResponseStart:case se.MultiDataResponse:n(u),s=c();break;case se.MultiDataResponseStop:n(u),this._dataReceivedEvent.Unsubscribe(l),r();break;default:let t=`Failed to process MultiDataResponse - recived incorrect response status: ${null==u?void 0:u.Status} method: ${e.Method} transaction id: ${e.TransactionId}\n make sure that the requested endpoint uses MultiDataResponse, otherwise use SendAndWaitForResponseAsync<T> method.`;a(new Error(t))}}}));if(this._dataReceivedEvent.Subscribe(l),s=c(),!(yield this.SendAsync(e,o))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;a(new Error(t))}}))))}))}PingControllerAsync(){var e;return Ht(this,void 0,void 0,(function*(){if((null===(e=this._connection)||void 0===e?void 0:e.state)!==D.Connected)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new re;return t.Resource="/system/ping",t.Method=ie.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SendAsync(e,t=!1){if(!this.IsConnected())throw new Error("Connection is not established");return new Promise((n=>{var o;this._logPackets?this._log.Debug(Vt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId} data:\n${JSON.stringify(e,null,2)}`):t&&this._log.Debug(Vt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId}`),null===(o=this._connection)||void 0===o||o.invoke("SendTo",this._serialId,e).then((()=>{n(!0)})).catch((e=>{this._log.Error(Vt.ServiceName,`${e}`),n(!1)}))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}}Vt.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(tt||(tt={})),(Ft=nt||(nt={}))[Ft.Default=0]="Default",Ft[Ft.Monostable=1]="Monostable",Ft[Ft.Bistable=2]="Bistable",Ft[Ft.Gate=3]="Gate",Ft[Ft.Gateway=4]="Gateway",function(e){e[e.None=0]="None",e[e.OnOff=1]="OnOff",e[e.OnOffLights=2]="OnOffLights",e[e.OnOffWithDelay=3]="OnOffWithDelay",e[e.GateSwitchState=4]="GateSwitchState",e[e.GatePulse=5]="GatePulse",e[e.GateOpenClose=6]="GateOpenClose",e[e.GatewayOpenClose=7]="GatewayOpenClose",e[e.GatewayPulse=8]="GatewayPulse",e[e.Monostable=9]="Monostable",e[e.Dimmer=10]="Dimmer",e[e.Blind=11]="Blind",e[e.Roller=12]="Roller",e[e.TemperatureSensor=13]="TemperatureSensor",e[e.BrightnessSensor=14]="BrightnessSensor",e[e.HumiditySensor=15]="HumiditySensor",e[e.PowerMeter=16]="PowerMeter",e[e.RGBLight=17]="RGBLight",e[e.RGBWLight=18]="RGBWLight",e[e.LightsWarmth=19]="LightsWarmth",e[e.TemperatureControl=20]="TemperatureControl",e[e.BlindsWithPrecisePosition=21]="BlindsWithPrecisePosition",e[e.MovementSensor=21]="MovementSensor",e[e.SimpleRemote=22]="SimpleRemote",e[e.BlindsRemote=23]="BlindsRemote",e[e.DistanceSensor=24]="DistanceSensor",e[e.Multisensor=25]="Multisensor",e[e.IOTransmitter=26]="IOTransmitter",e[e.DoorOpenClose=27]="DoorOpenClose",e[e.WindSensor=28]="WindSensor",e[e.BatterySensor=29]="BatterySensor",e[e.PressureSensor=30]="PressureSensor"}(ot||(ot={}));class jt{constructor(){this._type=rt.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Mt=rt||(rt={})).Unknown="Unknown",Mt.SetBlindPosition="IBlindPosition",Mt.SetBlindPositionSimple="IBlindPositionSimple",Mt.SetBlindMicroventilation="IMicroventilation",Mt.TurnOff="IChannelOff",Mt.TurnOn="IChannelOn",Mt.TogleState="IChannelSwitchState",Mt.SetLightBrightnessDynamicly="IDynamicLightBrightness",Mt.SetLightBrightness="ILightBrightness",Mt.SetLightColor="ILightColor",Mt.SetLightTemperature="ILightTemperature",Mt.PairDevice="IPair",Mt.UnpairDevice="IUnpair",Mt.IdentifyDevice="IIdentifyDevice",Mt.GetChannelsState="IGetDeviceState",Mt.GetPowerMeasurements="IGetPowerMeasurements",Mt.GetAvailableData="IGetAvailableData",Mt.MultipleDataRequest="IMultipleDataRequest",Mt.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",Mt.SetTemperature="IChangeTemperature",Mt.ChangeGatePositionPulse="IGatePulse",Mt.ChangeGatewayPositionPulse="IGatewayPulse",Mt.SetFacadePosition="IFacadePosition",Mt.GetFacadeType="IGetFacadeType",Mt.LightRGBW="ILightRGBW";class Kt{constructor(){this._type=st.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}!function(e){e.Unknown="Unknown",e.BatteryState="IBatteryState",e.BinarySensorState="IBinarySensor",e.BlindOpenCloseTime="IBlindOpenCloseTime",e.BlindPosition="IBlindPosition",e.BlindRemoteButtonState="IBlindsControlButton",e.MeasuredBrightness="IBrightness",e.RemoteButtonState="IButtonState",e.ChannelOnOffState="IChannelOnOff",e.DoorBellState="IDoorBell",e.FacadeRemoteButtonState="IFacadeControlButton",e.FacadePosition="IFacadeState",e.FacadeType="IFacadeType",e.FloodSensorState="IFloodSensor",e.GatePosition="IGatePosition",e.GatewayPosition="IGatewayPosition",e.HumiditySensorState="IHumiditySensor",e.LightBrightness="ILightBrightness",e.LightColor="ILightColor",e.LightWarmth="ILightTemperature",e.LightTreshold="ILightTreshold",e.MovementSensorState="IMovementSensor",e.OnlineCamera="IOnlineCamera",e.OvercurrentProtectionState="IOvercurrentProtection",e.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",e.ReedState="IReedState",e.SignalStrength="ISignalStrength",e.SmokeSensorState="ISmokeSensor",e.MeasuredTemperature="ITemperature",e.VibrationSensorState="IVibrationSensor",e.MeasuredWindSpeed="IWindSpeed",e.WindThreshold="IWindThreshold",e.MeasuredEnergy="IEnergy",e.MeasuredDistance="DistanceSensor",e.BlindCalibration="BlindCalibration",e.ConfigurationState="ConfigurationState",e.CurrentWindThreshold="CurrentWindThreshold",e.CurrentLightThreshold="CurrentLightThreshold",e.WindSpeedState="WindSpeed",e.TamperProtectionState="ITamperProtection",e.PressureSensorState="IPressureSensor",e.LightRGBWState="ILightRGBW"}(st||(st={})),(Wt=it||(it={}))[Wt.NotResponding=0]="NotResponding",Wt[Wt.Working=1]="Working",Wt[Wt.Broken=2]="Broken",Wt[Wt.FirmareUpgradeMode=3]="FirmareUpgradeMode",(Lt=at||(at={}))[Lt.TwoWay=1]="TwoWay",Lt[Lt.OneWay=2]="OneWay",Lt[Lt.ConditionalTwoWay=3]="ConditionalTwoWay",($t=ct||(ct={}))[$t.Unknown=-1]="Unknown",$t[$t.Multipurpose=0]="Multipurpose",$t[$t.Controller=1]="Controller",$t[$t.Driver=2]="Driver",$t[$t.Receiver=3]="Receiver",$t[$t.Remote=4]="Remote",$t[$t.Sensor=5]="Sensor",$t[$t.Scene=6]="Scene";class zt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=tt.NoTasksExecuting}}!function(e){e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed",e[e.ResponseTimeout=2]="ResponseTimeout",e[e.TaskRepeatedAndExecuted=3]="TaskRepeatedAndExecuted",e[e.TaskRepeatedResponseTimeout=4]="TaskRepeatedResponseTimeout",e[e.FlowControlNotAvailable=5]="FlowControlNotAvailable",e[e.ExecutionError=6]="ExecutionError"}(lt||(lt={})),function(e){e[e.ControllerResponseTimeout=-4]="ControllerResponseTimeout",e[e.DeviceNotFound=-3]="DeviceNotFound",e[e.DeviceResponseTimeout=-2]="DeviceResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed"}(ut||(ut={}));class qt{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=ut.Unknown}}class Jt{constructor(){this._type="",this._data=null,this._typeAsEnum=st.Unknown}get Data(){return this._data}set Data(e){this._data=e}get Type(){return this._type}set Type(e){this._type=e}get TypeAsEnum(){return this._typeAsEnum}set TypeAsEnum(e){this._typeAsEnum=e}}(Bt=dt||(dt={}))[Bt.Confident=0]="Confident",Bt[Bt.Unconfident=1]="Unconfident";class Yt extends Jt{constructor(e){super(),this.TypeAsEnum=st.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(ht||(ht={}));class Xt extends Jt{constructor(e){super(),this.TypeAsEnum=st.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(gt||(gt={}));class Qt extends Jt{constructor(e){super(),this.TypeAsEnum=st.ReedState,this.Type="ReedState",this.Data=e.state}}class Zt extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return ft.UnableToMove;case 201:return ft.MotorOverheatedPleaseWait;default:return ft.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(ft||(ft={}));class en extends Jt{constructor(e){super(),this.TypeAsEnum=st.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(pt||(pt={}));class tn extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightColor,this.Type="LightColorState",this.Data=e.state}}class nn extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class on extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class rn extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}!function(e){e[e.AirTemperature=0]="AirTemperature",e[e.InsideTemperature=1]="InsideTemperature",e[e.OutsideTemperature=2]="OutsideTemperature",e[e.FloorTemperature=3]="FloorTemperature",e[e.SafetyTemperature=4]="SafetyTemperature",e[e.SetTemperature=5]="SetTemperature"}(vt||(vt={}));class sn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BatteryState,this.Type="BatteryState",this.Data=e.state}}!function(e){e[e.Unknown=-1]="Unknown",e[e.Full=0]="Full",e[e.Empty=1]="Empty",e[e.Half=2]="Half",e[e.Percentage=3]="Percentage",e[e.Low=4]="Low",e[e.ExternalPower=5]="ExternalPower"}(yt||(yt={}));class an extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class cn extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state}}class ln extends Jt{constructor(e){super(),this.TypeAsEnum=st.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(wt||(wt={}));class un extends Jt{constructor(e){super(),this.TypeAsEnum=st.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(mt||(mt={}));class dn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}!function(e){e[e.OpenPressed=1]="OpenPressed",e[e.OpenReleased=2]="OpenReleased",e[e.StopPressed=3]="StopPressed",e[e.StopReleased=4]="StopReleased",e[e.ClosePressed=5]="ClosePressed",e[e.CloseReleased=6]="CloseReleased"}(St||(St={}));class hn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}!function(e){e[e.OpenPressed=1]="OpenPressed",e[e.OpenReleased=2]="OpenReleased",e[e.StopPressed=3]="StopPressed",e[e.StopReleased=4]="StopReleased",e[e.ClosePressed=5]="ClosePressed",e[e.CloseReleased=6]="CloseReleased"}(_t||(_t={}));class gn extends Jt{constructor(e){super(),this.TypeAsEnum=st.SignalStrength,this.Type="SignalStrenghtState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Excellent=1]="Excellent",e[e.Good=2]="Good",e[e.Acceptable=3]="Acceptable",e[e.Low=4]="Low",e[e.Terrible=5]="Terrible",e[e.NoLink=6]="NoLink"}(Ct||(Ct={}));class fn extends Jt{constructor(e){super(),this.TypeAsEnum=st.GatePosition,this.Type="GatePositionState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Open=1]="Open",e[e.PartiallyOpen=2]="PartiallyOpen",e[e.Close=3]="Close"}(At||(At={}));class pn extends Jt{constructor(e){super(),this.TypeAsEnum=st.GatewayPosition,this.Type="GatewayPositionState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Open=1]="Open",e[e.PartiallyOpen=2]="PartiallyOpen",e[e.Close=3]="Close",e[e.On=4]="On",e[e.Off=5]="Off"}(Dt||(Dt={}));class vn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindCalibration,this.Type="BlindCalibrationState",this.Data=e.state}}!function(e){e[e.AutoLernIdle=0]="AutoLernIdle",e[e.AutoLernInProgress=1]="AutoLernInProgress",e[e.AutoLernSuccessfull=2]="AutoLernSuccessfull",e[e.AutoLernCancelled=4]="AutoLernCancelled"}(bt||(bt={}));class yn extends Jt{constructor(e){super(),this.TypeAsEnum=st.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}!function(e){e[e.AirHumidity=0]="AirHumidity",e[e.InsideHumidity=1]="InsideHumidity",e[e.OutsideHumidity=2]="OutsideHumidity",e[e.SafetyHumidity=3]="SafetyHumidity",e[e.SetHumidity=4]="SetHumidity"}(Gt||(Gt={}));class wn extends Jt{constructor(e){super(),this.TypeAsEnum=st.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Et||(Et={}));class mn extends Jt{constructor(e){super(),this.TypeAsEnum=st.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(It||(It={}));class Sn extends Jt{constructor(e){super(),this.TypeAsEnum=st.ConfigurationState,this.Type="ConfigurationState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.OngoingConfiguration=1]="OngoingConfiguration",e[e.NotConfigured=2]="NotConfigured",e[e.Configured=3]="Configured",e[e.PartiallyConfigured=4]="PartiallyConfigured"}(Tt||(Tt={}));class _n extends Jt{constructor(e){super(),this.TypeAsEnum=st.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class Cn extends Jt{constructor(e){super(),this.TypeAsEnum=st.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class An extends Jt{constructor(e){super(),this.TypeAsEnum=st.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class Dn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class bn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Gn extends Jt{constructor(e){super(),this.TypeAsEnum=st.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Below=1]="Below",e[e.Exceeded=2]="Exceeded",e[e.Inactive=3]="Inactive"}(Nt||(Nt={}));class En extends Jt{constructor(e){super(),this.TypeAsEnum=st.CurrentLightThreshold,this.Type="CurrentLightThresholdState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Below=1]="Below",e[e.Exceeded=2]="Exceeded"}(Pt||(Pt={}));class In extends Jt{constructor(e){super(),this.TypeAsEnum=st.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class Tn extends Jt{constructor(e){super(),this.TypeAsEnum=st.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(kt||(kt={})),function(e){e[e.AirHumidity=0]="AirHumidity",e[e.InsideHumidity=1]="InsideHumidity",e[e.OutsideHumidity=2]="OutsideHumidity",e[e.SafetyHumidity=3]="SafetyHumidity",e[e.SetHumidity=4]="SetHumidity"}(Rt||(Rt={}));class Nn extends Jt{constructor(e){super(),this.TypeAsEnum=st.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(Ot||(Ot={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(xt||(xt={}));class Pn extends Jt{constructor(e){super(),this.TypeAsEnum=st.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(Ut||(Ut={}));class kn extends Jt{constructor(e){super(),this.TypeAsEnum=st.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Rn{constructor(){this._onDeviceStateChangedEvent=new n,this._onDeviceTasksExecutionChangedOnChannelsEvent=new n,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=it.Working,this._deviceType=ct.Unknown,this._communicationWay=at.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,null==Rn._devicesService&&(Rn._devicesService=Uh.Get(oo.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Rn._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Rn._devicesService.OnDevicesTasksExecutionChangeEvent().Subscribe((e=>{t.Invoke(e.filter((e=>e.DeviceGuid==this._guid)).map((e=>e.Channel)))}))}get States(){return o.DoesThrowStackTrace?Uh.Get(oo.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Rn._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Rn._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Rn._devicesService.ExecuteDeviceTaskAsync(this,e)}OnDeviceTasksExecutionChangedOnChannelsEvent(){return this._onDeviceTasksExecutionChangedOnChannelsEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}get Guid(){return null==this._guid?"":this._guid}set Guid(e){this._guid=e}get Name(){return null==this._name?"":this._name}set Name(e){this._name=e}get ChannelsAmount(){return null==this._channelsAmount?0:this._channelsAmount}set ChannelsAmount(e){this._channelsAmount=e}get SerialNumber(){return this._serialNumber}set SerialNumber(e){this._serialNumber=e}get Model(){return this._model}set Model(e){this._model=e}get ModelGuid(){return this._modelGuid}set ModelGuid(e){this._modelGuid=e}get ManufacturerGuid(){return this._manufacturerGuid}set ManufacturerGuid(e){this._manufacturerGuid=e}get IsVirtual(){return this._isVirtual}set IsVirtual(e){this._isVirtual=e}get IsEnabled(){return this._isEnabled}set IsEnabled(e){this._isEnabled=e}get DeviceState(){return this._deviceState}set DeviceState(e){this._deviceState=e}get DeviceType(){return this._deviceType}set DeviceType(e){this._deviceType=e}get CommunicationWay(){return this._communicationWay}set CommunicationWay(e){this._communicationWay=e}get AvailableTaskTypes(){return this._availableTasksTypes}set AvailableTaskTypes(e){this._availableTasksTypes=e}get AvailableResponseTypes(){return this._availableResponseTypes}set AvailableResponseTypes(e){this._availableResponseTypes=e}get Channels(){return this._channels}get ProtocolGuid(){return this._protocolGuid}set ProtocolGuid(e){this._protocolGuid=e}ChangeDeviceNameAsync(e){return t=this,n=void 0,r=function*(){try{const t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new On(this,e),2e4,!1);switch(t.Status){case se.OK:return this._name=e,Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),new _e(fe.Changed,"");case se.WrongData:if("DeviceNotFound"==t.Data)return new _e(fe.Failed,"DeviceNotFound");break;case se.NoPermissionsToCallGivenResource:return new _e(fe.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new _e(fe.ControllerResponseTimeout,""):new _e(fe.UnknownError,"")}return new _e(fe.Unknown,"")},new((o=void 0)||(o=Promise))((function(e,s){function i(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(t){var n;t.done?e(t.value):(n=t.value,n instanceof o?n:new o((function(e){e(n)}))).then(i,a)}c((r=r.apply(t,n||[])).next())}));var t,n,o,r}ExecuteTaskAsync(e){return Rn._devicesService.ExecuteDeviceTaskAsync(this,e)}}class On extends re{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ie.Put;const n=new xn;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class xn{constructor(){this.DeviceGuid="",this.Name=""}}var Un,Fn,Mn,$n,Ln,Wn=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Bn{constructor(){this._device=new Rn,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=nt.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new n,null==Bn._devicesService&&(Bn._devicesService=Uh.Get(oo.ServiceName))}IsCustomDataAndRolesSupported(){return this.CustomDataAndRolesSupported}get CustomData(){return this._customData}set CustomData(e){this._customData=e}get Roles(){return this._roles}set Roles(e){this._roles=e}get ChannelId(){return this._channelId}SetDevice(e){this._device=e,this._channelId=`${e.Guid}_${this.Number}`}GetDevice(){return this._device}SetCustomDataAsync(e,t){return Wn(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t;const o=new Hn;return o.DeviceGuid=this._device.Guid,o.ChannelConfiguration=n,this.ChangeConfigurationAsync(o)}))}RemoveCustomDataAsync(e){const t=this.GetChannelConfigurationData();delete t.CustomData[e];const n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new Vn;return e.Channel=this._number,e.ChannelName=this._name,e.Configuration=this._mode,e.CustomData=this._customData,e.GroupsGuids=this._channelGroups,e.Hidden=this._isHidden,e.IconName=this._iconName,e}HideAsync(){const e=this.GetChannelConfigurationData();e.Hidden=!0;const t=new Hn;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ShowAsync(){const e=this.GetChannelConfigurationData();e.Hidden=!1;const t=new Hn;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,t.ChannelName=e,this.ChangeConfigurationAsync(n)}ChangeIconNameAsync(e){const t=this.GetChannelConfigurationData();t.IconName=e;const n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}ChangeGroupsAsync(e){const t=this.GetChannelConfigurationData();t.GroupsGuids=e;const n=new Hn;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){var t;return Wn(this,void 0,void 0,(function*(){try{const n=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new jn(e),2e4,!1);switch(n.Status){case se.OK:return this._name=e.ChannelConfiguration.ChannelName,this._iconName=e.ChannelConfiguration.IconName,this._channelGroups=e.ChannelConfiguration.GroupsGuids,this._isHidden=e.ChannelConfiguration.Hidden,this._mode=e.ChannelConfiguration.Configuration,this._customData=e.ChannelConfiguration.CustomData,this._roles=e.ChannelConfiguration.Roles,Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),new _e(fe.Changed,"");case se.WrongData:if("DeviceNotFound"===n.Data)return null===(t=r.Log)||void 0===t||t.Error("Failed to change channel configuration, referenced device does not exist!"),new _e(fe.WrongData,"DeviceNotFound");break;case se.FatalError:return new _e(fe.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new _e(fe.ControllerResponseTimeout,"")}return new _e(fe.Unknown,"")}))}get Number(){return this._number}set Number(e){this._number=e}get Name(){return this._name}set Name(e){this._name=e}get IconName(){return this._iconName}set IconName(e){this._iconName=e}get States(){return o.DoesThrowStackTrace?Uh.Get(oo.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Bn._devicesService.GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray()}get Mode(){return this._mode}set Mode(e){this._mode=e}get ChannelGroups(){return this._channelGroups}set ChannelGroups(e){this._channelGroups=e}get IsHidden(){return this._isHidden}set IsHidden(e){this._isHidden=e}get AvailableTaskTypes(){return this._availableTasksTypes}set AvailableTaskTypes(e){this._availableTasksTypes=e}get AvailableResponseTypes(){return this._availableResponseTypes}set AvailableResponseTypes(e){this._availableResponseTypes=e}OnTasksExecutionChangeEvent(){return this._onTasksExecutionChangedEvent}ExecuteTaskAsync(e){return null!=this._device?(e.Channel=this.Number,e.DeviceGuid=this._device.Guid,Bn._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(ut.Failed)}}Bn._devicesService=null;class Hn{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new Vn}}class Vn{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=nt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class jn extends re{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ie.Put,this.Data=e}}(Ln=Un||(Un={}))[Ln.TurnOn=0]="TurnOn",Ln[Ln.TurnOff=1]="TurnOff",Ln[Ln.ToggleState=2]="ToggleState",Ln[Ln.SetBlindPosition=3]="SetBlindPosition",Ln[Ln.SetLightColor=4]="SetLightColor",Ln[Ln.SetLightTemperature=5]="SetLightTemperature",Ln[Ln.SetLightBrightness=6]="SetLightBrightness",Ln[Ln.SetTemperature=7]="SetTemperature",Ln[Ln.GetState=8]="GetState",Ln[Ln.TurnOnWithTimeout=9]="TurnOnWithTimeout",Ln[Ln.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",Ln[Ln.IdentifyDevice=11]="IdentifyDevice",Ln[Ln.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",Ln[Ln.SetBlindMicroventilation=13]="SetBlindMicroventilation",Ln[Ln.GatewayPulse=25]="GatewayPulse",Ln[Ln.GatePulse=26]="GatePulse",Ln[Ln.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",Ln[Ln.GetFacadeType=30]="GetFacadeType",Ln[Ln.LightRGBW=31]="LightRGBW",function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Fn||(Fn={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Mn||(Mn={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage",e[e.Tilt=4]="Tilt",e[e.TiltAndPercentage=5]="TiltAndPercentage"}($n||($n={}));var Kn=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class zn{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return zn.ServiceName}RegisterManuallyPairedDevicesProtocol(e){Uh.Get(o.ServiceName).Debug(zn.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return Kn(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()],n=[];if(null!=e)if(Array.isArray(e))for(let o=0;o<t.length;o++)e.any((e=>e==t[o].ProtocolExtensionGuid))&&n.push(...yield t[o].GetDevicesForManualPairingAsync());else{const o=t.find((t=>t.ProtocolExtensionGuid==e));null!=o&&n.push(...yield o.GetDevicesForManualPairingAsync())}else for(let e=0;e<t.length;e++)n.push(...yield t[e].GetDevicesForManualPairingAsync());return n}))}AddManuallyPairedDeviceAsync(e){return Kn(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=t?t.AddManuallyPairedDeviceAsync(e):ut.Failed}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}zn.ServiceName="ManualDeviceService";class qn{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var Jn=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Yn{constructor(){this._connection=null,this._localDb=null,this._connection=Uh.Get(Vt.ServiceName),this._localDb=Uh.Get(s.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return Jn(this,void 0,void 0,(function*(){let o=new Xn(e,t,n),r=yield this._connection.SendAndWaitForResponseAsync(o,35e3,!1);if(r.Status===se.OK){const o=new eo;o.ResourceGuid=e,o.Data=JSON.stringify(n),o.IsGlobal=t,this._localDb.Save(Yn.ServiceName,this.GetLocalDbName(e,t),o)}return r.Status}))}ReadAsync(e,t,n){return Jn(this,void 0,void 0,(function*(){let o=new Qn(e,t);if(!n){const n=this._localDb.Read(Yn.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new qn;return t.Data=JSON.parse(e.Data),t.IsGlobal=e.IsGlobal,t.ResourceGuid=e.ResourceGuid,t}}let r=yield this._connection.SendAndWaitForResponseAsync(o,35e3,!1);if(r.Status===se.OK){const e=new qn;return e.ResourceGuid=r.ResourceGuid,e.Data=JSON.parse(r.Data),e.IsGlobal=r.IsGlobal,e}return r.Status}))}RemoveAsync(e,t){return Jn(this,void 0,void 0,(function*(){let n=new Zn(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return Yn.ServiceName}}Yn.ServiceName="RemoteStorageService";class Xn extends re{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ie.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class Qn extends re{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ie.Get,this.ResourceGuid=e,this.Global=t}}class Zn extends re{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ie.Delete,this.ResourceGuid=e,this.Global=t}}class eo extends re{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}var to,no=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class oo{constructor(){this._devices=[],this._onDevicesTasksChangedEvent=new n,this._onDeviceFoundEvent=new n,this._onDeviceRegisteredEvent=new n,this._onDeviceRemovedEvent=new n,this._onDeviceStateChangedEvent=new n,this._connection=null,this._session=null,this._controllerConfiguration=null,this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devicesChannelsStates=[],this._synchronizationTaskCompletionSource=null,this._deviceStatesSynchronizationTaskCompletionSource=null,this._connection=Uh.Get(Vt.ServiceName),this._session=Uh.Get(He.ServiceName),this._controllerConfiguration=Uh.Get(qe.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>no(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),this._synchronizationTaskCompletionSource=new Promise((e=>{var t;null===(t=this._session)||void 0===t||t.OnUserLoggedInEvent().Subscribe((t=>no(this,void 0,void 0,(function*(){var t;try{this._devices=yield this.GetPairedDevicesAsync()}catch(e){null===(t=r.Log)||void 0===t||t.Error(oo.ServiceName,`Failed to get paired devices: ${e}`)}this._synchronized=!0,e()}))))})),this._deviceStatesSynchronizationTaskCompletionSource=new Promise((e=>{var t;null===(t=this._session)||void 0===t||t.OnUserLoggedInEvent().Subscribe((t=>no(this,void 0,void 0,(function*(){var t;try{yield this.WaitForSynchronizationAsync(),yield this.SyncDevicesStatesAsync()}catch(e){null===(t=r.Log)||void 0===t||t.Error(oo.ServiceName,`Failed to sync devices states: ${e}`)}this._synchronizedDevicesStates=!0,e()}))))})),this._connection.OnDataReceivedEvent().Subscribe((e=>{if("/info/devices/tasks"===e.Resource)this.ParseDeviceTaskInfo(e.Data);else if("/devices/blinds/times"===e.Resource);else if("/info/devices/device/found"===e.Resource)this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=r.Log)||void 0===t||t.Debug(oo.ServiceName,`Found device: ${e.Name} guid: ${e.Guid}`),this._onDeviceFoundEvent.Invoke(e)}));else if("/info/devices/device/state/changed"===e.Resource){const t=e.Data,n=this._devices.filter((e=>e.Guid==t.DeviceGuid));if(n.length>0){const e=n[0],o=this.MapApiDeviceStateToDeviceState(e,t);null!=o&&(this._onDeviceStateChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==st.SignalStrength?e.Channels.forEach((n=>{let o=new gn(Object.assign({},t));o.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:o})})):o.TypeAsEnum==st.BatteryState&&e.Channels.forEach((n=>{let o=new sn(Object.assign({},t));o.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:o})})))}}else"/info/devices/device/registered"===e.Resource?this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=r.Log)||void 0===t||t.Debug(oo.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)})):"/info/devices/device/removed"===e.Resource&&this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=r.Log)||void 0===t||t.Debug(oo.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}CanEditDevicesInfo(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=ue.Admin}CanAddAndRemoveAndConfigureDevices(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=ue.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return Uh.Get(Yn.ServiceName).SaveAsync("FastDevicesSync",!1,!0)}DisableFastStatesSyncAsync(){return Uh.Get(Yn.ServiceName).SaveAsync("FastDevicesSync",!1,!1)}IsFastStatesSyncEnabledAsync(){return no(this,void 0,void 0,(function*(){const e=yield Uh.Get(Yn.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof qn?e.Data:e}))}GetDevicesForManualPairingAsync(e){return no(this,void 0,void 0,(function*(){let t=Uh.Get(zn.ServiceName);const n=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$");return Array.isArray(e)||n.test(e)?yield t.GetDevicesForManualPairingAsync(e):yield t.GetDevicesForManualPairingAsync()}))}AddManuallyPairedDevice(e){return no(this,void 0,void 0,(function*(){return yield Uh.Get(zn.ServiceName).AddManuallyPairedDeviceAsync(e)}))}GetDeviceChannelStates(e,t){var n,o;return null!==(o=null===(n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===n?void 0:n.ChannelsStates.filter((e=>e.Channel==t)))&&void 0!==o?o:[]}GetDeviceStates(e){var t,n;return null!==(n=null===(t=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===t?void 0:t.ChannelsStates)&&void 0!==n?n:[]}PutDeviceStateOnList(e,t){let n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid));if(null==n){let o=new ro;o.Channel=t.Data.Channel,o.States=[t],n={DeviceGuid:e.Guid,ChannelsStates:[o]},this._devicesChannelsStates.push(n)}else{let e=n.ChannelsStates.firstOrDefault((e=>e.Channel==t.Data.Channel));null==e?(e=new ro,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e)):(null!=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum))&&(e.States=e.States.where((e=>e.TypeAsEnum!=t.TypeAsEnum)).toArray()),e.States.push(t))}}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}WaitForDevicesStatesSynchronizationAsync(){return this._deviceStatesSynchronizationTaskCompletionSource}GetCurrentlyRunningTaksAsync(){var e;return no(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ho,15e3,!1);(null==t?void 0:t.Status)==se.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),o=new zt;o.DeviceGuid=n[0],o.Channel=Number(n[1]),o.Status=tt.ExecutingTasks,t.push(o)})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new Yt(t);case"DoorBell":return new Xt(t);case"ReedPosition":return new Qt(t);case"BlindPosition":return new Zt(t);case"ButtonState":return new en(t);case"LightColor":return new tn(t);case"LightTemperature":return new nn(t);case"LightBrightness":return new on(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new rn(t);case"BatteryState":return new sn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new an(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"Energy":return new cn(t);case"DistanceSensor":return new ln(t);case"MovementSensor":return new un(t);case"BlindsControlButton":return new dn(t);case"FacadeControlButton":return new hn(t);case"SignalStrength":return new gn(t);case"GatePosition":return new fn(t);case"GatewayPosition":return new pn(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new vn(t);case"HumiditySensor":case"HumidityState":return new yn(t);case"VibrationSensor":return new wn(t);case"DigitalInputSensor":return new mn(t);case"ConfigurationState":return new Sn(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new _n(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new Cn(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new An(t);case"FacadePosition":case"FacadeState":return new Dn(t);case"FacadeTypeState":return new bn(t);case"CurrentWindThreshold":return new Gn(t);case"CurrentLightThreshold":return new En(t);case"WindSpeed":return new In(t);case"FloodSensor":return new Tn(t);case"PressureState":return new Nn(t);case"ITamperProtection":case"TamperProtection":return new Pn(t);case"ILightRGBW":case"LightRGBW":return new kn(t);default:null===(n=r.Log)||void 0===n||n.Debug(oo.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return oo.ServiceName}SyncDevicesStatesAsync(){var e,t;return no(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new io,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync())return(null==n?void 0:n.Status)==se.OK;{let e=new ao;e.Data=!0;const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(e,35e3,!1);return(null==n?void 0:n.Status)==se.OK}}))}OnDevicesTasksExecutionChangeEvent(){return this._onDevicesTasksChangedEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}OnDeviceRegisteredEvent(){return this._onDeviceRegisteredEvent}OnDeviceRemovedEvent(){return this._onDeviceRemovedEvent}OnDeviceFoundEvent(){return this._onDeviceFoundEvent}MapApiDevices(e){const t=[];return null==e?[]:(e.forEach((e=>{var n,o,s,i,a=new Rn;a.Guid=e.Guid,a.Name=e.DeviceName,a.ChannelsAmount=e.ChannelsNumber,a.DeviceType=e.DeviceType,a.CommunicationWay=e.CommunicationWay,a.DeviceState=e.DeviceState,a.IsEnabled=e.IsEnabled,a.IsVirtual=e.IsVirtual,a.SerialNumber=e.DeviceSerialNumber,a.ManufacturerGuid=e.ManufacturerGuid,a.ModelGuid=e.DeviceModelGuid,a.Model=e.DeviceModel,a.Name=e.DeviceName,a.ProtocolGuid=e.ProtocolGuid;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new jt;if(a.CommunicationWay==at.OneWay)"IBlindPosition"===e&&(t.InterfaceType="IBlindPositionSimple");else switch(e){case"IGatePosition":t.InterfaceType="IGatePulse";break;case"IGatewayPosition":t.InterfaceType="IGatewayPulse";break;default:t.InterfaceType=e}a.AvailableTaskTypes.push(t)})),null===(o=e.AvailableResponses)||void 0===o||o.forEach((e=>{var t=new Kt;t.InterfaceType=e,a.AvailableResponseTypes.push(t)})),null===(s=e.ChannelsConfiguration)||void 0===s||s.forEach((e=>{var t,n,o;try{var s=new Bn;s.Number=e.Channel,a.Channels.push(s),s.SetDevice(a),s.Name=e.ChannelName,s.ChannelGroups=e.GroupsGuids,s.IconName=e.IconName,s.IsHidden=e.Hidden,s.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(s.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(s.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{var t=new Kt;t.InterfaceType=e,s.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new jt;t.InterfaceType=e,s.AvailableTaskTypes.push(t)}))}catch(e){null===(o=r.Log)||void 0===o||o.Error(e)}}))}catch(e){null===(i=r.Log)||void 0===i||i.Error(e)}t.push(a)})),t)}GetPairedDevicesAsync(e=!1){var t,n,o;return no(this,void 0,void 0,(function*(){if(this._synchronized&&!(yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync()))return Promise.resolve(this._devices);const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new so,15e3,!0);return null==s||void 0===s?[]:s.Status==se.OK&&null!=s.Data?e?this.MapApiDevices(s.Data):this.MapApiDevices(s.Data.filter((e=>e.DeviceType!=ct.Scene))):(null===(o=r.Log)||void 0===o||o.Error(oo.ServiceName,`Failed to get devices. ${s.Status} ${s.Data}`),[])}))}GetDevicesAsync(e=!1){return no(this,void 0,void 0,(function*(){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){var e,t;return no(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new uo,15e3,!1);return null==n?[]:n.Status==se.OK&&null!=n.Data?this.MapApiDevices(n.Data):(null===(t=r.Log)||void 0===t||t.Error(oo.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){var e;return no(this,void 0,void 0,(function*(){yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new co,35e3,!1)}))}StopSearchingForDevices(){var e;return no(this,void 0,void 0,(function*(){yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new lo,2e4,!1)}))}RegisterDeviceAsync(e){var t;return no(this,void 0,void 0,(function*(){const n=new go;n.Data=e.Guid;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,2e4,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==se.OK?(this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),ut.Executed):ut.Failed}))}RemoveDeviceAsync(e,t=!1){var n;return no(this,void 0,void 0,(function*(){var o=new fo;t&&(o=new po),o.Data=e.Guid;const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,35e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==r?void 0:r.Status)==se.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),ut.Executed):ut.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new wo;const o=t;switch(o.FeatureType){case Un.SetTemperature:n.Data=o.Temperature;break;case Un.SetLightBrightness:n.Data=o.Brightness;break;case Un.SetLightColor:n=new mo;const e=o;n.R=e.R,n.G=e.G,n.B=e.B;break;case Un.SetLightTemperature:n.Data=o.Temperature;break;case Un.SetBlindPosition:switch(o.Action){case Fn.Open:n.Data=101;break;case Fn.Close:n.Data=102;break;case Fn.Stop:n.Data=103;break;case Fn.Percentage:n.Data=o.Position}break;case Un.SetLightBrightnessDynamicly:n.Data=o.Brightness;break;case Un.SetBlindOpenCloseTime:n.Data=o.Data;break;case Un.SetBlindMicroventilation:n.Data=o.Position;break;case Un.SetFacadePositionAndTilt:n=new So;const t=o;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case Un.LightRGBW:n.Data=o.Data}return n.Channel=o.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=o.FeatureType,n}ExecuteDeviceTaskAsync(e,t){var n,o,s,i,a,c,l,u;return no(this,void 0,void 0,(function*(){try{null===(n=r.Log)||void 0===n||n.Debug(oo.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let u=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new vo(u);null===(o=r.Log)||void 0===o||o.Debug(oo.ServiceName,`Sending device task for execution, device: ${u.DeviceGuid} task: ${u.ControlFeature} channel: ${u.Channel} request: ${JSON.stringify(e)}`);const t=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(e,15e3,!1);switch(null==t?void 0:t.Status){case se.OK:return ut.Executed;case se.FatalError:return null===(i=r.Log)||void 0===i||i.Error(oo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),ut.Failed;case se.WrongData:if("DeviceNotFound"===t.Data)return ut.DeviceNotFound;break;case se.Error:return"DeviceResponseTimeout"===t.Data?ut.DeviceResponseTimeout:(null===(a=r.Log)||void 0===a||a.Error(oo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),ut.Failed)}}catch(e){return e.message.includes("timeout")?(null===(c=r.Log)||void 0===c||c.Error(oo.ServiceName,`Failed to get controller response in time.\n${e}`),ut.ControllerResponseTimeout):(null===(l=r.Log)||void 0===l||l.Error(oo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),ut.Failed)}return ut.Unknown}catch(e){return null===(u=r.Log)||void 0===u||u.Error(oo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),ut.Failed}}))}ExecuteDevicesTasksAsync(e){var t,n,o,s;return no(this,void 0,void 0,(function*(){let i=[],a=[],c=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=c,c++,a.push(e)}const l=new yo(a);try{const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(l,12e4,!1);let s=-1;null===(n=null==o?void 0:o.Data)||void 0===n||n.forEach((t=>{var n,a;s++;let c=ut.Unknown;switch(t.Status){case se.OK:return ut.Executed;case se.FatalError:null===(n=r.Log)||void 0===n||n.Error(oo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),c=ut.Failed;break;case se.WrongData:"DeviceNotFound"===t.Data&&(c=ut.DeviceNotFound);break;case se.Error:"DeviceResponseTimeout"===t.Data?c=ut.DeviceResponseTimeout:(null===(a=r.Log)||void 0===a||a.Error(oo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${o.Data}`),c=ut.Failed)}let l=0,u=new qt;for(const[t,n]of e){if(l==s){u.Device=t,u.Task=n,u.Channel=n.Channel,i.push(u);break}l++}}))}catch(t){if(t.message.includes("timeout")){null===(o=r.Log)||void 0===o||o.Error(oo.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new qt;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=ut.ControllerResponseTimeout}}else{null===(s=r.Log)||void 0===s||s.Error(oo.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new qt;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=ut.Failed}}}return i}))}}oo.ServiceName="DevicesService";class ro{constructor(){this.Channel=0,this.States=[]}}class so extends re{constructor(){super(),this.Resource="/devices/list",this.Method=ie.Get}}class io extends re{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ie.Get}}class ao extends re{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ie.Get}}class co extends re{constructor(){super(),this.Resource="/devices/search",this.Method=ie.Post}}class lo extends re{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ie.Post}}class uo extends re{constructor(){super(),this.Resource="/devices/found/list",this.Method=ie.Get}}class ho extends re{constructor(){super(),this.Resource="/devices/tasks",this.Method=ie.Get}}class go extends re{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ie.Put}}class fo extends re{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ie.Put}}class po extends re{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ie.Put}}class vo extends re{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ie.Post,this.Data=e}}class yo extends re{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ie.Post,this.Data=e}}class wo{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Un.GetState,this.SequnceExecutionOrder=0}}class mo extends wo{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class So extends wo{constructor(){super(...arguments),this.FacadeAction=$n.Stop,this.Tilt=0,this.Position=0}}class _o{constructor(){this.Longitude=0,this.Latitude=0}}class Co{constructor(){this.Longitude=0,this.Latitude=0,this.IsNetworkBased=!1}}!function(e){e[e.OK=0]="OK",e[e.NoPermissions=1]="NoPermissions",e[e.UserIsNotLoggedIn=2]="UserIsNotLoggedIn",e[e.UnknownError=3]="UnknownError"}(to||(to={}));var Ao=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Do{IsControllerGeolocationSetAsync(){return Ao(this,void 0,void 0,(function*(){let e=new bo,t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===se.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return Ao(this,void 0,void 0,(function*(){return new Promise(((e,t)=>Ao(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){var t,n;return Ao(this,void 0,void 0,(function*(){let o=new Eo;o.Data.Latitude=e.Latitude,o.Data.Longitude=e.Longitude,null===(t=r.Log)||void 0===t||t.Warning(Do.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(o)}`);let s=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(o,15e3,!1);switch(null===(n=r.Log)||void 0===n||n.Warning(Do.ServiceName,`${JSON.stringify(s)}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null==s?void 0:s.Status){case se.OK:return new Ce(to.OK,"");case se.NoPermissionToPerformThisOperation:case se.NoPermissionsToCallGivenResource:return new Ce(to.NoPermissions,"");case se.UserIsNotLoggedIn:return new Ce(to.UserIsNotLoggedIn,"");default:return new Ce(to.UnknownError,"")}}))}GetControlllerGeolocationAsync(){var e,t;return Ao(this,void 0,void 0,(function*(){let n=new Go;null===(e=r.Log)||void 0===e||e.Warning(Do.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let o=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=r.Log)||void 0===t||t.Warning(Do.ServiceName,`${JSON.stringify(o)}`),(null==o?void 0:o.Status)===se.OK){let e=new Co;return e.IsNetworkBased=(null==o?void 0:o.Data).IsNetworkBased,e.Latitude=(null==o?void 0:o.Data).Latitude,e.Longitude=(null==o?void 0:o.Data).Longitude,e}return null==o?void 0:o.Status}))}GetServiceName(){return Do.ServiceName}}Do.ServiceName="GeolocationService";class bo extends re{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ie.Get}}class Go extends re{constructor(){super(),this.Resource="/geolocation/get",this.Method=ie.Get}}class Eo extends re{constructor(){super(),this.Data=new _o,this.Resource="/geolocation/save",this.Method=ie.Put}}class Io extends RangeError{constructor(e){super(`${e} was out of range. Must be non-negative and less than the size of the collection.`),this.paramName=e,this.name="ArgumentOutOfRangeException",this.stack=this.stack||(new Error).stack}}const To=Object.freeze({MoreThanOneElement:"Sequence contains more than one element",MoreThanOneMatchingElement:"Sequence contains more than one matching element",NoElements:"Sequence contains no elements",NoMatch:"Sequence contains no matching element"});class No extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Po=(e,t)=>e===t;class ko extends Array{}class Ro{constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Oo{constructor(e){this.dataFunc=e}[Symbol.asyncIterator](){const{dataFunc:e}=this;return async function*(){if(1===e.type)for(const t of e.generator())yield t;else for(const t of await e.generator())yield t}()}}class xo{constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}const Uo=e=>{var t;const n=ko.prototype,o=e.prototype,r=Object.getOwnPropertyNames(n);for(const e of r)o[e]=null!==(t=o[e])&&void 0!==t?t:n[e]},Fo=(e,t,n,o)=>{if(o){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Lo(e,t,n,o)}return n?$o(e,t,n):Mo(e,t)},Mo=(e,t)=>{let n;for(const o of e)n=n?t(n,o):o;if(void 0===n)throw new No(To.NoElements);return n},$o=(e,t,n)=>{let o=t;for(const t of e)o=n(o,t);return o},Lo=(e,t,n,o)=>{let r=t;for(const t of e)r=n(r,t);return o(r)},Wo=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},Bo=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Ho=(e,t)=>t?jo(e,t):Vo(e),Vo=e=>{for(const t of e)return!0;return!1},jo=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Ko=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},zo=e=>{if(Array.isArray(e)){if(0===e.length)throw new No(To.NoElements);return new Ro((async function*(){for await(const t of e)yield t}))}return new Ro(e)},qo=e=>zo((async function*(){for(const t of e)yield t})),Jo=(e,t)=>new Oo({generator:t,type:e}),Yo=e=>Jo(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Xo=(e,t)=>{let n=0,o=0;if(t)for(const r of e)n+=t(r),o+=1;else for(const t of e)n+=t,o+=1;if(0===o)throw new No(To.NoElements);return n/o},Qo=async(e,t)=>{let n=0,o=0;for(const r of e)n+=await t(r),o+=1;if(0===o)throw new No(To.NoElements);return n/o},Zo=(e,t)=>{if(t<1)throw new Io("index");return new xo((function*(){let n=[];for(const o of e)n.push(o),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},er=(e,t)=>new xo((function*(){yield*e,yield*t})),tr=(e,t,n=Po)=>{for(const o of e)if(n(t,o))return!0;return!1},nr=async(e,t,n)=>{for(const o of e)if(await n(t,o))return!0;return!1},or=(e,t)=>t?sr(e,t):rr(e),rr=e=>{let t=0;for(const n of e)t++;return t},sr=(e,t)=>{let n=0;for(const o of e)!0===t(o)&&n++;return n},ir=async(e,t)=>{let n=0;for(const o of e)!0===await t(o)&&n++;return n},ar=(e,t)=>new xo((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),cr=(e,t=Po)=>new xo((function*(){const n=[];for(const o of e)n.find((e=>t(e,o)))||(n.push(o),yield o)})),lr=(e,t)=>zo((async function*(){const n=[];e:for(const o of e){for(const e of n)if(await t(e,o))continue e;n.push(o),yield o}})),ur=(e,t)=>new xo((function*(){for(const n of e)t(n),yield n})),dr=(e,t)=>zo((async function*(){for(const n of e)await t(n),yield n})),hr=(e,t)=>{if(t<0)throw new Io("index");let n=0;for(const o of e)if(t===n++)return o;throw new Io("index")},gr=(e,t)=>{let n=0;for(const o of e)if(t===n++)return o;return null},fr=(e,t,n=Po)=>new xo((function*(){const o=[...t];for(const t of e){let e=!1;for(let r=0;r<o.length;r++)if(!0===n(t,o[r])){e=!0;break}!1===e&&(yield t)}})),pr=(e,t,n)=>zo((async function*(){const o=[...t];for(const t of e){let e=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),vr=(e,t)=>t?wr(e,t):yr(e),yr=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new No(To.NoElements);return t.value},wr=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new No(To.NoMatch)},mr=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new No(To.NoMatch)},Sr=(e,t)=>t?Cr(e,t):_r(e),_r=e=>e[Symbol.iterator]().next().value||null,Cr=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},Ar=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class Dr extends ko{constructor(e,t){super(1),this.key=e,this[0]=t}}const br=(e,t,n)=>{let o;return o=n?((e,t,n)=>function*(){const o=new Array;for(const r of e){const e=t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})(e,t,n):((e,t)=>function*(){const n={};for(const o of e){const e=t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})(e,t),new xo(o)},Gr=(e,t,n)=>n?Ir(e,t,n):Er(e,t),Er=(e,t)=>zo((async function*(){const n={};for(const o of e){const e=await t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})),Ir=(e,t,n)=>zo((async function*(){const o=new Array;for(const r of e){const e=await t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(!0===await n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})),Tr=(e,t,n,o)=>o?((e,t,n,o)=>new xo((function*(){const r=new Array;for(const s of e){const e=t(s);let i=!1;for(let t=0;t<r.length;t++){const a=r[t];if(o(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);r.push(new Dr(e,t))}}for(const e of r)yield e})))(e,t,n,o):((e,t,n)=>new xo((function*(){const o={};for(const r of e){const e=t(r),s=o[e],i=n(r);s?s.push(i):o[e]=new Dr(e,i)}for(const e in o)yield o[e]})))(e,t,n),Nr=(e,t,n,o,r,s)=>{const i=s?Pr(e,t,n,o,r,s):kr(e,t,n,o,r);return new xo(i)},Pr=(e,t,n,o,r,s)=>function*(){var i;const a=[];for(const e of t){const t=o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},kr=(e,t,n,o,r)=>function*(){var s;const i=new Map;for(const e of t){const t=o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},Rr=(e,t,n,o,r,s)=>{const i=s?Or(e,t,n,o,r,s):xr(e,t,n,o,r);return zo(i)},Or=(e,t,n,o,r,s)=>async function*(){var i;const a=[];for(const e of t){const t=await o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=await n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},xr=(e,t,n,o,r)=>async function*(){var s;const i=new Map;for(const e of t){const t=await o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=await n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},Ur=(e,t,n=Po)=>new xo((function*(){const o=[...e.distinct(n)];if(0===o.length)return;const r=[...t];for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++)if(!0===n(t,r[e])){yield t;break}}})),Fr=(e,t,n)=>zo((async function*(){const o=[];for await(const t of e.distinctAsync(n))o.push(t);if(0===o.length)return;const r=[...t];for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===await n(t,o)){yield t;break}}}})),Mr=(e,t,n,o,r,s=Po)=>new xo((function*(){const i=[...t];for(const t of e){const e=n(t);for(const n of i){const i=o(n);!0===s(e,i)&&(yield r(t,n))}}})),$r=(e,t)=>t?Wr(e,t):Lr(e),Lr=e=>{let t;for(const n of e)t=n;if(!t)throw new No(To.NoElements);return t},Wr=(e,t)=>{let n;for(const o of e)!0===t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Br=async(e,t)=>{let n;for(const o of e)!0===await t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Hr=(e,t)=>t?jr(e,t):Vr(e),Vr=e=>{let t=null;for(const n of e)t=n;return t},jr=(e,t)=>{let n=null;for(const o of e)!0===t(o)&&(n=o);return n},Kr=async(e,t)=>{let n=null;for(const o of e)!0===await t(o)&&(n=o);return n},zr=(e,t)=>t?Jr(e,t):qr(e),qr=e=>{let t=null;for(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Jr=(e,t)=>{let n=null;for(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},Yr=async(e,t)=>{let n=null;for(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},Xr=(e,t)=>t?Zr(e,t):Qr(e),Qr=e=>{let t=null;for(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Zr=(e,t)=>{let n=null;for(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},es=async(e,t)=>{let n=null;for(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},ts=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new xo((function*(){for(const t of e)n(t)&&(yield t)}))};async function*ns(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}function*os(e,t,n,o){const r=((e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}class rs extends Ro{constructor(e){super((async function*(){for await(const t of e())yield*t})),this.orderedPairs=e}static generateAsync(e,t,n,o){let r;return r=e instanceof rs?async function*(){for await(const r of e.orderedPairs())yield*ns(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new rs(r)}static generate(e,t,n,o){let r;return r=e instanceof rs?async function*(){for await(const r of e.orderedPairs())yield*os(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new rs(r)}thenBy(e,t){return rs.generate(this,e,!0,t)}thenByAsync(e,t){return rs.generateAsync(this,e,!0,t)}thenByDescending(e,t){return rs.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return rs.generateAsync(this,e,!1,t)}}function*ss(e,t,n,o){const r=((e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}async function*is(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}class as extends xo{constructor(e){super((function*(){for(const t of e())yield*t})),this.orderedPairs=e}static generate(e,t,n,o){let r;return r=e instanceof as?function*(){for(const r of e.orderedPairs())yield*ss(r,t,n,o)}:()=>ss(e,t,n,o),new as(r)}static generateAsync(e,t,n,o){let r;return r=e instanceof as?async function*(){for(const r of e.orderedPairs())yield*is(r,t,n,o)}:()=>is(e,t,n,o),new rs(r)}thenBy(e,t){return as.generate(this,e,!0,t)}thenByAsync(e,t){return as.generateAsync(this,e,!0,t)}thenByDescending(e,t){return as.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return as.generateAsync(this,e,!1,t)}}const cs=(e,t,n)=>as.generate(e,t,!0,n),ls=(e,t,n)=>as.generateAsync(e,t,!0,n),us=(e,t,n)=>as.generate(e,t,!1,n),ds=(e,t,n)=>as.generateAsync(e,t,!1,n),hs=(e,t)=>{const n=[],o=[];for(const r of e)!0===t(r)?o.push(r):n.push(r);return[o,n]},gs=async(e,t)=>{const n=[],o=[];for(const r of e)!0===await t(r)?o.push(r):n.push(r);return[o,n]},fs=e=>new xo((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),ps=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?vs(e,t):ys(e,t)}return ws(e,t)},vs=(e,t)=>new xo((function*(){for(const n of e)yield t(n)})),ys=(e,t)=>new xo((function*(){let n=0;for(const o of e)yield t(o,n),n++})),ws=(e,t)=>new xo((function*(){for(const n of e)yield n[t]})),ms=(e,t)=>"function"==typeof t?1===t.length?Ss(e,t):_s(e,t):Cs(e,t),Ss=(e,t)=>zo((async function*(){for(const n of e)yield t(n)})),_s=(e,t)=>zo((async function*(){let n=0;for(const o of e)yield t(o,n),n++})),Cs=(e,t)=>zo((async function*(){for(const n of e)yield n[t]})),As=(e,t)=>"function"==typeof t?1===t.length?Ds(e,t):bs(e,t):Gs(e,t),Ds=(e,t)=>new xo((function*(){for(const n of e)for(const e of t(n))yield e})),bs=(e,t)=>new xo((function*(){let n=0;for(const o of e){for(const e of t(o,n))yield e;n++}})),Gs=(e,t)=>new xo((function*(){for(const n of e)for(const e of n[t])yield e})),Es=(e,t)=>1===t.length?Is(e,t):Ts(e,t),Is=(e,t)=>zo((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Ts=(e,t)=>zo((async function*(){let n=0;for(const o of e){const e=await t(o,n);for(const t of e)yield t;n++}})),Ns=(e,t,n=Po)=>{const o=e[Symbol.iterator](),r=t[Symbol.iterator]();let s=o.next(),i=r.next();for(;!s.done&&!i.done;){if(!n(s.value,i.value))return!1;s=o.next(),i=r.next()}return!0===s.done&&!0===i.done},Ps=async(e,t,n)=>{const o=e[Symbol.iterator](),r=t[Symbol.iterator]();let s=o.next(),i=r.next();for(;!s.done&&!i.done;){if(!1===await n(s.value,i.value))return!1;s=o.next(),i=r.next()}return!0===s.done&&!0===i.done},ks=(e,t)=>t?Os(e,t):Rs(e),Rs=e=>{let t=!1,n=null;for(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}if(!1===t)throw new No(To.NoElements);return n},Os=(e,t)=>{let n=!1,o=null;for(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},xs=async(e,t)=>{let n=!1,o=null;for(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},Us=(e,t)=>t?Ms(e,t):Fs(e),Fs=e=>{let t=!1,n=null;for(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}return n},Ms=(e,t)=>{let n=!1,o=null;for(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}return o},$s=async(e,t)=>{let n=!1,o=null;for(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneElement);n=!0,o=r}return o},Ls=(e,t)=>new xo((function*(){let n=0;for(const o of e)n++>=t&&(yield o)})),Ws=(e,t)=>1===t.length?Bs(e,t):Hs(e,t),Bs=(e,t)=>new xo((function*(){let n=!0;for(const o of e)!1===n?yield o:!1===t(o)&&(n=!1,yield o)})),Hs=(e,t)=>new xo((function*(){let n=0,o=!0;for(const r of e)!1===o?yield r:!1===t(r,n)&&(o=!1,yield r),n++})),Vs=(e,t)=>1===t.length?js(e,t):Ks(e,t),js=(e,t)=>zo((async function*(){let n=!0;for(const o of e)!1===n?yield o:!1===await t(o)&&(n=!1,yield o)})),Ks=(e,t)=>zo((async function*(){let n=0,o=!0;for(const r of e)!1===o?yield r:!1===await t(r,n)&&(o=!1,yield r),n++})),zs=(e,t)=>t?Js(e,t):qs(e),qs=e=>{let t=0;for(const n of e)t+=n;return t},Js=(e,t)=>{let n=0;for(const o of e)n+=t(o);return n},Ys=async(e,t)=>{let n=0;for(const o of e)n+=await t(o);return n},Xs=(e,t)=>new xo((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),Qs=(e,t)=>1===t.length?Zs(e,t):ei(e,t),Zs=(e,t)=>new xo((function*(){for(const n of e){if(!t(n))break;yield n}})),ei=(e,t)=>new xo((function*(){let n=0;for(const o of e){if(!t(o,n++))break;yield o}})),ti=(e,t)=>1===t.length?ni(e,t):oi(e,t),ni=(e,t)=>zo((async function*(){for(const n of e){if(!await t(n))break;yield n}})),oi=(e,t)=>zo((async function*(){let n=0;for(const o of e){if(!await t(o,n++))break;yield o}})),ri=e=>[...e],si=(e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},ii=async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},ai=(e,t)=>{const n={};for(const o of e)n[t(o)]=o;return n},ci=async(e,t)=>{const n={};for(const o of e)n[await t(o)]=o;return n},li=e=>new Set(e),ui=(e,t,n)=>n?hi(e,t,n):di(e,t),di=(e,t)=>new xo((function*(){const n=new Set;for(const t of e)!1===n.has(t)&&(yield t,n.add(t));for(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),hi=(e,t,n)=>new xo((function*(){const o=[];for(const r of[e,t])for(const e of r){let t=!1;for(const r of o)if(!0===n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),gi=(e,t,n)=>zo((async function*(){const o=[];for(const r of[e,t])for(const e of r){let t=!1;for(const r of o)if(!0===await n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),fi=(e,t)=>1===t.length?pi(e,t):vi(e,t),pi=(e,t)=>new xo((function*(){for(const n of e)!0===t(n)&&(yield n)})),vi=(e,t)=>new xo((function*(){let n=0;for(const o of e)!0===t(o,n++)&&(yield o)})),yi=(e,t)=>1===t.length?wi(e,t):mi(e,t),wi=(e,t)=>zo((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),mi=(e,t)=>zo((async function*(){let n=0;for(const o of e)!0===await t(o,n++)&&(yield o)})),Si=(e,t,n)=>n?Ci(e,t,n):_i(e,t),_i=(e,t)=>new xo((function*(){const n=e[Symbol.iterator](),o=t[Symbol.iterator]();for(;;){const e=n.next(),t=o.next();if(e.done||t.done)break;yield[e.value,t.value]}})),Ci=(e,t,n)=>new xo((function*(){const o=e[Symbol.iterator](),r=t[Symbol.iterator]();for(;;){const e=o.next(),t=r.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Ai=(e,t,n)=>zo((async function*(){const o=e[Symbol.iterator](),r=t[Symbol.iterator]();for(;;){const e=o.next(),t=r.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Di=e=>{const t=e.prototype,n=(e,n)=>{const o=function(...t){return e(this,...t)};Object.defineProperty(o,"length",{value:e.length-1}),t[n]=o};n(Fo,"aggregate"),n(Wo,"all"),n(Bo,"allAsync"),n(Ho,"any"),n(Ko,"anyAsync"),n(qo,"asAsync"),n(Yo,"asParallel"),n(Xo,"average"),n(Qo,"averageAsync"),n(Zo,"chunk"),n(er,"concatenate"),n(tr,"contains"),n(nr,"containsAsync"),n(or,"count"),n(ir,"countAsync"),n(ar,"defaultIfEmpty"),n(cr,"distinct"),n(lr,"distinctAsync"),n(ur,"each"),n(dr,"eachAsync"),n(hr,"elementAt"),n(gr,"elementAtOrDefault"),n(fr,"except"),n(pr,"exceptAsync"),n(vr,"first"),n(mr,"firstAsync"),n(Sr,"firstOrDefault"),n(Ar,"firstOrDefaultAsync"),n(br,"groupBy"),n(Gr,"groupByAsync"),n(Tr,"groupByWithSel"),n(Nr,"groupJoin"),n(Rr,"groupJoinAsync"),n(Ur,"intersect"),n(Fr,"intersectAsync"),n(Mr,"joinByKey"),n($r,"last"),n(Br,"lastAsync"),n(Hr,"lastOrDefault"),n(Kr,"lastOrDefaultAsync"),n(zr,"max"),n(Yr,"maxAsync"),n(Xr,"min"),n(es,"minAsync"),n(ts,"ofType"),n(cs,"orderBy"),n(ls,"orderByAsync"),n(us,"orderByDescending"),n(ds,"orderByDescendingAsync"),n(fs,"reverse"),n(ps,"select"),n(ms,"selectAsync"),n(As,"selectMany"),n(Es,"selectManyAsync"),n(Ns,"sequenceEquals"),n(Ps,"sequenceEqualsAsync"),n(ks,"single"),n(xs,"singleAsync"),n(Us,"singleOrDefault"),n($s,"singleOrDefaultAsync"),n(Ls,"skip"),n(Ws,"skipWhile"),n(Vs,"skipWhileAsync"),n(zs,"sum"),n(Ys,"sumAsync"),n(Xs,"take"),n(Qs,"takeWhile"),n(ti,"takeWhileAsync"),n(ri,"toArray"),n(si,"toMap"),n(ii,"toMapAsync"),n(ai,"toObject"),n(ci,"toObjectAsync"),n(hs,"partition"),n(gs,"partitionAsync"),n(li,"toSet"),n(ui,"union"),n(gi,"unionAsync"),n(fi,"where"),n(yi,"whereAsync"),n(Si,"zip"),n(Ai,"zipAsync")},bi=(e,t,n,o)=>{if(o){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Ii(e,t,n,o)}return n?Ei(e,t,n):Gi(e,t)},Gi=async(e,t)=>{let n;for await(const o of e)n=n?t(n,o):o;if(void 0===n)throw new No(To.NoElements);return n},Ei=async(e,t,n)=>{let o=t;for await(const t of e)o=n(o,t);return o},Ii=async(e,t,n,o)=>{let r=t;for await(const t of e)r=n(r,t);return o(r)},Ti=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Ni=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},Pi=(e,t)=>t?Ri(e,t):ki(e),ki=async e=>{for await(const t of e)return!0;return!1},Ri=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Oi=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},xi=e=>Jo(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),Ui=async(e,t)=>{let n=0,o=0;if(t)for await(const r of e)n+=t(r),o+=1;else for await(const t of e)n+=t,o+=1;if(0===o)throw new No(To.NoElements);return n/o},Fi=async(e,t)=>{let n=0,o=0;for await(const r of e)n+=await t(r),o+=1;if(0===o)throw new No(To.NoElements);return n/o},Mi=(e,t)=>{if(t<1)throw new Io("index");return new Ro((async function*(){let n=[];for await(const o of e)n.push(o),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},$i=(e,t)=>new Ro((async function*(){yield*e,yield*t})),Li=async(e,t,n=Po)=>{for await(const o of e)if(n(t,o))return!0;return!1},Wi=async(e,t,n)=>{for await(const o of e)if(await n(t,o))return!0;return!1},Bi=(e,t)=>t?Vi(e,t):Hi(e),Hi=async e=>{let t=0;for await(const n of e)t++;return t},Vi=async(e,t)=>{let n=0;for await(const o of e)!0===t(o)&&n++;return n},ji=async(e,t)=>{let n=0;for await(const o of e)!0===await t(o)&&n++;return n},Ki=(e,t)=>new Ro((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),zi=(e,t=Po)=>new Ro((async function*(){const n=[];for await(const o of e)n.find((e=>t(e,o)))||(n.push(o),yield o)})),qi=(e,t)=>new Ro((async function*(){const n=[];e:for await(const o of e){for(const e of n)if(await t(e,o))continue e;n.push(o),yield o}})),Ji=(e,t)=>new Ro((async function*(){for await(const n of e)t(n),yield n})),Yi=(e,t)=>new Ro((async function*(){for await(const n of e)await t(n),yield n})),Xi=async(e,t)=>{if(t<0)throw new Io("index");let n=0;for await(const o of e)if(t===n++)return o;throw new Io("index")},Qi=async(e,t)=>{let n=0;for await(const o of e)if(t===n++)return o;return null},Zi=(e,t,n=Po)=>new Ro((async function*(){const o=[];for await(const e of t)o.push(e);for await(const t of e){let e=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===n(t,s)){e=!0;break}}!1===e&&(yield t)}})),ea=(e,t,n)=>new Ro((async function*(){const o=[];for await(const e of t)o.push(e);for await(const t of e){let e=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),ta=(e,t)=>t?oa(e,t):na(e),na=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new No(To.NoElements);return t.value},oa=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new No(To.NoMatch)},ra=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new No(To.NoMatch)},sa=(e,t)=>t?aa(e,t):ia(e),ia=async e=>(await e[Symbol.asyncIterator]().next()).value||null,aa=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},ca=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},la=(e,t,n)=>n?ua(e,t,n):da(e,t),ua=(e,t,n)=>new Ro((async function*(){const o=new Array;for await(const r of e){const e=t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})),da=(e,t)=>new Ro((async function*(){const n={};for await(const o of e){const e=t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})),ha=(e,t,n)=>n?fa(e,t,n):ga(e,t),ga=(e,t)=>new Ro((async function*(){const n={};for await(const o of e){const e=await t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}for(const e in n)yield n[e]})),fa=(e,t,n)=>new Ro((async function*(){const o=new Array;for await(const r of e){const e=await t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(!0===await n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}for(const e of o)yield e})),pa=(e,t,n,o)=>o?ya(e,t,n,o):va(e,t,n),va=(e,t,n)=>new Ro((async function*(){const o={};for await(const r of e){const e=t(r),s=o[e],i=n(r);s?s.push(i):o[e]=new Dr(e,i)}for(const e in o)yield o[e]})),ya=(e,t,n,o)=>new Ro((async function*(){const r=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<r.length;t++){const a=r[t];if(o(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);r.push(new Dr(e,t))}}for(const e of r)yield e})),wa=(e,t,n,o,r,s)=>{const i=s?ma(e,t,n,o,r,s):Sa(e,t,n,o,r);return new Ro(i)},ma=(e,t,n,o,r,s)=>async function*(){var i;const a=[];for await(const e of t){const t=o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},Sa=(e,t,n,o,r)=>async function*(){var s;const i=new Map;for await(const e of t){const t=o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},_a=(e,t,n,o,r,s)=>{const i=s?Ca(e,t,n,o,r,s):Aa(e,t,n,o,r);return new Ro(i)},Ca=(e,t,n,o,r,s)=>async function*(){var i;const a=[];for await(const e of t){const t=await o(e),n=a.find((e=>s(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=await n(t),o=null!==(i=a.find((t=>s(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield r(t,o.values)}},Aa=(e,t,n,o,r)=>async function*(){var s;const i=new Map;for await(const e of t){const t=await o(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=await n(t),o=null!==(s=i.get(e))&&void 0!==s?s:[];yield r(t,o)}},Da=(e,t,n=Po)=>new Ro((async function*(){const o=await e.distinct(n).toArray();if(0===o.length)return;const r=await t.toArray();for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===n(t,o)){yield t;break}}}})),ba=(e,t,n)=>new Ro((async function*(){const o=await e.distinctAsync(n).toArray();if(0===o.length)return;const r=await t.toArray();for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===await n(t,o)){yield t;break}}}})),Ga=(e,t,n,o,r,s=Po)=>new Ro((async function*(){const i=[];for await(const e of t)i.push(e);for await(const t of e){const e=n(t);for(const n of i){const i=o(n);!0===s(e,i)&&(yield r(t,n))}}})),Ea=(e,t)=>t?Ta(e,t):Ia(e),Ia=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new No(To.NoElements);return t},Ta=async(e,t)=>{let n=null;for await(const o of e)!0===t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Na=async(e,t)=>{let n=null;for await(const o of e)!0===await t(o)&&(n=o);if(!n)throw new No(To.NoMatch);return n},Pa=(e,t)=>t?Ra(e,t):ka(e),ka=async e=>{let t=null;for await(const n of e)t=n;return t},Ra=async(e,t)=>{let n=null;for await(const o of e)!0===t(o)&&(n=o);return n},Oa=async(e,t)=>{let n=null;for await(const o of e)!0===await t(o)&&(n=o);return n},xa=(e,t)=>t?Fa(e,t):Ua(e),Ua=async e=>{let t=null;for await(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Fa=async(e,t)=>{let n=null;for await(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},Ma=async(e,t)=>{let n=null;for await(const o of e)n=Math.max(n||Number.NEGATIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},$a=(e,t)=>t?Wa(e,t):La(e),La=async e=>{let t=null;for await(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new No(To.NoElements);return t},Wa=async(e,t)=>{let n=null;for await(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,t(o));if(null===n)throw new No(To.NoElements);return n},Ba=async(e,t)=>{let n=null;for await(const o of e)n=Math.min(n||Number.POSITIVE_INFINITY,await t(o));if(null===n)throw new No(To.NoElements);return n},Ha=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Ro((async function*(){for await(const t of e)n(t)&&(yield t)}))},Va=(e,t,n)=>rs.generate(e,t,!0,n),ja=(e,t,n)=>rs.generateAsync(e,t,!0,n),Ka=(e,t,n)=>rs.generate(e,t,!1,n),za=(e,t,n)=>rs.generateAsync(e,t,!1,n),qa=async(e,t)=>{const n=[],o=[];for await(const r of e)!0===t(r)?o.push(r):n.push(r);return[o,n]},Ja=async(e,t)=>{const n=[],o=[];for await(const r of e)!0===await t(r)?o.push(r):n.push(r);return[o,n]},Ya=e=>new Ro((async function*(){const t=[];for await(const n of e)t.push(n);for(let e=t.length-1;e>=0;e--)yield t[e]})),Xa=(e,t)=>"function"==typeof t?1===t.length?Qa(e,t):Za(e,t):ec(e,t),Qa=(e,t)=>new Ro((async function*(){for await(const n of e)yield t(n)})),Za=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)yield t(o,n),n++})),ec=(e,t)=>new Ro((async function*(){for await(const n of e)yield n[t]})),tc=(e,t)=>"string"==typeof t?oc(e,t):nc(e,t),nc=(e,t)=>new Ro((async function*(){for await(const n of e)yield t(n)})),oc=(e,t)=>new Ro((async function*(){for await(const n of e)yield n[t]})),rc=(e,t)=>"function"==typeof t?1===t.length?sc(e,t):ic(e,t):ac(e,t),sc=(e,t)=>new Ro((async function*(){for await(const n of e)for(const e of t(n))yield e})),ic=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e){for(const e of t(o,n))yield e;n++}})),ac=(e,t)=>new Ro((async function*(){for await(const n of e)for(const e of n[t])yield e})),cc=(e,t)=>1===t.length?new Ro((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Ro((async function*(){let n=0;for await(const o of e){const e=await t(o,n);for(const t of e)yield t;n++}})),lc=async(e,t,n=Po)=>{const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();let s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1];for(;!i.done&&!a.done;){if(!n(i.value,a.value))return!1;s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},uc=async(e,t,n)=>{const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();let s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1];for(;!i.done&&!a.done;){if(!1===await n(i.value,a.value))return!1;s=await Promise.all([o.next(),r.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},dc=(e,t)=>t?gc(e,t):hc(e),hc=async e=>{let t=!1,n=null;for await(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}if(!1===t)throw new No(To.NoElements);return n},gc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},fc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}if(!1===n)throw new No(To.NoMatch);return o},pc=(e,t)=>t?yc(e,t):vc(e),vc=async e=>{let t=!1,n=null;for await(const o of e){if(!0===t)throw new No(To.MoreThanOneElement);t=!0,n=o}return n},yc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}return o},wc=async(e,t)=>{let n=!1,o=null;for await(const r of e)if(await t(r)){if(!0===n)throw new No(To.MoreThanOneMatchingElement);n=!0,o=r}return o},mc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)n++>=t&&(yield o)})),Sc=(e,t)=>1===t.length?_c(e,t):Cc(e,t),_c=(e,t)=>new Ro((async function*(){let n=!0;for await(const o of e)!1===n?yield o:!1===t(o)&&(n=!1,yield o)})),Cc=(e,t)=>new Ro((async function*(){let n=0,o=!0;for await(const r of e)!1===o?yield r:!1===t(r,n)&&(o=!1,yield r),n++})),Ac=(e,t)=>1===t.length?Dc(e,t):bc(e,t),Dc=(e,t)=>new Ro((async function*(){let n=!0;for await(const o of e)!1===n?yield o:!1===await t(o)&&(n=!1,yield o)})),bc=(e,t)=>new Ro((async function*(){let n=0,o=!0;for await(const r of e)!1===o?yield r:!1===await t(r,n)&&(o=!1,yield r),n++})),Gc=(e,t)=>t?Ic(e,t):Ec(e),Ec=async e=>{let t=0;for await(const n of e)t+=n;return t},Ic=async(e,t)=>{let n=0;for await(const o of e)n+=t(o);return n},Tc=async(e,t)=>{let n=0;for await(const o of e)n+=await t(o);return n},Nc=(e,t)=>new Ro((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Pc=(e,t)=>1===t.length?kc(e,t):Rc(e,t),kc=(e,t)=>new Ro((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Rc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e){if(!t(o,n++))break;yield o}})),Oc=(e,t)=>1===t.length?xc(e,t):Uc(e,t),xc=(e,t)=>new Ro((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Uc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e){if(!await t(o,n++))break;yield o}})),Fc=async e=>{const t=[];for await(const n of e)t.push(n);return t},Mc=async(e,t)=>{const n=new Map;for await(const o of e){const e=t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},$c=async(e,t)=>{const n=new Map;for await(const o of e){const e=await t(o),r=n.get(e);void 0===r?n.set(e,[o]):r.push(o)}return n},Lc=async(e,t)=>{const n={};for await(const o of e)n[t(o)]=o;return n},Wc=async(e,t)=>{const n={};for await(const o of e)n[await t(o)]=o;return n},Bc=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Hc=(e,t,n)=>n?jc(e,t,n):Vc(e,t),Vc=(e,t)=>new Ro((async function*(){const n=new Set;for await(const t of e)!1===n.has(t)&&(yield t,n.add(t));for await(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),jc=(e,t,n)=>new Ro((async function*(){const o=[];for(const r of[e,t])for await(const e of r){let t=!1;for(const r of o)if(!0===n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),Kc=(e,t,n)=>new Ro((async function*(){const o=[];for(const r of[e,t])for await(const e of r){let t=!1;for(const r of o)if(!0===await n(e,r)){t=!0;break}!1===t&&(yield e,o.push(e))}})),zc=(e,t)=>1===t.length?qc(e,t):Jc(e,t),qc=(e,t)=>new Ro((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Jc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)!0===t(o,n++)&&(yield o)})),Yc=(e,t)=>1===t.length?Xc(e,t):Qc(e,t),Xc=(e,t)=>new Ro((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),Qc=(e,t)=>new Ro((async function*(){let n=0;for await(const o of e)!0===await t(o,n++)&&(yield o)})),Zc=(e,t,n)=>n?tl(e,t,n):el(e,t),el=(e,t)=>new Ro((async function*(){const n=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([n.next(),o.next()]);if(e.done||t.done)break;yield[e.value,t.value]}})),tl=(e,t,n)=>new Ro((async function*(){const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([o.next(),r.next()]);if(e.done||t.done)break;yield n(e.value,t.value)}})),nl=(e,t,n)=>new Ro((async function*(){const o=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();for(;;){const e=await Promise.all([o.next(),r.next()]),t=e[0],s=e[1];if(t.done||s.done)break;yield n(t.value,s.value)}})),ol=(e,t,n,o)=>{if(o){if(!n)throw new ReferenceError("TAccumulate function is undefined");return il(e,t,n,o)}return n?sl(e,t,n):rl(e,t)},rl=async(e,t)=>{let n;for await(const o of e)n=n?t(n,o):o;if(void 0===n)throw new No(To.NoElements);return n},sl=async(e,t,n)=>{let o=t;for await(const t of e)o=n(o,t);return o},il=async(e,t,n,o)=>{let r=t;for await(const t of e)r=n(r,t);return o(r)},al=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:()=>n.generator().then((e=>{const n=new Array(e.length);for(let o=0;o<e.length;o++)n[o]=t(e[o]);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then(t);return o},type:1};case 2:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then(t);return o},type:2}}},cl=(e,t)=>{const n=al(e,(e=>{if(!t(e))throw new Error(String(!1));return!0}));switch(n.type){case 0:return n.generator().then((()=>!0),(()=>!1));case 1:return Promise.all(n.generator()).then((()=>!0),(()=>!1));case 2:return n.generator().then(Promise.all.bind(Promise)).then((()=>!0),(()=>!1))}},ll=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=t(e[n]);return o},type:2};case 1:return{generator:()=>n.generator().map((async e=>{const n=await e;return await t(n)})),type:1};case 2:return{generator:async()=>(await n.generator()).map((e=>e.then(t))),type:2}}},ul=(e,t)=>{const n=ll(e,(async e=>{if(!1===await t(e))throw new Error(String(!1));return!0}));switch(n.type){case 1:return Promise.all(n.generator()).then((()=>!0),(()=>!1));case 2:return n.generator().then(Promise.all.bind(Promise)).then((()=>!0),(()=>!1))}},dl=(e,t)=>t?gl(e,t):hl(e),hl=async e=>{const t=e.dataFunc;let n;switch(t.type){case 1:return n=t.generator(),0!==n.length;case 0:case 2:return n=await t.generator(),0!==n.length}},gl=async(e,t)=>{const n=al(e,t);let o;switch(n.type){case 0:return o=await n.generator(),o.includes(!0);case 1:return o=await Promise.all(n.generator()),o.includes(!0);case 2:return o=await Promise.all(await n.generator()),o.includes(!0)}},fl=async(e,t)=>{const n=ll(e,t);let o;switch(n.type){case 1:return o=n.generator(),0!==o.length&&new Promise(((e,t)=>{let n=0;for(const r of o)r.then((t=>{n++,t?e(!0):n===o.length&&e(!1)}),t)}));case 2:return o=await n.generator(),0===Promise.length?!1:(await Promise.all(o)).includes(!0)}},pl=e=>zo((async function*(){for await(const t of e)yield t})),vl=async e=>{switch(e.type){case 0:return await e.generator();case 1:return await Promise.all(e.generator());case 2:const t=await e.generator();return await Promise.all(t)}},yl=async(e,t)=>{let n;n=t?al(e,t):e.dataFunc;const o=await vl(n);if(0===o.length)throw new No(To.NoElements);let r=0;for(const e of o)r+=e;return r/o.length},wl=async(e,t)=>{const n=ll(e,t),o=await vl(n);if(0===o.length)throw new No(To.NoElements);let r=0;for(const e of o)r+=e;return r/o.length},ml=(e,t)=>{if(t<1)throw new Io("index");let n;switch(e.dataFunc.type){case 1:const o=e.dataFunc.generator;n={type:1,generator:()=>{const e=[];let n=[];for(const r of o())n.push(r),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 2:const r=e.dataFunc.generator;n={type:2,generator:async()=>{const e=[];let n=[];for(const o of await r())n.push(o),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 0:const s=e.dataFunc.generator;n={type:0,generator:async()=>{const e=[];let n=[];for(const o of await s())n.push(o),n.length===t&&(e.push(n),n=[]);return n.length&&e.push(n),e}}}return new Oo(n)},Sl=(e,t)=>new Oo({generator:async()=>{const[n,o]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...o]},type:0}),_l=async(e,t,n=Po)=>{let o;switch(o=al(e,n?e=>n(t,e):e=>e===t),o.type){case 0:return(await o.generator()).some((e=>e));case 1:return(await Promise.all(o.generator())).some((e=>e));case 2:return(await Promise.all(await o.generator())).some((e=>e))}},Cl=async(e,t,n)=>{const o=ll(e,(e=>n(t,e)));switch(o.type){case 1:return(await Promise.all(o.generator())).some((e=>e));case 2:return(await Promise.all(await o.generator())).some((e=>e))}},Al=(e,t)=>t?bl(e,t):Dl(e),Dl=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},bl=async(e,t)=>{const n=await e.toArray();let o=0;for(let e=0;e<n.length;e++)!0===t(n[e])&&o++;return o},Gl=async(e,t)=>{const n=ll(e,t);let o;switch(n.type){case 1:o=Promise.all(n.generator());break;case 2:o=Promise.all(await n.generator())}let r=0;for(const e of await o)e&&r++;return r},El=(e,t)=>{const n=e.dataFunc,o=t instanceof Promise;let r;switch(n.type){case 0:r={generator:()=>n.generator().then((e=>e.length?e:o?t.then((e=>[e])):[t])),type:n.type};break;case 1:r={generator:()=>{const e=n.generator();return e.length?e:o?[t]:[Promise.resolve(t)]},type:n.type};break;case 2:r={generator:async()=>{const e=await n.generator();return e.length?e:o?[t]:[Promise.resolve(t)]},type:n.type}}return new Oo(r)},Il=(e,t=Po)=>new Oo({generator:async()=>{const n=[];for(const o of await e.toArray())n.find((e=>t(e,o)))||n.push(o);return n},type:0}),Tl=(e,t)=>new Oo({generator:async()=>{const n=[];e:for(const o of await e.toArray()){for(const e of n)if(await t(e,o))continue e;n.push(o)}return n},type:0}),Nl=(e,t)=>new Oo(al(e,(e=>(t(e),e)))),Pl=(e,t)=>{const n=ll(e,(async e=>(await t(e),e)));return new Oo(n)},kl=async(e,t)=>{if(t<0)throw new Io("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new Io("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new Io("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new Io("index");return await e[t]}}},Rl=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();return t>=e.length?null:e[t]}case 1:{const e=n.generator();return t>=e.length?null:await e[t]}case 2:{const e=await n.generator();return t>=e.length?null:await e[t]}}},Ol=(e,t,n=Po)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of o){let t=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),xl=(e,t,n)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of o){let t=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===await n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),Ul=e=>vl(e.dataFunc),Fl=(e,t)=>t?$l(e,t):Ml(e),Ml=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new No(To.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return await e[0]}}},$l=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===t(e))return e;throw new No(To.NoMatch)},Ll=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===await t(e))return e;throw new No(To.NoMatch)},Wl=(e,t)=>t?Hl(e,t):Bl(e),Bl=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();return 0===e.length?null:e[0]}case 1:{const e=t.generator();return 0===e.length?null:await e[0]}case 2:{const e=await t.generator();return 0===e.length?null:await e[0]}}},Hl=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===t(e))return e;return null},Vl=async(e,t)=>{const n=await Ul(e);for(const e of n)if(!0===await t(e))return e;return null},jl=(e,t,n)=>n?zl(e,t,n):Kl(e,t),Kl=(e,t)=>new Oo({generator:async()=>{const n={};for(const o of await e.toArray()){const e=t(o),r=n[e];r?r.push(o):n[e]=new Dr(e,o)}const o=new Array;for(const e in n)o.push(n[e]);return o},type:0}),zl=(e,t,n)=>new Oo({generator:async()=>{const o=new Array;for(const r of await e.toArray()){const e=t(r);let s=!1;for(let t=0;t<o.length;t++){const i=o[t];if(n(i.key,e)){i.push(r),s=!0;break}}!1===s&&o.push(new Dr(e,r))}const r=new Array;for(const e of o)r.push(e);return r},type:0}),ql=(e,t,n)=>n?Jl(e,t,n):Yl(e,t),Jl=(e,t,n)=>new Oo({generator:async()=>{const o=ll(e,(async e=>[await t(e),e]));let r;switch(o.type){case 1:r=await Promise.all(o.generator());break;case 2:r=await Promise.all(await o.generator())}const s=new Array;for(const[e,t]of r){let o=!1;for(let r=0;r<s.length;r++){const i=s[r];if(!0===await n(i.key,e)){i.push(t),o=!0;break}}!1===o&&s.push(new Dr(e,t))}const i=new Array;for(const e of s)i.push(e);return i},type:0}),Yl=(e,t)=>new Oo({generator:async()=>{const n=ll(e,(async e=>[await t(e),e]));let o;switch(n.type){case 1:o=await Promise.all(n.generator());break;case 2:o=await Promise.all(await n.generator())}const r={};for(const[e,t]of o){const n=r[e];n?n.push(t):r[e]=new Dr(e,t)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),Xl=(e,t,n,o)=>o?Ql(e,t,n,o):Zl(e,t,n),Ql=(e,t,n,o)=>new Oo({generator:async()=>{const r=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<r.length;t++){const a=r[t];if(o(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);r.push(new Dr(e,t))}}const s=new Array;for(const e of r)s.push(e);return s},type:0}),Zl=(e,t,n)=>new Oo({generator:async()=>{const o={};for(const r of await e.toArray()){const e=t(r),s=o[e],i=n(r);s?s.push(i):o[e]=new Dr(e,i)}const r=new Array;for(const e in o)r.push(o[e]);return r},type:0}),eu=(e,t,n,o,r,s)=>{const i=s?tu(e,t,n,o,r,s):nu(e,t,n,o,r);return new Oo({generator:i,type:0})},tu=(e,t,n,o,r,s)=>async()=>{const i=[];for await(const e of t){const t=o(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}return(await e.toArray()).map((e=>{var t;const o=n(e),a=null!==(t=i.find((e=>s(e.key,o))))&&void 0!==t?t:{key:o,values:[]};return r(e,a.values)}))},nu=(e,t,n,o,r)=>async()=>{const s=new Map;for await(const e of t){const t=o(e),n=s.get(t);n?n.push(e):s.set(t,[e])}return(await e.toArray()).map((e=>{var t;const o=n(e),i=null!==(t=s.get(o))&&void 0!==t?t:[];return r(e,i)}))},ou=(e,t,n,o,r,s)=>{const i=s?ru(e,t,n,o,r,s):su(e,t,n,o,r);return new Oo({generator:i,type:0})},ru=(e,t,n,o,r,s)=>async()=>{const i=[];for await(const e of t){const t=await o(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}const a=(await e.toArray()).map((async e=>{var t;const o=await n(e),a=null!==(t=i.find((e=>s(e.key,o))))&&void 0!==t?t:{key:o,values:[]};return r(e,a.values)}));return await Promise.all(a)},su=(e,t,n,o,r)=>async()=>{const s=new Map;for await(const e of t){const t=await o(e),n=s.get(t);n?n.push(e):s.set(t,[e])}const i=(await e.toArray()).map((async e=>{var t;const o=await n(e),i=null!==(t=s.get(o))&&void 0!==t?t:[];return r(e,i)}));return await Promise.all(i)},iu=(e,t,n=Po)=>new Oo({generator:async()=>{const o=await e.distinct(n).toArray();if(0===o.length)return[];const r=await t.toArray(),s=new Array;for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===n(t,o)){s.push(t);break}}}return s},type:0}),au=(e,t,n)=>new Oo({generator:async()=>{const o=await e.distinctAsync(n).toArray();if(0===o.length)return[];const r=await t.toArray(),s=new Array;for(let e=0;e<o.length;e++){const t=o[e];for(let e=0;e<r.length;e++){const o=r[e];if(!0===await n(t,o)){s.push(t);break}}}return s},type:0}),cu=(e,t,n,o,r,s=Po)=>new Oo({generator:async()=>{const[i,a]=await Promise.all([t.toArray(),e.toArray()]),c=new Array;for(const e of a){const t=n(e);for(const n of i){const i=o(n);!0===s(t,i)&&c.push(r(e,n))}}return c},type:0}),lu=(e,t)=>t?du(e,t):uu(e),uu=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new No(To.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new No(To.NoElements);return await e[e.length-1]}}},du=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}}throw new No(To.NoMatch)},hu=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(!0===await t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}}throw new No(To.NoMatch)},gu=(e,t)=>t?pu(e,t):fu(e),fu=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();return 0===e.length?null:e[e.length-1]}case 1:{const e=t.generator();return 0===e.length?null:await e[e.length-1]}case 2:{const e=await t.generator();return 0===e.length?null:await e[e.length-1]}}},pu=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(t(o))return o}break}}return null},vu=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=e[n];if(!0===await t(o))return o}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const o=await e[n];if(!0===await t(o))return o}break}}return null},yu=async(e,t)=>{let n;n=t?al(e,t):e.dataFunc;const o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.max.apply(null,o)},wu=async(e,t)=>{const n=ll(e,t),o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.max.apply(null,o)},mu=async(e,t)=>{let n;n=t?al(e,t):e.dataFunc;const o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.min.apply(null,o)},Su=async(e,t)=>{const n=ll(e,t),o=await vl(n);if(0===o.length)throw new No(To.NoElements);return Math.min.apply(null,o)},_u=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Oo({generator:async()=>{const t=al(e,n),o=await vl(t),r=[];for(const[e,t]of o)e&&r.push(t);return r},type:0})};async function*Cu(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}async function*Au(e,t,n,o){const r=((e,t)=>{const n=new Map;for(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}class Du extends Oo{constructor(e){super({generator:async()=>{const t=e(),n=[];for await(const e of t)n.push(...e);return n},type:0}),this.orderedPairs=e}static generateAsync(e,t,n,o){let r;return r=e instanceof Du?async function*(){for await(const r of e.orderedPairs())yield*Cu(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=await t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new Du(r)}static generate(e,t,n,o){let r;return r=e instanceof Du?async function*(){for await(const r of e.orderedPairs())yield*Au(r,t,n,o)}:()=>async function*(e,t,n,o){const r=await(async(e,t)=>{const n=new Map;for await(const o of e){const e=t(o),r=n.get(e);r?r.push(o):n.set(e,[o])}return n})(e,t),s=[...r.keys()].sort(o||void 0);if(n)for(let e=0;e<s.length;e++)yield r.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield r.get(s[e])}(e,t,n,o),new Du(r)}thenBy(e,t){return Du.generate(this,e,!0,t)}thenByAsync(e,t){return Du.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Du.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Du.generateAsync(this,e,!1,t)}}const bu=(e,t,n)=>Du.generate(e,t,!0,n),Gu=(e,t,n)=>Du.generateAsync(e,t,!0,n),Eu=(e,t,n)=>Du.generate(e,t,!1,n),Iu=(e,t,n)=>Du.generateAsync(e,t,!1,n),Tu=async(e,t)=>{const n=al(e,(e=>[t(e),e])),o=await vl(n),r=[],s=[];for(const[e,t]of o)e?s.push(t):r.push(t);return[s,r]},Nu=async(e,t)=>{const n=ll(e,(async e=>[await t(e),e])),o=await vl(n),r=[],s=[];for(const[e,t]of o)e?s.push(t):r.push(t);return[s,r]},Pu=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Oo({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Oo({generator:async()=>(await t.generator()).reverse(),type:t.type})}},ku=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:()=>n.generator().then((e=>{const n=new Array(e.length);for(let o=0;o<e.length;o++)n[o]=t(e[o],o);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then((e=>t(e,n)));return o},type:1};case 2:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=e[n].then((e=>t(e,n)));return o},type:2}}},Ru=(e,t)=>"function"==typeof t?1===t.length?new Oo(al(e,t)):new Oo(ku(e,t)):new Oo(al(e,(e=>e[t]))),Ou=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),o=new Array(e.length);for(let n=0;n<e.length;n++)o[n]=t(e[n],n);return o},type:2};case 1:return{generator:()=>n.generator().map(((e,n)=>e.then((e=>t(e,n))))),type:1};case 2:return{generator:async()=>(await n.generator()).map(((e,n)=>e.then((e=>t(e,n))))),type:2}}},xu=(e,t)=>{let n;return n="function"==typeof t?1===t.length?ll(e,t):Ou(e,t):ll(e,(e=>e[t])),new Oo(n)},Uu=(e,t)=>new Oo({generator:async()=>{let n;n="function"==typeof t?1===t.length?al(e,t):ku(e,t):al(e,(e=>e[t]));const o=[];switch(n.type){case 0:for(const e of await n.generator())for(const t of e)o.push(t);break;case 1:for(const e of n.generator())for(const t of await e)o.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)o.push(t)}return o},type:0}),Fu=(e,t)=>new Oo({generator:async()=>{let n;n=1===t.length?ll(e,t):Ou(e,t);const o=[];switch(n.type){case 1:for(const e of n.generator())for(const t of await e)o.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)o.push(t)}return o},type:0}),Mu=async(e,t,n=Po)=>{const o=await e.toArray(),r=await t.toArray();if(o.length!==r.length)return!1;for(let e=0;e<o.length;e++)if(!1===n(o[e],r[e]))return!1;return!0},$u=async(e,t,n)=>{const o=await e.toArray(),r=await t.toArray();if(o.length!==r.length)return!1;for(let e=0;e<o.length;e++){const t=o[e],s=r[e];if(!1===await n(t,s))return!1}return!0},Lu=(e,t)=>t?Bu(e,t):Wu(e),Wu=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);if(0===e.length)throw new No(To.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);if(0===e.length)throw new No(To.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);if(0===e.length)throw new No(To.NoElements);return await e[0]}}},Bu=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(t(e)){if(!0===o)throw new No(To.MoreThanOneMatchingElement);o=!0,r=e}if(!1===o)throw new No(To.NoMatch);return r},Hu=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(!0===await t(e)){if(!0===o)throw new No(To.MoreThanOneMatchingElement);o=!0,r=e}if(!1===o)throw new No(To.NoMatch);return r},Vu=(e,t)=>t?Ku(e,t):ju(e),ju=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new No(To.MoreThanOneElement);return 0===e.length?null:await e[0]}}},Ku=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(t(e)){if(!0===o)throw new No(To.MoreThanOneElement);o=!0,r=e}return r},zu=async(e,t)=>{const n=await Ul(e);let o=!1,r=null;for(const e of n)if(!0===await t(e)){if(!0===o)throw new No(To.MoreThanOneElement);o=!0,r=e}return r},qu=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Oo({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Oo({generator:()=>n.generator().slice(t),type:1});case 2:return new Oo({generator:async()=>(await n.generator()).slice(t),type:2})}},Ju=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray();let o=0;for(;o<n.length;o++){const e=n[o];if(!1===t(e,o))break}const r=[];for(;o<n.length;o++)r.push(n[o]);return r},type:0}),Yu=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray();let o=0;for(;o<n.length;o++){const e=n[o];if(!1===await t(e,o))break}const r=[];for(;o<n.length;o++)r.push(n[o]);return r},type:0}),Xu=(e,t)=>t?Zu(e,t):Qu(e),Qu=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},Zu=async(e,t)=>{let n=0;for(const o of await e.toArray())n+=t(o);return n},ed=async(e,t)=>{const n=ll(e,t),o=await vl(n);let r=0;for(const e of o)r+=e;return r},td=(e,t)=>{const n=t>0?t:0,o=e.dataFunc;switch(o.type){case 1:return new Oo({generator:()=>o.generator().splice(0,n),type:1});case 2:return new Oo({generator:()=>o.generator().then((e=>e.splice(0,n))),type:2});default:return new Oo({generator:()=>o.generator().then((e=>e.splice(0,n))),type:0})}},nd=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray(),o=new Array;if(1===t.length)for(const e of n){if(!0!==t(e))break;o.push(e)}else for(let e=0;e<n.length;e++){const r=n[e];if(!0!==t(r,e))break;o.push(r)}return o},type:0}),od=(e,t)=>new Oo({generator:async()=>{const n=await e.toArray(),o=new Array;if(1===t.length){const e=t;for(const t of n){if(!0!==await e(t))break;o.push(t)}}else for(let e=0;e<n.length;e++){const r=n[e];if(!0!==await t(r,e))break;o.push(r)}return o},type:0}),rd=async(e,t)=>{const n=new Map,o=al(e,(e=>[t(e),e])),r=await vl(o);for(const[e,t]of r){const o=n.get(e);void 0===o?n.set(e,[t]):o.push(t)}return n},sd=async(e,t)=>{const n=new Map,o=ll(e,(async e=>[await t(e),e])),r=await vl(o);for(const[e,t]of r){const o=n.get(e);void 0===o?n.set(e,[t]):o.push(t)}return n},id=async(e,t)=>{const n=e.dataFunc,o=await vl(n),r={};for(const e of o)r[t(e)]=e;return r},ad=async(e,t)=>{const n=ll(e,(async e=>[await t(e),e])),o=await vl(n),r={};for(const[e,t]of o)r[e]=t;return r},cd=async e=>{const t=e.dataFunc,n=await vl(t);return new Set(n)},ld=(e,t,n)=>n?dd(e,t,n):ud(e,t),ud=(e,t)=>new Oo({generator:async()=>{const n=new Set,o=t.toArray();for await(const t of e)!1===n.has(t)&&n.add(t);const r=await o;for(const e of r)!1===n.has(e)&&n.add(e);return[...n.keys()]},type:0}),dd=(e,t,n)=>new Oo({generator:async()=>{const o=[],r=await Promise.all([e.toArray(),t.toArray()]);for(const e of r)for(const t of e){let e=!1;for(const r of o)if(!0===n(t,r)){e=!0;break}!1===e&&o.push(t)}return o},type:0}),hd=(e,t,n)=>new Oo({generator:async()=>{const o=[],r=await Promise.all([e.toArray(),t.toArray()]);for(const e of r)for(const t of e){let e=!1;for(const r of o)if(!0===await n(t,r)){e=!0;break}!1===e&&o.push(t)}return o},type:0}),gd=(e,t)=>new Oo({generator:async()=>(await e.toArray()).filter(t),type:0}),fd=(e,t)=>new Oo({generator:async()=>{const n=Ou(e,(async(e,n)=>[await t(e,n),e])),o=await vl(n),r=[];for(const[e,t]of o)e&&r.push(t);return r},type:0}),pd=(e,t,n)=>n?yd(e,t,n):vd(e,t),vd=(e,t)=>new Oo({generator:async()=>{const[n,o]=await Promise.all([e.toArray(),t.toArray()]),r=n.length<o.length?n.length:o.length,s=new Array(r);for(let e=0;e<r;e++){const t=n[e],r=o[e];s[e]=[t,r]}return s},type:0}),yd=(e,t,n)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=o.length<r.length?o.length:r.length,i=new Array(s);for(let e=0;e<s;e++){const t=o[e],s=r[e];i[e]=n(t,s)}return i},type:0}),wd=(e,t,n)=>new Oo({generator:async()=>{const[o,r]=await Promise.all([e.toArray(),t.toArray()]),s=o.length<r.length?o.length:r.length,i=new Array(s);for(let e=0;e<s;e++){const t=o[e],s=r[e];i[e]=n(t,s)}return Promise.all(i)},type:0});Di(xo),(e=>{const t=e.prototype,n=(e,n)=>{const o=function(...t){return e(this,...t)};Object.defineProperty(o,"length",{value:e.length-1}),t[n]=o};n(bi,"aggregate"),n(Ti,"all"),n(Ni,"allAsync"),n(Pi,"any"),n(Oi,"anyAsync"),n(xi,"asParallel"),n(Ui,"average"),n(Fi,"averageAsync"),n(Mi,"chunk"),n($i,"concatenate"),n(Li,"contains"),n(Wi,"containsAsync"),n(Bi,"count"),n(ji,"countAsync"),n(Ki,"defaultIfEmpty"),n(zi,"distinct"),n(qi,"distinctAsync"),n(Ji,"each"),n(Yi,"eachAsync"),n(Xi,"elementAt"),n(Qi,"elementAtOrDefault"),n(Zi,"except"),n(ea,"exceptAsync"),n(ta,"first"),n(ra,"firstAsync"),n(sa,"firstOrDefault"),n(ca,"firstOrDefaultAsync"),n(la,"groupBy"),n(ha,"groupByAsync"),n(pa,"groupByWithSel"),n(wa,"groupJoin"),n(_a,"groupJoinAsync"),n(Da,"intersect"),n(ba,"intersectAsync"),n(Ga,"joinByKey"),n(Ea,"last"),n(Na,"lastAsync"),n(Pa,"lastOrDefault"),n(Oa,"lastOrDefaultAsync"),n(xa,"max"),n(Ma,"maxAsync"),n($a,"min"),n(Ba,"minAsync"),n(Ha,"ofType"),n(Va,"orderBy"),n(ja,"orderByAsync"),n(Ka,"orderByDescending"),n(za,"orderByDescendingAsync"),n(qa,"partition"),n(Ja,"partitionAsync"),n(Ya,"reverse"),n(Xa,"select"),n(tc,"selectAsync"),n(rc,"selectMany"),n(cc,"selectManyAsync"),n(lc,"sequenceEquals"),n(uc,"sequenceEqualsAsync"),n(dc,"single"),n(fc,"singleAsync"),n(pc,"singleOrDefault"),n(wc,"singleOrDefaultAsync"),n(mc,"skip"),n(Sc,"skipWhile"),n(Ac,"skipWhileAsync"),n(Gc,"sum"),n(Tc,"sumAsync"),n(Nc,"take"),n(Pc,"takeWhile"),n(Oc,"takeWhileAsync"),n(Fc,"toArray"),n(Mc,"toMap"),n($c,"toMapAsync"),n(Lc,"toObject"),n(Wc,"toObjectAsync"),n(Bc,"toSet"),n(Hc,"union"),n(Kc,"unionAsync"),n(zc,"where"),n(Yc,"whereAsync"),n(Zc,"zip"),n(nl,"zipAsync")})(Ro),(e=>{const t=e.prototype,n=(e,n)=>{const o=function(...t){return e(this,...t)};Object.defineProperty(o,"length",{value:e.length-1}),t[n]=o};n(ol,"aggregate"),n(cl,"all"),n(ul,"allAsync"),n(dl,"any"),n(fl,"anyAsync"),n(pl,"asAsync"),n(yl,"average"),n(wl,"averageAsync"),n(ml,"chunk"),n(Sl,"concatenate"),n(_l,"contains"),n(Cl,"containsAsync"),n(Al,"count"),n(Gl,"countAsync"),n(El,"defaultIfEmpty"),n(Il,"distinct"),n(Tl,"distinctAsync"),n(Nl,"each"),n(Pl,"eachAsync"),n(kl,"elementAt"),n(Rl,"elementAtOrDefault"),n(Ol,"except"),n(xl,"exceptAsync"),n(Fl,"first"),n(Ll,"firstAsync"),n(Wl,"firstOrDefault"),n(Vl,"firstOrDefaultAsync"),n(jl,"groupBy"),n(ql,"groupByAsync"),n(Xl,"groupByWithSel"),n(eu,"groupJoin"),n(ou,"groupJoinAsync"),n(eu,"groupJoin"),n(ou,"groupJoinAsync"),n(iu,"intersect"),n(au,"intersectAsync"),n(cu,"joinByKey"),n(lu,"last"),n(hu,"lastAsync"),n(gu,"lastOrDefault"),n(vu,"lastOrDefaultAsync"),n(yu,"max"),n(wu,"maxAsync"),n(mu,"min"),n(Su,"minAsync"),n(_u,"ofType"),n(bu,"orderBy"),n(Gu,"orderByAsync"),n(Eu,"orderByDescending"),n(Iu,"orderByDescendingAsync"),n(Tu,"partition"),n(Nu,"partitionAsync"),n(Pu,"reverse"),n(Ru,"select"),n(xu,"selectAsync"),n(Uu,"selectMany"),n(Fu,"selectManyAsync"),n(Mu,"sequenceEquals"),n($u,"sequenceEqualsAsync"),n(Lu,"single"),n(Hu,"singleAsync"),n(Vu,"singleOrDefault"),n(zu,"singleOrDefaultAsync"),n(qu,"skip"),n(Ju,"skipWhile"),n(Yu,"skipWhileAsync"),n(Xu,"sum"),n(ed,"sumAsync"),n(td,"take"),n(nd,"takeWhile"),n(od,"takeWhileAsync"),n(Ul,"toArray"),n(rd,"toMap"),n(sd,"toMapAsync"),n(id,"toObject"),n(ad,"toObjectAsync"),n(cd,"toSet"),n(ld,"union"),n(hd,"unionAsync"),n(gd,"where"),n(fd,"whereAsync"),n(pd,"zip"),n(wd,"zipAsync")})(Oo),(()=>{var e;const{prototype:t}=ko,n=Object.getOwnPropertyNames(xo.prototype);for(const o of n)t[o]=null!==(e=t[o])&&void 0!==e?e:xo.prototype[o];t.all=function(e){return this.every(e)},t.any=function(e){return e?this.some(e):0!==this.length},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Io("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new No(To.NoMatch);return t}if(0===this.length)throw new No(To.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new No(To.NoMatch)}if(0===this.length)throw new No(To.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.max=function(e){if(0===this.length)throw new No(To.NoElements);if(e){let t=Number.NEGATIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.max(e(this[n]),t);return t}return Math.max.apply(null,this)},t.min=function(e){if(0===this.length)throw new No(To.NoElements);if(e){let t=Number.POSITIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.min(e(this[n]),t);return t}return Math.min.apply(null,this)},t.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var md;!function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(md||(md={}));class Sd{constructor(){this._guid="",this._name="",this._position=0,this._objectsOrder={},null==Sd._devicesService&&(Sd._devicesService=Uh.Get(oo.ServiceName))}GetDevicesChannelsInGroupAsync(e=!1){return t=this,n=void 0,r=function*(){let t=[];for(let n of yield Uh.Get(oo.ServiceName).GetDevicesAsync(e))for(let e of n.Channels.where((e=>e.ChannelGroups.any((e=>e===this._guid)))))t.push(e);let n=[];if(void 0!==this._objectsOrder&&null!==this._objectsOrder&&Object.entries(this._objectsOrder).length>0){const e=Object.keys(this._objectsOrder).map(Number).sort(((e,t)=>e-t));for(let o of e){const e=t.firstOrDefault((e=>e.ChannelId===this._objectsOrder[o]));null!==e&&n.push(e)}return t.forEach((e=>{n.any((t=>t.ChannelId===e.ChannelId))||n.push(e)})),n}return t},new((o=void 0)||(o=Promise))((function(e,s){function i(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(t){var n;t.done?e(t.value):(n=t.value,n instanceof o?n:new o((function(e){e(n)}))).then(i,a)}c((r=r.apply(t,n||[])).next())}));var t,n,o,r}get Guid(){return this._guid}set Guid(e){this._guid=e}get Name(){return this._name}set Name(e){this._name=e}get OrderPosition(){return this._position}set OrderPosition(e){this._position=e}get ObjectsOrder(){return this._objectsOrder}set ObjectsOrder(e){this._objectsOrder=e}ChangeNameAsync(e){return Uh.Get(Ad.ServiceName).ChangeGroupNameAsync(this,e)}}var _d,Cd=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Ad{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._connection=Uh.Get(Vt.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{Uh.Get(He.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Cd(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}ChangeGroupsOrderAsync(e){var t;return Cd(this,void 0,void 0,(function*(){const n=e.select((e=>e.Guid)).toArray(),o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new bd(n),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==o?void 0:o.Status}))}ChangeObjectsPositionsInGroupAsync(e,t){var n;return Cd(this,void 0,void 0,(function*(){const o=t.select((e=>e.ChannelId)).toArray(),r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Id(e.Guid,o),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==r?void 0:r.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==r?void 0:r.Status}))}IsGroupsAndObjectsOrderingAvailable(){return!this._groups.any((e=>void 0===e.ObjectsOrder||null===e.ObjectsOrder))}MoveGroupPositionAsync(e,t){var n;return Cd(this,void 0,void 0,(function*(){const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Dd(e.Guid,t),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==o?void 0:o.Status}))}MoveObjectInGroupPositionAsync(e,t,n){var o;return Cd(this,void 0,void 0,(function*(){const r=`${t.GetDevice().Guid}_${t.Number}`,s=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Ed(e.Guid,r,n),15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===se.OK?(Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),se.OK):null==s?void 0:s.Status}))}AddDeviceChannelToGroupByGuidAsync(e,t){var n,o;return Cd(this,void 0,void 0,(function*(){const r=new Od;if(r.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");r.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,r.Data.GroupGuid=t;const s=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(r,15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=s&&null!=s.Status?(s.Status==se.OK&&e.ChannelGroups.push(t),yield this.GetGroupsAsync(!1),s.Status):(yield this.GetGroupsAsync(),se.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){var n,o;return Cd(this,void 0,void 0,(function*(){const r=new xd;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");r.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,r.Data.Channel=e.Number,r.Data.GroupGuid=t;const s=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(r,15e3,!1);return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=s&&null!=s.Status?(s.Status==se.OK&&(e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray()),yield this.GetGroupsAsync(),s.Status):(yield this.GetGroupsAsync(),se.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Cd(this,void 0,void 0,(function*(){if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupAsync(e.Name);if(!(t instanceof Sd))return t instanceof Ce?t:new Ce(md.UnknownError,"");e=t}for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`),new Ce(md.UnknownError,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`)}let n=yield Uh.Get(oo.ServiceName).GetDevicesAsync();for(let s of n)for(let n of s.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var r of n.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),new Ce(md.UnknownError,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`)}return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Cd(this,void 0,void 0,(function*(){for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),se.FatalError}let n=yield Uh.Get(oo.ServiceName).GetDevicesAsync();for(let s of n)for(let n of s.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var r of n.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(n,e);if(yield this.GetGroupsAsync(),t!==se.OK)return Uh.Get(o.ServiceName).Error(Ad.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),se.FatalError}return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),se.OK}))}ChangeGroupNameByGuidAsync(e,t){var n,o;return Cd(this,void 0,void 0,(function*(){let r=new Rd,s=new Ud;s.Guid=e,s.Name=t,null===(n=r.Data)||void 0===n||n.push(s);const i=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(r,15e3,!1);if(Uh.Get(Ke.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status)switch(i.Status){case se.OK:return new Ce(md.Success,"");case se.WrongData:switch(i.Data){case"NameToShort":return new Ce(md.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ce(md.NameAlreadyExists,"Group with this name already exists");default:return new Ce(md.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Ce(md.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Ce(md.UnknownError,"")}))}GetServiceName(){return Ad.ServiceName}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}GetGroupByGuid(e){return this._groups.first((t=>t.Guid===e))}ChangeGroupNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}RemoveGroupAsync(e){return this.RemoveGroupByGuidAsync(e.Guid)}RemoveGroupByGuidAsync(e){var t;return Cd(this,void 0,void 0,(function*(){let n=new Pd;n.Data=e;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);Uh.Get(Ke.ServiceName).ClearCache(),yield this.GetGroupsAsync();for(let t of yield Uh.Get(oo.ServiceName).GetDevicesAsync())for(let n of t.Channels)n.ChannelGroups.any((t=>t===e))&&(n.ChannelGroups=n.ChannelGroups.except(e,((e,t)=>e===t)).toArray());return Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=o&&null!=o.Status?null==o?void 0:o.Status:se.Error}))}GetGroupsAsync(e=!1){var t,n;return Cd(this,void 0,void 0,(function*(){const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new kd,15e3,e);let s=[];if((null==r?void 0:r.Status)===se.OK){let e=Uh.Get(o.ServiceName);return null===(n=r.Data)||void 0===n||n.forEach((t=>{let n=new Sd;n.Guid=t.Guid,n.Name=t.Name,n.ObjectsOrder=t.ObjectsOrder,n.OrderPosition=t.OrderPosition,e.Info(Ad.ServiceName,`Got group: ${t.Name} ${t.Guid} order: ${n.OrderPosition} objects order: ${JSON.stringify(n.ObjectsOrder)}`),s.push(n)})),this._groups=s,s}throw new Error(`Failed to get groups, API responded with status ${null==r?void 0:r.Status} data: ${null==r?void 0:r.Data}`)}))}AddDeviceChannelToGroupAsync(e,t){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid)}RemoveDeviceChannelFromGroupAsync(e,t){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid)}AddNewGroupAsync(e){var t,n;return Cd(this,void 0,void 0,(function*(){let o=new Rd,r=new Ud;r.Name=e,null===(t=o.Data)||void 0===t||t.push(r);const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,15e3,!1);if(Uh.Get(Ke.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),Uh.Get(qe.ServiceName).ExitConfigurationModeAsync(),null!=s&&null!=s.Status)switch(s.Status){case se.OK:return this._groups.first((t=>t.Name===e));case se.WrongData:switch(s.Data){case"NameToShort":return new Ce(md.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ce(md.NameAlreadyExists,"Group with this name already exists");default:return new Ce(md.OtherError,`Response error: ${s.Status} data: ${s.Data}`)}default:return new Ce(md.OtherError,`Response error: ${s.Status} data: ${s.Data}`)}return new Ce(md.UnknownError,"")}))}}Ad.ServiceName="ChannelsGroupsService";class Dd extends re{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ie.Post,this.Data=new Gd,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class bd extends re{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ie.Post,this.Data=e}}class Gd{constructor(){this.GroupGuid="",this.NewPosition=0}}class Ed extends re{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ie.Post,this.Data=new Td,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Id extends re{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ie.Post,this.Data=new Nd,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class Td{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Nd{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Pd extends re{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ie.Delete}}class kd extends re{constructor(){super(),this.Resource="/devices/groups/",this.Method=ie.Get}}class Rd extends re{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ie.Put,this.Data=[]}}class Od extends re{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ie.Put,this.Data=new Fd}}class xd extends re{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ie.Delete,this.Data=new Fd}}class Ud{constructor(){this.Id=0,this.Guid="",this.Name="",this.OrderPosition=0,this.ObjectsOrder={}}}class Fd{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Md{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}!function(e){e[e.Suspended=1]="Suspended",e[e.ReturnedFromSuspension=2]="ReturnedFromSuspension",e[e.EnteredLowPowerMode=3]="EnteredLowPowerMode",e[e.ExitedLowPowerMode=4]="ExitedLowPowerMode",e[e.LoggedIn=5]="LoggedIn",e[e.LoggedOut=6]="LoggedOut",e[e.Connected=7]="Connected",e[e.Disconnected=8]="Disconnected",e[e.FailedToConnect=9]="FailedToConnect",e[e.Connecting=10]="Connecting",e[e.Disconnecting=11]="Disconnecting",e[e.Reconnecting=12]="Reconnecting"}(_d||(_d={}));var $d=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Ld{constructor(){this._syncLock=new Md,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=_d.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new Se,this._onSuspendedEvent=new Se,this._onEnterLowPowerModeEvent=new Se,this._onExitLowPowerModeEvent=new Se,this._onBackButtonPressedEvent=new Se,this._onForwardButtonPressedEvent=new Se,this._onAppStateChanged=new n,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>$d(this,void 0,void 0,(function*(){yield this._syncLock.WaitForLockAsync(),this._syncLock.Lock(),this.IsHidden()?this.Suspend():this.ReturnFromSuspension(),this._syncLock.Unlock()})))):(window.addEventListener("onblur",(()=>{this._isInFouces&&(this._isInFouces=!1,this.Suspend())})),window.addEventListener("onfocus",(()=>{this._isInFouces||(this._isInFouces=!0,this.ReturnFromSuspension())}))),window.addEventListener("popstate",(e=>{var t,n,o,s;document.location,e.state&&("forward"==e.state.direction?(null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(o=r.Log)||void 0===o||o.Warning(Ld.ServiceName,"Back button pressed"),null===(s=this._onBackButtonPressedEvent)||void 0===s||s.Invoke()))}))}MonitorAppState(){return $d(this,void 0,void 0,(function*(){this._session=yield Uh.GetAsync("SessionService"),this._connection=yield Uh.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(_d.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(_d.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,o,s,i,a;switch(e){case le.Connected:null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App state changed to: connected"),this._onAppStateChanged.Invoke(_d.Connected);break;case le.Disconnected:null===(n=r.Log)||void 0===n||n.Warning(Ld.ServiceName,"App state changed to: disconnected"),this._onAppStateChanged.Invoke(_d.Disconnected);break;case le.Connecting:null===(o=r.Log)||void 0===o||o.Warning(Ld.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(_d.Connecting);break;case le.Disconnecting:null===(s=r.Log)||void 0===s||s.Warning(Ld.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(_d.Disconnecting);break;case le.Reconnecting:null===(i=r.Log)||void 0===i||i.Warning(Ld.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(_d.Reconnecting);break;case le.Failed:null===(a=r.Log)||void 0===a||a.Warning(Ld.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(_d.FailedToConnect)}}))}))}get CurrentAppState(){return this._currentAppState}OnAppStateChanged(){return this._onAppStateChanged}Suspend(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!1,this._onSuspendedEvent.Invoke(),this._onAppStateChanged.Invoke(_d.Suspended),null===(e=r.Log)||void 0===e||e.Warning(Ld.ServiceName,"App state changed to: suspended"),null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(_d.ReturnedFromSuspension),null===(e=r.Log)||void 0===e||e.Warning(Ld.ServiceName,"App state changed to: returned from suspension"),null===(t=r.Log)||void 0===t||t.Warning(Ld.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(_d.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(_d.ExitedLowPowerMode)}IsWorkingInWebView(){return"file:"===window.location.protocol||null!=navigator.userAgent.match(/Safari/i)&&!navigator.mediaDevices}IsHidden(){return document.hidden}IsActive(){return!this.IsHidden()}IsInBackground(){return this.IsHidden()}ReturnedFromSuspension(){return this._returnedFromSuspension}IsHibernationAllowed(){return this._canHibernate}DisallowHibernation(){this._canHibernate=!1}AllowHibernation(){this._canHibernate=!0}OnReturnedFromSuspension(){return this._onReturnedFromSuspensionEvent}OnSuspended(){return this._onSuspendedEvent}OnEnterLowPowerMode(){return this._onEnterLowPowerModeEvent}OnExitLowPowerMode(){return this._onExitLowPowerModeEvent}OnBackButtonPressed(){return this._onBackButtonPressedEvent}OnForwardButtonPressed(){return this._onForwardButtonPressedEvent}GetServiceName(){return Ld.ServiceName}}Ld.ServiceName="AppStateService";class Wd{constructor(e){if(this.initialCount=e,this._running=0,this._waiting=[],this.Take=()=>{if(this._waiting.length>0&&this._running<this.initialCount){this._running++;const e=this._waiting.shift();null==e||e.Resolve({Release:this.Release})}},this.AcquireAsync=()=>this._running<this.initialCount?(this._running++,Promise.resolve({Release:this.Release})):new Promise(((e,t)=>{this._waiting.push({Resolve:e,Reject:t})})),this.Release=()=>{this._running--,this.Take()},this.Purge=()=>{this._waiting.forEach((e=>{e.Reject(new Error("The semaphore was purged and as a result this task has been cancelled"))})),this._running=0,this._waiting=[]},e<1)throw new Error(`The semaphore was created with a max value of ${e} but the max value cannot be less than 1`)}}var Bd,Hd,Vd=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class jd{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new Wd(1)}GetServiceName(){return jd.ServiceName}GetExtensionsInfoAsync(e,t=!1){return Vd(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(jd.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);var n=yield this._semaphore.AcquireAsync();if(this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync()),n.Release(),0==[...this._extensionInfoCache.values()].length)throw new qd("Cannot get ExtensionsInfo, controler may return empty list of Extensions or other unknown error occurs!");if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new qd("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e,t=!1,n=!1){return Vd(this,void 0,void 0,(function*(){if(Uh.Get(o.ServiceName).Debug(jd.ServiceName,`Getting ProtocolInfo, data loaded from cache: ${!t}`),t&&(yield this.GetProtocolExtensionInfoFromControllerAsync()),0!=[...this._protocolInfoCache.values()].length||n){if(0==[...this._protocolInfoCache.values()].length)throw new qd("Cannot get ProtocolInfo, controler may return empty list of Extensions or other unknown error occurs!")}else yield this.GetProtocolInfoAsync(e,!0,!0);if(null!=e){const t=this._protocolInfoCache.get(e);if(null==t)throw new qd("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return Vd(this,void 0,void 0,(function*(){const e=new Kd,t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new qd("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=se.OK)throw new qd(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new qd("Cannot get ExtensionsInfo from controller, controller response does not contain data!");t.Data.forEach((e=>{this._extensionInfoCache.set(e.ExtensionGuid,e)})),0!=[...this._extensionInfoCache.values()].length&&(this._isExtensionInfoInitialized=!0)}))}GetProtocolExtensionInfoFromControllerAsync(){return Vd(this,void 0,void 0,(function*(){const e=new zd,t=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new qd("Cannot get ProtocolInfo from controller, controller response does not contain data!");if(t.Status!=se.OK)throw new qd(`Cannot get ProtocolInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new qd("Cannot get ProtocolInfo from controller, controller response does not contain data!");t.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}))}))}}jd.ServiceName="StatisticsInfoService";class Kd extends re{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ie.Get}}class zd extends re{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ie.Get}}class qd extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Bd||(Bd={}));class Jd{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=Hd.Unknown,this.ResourceGuid=""}}class Yd{constructor(){this.UpdateDescription=new Map,this.Update=new Jd,this.UpdatedResourceName="",this.CurrentResourceVersion=""}}!function(e){e[e.Unknown=0]="Unknown",e[e.Container=1]="Container",e[e.RadioFirmware=2]="RadioFirmware",e[e.DeviceFirmware=3]="DeviceFirmware",e[e.Configuration=4]="Configuration",e[e.ContainerScript=5]="ContainerScript",e[e.ContainerSoftware=6]="ContainerSoftware",e[e.RuntimeSoftware=7]="RuntimeSoftware",e[e.RuntimeScript=8]="RuntimeScript",e[e.RuntimeFixingScript=9]="RuntimeFixingScript"}(Hd||(Hd={}));class Xd extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var Qd,Zd,eh,th,nh,oh,rh,sh=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class ih{constructor(){this._services=new Map,this._runtimeInfo=new ah,this._hardwareInfo=new lh,this._semaphore=new Wd(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return ih.ServiceName}RegisterUpdatesProvider(e){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const t=this._services.get(e);if(null==t)throw new Xd("Cannot get update provider! Requested update provider has not been registered.");return t}))}GetUpdatesProvidersAsync(e){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let t=[];if(t=[...this._services.values()].filter((t=>t.ProviderType==e)),0==t.length)throw new Xd("Cannot get update providers! Requested update providers has not been registered.");return t}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return sh(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update providers with protocol guid: [${e}] by GetUpdateProvidersByProtocolAsync<T>()`);let r=[];if(r=null!=n?[...this._services.values()].filter((o=>o.ProtocolGuid==e&&o.ProviderType==t&&o.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ProtocolGuid==e&&n.ProviderType==t)),0==r.length)throw new Xd("Cannot get update providers! Requested update providers has not been registered.");return r}throw new Xd("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return sh(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){Uh.Get(o.ServiceName).Debug(ih.ServiceName,`Getting update providers with extension guid: [${e}] by GetUpdateProvidersByExtensionAsync<T>()`);let r=[];if(r=null!=n?[...this._services.values()].filter((o=>o.ExtensionGuid==e&&o.ProviderType==t&&o.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ExtensionGuid==e&&n.ProviderType==t)),0==r.length)throw new Xd("Cannot get update providers! Requested update providers has not been registered.");return r}throw new Xd("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(e=!1){return sh(this,void 0,void 0,(function*(){var t=yield this._semaphore.AcquireAsync();return!this._isRuntimeInfoInitialized||e?(yield this.GetRuntimeControllerInfoAsync(),t.Release(),this._runtimeInfo):(t.Release(),this._runtimeInfo)}))}GetRuntimeControllerInfoAsync(){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,"Getting runtime version info from controller.");const e=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new ch,16e3,!1);if(null==e||null==e.Status)throw new dh('Cannot get runtime info, controller response result is empty."');if(e.Status!=se.OK)throw new dh(`Cannot get runtime info, controller responded with status ${e.Status}.`);if(null==e.Data)throw new dh("Cannot get runtime info, controller responded with status OK but response does not contains data.");this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}GetHardwareInfoAsync(e=!1){return sh(this,void 0,void 0,(function*(){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return sh(this,void 0,void 0,(function*(){Uh.Get(o.ServiceName).Debug(ih.ServiceName,"Getting hardware info from controller.");const e=yield Uh.Get(Vt.ServiceName).SendAndWaitForResponseAsync(new uh,16e3,!1);if(null==e||null==e.Status)throw new dh('Cannot get hardware info, controller response result is empty."');if(e.Status!=se.OK)throw new dh(`Cannot get hardware info, controller responded with status ${e.Status}.`);if(null==e.Data)throw new dh("Cannot get hardware info, controller responded with status OK but response does not contains data.");this._hardwareInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}}ih.ServiceName="UpdateProvider";class ah{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class ch extends re{constructor(){super(),this.Resource="/controller/software/info",this.Method=ie.Get}}class lh{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class uh extends re{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ie.Get}}class dh extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetRuntimeInfo"}}class hh{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class gh{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(Qd||(Qd={})),function(e){e[e.DownloadingFailure=-5]="DownloadingFailure",e[e.InstallationStopped=-4]="InstallationStopped",e[e.InstallationError=-3]="InstallationError",e[e.IncompatiblePackage=-2]="IncompatiblePackage",e[e.Error=-1]="Error",e[e.OK=0]="OK",e[e.DownloadingPackage=1]="DownloadingPackage",e[e.CheckingPackage=2]="CheckingPackage",e[e.PreparingForUpgrade=3]="PreparingForUpgrade",e[e.Upgrading=4]="Upgrading",e[e.MovingData=5]="MovingData",e[e.Reloading=6]="Reloading",e[e.Upgraded=7]="Upgraded"}(Zd||(Zd={})),(rh=eh||(eh={}))[rh.WaitingForUser=1]="WaitingForUser",rh[rh.Downloading=2]="Downloading",rh[rh.Unpackaging=3]="Unpackaging",rh[rh.CheckingApplicability=4]="CheckingApplicability",rh[rh.MigratingData=5]="MigratingData",rh[rh.CreatingBackup=6]="CreatingBackup",rh[rh.Deploying=7]="Deploying",rh[rh.Installing=8]="Installing",rh[rh.Removing=9]="Removing",rh[rh.Error=10]="Error",rh[rh.ReadyToDownload=11]="ReadyToDownload",rh[rh.PreparingSystem=12]="PreparingSystem",rh[rh.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",rh[rh.CheckingIntegrity=14]="CheckingIntegrity",rh[rh.UndoingInstallation=15]="UndoingInstallation",rh[rh.Installed=16]="Installed",(oh=th||(th={}))[oh.Ignore=0]="Ignore",oh[oh.Cancel=1]="Cancel",oh[oh.Install=2]="Install";class fh{constructor(){this.UpdatedResourceName="",this.Percentage=0,this.Status=Zd.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}!function(e){e[e.DeviceIsUpToDate=0]="DeviceIsUpToDate",e[e.CannotFindDevice=1]="CannotFindDevice",e[e.UnsupportedApiVersion=2]="UnsupportedApiVersion",e[e.UnsupportedDevice=3]="UnsupportedDevice",e[e.CannotGetFirmwareVersion=4]="CannotGetFirmwareVersion",e[e.CannotGetUpdates=5]="CannotGetUpdates",e[e.CannotProcessUpdate=6]="CannotProcessUpdate",e[e.UpdateActionsNotSupported=7]="UpdateActionsNotSupported",e[e.UnsupportedExtensionVersion=8]="UnsupportedExtensionVersion",e[e.UpdatesPartiallyInstalled=9]="UpdatesPartiallyInstalled"}(nh||(nh={}));var ph,vh,yh,wh,mh,Sh,_h=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class Ch{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._updateProviders=Uh.Get(ih.ServiceName),this._logger=Uh.Get(o.ServiceName),this._connection=Uh.Get(Vt.ServiceName),this._appStateService=Uh.Get(Ld.ServiceName)}GetServiceName(){return Ch.ServiceName}CheckDeviceVersionAsync(e){var t;return _h(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(nh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ce(nh.UnsupportedDevice,"Device does not contains data about protocol GUID.");const o=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Bd.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return o.Type,o}))}CheckDeviceUpdateAsync(e){var t;return _h(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(nh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ce(nh.UnsupportedDevice,"Device does not contains data about protocol GUID.");const o=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Bd.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=o.Type)return o;const r=new bh;return r.CurrentResourceVersion=o.CurrentResourceVersion,r.NewResourceVersion=o.Update.Version,r.UpdatedResourceName=o.UpdatedResourceName,r.UpdateResourceGuid=o.Update.ResourceGuid,r.UpdateDescription=new Map([["pl-PL",o.Update.Description]]),r.Protocol=yield(yield Uh.Get(jd.ServiceName).GetProtocolInfoAsync(n.ProtocolGuid)).first().Name,r.ProtocolGuid=n.ProtocolGuid,(yield Uh.Get(oo.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(r.IsUpdateSafe=!1),r}))}InstallDeviceUpdateAsync(e,t,n){var o;return _h(this,void 0,void 0,(function*(){let r;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(nh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);r=t}else r=e;if(null==r.ProtocolGuid)return new Ce(nh.UnsupportedDevice,"Device does not contains data about protocol GUID.");const s=yield null===(o=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(r.ProtocolGuid,Bd.Device)).first())||void 0===o?void 0:o.GetAvailableUpdateAsync(r);if(null!=s.Type)return s;this._appStateService.DisallowHibernation();const i=yield(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(r.ProtocolGuid,Bd.Device)).first().InstallUpdateAsync(s,t,n);return null!=i.Type?(this._appStateService.AllowHibernation(),i):(this._appStateService.AllowHibernation(),se.OK)}))}CheckControllerUpdatesAsync(){return _h(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Bd.Controller),t=new hh;this._controllerUpdates=[];for(let n=0;n<e.length;n++){const o=yield e[n].GetAvailableRadioUpdateAsync();if(null!=o.Type){const r=new Ah;r.ResponseResult=o,r.UpdateType=Qd.RadioUpdate,r.UpdatedResourceName=yield(yield Uh.Get(jd.ServiceName).GetProtocolInfoAsync(e[n].ProtocolGuid)).first().Name,r.CurrentResourceVersion=yield e[n].GetCurrentRadioVersionAsync(),t.UpdatesNotAvailable.push(r)}else{const r=o,s=new Dh;s.UpdatedResourceName=r.UpdatedResourceName,s.CurrentResourceVersion=r.CurrentResourceVersion,s.NewResourceVersion=r.Update.Version,s.UpdateDescription=new Map([["pl-PL",r.Update.Description]]),s.UpdateType=Qd.RadioUpdate,s.UpdateIdentifier=ne.GenerateUUID(),t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:e[n].GetUpdateProviderName(),UpdateType:Qd.RadioUpdate}))}}const n=yield this._updateProviders.GetSoftwareRuntimeInfoAsync(),o=`https://updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const e=yield fetch(o);let r,s=new Yd;const i=new Ah;switch(i.UpdateType=Qd.SoftwareUpdate,i.UpdatedResourceName="Controller software",e.status){case 200:null!=e.body&&(r=yield e.json());break;case 404:i.ResponseResult=new Ce(nh.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Ce(nh.CannotGetUpdates,`Response status code does not indicate success. Status: ${e.status}`),t.UpdatesNotAvailable.push(i)}if(null!=r){s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdatedResourceName="Controller software",s.Update=r;const e=new Dh;e.UpdatedResourceName=s.UpdatedResourceName,e.CurrentResourceVersion=s.CurrentResourceVersion,e.NewResourceVersion=s.Update.Version,e.UpdateDescription=new Map([["pl-PL",s.Update.Description]]),e.UpdateType=Qd.SoftwareUpdate,e.UpdateIdentifier=ne.GenerateUUID(),t.UpdatesAvailable.push(e),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:e.UpdateIdentifier,ProviderName:Ch.ServiceName,UpdateType:Qd.SoftwareUpdate}))}else if(200==e.status)throw new Error(`Cannot get Update Data from response. Status: ${e.status}`)}catch(e){const n=yield this._updateProviders.GetSoftwareRuntimeInfoAsync(),o=new Ah;o.UpdateType=Qd.SoftwareUpdate,o.UpdatedResourceName="Controller software",o.ResponseResult=new Ce(nh.CannotGetUpdates,`Cannot get available updates! ${e}`),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(o)}return t}))}CheckControllerVersionAsync(){return _h(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Bd.Controller),t=[];let n;for(let o=0;o<e.length;o++)n=new gh,n.Version=yield e[o].GetCurrentRadioVersionAsync(),n.Type=Qd.RadioUpdate,n.Resource=yield(yield Uh.Get(jd.ServiceName).GetProtocolInfoAsync(e[o].ProtocolGuid)).first().Name,t.push(n);n=new gh,n.Resource="Controller software",n.Type=Qd.SoftwareUpdate;const o=yield this._updateProviders.GetSoftwareRuntimeInfoAsync();return n.Version=`${o.RuntimeVersion}.${o.SoftwareVersion}`,t.push(n),t}))}InstallControllerUpdateAsync(e,t,n){return _h(this,void 0,void 0,(function*(){const o=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),r=this._controllerUpdates.length;if(0==this._controllerUpdates.length)return new Ce(nh.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if("string"!=typeof e||!o.test(e)){const t=[1],o=n=>{n.UpdateNumber=t[0],n.AvailableUpdates=r,e(n)},s=e=>_h(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let i=this._controllerUpdates.where((e=>e.UpdateType==Qd.RadioUpdate)).toArray(),a=[];this._appStateService.DisallowHibernation();for(let e=0;e<i.length;e++){const r=yield(yield this._updateProviders.GetUpdatesProviderAsync(i[e].ProviderName)).InstallRadioUpdateAsync(i[e],o,n);yield s(5e3),r==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=i[e].UpdateIdentifier))),a.push(r),t[0]++}const c=this._controllerUpdates.find((e=>e.UpdateType==Qd.SoftwareUpdate));if(null!=c){const e=yield this.UpdateControllerAsync(c.Update,o);e==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=c.UpdateIdentifier))),a.push(e),t[0]++}const l=a.where((e=>e instanceof Ce)).toArray();if(null!=l&&0!=l.length){let e="";return l.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),new Ce(nh.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),se.OK}{let o;const r=this._controllerUpdates.find((t=>t.UpdateIdentifier==e));if(null==r)return new Ce(nh.CannotGetUpdates,`Update with requested guid (${e}) not found.`);switch(this._logger.Debug(`Installing single update type: ${r.Update.UpdateType}, resource: ${r.UpdatedResourceName}, version: ${r.Update.Version}`),this._appStateService.DisallowHibernation(),r.UpdateType){case Qd.RadioUpdate:return o=yield(yield this._updateProviders.GetUpdatesProviderAsync(r.ProviderName)).InstallRadioUpdateAsync(r,t,n),this._appStateService.AllowHibernation(),o==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=e))),o;case Qd.SoftwareUpdate:return o=yield this.UpdateControllerAsync(r.Update,t),this._appStateService.AllowHibernation(),o==se.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=e))),o;default:return new Ce(nh.CannotProcessUpdate,`Update with type ${r.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerAsync(e,t){var n,o,r,s,i,a;return _h(this,void 0,void 0,(function*(){switch(e.UpdateType){case Hd.Container:case Hd.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Gh(e.DownloadUri),this._updateRequestTimeout,(n=>{const o=new fh;switch(o.UpdatedResourceName="Controller software",n.Status){case se.MultiDataResponseStart:o.Status=Zd.PreparingForUpgrade;break;case se.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(Ch.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(o.Percentage=n.Data.Progress,n.Data.State){case eh.CheckingApplicability:case eh.CheckingIntegrity:case eh.CheckingPackageIntegrity:o.Status=Zd.CheckingPackage;break;case eh.CreatingBackup:case eh.MigratingData:case eh.Removing:o.Status=Zd.MovingData;break;case eh.Deploying:case eh.Installing:o.Status=Zd.Upgrading;break;case eh.Downloading:o.Status=Zd.DownloadingPackage;break;case eh.Error:o.Status=Zd.Error;break;case eh.Installed:o.Status=Zd.Upgraded;break;case eh.PreparingSystem:case eh.ReadyToDownload:o.Status=Zd.PreparingForUpgrade;break;case eh.UndoingInstallation:o.Status=Zd.InstallationStopped;break;case eh.Unpackaging:o.Status=Zd.MovingData;break;case eh.WaitingForUser:o.Status=Zd.Upgrading}break;case se.MultiDataResponseStop:o.Status=Zd.OK}t(o)}),!1),se.OK}catch(e){return new Ce(nh.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case Hd.RuntimeFixingScript:var c=10,l=(yield Uh.Get(jd.ServiceName).GetExtensionsInfoAsync()).first((e=>"f4f45dac-beda-441a-8d29-efc6dc977cd1"==e.ExtensionGuid)).ExtensionVersion,u=parseFloat((yield this._updateProviders.GetSoftwareRuntimeInfoAsync()).RuntimeVersion)>=2||parseFloat(l)>=1.2201125;try{c=(yield Uh.Get(oo.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(Ch.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(u){let n,o=new fh;o.UpdatedResourceName="Controller software",o.Percentage=1,o.Status=Zd.PreparingForUpgrade,t(o);let r=2;const s=Date.now(),i=900*c+36e4,a=i/100,l=s+i,u=new Promise(((s,c)=>_h(this,void 0,void 0,(function*(){var c;try{const u=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(u),Date.now()>l)clearInterval(n),this._logger.Debug("Update already finished!"),o.Percentage=100,o.Status=Zd.Upgraded,t(o),s(se.OK);else{var e=l-Date.now();e<i?r=80-e/a:(clearInterval(n),n=setInterval((()=>{clearInterval(n),o.Percentage=100,o.Status=Zd.Upgraded,t(o),s(se.OK)}),e))}};this._appStateService.OnReturnedFromSuspension().Subscribe(u),n=setInterval((()=>{if(r>99)clearInterval(n),o.Percentage=100,o.Status=Zd.Upgraded,t(o),s(se.OK);else{var e=r;e<99&&(o.Percentage=e,o.Status=Zd.Upgrading,t(o))}r++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Eh(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=se.OK&&(clearInterval(n),o.Percentage=0,o.Status=Zd.InstallationError,t(o),this._logger.Debug(Ch.ServiceName,`Update failed with error. Update response status: ${d.Status}`),s(new Ce(nh.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(Ch.ServiceName,`Update failed with error. ${e}`),o.Percentage=0,o.Status=Zd.Error,t(o),clearInterval(n),s(new Ce(nh.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield u}{let n=new fh;n.UpdatedResourceName="Controller software",n.Percentage=1,n.Status=Zd.PreparingForUpgrade,t(n);const l=this._connection.GetAuthorizationInfo();if(null==l)return new Ce(nh.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Ih({Email:"support@support",Password:`support@${l.SerialNumber}:${l.PIN}`}),12e3,!1)).Status===se.OK){n.Percentage=5,n.Status=Zd.PreparingForUpgrade,t(n);let o=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Th("rm /runtime/tmp/update.sh"),12e3,!1);if(o.Status==se.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=10,n.Status=Zd.PreparingForUpgrade,t(n),o=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Th(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh`),this._updateRequestTimeout,!1),o.Status==se.OK){this._logger.Debug("Downloaded update script"),n.Percentage=15,n.Status=Zd.PreparingForUpgrade,t(n);try{if(o=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Th("chmod a+x /runtime/tmp/update.sh"),12e3,!1),o.Status==se.OK){this._logger.Debug("Executed update script"),n.Percentage=20,n.Status=Zd.Upgrading,t(n);let e,o=0;const r=.8,s=Date.now(),i=900*c+2e5,a=i/80,l=s+i,u=new Promise(((s,c)=>_h(this,void 0,void 0,(function*(){var c;try{const u=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(u),Date.now()>l)clearInterval(e),this._logger.Debug("Update already finished!"),n.Percentage=100,n.Status=Zd.Upgraded,t(n),s(se.OK);else{var r=l-Date.now();r<i?o=80-r/a:(clearInterval(e),e=setInterval((()=>{clearInterval(e),n.Percentage=100,n.Status=Zd.Upgraded,t(n),s(se.OK)}),r))}};this._appStateService.OnReturnedFromSuspension().Subscribe(u),e=setInterval((()=>{if(o>99)clearInterval(e),n.Percentage=100,n.Status=Zd.Upgraded,t(n),s(se.OK);else{var i=20+o*r;i<99&&(n.Percentage=i,n.Status=Zd.Upgrading,t(n))}o++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Th("/runtime/tmp/update.sh"),12e3,!1)}catch(e){s(new Ce(nh.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield u}return n.Percentage=0,n.Status=Zd.InstallationError,t(n),new Ce(nh.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Th("/runtime/scripts/restart_all.sh"),12e3,!1),new Ce(nh.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Ce(nh.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Ce(nh.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Ce(nh.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}}Ch.ServiceName="UpdatesService";class Ah{constructor(){this.UpdatedResourceName="",this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class Dh{constructor(){this._updateIdentifier="",this._updateResourceName="",this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map}get UpdateDescription(){return this._updateDescription}set UpdateDescription(e){this._updateDescription=e}get UpdateIdentifier(){return this._updateIdentifier}get UpdatedResourceName(){return this._updateResourceName}get UpdateType(){return this._updateType}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}set UpdateIdentifier(e){this._updateIdentifier=e}set UpdatedResourceName(e){this._updateResourceName=e}set UpdateType(e){this._updateType=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}}class bh{constructor(){this._updatedResourceName="",this._updateResourceGuid="",this._protocol="",this._protocolGuid="",this._currentResourceVersion="",this._newResourceVersion="",this._isUpdateSafe=!0,this._updateDescription=new Map}get UpdateDescription(){return this._updateDescription}set UpdateDescription(e){this._updateDescription=e}get UpdatedResourceName(){return this._updatedResourceName}get UpdateResourceGuid(){return this._updateResourceGuid}get Protocol(){return this._protocol}get ProtocolGuid(){return this._protocolGuid}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}get IsUpdateSafe(){return this._isUpdateSafe}set UpdatedResourceName(e){this._updatedResourceName=e}set UpdateResourceGuid(e){this._updateResourceGuid=e}set Protocol(e){this._protocol=e}set ProtocolGuid(e){this._protocolGuid=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}set IsUpdateSafe(e){this._isUpdateSafe=e}}class Gh extends re{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=ie.Post,this.Data=e}}!function(e){e[e.Windows=0]="Windows",e[e.Linux=1]="Linux",e[e.Unix=2]="Unix",e[e.OSX=3]="OSX",e[e.Android=4]="Android",e[e.iOS=5]="iOS",e[e.WindowsMobile=6]="WindowsMobile"}(ph||(ph={})),function(e){e[e.Any=0]="Any",e[e.MIPS=1]="MIPS",e[e.ARM32=2]="ARM32",e[e.ARM64=3]="ARM64",e[e.IntelX86=4]="IntelX86",e[e.IntelX64=5]="IntelX64"}(vh||(vh={})),function(e){e[e.Unknown=0]="Unknown",e[e.Environment=1]="Environment",e[e.OperatingSystem=2]="OperatingSystem",e[e.Application=3]="Application",e[e.Extension=4]="Extension",e[e.HardwareFirmware=5]="HardwareFirmware",e[e.Script=6]="Script",e[e.Command=7]="Command"}(yh||(yh={}));class Eh extends re{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ie.Put,this.Data=e}}class Ih extends re{constructor(e){super(),this.Resource="/users/user/login",this.Method=ie.Put,this.Data=e}}class Th extends re{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ie.Post,this.Data=e}}!function(e){e.CannotFindDevice="CannotFindDevice",e.ResponseTypeNotSupported="ResponseTypeNotSupported",e.InvalidChannelNumber="InvalidChannelNumber",e.IncorrectLimitValue="IncorrectLimitValue",e.IncorrectOffsetValue="IncorrectOffsetValue",e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.FunctionalityNotSupported="FunctionalityNotSupported"}(wh||(wh={})),function(e){e[e.None=0]="None",e[e.DataRange=1]="DataRange",e[e.Hour=2]="Hour",e[e.Day=3]="Day",e[e.Week=4]="Week",e[e.Month=5]="Month",e[e.Year=6]="Year"}(mh||(mh={}));class Nh{constructor(){this._objectType="Unknown",this._stateInterfaceType="Unknown"}get StateObjectType(){return this._objectType}get StateInterfaceType(){return this._stateInterfaceType}get StateResponseType(){return this._stateInterfaceType}set StateObjectType(e){this._objectType=e}set StateInterfaceType(e){this._stateInterfaceType=e}}!function(e){e[e.Unknown=-1]="Unknown",e[e.PitchBlack=0]="PitchBlack",e[e.VeryDark=1]="VeryDark",e[e.DarkIndoors=2]="DarkIndoors",e[e.DimIndoors=3]="DimIndoors",e[e.NormalIndoors=4]="NormalIndoors",e[e.BrightIndoors=5]="BrightIndoors",e[e.DimOutdoors=6]="DimOutdoors",e[e.CloudyOutdoors=7]="CloudyOutdoors",e[e.DirectSunlight=8]="DirectSunlight"}(Sh||(Sh={}));var Ph=function(e,t,n,o){return new(n||(n=Promise))((function(r,s){function i(e){try{c(o.next(e))}catch(e){s(e)}}function a(e){try{c(o.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((o=o.apply(e,t||[])).next())}))};class kh{constructor(){this._connection=null,this._connection=Uh.Get(Vt.ServiceName)}GetServiceName(){return kh.ServiceName}GetStatesByIntervalAsync(e,t,n,o,r,s){var i;return Ph(this,void 0,void 0,(function*(){try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Ce(wh.FunctionalityNotSupported,"State history data is not supported with this version of controller software, update software to get this functionality.");let a;if("string"==typeof e){const t=yield Uh.Get(oo.ServiceName).GetDevice(e);if(null==t)return new Ce(wh.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);a=t}else a=e;if(!a.Channels.any((e=>e.Number==t)))return new Ce(wh.InvalidChannelNumber,`Given channel not found in device with guid: ${a.Guid}.`);if(!a.Channels.any((e=>e.Number==t&&e.AvailableResponseTypes.any((e=>e.Type==n)))))return new Ce(wh.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const c=new Oh;c.DeviceGuid=a.Guid,c.DeviceChannel=t,c.Range=o,c.StateInterfaceType=n,c.Limit=r,c.Offset=s;const l=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Rh(c),16e3,!1);if(null==l)return new Ce(wh.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case se.WrongData:switch(l.Data){case"IncorrectLimitValue":return new Ce(wh.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ce(wh.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ce(wh.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Ce(wh.OtherError,"Cannot get state history data - unknown error!")}case se.FatalError:return new Ce(wh.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case se.ResourceDoesNotExists:return new Ce(wh.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case se.OK:return null==l.Data?new Ce(wh.NoData,"Controller responede with status OK, but response does not contain data!"):l.Data;default:return new Ce(wh.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new Ce(wh.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){var e;return Ph(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new xh,8e3,!1);return null==t?new Ce(wh.OtherError,"Cannot get available states - response is null."):t.Status!=se.OK?new Ce(wh.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Ce(wh.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Nh;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Ce(wh.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return Ph(this,void 0,void 0,(function*(){return!(parseFloat((yield Uh.Get(ih.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}}kh.ServiceName="StatesHistoryService";class Rh extends re{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ie.Get,this.Data=e}}class Oh{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=mh.Day,this.Limit=0,this.Offset=0}}class xh extends re{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ie.Get}}Di(Map),Di(Set),(()=>{var e;const t=String.prototype,n=Object.getOwnPropertyNames(xo.prototype);for(const o of n)t[o]=null!==(e=t[o])&&void 0!==e?e:xo.prototype[o];t.first=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}throw new No(To.NoMatch)}if(0===this.length)throw new No(To.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[0]},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Io("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new No(To.NoMatch)}if(0===this.length)throw new No(To.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.reverse=function(){const e=this;return new xo((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),Uo(Array),Uo(Int8Array),Uo(Int16Array),Uo(Int32Array),Uo(Uint8Array),Uo(Uint8ClampedArray),Uo(Uint16Array),Uo(Uint32Array),Uo(Float32Array),Uo(Float64Array);class Uh{static Init(){if(r.IsInitialized)return;let e=r.Instance;try{e.RegisterService(new s),e.RegisterService(new Ld),e.RegisterService(new Ke),e.RegisterService(new He),e.RegisterService(new Vt),e.RegisterService(new Yn),e.RegisterService(new Do),e.RegisterService(new qe),e.RegisterService(new zn),e.RegisterService(new jd),e.RegisterService(new be),e.RegisterService(new xe),e.RegisterService(new oo),e.RegisterService(new Ad),e.RegisterService(new ih),e.RegisterService(new Ch),e.RegisterService(new kh)}catch(e){console.error(e)}}static GetAsync(e,t){return r.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return r.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return r.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}}Uh.WorksInContextOf="",Uh.Version=1})();
|
|
2
2
|
//# sourceMappingURL=exalushome-library-bundle.js.map
|