lavva.exalushome 2.0.210 → 2.0.211
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,n,r,o,s,i={d:(e,t)=>{for(var n in t)i.o(t,n)&&!i.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}};i.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),i.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),i.d({},{j:()=>Qv});class a{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=u.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.None=4]="None"}(e||(e={}));class c{constructor(){this._blockedServices=[],this._logLevel=e.Debug,void 0!==window.loglevel&&null!==window.loglevel&&(this._logLevel=window.loglevel),window.logger=this}EnableStackTrace(){c.DoesThrowStackTrace=!0}DisableStackTrace(){c.DoesThrowStackTrace=!1}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(c.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(c.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return c.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;case e.None: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(t,n){switch(this._logLevel){case e.Warning:case e.Info:case e.Debug:case e.Error:break;case e.None:default:return}null!=t&&(null==n?console.error(`${this.GetTimeStamp()}[ERROR] ${t}`):console.error(`${this.GetTimeStamp()}[ERROR] [${t}] ${n}`))}Info(t,n){switch(this._logLevel){case e.Info:case e.Debug:break;case e.None: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){switch(this._logLevel){case e.Debug:break;case e.None:default:return}void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.debug(`${this.GetTimeStamp()}[DEBUG] ${t}`):c.DoesThrowStackTrace||!0===window.stacktrace?console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n} \nstack:\n${(new Error).stack}}`):console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n}`))}Log(t,n){this._logLevel!==e.None&&(void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.log(`${this.GetTimeStamp()}[LOG] ${t}`):console.log(`${this.GetTimeStamp()}[LOG] [${t}] ${n}`)))}}c.ServiceName="LoggerService",c.DoesThrowStackTrace=!1;class u{constructor(){this._services={},this._serviceRegistrationEvent=new a}set DebugCalls(e){u._debugCalls=e,localStorage.setItem("_exalus_DependencyContainer_debugCalls",e.toString())}static get Instance(){if(null!=u._instance)return u._instance;const e=localStorage.getItem("_exalus_DependencyContainer_debugCalls");return u._debugCalls=e===(!0).toString(),u._instance=new u,this.Log=new c,this.Log.Warning("Initializing DependencyContainer"),u._instance.RegisterService(this.Log),this.IsInitialized=!0,window.services=this,u._instance}RegisterService(e){var t;if(null===(t=u.Log)||void 0===t||t.Debug("DependencyContainer",`Registering new service: ${e.GetServiceName()}`),u._debugCalls)try{throw new Error(`Registering new service: ${e.GetServiceName()}`)}catch(e){console.error(e)}this._services[e.GetServiceName()]=e,this._serviceRegistrationEvent.Invoke(e)}GetService(e){var t;if(null===(t=u.Log)||void 0===t||t.Debug("DependencyContainer",`Getting service [${e}] by GetService<T>()`),u._debugCalls)try{throw new Error(`Getting service: ${e}`)}catch(e){console.error(e)}return this._services[e]}GetServiceAsync(e,t){var n,r;if(null===(n=u.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service availability [${e}] by GetServiceAsync<T>()`),u._debugCalls)try{throw new Error(`Waiting for service availability: ${e}`)}catch(e){console.error(e)}return this._services.hasOwnProperty(e)?(null===(r=u.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,r)=>{var o=t=>{var r;(null==t?void 0:t.GetServiceName())===e&&(null===(r=u.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),n(t))},s=()=>{var n;null===(n=u.Log)||void 0===n||n.Debug("DependencyContainer",`Cancelled service [${e}] retrieval by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),null==t||t.CancellationEvent.Unsubscribe(s),r(new Error("Operation cancelled!"))};null==t||t.CancellationEvent.Subscribe(s),this._serviceRegistrationEvent.Subscribe(o)}))}GetServiceWithTimeoutAsync(e,t){var n,r;if(null===(n=u.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service[${e}] availability by GetServiceWithTimeoutAsync<T>()`),u._debugCalls)try{throw new Error(`Waiting for service availability: ${e}`)}catch(e){console.error(e)}return this._services.hasOwnProperty(e)?(null===(r=u.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,r)=>{let o=0,s=e=>{var t;(null==e?void 0:e.GetClassName())===e&&(null===(t=u.Log)||void 0===t||t.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(s),n(e))};o=window.setTimeout((()=>{var t;window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(s),null===(t=u.Log)||void 0===t||t.Error("DependencyContainer",`Failed to get service [${e}] in time by GetServiceWithTimeoutAsync<T>()`),r(new Error("Operation cancelled!"))}),t),this._serviceRegistrationEvent.Subscribe(s)}))}}u.IsInitialized=!1,u._debugCalls=!1;class l{GetServiceName(){return l.ServiceName}GetResourceName(e,t){return`_exalus_${Qv.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),r=localStorage.getItem(n);return null==r?null:JSON.parse(r)}catch(r){return null===(n=u.Log)||void 0===n||n.Error(l.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}l.ServiceName="LocalStorageService",function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(t||(t={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(n||(n={})),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"}(r||(r={}));class d{static write(e){return`${e}${d.RecordSeparator}`}static parse(e){if(e[e.length-1]!==d.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(d.RecordSeparator);return t.pop(),t}}d.RecordSeparatorCode=30,d.RecordSeparator=String.fromCharCode(d.RecordSeparatorCode);class h{constructor(){}log(e,t){}}h.instance=new h;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 p{static get isBrowser(){return!p.isNode&&"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return!p.isNode&&"object"==typeof self&&"importScripts"in self}static get isReactNative(){return!p.isNode&&"object"==typeof window&&void 0===window.document}static get isNode(){return"undefined"!=typeof process&&process.release&&"node"===process.release.name}}function f(e,t){let n="";return v(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 v(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function y(e,t,n,o,s,i){const a={},[c,u]=S();a[c]=u,e.log(r.Trace,`(${t} transport) sending data. ${f(s,i.logMessageContent)}.`);const l=v(s)?"arraybuffer":"text",d=await n.post(o,{content:s,headers:{...a,...i.headers},responseType:l,timeout:i.timeout,withCredentials:i.withCredentials});e.log(r.Trace,`(${t} transport) request complete. Response status: ${d.statusCode}.`)}class m{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 w{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${r[e]}: ${t}`;switch(e){case r.Critical:case r.Error:this.out.error(n);break;case r.Warning:this.out.warn(n);break;case r.Information:this.out.info(n);break;default:this.out.log(n)}}}}function S(){let e="X-SignalR-User-Agent";return p.isNode&&(e="User-Agent"),[e,A("8.0.7",_(),p.isNode?"NodeJS":"Browser",C())]}function A(e,t,n,r){let o="Microsoft SignalR/";const s=e.split(".");return o+=`${s[0]}.${s[1]}`,o+=` (${e}; `,o+=t&&""!==t?`${t}; `:"Unknown OS; ",o+=`${n}`,o+=r?`; ${r}`:"; Unknown Runtime Version",o+=")",o}function _(){if(!p.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function C(){if(p.isNode)return process.versions.node}function T(e){return e.stack?e.stack:e.message?e.message:`${e}`}class D{writeHandshakeRequest(e){return d.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(v(e)){const r=new Uint8Array(e),o=r.indexOf(d.RecordSeparatorCode);if(-1===o)throw new Error("Message is incomplete.");const s=o+1;t=String.fromCharCode.apply(null,Array.prototype.slice.call(r.slice(0,s))),n=r.byteLength>s?r.slice(s).buffer:null}else{const r=e,o=r.indexOf(d.RecordSeparator);if(-1===o)throw new Error("Message is incomplete.");const s=o+1;t=r.substring(0,s),n=r.length>s?r.substring(s):null}const r=d.parse(t),o=JSON.parse(r[0]);if(o.type)throw new Error("Expected a handshake response from the server.");return[n,o]}}class k extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class E extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class b extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class I extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class G extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class N extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class R extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class P extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}!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",e[e.Ack=8]="Ack",e[e.Sequence=9]="Sequence"}(o||(o={}));class O{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 m(this,e)}}class U{constructor(e,t,n){this._bufferSize=1e5,this._messages=[],this._totalMessageCount=0,this._waitForSequenceMessage=!1,this._nextReceivingSequenceId=1,this._latestReceivedSequenceId=0,this._bufferedByteCount=0,this._reconnectInProgress=!1,this._protocol=e,this._connection=t,this._bufferSize=n}async _send(e){const t=this._protocol.writeMessage(e);let n=Promise.resolve();if(this._isInvocationMessage(e)){this._totalMessageCount++;let e=()=>{},r=()=>{};v(t)?this._bufferedByteCount+=t.byteLength:this._bufferedByteCount+=t.length,this._bufferedByteCount>=this._bufferSize&&(n=new Promise(((t,n)=>{e=t,r=n}))),this._messages.push(new M(t,this._totalMessageCount,e,r))}try{this._reconnectInProgress||await this._connection.send(t)}catch{this._disconnected()}await n}_ack(e){let t=-1;for(let n=0;n<this._messages.length;n++){const r=this._messages[n];if(r._id<=e.sequenceId)t=n,v(r._message)?this._bufferedByteCount-=r._message.byteLength:this._bufferedByteCount-=r._message.length,r._resolver();else{if(!(this._bufferedByteCount<this._bufferSize))break;r._resolver()}}-1!==t&&(this._messages=this._messages.slice(t+1))}_shouldProcessMessage(e){if(this._waitForSequenceMessage)return e.type===o.Sequence&&(this._waitForSequenceMessage=!1,!0);if(!this._isInvocationMessage(e))return!0;const t=this._nextReceivingSequenceId;return this._nextReceivingSequenceId++,t<=this._latestReceivedSequenceId?(t===this._latestReceivedSequenceId&&this._ackTimer(),!1):(this._latestReceivedSequenceId=t,this._ackTimer(),!0)}_resetSequence(e){e.sequenceId>this._nextReceivingSequenceId?this._connection.stop(new Error("Sequence ID greater than amount of messages we've received.")):this._nextReceivingSequenceId=e.sequenceId}_disconnected(){this._reconnectInProgress=!0,this._waitForSequenceMessage=!0}async _resend(){const e=0!==this._messages.length?this._messages[0]._id:this._totalMessageCount+1;await this._connection.send(this._protocol.writeMessage({type:o.Sequence,sequenceId:e}));const t=this._messages;for(const e of t)await this._connection.send(e._message);this._reconnectInProgress=!1}_dispose(e){null!=e||(e=new Error("Unable to reconnect to server."));for(const t of this._messages)t._rejector(e)}_isInvocationMessage(e){switch(e.type){case o.Invocation:case o.StreamItem:case o.Completion:case o.StreamInvocation:case o.CancelInvocation:return!0;case o.Close:case o.Sequence:case o.Ping:case o.Ack:return!1}}_ackTimer(){void 0===this._ackTimerHandle&&(this._ackTimerHandle=setTimeout((async()=>{try{this._reconnectInProgress||await this._connection.send(this._protocol.writeMessage({type:o.Ack,sequenceId:this._latestReceivedSequenceId}))}catch{}clearTimeout(this._ackTimerHandle),this._ackTimerHandle=void 0}),1e3))}}class M{constructor(e,t,n,r){this._message=e,this._id=t,this._resolver=n,this._rejector=r}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(s||(s={}));class x{static create(e,t,n,r,o,s,i){return new x(e,t,n,r,o,s,i)}constructor(e,t,n,i,a,c,u){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(r.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://learn.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},g.isRequired(e,"connection"),g.isRequired(t,"logger"),g.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=null!=a?a:3e4,this.keepAliveIntervalInMilliseconds=null!=c?c:15e3,this._statefulReconnectBufferSize=null!=u?u:1e5,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=i,this._handshakeProtocol=new D,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=s.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:o.Ping})}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!==s.Disconnected&&this._connectionState!==s.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!==s.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=s.Connecting,this._logger.log(r.Debug,"Starting HubConnection.");try{await this._startInternal(),p.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=s.Connected,this._connectionStarted=!0,this._logger.log(r.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=s.Disconnected,this._logger.log(r.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{let t=this._protocol.version;this.connection.features.reconnect||(t=1);const n={protocol:this._protocol.name,version:t};if(this._logger.log(r.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(n)),this._logger.log(r.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;!!this.connection.features.reconnect&&(this._messageBuffer=new U(this._protocol,this.connection,this._statefulReconnectBufferSize),this.connection.features.disconnected=this._messageBuffer._disconnected.bind(this._messageBuffer),this.connection.features.resend=()=>{if(this._messageBuffer)return this._messageBuffer._resend()}),this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(r.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.connection.features.reconnect=!1,this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){if(this._connectionState===s.Disconnected)return this._logger.log(r.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve();if(this._connectionState===s.Disconnecting)return this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise;const t=this._connectionState;return this._connectionState=s.Disconnecting,this._logger.log(r.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(r.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(t===s.Connected&&this._sendCloseMessage(),this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new b("The connection was stopped before the hub handshake could complete."),this.connection.stop(e))}async _sendCloseMessage(){try{await this._sendWithProtocol(this._createCloseMessage())}catch{}}stream(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._createStreamInvocation(e,t,r);let i;const a=new O;return a.cancelCallback=()=>{const e=this._createCancelInvocation(s.invocationId);return delete this._callbacks[s.invocationId],i.then((()=>this._sendWithProtocol(e)))},this._callbacks[s.invocationId]=(e,t)=>{t?a.error(t):e&&(e.type===o.Completion?e.error?a.error(new Error(e.error)):a.complete():a.next(e.item))},i=this._sendWithProtocol(s).catch((e=>{a.error(e),delete this._callbacks[s.invocationId]})),this._launchStreams(n,i),a}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._messageBuffer?this._messageBuffer._send(e):this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,r]=this._replaceStreamingParams(t),o=this._sendWithProtocol(this._createInvocation(e,t,!0,r));return this._launchStreams(n,o),o}invoke(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._createInvocation(e,t,!1,r);return new Promise(((e,t)=>{this._callbacks[s.invocationId]=(n,r)=>{r?t(r):n&&(n.type===o.Completion?n.error?t(new Error(n.error)):e(n.result):t(new Error(`Unexpected message type: ${n.type}`)))};const r=this._sendWithProtocol(s).catch((e=>{t(e),delete this._callbacks[s.invocationId]}));this._launchStreams(n,r)}))}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 r=n.indexOf(t);-1!==r&&(n.splice(r,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)if(!this._messageBuffer||this._messageBuffer._shouldProcessMessage(e))switch(e.type){case o.Invocation:this._invokeClientMethod(e).catch((e=>{this._logger.log(r.Error,`Invoke client method threw error: ${T(e)}`)}));break;case o.StreamItem:case o.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===o.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(r.Error,`Stream callback threw error: ${T(e)}`)}}break}case o.Ping:break;case o.Close:{this._logger.log(r.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}case o.Ack:this._messageBuffer&&this._messageBuffer._ack(e);break;case o.Sequence:this._messageBuffer&&this._messageBuffer._resetSequence(e);break;default:this._logger.log(r.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(r.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(r.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(r.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===s.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(r.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(r.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(),s=!!e.invocationId;let i,a,c;for(const n of o)try{const o=i;i=await n.apply(this,e.arguments),s&&i&&o&&(this._logger.log(r.Error,`Multiple results provided for '${t}'. Sending error to server.`),c=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),a=void 0}catch(e){a=e,this._logger.log(r.Error,`A callback for the method '${t}' threw error '${e}'.`)}c?await this._sendWithProtocol(c):s?(a?c=this._createCompletionMessage(e.invocationId,`${a}`,null):void 0!==i?c=this._createCompletionMessage(e.invocationId,null,i):(this._logger.log(r.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),c=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(c)):i&&this._logger.log(r.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(r.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new b("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===s.Disconnecting?this._completeClose(e):this._connectionState===s.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===s.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=s.Disconnected,this._connectionStarted=!1,this._messageBuffer&&(this._messageBuffer._dispose(null!=e?e:new Error("Connection closed.")),this._messageBuffer=void 0),p.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.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."),i=this._getNextRetryDelay(n++,0,o);if(null===i)return this._logger.log(r.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=s.Reconnecting,e?this._logger.log(r.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(r.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==s.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==i;){if(this._logger.log(r.Information,`Reconnect attempt number ${n} will start in ${i} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,i)})),this._reconnectDelayHandle=void 0,this._connectionState!==s.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=s.Connected,this._logger.log(r.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(r.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(r.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==s.Reconnecting)return this._logger.log(r.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===s.Disconnecting&&this._completeClose());o=e instanceof Error?e:new Error(e.toString()),i=this._getNextRetryDelay(n++,Date.now()-t,o)}}this._logger.log(r.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(r.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(r.Error,`Stream 'error' callback called with '${e}' threw error: ${T(t)}`)}}))}_cleanupPingTimer(){this._pingServerHandle&&(clearTimeout(this._pingServerHandle),this._pingServerHandle=void 0)}_cleanupTimeout(){this._timeoutHandle&&clearTimeout(this._timeoutHandle)}_createInvocation(e,t,n,r){if(n)return 0!==r.length?{arguments:t,streamIds:r,target:e,type:o.Invocation}:{arguments:t,target:e,type:o.Invocation};{const n=this._invocationId;return this._invocationId++,0!==r.length?{arguments:t,invocationId:n.toString(),streamIds:r,target:e,type:o.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:o.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 r;r=e instanceof Error?e.message:e&&e.toString?e.toString():"Unknown error",t=t.then((()=>this._sendWithProtocol(this._createCompletionMessage(n,r))))},next:e=>{t=t.then((()=>this._sendWithProtocol(this._createStreamItemMessage(n,e))))}})}}_replaceStreamingParams(e){const t=[],n=[];for(let r=0;r<e.length;r++){const o=e[r];if(this._isObservable(o)){const s=this._invocationId;this._invocationId++,t[s]=o,n.push(s.toString()),e.splice(r,1)}}return[t,n]}_isObservable(e){return e&&e.subscribe&&"function"==typeof e.subscribe}_createStreamInvocation(e,t,n){const r=this._invocationId;return this._invocationId++,0!==n.length?{arguments:t,invocationId:r.toString(),streamIds:n,target:e,type:o.StreamInvocation}:{arguments:t,invocationId:r.toString(),target:e,type:o.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:o.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:o.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:o.Completion}:{invocationId:e,result:n,type:o.Completion}}_createCloseMessage(){return{type:o.Close}}}const F=[0,2e3,1e4,3e4,null];class L{constructor(e){this._retryDelays=void 0!==e?[...e,null]:F}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class B{}B.Authorization="Authorization",B.Cookie="Cookie";class W{constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class ${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 q extends ${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[B.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[B.Authorization]&&delete e.headers[B.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class V extends ${constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch||p.isNode){const e=require;this._jar=new(e("tough-cookie").CookieJar),"undefined"==typeof fetch?this._fetchType=e("node-fetch"):this._fetchType=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!==i.g)return i.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 b;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 b});let o,s=null;if(e.timeout){const o=e.timeout;s=setTimeout((()=>{t.abort(),this._logger.log(r.Warning,"Timeout from HTTP request."),n=new E}),o)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},v(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(r.Warning,`Error from HTTP request. ${e}.`),e}finally{s&&clearTimeout(s),e.abortSignal&&(e.abortSignal.onabort=null)}if(!o.ok){const e=await H(o,"text");throw new k(e||o.statusText,o.status)}const i=H(o,e.responseType),a=await i;return new W(o.status,o.statusText,a)}getCookieString(e){let t="";return p.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function H(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 K extends ${constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new b):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&&(v(e.content)?o.setRequestHeader("Content-Type","application/octet-stream"):o.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const s=e.headers;s&&Object.keys(s).forEach((e=>{o.setRequestHeader(e,s[e])})),e.responseType&&(o.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{o.abort(),n(new b)}),e.timeout&&(o.timeout=e.timeout),o.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),o.status>=200&&o.status<300?t(new W(o.status,o.statusText,o.response||o.responseText)):n(new k(o.response||o.responseText||o.statusText,o.status))},o.onerror=()=>{this._logger.log(r.Warning,`Error from HTTP request. ${o.status}: ${o.statusText}.`),n(new k(o.statusText,o.status))},o.ontimeout=()=>{this._logger.log(r.Warning,"Timeout from HTTP request."),n(new E)},o.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class j extends ${constructor(e){if(super(),"undefined"!=typeof fetch||p.isNode)this._httpClient=new V(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new K(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new b):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)}}class z{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 J{get pollAborted(){return this._pollAbort.aborted}constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new z,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}async connect(e,t){if(g.isRequired(e,"url"),g.isRequired(t,"transferFormat"),g.isIn(t,n,"transferFormat"),this._url=e,this._logger.log(r.Trace,"(LongPolling transport) Connecting."),t===n.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[o,s]=S(),i={[o]:s,...this._options.headers},a={abortSignal:this._pollAbort.signal,headers:i,timeout:1e5,withCredentials:this._options.withCredentials};t===n.Binary&&(a.responseType="arraybuffer");const c=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${c}.`);const u=await this._httpClient.get(c,a);200!==u.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${u.statusCode}.`),this._closeError=new k(u.statusText||"",u.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,a)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${n}.`);const o=await this._httpClient.get(n,t);204===o.statusCode?(this._logger.log(r.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==o.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${o.statusCode}.`),this._closeError=new k(o.statusText||"",o.statusCode),this._running=!1):o.content?(this._logger.log(r.Trace,`(LongPolling transport) data received. ${f(o.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(o.content)):this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof E?this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(r.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(r.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?y(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(r.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(r.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=S();e[t]=n;const o={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};let s;try{await this._httpClient.delete(this._url,o)}catch(e){s=e}s?s instanceof k&&(404===s.statusCode?this._logger.log(r.Trace,"(LongPolling transport) A 404 response was returned from sending a DELETE request."):this._logger.log(r.Trace,`(LongPolling transport) Error sending a DELETE request: ${s}`)):this._logger.log(r.Trace,"(LongPolling transport) DELETE request accepted.")}finally{this._logger.log(r.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(r.Trace,e),this.onclose(this._closeError)}}}class X{constructor(e,t,n,r){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=r,this.onreceive=null,this.onclose=null}async connect(e,t){return g.isRequired(e,"url"),g.isRequired(t,"transferFormat"),g.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((o,s)=>{let i,a=!1;if(t===n.Text){if(p.isBrowser||p.isWebWorker)i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[r,o]=S();n[r]=o,i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{i.onmessage=e=>{if(this.onreceive)try{this._logger.log(r.Trace,`(SSE transport) data received. ${f(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},i.onerror=e=>{a?this._close():s(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."))},i.onopen=()=>{this._logger.log(r.Information,`SSE connected to ${this._url}`),this._eventSource=i,a=!0,o()}}catch(e){return void s(e)}}else s(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?y(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 Y{constructor(e,t,n,r,o,s){this._logger=n,this._accessTokenFactory=t,this._logMessageContent=r,this._webSocketConstructor=o,this._httpClient=e,this.onreceive=null,this.onclose=null,this._headers=s}async connect(e,t){let o;return g.isRequired(e,"url"),g.isRequired(t,"transferFormat"),g.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(o=await this._accessTokenFactory()),new Promise(((s,i)=>{let a;e=e.replace(/^http/,"ws");const c=this._httpClient.getCookieString(e);let u=!1;if(p.isNode||p.isReactNative){const t={},[n,r]=S();t[n]=r,o&&(t[B.Authorization]=`Bearer ${o}`),c&&(t[B.Cookie]=c),a=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else o&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(o)}`);a||(a=new this._webSocketConstructor(e)),t===n.Binary&&(a.binaryType="arraybuffer"),a.onopen=t=>{this._logger.log(r.Information,`WebSocket connected to ${e}.`),this._webSocket=a,u=!0,s()},a.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(r.Information,`(WebSockets transport) ${t}.`)},a.onmessage=e=>{if(this._logger.log(r.Trace,`(WebSockets transport) data received. ${f(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},a.onclose=e=>{if(u)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.",i(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(r.Trace,`(WebSockets transport) sending data. ${f(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(r.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 Q{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 w(r.Information):null===n?h.instance:void 0!==n.log?n:new w(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,s=null;if(p.isNode){const e=require;o=e("ws"),s=e("eventsource")}p.isNode||"undefined"==typeof WebSocket||t.WebSocket?p.isNode&&!t.WebSocket&&o&&(t.WebSocket=o):t.WebSocket=WebSocket,p.isNode||"undefined"==typeof EventSource||t.EventSource?p.isNode&&!t.EventSource&&void 0!==s&&(t.EventSource=s):t.EventSource=EventSource,this._httpClient=new q(t.httpClient||new j(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||n.Binary,g.isIn(e,n,"transferFormat"),this._logger.log(r.Debug,`Starting connection with transfer format '${n[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(r.Error,e),await this._stopPromise,Promise.reject(new b(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(r.Error,e),Promise.reject(new b(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(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(r.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(r.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(r.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let n=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==t.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(t.WebSockets),await this._startTransport(n,e)}else{let t=null,r=0;do{if(t=await this._getNegotiationResponse(n),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new b("The connection was stopped during negotiation.");if(t.error)throw new Error(t.error);if(t.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(t.url&&(n=t.url),t.accessToken){const e=t.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}r++}while(t.url&&r<100);if(100===r&&t.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(n,this._options.transport,t,e)}this.transport instanceof J&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(r.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(r.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]=S();t[n]=o;const s=this._resolveNegotiateUrl(e);this._logger.log(r.Debug,`Sending negotiation request: ${s}.`);try{const e=await this._httpClient.post(s,{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.useStatefulReconnect&&!0!==this._options._useStatefulReconnect?Promise.reject(new R("Client didn't negotiate Stateful Reconnect but the server did.")):n}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof k&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(r.Error,t),Promise.reject(new R(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,n,o,s){let i=this._createConnectUrl(e,o.connectionToken);if(this._isITransport(n))return this._logger.log(r.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=n,await this._startTransport(i,s),void(this.connectionId=o.connectionId);const a=[],c=o.availableTransports||[];let u=o;for(const o of c){const c=this._resolveTransportOrError(o,n,s,!0===(null==u?void 0:u.useStatefulReconnect));if(c instanceof Error)a.push(`${o.transport} failed:`),a.push(c);else if(this._isITransport(c)){if(this.transport=c,!u){try{u=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}i=this._createConnectUrl(e,u.connectionToken)}try{return await this._startTransport(i,s),void(this.connectionId=u.connectionId)}catch(e){if(this._logger.log(r.Error,`Failed to start the transport '${o.transport}': ${e}`),u=void 0,a.push(new N(`${o.transport} failed: ${e}`,t[o.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(r.Debug,e),Promise.reject(new b(e))}}}}return a.length>0?Promise.reject(new P(`Unable to connect to the server with any of the available transports. ${a.join(" ")}`,a)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case t.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new Y(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case t.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new X(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case t.LongPolling:return new J(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.features.reconnect?this.transport.onclose=async n=>{let r=!1;if(this.features.reconnect){try{this.features.disconnected(),await this.transport.connect(e,t),await this.features.resend()}catch{r=!0}r&&this._stopConnection(n)}else this._stopConnection(n)}:this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,o,s,i){const a=t[e.transport];if(null==a)return this._logger.log(r.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||!!(t&e)}(o,a))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it was disabled by the client.`),new G(`'${t[a]}' is disabled by the client.`,a);if(!(e.transferFormats.map((e=>n[e])).indexOf(s)>=0))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it does not support the requested transfer format '${n[s]}'.`),new Error(`'${t[a]}' does not support ${n[s]}.`);if(a===t.WebSockets&&!this._options.WebSocket||a===t.ServerSentEvents&&!this._options.EventSource)return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it is not supported in your environment.'`),new I(`'${t[a]}' is not supported in your environment.`,a);this._logger.log(r.Debug,`Selecting transport '${t[a]}'.`);try{return this.features.reconnect=a===t.WebSockets?i:void 0,this._constructTransport(a)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(r.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(r.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(r.Error,`Connection disconnected with error '${e}'.`):this._logger.log(r.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(r.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(r.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(r.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(!p.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(r.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=new URL(e);t.pathname.endsWith("/")?t.pathname+="negotiate":t.pathname+="/negotiate";const n=new URLSearchParams(t.searchParams);return n.has("negotiateVersion")||n.append("negotiateVersion",this._negotiateVersion.toString()),n.has("useStatefulReconnect")?"true"===n.get("useStatefulReconnect")&&(this._options._useStatefulReconnect=!0):!0===this._options._useStatefulReconnect&&n.append("useStatefulReconnect","true"),t.search=n.toString(),t.toString()}}class Z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new ee,this._transportResult=new ee,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new ee),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 ee;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 r=0;for(const t of e)n.set(new Uint8Array(t),r),r+=t.byteLength;return n.buffer}}class ee{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class te{constructor(){this.name="json",this.version=2,this.transferFormat=n.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=h.instance);const n=d.parse(e),s=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case o.Invocation:this._isInvocationMessage(n);break;case o.StreamItem:this._isStreamItemMessage(n);break;case o.Completion:this._isCompletionMessage(n);break;case o.Ping:case o.Close:break;case o.Ack:this._isAckMessage(n);break;case o.Sequence:this._isSequenceMessage(n);break;default:t.log(r.Information,"Unknown message type '"+n.type+"' ignored.");continue}s.push(n)}return s}writeMessage(e){return d.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.")}_isAckMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Ack message.")}_isSequenceMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Sequence message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const ne={trace:r.Trace,debug:r.Debug,info:r.Information,information:r.Information,warn:r.Warning,warning:r.Warning,error:r.Error,critical:r.Critical,none:r.None};class re{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=ne[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new w(t)}else this.logger=new w(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 L(e):this.reconnectPolicy=e:this.reconnectPolicy=new L,this}withServerTimeout(e){return g.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return g.isRequired(e,"milliseconds"),this._keepAliveIntervalInMilliseconds=e,this}withStatefulReconnect(e){return void 0===this.httpConnectionOptions&&(this.httpConnectionOptions={}),this.httpConnectionOptions._useStatefulReconnect=!0,this._statefulReconnectBufferSize=null==e?void 0:e.bufferSize,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 Q(this.url,e);return x.create(t,this.logger||h.instance,this.protocol||new te,this.reconnectPolicy,this._serverTimeoutInMilliseconds,this._keepAliveIntervalInMilliseconds,this._statefulReconnectBufferSize)}}class oe{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 r=16*Math.random();return e>0?(r=(e+r)%16|0,e=Math.floor(e/16)):(r=(t+r)%16|0,t=Math.floor(t/16)),("x"===n?r:3&r|8).toString(16)}))}static GenerateMd5(e){let t="0123456789abcdef";function n(e){let n,r="";for(n=0;n<=3;n++)r+=t.charAt(e>>8*n+4&15)+t.charAt(e>>8*n&15);return r}function r(e,t){let n=(65535&e)+(65535&t);return(e>>16)+(t>>16)+(n>>16)<<16|65535&n}function o(e,t,n,o,s,i){return r(function(e,t){return e<<t|e>>>32-t}(r(r(t,e),r(o,i)),s),n)}function s(e,t,n,r,s,i,a){return o(t&n|~t&r,e,t,s,i,a)}function i(e,t,n,r,s,i,a){return o(t&r|n&~r,e,t,s,i,a)}function a(e,t,n,r,s,i,a){return o(t^n^r,e,t,s,i,a)}function c(e,t,n,r,s,i,a){return o(n^(t|~r),e,t,s,i,a)}let u,l,d,h,g,p=function(e){let t,n=1+(e.length+8>>6),r=new Array(16*n);for(t=0;t<16*n;t++)r[t]=0;for(t=0;t<e.length;t++)r[t>>2]|=e.charCodeAt(t)<<t%4*8;return r[t>>2]|=128<<t%4*8,r[16*n-2]=8*e.length,r}(""+e),f=1732584193,v=-271733879,y=-1732584194,m=271733878;for(u=0;u<p.length;u+=16)l=f,d=v,h=y,g=m,f=s(f,v,y,m,p[u+0],7,-680876936),m=s(m,f,v,y,p[u+1],12,-389564586),y=s(y,m,f,v,p[u+2],17,606105819),v=s(v,y,m,f,p[u+3],22,-1044525330),f=s(f,v,y,m,p[u+4],7,-176418897),m=s(m,f,v,y,p[u+5],12,1200080426),y=s(y,m,f,v,p[u+6],17,-1473231341),v=s(v,y,m,f,p[u+7],22,-45705983),f=s(f,v,y,m,p[u+8],7,1770035416),m=s(m,f,v,y,p[u+9],12,-1958414417),y=s(y,m,f,v,p[u+10],17,-42063),v=s(v,y,m,f,p[u+11],22,-1990404162),f=s(f,v,y,m,p[u+12],7,1804603682),m=s(m,f,v,y,p[u+13],12,-40341101),y=s(y,m,f,v,p[u+14],17,-1502002290),v=s(v,y,m,f,p[u+15],22,1236535329),f=i(f,v,y,m,p[u+1],5,-165796510),m=i(m,f,v,y,p[u+6],9,-1069501632),y=i(y,m,f,v,p[u+11],14,643717713),v=i(v,y,m,f,p[u+0],20,-373897302),f=i(f,v,y,m,p[u+5],5,-701558691),m=i(m,f,v,y,p[u+10],9,38016083),y=i(y,m,f,v,p[u+15],14,-660478335),v=i(v,y,m,f,p[u+4],20,-405537848),f=i(f,v,y,m,p[u+9],5,568446438),m=i(m,f,v,y,p[u+14],9,-1019803690),y=i(y,m,f,v,p[u+3],14,-187363961),v=i(v,y,m,f,p[u+8],20,1163531501),f=i(f,v,y,m,p[u+13],5,-1444681467),m=i(m,f,v,y,p[u+2],9,-51403784),y=i(y,m,f,v,p[u+7],14,1735328473),v=i(v,y,m,f,p[u+12],20,-1926607734),f=a(f,v,y,m,p[u+5],4,-378558),m=a(m,f,v,y,p[u+8],11,-2022574463),y=a(y,m,f,v,p[u+11],16,1839030562),v=a(v,y,m,f,p[u+14],23,-35309556),f=a(f,v,y,m,p[u+1],4,-1530992060),m=a(m,f,v,y,p[u+4],11,1272893353),y=a(y,m,f,v,p[u+7],16,-155497632),v=a(v,y,m,f,p[u+10],23,-1094730640),f=a(f,v,y,m,p[u+13],4,681279174),m=a(m,f,v,y,p[u+0],11,-358537222),y=a(y,m,f,v,p[u+3],16,-722521979),v=a(v,y,m,f,p[u+6],23,76029189),f=a(f,v,y,m,p[u+9],4,-640364487),m=a(m,f,v,y,p[u+12],11,-421815835),y=a(y,m,f,v,p[u+15],16,530742520),v=a(v,y,m,f,p[u+2],23,-995338651),f=c(f,v,y,m,p[u+0],6,-198630844),m=c(m,f,v,y,p[u+7],10,1126891415),y=c(y,m,f,v,p[u+14],15,-1416354905),v=c(v,y,m,f,p[u+5],21,-57434055),f=c(f,v,y,m,p[u+12],6,1700485571),m=c(m,f,v,y,p[u+3],10,-1894986606),y=c(y,m,f,v,p[u+10],15,-1051523),v=c(v,y,m,f,p[u+1],21,-2054922799),f=c(f,v,y,m,p[u+8],6,1873313359),m=c(m,f,v,y,p[u+15],10,-30611744),y=c(y,m,f,v,p[u+6],15,-1560198380),v=c(v,y,m,f,p[u+13],21,1309151649),f=c(f,v,y,m,p[u+4],6,-145523070),m=c(m,f,v,y,p[u+11],10,-1120210379),y=c(y,m,f,v,p[u+2],15,718787259),v=c(v,y,m,f,p[u+9],21,-343485551),f=r(f,l),v=r(v,d),y=r(y,h),m=r(m,g);return n(f)+n(v)+n(y)+n(m)}}class se{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function ie(e){return new Map(Object.entries(e))}class ae{constructor(){this.TransactionId=oe.GenerateUUID()}}var ce,ue,le,de,he,ge,pe,fe,ve,ye,me,we,Se,Ae,_e;(Se=ce||(ce={}))[Se.OK=0]="OK",Se[Se.UnknownError=1]="UnknownError",Se[Se.FatalError=2]="FatalError",Se[Se.WrongData=3]="WrongData",Se[Se.ResourceDoesNotExists=4]="ResourceDoesNotExists",Se[Se.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",Se[Se.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",Se[Se.OperationNotPermitted=7]="OperationNotPermitted",Se[Se.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",Se[Se.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",Se[Se.Error=10]="Error",Se[Se.NoData=11]="NoData",Se[Se.NotSupportedMethod=12]="NotSupportedMethod",Se[Se.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",Se[Se.MultiDataResponseStart=14]="MultiDataResponseStart",Se[Se.MultiDataResponse=15]="MultiDataResponse",Se[Se.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"}(ue||(ue={}));class Ce{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"}(le||(le={})),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"}(de||(de={})),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",e[e.ConnectedAndAuthorized=7]="ConnectedAndAuthorized"}(he||(he={}));class Te extends Error{constructor(e){super(e),this.name="StreamError"}}class De{constructor(){this._log=Qv.Get(c.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)}}))}}!function(e){e.CannotExportConfiguration="CannotExportConfiguration"}(ge||(ge={})),(_e=pe||(pe={}))[_e.Any=0]="Any",_e[_e.Guest=10]="Guest",_e[_e.Standard=20]="Standard",_e[_e.Admin=30]="Admin",_e[_e.Installator=40]="Installator",_e[_e.Support=50]="Support",(Ae=fe||(fe={}))[Ae.Unknown=0]="Unknown",Ae[Ae.Men=1]="Men",Ae[Ae.Woman=2]="Woman",Ae[Ae.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(ve||(ve={})),function(e){e[e.Unknown=0]="Unknown",e[e.WrongAuthData=1]="WrongAuthData",e[e.NoResponseFromController=2]="NoResponseFromController",e[e.AuthDisabled=3]="AuthDisabled",e[e.MethodNotSupported=4]="MethodNotSupported"}(ye||(ye={}));class ke{constructor(e,t){this._type=me.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 Ee{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.ResourceDoesNotExists=-6]="ResourceDoesNotExists",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"}(me||(me={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(we||(we={}));class be{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=we.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 Ie=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ge{constructor(){this._imageExistsCaseNumber=0,this._connection=Qv.Get(_t.ServiceName),this._logger=Qv.Get(c.ServiceName)}GetServiceName(){return Ge.ServiceName}AddPictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t,n;try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ge.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ce.WrongData;let r=new Image;const o=new Promise(((t,n)=>{r.src=e.Base64Image,r.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield o))return this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ce.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ce.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot add picture - Guid must be empty."),ce.WrongData;const s=new Re;s.Guid=oe.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 Oe(s.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(Ge.ServiceName,"Cannot add picture - unknown error!"),ce.UnknownError;if(i.Status==ce.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new xe(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(Ge.ServiceName,"Cannot add picture - unknown error!"),ce.UnknownError):e.Status}return i.Status==ce.OK?(this._logger.Warning(Ge.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ce.UnknownError):(this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot get current picture status."),ce.Error)}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot add picture! ${e}`),ce.FatalError}}))}EditPictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t,n,r,o;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - guid is empty."),ce.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ce.WrongData;let s=new Image;const i=new Promise(((t,n)=>{s.src=e.Base64Image,s.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield i))return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ce.WrongData;if(0===s.height||0===s.width)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ce.WrongData;const a=new Re;a.DateTime=(new Date).toISOString(),a.ImageType=e.ImageType,a.Base64Image=e.Base64Image,a.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?a.OwnerGuid=e.OwnerGuid:a.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const c=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Oe(a.Guid),8e3,!1);if(null===(n=u.Log)||void 0===n||n.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==c||null==c.Status)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - unknown error!"),ce.UnknownError;if(c.Status==ce.ResourceDoesNotExists)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - picture not exists."),ce.OperationNotPermitted;if(c.Status==ce.OK){const e=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new xe(a),8e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(Ge.ServiceName,"Cannot edit picture - unknown error!"),ce.UnknownError):e.Status}return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot get current picture status."),ce.Error}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot edit picture! ${e}`),ce.FatalError}}))}DeletePictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t,n;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot delete picture - guid is empty."),ce.WrongData;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Fe(e.Guid),8e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DeletePictureAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==r||null==r.Status?(this._logger.Error(Ge.ServiceName,"Cannot delete picture - unknown error!"),ce.UnknownError):r.Status}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot delete picture! ${e}`),ce.FatalError}}))}GetPicturesInfoAsync(){return Ie(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ue,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ge.ServiceName,"Cannot get pictures info - unknown error!"),new Ee(ce.UnknownError,"NoDataInResult")):t.Status!=ce.OK?(this._logger.Error(Ge.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Ee(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ge.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Ee(ce.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Pe;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(Ge.ServiceName,`Cannot get picture info! ${e}`),new Ee(ce.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Oe(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(Ge.ServiceName,"Cannot get picture - unknown error!"),new Ee(ce.UnknownError,"NoDataInResult");switch(n.Status){case ce.ResourceDoesNotExists:return new Ee(ce.ResourceDoesNotExists,"PictureNotFound");case ce.OK:if(null==n.Data)return new Ee(ce.Error,"RespondedWithOKButNoData");const e=new Ne;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 Ee(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot get picture! ${e}`),new Ee(ce.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){return Ie(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Me,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ge.ServiceName,"Cannot get pictures - unknown error!"),new Ee(ce.UnknownError,"NoDataInResult")):t.Status!=ce.OK?(this._logger.Error(Ge.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Ee(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ge.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Ee(ce.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ne;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(Ge.ServiceName,`Cannot get pictures! ${e}`),new Ee(ce.FatalError,"ExceptionOccurred")}}))}}Ge.ServiceName="PictureService";class Ne extends be{set DateTime(e){this._dateTime=e}}class Re{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=we.Device,this.DateTime=""}}class Pe{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 Oe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Get,this.Data=e}}class Ue extends ae{constructor(){super(),this.Resource="/pictures/info",this.Method=ue.Get}}class Me extends ae{constructor(){super(),this.Resource="/pictures/list",this.Method=ue.Get}}class xe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Put,this.Data=e}}class Fe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Delete,this.Data=e}}class Le{constructor(){this._log=Qv.Get(c.ServiceName),Le._localStorageService=Qv.Get(l.ServiceName)}GetServiceName(){return Le.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ce.OK&&(this._log.Debug(Le.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Le._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Le._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Le.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Le._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Le.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Le._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Le.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Le._localStorageService=null,Le.ServiceName="WebApiCacheService";var Be=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class We{constructor(){this._connection=null,this._connection=Qv.Get(_t.ServiceName),this._pictureService=Qv.Get(Ge.ServiceName),this._sessionService=Qv.Get(Je.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 pe.Support:return n===pe.Support;case pe.Installator:return n>=pe.Installator;case pe.Admin:default:return n>=pe.Admin}}GetServiceName(){return We.ServiceName}GetUsersAsync(){return Be(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new He,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ce.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new je;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)==ce.NoData)return Promise.resolve([]);throw null===(t=u.Log)||void 0===t||t.Debug(We.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){return Be(this,void 0,void 0,(function*(){var t,n;if(""===e)return Promise.resolve(null);null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new $e(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ce.OK)return null===(n=u.Log)||void 0===n||n.Debug(We.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const o=new je;return o.AccessLevel=r.Data.AccessLevel,o.Email=r.Data.Email,o.Gender=r.Data.Gender,o.Guid=r.Data.Guid,o.IsAccountOnline=r.Data.IsAccountOnline,o.Name=r.Data.Name,o.IsActive=r.Data.IsActive,o.IsBanned=r.Data.IsBanned,o.Phone=r.Data.Phone,o.Surname=r.Data.Surname,o}))}CreateUserAsync(e,t){return Be(this,void 0,void 0,(function*(){var n;if(null!=e.Guid&&""!=e.Guid)return new Ee(ce.WrongData,"GuidMustBeEmpty");const r=new qe;r.Name=e.Name.trim(),r.Surname=e.Surname.trim(),r.Email=e.Email.trim(),r.Password=t.trim(),r.Phone=e.Phone.trim(),r.Gender=e.Gender,r.AccessLevel=e.AccessLevel;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ve(r),2e4,!1);return Qv.Get(Le.ServiceName).ClearCache(),null==o||null==o.Status?new Ee(ce.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Ee(o.Status,o.Data))}))}UpdateUserAsync(e){return Be(this,void 0,void 0,(function*(){var t;if(null==e.Guid||""==e.Guid)return new Ee(ce.WrongData,"GuidCannotBeEmpty");const n=new qe;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 r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ve(n),2e4,!1);return Qv.Get(Le.ServiceName).ClearCache(),null==r||null==r.Status?new Ee(ce.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Ee(r.Status,r.Data))}))}ChangePasswordAsync(e,t){return Be(this,void 0,void 0,(function*(){var n;if(null==e.Guid||""==e.Guid)return new Ee(ce.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Ee(ce.ResourceIsNotAvailable,"CannotGetUser");const o=new qe;o.Guid=e.Guid,o.Password=t,o.AccessLevel=r.AccessLevel,o.Email=r.Email;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ve(o),2e4,!1);return null==s||null==s.Status?new Ee(ce.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Ee(s.Status,s.Data))}))}DeleteUserAsync(e){return Be(this,void 0,void 0,(function*(){var t,n;if(""===e)return ce.WrongData;null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ke(e),2e4,!1);return Qv.Get(Le.ServiceName).ClearCache(),null==r||null==r.Status?ce.FatalError:(r.Status!=ce.OK&&(null===(n=u.Log)||void 0===n||n.Debug(We.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}))}GetUserProfilePictureAsync(e){return Be(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ee(ce.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 Qv.Get(Le.ServiceName).ClearCache(),null!=e.Type?t:e}return new Ee(ce.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return Be(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ee(ce.WrongData,"GuidCannotBeEmpty");let n=new be;n.ImageType=we.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(Qv.Get(Le.ServiceName).ClearCache(),r.Type==ce.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ce.OK?new Ee(ce.OK,"PictureSet"):new Ee(e,"PictureServiceError")}if(null!=r.Type)return new Ee(ce.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ce.OK?new Ee(ce.OK,"PictureSet"):new Ee(e,"PictureServiceError")}}))}}We.ServiceName="UsersService";class $e extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Get,this.Data=e}}class qe{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=fe.Unknown,this.AccessLevel=pe.Any}}class Ve extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Put,this.Data=e}}class He extends ae{constructor(){super(),this.Resource="/users/list",this.Method=ue.Get}}class Ke extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Delete,this.Data=e}}class je{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=fe.Unknown,this._accessLevel=pe.Any,this._localization=ve.En_Us,this._softwareVersion=""}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}get SoftwareVersion(){return this._softwareVersion}set SoftwareVersion(e){this._softwareVersion=e}GetUserProfilePictureAsync(){return Qv.Get(We.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return Qv.Get(We.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var ze=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Je{constructor(){this._onUserLoggedInEvent=new a,this._onUserLoggedOutEvent=new a,this._email="",this._password="",this._authToken="",this._loginTaskCompletionSource=this.CreateSessionCompletionSourceAsync(),this._alreadySubsribedToNetworkEvents=!1,this._user=null}CreateSessionCompletionSourceAsync(){return ze(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(Je.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{this.OnUserLoggedInEvent().Subscribe((t=>{var n;null===(n=u.Log)||void 0===n||n.Debug(Je.ServiceName,`Logged in as ${t.Name}, completing CreateSessionCompletionSourceAsync()`),e()}))}))}))}RestoreSessionAsync(){return ze(this,void 0,void 0,(function*(){var e,t;if(null===(e=u.Log)||void 0===e||e.Debug(Je.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0===this._user||null===this._user)return;const n=Qv.Get(_t.ServiceName),r=n.GetAuthorizationInfo();null!==r?(yield n.AuthorizeAsync(r),yield this.UserLogInAsync(this._email,this._password)):null===(t=u.Log)||void 0===t||t.Error(Je.ServiceName,"RestoreSessionAsync failed, no authorization info")}))}WaitForSessionCreationAsync(){return ze(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){return ze(this,void 0,void 0,(function*(){var e,t,n=new ae;n.Resource="/users/user/logout",n.Method=ue.Put,this._email="",this._password="",(yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ce.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=u.Log)||void 0===e||e.Debug(Je.ServiceName,"User has been logged out.")):null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return ze(this,void 0,void 0,(function*(){switch(e){case he.Disconnected:case he.Failed:break;case he.Connected:Qv.Get(Je.ServiceName).RestoreSessionAsync()}}))}AuthorizeAppAsync(e){return ze(this,void 0,void 0,(function*(){var t,n,r,o,s=Qv.Get(_t.ServiceName);const i=yield s.SendAndWaitForResponseAsync(new Ye(e),2e4,!1);if(i.Status==ce.OK&&null!=i.Data){this._authToken=e;var a=new je;return this._user=a,a.AccessLevel=i.Data.AccessLevel,a.Email=i.Data.Email,this._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,a.SoftwareVersion=i.Data.SoftwareVersion,void 0!==i.Data.ConfigurationTime&&(it.ConfigurationTimeRetrieved=new Date(i.Data.ConfigurationTime)),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,s.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged),Qv.Get(_t.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>ze(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user)}))))),null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,`Did logging in succeded?: ${i.Status==ce.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return i.Status===ce.OperationNotPermitted?(null===(n=u.Log)||void 0===n||n.Debug(Je.ServiceName,`App login response: ${i.Data}`),ye.AuthDisabled):i.Status===ce.ResourceDoesNotExists?(null===(r=u.Log)||void 0===r||r.Debug(Je.ServiceName,`App login response: ${i.Data}`),ye.MethodNotSupported):(null===(o=u.Log)||void 0===o||o.Debug(Je.ServiceName,`App login response: ${i.Data}`),ye.WrongAuthData)}))}UserLogInAsync(e,t){return ze(this,void 0,void 0,(function*(){var n,r,o=Qv.Get(_t.ServiceName);const s=yield o.SendAndWaitForResponseAsync(new Qe(e,t),2e4,!1);if(s.Status==ce.OK&&null!=s.Data){this._email=e,this._password=t;var i=new je;return this._user=i,i.AccessLevel=s.Data.AccessLevel,i.Email=s.Data.Email,i.Gender=s.Data.Gender,i.Guid=s.Data.Guid,i.IsAccountOnline=s.Data.IsAccountOnline,i.Name=s.Data.Name,i.IsActive=s.Data.IsActive,i.IsBanned=s.Data.IsBanned,i.Phone=s.Data.Phone,i.Surname=s.Data.Surname,i.SoftwareVersion=s.Data.SoftwareVersion,void 0!==s.Data.ConfigurationTime&&(it.ConfigurationTimeRetrieved=new Date(s.Data.ConfigurationTime)),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,o.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged),Qv.Get(_t.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>ze(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user)}))))),null===(n=u.Log)||void 0===n||n.Debug(Je.ServiceName,`Did logging in succeded?: ${s.Status==ce.OK}`),this._onUserLoggedInEvent.Invoke(this._user),i}return null===(r=u.Log)||void 0===r||r.Debug(Je.ServiceName,`User login response: ${s.Data}`),ye.WrongAuthData}))}GetServiceName(){return Je.ServiceName}}Je.ServiceName="SessionService";class Xe{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class Ye extends ae{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=ue.Put}}class Qe extends ae{constructor(e,t){super(),this.Data=new Xe(e,t),this.Resource="/users/user/login",this.Method=ue.Put}}class Ze{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 et=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class tt{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new Ze(1)}GetServiceName(){return tt.ServiceName}GetExtensionsInfoAsync(e){return et(this,arguments,void 0,(function*(e,t=!1){var n;null===(n=u.Log)||void 0===n||n.Debug(tt.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);var r=yield this._semaphore.AcquireAsync();if(this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync()),r.Release(),0==[...this._extensionInfoCache.values()].length)return[];if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new ot("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e){return et(this,arguments,void 0,(function*(e,t=!1,n=!1){var r;if(null===(r=u.Log)||void 0===r||r.Debug(tt.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 ot("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 ot("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return et(this,void 0,void 0,(function*(){const e=new nt,t=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(e,16e3,!0);if(null==t||null==t.Status)throw new ot("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ce.OK)throw new ot(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new ot("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 et(this,void 0,void 0,(function*(){var e;const t=new rt,n=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(t,16e3,!0);if(null==n||null==n.Status)throw new ot("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(n.Status){case ce.OK:if(null==n.Data)throw new ot("Cannot get ProtocolInfo from controller, controller response does not contain data!");n.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ce.ResourceDoesNotExists:null===(e=u.Log)||void 0===e||e.Debug(tt.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new ot(`Cannot get ProtocolInfo from controller! Response status: ${n.Status}`)}}))}}tt.ServiceName="StatisticsInfoService";class nt extends ae{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ue.Get}}class rt extends ae{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ue.Get}}class ot extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var st=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class it{GetServiceName(){return it.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new De,this._onExitedConfigurationEvent=new De,this._onConfigurationTimeCheckedEvent=new a,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{Qv.Get(Je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>st(this,void 0,void 0,(function*(){null!==it.ConfigurationTimeRetrieved?this._didConfigurationChange=yield this.CheckIfConfigurationTimeHasChangedAsync(it.ConfigurationTimeRetrieved):this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),this._didConfigurationChange&&Qv.Get(Le.ServiceName).ClearCache(),e()}))))})),this._connection=Qv.Get(_t.ServiceName),this._session=Qv.Get(Je.ServiceName),this._localStorage=Qv.Get(l.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke()}))}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,o;const s=null!==(o=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==o?o:null;if(!s||!s.includes("."))return!1;const i=s.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}ImportControllerConfigurationAsync(e){return st(this,void 0,void 0,(function*(){var t,n,r;let o=yield e.text(),s=this.SplitStringBySize(o),i=new at("");i.Status=ce.MultiDataResponseStart;let a=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(i,6e3,!1);if(void 0===a||(null==a?void 0:a.Status)!=ce.OK)return ce.Error;for(const e of s){let t=new at(e);t.Status=ce.MultiDataResponse;let r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(t,6e3,!1);if(void 0===r||(null==r?void 0:r.Status)!=ce.OK)return ce.Error}i.Status=ce.MultiDataResponseStop;let c=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(i,12e4,!1);return void 0===c||(null==c?void 0:c.Status)!=ce.OK?ce.Error:ce.OK}))}SplitStringBySize(e,t=1e5){const n=Math.floor(t/2),r=[];let o=0;for(;o<e.length;){let s=e.slice(o,o+n);for(;new Blob([s]).size>t;)s=s.slice(0,-1);r.push(s),o+=s.length}return r}GetControllerSystemTimeAsync(){return st(this,void 0,void 0,(function*(){var e,t;try{var n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ft,8e3,!1);return null==n||null==n.Status?ce.Error:n.Status!=ce.OK?n.Status:null==n.Data?ce.ResourceIsNotAvailable:new Date(n.Data)}catch(e){return null===(t=u.Log)||void 0===t||t.Error(it.ServiceName,`Cannot get current controller time! ${e}`),ce.FatalError}}))}SetControllerSystemTimeAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{var r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new vt(e.toISOString()),8e3,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(e){return null===(n=u.Log)||void 0===n||n.Error(it.ServiceName,`Cannot set current controller time! ${e}`),ce.FatalError}}))}StartNtpTimeSynchronizationAsync(){return st(this,void 0,void 0,(function*(){var e,t;try{var n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new yt,8e3,!1);return null==n||null==n.Status?ce.Error:n.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(it.ServiceName,`Cannot set current controller time! ${e}`),ce.FatalError}}))}FactoryResetAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{Qv.Get(Le.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new lt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=300,n=0,r=100/t,o=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Qv.Get(Le.ServiceName).ClearCache(),clearInterval(o),ce.OK}return r}catch(e){return ce.FatalError}}))}RollbackLastUpdateAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{Qv.Get(Le.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new dt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=420,n=0,r=100/t,o=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Qv.Get(Le.ServiceName).ClearCache(),clearInterval(o),ce.OK}return r}catch(e){return ce.FatalError}}))}RestartControllerAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{Qv.Get(Le.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ut,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=240,n=0,r=100/t,o=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Qv.Get(Le.ServiceName).ClearCache(),clearInterval(o),ce.OK}return r}catch(e){return ce.FatalError}}))}DidCofigurationChangeAsync(){return st(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(){return st(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,Qv.Get(Le.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ht,2e4,!1)}))}ExitConfigurationModeAsync(){return st(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,Qv.Get(Le.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new gt,2e4,!1),this._didConfigurationChange=!0,Qv.Get(Le.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._didConfigurationChange=!0,this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){return st(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new pt,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ce.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return st(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),Qv.Get(Le.ServiceName).ClearCache(),!0)}))}CheckIfConfigurationTimeHasChangedAsync(e){return st(this,void 0,void 0,(function*(){return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),Qv.Get(Le.ServiceName).ClearCache(),!0)}))}CanExportOrImportControllerConfigurationAsync(){return st(this,void 0,void 0,(function*(){try{let e=yield Qv.Get(tt.ServiceName).GetExtensionsInfoAsync(),t=Qv.Get(Je.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=pe.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){return st(this,void 0,void 0,(function*(){var e;let t=[],n=null;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndHandleResponseAsync(new ct,3e4,(e=>{switch(e.Status){case ce.MultiDataResponseStart:break;case ce.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);break;case ce.MultiDataResponseStop:break;case ce.Error:case ce.FatalError:n=new Ee(ge.CannotExportConfiguration,"Cannot export configuration! Controller returned error!")}}),!0);let r=JSON.stringify(JSON.parse(t.join("")),null,2);return console.log(r),null!=n?n:Qv.ExportStringAsFileToDownload(this.GetCurrentTimestampedFilename(),r)}))}GetCurrentTimestampedFilename(){var e,t;const n=new Date,r=n.getHours().toString().padStart(2,"0"),o=n.getMinutes().toString().padStart(2,"0"),s=n.getDate().toString().padStart(2,"0"),i=(n.getMonth()+1).toString().padStart(2,"0"),a=n.getFullYear().toString();return`${null===(t=null===(e=this._connection)||void 0===e?void 0:e.GetAuthorizationInfo())||void 0===t?void 0:t.SerialNumber}_${r}-${o}-${s}-${i}-${a}-config.cexp`}}it.ServiceName="ControllerConfigurationService",it.ConfigurationTimeRetrieved=null;class at extends ae{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=ue.Put,this.Data=e}}class ct extends ae{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=ue.Get}}class ut extends ae{constructor(){super(),this.Resource="/controller/restart",this.Method=ue.Post}}class lt extends ae{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ue.Post}}class dt extends ae{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ue.Post}}class ht extends ae{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ue.Put}}class gt extends ae{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ue.Put}}class pt extends ae{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ue.Get}}class ft extends ae{constructor(){super(),this.Resource="/system/time",this.Method=ue.Get}}class vt extends ae{constructor(e){super(),this.Resource="/system/time",this.Method=ue.Put,this.Data=e}}class yt extends ae{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=ue.Put}}var mt=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class wt{nextRetryDelayInMilliseconds(){return 1e3}}const St=[t.WebSockets,t.ServerSentEvents,t.LongPolling];class At{constructor(){this._log=Qv.Get(c.ServiceName)}log(e,t){if(!(e<_t.SignalRLogLevel))switch(t=`[SignalR] ${t}`,e){case r.Critical:case r.Error:this._log.Error(t);break;case r.Warning:this._log.Warning(t);break;case r.Information:this._log.Info(t);break;default:this._log.Debug(t)}}}class _t{constructor(){this._connectTask=null,this._pingTimerId=null,this._consecutivePingFailures=0,this._disconnectedOnPurpose=!1,this._address="packets-broker1.tr7.pl",this._serversBrokerAddress="https://servers-broker.tr7.pl",this._serversBrokerAddressList=["https://servers-broker.tr7.pl","https://broker.tr7.pl","https://dev-broker.tr7.pl"],this._allBrokersChecked=!1,this._packetsBrokerServers=["packets-broker1.tr7.pl","packets-broker2.tr7.pl"],this._lastReceivedPacket=Date.now(),this._everConnected=!1,this._pendingRequests=new Map,this._log=Qv.Get(c.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._dataReceivedEvent=new a,this._pongReceivedEvent=new De,this._authorizationReceivedEvent=new a,this._registrationReceivedEvent=new a,this._streamStartedEvent=new a,this._connectionStateChangedEvent=new a,this._errorOccuredEvent=new a,this._tryReconnect=()=>{navigator.onLine&&this.validateConnectionToController().then((e=>{e||(this._log.Debug(_t.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._onVisibility=()=>{"visible"===document.visibilityState&&(this._log.Debug(_t.ServiceName,"Page visible → connection check"),this.validateConnectionToController().then((e=>{e||(this._log.Debug(_t.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())})))},this._onHidden=()=>{},this._onVisible=()=>{this.validateConnectionToController().then((e=>{e||(this._log.Debug(_t.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))}}GetServiceName(){return _t.ServiceName}GetAuthorizationInfo(){return this._serialId&&this._PIN?new Ce(this._serialId,this._PIN):null}GetControllerSerialNumber(){return this._serialId}GetControllerPin(){return this._PIN}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._address=e}EnablePacketsLogging(){window.packets=!0}DisablePacketsLogging(){window.packets=!1}SubscribeTo(e,t){const n=n=>{n.Resource===e&&t(n)};return this._dataReceivedEvent.Subscribe(n),()=>this._dataReceivedEvent.Unsubscribe(n)}GetServerAddressAsync(){return mt(this,void 0,void 0,(function*(){if(!this._serialId)return this._log.Warning(_t.ServiceName,"GetServerAddressAsync() – serialId nieustawiony"),null;const e=`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`;try{const t=yield fetch(e);switch(t.status){case 200:{const e=(yield t.text()).trim();return e?(this._log.Debug(_t.ServiceName,`Broker address resolved: ${e}`),e):(this._log.Warning(_t.ServiceName,"Broker returned empty address"),null)}case 204:return this._allBrokersChecked?(this._log.Error(_t.ServiceName,"All brokers checkt but controller not found! Controller probably offline!"),null):(this._log.Warning(_t.ServiceName,`Broker controller ${this._serversBrokerAddress} returned 204 (no content) – controller not found on given server`),yield this.rotateServersBroker(),this.GetServerAddressAsync());default:return this._log.Warning(_t.ServiceName,`GetServerAddressAsync() – HTTP ${t.status}`),null}}catch(e){return this._log.Error(_t.ServiceName,String(e)),null}}))}rotateServersBroker(){return mt(this,void 0,void 0,(function*(){const e=this._serversBrokerAddressList.indexOf(this._serversBrokerAddress),t=e+1<this._serversBrokerAddressList.length?e+1:0;this._serversBrokerAddress=this._serversBrokerAddressList[t],this._allBrokersChecked=0===t,this._log.Info(_t.ServiceName,`Switching servers‑broker to: ${this._serversBrokerAddress}`)}))}ConnectAsync(e){return mt(this,void 0,void 0,(function*(){return this._address=e,this.serialisedConnect()}))}ConnectAndAuthorizeAsync(e){return mt(this,void 0,void 0,(function*(){this._serialId=e.serialNumber,this._PIN=e.pin,Qv.WorksInContextOf=this._serialId;let t=yield this.GetServerAddressAsync();if(t&&(this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===de.Connected&&(yield this.AuthorizeAsync(e))))return de.Connected;for(const t of this._packetsBrokerServers)if(this._log.Info(_t.ServiceName,`Fallback broker: ${t}`),this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===de.Connected&&(yield this.AuthorizeAsync(e)))return de.Connected;return de.FailedToConnect}))}AuthorizeAsync(e){return mt(this,void 0,void 0,(function*(){return new Promise((t=>mt(this,void 0,void 0,(function*(){var n;const r=window.setTimeout((()=>{this._authorizationReceivedEvent.Unsubscribe(o),t(!1)}),2e3),o=e=>{clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(o),this._log.Debug(_t.ServiceName,`Authorization → ${e}`),e&&this._connectionStateChangedEvent.Invoke(he.ConnectedAndAuthorized),t(e)};this._authorizationReceivedEvent.Subscribe(o),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)}))))}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===s.Connected}DisconnectAsync(){return mt(this,void 0,void 0,(function*(){var e;this._disconnectedOnPurpose=!0,this._log.Debug(_t.ServiceName,"Disconnecting..."),yield null===(e=this._connection)||void 0===e?void 0:e.stop(),this.cleanup()}))}SendAsync(e){return mt(this,arguments,void 0,(function*(e,t=!1){if(!this.IsConnected())throw new Error("Not connected");const n=!0===window.packets;(n||t)&&this._log.Debug(_t.ServiceName,`⇢ ${e.Resource} ${e.Method} ${e.TransactionId}`+(n?`\n${JSON.stringify(e,null,2)}`:""));try{return yield this._connection.invoke("SendTo",this._serialId,e),!0}catch(e){return this._log.Error(_t.ServiceName,String(e)),!1}}))}SendAndWaitForResponseAsync(e,t,n){return mt(this,arguments,void 0,(function*(e,t,n,r=!0){var o,s,i;if(e.Method===ue.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.DidCofigurationChangeAsync())){const t=null===(s=this._cache)||void 0===s?void 0:s.GetCache(e);if(t)return t}if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(i=this._session)||void 0===i?void 0:i.WaitForSessionCreationAsync()),new Promise(((o,s)=>mt(this,void 0,void 0,(function*(){const i=window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(a),this._pendingRequests.delete(e.TransactionId),s(new E("Response timeout"))}),t),a=s=>{var c,u;s.TransactionId===e.TransactionId&&(clearTimeout(i),this._dataReceivedEvent.Unsubscribe(a),this._pendingRequests.delete(e.TransactionId),e.Method===ue.Get&&n&&(null===(c=this._cache)||void 0===c||c.Cache(s)),n||s.Status!==ce.UserIsNotLoggedIn?o(s):null===(u=this._session)||void 0===u||u.RestoreSessionAsync().then((()=>o(this.SendAndWaitForResponseAsync(e,t,n,r)))))};this._dataReceivedEvent.Subscribe(a),this._pendingRequests.set(e.TransactionId,{resolve:e=>o(e),reject:s,timeoutId:i}),(yield this.SendAsync(e,r))||(clearTimeout(i),this._dataReceivedEvent.Unsubscribe(a),this._pendingRequests.delete(e.TransactionId),s(new Error("Failed to send request")))}))))}))}SendAndHandleResponseAsync(e,t,n){return mt(this,arguments,void 0,(function*(e,t,n,r=!0){var o;if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(o=this._session)||void 0===o?void 0:o.WaitForSessionCreationAsync()),new Promise(((o,s)=>mt(this,void 0,void 0,(function*(){const i=()=>window.setTimeout((()=>{c(),s(new E("MultiDataResponse timeout"))}),t);let a=i();const c=()=>{clearTimeout(a),this._dataReceivedEvent.Unsubscribe(u),this._pendingRequests.delete(e.TransactionId)},u=t=>{if(t.TransactionId===e.TransactionId)switch(clearTimeout(a),t.Status){case ce.MultiDataResponseStart:case ce.MultiDataResponse:n(t),a=i();break;case ce.MultiDataResponseStop:case ce.OK:n(t),c(),o();break;default:c(),s(new Error(`Unexpected status ${t.Status}`))}};this._dataReceivedEvent.Subscribe(u),this._pendingRequests.set(e.TransactionId,{resolve:()=>o(),reject:s,timeoutId:a}),(yield this.SendAsync(e,r))||(c(),s(new Error("Failed to send request")))}))))}))}SendAndHandleStreamAsync(e,t){return mt(this,arguments,void 0,(function*(e,t,n=!0){var r;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,o)=>mt(this,void 0,void 0,(function*(){const s=window.setTimeout((()=>{this._streamStartedEvent.Unsubscribe(i),o(new E("Stream registration timeout"))}),8e3),i=n=>{n===e.TransactionId&&(clearTimeout(s),this._streamStartedEvent.Unsubscribe(i),this._connection.stream("WatchStream",n).subscribe({next:e=>t.Next(e),complete:()=>{t.Complete(),r()},error:e=>{t.Error(e),o(new Te(String(e)))}}))};this._streamStartedEvent.Subscribe(i),(yield this.SendAsync(e,n))||(clearTimeout(s),this._streamStartedEvent.Unsubscribe(i),o(new Error("Failed to send request")))}))))}))}PingControllerAsync(){return mt(this,void 0,void 0,(function*(){if(!this.IsConnected())return!1;if(Date.now()-this._lastReceivedPacket<_t.PING_INTERVAL_MS)return!1;const e=new ae;e.Resource="/system/ping",e.Method=ue.Get;try{return yield this.SendAndWaitForResponseAsync(e,2e3,!1,!1),!0}catch(e){return!1}}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}serialisedConnect(){return this._connectTask||(this._connectTask=this.connectCore().finally((()=>this._connectTask=null))),this._connectTask}connectCore(){return mt(this,void 0,void 0,(function*(){var n,o,i,a,c;if(!this._address)return de.ControllerIsNotConnected;if((null===(n=this._connection)||void 0===n?void 0:n.state)===s.Reconnecting){this._log.Info(_t.ServiceName,"Connection is already in reconnecting state - letting automatic reconnect handle it");try{return yield this.waitForReconnection(),this._log.Info(_t.ServiceName,"Automatic reconnect successful"),de.Connected}catch(e){this._log.Warning(_t.ServiceName,`Automatic reconnect failed: ${e} trying to reconnect by creting new connection`)}}(null===(o=this._connection)||void 0===o?void 0:o.state)!=s.Disconnected&&(this._log.Info(_t.ServiceName,"connectCore() was called, but connection curently exists! Disconnecting..."),yield null===(i=this._connection)||void 0===i?void 0:i.stop()),this.initializeServices(),this.cleanup();for(const n of St){var u=(new re).withAutomaticReconnect(new wt).configureLogging(new At).withStatefulReconnect({bufferSize:256e3}).withServerTimeout(_t.SERVER_TIMOUT_MS).withUrl(`https://${this._address}/broker`,{skipNegotiation:n===t.WebSockets,transport:n});this._log.LogLevel===e.Debug&&u.configureLogging(r.Debug),this._connection=u.build(),this.wireConnectionEvents();try{return yield this._connection.start(),this.startPingLoop(),this._connectionStateChangedEvent.Invoke(he.Connected),de.Connected}catch(e){this._log.Warning(_t.ServiceName,`Transport ${t[n]} failed (${null==e?void 0:e.message}).`),yield this._connection.stop().catch((()=>{})),null===(c=(a=this._connection).off)||void 0===c||c.call(a)}}return this._connectionStateChangedEvent.Invoke(he.Failed),de.FailedToConnect}))}waitForReconnection(e=0){return new Promise(((t,n)=>{if(!this._connection||this._connection.state!==s.Reconnecting)return void n(new Error("Connection is not in reconnecting state"));let r;e>0&&(r=window.setTimeout((()=>{this._connectionStateChangedEvent.Unsubscribe(o),n(new Error("Reconnection timeout"))}),e));const o=e=>{e===he.Connected?(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),t()):e!==he.Disconnected&&e!==he.Failed||(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),n(new Error("Connection closed during reconnection")))};this._connectionStateChangedEvent.Subscribe(o),this._connection.state!==s.Reconnecting&&(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),this._connection.state===s.Connected?t():n(new Error(`Connection is in unexpected state: ${this._connection.state}`)))}))}initializeServices(){this._controllerConfiguration=Qv.Get(it.ServiceName),this._cache=Qv.Get(Le.ServiceName),this._session=Qv.Get(Je.ServiceName)}wireConnectionEvents(){this._connection&&(this._connection.on("Pong",(()=>{this._lastReceivedPacket=Date.now(),this._pongReceivedEvent.Invoke()})),this._connection.on("Authorization",(e=>this._authorizationReceivedEvent.Invoke(e))),this._connection.on("Registration",(e=>this._registrationReceivedEvent.Invoke(e))),this._connection.on("SendError",((e,t)=>{e.startsWith("NotAuthorized:")?this.AuthorizeAsync(new Ce(this._serialId,this._PIN)):this._errorOccuredEvent.Invoke([e,t])})),this._connection.on("Data",((e,t)=>{this._lastReceivedPacket=Date.now(),!0===window.packets&&this._log.Debug(_t.ServiceName,`Received: ${JSON.stringify(JSON.parse(t),null,2)}`),this._dataReceivedEvent.Invoke(JSON.parse(t))})),this._connection.onclose((()=>{this.cleanup(),this._connectionStateChangedEvent.Invoke(he.Disconnected)})),this._connection.onreconnecting((()=>this._connectionStateChangedEvent.Invoke(he.Reconnecting))),this._connection.onreconnected((()=>this._connectionStateChangedEvent.Invoke(he.Connected))))}startPingLoop(){null!==this._pingTimerId&&clearInterval(this._pingTimerId),this._pingTimerId=window.setInterval((()=>{this.pingOnce()}),_t.PING_INTERVAL_MS),window.addEventListener("online",this._tryReconnect),window.addEventListener("offline",this._tryReconnect),document.addEventListener("visibilitychange",this._onVisibility,!0),window.addEventListener("pagehide",this._onHidden,!0),window.addEventListener("pageshow",this._onVisible,!0)}pingOnce(){return mt(this,void 0,void 0,(function*(){this.IsConnected()&&(Date.now()-this._lastReceivedPacket<_t.PING_INTERVAL_MS||((yield this.PingControllerAsync())?this._consecutivePingFailures=0:++this._consecutivePingFailures>=_t.MAX_CONSECUTIVE_PING_FAILURES&&(this._consecutivePingFailures=0,this._log.Warning(_t.ServiceName,"Ping failed too many times → reconnecting..."),_t.SERVER_TIMOUT_MS<_t.PING_INTERVAL_MS*_t.MAX_CONSECUTIVE_PING_FAILURES&&this._log.Error("Server timeout is shorter than ping interval! SignalR automatic reconnect will not work!."),this.serialisedConnect())))}))}validateConnectionToController(){return mt(this,void 0,void 0,(function*(){var e;if(!this.IsConnected())return this._log.Warning(_t.ServiceName,"Connection was lost."),!1;{const n=new ae;n.Resource="/system/ping",n.Method=ue.Get;try{var t=yield this.SendAndWaitForResponseAsync(n,_t.SERVER_TIMOUT_MS+1e3,!1,!1);return(null==t?void 0:t.Status)!==ce.OK?(this._log.Warning(_t.ServiceName,"Connection check failed, "+(null==t?"result is null":`status: ${t.Status}`)),!1):(null===(e=this._connection)||void 0===e?void 0:e.state)==s.Reconnecting?(this._log.Warning(_t.ServiceName,"Connection check failed, but connection is in reconnecting state!"),!1):(this._log.Info(_t.ServiceName,"Connection still active!"),!0)}catch(e){return!1}}}))}cleanup(){var e,t;null!==this._pingTimerId&&(clearInterval(this._pingTimerId),this._pingTimerId=null);for(const[,e]of this._pendingRequests)clearTimeout(e.timeoutId),e.reject(new Error("Connection lost"));this._pendingRequests.clear(),window.removeEventListener("online",this._tryReconnect),window.removeEventListener("offline",this._tryReconnect),document.removeEventListener("visibilitychange",this._onVisibility,!0),window.removeEventListener("pagehide",this._onHidden,!0),window.removeEventListener("pageshow",this._onVisible,!0),null===(t=null===(e=this._connection)||void 0===e?void 0:e.off)||void 0===t||t.call(e),this._connection=void 0}}var Ct,Tt,Dt,kt,Et,bt,It,Gt,Nt,Rt,Pt,Ot,Ut,Mt,xt,Ft;_t.PING_INTERVAL_MS=5e3,_t.MAX_CONSECUTIVE_PING_FAILURES=6,_t.SERVER_TIMOUT_MS=1e4,_t.SignalRLogLevel=r.Warning,_t.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(Ct||(Ct={})),(Ot=Tt||(Tt={}))[Ot.Default=0]="Default",Ot[Ot.Monostable=1]="Monostable",Ot[Ot.Bistable=2]="Bistable",Ot[Ot.Gate=3]="Gate",Ot[Ot.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"}(Dt||(Dt={}));class Lt{constructor(){this._type=Et.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Ut=kt||(kt={}))[Ut.Unknown=0]="Unknown",Ut[Ut.BlindMotor=1]="BlindMotor",Ut[Ut.DinModule=2]="DinModule",Ut[Ut.DinModuleWithAntenna=3]="DinModuleWithAntenna",Ut[Ut.Remote=4]="Remote",Ut[Ut.RemoteForBlinds=5]="RemoteForBlinds",Ut[Ut.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",Ut[Ut.MovementSensor=7]="MovementSensor",Ut[Ut.TemperatureSensor=8]="TemperatureSensor",Ut[Ut.HumiditySensor=9]="HumiditySensor",Ut[Ut.DinPowerMeter=10]="DinPowerMeter",Ut[Ut.Intercom=11]="Intercom",Ut[Ut.SecurityCamera=12]="SecurityCamera",Ut[Ut.Multisensor=13]="Multisensor",Ut[Ut.FloodSensor=14]="FloodSensor",Ut[Ut.FlushMountedReceiver=15]="FlushMountedReceiver",Ut[Ut.FlushMountedBlindController=16]="FlushMountedBlindController",Ut[Ut.FlushMountedDimmer=17]="FlushMountedDimmer",Ut[Ut.FlushMountedRelay=18]="FlushMountedRelay",Ut[Ut.FlushMountedGateController=19]="FlushMountedGateController",Ut[Ut.WindSensor=20]="WindSensor",Ut[Ut.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",Ut[Ut.AirPressureSensor=22]="AirPressureSensor",Ut[Ut.LightBrightnessSensor=23]="LightBrightnessSensor",Ut[Ut.ReedSensor=24]="ReedSensor",Ut[Ut.FlushMountedTransceiver=25]="FlushMountedTransceiver",Ut[Ut.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",Ut[Ut.WallMountedThermoregulator=27]="WallMountedThermoregulator",Ut[Ut.ImpulseCounter=28]="ImpulseCounter",Ut[Ut.FlushMountedFacadeController=29]="FlushMountedFacadeController",Ut[Ut.WallMountedGateController=30]="WallMountedGateController",Ut[Ut.WallMountedRGBLightController=31]="WallMountedRGBLightController",Ut[Ut.WallMountedDimmer=32]="WallMountedDimmer",Ut[Ut.WallMountedRemote=33]="WallMountedRemote",Ut[Ut.DinRelay=34]="DinRelay",Ut[Ut.DinReceiver=35]="DinReceiver",Ut[Ut.DinBlindController=36]="DinBlindController",Ut[Ut.DinTransceiver=37]="DinTransceiver",Ut[Ut.SocketPlugIn=38]="SocketPlugIn",Ut[Ut.WallMountedRelay=39]="WallMountedRelay",Ut[Ut.Retransmitter=40]="Retransmitter",function(e){e.Unknown="Unknown",e.SetBlindPosition="IBlindPosition",e.SetBlindPositionSimple="IBlindPositionSimple",e.SetBlindMicroventilation="IMicroventilation",e.TurnOff="IChannelOff",e.TurnOn="IChannelOn",e.TurnOnWithTime="IChannelOnWithTime",e.TogleState="IChannelSwitchState",e.SetLightBrightnessDynamicly="IDynamicLightBrightness",e.SetLightBrightness="ILightBrightness",e.SetLightColor="ILightColor",e.SetLightTemperature="ILightTemperature",e.PairDevice="IPair",e.UnpairDevice="IUnpair",e.IdentifyDevice="IIdentifyDevice",e.GetChannelsState="IGetDeviceState",e.GetPowerMeasurements="IGetPowerMeasurements",e.GetAvailableData="IGetAvailableData",e.MultipleDataRequest="IMultipleDataRequest",e.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",e.SetTemperature="IChangeTemperature",e.SetGatePosition="IGatePosition",e.SetGatewayPosition="IGatewayPosition",e.ChangeGatePositionPulse="IGatePulse",e.ChangeGatewayPositionPulse="IGatewayPulse",e.SetFacadePosition="IFacadePosition",e.GetFacadeType="IGetFacadeType",e.LightRGBW="ILightRGBW",e.PreciseGateControl="IPreciseGateControl"}(Et||(Et={}));class Bt{constructor(){this._type=bt.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.BlindErrorState="IBlindError",e.MeasuredBrightness="IBrightness",e.RemoteButtonState="IButtonState",e.ChannelOnOffState="IChannelOnOff",e.IntercomState="IIntercom",e.DoorBellState="IDoorBell",e.FacadeRemoteButtonState="IFacadeControlButton",e.FacadePosition="IFacadeState",e.FacadeType="IFacadeType",e.FloodSensorState="IFloodSensor",e.GatePosition="IGatePosition",e.GatewayPosition="IGatewayPosition",e.GateControllerHealth="IGateControllerHealth",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",e.SceneExecuted="ISceneExecuted",e.HallState="IHallState",e.Intercom="IIntercom"}(bt||(bt={})),(Ft=It||(It={}))[Ft.NotResponding=0]="NotResponding",Ft[Ft.Working=1]="Working",Ft[Ft.Broken=2]="Broken",Ft[Ft.FirmareUpgradeMode=3]="FirmareUpgradeMode",(xt=Gt||(Gt={}))[xt.TwoWay=1]="TwoWay",xt[xt.OneWay=2]="OneWay",xt[xt.ConditionalTwoWay=3]="ConditionalTwoWay",(Mt=Nt||(Nt={}))[Mt.Unknown=-1]="Unknown",Mt[Mt.Multipurpose=0]="Multipurpose",Mt[Mt.Controller=1]="Controller",Mt[Mt.Driver=2]="Driver",Mt[Mt.Receiver=3]="Receiver",Mt[Mt.Remote=4]="Remote",Mt[Mt.Sensor=5]="Sensor",Mt[Mt.Scene=6]="Scene";class Wt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=Ct.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"}(Rt||(Rt={})),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"}(Pt||(Pt={}));class $t{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=Pt.Unknown}}var qt,Vt,Ht,Kt,jt,zt,Jt,Xt,Yt,Qt,Zt,en,tn,nn,rn,on,sn,an,cn,un,ln,dn,hn,gn,pn,fn,vn,yn,mn,wn,Sn;class An{constructor(){this._type="",this._data=null,this._typeAsEnum=bt.Unknown,this._serializedDataWithoutTime=""}get Data(){return this._data}set Data(e){this._data=e;let{Time:t}=e,n=function(e,t){var n={};for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var o=0;for(r=Object.getOwnPropertySymbols(e);o<r.length;o++)t.indexOf(r[o])<0&&Object.prototype.propertyIsEnumerable.call(e,r[o])&&(n[r[o]]=e[r[o]])}return n}(e,["Time"]);this._serializedDataWithoutTime=JSON.stringify(n)}get Type(){return this._type}set Type(e){this._type=e}get TypeAsEnum(){return this._typeAsEnum}set TypeAsEnum(e){this._typeAsEnum=e}get StatesComparisonData(){return this._serializedDataWithoutTime}}(Sn=qt||(qt={}))[Sn.Confident=0]="Confident",Sn[Sn.Unconfident=1]="Unconfident";class _n extends An{constructor(e){super(),this.TypeAsEnum=bt.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class Cn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Vt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Vt||(Vt={}));class Tn extends An{constructor(e){super(),this.TypeAsEnum=bt.HallState,this.Type="IHallState",this.Data=e.state}}class Dn extends An{constructor(e){super(),this.TypeAsEnum=bt.SceneExecuted,this.Type="ISceneExecuted",this.Data=e.state}}class kn extends An{constructor(e){super(),this.TypeAsEnum=bt.IntercomState,this.Type="IntercomState",this.Data=e.state}}!function(e){e[e.Idle=0]="Idle",e[e.IncomingCall=1]="IncomingCall",e[e.AnsweringCall=2]="AnsweringCall",e[e.Busy=3]="Busy",e[e.NoAnswerToCall=4]="NoAnswerToCall",e[e.Unknown=5]="Unknown"}(Ht||(Ht={}));class En extends An{constructor(e){super(),this.TypeAsEnum=bt.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class bn extends An{constructor(e){super(),this.TypeAsEnum=bt.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class In{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Kt.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(Kt||(Kt={}));class Gn extends An{constructor(e){super(),this.TypeAsEnum=bt.ReedState,this.Type="ReedState",this.Data=e.state}}class Nn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=!1,this.Time=""}}class Rn extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return jt.UnableToMove;case 201:return jt.MotorOverheatedPleaseWait;default:return jt.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(jt||(jt={}));class Pn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class On extends An{constructor(e){super(),this.TypeAsEnum=bt.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class Un{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=zt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(zt||(zt={}));class Mn extends An{constructor(e){super(),this.TypeAsEnum=bt.LightColor,this.Type="LightColorState",this.Data=e.state}}class xn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class Fn extends An{constructor(e){super(),this.TypeAsEnum=bt.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class Ln{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Temperature=0,this.Time=""}}class Bn extends An{constructor(e){super(),this.TypeAsEnum=bt.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class Wn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class $n extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class qn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Temperature=0,this.Type=Jt.InsideTemperature,this.Time=""}}!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"}(Jt||(Jt={}));class Vn extends An{constructor(e){super(),this.TypeAsEnum=bt.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Hn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Xt.Half,this.Percentage=-1,this.Time=""}}!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"}(Xt||(Xt={}));class Kn extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class jn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class zn extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class Jn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Time="",this.MeasurementParameters=new Map}}!function(e){e.Voltage="Voltage",e.Current="Current",e.PhaseShift="PhaseShift",e.ActivePower="ActivePower",e.ReactivePower="ReactivePower",e.ApparentPower="ApparentPower",e.PowerFactor="PowerFactor",e.ActiveForwardEnergy="ActiveForwardEnergy",e.ActiveReverseEnergy="ActiveReverseEnergy",e.ApparentEnergy="ApparentEnergy",e.ReactiveForwardEnergy="ReactiveForwardEnergy",e.ReactiveReverseEnergy="ReactiveReverseEnergy",e.Frequency="Frequency",e.SPIErrorRate="SPIErrorRate",e.CRCErrorRate="CRCErrorRate",e.Timestamp="Timestamp",e.FailedMeasurementsRate="FailedMeasurementsRate",e.FundamentalActivePower="FundamentalActivePower",e.HarmonicActivePower="HarmonicActivePower"}(Yt||(Yt={}));class Xn extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Qt||(Qt={}));class Yn extends An{constructor(e){super(),this.TypeAsEnum=bt.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Qn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Intensity=0,this.Movement=Zt.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Zt||(Zt={}));class Zn extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class er{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=en.StopReleased,this.Time=""}}!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"}(en||(en={}));class tr extends An{constructor(e){super(),this.TypeAsEnum=bt.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class nr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=tn.StopReleased,this.Time=""}}!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"}(tn||(tn={}));class rr extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(nn||(nn={}));class or extends An{constructor(e){super(),this.TypeAsEnum=bt.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class sr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.PositionType=rn.Unknown,this.Position=0,this.Time=""}}!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",e[e.Percentage=6]="Percentage"}(rn||(rn={}));class ir extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(on||(on={}));class ar extends An{constructor(e){super(),this.TypeAsEnum=bt.GateControllerHealth,this.Type="GateControllerHealthState",this.Data=e.state}}!function(e){e[e.Unknown=-1]="Unknown",e[e.Inactive=0]="Inactive",e[e.Active=1]="Active",e[e.UnconnectedOrMalfunction=2]="UnconnectedOrMalfunction"}(sn||(sn={}));class cr extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(an||(an={}));class ur extends An{constructor(e){super(),this.TypeAsEnum=bt.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class lr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Type=cn.AirHumidity,this.Humidity=0,this.Time=""}}!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"}(cn||(cn={}));class dr extends An{constructor(e){super(),this.TypeAsEnum=bt.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(un||(un={}));class hr extends An{constructor(e){super(),this.TypeAsEnum=bt.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class gr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=ln.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(ln||(ln={}));class pr extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(dn||(dn={}));class fr extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class vr extends An{constructor(e){super(),this.TypeAsEnum=bt.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class yr extends An{constructor(e){super(),this.TypeAsEnum=bt.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class mr extends An{constructor(e){super(),this.TypeAsEnum=bt.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class wr extends An{constructor(e){super(),this.TypeAsEnum=bt.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Sr extends An{constructor(e){super(),this.TypeAsEnum=bt.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class Ar{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.WindThreshold=hn.Unknown,this.Time=""}}!function(e){e[e.Unknown=0]="Unknown",e[e.Below=1]="Below",e[e.Exceeded=2]="Exceeded",e[e.Inactive=3]="Inactive"}(hn||(hn={}));class _r extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(gn||(gn={}));class Cr extends An{constructor(e){super(),this.TypeAsEnum=bt.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class Tr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Value=0,this.Time=""}}class Dr extends An{constructor(e){super(),this.TypeAsEnum=bt.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class kr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=pn.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(pn||(pn={})),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"}(fn||(fn={}));class Er extends An{constructor(e){super(),this.TypeAsEnum=bt.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class br{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Pressure=0,this.Time="",this.PressureType=vn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(vn||(vn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(yn||(yn={}));class Ir extends An{constructor(e){super(),this.TypeAsEnum=bt.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(mn||(mn={}));class Gr extends An{constructor(e){super(),this.TypeAsEnum=bt.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Nr extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindErrorState,this.Type="BlindError",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.ObstacleDetected=1]="ObstacleDetected",e[e.MotorFailure=2]="MotorFailure"}(wn||(wn={}));class Rr{constructor(){this._onDeviceStateChangedEvent=new a,this._onDeviceStateRefreshedOrChangedEvent=new a,this._onDeviceTasksExecutionChangedOnChannelsEvent=new a,this._onDeviceFirmwareVersionChangedEvent=new a,this._iconType=kt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=It.Working,this._deviceType=Nt.Unknown,this._communicationWay=Gt.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==Rr._devicesService&&(Rr._devicesService=Qv.Get(Ys.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Rr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Rr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),Rr._devicesService.OnDevicesTasksExecutionChangeEvent().Subscribe((e=>{t.Invoke(e.filter((e=>e.DeviceGuid==this._guid)).map((e=>e.Channel)))}))}OnDeviceFirmwareVersionChangedEvent(){return this._onDeviceFirmwareVersionChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}get ShouldChannelsBeGrouped(){if(this._deviceType===Nt.Remote)switch(this._modelGuid){case"afea26ac-d5de-4aa9-8e74-ff69679d097b":case"908a71ec-ca46-4431-9504-05b7801e77f8":case"d8fea502-541e-42d9-8ece-a1bcfaaa93f9":return!1;default:return this._availableTasksTypes.all((e=>e.Type!==Et.SetBlindPositionSimple))}return!1}get States(){return c.DoesThrowStackTrace?Qv.Get(Ys.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Rr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Rr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Rr._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 IconType(){return this._iconType}set IconType(e){this._iconType=e}get Name(){return null==this._name?"":this._name}set Name(e){this._name=e}set SoftwareVersion(e){this._softwareVersion=e}get SoftwareVersion(){return this._softwareVersion}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,o=function*(){var t;try{const n=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new Pr(this,e),2e4,!1);switch(n.Status){case ce.OK:return this._name=e,null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeDeviceNameAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),new ke(me.Changed,"");case ce.WrongData:if("DeviceNotFound"==n.Data)return new ke(me.Failed,"DeviceNotFound");break;case ce.NoPermissionsToCallGivenResource:return new ke(me.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new ke(me.ControllerResponseTimeout,""):new ke(me.UnknownError,"")}return new ke(me.Unknown,"")},new((r=void 0)||(r=Promise))((function(e,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(t){var n;t.done?e(t.value):(n=t.value,n instanceof r?n:new r((function(e){e(n)}))).then(i,a)}c((o=o.apply(t,n||[])).next())}));var t,n,r,o}ExecuteTaskAsync(e){return Rr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class Pr extends ae{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ue.Put;const n=new Or;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class Or{constructor(){this.DeviceGuid="",this.Name=""}}var Ur,Mr,xr,Fr,Lr,Br=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Wr{constructor(){this._device=new Rr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=Tt.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this._configurations={},this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new a,this._onChannelStateChangedEvent=new a,this._onChannelStateRefreshedOrChangedEvent=new a,null==Wr._devicesService&&(Wr._devicesService=Qv.Get(Ys.ServiceName))}OnChannelStateChangedEvent(){return this._onChannelStateChangedEvent}OnChannelStateRefreshedOrChangedEvent(){return this._onChannelStateRefreshedOrChangedEvent}get Configurations(){return this._configurations}set Configurations(e){this._configurations=e}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}`,this._device.OnDeviceStateChangedEvent().Subscribe((e=>{e.Data.Channel==this.Number&&this._onChannelStateChangedEvent.Invoke(e)})),this._device.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Data.Channel==this.Number&&this._onChannelStateRefreshedOrChangedEvent.Invoke(e)}))}GetDevice(){return this._device}SetCustomDataAsync(e,t){return Br(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new $r;return r.DeviceGuid=this._device.Guid,r.ChannelConfiguration=n,this.ChangeConfigurationAsync(r)}))}RemoveCustomDataAsync(e){const t=this.GetChannelConfigurationData();delete t.CustomData[e],delete this._customData[e];const n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new qr;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();this._isHidden=!0,e.Hidden=!0;const t=new $r;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ShowAsync(){const e=this.GetChannelConfigurationData();e.Hidden=!1,this._isHidden=!1;const t=new $r;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,t.ChannelName=e,this._name=e,this.ChangeConfigurationAsync(n)}ChangeIconNameAsync(e){const t=this.GetChannelConfigurationData();t.IconName=e;const n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._iconName=e,this.ChangeConfigurationAsync(n)}ChangeGroupsAsync(e){const t=this.GetChannelConfigurationData();t.GroupsGuids=e;const n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){return Br(this,void 0,void 0,(function*(){var t,n;try{const r=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new Vr(e),2e4,!1);switch(null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeConfigurationAsync()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),r.Status){case ce.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,this._configurations=e.ChannelConfiguration.Configurations,new ke(me.Changed,"");case ce.WrongData:if("DeviceNotFound"===r.Data)return null===(n=u.Log)||void 0===n||n.Error("Failed to change channel configuration, referenced device does not exist!"),new ke(me.WrongData,"DeviceNotFound");break;case ce.FatalError:return new ke(me.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new ke(me.ControllerResponseTimeout,"")}return new ke(me.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 c.DoesThrowStackTrace?Qv.Get(Ys.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Wr._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,Wr._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(Pt.Failed)}}Wr._devicesService=null;class $r{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new qr}}class qr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=Tt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class Vr extends ae{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ue.Put,this.Data=e}}!function(e){e[e.TurnOn=0]="TurnOn",e[e.TurnOff=1]="TurnOff",e[e.ToggleState=2]="ToggleState",e[e.SetBlindPosition=3]="SetBlindPosition",e[e.SetLightColor=4]="SetLightColor",e[e.SetLightTemperature=5]="SetLightTemperature",e[e.SetLightBrightness=6]="SetLightBrightness",e[e.SetTemperature=7]="SetTemperature",e[e.GetState=8]="GetState",e[e.TurnOnWithTimeout=9]="TurnOnWithTimeout",e[e.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",e[e.IdentifyDevice=11]="IdentifyDevice",e[e.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",e[e.SetBlindMicroventilation=13]="SetBlindMicroventilation",e[e.GatewayPulse=25]="GatewayPulse",e[e.GatePulse=26]="GatePulse",e[e.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",e[e.GetFacadeType=30]="GetFacadeType",e[e.LightRGBW=31]="LightRGBW",e[e.SetGatePositionPrecise=32]="SetGatePositionPrecise"}(Ur||(Ur={}));class Hr{static NewGuid(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){var t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)}))}}class Kr{constructor(){this._taskType=Et.GetChannelsState,this._featureType=Ur.GetState,this._channel=0,this._guid=Hr.NewGuid(),this._deviceGuid=""}get TaskType(){return this._taskType}set TaskType(e){this._taskType=e}get FeatureType(){return this._featureType}set FeatureType(e){this._featureType=e}get Guid(){return this._guid}set Guid(e){this._guid=e}get DeviceGuid(){return this._deviceGuid}set DeviceGuid(e){this._deviceGuid=e}get Channel(){return this._channel}set Channel(e){this._channel=e}}class jr extends Kr{constructor(){super(),this.Temperature=0,this.FeatureType=Ur.SetTemperature,this.TaskType=Et.SetTemperature}}class zr extends Kr{constructor(){super(),this.FeatureType=Ur.TurnOff,this.TaskType=Et.TurnOff}}class Jr extends Kr{constructor(){super(),this.FeatureType=Ur.TurnOn,this.TaskType=Et.TurnOn}}class Xr extends Kr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=Ur.TurnOnWithTimeout,this.TaskType=Et.TurnOnWithTime}}class Yr extends Kr{constructor(){super(),this.Brightness=0,this.FeatureType=Ur.SetLightBrightness,this.TaskType=Et.SetLightBrightness}}class Qr extends Kr{constructor(){super(),this.FeatureType=Ur.ToggleState,this.TaskType=Et.TogleState}}class Zr extends Kr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=Ur.SetLightColor,this.TaskType=Et.SetLightColor}}class eo extends Kr{constructor(){super(),this.Temperature=0,this.FeatureType=Ur.SetLightTemperature,this.TaskType=Et.SetLightTemperature}}class to extends Kr{constructor(){super(),this.Action=Mr.Stop,this.Position=0,this.FeatureType=Ur.SetBlindPosition,this.TaskType=Et.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Mr||(Mr={}));class no extends Kr{constructor(){super(),this.GateControlAction=xr.Stop,this.Position=0,this.FeatureType=Ur.SetGatePositionPrecise,this.TaskType=Et.PreciseGateControl}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(xr||(xr={}));class ro extends Kr{constructor(){super(),this.Action=Fr.Stop,this.Position=0,this.FeatureType=Ur.SetBlindPosition,this.TaskType=Et.SetBlindPositionSimple}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Fr||(Fr={}));class oo extends Kr{constructor(){super(),this.Brightness=0,this.FeatureType=Ur.SetLightBrightnessDynamicly,this.TaskType=Et.SetLightBrightnessDynamicly}}class so extends Kr{constructor(){super(),this.FeatureType=Ur.IdentifyDevice,this.TaskType=Et.IdentifyDevice}}class io extends Kr{constructor(){super(),this.Data=new ao,this.FeatureType=Ur.SetBlindOpenCloseTime,this.TaskType=Et.SetBlindOpenCloseTime}}class ao{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class co extends Kr{constructor(){super(),this.FeatureType=Ur.GetState,this.TaskType=Et.GetChannelsState}}class uo extends Kr{constructor(){super(),this.Position=0,this.FeatureType=Ur.SetBlindMicroventilation,this.TaskType=Et.SetBlindMicroventilation}}class lo extends Kr{constructor(){super(),this.FeatureType=Ur.GatePulse,this.TaskType=Et.ChangeGatewayPositionPulse}}class ho extends Kr{constructor(){super(),this.FeatureType=Ur.GatewayPulse,this.TaskType=Et.ChangeGatewayPositionPulse}}class go extends Kr{constructor(){super(),this.FacadeAction=Lr.Stop,this.Tilt=0,this.Position=0,this.FeatureType=Ur.SetFacadePositionAndTilt,this.TaskType=Et.SetFacadePosition}}class po extends Kr{constructor(){super(),this.FeatureType=Ur.GetFacadeType,this.TaskType=Et.GetFacadeType}}!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"}(Lr||(Lr={}));class fo{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class vo extends Kr{constructor(){super(),this.Data=new fo,this.FeatureType=Ur.LightRGBW,this.TaskType=Et.LightRGBW}}var yo=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class mo{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return mo.ServiceName}RegisterManuallyPairedDevicesProtocol(e){var t;null===(t=u.Log)||void 0===t||t.Debug(mo.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return yo(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()],n=[];if(null!=e)if(Array.isArray(e))for(let r=0;r<t.length;r++)e.any((e=>e==t[r].ProtocolExtensionGuid))&&n.push(...yield t[r].GetDevicesForManualPairingAsync());else{const r=t.find((t=>t.ProtocolExtensionGuid==e));null!=r&&n.push(...yield r.GetDevicesForManualPairingAsync())}else for(let e=0;e<t.length;e++)n.push(...yield t[e].GetDevicesForManualPairingAsync());return n}))}AddManuallyPairedDeviceAsync(e){return yo(this,void 0,void 0,(function*(){var t;const n=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=n?n.AddManuallyPairedDeviceAsync(e):(null===(t=u.Log)||void 0===t||t.Error(mo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDeviceAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),Pt.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}mo.ServiceName="ManualDeviceService";class wo{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var So,Ao=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class _o{constructor(){this._connection=null,this._localDb=null,this._connection=Qv.Get(_t.ServiceName),this._localDb=Qv.Get(l.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return Ao(this,void 0,void 0,(function*(){let r=new Co(e,t,n),o=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(o.Status===ce.OK){const r=new ko;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(_o.ServiceName,this.GetLocalDbName(e,t),r)}return o.Status}))}ReadAsync(e,t,n){return Ao(this,void 0,void 0,(function*(){let r=new To(e,t);if(!n){const n=this._localDb.Read(_o.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new wo;return t.Data=JSON.parse(e.Data),t.IsGlobal=e.IsGlobal,t.ResourceGuid=e.ResourceGuid,t}}let o=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(o.Status===ce.OK){const e=new wo;return e.ResourceGuid=o.ResourceGuid,e.Data=JSON.parse(o.Data),e.IsGlobal=o.IsGlobal,e}return o.Status}))}RemoveAsync(e,t){return Ao(this,void 0,void 0,(function*(){let n=new Do(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return _o.ServiceName}}_o.ServiceName="RemoteStorageService";class Co extends ae{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class To extends ae{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Get,this.ResourceGuid=e,this.Global=t}}class Do extends ae{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Delete,this.ResourceGuid=e,this.Global=t}}class ko extends ae{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class Eo{constructor(){this.Longitude=0,this.Latitude=0}}class bo{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"}(So||(So={}));var Io,Go,No=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ro{IsControllerGeolocationSetAsync(){return No(this,void 0,void 0,(function*(){let e=new Po,t=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ce.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return No(this,void 0,void 0,(function*(){return new Promise(((e,t)=>No(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){return No(this,void 0,void 0,(function*(){var t,n,r;let o=new Uo;o.Data.Latitude=e.Latitude,o.Data.Longitude=e.Longitude,null===(t=u.Log)||void 0===t||t.Warning(Ro.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(o)}`);let s=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(o,15e3,!1);switch(null===(n=u.Log)||void 0===n||n.Warning(Ro.ServiceName,`${JSON.stringify(s)}`),null===(r=u.Log)||void 0===r||r.Error(Ro.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetControllerGeolocationAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==s?void 0:s.Status){case ce.OK:return new Ee(So.OK,"");case ce.NoPermissionToPerformThisOperation:case ce.NoPermissionsToCallGivenResource:return new Ee(So.NoPermissions,"");case ce.UserIsNotLoggedIn:return new Ee(So.UserIsNotLoggedIn,"");default:return new Ee(So.UnknownError,"")}}))}GetControlllerGeolocationAsync(){return No(this,void 0,void 0,(function*(){var e,t;let n=new Oo;null===(e=u.Log)||void 0===e||e.Warning(Ro.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=u.Log)||void 0===t||t.Warning(Ro.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ce.OK){let e=new bo;return e.IsNetworkBased=(null==r?void 0:r.Data).IsNetworkBased,e.Latitude=(null==r?void 0:r.Data).Latitude,e.Longitude=(null==r?void 0:r.Data).Longitude,e}return null==r?void 0:r.Status}))}GetServiceName(){return Ro.ServiceName}}Ro.ServiceName="GeolocationService";class Po extends ae{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ue.Get}}class Oo extends ae{constructor(){super(),this.Resource="/geolocation/get",this.Method=ue.Get}}class Uo extends ae{constructor(){super(),this.Data=new Eo,this.Resource="/geolocation/save",this.Method=ue.Put}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Io||(Io={}));class Mo{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=Go.Unknown,this.ResourceGuid=""}}class xo{constructor(){this.UpdateDescription=new Map,this.Update=new Mo,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"}(Go||(Go={}));class Fo extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var Lo,Bo,Wo,$o,qo,Vo,Ho,Ko,jo,zo,Jo,Xo,Yo,Qo,Zo,es,ts,ns,rs=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class os{constructor(){this._services=new Map,this._runtimeInfo=new ss,this._hardwareInfo=new as,this._semaphore=new Ze(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return os.ServiceName}RegisterUpdatesProvider(e){var t;null===(t=u.Log)||void 0===t||t.Debug(os.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return rs(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(os.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const n=this._services.get(e);if(null==n)throw new Fo("Cannot get update provider! Requested update provider has not been registered.");return n}))}GetUpdatesProvidersAsync(e){return rs(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(os.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let n=[];if(n=[...this._services.values()].filter((t=>t.ProviderType==e)),0==n.length)throw new Fo("Cannot get update providers! Requested update providers has not been registered.");return n}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return rs(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(os.ServiceName,`Getting update providers with protocol guid: [${e}] by GetUpdateProvidersByProtocolAsync<T>()`);let o=[];if(o=null!=n?[...this._services.values()].filter((r=>r.ProtocolGuid==e&&r.ProviderType==t&&r.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ProtocolGuid==e&&n.ProviderType==t)),0==o.length)throw new Fo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Fo("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return rs(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(os.ServiceName,`Getting update providers with extension guid: [${e}] by GetUpdateProvidersByExtensionAsync<T>()`);let o=[];if(o=null!=n?[...this._services.values()].filter((r=>r.ExtensionGuid==e&&r.ProviderType==t&&r.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ExtensionGuid==e&&n.ProviderType==t)),0==o.length)throw new Fo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Fo("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(){return rs(this,arguments,void 0,(function*(e=!1){var t=yield this._semaphore.AcquireAsync();return!this._isRuntimeInfoInitialized||e?(yield this.GetRuntimeControllerInfoAsync(),t.Release(),this._runtimeInfo):(t.Release(),this._runtimeInfo)}))}GetRuntimeControllerInfoAsync(){return rs(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(os.ServiceName,"Getting runtime version info from controller.");try{const e=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new is,16e3,!1);if(null==e||null==e.Status)throw new us('Cannot get runtime info, controller response result is empty."',Lo.EmptyResponse);if(e.Status!=ce.OK)throw new us(`Cannot get runtime info, controller responded with status ${e.Status}.`,Lo.WrongResponseStatus);if(null==e.Data)throw new us("Cannot get runtime info, controller responded with status OK but response does not contains data.",Lo.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof E?new us("Cannot get runtime info, controller response timeout.",Lo.Timeout):e}}))}GetHardwareInfoAsync(){return rs(this,arguments,void 0,(function*(e=!1){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return rs(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(os.ServiceName,"Getting hardware info from controller.");const t=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new cs,8e3,!1);if(null==t||null==t.Status)throw new us('Cannot get hardware info, controller response result is empty."',Lo.EmptyResponse);if(t.Status!=ce.OK)throw new us(`Cannot get hardware info, controller responded with status ${t.Status}.`,Lo.WrongResponseStatus);if(null==t.Data)throw new us("Cannot get hardware info, controller responded with status OK but response does not contains data.",Lo.NoDataInResponse);this._hardwareInfo=t.Data,this._isRuntimeInfoInitialized=!0}))}}os.ServiceName="UpdateProvider";class ss{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class is extends ae{constructor(){super(),this.Resource="/controller/software/info",this.Method=ue.Get}}class as{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class cs extends ae{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ue.Get}}class us extends Error{constructor(e,t){super(e),this.message=e,this.code=0,this.name="CannotGetRuntimeInfo",this.code=t}}!function(e){e[e.Unknown=0]="Unknown",e[e.EmptyResponse=1]="EmptyResponse",e[e.NoDataInResponse=2]="NoDataInResponse",e[e.WrongResponseStatus=3]="WrongResponseStatus",e[e.Timeout=4]="Timeout"}(Lo||(Lo={})),function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(Bo||(Bo={}));class ls{constructor(){this._comparisonParams=new Map,this.Type=bt.Unknown,this.DeviceGuid="",this.ComparisonMethod=Wo.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Hn&&(this.Type=bt.BatteryState),e instanceof gr&&(this.Type=bt.BinarySensorState),e instanceof Pn&&(this.Type=bt.BlindPosition),e instanceof Wn&&(this.Type=bt.LightBrightness),e instanceof jn&&(this.Type=bt.MeasuredBrightness),e instanceof Un&&(this.Type=bt.RemoteButtonState),e instanceof Cn&&(this.Type=bt.ChannelOnOffState),e instanceof In&&(this.Type=bt.DoorBellState),e instanceof Jn&&(this.Type=bt.MeasuredEnergy),e instanceof kr&&(this.Type=bt.FloodSensorState),e instanceof sr&&(this.Type=bt.GatePosition),e instanceof xn&&(this.Type=bt.LightColor),e instanceof Ln&&(this.Type=bt.LightWarmth),e instanceof Nn&&(this.Type=bt.ReedState),e instanceof qn&&(this.Type=bt.MeasuredTemperature),e instanceof lr&&(this.Type=bt.HumiditySensorState),e instanceof er&&(this.Type=bt.BlindRemoteButtonState),e instanceof nr&&(this.Type=bt.FacadeRemoteButtonState),e instanceof Qn&&(this.Type=bt.MovementSensorState),e instanceof Jn&&(this.Type=bt.MeasuredEnergy),e instanceof br&&(this.Type=bt.PressureSensorState),e instanceof Tr&&(this.Type=bt.WindSpeedState),e instanceof Ar&&(this.Type=bt.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class ds{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class hs{constructor(...e){this._value="00:00:00",e.length>1?this.SetTimeSpan(e[0],e[1],e[2],e[3]):this._value=e[0]}SetTimeSpan(e,t,n,r){this._value=r<=0?`${n.toString().padStart(2,"0")}:${t.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`:`${r}.${n.toString().padStart(2,"0")}:${t.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`}get Value(){return this._value}}!function(e){e[e.Default=0]="Default",e[e.Delta=1]="Delta",e[e.StateRepeat=2]="StateRepeat"}(Wo||(Wo={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}($o||($o={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(qo||(qo={}));class gs{constructor(){this.DeviceGuid=""}}!function(e){e[e.Unknown=-1]="Unknown",e[e.DeviceTask=0]="DeviceTask",e[e.DelayTask=1]="DelayTask",e[e.NotifyTask=2]="NotifyTask",e[e.LockExecution=3]="LockExecution"}(Vo||(Vo={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(Ho||(Ho={})),(ns=Ko||(Ko={}))[ns.Unknown=0]="Unknown",ns[ns.Second=1]="Second",ns[ns.Minute=2]="Minute",ns[ns.Hour=3]="Hour",ns[ns.Day=4]="Day",ns[ns.DayOfWeek=5]="DayOfWeek",ns[ns.Month=6]="Month",ns[ns.Year=7]="Year",ns[ns.Date=8]="Date",ns[ns.Time=9]="Time",ns[ns.WeatherType=11]="WeatherType",ns[ns.CompareNumbers=12]="CompareNumbers",ns[ns.CompareBooleans=13]="CompareBooleans",ns[ns.DeviceState=14]="DeviceState",ns[ns.Timer=15]="Timer",ns[ns.Temperature=17]="Temperature",ns[ns.DaysOfWeek=18]="DaysOfWeek",ns[ns.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",ns[ns.SceneExecuted=20]="SceneExecuted",(ts=jo||(jo={}))[ts.Unknown=0]="Unknown",ts[ts.Equal=1]="Equal",ts[ts.NotEqueal=2]="NotEqueal",ts[ts.BiggerThan=3]="BiggerThan",ts[ts.SmallerThan=4]="SmallerThan",ts[ts.BiggerThanOrEqual=5]="BiggerThanOrEqual",ts[ts.SmallerThanOrEqual=6]="SmallerThanOrEqual",ts[ts.OneOfBothIsTrue=7]="OneOfBothIsTrue",ts[ts.BothAreTrue=8]="BothAreTrue",function(e){e[e.Unknown=0]="Unknown",e[e.BatteryState=1]="BatteryState",e[e.BinarySensor=2]="BinarySensor",e[e.BlindPosition=3]="BlindPosition",e[e.Brightness=4]="Brightness",e[e.ButtonState=5]="ButtonState",e[e.ChannelOnOff=6]="ChannelOnOff",e[e.DoorBell=7]="DoorBell",e[e.Energy=8]="Energy",e[e.FloodSensor=9]="FloodSensor",e[e.GatePosition=10]="GatePosition",e[e.HeatSensor=11]="HeatSensor",e[e.LightBrightness=12]="LightBrightness",e[e.LightColor=13]="LightColor",e[e.LightTemperature=14]="LightTemperature",e[e.MeasuredCurrent=15]="MeasuredCurrent",e[e.MeasuredPower=16]="MeasuredPower",e[e.MeasuredVoltage=17]="MeasuredVoltage",e[e.ReedState=18]="ReedState",e[e.SmokeSensor=19]="SmokeSensor",e[e.Temperature=20]="Temperature",e[e.BlindsControlButton=21]="BlindsControlButton",e[e.Movement=22]="Movement",e[e.WindSpeed=24]="WindSpeed",e[e.Humidity=25]="Humidity",e[e.AirPressure=26]="AirPressure",e[e.WindThreshold=31]="WindThreshold",e[e.FacadeControlButton=36]="FacadeControlButton"}(zo||(zo={})),function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(Jo||(Jo={})),(es=Xo||(Xo={})).Null="Null",es.Condition="Condition",es.ConditionGroup="ConditionGroup",es.ArgumentAsInt="ArgumentAsInt",es.ArgumentAsTimeSpan="ArgumentAsTimeSpan",es.ArgumentAsBoolean="ArgumentAsBoolean",es.ArgumentAsTimeout="ArgumentAsTimeout",es.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",es.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",es.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",es.ArgumentAsTime="ArgumentAsTime",es.ArgumentAsDeviceState="ArgumentAsDeviceState",es.ArgumentAsNumber="ArgumentAsNumber",es.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",es.ArgumentAsConditionInfo="ArgumentAsConditionInfo",function(e){e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.LockExecutionTask="LockExecutionTask",e.NotifyTaskAppNotify="NotifyTaskAppNotify",e.NotifyTaskEmailNotify="NotifyTaskEmailNotify"}(Yo||(Yo={}));class ps extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedScenesDeviceState"}}!function(e){e[e.None=0]="None",e[e.AppNotification=1]="AppNotification",e[e.Email=2]="Email"}(Qo||(Qo={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(Zo||(Zo={}));var fs,vs,ys;class ms{constructor(e,t="Cube"){this._result=null,this._tmp=new ws,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=Qv.Get(Ms.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Hr.NewGuid())}SetSequenceName(e){const t=n=>{if(n.RightArgumentType!=ys.Null)return t(n.RightArgument);n.Tasks.ControllerTasks.where((e=>e.TaskType==Vo.NotifyTask)).toArray().forEach((t=>{t.Title=e}))};this._sequenceName=e,this._editingExistingSequence&&null!=this._result&&(this._result.Name=e,t(this._result))}SetSequenceIcon(e){this._sequenceIcon=e,this._editingExistingSequence&&null!=this._result&&(this._result.Icon=e)}GetNext(){if(null==this._result)return null;if(""==this._currentSeqGuid)return this._currentSeqGuid=this._result.Guid,this._service.MapSequence(JSON.parse(JSON.stringify(this._result)),!0);{const e=this.FindArgumentWithGuid(this._result,this._currentSeqGuid);return null==e?null:e.RightArgumentType==ys.Condition?(this._prevSeqGuid=this._currentSeqGuid,this._currentSeqGuid=e.RightArgument.Guid,this._service.MapSequence(JSON.parse(JSON.stringify(e.RightArgument)),!0)):null}}CloneCurrentBuilder(){var e=new ms;return e._currentSeqGuid="",e._prevSeqGuid="",e._editingExistingSequence=structuredClone(this._editingExistingSequence),e._rawExistingSequenceTasks=structuredClone(this._rawExistingSequenceTasks),e._result=structuredClone(this._result),e._sequenceIcon=structuredClone(this._sequenceIcon),e._sequenceName=structuredClone(this._sequenceName),e._tmp=structuredClone(this._tmp),(e=>{const t=e=>{e.Guid=Hr.NewGuid(),e.RightArgumentType==ys.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Hr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==ys.Condition?(e=n.Guid,t(n.RightArgument,r)):null;if(null==this._result)return null;if(""==this._currentSeqGuid||""==this._prevSeqGuid)return null;const n=t(this._result,this._prevSeqGuid);return null==n?null:(this._currentSeqGuid=n.sequence.Guid,this._prevSeqGuid=n.prevGuid,this._service.MapSequence(JSON.parse(JSON.stringify(n.sequence)),!0))}GetByGuid(e){if(null==this._result)return null;const t=this.FindArgumentWithGuid(this._result,e);return null==t?null:this._service.MapSequence(t)}EditCurrentSequence(e){const t=e=>{if(e.RightArgumentType!=ys.Null)return t(e.RightArgument);this._rawExistingSequenceTasks=JSON.parse(JSON.stringify(e.Tasks))};return this._editingExistingSequence=!0,t(e._rawRequestData),Object.hasOwn(e._rawRequestData,"Condition")?this._result=e._rawRequestData.Condition:this._result=e._rawRequestData,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequence:e=>this.RemoveSequenceByGuid(e),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),RemoveTask:e=>this.RemoveTask(e)}}ArgumentAsAstronomicalClockWithOffset(e,t,n){if(this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=ys.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=jo.Equal)throw new Is("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new Is("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=jo.Equal;else{if(null==n)throw new Is("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.Unknown,this._tmp.LeftArgumentType=ys.Null,this._tmp.ConditionType=jo.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=ys.Null,this._tmp.Name=this._sequenceName,this._tmp.Icon=this._sequenceIcon,this._tmp.AtMeetCondition=!1,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDaysOfWeek(e,t,n=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.DaysOfWeek,this._tmp.LeftArgumentType=ys.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.Timer,this._tmp.LeftArgumentType=ys.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.Time,this._tmp.LeftArgumentType=ys.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.DeviceState,this._tmp.LeftArgumentType=ys.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=ys.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.SceneExecuted,this._tmp.LeftArgumentType=ys.ArgumentAsConditionInfo,this._tmp.ConditionType=jo.Equal,this._tmp.AtMeetCondition=!0;const t=new gs;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=ys.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new _s;t.Channel=e.GetCheckDeviceState().Channel,t.ComparisonMethod=e.ComparisonMethod;let n={},r=e.GetComparisonParams().entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[$o[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case bt.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case bt.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case bt.LightBrightness:case bt.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case bt.RemoteButtonState:case bt.ChannelOnOffState:case bt.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[Yt[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case bt.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case bt.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case bt.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case bt.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.SmokeSensorState:throw new ps("Unsupported device state!");case bt.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case bt.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case bt.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.LightRGBWState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B,t.CheckedDeviceState.W=n.W;break}case bt.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case bt.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case bt.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case bt.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case bt.Unknown:t.CheckedDeviceState={};break;default:throw new ps("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case bt.BatteryState:return zo.BatteryState;case bt.BinarySensorState:return zo.BinarySensor;case bt.BlindPosition:return zo.BlindPosition;case bt.LightBrightness:return zo.LightBrightness;case bt.RemoteButtonState:return zo.ButtonState;case bt.ChannelOnOffState:return zo.ChannelOnOff;case bt.DoorBellState:return zo.DoorBell;case bt.MeasuredEnergy:return zo.Energy;case bt.FloodSensorState:return zo.FloodSensor;case bt.GatePosition:return zo.GatePosition;case bt.MeasuredBrightness:return zo.Brightness;case bt.LightColor:return zo.LightColor;case bt.LightWarmth:return zo.LightTemperature;case bt.ReedState:return zo.ReedState;case bt.SmokeSensorState:return zo.SmokeSensor;case bt.MeasuredTemperature:return zo.Temperature;case bt.HumiditySensorState:return zo.Humidity;case bt.BlindRemoteButtonState:return zo.BlindsControlButton;case bt.FacadeRemoteButtonState:return zo.FacadeControlButton;case bt.MovementSensorState:return zo.Movement;case bt.PressureSensorState:return zo.AirPressure;case bt.WindSpeedState:return zo.WindSpeed;case bt.CurrentWindThreshold:return zo.WindThreshold;default:return zo.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=ys.Null)return e(t.RightArgument,n);t.RightArgumentType=ys.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Cs)};null==this._result?(this._tmp.Name=this._sequenceName,this._tmp.Icon=this._sequenceIcon,this._result=this._tmp,this._result.AtMeetCondition=!0):e(this._result,this._tmp);const t=this._service.MapSequence(JSON.parse(JSON.stringify(this._tmp)));return this._tmp=new ws,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),SequenceData:t}}EditSequence(e){const t=(n,r)=>{if(n.Guid!=e||n.ObjectType!=ys.Condition){if(n.RightArgumentType==ys.Condition)return t(n.RightArgument,r);throw new Gs(`Cannot edit sequence with given GUID ${e} - sequence not foud in chain`)}n.AtMeetCondition=r.AtMeetCondition,n.ConditionTimeout=r.ConditionTimeout,n.ConditionType=r.ConditionType,n.ExecuteOnce=r.ExecuteOnce,n.HandledType=r.HandledType,n.IsDisabled=r.IsDisabled,n.LeftArgument=r.LeftArgument,n.LeftArgumentType=r.LeftArgumentType,n.ObjectType=r.ObjectType,n.Tasks=r.Tasks,r.Guid=n.Guid,r.Icon=n.Icon,r.Name=n.Name};if(null==this._result)throw new Gs(`Cannot edit sequence with given GUID ${e} - sequence not initialized (no root element)`);t(this._result,this._tmp);const n=this._service.MapSequence(JSON.parse(JSON.stringify(this._tmp)));return this._tmp=new ws,console.log(`new tmp guid: ${this._tmp.Guid}`),this._result.AtMeetCondition||(this._result.AtMeetCondition=!0),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),SequenceData:n}}RemoveSequenceByGuid(e){let t;const n=(e,n)=>{""==this._currentSeqGuid&&""==this._prevSeqGuid||(this._currentSeqGuid==n?(this._currentSeqGuid=e.RightArgumentType==ys.Condition?e.RightArgument.Guid:"",this._prevSeqGuid=null!=t?t.Guid:""):this._prevSeqGuid==n&&(this._prevSeqGuid=null!=t?t.Guid:""))},r=(e,o)=>{if(e.Guid!=o){if(t=e,e.RightArgumentType==ys.Null)throw new Gs(`Cannot remove sequence, sequence with given guid ${o} not found!`);return r(e.RightArgument,o)}null==t?this._result=null:(t.RightArgument=e.RightArgument,t.RightArgumentType=e.RightArgumentType),n(e,o)};if(null==this._result)throw new Gs("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=ys.Null?(this._result.RightArgument.Name=this._result.Name,this._result.RightArgument.Icon=this._result.Icon,this._result.RightArgument.Guid=this._result.Guid,this._result=this._result.RightArgument,this._result.AtMeetCondition=!0,n(this._result,e)):r(this._result,e),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),SequenceData:null}}Commit(){const e=t=>{if(t.RightArgumentType!=ys.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new Gs("Sequence are not initialized! Not found root sequence.");return this._editingExistingSequence&&e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}DeviceTask(e){if(this._tmpTask=this.ParseDeviceTask(e),null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(this._tmpTask))}}ParseDeviceTask(e){const t=new Ds;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==Et.SetBlindPosition||e instanceof to?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==Et.SetBlindPositionSimple||e instanceof ro?(t.Data.Action=e.Action,t.Data.Position=0):e.TaskType==Et.SetLightColor||e instanceof Zr?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==Et.SetLightTemperature||e instanceof eo?t.Data.Temperature=e.Temperature:e.TaskType==Et.SetLightBrightness||e instanceof Yr?t.Data.Brightness=e.Brightness:e.TaskType==Et.SetTemperature||e instanceof jr?t.Data.Temperature=e.Temperature:e.TaskType==Et.TurnOnWithTime||e instanceof Xr?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==Et.SetLightBrightnessDynamicly||e instanceof oo?t.Data.Brightness=e.Brightness:e.TaskType==Et.SetBlindOpenCloseTime||e instanceof io?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==Et.SetBlindMicroventilation||e instanceof uo?t.Data.Position=e.Position:e.TaskType==Et.SetFacadePosition||e instanceof go?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):e.TaskType==Et.LightRGBW||e instanceof vo?(t.Data.R=e.Data.R,t.Data.G=e.Data.G,t.Data.B=e.Data.B,t.Data.W=e.Data.W,t.Data.Brightness=e.Data.Brightness):(e.TaskType==Et.PreciseGateControl||e instanceof no)&&(t.Data.Position=e.Position,t.Data.GateControlAction=e.GateControlAction),t}DelayTask(e){const t=new ks;if("00:00:00"==e.Delay.Value)throw new Is("Delay must be other than 00:00:00!");if(t.Delay=e.Delay.Value,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(t))}}NotifyTask(e){if(e.NotifyType==Qo.Email)throw new Rs("NotifyType 'Email' is not supported!");if(e.NotifyType==Qo.None)throw new Error("NotifyType mus be set!");if(""==e.Message)throw new Is("Message must be set!");if(e.Message.length>1e3)throw new Is("Message is too long! Max length is 1000 characters.");const t=new bs;if(t.NotifyType=e.NotifyType,t.Message=e.Message,t.NotificationClients=e.NotificationClients,t.Title=this._sequenceName,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(t))}}LockExecutionTask(e){const t=new Es;if(t.LockType=e.LockType,t.LockType==Zo.Timeout&&"00:00:00"!=t.LockEndHour)throw new Rs("Parameter LockEndHour at lock type `Timeout` must be default!");if(t.LockStartHour=e.LockStartHour.Value,t.LockEndHour=e.LockEndHour.Value,t.ResetLockScenesGuids=e.ResetLockScenesGuids,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(t))}}AddTask(){const e=t=>{var n;if(t.RightArgumentType!=ys.Null)return e(t.RightArgument);if(null==this._tmpTask)throw Error("No task context!");void 0!==t.Tasks.DevicesTasks&&null!==t.Tasks.DevicesTasks||(t.Tasks.DevicesTasks=[]),this._tmpTask instanceof Ds&&t.Tasks.DevicesTasks.push(structuredClone(this._tmpTask)),t.Tasks.ControllerTasks.push(structuredClone(this._tmpTask)),this._tmpTask=null,null===(n=u.Log)||void 0===n||n.Debug(`Task added to sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(t.Tasks)}`)};if(null==this._result)throw new Error("No context!");return e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}EditTask(e){const t=n=>{var r;if(n.RightArgumentType!=ys.Null)return t(n.RightArgument);if(null==this._tmpTask)throw Error("No task context!");if(null==n.Tasks.ControllerTasks||0==n.Tasks.ControllerTasks.length)throw new Ns("Task not found, cannot edit!");this._tmpTask instanceof Ds&&null!=n.Tasks.DevicesTasks&&(n.Tasks.DevicesTasks=n.Tasks.DevicesTasks.map((t=>oe.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t))),n.Tasks.ControllerTasks=n.Tasks.ControllerTasks.map((t=>oe.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t)),this._tmpTask=null,null===(r=u.Log)||void 0===r||r.Debug(`Task edited in sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(n.Tasks)}`)};if(null==this._result)throw new Error("No context!");return t(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}RemoveTask(e){const t=(e,n)=>{var r,o;if(e.RightArgumentType!=ys.Null)return t(e.RightArgument,n);{const t=e.Tasks.ControllerTasks.filter((e=>oe.GenerateMd5(JSON.stringify(e))!=n));if(e.Tasks.ControllerTasks=null==t?[]:t,null===(o=null===(r=e.Tasks)||void 0===r?void 0:r.DevicesTasks)||void 0===o?void 0:o.any()){const t=e.Tasks.DevicesTasks.filter((e=>oe.GenerateMd5(JSON.stringify(e))!=n));e.Tasks.DevicesTasks=null==t?[]:t}}};if(null==this._result)throw Error("Cannot remove task, sequence not configured!");t(this._result,e)}MapTaskTypeToControlFeature(e){switch(e){case Et.Unknown:throw new Is("Unsupported task type!");case Et.SetBlindPosition:case Et.SetBlindPositionSimple:return Ur.SetBlindPosition;case Et.SetBlindMicroventilation:return Ur.SetBlindMicroventilation;case Et.TurnOff:return Ur.TurnOff;case Et.TurnOn:return Ur.TurnOn;case Et.TurnOnWithTime:return Ur.TurnOnWithTimeout;case Et.TogleState:return Ur.ToggleState;case Et.SetLightBrightnessDynamicly:return Ur.SetLightBrightnessDynamicly;case Et.SetLightBrightness:return Ur.SetLightBrightness;case Et.SetLightColor:return Ur.SetLightColor;case Et.SetLightTemperature:return Ur.SetLightTemperature;case Et.PairDevice:case Et.UnpairDevice:throw new Is("Unsupported task type!");case Et.IdentifyDevice:return Ur.IdentifyDevice;case Et.GetChannelsState:return Ur.GetState;case Et.GetPowerMeasurements:case Et.GetAvailableData:case Et.MultipleDataRequest:throw new Is("Unsupported task type!");case Et.SetBlindOpenCloseTime:return Ur.SetBlindOpenCloseTime;case Et.SetTemperature:return Ur.SetTemperature;case Et.ChangeGatePositionPulse:return Ur.GatePulse;case Et.ChangeGatewayPositionPulse:return Ur.GatewayPulse;case Et.SetFacadePosition:case Et.GetFacadeType:return Ur.SetFacadePositionAndTilt;case Et.LightRGBW:return Ur.LightRGBW;case Et.PreciseGateControl:return Ur.SetGatePositionPrecise;default:throw new Is("Unsupported task type!")}}GetSupportedTaskTypesAsync(){return e=this,t=void 0,r=function*(){const e=yield Qv.Get(os.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Yo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Yo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Yo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Yo.NotifyTaskAppNotify),r},new((n=void 0)||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}));var e,t,n,r}Build(){const e=t=>{if(t.RightArgumentType!=ys.Null)return e(t.RightArgument);t.Tasks.ControllerTasks=t.Tasks.ControllerTasks.map((e=>(Object.hasOwn(e,"_taskGuid")&&delete e._taskGuid,e)))};if(null!=this._result)return e(this._result),this._result;throw Error("Cannot build sequence, sequence not configured!")}FindArgumentWithGuid(e,t){return e.Guid==t?e:e.RightArgumentType==ys.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}GetAllowedArguments(){const e=[];return null==this._result?(e.push({ArgumentType:vs.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1})):null!=this._result&&(null==this._result.RightArgument||this._result.RightArgument instanceof Ss)&&(this._result.LeftArgumentType==ys.ArgumentAsDaysOfWeek&&(e.push({ArgumentType:vs.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),e.push({ArgumentType:vs.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0})),this._result.LeftArgumentType==ys.ArgumentAsTime&&e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1}),this._result.LeftArgumentType==ys.ArgumentAsAstronomicalClockWithOffset&&e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1})),0==e.any((e=>e.ArgumentType==vs.ArgumentAsAstronomicalClockWithOffset))&&e.push({ArgumentType:vs.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsDaysOfWeek))&&e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsDeviceState))&&e.push({ArgumentType:vs.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsSceneExecuted))&&e.push({ArgumentType:vs.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsTime))&&e.push({ArgumentType:vs.ArgumentAsTime,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsTimeSpan))&&e.push({ArgumentType:vs.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e}ValidateScene(){var e,t,n,r;if(null==this._result)throw new Error("No context!");const o=[],s=(e,t,n)=>e.RightArgumentType==ys.Null?e.LeftArgumentType==t&&e.AtMeetCondition==n?e:null:e.LeftArgumentType==t&&e.AtMeetCondition==n?e:s(e.RightArgument,t,n),i=s(this._result,ys.ArgumentAsDaysOfWeek,!0);null!=i&&((null===(e=i.RightArgument)||void 0===e?void 0:e.LeftArgumentType)==ys.ArgumentAsTime||(null===(t=i.RightArgument)||void 0===t?void 0:t.LeftArgumentType)==ys.ArgumentAsAstronomicalClockWithOffset)&&o.push(fs.OptimizeDayOfWeekArgument);const a=s(this._result,ys.ArgumentAsTime,!0);return null!=a&&(null===(n=a.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ys.ArgumentAsDaysOfWeek&&(null===(r=a.RightArgument)||void 0===r?void 0:r.AtMeetCondition)&&o.push(fs.OptimizeAtInDayOfWeekArgument),{IsValid:0==o.length,Errors:o,TryFix:()=>this.TryFix(o),Ignore:()=>this.Commit()}}TryFix(e){if(null==this._result)throw new Error("No context!");if(e.includes(fs.OptimizeDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ys.ArgumentAsDaysOfWeek?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ys.ArgumentAsTime||(null===(r=t.RightArgument)||void 0===r?void 0:r.LeftArgumentType)==ys.ArgumentAsAstronomicalClockWithOffset?t:e(t.RightArgument):t.RightArgumentType==ys.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)throw new Error("Something wrong! Cannot find 'days of week' argument! Cannot fix!");const n=structuredClone(t),r=t.RightArgument;t.LeftArgument=r.LeftArgument,t.LeftArgumentType=r.LeftArgumentType,t.HandledType=r.HandledType,r.LeftArgument=n.LeftArgument,r.LeftArgumentType=n.LeftArgumentType,r.HandledType=n.HandledType,r.AtMeetCondition=!1}if(e.includes(fs.OptimizeAtInDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ys.ArgumentAsTime?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ys.ArgumentAsDaysOfWeek&&(null===(r=t.RightArgument)||void 0===r?void 0:r.AtMeetCondition)?t:e(t.RightArgument):t.RightArgumentType==ys.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)throw new Error("Something wrong! Cannot find 'time' argument! Cannot fix!");t.RightArgument.AtMeetCondition=!1}return this.Commit()}}!function(e){e.OptimizeDayOfWeekArgument="OptimizeDayOfWeekArgument",e.OptimizeAtInDayOfWeekArgument="OptimizeAtInDayOfWeekArgument"}(fs||(fs={})),function(e){e.Unknown="Unknown",e.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",e.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",e.ArgumentAsTimeSpan="ArgumentAsTimeSpan",e.ArgumentAsTime="ArgumentAsTime",e.ArgumentAsDeviceState="ArgumentAsDeviceState",e.ArgumentAsSceneExecuted="ArgumentAsSceneExecuted"}(vs||(vs={}));class ws{constructor(){this.Tasks=new Cs,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=Ko.Unknown,this.ConditionType=jo.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=ys.Null,this.RightArgumentType=ys.Null,this.LeftArgument=new As({},ys.Null),this.RightArgument=new Ss}}class Ss{constructor(){this.HandledType=0,this.Argument=null}}class As{constructor(e,t){this.Argument=e,this.HandledType=t}}class _s{constructor(){this.DeviceStateType=zo.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=Wo.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Cs{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Ts{constructor(){this.Guid=Hr.NewGuid(),this.RunParallel=!1,this.TaskType=Vo.Unknown}}class Ds extends Ts{constructor(){super(...arguments),this.TaskType=Vo.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=Ur.TurnOn}}class ks extends Ts{constructor(){super(...arguments),this.TaskType=Vo.DelayTask,this.Delay="00:00:00"}}class Es extends Ts{constructor(){super(...arguments),this.TaskType=Vo.LockExecution,this.LockType=Zo.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}class bs extends Ts{constructor(){super(...arguments),this.TaskType=Vo.NotifyTask,this.Title="",this.Message="",this.NotifyType=Qo.None,this.NotificationClients=[]}}!function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(ys||(ys={}));class Is extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class Gs extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class Ns extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class Rs extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var Ps,Os,Us=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ms{constructor(){this._connection=Qv.Get(_t.ServiceName),this._configurationService=Qv.Get(it.ServiceName)}GetServiceName(){return Ms.ServiceName}GetSequencesListAsync(){return Us(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new xs,12e3,!1);return null===(t=u.Log)||void 0===t||t.Debug(`GetSequencesListAsync result:\n ${JSON.stringify(n)}}`),null==n?new Ee(Bo.OtherError,"Cannot get sequences list - response is null."):n.Status!=ce.OK?new Ee(Bo.OtherError,`Cannot get sequences list - controller responded with response code ${n.Status}.`):null==n.Data?new Ee(Bo.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):n.Data}))}GetSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Fs(n),12e3,!1);if(null==r)return new Ee(Bo.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ce.OK)return new Ee(Bo.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Ee(Bo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");const o=r.Data;let s=this.MapSequence(o);if("string"==typeof e){let e=yield this.GetSequencesListAsync();if(e instanceof Ee){let t=e;console.warn(`Cannot get sequence - response is null. Error: ${t.Data} ${t.Type}`)}else{const t=e.find((e=>e.Guid==n));if(!t)return new Ee(Bo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");s.IsDisabled=t.IsDisabled}}else{const e=o;s.IsDisabled=e.IsDisabled}return s}))}GetSequenceBuilder(e,t){return new ms(e,t)}CreateSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t,n,r,o;try{yield this._configurationService.EnterConfigurationModeAsync(),null===(t=u.Log)||void 0===t||t.Debug(`Creating sequence ${e.Name} json: \n${JSON.stringify(e)}`);const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new $s(e),2e4,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(t){return null===(r=u.Log)||void 0===r||r.Error(`Creating sequence ${e.Name} error: ${t}`),ce.FatalError}finally{null===(o=u.Log)||void 0===o||o.Error(Ms.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! CreateSequenceAsync()"),yield this._configurationService.ExitConfigurationModeAsync(),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(!0)}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;try{let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ls(n),12e3,!1);if(null==r)return new Ee(Bo.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ce.WrongData:return new Ee(Bo.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ce.OK:return null==r.Data?new Ee(Bo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Ee(Bo.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Ee(Bo.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;try{let n="";n="string"==typeof e?e:e.Guid,yield this._configurationService.EnterConfigurationModeAsync();const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Vs(n),12e3,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(e){return ce.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(!0)}}))}EditSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t,n;try{const n={Guid:e.Guid,Icon:e.Icon,Name:e.Name,Condition:e};var r=n.Condition.IsDisabled;n.Condition.IsDisabled=!1,yield this._configurationService.EnterConfigurationModeAsync();const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new qs(n),2e4,!1);return n.Condition.IsDisabled=r,null==o||null==o.Status?ce.Error:o.Status}catch(t){return null===(n=u.Log)||void 0===n||n.Error(`Editing sequence ${e.Name} error: ${t}`),ce.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(!0)}}))}EnableSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Hs(n),12e3,!1);return yield this._configurationService.ExitConfigurationModeAsync(),null==r||null==r.Status?ce.Error:r.Status}))}DisableSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ks(n),12e3,!1);return yield this._configurationService.ExitConfigurationModeAsync(),null==r||null==r.Status?ce.Error:r.Status}))}RunSequenceAsync(e){return Us(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ce.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ce.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new Jr;switch(n.Channel=1,n.DeviceGuid=t,yield Qv.Get(Ys.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case Pt.Executed:return ce.OK;case Pt.DeviceNotFound:return ce.WrongData;default:return ce.Error}}))}GetUtilsAsync(){return Us(this,void 0,void 0,(function*(){const e=yield this.SunCalculatorAsync();return{GetSunRiseTime:e.GetSunRiseTime,GetSunSetTime:e.GetSunSetTime,ParseLinearScaleToLux:this._parseLinearScaleToLux,ParseLuxToLinearScale:this._parseLuxToLinearScale}}))}_parseLinearScaleToLux(e){if(!(e<0||e>1))return Math.round(Math.pow(10,5*e))}_parseLuxToLinearScale(e){if(e<=0)return 0;const t=Math.log10(e)/5;return t>1?1:t}SunCalculatorAsync(){return Us(this,void 0,void 0,(function*(){var e;const t=Qv.Get(Ro.ServiceName),n=new Eo;let r=!1;n.Latitude=49.9958888026741,n.Longitude=18.9172596008914;try{if(yield t.IsControllerGeolocationSetAsync()){const e=yield t.GetControlllerGeolocationAsync();e instanceof bo&&(n.Latitude=e.Latitude,n.Longitude=e.Longitude)}}catch(t){null===(e=u.Log)||void 0===e||e.Warning(`Cannot get localization data, using default values: 49.9958888026741, 18.9172596008914. Error: ${t}`)}const o=e=>{let t=7.95204*Math.sin(.01768*e+3.03217)+9.98906*Math.sin(.03383*e+3.4687)+4*(n.Longitude-15*Math.round(n.Longitude/15));return((e=new Date)=>{const t=new Date(e.getFullYear(),0,1).getTimezoneOffset(),n=new Date(e.getFullYear(),6,1).getTimezoneOffset();return Math.max(t,n)!==e.getTimezoneOffset()})()&&(t-=60),t},s=e=>Math.asin(-.39795*Math.cos(2*Math.PI*(e+10)/365)),i=e=>{const t=n.Latitude*Math.PI/180;let r=Math.sin(t)*Math.sin(e)/(Math.cos(t)*Math.cos(e));return r=(e=>(e<-1&&(e=-1),e>1&&(e=1),e))(r),r},a=e=>{const t=Math.ceil(e/60),n=e-60*t,r=new Date;return new Date(r.getFullYear(),r.getMonth(),r.getDate(),t,n)},c=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(u=t,Math.floor((u.valueOf()-new Date(u.getFullYear(),0,0).valueOf())/1e3/60/60/24));var u;const l=o(n),d=s(n),h=((e,t)=>{let n=720-720/Math.PI*Math.acos(-e)-t;return n<0&&(n+=1440),n})(i(d),l),g=a(h);return new Date>g&&!r?(r=!0,c(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))},l=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(c=t,Math.floor((c.valueOf()-new Date(c.getFullYear(),0,0).valueOf())/1e3/60/60/24));var c;const u=o(n),d=s(n),h=i(d),g=Math.floor(((e,t)=>{let n=720+720/Math.PI*Math.acos(-e)-t;return n>1439&&(n-=1439),n})(h,u)),p=a(g);return new Date>p&&!r?(r=!0,l(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>l(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=Ps.Null)return!Object.hasOwn(e.Tasks,"ControllerTasks")&&Object.hasOwn(e.Tasks,"DevicesTasks")&&delete Object.assign(e.Tasks,{ControllerTasks:e.Tasks.DevicesTasks}).DevicesTasks,r(e.RightArgument);!Object.hasOwn(e.Tasks,"ControllerTasks")&&Object.hasOwn(e.Tasks,"DevicesTasks")&&(delete Object.assign(e.Tasks,{ControllerTasks:e.Tasks.DevicesTasks}).DevicesTasks,e.Tasks.ControllerTasks.map((e=>{e.TaskType=Vo.DeviceTask,e.RunParallel=!1}))),null!=e.Tasks.ControllerTasks&&e.Tasks.ControllerTasks.map((e=>{null==(null==e?void 0:e.Guid)&&(e.Guid=Hr.NewGuid())}))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=Xo.Null):(n.RightArgumentType=this.MapArgumentType(e.RightArgumentType),n.RightArgument=this.MapRightArgument(e.RightArgument,n.RightArgumentType)),n.LeftArgumentType=this.MapArgumentType(e.LeftArgumentType),n.LeftArgument=this.MapLeftArgument(e.LeftArgument,n.LeftArgumentType),n.Tasks.ControllerTasks=this.MapControllerTasks(e.Tasks.ControllerTasks),void 0===n.DoesHaveTriggers&&(n.DoesHaveTriggers=n.LeftArgumentType==Xo.Null),n}MapRightArgument(e,t){return 0==e.HandledType||(e.LeftArgumentType=this.MapArgumentType(e.LeftArgumentType),e.LeftArgument=this.MapLeftArgument(e.LeftArgument,e.LeftArgumentType),e.Tasks.ControllerTasks=this.MapControllerTasks(e.Tasks.ControllerTasks),Object.hasOwn(e.Tasks,"DevicesTasks")&&delete e.Tasks.DevicesTasks,t===Xo.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new Bs;switch(n.HandledType=e.HandledType,t){case Xo.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case Xo.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case Xo.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case Xo.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case Xo.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case Xo.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case Xo.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case Xo.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case Xo.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case Xo.ArgumentAsDeviceState:{const t=new ls;t.Type=this.MapDeviceStateTypeToResponseType(e.Argument.DeviceStateType),t.SetCheckDeviceState(this.CreateDeviceState(e.Argument.CheckedDeviceState,e.Argument.Channel,t.Type)),t.DeviceGuid=e.Argument.DeviceGuid,t.ComparisonMethod=null==e.Argument.ComparisonMethod?Wo.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam($o[e[0]],new ds(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam($o[e[0]],new hs(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case Xo.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return Xo[Ps[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case zo.BatteryState:return bt.BatteryState;case zo.BinarySensor:return bt.BinarySensorState;case zo.BlindPosition:return bt.BlindPosition;case zo.Brightness:return bt.MeasuredBrightness;case zo.ButtonState:return bt.RemoteButtonState;case zo.ChannelOnOff:return bt.ChannelOnOffState;case zo.DoorBell:return bt.DoorBellState;case zo.Energy:return bt.MeasuredEnergy;case zo.FloodSensor:return bt.FloodSensorState;case zo.GatePosition:return bt.GatePosition;case zo.LightBrightness:return bt.LightBrightness;case zo.LightColor:return bt.LightColor;case zo.LightTemperature:return bt.LightWarmth;case zo.ReedState:return bt.ReedState;case zo.SmokeSensor:return bt.SmokeSensorState;case zo.Temperature:return bt.MeasuredTemperature;case zo.Humidity:return bt.HumiditySensorState;case zo.BlindsControlButton:return bt.BlindRemoteButtonState;case zo.FacadeControlButton:return bt.FacadeRemoteButtonState;case zo.Movement:return bt.MovementSensorState;case zo.AirPressure:return bt.PressureSensorState;case zo.WindSpeed:return bt.WindSpeedState;case zo.WindThreshold:return bt.CurrentWindThreshold;default:return bt.Unknown}}CreateDeviceState(e,t,n){switch(n){case bt.BatteryState:return{Channel:t,StateReliability:qt.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case bt.BinarySensorState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.BlindPosition:return{Channel:t,StateReliability:qt.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case bt.LightBrightness:case bt.MeasuredBrightness:return{Channel:t,StateReliability:qt.Unconfident,Brightness:e.Brightness,Time:""};case bt.RemoteButtonState:case bt.ChannelOnOffState:case bt.DoorBellState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(Yt[t],r);return{Channel:t,StateReliability:qt.Unconfident,MeasurementParameters:n,Time:""}}case bt.FloodSensorState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.GatePosition:return{Channel:t,StateReliability:qt.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case bt.LightColor:return{Channel:t,StateReliability:qt.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case bt.LightWarmth:return{Channel:t,StateReliability:qt.Unconfident,Temperature:e.Temperature,Time:""};case bt.ReedState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.SmokeSensorState:throw new ps("Unsupported device state!");case bt.MeasuredTemperature:return{Channel:t,StateReliability:qt.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case bt.HumiditySensorState:return{Channel:t,StateReliability:qt.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case bt.BlindRemoteButtonState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.LightRGBWState:return{StateReliability:qt.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case bt.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,State:e.State};case bt.MovementSensorState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case bt.PressureSensorState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case bt.WindSpeedState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Value:e.Value};case bt.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:qt.Unconfident,WindThreshold:e.WindThreshold};case bt.Unknown:return new An;default:throw new ps("Unsupported device state!")}}MapDeviceTask(e){var t;let n=new Kr,r=e;switch(null===(t=u.Log)||void 0===t||t.Debug(`[TASK] object: ${JSON.stringify(r)}`),r.ControlFeature){case Ur.TurnOn:n=new Jr,n.TaskType=Et.TurnOn;break;case Ur.TurnOff:n=new zr,n.TaskType=Et.TurnOff;break;case Ur.ToggleState:n=new Qr,n.TaskType=Et.TogleState;break;case Ur.SetBlindPosition:{const e=Qv.Get(Ys.ServiceName).GetDevice(r.DeviceGuid);(null==e?void 0:e.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType)))?(n=new ro,n.TaskType=Et.SetBlindPositionSimple,n.Action=r.Data.Action):(n=new to,n.TaskType=Et.SetBlindPosition,n.Action=r.Data.Action,n.Position=r.Data.Position);break}case Ur.SetLightColor:n=new Zr,n.TaskType=Et.SetLightColor,n.R=r.Data.R,n.G=r.Data.G,n.B=r.Data.B;break;case Ur.SetLightTemperature:n=new eo,n.TaskType=Et.SetLightTemperature,n.Temperature=r.Data.Temperature;break;case Ur.SetLightBrightness:n=new Yr,n.TaskType=Et.SetLightBrightness,n.Brightness=r.Data.Brightness;break;case Ur.SetTemperature:n=new jr,n.TaskType=Et.SetTemperature,n.Temperature=r.Data.Temperature;break;case Ur.GetState:n=new co,n.TaskType=Et.GetChannelsState;break;case Ur.TurnOnWithTimeout:n=new Xr,n.TaskType=Et.TurnOnWithTime,n.SwitchOffDelaySeconds=r.Data.SwitchOffDelaySeconds;break;case Ur.SetLightBrightnessDynamicly:n=new oo,n.TaskType=Et.SetLightBrightnessDynamicly,n.Brightness=r.Data.Brightness;break;case Ur.IdentifyDevice:n=new so,n.TaskType=Et.IdentifyDevice;break;case Ur.SetBlindOpenCloseTime:n=new io,n.TaskType=Et.SetBlindOpenCloseTime,n.Data.CloseTime=r.Data;break;case Ur.SetBlindMicroventilation:n=new uo,n.TaskType=Et.SetBlindMicroventilation,n.Position=r.Data.Position;break;case Ur.GatewayPulse:n=new ho,n.TaskType=Et.ChangeGatewayPositionPulse;break;case Ur.GatePulse:n=new lo,n.TaskType=Et.ChangeGatePositionPulse;break;case Ur.SetFacadePositionAndTilt:n=new go,n.TaskType=Et.SetFacadePosition,n.Position=r.Data.Position,n.Tilt=r.Data.Tilt,n.FacadeAction=Lr.TiltAndPercentage;break;case Ur.GetFacadeType:n=new po,n.TaskType=Et.GetFacadeType;break;case Ur.LightRGBW:n=new vo,n.TaskType=Et.LightRGBW,n.Data=r.Data;break;case Ur.SetGatePositionPrecise:n=new no,n.TaskType=Et.PreciseGateControl,n.Position=r.Data.Position,n.GateControlAction=r.Data.GateControlAction}return n.Channel=r.Channel,n.DeviceGuid=r.DeviceGuid,n.FeatureType=r.ControlFeature,n.Guid=Hr.NewGuid(),n}MapControllerTasks(e){var t,n;const r=[];null===(t=u.Log)||void 0===t||t.Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let t of e){const e=new Ws;switch(e.Guid=t.Guid,e.TaskId=oe.GenerateMd5(JSON.stringify(t)),t.TaskType){case Vo.DeviceTask:e.TaskType=Ho.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(t);break;case Vo.DelayTask:e.TaskType=Ho.DelayTask,e.Task.DelayTask={Delay:new hs(t.Delay)};break;case Vo.NotifyTask:e.TaskType=Ho.NotifyTask,e.Task.NotifyTask={Message:t.Message,NotifyType:t.NotifyType,NotificationClients:t.NotificationClients};break;case Vo.LockExecution:case Vo.LockExecution:e.TaskType=Ho.LockExecution,null===(n=u.Log)||void 0===n||n.Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(t)}`),e.Task.LockExecution={LockStartHour:new hs(t.LockStartHour),LockEndHour:new hs(t.LockEndHour),LockType:t.LockType,ResetLockScenesGuids:t.ResetLockScenesGuids};case Vo.Unknown:}r.push(e)}return r}GetSupportedTaskTypesAsync(){return Us(this,void 0,void 0,(function*(){const e=yield Qv.Get(os.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Yo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Yo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Yo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Yo.NotifyTaskAppNotify),r}))}}Ms.ServiceName="ScenesService";class xs extends ae{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=ue.Get}}class Fs extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Get,this.Data=e}}class Ls extends ae{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=ue.Get,this.Data=e}}class Bs{constructor(){this.HandledType=Ps.Null,this.Argument={}}}!function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(Ps||(Ps={}));class Ws{constructor(){this.TaskId="",this.Guid="",this.TaskType=Ho.Unknown,this.Task={}}}class $s extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Put,this.Data=e}}class qs extends ae{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=ue.Put,this.Data=e}}class Vs extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Delete,this.Data=e}}class Hs extends ae{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=ue.Post,this.Data=e}}class Ks extends ae{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=ue.Post,this.Data=e}}!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"}(Os||(Os={}));class js{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}var zs=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Js{constructor(){this._isConnectedAndAuthorized=!1,this._syncLock=new js,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=Os.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new De,this._onSuspendedEvent=new De,this._onEnterLowPowerModeEvent=new De,this._onExitLowPowerModeEvent=new De,this._onBackButtonPressedEvent=new De,this._onForwardButtonPressedEvent=new De,this._onAppStateChanged=new a,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>zs(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,r,o;document.location,e.state&&("forward"==e.state.direction?(null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=u.Log)||void 0===r||r.Warning(Js.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return zs(this,void 0,void 0,(function*(){this._session=yield Qv.GetAsync("SessionService"),this._connection=yield Qv.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(Os.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(Os.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,o,s,i;switch(e){case he.ConnectedAndAuthorized:null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App state changed to: connected"),this._isConnectedAndAuthorized=!0,this._onAppStateChanged.Invoke(Os.Connected);break;case he.Disconnected:null===(n=u.Log)||void 0===n||n.Warning(Js.ServiceName,"App state changed to: disconnected"),this._isConnectedAndAuthorized&&this._onAppStateChanged.Invoke(Os.Disconnected),this._isConnectedAndAuthorized=!1;break;case he.Connecting:null===(r=u.Log)||void 0===r||r.Warning(Js.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(Os.Connecting);break;case he.Disconnecting:null===(o=u.Log)||void 0===o||o.Warning(Js.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(Os.Disconnecting);break;case he.Reconnecting:null===(s=u.Log)||void 0===s||s.Warning(Js.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(Os.Reconnecting);break;case he.Failed:null===(i=u.Log)||void 0===i||i.Warning(Js.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(Os.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(Os.Suspended),null===(e=u.Log)||void 0===e||e.Warning(Js.ServiceName,"App state changed to: suspended"),null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(Os.ReturnedFromSuspension),null===(e=u.Log)||void 0===e||e.Warning(Js.ServiceName,"App state changed to: returned from suspension"),null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Os.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Os.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 Js.ServiceName}}Js.ServiceName="AppStateService";var Xs=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ys{constructor(){this._devices=[],this._onDevicesTasksChangedEvent=new a,this._onDeviceFoundEvent=new a,this._onDeviceRegisteredEvent=new a,this._onDeviceRemovedEvent=new a,this._onDeviceFirmwareVersionChangedEvent=new a,this._onDeviceStateChangedEvent=new a,this._onDeviceStateRefreshedOrChangedEvent=new a,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=Qv.Get(_t.ServiceName),this._session=Qv.Get(Je.ServiceName),this._controllerConfiguration=Qv.Get(it.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>Xs(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=>Xs(this,void 0,void 0,(function*(){var t;try{this._devices=yield this.GetPairedDevicesAsync(!0)}catch(e){null===(t=u.Log)||void 0===t||t.Error(Ys.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=>Xs(this,void 0,void 0,(function*(){var t;try{yield this.WaitForSynchronizationAsync(),yield this.SyncDevicesStatesAsync()}catch(e){null===(t=u.Log)||void 0===t||t.Error(Ys.ServiceName,`Failed to sync devices states: ${e}`)}this._synchronizedDevicesStates=!0,e()}))))})),Qv.Get(Js.ServiceName).OnAppStateChanged().Subscribe((e=>Xs(this,void 0,void 0,(function*(){switch(e){case Os.ReturnedFromSuspension:Qv.Get(_t.ServiceName).IsConnected()&&1==this._synchronizedDevicesStates&&this.SyncDevicesStatesAsync();break;case Os.Disconnected:break;case Os.Connected:1==this._synchronizedDevicesStates&&this.SyncDevicesStatesAsync()}})))),this._connection.SubscribeTo("/info/devices/tasks",(e=>{this.ParseDeviceTaskInfo(e.Data)})),this._connection.SubscribeTo("/info/devices/device/found",(e=>{this.MapApiDevices(e.Data).forEach((e=>{var t;e.DeviceType!=Nt.Scene&&(null===(t=u.Log)||void 0===t||t.Debug(Ys.ServiceName,`Found device: ${e.Name} guid: ${e.Guid}`),this._onDeviceFoundEvent.Invoke(e))}))})),this._connection.SubscribeTo("/info/devices/device/firmware/updated",(e=>{const t=e.Data.DeviceGuid,n=e.Data.Version,r=this._devices.find((e=>e.Guid==t));void 0!==r&&(this._onDeviceFirmwareVersionChangedEvent.Invoke({Device:r,FirmwareVersion:n}),r.SoftwareVersion=n,r.OnDeviceFirmwareVersionChangedEvent().Invoke({FirmwareVersion:n}))})),this._connection.SubscribeTo("/info/devices/device/state/changed",(e=>{var t;const n=e.Data,r=this._devices.filter((e=>e.Guid==n.DeviceGuid));if(r.length>0){const e=r[0],o=this.MapApiDeviceStateToDeviceState(e,n);if(null!=o){this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==bt.SignalStrength?e.Channels.forEach((t=>{let r=new rr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==bt.BatteryState&&e.Channels.forEach((t=>{let r=new Vn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})}));let r=e.States.find((e=>e.TypeAsEnum===o.TypeAsEnum&&e.Data.Channel===o.Data.Channel));if(r){let s=r.StatesComparisonData;if(o.TypeAsEnum==bt.BlindErrorState&&(null===(t=o.Data)||void 0===t?void 0:t.ErrorCode)!=r.Data.ErrorCode)return void this._onDeviceStateChangedEvent.Invoke({Device:e,State:o});r.Data=o.Data,s!==o.StatesComparisonData&&(this._onDeviceStateChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==bt.SignalStrength?e.Channels.forEach((t=>{let r=new rr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==bt.BatteryState&&e.Channels.forEach((t=>{let r=new Vn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})))}else e.States.push(o),this._onDeviceStateChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==bt.SignalStrength?e.Channels.forEach((t=>{let r=new rr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==bt.BatteryState&&e.Channels.forEach((t=>{let r=new Vn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Ys.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Ys.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}ProtocolGuidToProtocolName(e){switch(e){case"1fca7e8a-a2dc-4883-bd94-4e9b2012f685":return"ExtaLife";case"cd25bdff-628c-4dbc-a16a-648c96a819d4":return"Portos 433MHz";case"634c2bb2-1a4f-4db6-8dd4-d5fbaf92678e":return"Supla";case"194aeb81-990c-4a02-9236-59e902958fda":return"RTSP";case"b3e4644e-ab5b-494e-b3c5-66fabe7fff64":return"Wekta";case"247198e1-e360-4355-9886-232ac1456eea":return"Lavva Wi-Fi";default:return null}}CanDisplaySceneDevices(){return this.CheckIfControllerSoftwareVersionIsEnough(6,56)}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,o;const s=null!==(o=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==o?o:null;if(!s||!s.includes("."))return!1;const i=s.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}CheckIfDeviceUsedInScenesAsync(e){return Xs(this,void 0,void 0,(function*(){var t,n,r,o,s,i;try{let i;if("string"==typeof e){const n=this.GetDevice(e);if(null==n)return null===(t=u.Log)||void 0===t||t.Error("Cannot check if device is used in scenes! Device with given guid not exists"),ce.ResourceDoesNotExists;i=n}else i=e;const c=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new di(i.Guid),2e4,!1);if(null==c||null==c.Status)return null===(r=u.Log)||void 0===r||r.Error("Cannot check if device is used in scenes! Response or status is null!"),ce.FatalError;if(c.Status!=ce.OK)return c.Status;if(null==c.Data)return null===(o=u.Log)||void 0===o||o.Error("Cannot check if device is used in scenes! No data!"),ce.FatalError;var a=yield Qv.Get(Ms.ServiceName).GetSequencesListAsync();if(a instanceof Ee)return null===(s=u.Log)||void 0===s||s.Error(`Cannot check if device is used in scenes! Cannot get sequence list, ScenesServiceErrorCode: ${a.Type}`),ce.Error;const l=new fi;return l.DeviceGuid=i.Guid,c.Data.ConditionsAsCondition.forEach((e=>{const t=a.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),c.Data.ConditionsAsTask.forEach((e=>{const t=a.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),l}catch(e){return null===(i=u.Log)||void 0===i||i.Error(`Cannot check if device is used in scenes! ${e}`),ce.FatalError}}))}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)>=pe.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)>=pe.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return Xs(this,void 0,void 0,(function*(){var e;const t=Qv.Get(_o.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return null===(e=u.Log)||void 0===e||e.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EnableFastStatesSyncAsync()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),t}))}DisableFastStatesSyncAsync(){return Xs(this,void 0,void 0,(function*(){var e;const t=Qv.Get(_o.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return null===(e=u.Log)||void 0===e||e.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DisableFastStatesSyncAsync()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),t}))}IsFastStatesSyncEnabledAsync(){return Xs(this,void 0,void 0,(function*(){const e=yield Qv.Get(_o.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof wo?e.Data:e!=ce.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return Xs(this,void 0,void 0,(function*(){let t=Qv.Get(mo.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 Xs(this,void 0,void 0,(function*(){var t,n=yield Qv.Get(mo.ServiceName).AddManuallyPairedDeviceAsync(e);return null===(t=u.Log)||void 0===t||t.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDevice()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),n}))}GetDeviceChannelStates(e,t){var n,r;return null!==(r=null===(n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===n?void 0:n.ChannelsStates.filter((e=>e.Channel==t)))&&void 0!==r?r:[]}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 r=new Qs;r.Channel=t.Data.Channel,r.States=[t],n={DeviceGuid:e.Guid,ChannelsStates:[r]},this._devicesChannelsStates.push(n)}else{let e=n.ChannelsStates.firstOrDefault((e=>e.Channel==t.Data.Channel));if(null==e)e=new Qs,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e);else{let n=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum));null!=n&&(n.TypeAsEnum==bt.BlindErrorState?e.States=e.States.where((e=>e.Data.ErrorCode!=t.Data.ErrorCode)).toArray():e.States=e.States.where((e=>e.TypeAsEnum!=t.TypeAsEnum)).toArray()),e.States.push(t)}}}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}WaitForDevicesStatesSynchronizationAsync(){return this._deviceStatesSynchronizationTaskCompletionSource}GetCurrentlyRunningTaksAsync(){return Xs(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new si,15e3,!1);(null==t?void 0:t.Status)==ce.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),r=new Wt;if(r.DeviceGuid=n[0],r.Channel=Number(n[1]),r.Status=Ct.ExecutingTasks,t.push(r),0===r.Channel){const e=this._devices.find((e=>e.Guid==r.DeviceGuid));void 0!==e&&e.Channels.forEach((n=>{const r=new Wt;r.DeviceGuid=e.Guid,r.Channel=n.Number,r.Status=Ct.ExecutingTasks,t.push(r)}))}})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new _n(t);case"DoorBell":return new bn(t);case"ReedPosition":return new Gn(t);case"BlindPosition":return new Rn(t);case"ButtonState":return new On(t);case"LightColor":return new Mn(t);case"LightTemperature":return new Fn(t);case"LightBrightness":return new Bn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new $n(t);case"BatteryState":return new Vn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new Kn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new zn(t);case"DistanceSensor":return new Xn(t);case"MovementSensor":return new Yn(t);case"BlindsControlButton":return new Zn(t);case"FacadeControlButton":return new tr(t);case"SignalStrength":return new rr(t);case"GatePosition":return new or(t);case"GatewayPosition":return new ir(t);case"GateControllerHealth":return new ar(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new cr(t);case"HumiditySensor":case"HumidityState":return new ur(t);case"VibrationSensor":return new dr(t);case"DigitalInputSensor":return new hr(t);case"ConfigurationState":return new pr(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new fr(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new vr(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new yr(t);case"FacadePosition":case"FacadeState":return new mr(t);case"FacadeTypeState":return new wr(t);case"CurrentWindThreshold":return new Sr(t);case"CurrentLightThreshold":return new _r(t);case"WindSpeed":return new Cr(t);case"FloodSensor":return new Dr(t);case"PressureState":return new Er(t);case"ITamperProtection":case"TamperProtection":return new Ir(t);case"ILightRGBW":case"LightRGBW":return new Gr(t);case"OnlineCamera":case"IOnlineCamera":return new En(t);case"BlindError":case"IBlindError":return t.state.ErrorData=ie(t.state.ErrorData),new Nr(t);case"HallState":return new Tn(t);case"SceneExecuted":return new Dn(t);case"Intercom":return new kn(t);default:null===(n=u.Log)||void 0===n||n.Debug(Ys.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return Ys.ServiceName}SyncDevicesStatesAsync(){return Xs(this,arguments,void 0,(function*(e=!1){var t,n,r;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ei,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync()){if(e){let e=new ti;e.Data=!0;const t=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ce.OK}return(null==o?void 0:o.Status)==ce.OK}{let e=new ti;e.Data=!0;const t=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ce.OK}}))}OnDevicesTasksExecutionChangeEvent(){return this._onDevicesTasksChangedEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}OnDeviceRegisteredEvent(){return this._onDeviceRegisteredEvent}OnDeviceRemovedEvent(){return this._onDeviceRemovedEvent}OnDeviceFoundEvent(){return this._onDeviceFoundEvent}MapApiDevices(e){const t=[];return null==e?[]:(e.forEach((e=>{var n,r,o,s,i=new Rr;i.Guid=e.Guid,i.Name=e.DeviceName,i.ChannelsAmount=e.ChannelsNumber,i.DeviceType=e.DeviceType,i.CommunicationWay=e.CommunicationWay,i.DeviceState=e.DeviceState,i.IsEnabled=e.IsEnabled,i.IsVirtual=e.IsVirtual,i.SerialNumber=e.DeviceSerialNumber,i.ManufacturerGuid=e.ManufacturerGuid,i.ModelGuid=e.DeviceModelGuid,i.Model=e.DeviceModel,i.Name=e.DeviceName,i.ProtocolGuid=e.ProtocolGuid,void 0!==e.IconType&&null!==e.IconType?i.IconType=e.IconType:i.IconType=kt.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Lt;if(i.CommunicationWay==Gt.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}i.AvailableTaskTypes.push(t)})),null===(r=e.AvailableResponses)||void 0===r||r.forEach((e=>{var t=new Bt;t.InterfaceType=e,i.AvailableResponseTypes.push(t)})),null===(o=e.ChannelsConfiguration)||void 0===o||o.forEach((e=>{var t,n,r;try{var o=new Wr;o.Number=e.Channel,i.Channels.push(o),o.SetDevice(i),o.Name=e.ChannelName,o.ChannelGroups=e.GroupsGuids,o.IconName=e.IconName,o.IsHidden=e.Hidden,o.Configurations=e.Configurations,o.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(o.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(o.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{var t=new Bt;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Lt;i.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType))?"IBlindPosition"==e&&(t.InterfaceType="IBlindPositionSimple"):t.InterfaceType=e,o.AvailableTaskTypes.push(t)}))}catch(e){null===(r=u.Log)||void 0===r||r.Error(e)}}))}catch(e){null===(s=u.Log)||void 0===s||s.Error(e)}t.push(i)})),t)}GetPairedDevicesAsync(){return Xs(this,arguments,void 0,(function*(e=!1){var t,n,r;if(this._synchronized&&!(yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync()))return e?Promise.resolve(this._devices):Promise.resolve(this._devices.filter((e=>e.DeviceType!=Nt.Scene)));const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Zs,15e3,!0);return null==o||void 0===o?[]:o.Status==ce.OK&&null!=o.Data?(this._devices=this.MapApiDevices(o.Data),e?this._devices:this._devices.filter((e=>e.DeviceType!=Nt.Scene))):(null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(){return Xs(this,arguments,void 0,(function*(e=!1){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){return Xs(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new oi,15e3,!1);return null==n?[]:n.Status==ce.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Nt.Scene)).toArray():(null===(t=u.Log)||void 0===t||t.Error(Ys.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){return Xs(this,void 0,void 0,(function*(){var e;Qv.Get(Le.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ni,35e3,!1)}))}StopSearchingForDevices(){return Xs(this,void 0,void 0,(function*(){var e;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ri,2e4,!1)}))}RegisterDeviceAsync(e){return Xs(this,void 0,void 0,(function*(){var t,n,r;try{const r=new ii;r.Data=e.Guid;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(r,2e4,!1);return null===(n=u.Log)||void 0===n||n.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RegisterDeviceAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==ce.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),Pt.Executed):Pt.Failed}catch(e){return null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,`Failed to paired devices: ${e}`),Pt.ControllerResponseTimeout}}))}RemoveDeviceAsync(e){return Xs(this,arguments,void 0,(function*(e,t=!1){var n,r,o=new ai;t&&(o=new ci),o.Data=e.Guid;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,35e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RemoveDeviceAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ce.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),Pt.Executed):Pt.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new hi;const r=t;switch(r.FeatureType){case Ur.SetTemperature:n.Data=r.Temperature;break;case Ur.SetLightBrightness:n.Data=r.Brightness;break;case Ur.SetLightColor:n=new gi;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case Ur.SetLightTemperature:n.Data=r.Temperature;break;case Ur.SetGatePositionPrecise:switch(r.GateControlAction){case xr.Open:n.Data=101;break;case xr.Close:n.Data=102;break;case xr.Stop:n.Data=103;break;case xr.Percentage:n.Data=r.Position}break;case Ur.SetBlindPosition:switch(r.Action){case Mr.Open:n.Data=101;break;case Mr.Close:n.Data=102;break;case Mr.Stop:n.Data=103;break;case Mr.Percentage:n.Data=r.Position}break;case Ur.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case Ur.SetBlindOpenCloseTime:n.Data=r.Data;break;case Ur.SetBlindMicroventilation:n.Data=r.Position;break;case Ur.SetFacadePositionAndTilt:n=new pi;const t=r;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case Ur.LightRGBW:n.Data=r.Data;break;case Ur.GatePulse:case Ur.GatewayPulse:n.Data=0;break;case Ur.TurnOnWithTimeout:n.Data=r.SwitchOffDelaySeconds}return n.Channel=r.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=r.FeatureType,n}ExecuteDeviceTaskAsync(e,t){return Xs(this,void 0,void 0,(function*(){var n,r,o,s,i,a,c,l;try{null===(n=u.Log)||void 0===n||n.Debug(Ys.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new ui(l);null===(r=u.Log)||void 0===r||r.Debug(Ys.ServiceName,`Sending device task for execution, device: ${l.DeviceGuid} task: ${l.ControlFeature} channel: ${l.Channel} request: ${JSON.stringify(e)}`);const t=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(e,15e3,!1);switch(null==t?void 0:t.Status){case ce.OK:return Pt.Executed;case ce.FatalError:return null===(s=u.Log)||void 0===s||s.Error(Ys.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),Pt.Failed;case ce.WrongData:if("DeviceNotFound"===t.Data)return Pt.DeviceNotFound;break;case ce.Error:return"DeviceResponseTimeout"===t.Data?Pt.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Ys.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),Pt.Failed)}}catch(e){return e.message.includes("timeout")?(null===(a=u.Log)||void 0===a||a.Error(Ys.ServiceName,`Failed to get controller response in time.\n${e}`),Pt.ControllerResponseTimeout):(null===(c=u.Log)||void 0===c||c.Error(Ys.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Pt.Failed)}return Pt.Unknown}catch(e){return null===(l=u.Log)||void 0===l||l.Error(Ys.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Pt.Failed}}))}ExecuteDevicesTasksAsync(e){return Xs(this,void 0,void 0,(function*(){var t,n,r,o;let s=[],i=[],a=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=a,a++,i.push(e)}const c=new li(i);try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(c,12e4,!1);let o=-1;null===(n=null==r?void 0:r.Data)||void 0===n||n.forEach((t=>{var n,i;o++;let a=Pt.Unknown;switch(t.Status){case ce.OK:return Pt.Executed;case ce.FatalError:null===(n=u.Log)||void 0===n||n.Error(Ys.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),a=Pt.Failed;break;case ce.WrongData:"DeviceNotFound"===t.Data&&(a=Pt.DeviceNotFound);break;case ce.Error:"DeviceResponseTimeout"===t.Data?a=Pt.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Ys.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),a=Pt.Failed)}let c=0,l=new $t;for(const[t,n]of e){if(c==o){l.Device=t,l.Task=n,l.Channel=n.Channel,s.push(l);break}c++}}))}catch(t){if(t.message.includes("timeout")){null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new $t;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Pt.ControllerResponseTimeout}}else{null===(o=u.Log)||void 0===o||o.Error(Ys.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new $t;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Pt.Failed}}}return s}))}}Ys.ServiceName="DevicesService";class Qs{constructor(){this.Channel=0,this.States=[]}}class Zs extends ae{constructor(){super(),this.Resource="/devices/list",this.Method=ue.Get}}class ei extends ae{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ue.Get}}class ti extends ae{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ue.Get}}class ni extends ae{constructor(){super(),this.Resource="/devices/search",this.Method=ue.Post}}class ri extends ae{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ue.Post}}class oi extends ae{constructor(){super(),this.Resource="/devices/found/list",this.Method=ue.Get}}class si extends ae{constructor(){super(),this.Resource="/devices/tasks",this.Method=ue.Get}}class ii extends ae{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ue.Put}}class ai extends ae{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ue.Put}}class ci extends ae{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ue.Put}}class ui extends ae{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ue.Post,this.Data=e}}class li extends ae{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ue.Post,this.Data=e}}class di extends ae{constructor(e){super(),this.Resource="/logic/device/used",this.Method=ue.Get,this.Data=e}}class hi{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Ur.GetState,this.SequnceExecutionOrder=0}}class gi extends hi{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class pi extends hi{constructor(){super(...arguments),this.FacadeAction=Lr.Stop,this.Tilt=0,this.Position=0}}class fi{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class vi extends RangeError{paramName;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 yi=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 mi extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const wi=(e,t)=>e===t;class Si{iterator;constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Ai{dataFunc;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 _i{iterator;constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class Ci extends Array{}const Ti=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Ei(e,t,n,r)}return n?ki(e,t,n):Di(e,t)},Di=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},ki=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},Ei=(e,t,n,r)=>{let o=t;for(const t of e)o=n(o,t);return r(o)},bi=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},Ii=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Gi=(e,t)=>t?Ri(e,t):Ni(e),Ni=e=>{for(const t of e)return!0;return!1},Ri=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Pi=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},Oi=(e,t)=>new _i((function*(){yield*e,yield t})),Ui=e=>{if(Array.isArray(e)){if(0===e.length)throw new mi(yi.NoElements);return new Si((async function*(){for await(const t of e)yield t}))}return new Si(e)},Mi=e=>Ui((async function*(){for(const t of e)yield t})),xi=(e,t)=>new Ai({generator:t,type:e}),Fi=e=>xi(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Li=(e,t)=>{let n=0,r=0;if(t)for(const o of e)n+=t(o),r+=1;else for(const t of e)n+=t,r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Bi=async(e,t)=>{let n=0,r=0;for(const o of e)n+=await t(o),r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Wi=(e,t)=>{if(t<1)throw new vi("size");return new _i((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},$i=(e,t)=>new _i((function*(){yield*e,yield*t})),qi=(e,t,n=wi)=>{for(const r of e)if(n(t,r))return!0;return!1},Vi=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},Hi=(e,t)=>t?ji(e,t):Ki(e),Ki=e=>{let t=0;for(const n of e)t++;return t},ji=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},zi=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},Ji=(e,t)=>new _i((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),Xi=(e,t=wi)=>new _i((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Yi=(e,t)=>Ui((async function*(){const n=[];e:for(const r of e){for(const e of n)if(await t(e,r))continue e;n.push(r),yield r}})),Qi=(e,t)=>new _i((function*(){for(const n of e)t(n),yield n})),Zi=(e,t)=>Ui((async function*(){for(const n of e)await t(n),yield n})),ea=(e,t)=>{if(t<0)throw new vi("index");let n=0;for(const r of e)if(t===n++)return r;throw new vi("index")},ta=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},na=(e,t,n=wi)=>new _i((function*(){const r=[...t];for(const t of e){let e=!1;for(let o=0;o<r.length;o++)if(!0===n(t,r[o])){e=!0;break}!1===e&&(yield t)}})),ra=(e,t,n)=>Ui((async function*(){const r=[...t];for(const t of e){let e=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),oa=(e,t)=>t?ia(e,t):sa(e),sa=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new mi(yi.NoElements);return t.value},ia=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new mi(yi.NoMatch)},aa=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new mi(yi.NoMatch)},ca=(e,t)=>t?la(e,t):ua(e),ua=e=>e[Symbol.iterator]().next().value??null,la=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},da=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class ha extends Ci{key;constructor(e,t){super(1),this.key=e,this[0]=t}}const ga=(e,t,n)=>{let r;return r=n?((e,t,n)=>function*(){const r=new Array;for(const o of e){const e=t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})(e,t,n):((e,t)=>function*(){const n={};for(const r of e){const e=t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})(e,t),new _i(r)},pa=(e,t,n)=>n?va(e,t,n):fa(e,t),fa=(e,t)=>Ui((async function*(){const n={};for(const r of e){const e=await t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})),va=(e,t,n)=>Ui((async function*(){const r=new Array;for(const o of e){const e=await t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})),ya=(e,t,n,r)=>r?((e,t,n,r)=>new _i((function*(){const o=new Array;for(const s of e){const e=t(s);let i=!1;for(let t=0;t<o.length;t++){const a=o[t];if(r(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);o.push(new ha(e,t))}}for(const e of o)yield e})))(e,t,n,r):((e,t,n)=>new _i((function*(){const r={};for(const o of e){const e=t(o),s=r[e],i=n(o);s?s.push(i):r[e]=new ha(e,i)}for(const e in r)yield r[e]})))(e,t,n),ma=(e,t,n,r,o,s)=>{const i=s?wa(e,t,n,r,o,s):Sa(e,t,n,r,o);return new _i(i)},wa=(e,t,n,r,o,s)=>function*(){const i=[];for(const e of t){const t=r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for(const t of e){const e=n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},Sa=(e,t,n,r,o)=>function*(){const s=new Map;for(const e of t){const t=r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for(const t of e){const e=n(t),r=s.get(e)??[];yield o(t,r)}},Aa=(e,t,n,r,o,s)=>{const i=s?_a(e,t,n,r,o,s):Ca(e,t,n,r,o);return Ui(i)},_a=(e,t,n,r,o,s)=>async function*(){const i=[];for(const e of t){const t=await r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for(const t of e){const e=await n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},Ca=(e,t,n,r,o)=>async function*(){const s=new Map;for(const e of t){const t=await r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for(const t of e){const e=await n(t),r=s.get(e)??[];yield o(t,r)}},Ta=(e,t,n=wi)=>new _i((function*(){const r=[...e.distinct(n)];if(0===r.length)return;const o=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++)if(!0===n(t,o[e])){yield t;break}}})),Da=(e,t,n)=>Ui((async function*(){const r=[];for await(const t of e.distinctAsync(n))r.push(t);if(0===r.length)return;const o=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===await n(t,r)){yield t;break}}}})),ka=(e,t,n,r,o,s=wi)=>new _i((function*(){const i=[...t];for(const t of e){const e=n(t);for(const n of i){const i=r(n);!0===s(e,i)&&(yield o(t,n))}}})),Ea=(e,t)=>t?Ia(e,t):ba(e),ba=e=>{let t;for(const n of e)t=n;if(!t)throw new mi(yi.NoElements);return t},Ia=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Ga=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Na=(e,t)=>t?Pa(e,t):Ra(e),Ra=e=>{let t=null;for(const n of e)t=n;return t},Pa=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},Oa=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},Ua=(e,t)=>t?xa(e,t):Ma(e),Ma=e=>{let t=null;for(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},xa=(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Fa=async(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},La=(e,t)=>t?Wa(e,t):Ba(e),Ba=e=>{let t=null;for(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},Wa=(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},$a=async(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},qa=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new _i((function*(){for(const t of e)n(t)&&(yield t)}))};async function*Va(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}function*Ha(e,t,n,r){const o=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}class Ka extends Si{orderedPairs;constructor(e){super((async function*(){for await(const t of e())yield*t})),this.orderedPairs=e}static generateAsync(e,t,n,r){let o;return o=e instanceof Ka?async function*(){for await(const o of e.orderedPairs())yield*Va(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Ka(o)}static generate(e,t,n,r){let o;return o=e instanceof Ka?async function*(){for await(const o of e.orderedPairs())yield*Ha(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Ka(o)}thenBy(e,t){return Ka.generate(this,e,!0,t)}thenByAsync(e,t){return Ka.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Ka.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Ka.generateAsync(this,e,!1,t)}}function*ja(e,t,n,r){const o=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}async function*za(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}class Ja extends _i{orderedPairs;constructor(e){super((function*(){for(const t of e())yield*t})),this.orderedPairs=e}static generate(e,t,n,r){let o;return o=e instanceof Ja?function*(){for(const o of e.orderedPairs())yield*ja(o,t,n,r)}:()=>ja(e,t,n,r),new Ja(o)}static generateAsync(e,t,n,r){let o;return o=e instanceof Ja?async function*(){for(const o of e.orderedPairs())yield*za(o,t,n,r)}:()=>za(e,t,n,r),new Ka(o)}thenBy(e,t){return Ja.generate(this,e,!0,t)}thenByAsync(e,t){return Ja.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Ja.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Ja.generateAsync(this,e,!1,t)}}const Xa=(e,t)=>Ja.generate(e,(e=>e),!0,t),Ya=(e,t,n)=>Ja.generate(e,t,!0,n),Qa=(e,t,n)=>Ja.generateAsync(e,t,!0,n),Za=(e,t,n)=>Ja.generate(e,t,!1,n),ec=(e,t,n)=>Ja.generateAsync(e,t,!1,n),tc=(e,t)=>Ja.generate(e,(e=>e),!1,t),nc=(e,t)=>{const n=[],r=[];for(const o of e)!0===t(o)?r.push(o):n.push(o);return[r,n]},rc=async(e,t)=>{const n=[],r=[];for(const o of e)!0===await t(o)?r.push(o):n.push(o);return[r,n]},oc=(e,t)=>new _i((function*(){yield t,yield*e})),sc=e=>new _i((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),ic=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?ac(e,t):cc(e,t)}return uc(e,t)},ac=(e,t)=>new _i((function*(){for(const n of e)yield t(n)})),cc=(e,t)=>new _i((function*(){let n=0;for(const r of e)yield t(r,n),n++})),uc=(e,t)=>new _i((function*(){for(const n of e)yield n[t]})),lc=(e,t)=>"function"==typeof t?1===t.length?dc(e,t):hc(e,t):gc(e,t),dc=(e,t)=>Ui((async function*(){for(const n of e)yield t(n)})),hc=(e,t)=>Ui((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),gc=(e,t)=>Ui((async function*(){for(const n of e)yield n[t]})),pc=(e,t)=>"function"==typeof t?1===t.length?fc(e,t):vc(e,t):yc(e,t),fc=(e,t)=>new _i((function*(){for(const n of e)for(const e of t(n))yield e})),vc=(e,t)=>new _i((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),yc=(e,t)=>new _i((function*(){for(const n of e)for(const e of n[t])yield e})),mc=(e,t)=>1===t.length?wc(e,t):Sc(e,t),wc=(e,t)=>Ui((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Sc=(e,t)=>Ui((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),Ac=(e,t,n=wi)=>{const r=e[Symbol.iterator](),o=t[Symbol.iterator]();let s=r.next(),i=o.next();for(;!s.done&&!i.done;){if(!n(s.value,i.value))return!1;s=r.next(),i=o.next()}return!0===s.done&&!0===i.done},_c=async(e,t,n)=>{const r=e[Symbol.iterator](),o=t[Symbol.iterator]();let s=r.next(),i=o.next();for(;!s.done&&!i.done;){if(!1===await n(s.value,i.value))return!1;s=r.next(),i=o.next()}return!0===s.done&&!0===i.done},Cc=(e,t)=>t?Dc(e,t):Tc(e),Tc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new mi(yi.NoElements);return n},Dc=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},kc=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},Ec=(e,t)=>t?Ic(e,t):bc(e),bc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}return n},Ic=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}return r},Gc=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneElement);n=!0,r=o}return r},Nc=(e,t)=>new _i((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),Rc=(e,t)=>1===t.length?Pc(e,t):Oc(e,t),Pc=(e,t)=>new _i((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Oc=(e,t)=>new _i((function*(){let n=0,r=!0;for(const o of e)!1===r?yield o:!1===t(o,n)&&(r=!1,yield o),n++})),Uc=(e,t)=>1===t.length?Mc(e,t):xc(e,t),Mc=(e,t)=>Ui((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),xc=(e,t)=>Ui((async function*(){let n=0,r=!0;for(const o of e)!1===r?yield o:!1===await t(o,n)&&(r=!1,yield o),n++})),Fc=(e,t)=>t?Bc(e,t):Lc(e),Lc=e=>{let t=0;for(const n of e)t+=n;return t},Bc=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},Wc=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},$c=(e,t)=>new _i((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),qc=(e,t)=>1===t.length?Vc(e,t):Hc(e,t),Vc=(e,t)=>new _i((function*(){for(const n of e){if(!t(n))break;yield n}})),Hc=(e,t)=>new _i((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),Kc=(e,t)=>1===t.length?jc(e,t):zc(e,t),jc=(e,t)=>Ui((async function*(){for(const n of e){if(!await t(n))break;yield n}})),zc=(e,t)=>Ui((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),Jc=e=>[...e],Xc=(e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Yc=async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Qc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},Zc=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},eu=e=>new Set(e),tu=(e,t,n)=>n?ru(e,t,n):nu(e,t),nu=(e,t)=>new _i((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))})),ru=(e,t,n)=>new _i((function*(){const r=[];for(const o of[e,t])for(const e of o){let t=!1;for(const o of r)if(!0===n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),ou=(e,t,n)=>Ui((async function*(){const r=[];for(const o of[e,t])for(const e of o){let t=!1;for(const o of r)if(!0===await n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),su=(e,t)=>1===t.length?iu(e,t):au(e,t),iu=(e,t)=>new _i((function*(){for(const n of e)!0===t(n)&&(yield n)})),au=(e,t)=>new _i((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),cu=(e,t)=>1===t.length?uu(e,t):lu(e,t),uu=(e,t)=>Ui((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),lu=(e,t)=>Ui((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),du=(e,t,n)=>n?gu(e,t,n):hu(e,t),hu=(e,t)=>new _i((function*(){const n=e[Symbol.iterator](),r=t[Symbol.iterator]();for(;;){const e=n.next(),t=r.next();if(e.done||t.done)break;yield[e.value,t.value]}})),gu=(e,t,n)=>new _i((function*(){const r=e[Symbol.iterator](),o=t[Symbol.iterator]();for(;;){const e=r.next(),t=o.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),pu=(e,t,n)=>Ui((async function*(){const r=e[Symbol.iterator](),o=t[Symbol.iterator]();for(;;){const e=r.next(),t=o.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),fu=e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(Ti,"aggregate"),n(bi,"all"),n(Ii,"allAsync"),n(Gi,"any"),n(Pi,"anyAsync"),n(Oi,"append"),n(Mi,"asAsync"),n(Fi,"asParallel"),n(Li,"average"),n(Bi,"averageAsync"),n(Wi,"chunk"),n($i,"concatenate"),n(qi,"contains"),n(Vi,"containsAsync"),n(Hi,"count"),n(zi,"countAsync"),n(Ji,"defaultIfEmpty"),n(Xi,"distinct"),n(Yi,"distinctAsync"),n(Qi,"each"),n(Zi,"eachAsync"),n(ea,"elementAt"),n(ta,"elementAtOrDefault"),n(na,"except"),n(ra,"exceptAsync"),n(oa,"first"),n(aa,"firstAsync"),n(ca,"firstOrDefault"),n(da,"firstOrDefaultAsync"),n(ga,"groupBy"),n(pa,"groupByAsync"),n(ya,"groupByWithSel"),n(ma,"groupJoin"),n(Aa,"groupJoinAsync"),n(Ta,"intersect"),n(Da,"intersectAsync"),n(ka,"joinByKey"),n(Ea,"last"),n(Ga,"lastAsync"),n(Na,"lastOrDefault"),n(Oa,"lastOrDefaultAsync"),n(Ua,"max"),n(Fa,"maxAsync"),n(La,"min"),n($a,"minAsync"),n(qa,"ofType"),n(Xa,"order"),n(Ya,"orderBy"),n(Qa,"orderByAsync"),n(Za,"orderByDescending"),n(ec,"orderByDescendingAsync"),n(tc,"orderDescending"),n(oc,"prepend"),n(sc,"reverse"),n(ic,"select"),n(lc,"selectAsync"),n(pc,"selectMany"),n(mc,"selectManyAsync"),n(Ac,"sequenceEquals"),n(_c,"sequenceEqualsAsync"),n(Cc,"single"),n(kc,"singleAsync"),n(Ec,"singleOrDefault"),n(Gc,"singleOrDefaultAsync"),n(Nc,"skip"),n(Rc,"skipWhile"),n(Uc,"skipWhileAsync"),n(Fc,"sum"),n(Wc,"sumAsync"),n($c,"take"),n(qc,"takeWhile"),n(Kc,"takeWhileAsync"),n(Jc,"toArray"),n(Xc,"toMap"),n(Yc,"toMapAsync"),n(Qc,"toObject"),n(Zc,"toObjectAsync"),n(nc,"partition"),n(rc,"partitionAsync"),n(eu,"toSet"),n(tu,"union"),n(ou,"unionAsync"),n(su,"where"),n(cu,"whereAsync"),n(du,"zip"),n(pu,"zipAsync")},vu=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return wu(e,t,n,r)}return n?mu(e,t,n):yu(e,t)},yu=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},mu=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},wu=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},Su=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Au=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},_u=(e,t)=>new Si((async function*(){yield*e,yield t})),Cu=(e,t)=>t?Du(e,t):Tu(e),Tu=async e=>{for await(const t of e)return!0;return!1},Du=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},ku=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},Eu=e=>xi(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),bu=async(e,t)=>{let n=0,r=0;if(t)for await(const o of e)n+=t(o),r+=1;else for await(const t of e)n+=t,r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Iu=async(e,t)=>{let n=0,r=0;for await(const o of e)n+=await t(o),r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Gu=(e,t)=>{if(t<1)throw new vi("size");return new Si((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Nu=(e,t)=>new Si((async function*(){yield*e,yield*t})),Ru=async(e,t,n=wi)=>{for await(const r of e)if(n(t,r))return!0;return!1},Pu=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},Ou=(e,t)=>t?Mu(e,t):Uu(e),Uu=async e=>{let t=0;for await(const n of e)t++;return t},Mu=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},xu=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},Fu=(e,t)=>new Si((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),Lu=(e,t=wi)=>new Si((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Bu=(e,t)=>new Si((async function*(){const n=[];e:for await(const r of e){for(const e of n)if(await t(e,r))continue e;n.push(r),yield r}})),Wu=(e,t)=>new Si((async function*(){for await(const n of e)t(n),yield n})),$u=(e,t)=>new Si((async function*(){for await(const n of e)await t(n),yield n})),qu=async(e,t)=>{if(t<0)throw new vi("index");let n=0;for await(const r of e)if(t===n++)return r;throw new vi("index")},Vu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},Hu=(e,t,n=wi)=>new Si((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===n(t,s)){e=!0;break}}!1===e&&(yield t)}})),Ku=(e,t,n)=>new Si((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),ju=(e,t)=>t?Ju(e,t):zu(e),zu=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new mi(yi.NoElements);return t.value},Ju=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new mi(yi.NoMatch)},Xu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new mi(yi.NoMatch)},Yu=(e,t)=>t?Zu(e,t):Qu(e),Qu=async e=>(await e[Symbol.asyncIterator]().next()).value??null,Zu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},el=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},tl=(e,t,n)=>n?nl(e,t,n):rl(e,t),nl=(e,t,n)=>new Si((async function*(){const r=new Array;for await(const o of e){const e=t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})),rl=(e,t)=>new Si((async function*(){const n={};for await(const r of e){const e=t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})),ol=(e,t,n)=>n?il(e,t,n):sl(e,t),sl=(e,t)=>new Si((async function*(){const n={};for await(const r of e){const e=await t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})),il=(e,t,n)=>new Si((async function*(){const r=new Array;for await(const o of e){const e=await t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})),al=(e,t,n,r)=>r?ul(e,t,n,r):cl(e,t,n),cl=(e,t,n)=>new Si((async function*(){const r={};for await(const o of e){const e=t(o),s=r[e],i=n(o);s?s.push(i):r[e]=new ha(e,i)}for(const e in r)yield r[e]})),ul=(e,t,n,r)=>new Si((async function*(){const o=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<o.length;t++){const a=o[t];if(r(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);o.push(new ha(e,t))}}for(const e of o)yield e})),ll=(e,t,n,r,o,s)=>{const i=s?dl(e,t,n,r,o,s):hl(e,t,n,r,o);return new Si(i)},dl=(e,t,n,r,o,s)=>async function*(){const i=[];for await(const e of t){const t=r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for await(const t of e){const e=n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},hl=(e,t,n,r,o)=>async function*(){const s=new Map;for await(const e of t){const t=r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for await(const t of e){const e=n(t),r=s.get(e)??[];yield o(t,r)}},gl=(e,t,n,r,o,s)=>{const i=s?pl(e,t,n,r,o,s):fl(e,t,n,r,o);return new Si(i)},pl=(e,t,n,r,o,s)=>async function*(){const i=[];for await(const e of t){const t=await r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for await(const t of e){const e=await n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},fl=(e,t,n,r,o)=>async function*(){const s=new Map;for await(const e of t){const t=await r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for await(const t of e){const e=await n(t),r=s.get(e)??[];yield o(t,r)}},vl=(e,t,n=wi)=>new Si((async function*(){const r=await e.distinct(n).toArray();if(0===r.length)return;const o=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===n(t,r)){yield t;break}}}})),yl=(e,t,n)=>new Si((async function*(){const r=await e.distinctAsync(n).toArray();if(0===r.length)return;const o=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===await n(t,r)){yield t;break}}}})),ml=(e,t,n,r,o,s=wi)=>new Si((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=r(n);!0===s(e,i)&&(yield o(t,n))}}})),wl=(e,t)=>t?Al(e,t):Sl(e),Sl=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new mi(yi.NoElements);return t},Al=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},_l=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Cl=(e,t)=>t?Dl(e,t):Tl(e),Tl=async e=>{let t=null;for await(const n of e)t=n;return t},Dl=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},kl=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},El=(e,t)=>t?Il(e,t):bl(e),bl=async e=>{let t=null;for await(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},Il=async(e,t)=>{let n=null;for await(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Gl=async(e,t)=>{let n=null;for await(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},Nl=(e,t)=>t?Pl(e,t):Rl(e),Rl=async e=>{let t=null;for await(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},Pl=async(e,t)=>{let n=null;for await(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Ol=async(e,t)=>{let n=null;for await(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},Ul=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Si((async function*(){for await(const t of e)n(t)&&(yield t)}))},Ml=(e,t)=>Ka.generate(e,(e=>e),!0,t),xl=(e,t,n)=>Ka.generate(e,t,!0,n),Fl=(e,t,n)=>Ka.generateAsync(e,t,!0,n),Ll=(e,t,n)=>Ka.generate(e,t,!1,n),Bl=(e,t,n)=>Ka.generateAsync(e,t,!1,n),Wl=(e,t)=>Ka.generate(e,(e=>e),!1,t),$l=async(e,t)=>{const n=[],r=[];for await(const o of e)!0===t(o)?r.push(o):n.push(o);return[r,n]},ql=async(e,t)=>{const n=[],r=[];for await(const o of e)!0===await t(o)?r.push(o):n.push(o);return[r,n]},Vl=(e,t)=>new Si((async function*(){yield t,yield*e})),Hl=e=>new Si((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]})),Kl=(e,t)=>"function"==typeof t?1===t.length?jl(e,t):zl(e,t):Jl(e,t),jl=(e,t)=>new Si((async function*(){for await(const n of e)yield t(n)})),zl=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),Jl=(e,t)=>new Si((async function*(){for await(const n of e)yield n[t]})),Xl=(e,t)=>"string"==typeof t?Ql(e,t):Yl(e,t),Yl=(e,t)=>new Si((async function*(){for await(const n of e)yield t(n)})),Ql=(e,t)=>new Si((async function*(){for await(const n of e)yield n[t]})),Zl=(e,t)=>"function"==typeof t?1===t.length?ed(e,t):td(e,t):nd(e,t),ed=(e,t)=>new Si((async function*(){for await(const n of e)for(const e of t(n))yield e})),td=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),nd=(e,t)=>new Si((async function*(){for await(const n of e)for(const e of n[t])yield e})),rd=(e,t)=>1===t.length?new Si((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Si((async function*(){let n=0;for await(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),od=async(e,t,n=wi)=>{const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();let s=await Promise.all([r.next(),o.next()]),i=s[0],a=s[1];for(;!i.done&&!a.done;){if(!n(i.value,a.value))return!1;s=await Promise.all([r.next(),o.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},sd=async(e,t,n)=>{const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();let s=await Promise.all([r.next(),o.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([r.next(),o.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},id=(e,t)=>t?cd(e,t):ad(e),ad=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new mi(yi.NoElements);return n},cd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},ud=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},ld=(e,t)=>t?hd(e,t):dd(e),dd=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}return n},hd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}return r},gd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}return r},pd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),fd=(e,t)=>1===t.length?vd(e,t):yd(e,t),vd=(e,t)=>new Si((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),yd=(e,t)=>new Si((async function*(){let n=0,r=!0;for await(const o of e)!1===r?yield o:!1===t(o,n)&&(r=!1,yield o),n++})),md=(e,t)=>1===t.length?wd(e,t):Sd(e,t),wd=(e,t)=>new Si((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Sd=(e,t)=>new Si((async function*(){let n=0,r=!0;for await(const o of e)!1===r?yield o:!1===await t(o,n)&&(r=!1,yield o),n++})),Ad=(e,t)=>t?Cd(e,t):_d(e),_d=async e=>{let t=0;for await(const n of e)t+=n;return t},Cd=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},Td=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},Dd=(e,t)=>new Si((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),kd=(e,t)=>1===t.length?Ed(e,t):bd(e,t),Ed=(e,t)=>new Si((async function*(){for await(const n of e){if(!t(n))break;yield n}})),bd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Id=(e,t)=>1===t.length?Gd(e,t):Nd(e,t),Gd=(e,t)=>new Si((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Nd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Rd=async e=>{const t=[];for await(const n of e)t.push(n);return t},Pd=async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Od=async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Ud=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},Md=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},xd=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Fd=(e,t,n)=>n?Bd(e,t,n):Ld(e,t),Ld=(e,t)=>new Si((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))})),Bd=(e,t,n)=>new Si((async function*(){const r=[];for(const o of[e,t])for await(const e of o){let t=!1;for(const o of r)if(!0===n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),Wd=(e,t,n)=>new Si((async function*(){const r=[];for(const o of[e,t])for await(const e of o){let t=!1;for(const o of r)if(!0===await n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),$d=(e,t)=>1===t.length?qd(e,t):Vd(e,t),qd=(e,t)=>new Si((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Vd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),Hd=(e,t)=>1===t.length?Kd(e,t):jd(e,t),Kd=(e,t)=>new Si((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),jd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),zd=(e,t,n)=>n?Xd(e,t,n):Jd(e,t),Jd=(e,t)=>new Si((async function*(){const n=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([n.next(),r.next()]);if(e.done||t.done)break;yield[e.value,t.value]}})),Xd=(e,t,n)=>new Si((async function*(){const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([r.next(),o.next()]);if(e.done||t.done)break;yield n(e.value,t.value)}})),Yd=(e,t,n)=>new Si((async function*(){const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();for(;;){const e=await Promise.all([r.next(),o.next()]),t=e[0],s=e[1];if(t.done||s.done)break;yield n(t.value,s.value)}})),Qd=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return th(e,t,n,r)}return n?eh(e,t,n):Zd(e,t)},Zd=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},eh=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},th=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},nh=(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 r=0;r<e.length;r++)n[r]=t(e[r]);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:1};case 2:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:2}}},rh=(e,t)=>{const n=nh(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))}},oh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=t(e[n]);return r},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}}},sh=(e,t)=>{const n=oh(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))}},ih=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ai({generator:()=>{const e=n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 2:return new Ai({generator:async()=>{const e=await n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 0:return new Ai({generator:async()=>{const e=await n.generator();return e.push(t),e},type:n.type})}},ah=(e,t)=>t?uh(e,t):ch(e),ch=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}},uh=async(e,t)=>{const n=nh(e,t);let r;switch(n.type){case 0:return r=await n.generator(),r.includes(!0);case 1:return r=await Promise.all(n.generator()),r.includes(!0);case 2:return r=await Promise.all(await n.generator()),r.includes(!0)}},lh=async(e,t)=>{const n=oh(e,t);let r;switch(n.type){case 1:return r=n.generator(),0!==r.length&&new Promise(((e,t)=>{let n=0;for(const o of r)o.then((t=>{n++,t?e(!0):n===r.length&&e(!1)}),t)}));case 2:return r=await n.generator(),0===Promise.length?!1:(await Promise.all(r)).includes(!0)}},dh=e=>Ui((async function*(){for await(const t of e)yield t})),hh=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)}},gh=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},ph=async(e,t)=>{const n=oh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},fh=(e,t)=>{if(t<1)throw new vi("size");let n;switch(e.dataFunc.type){case 1:const r=e.dataFunc.generator;n={type:1,generator:()=>{const e=[];let n=[];for(const o of r())n.push(o),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 2:const o=e.dataFunc.generator;n={type:2,generator:async()=>{const e=[];let n=[];for(const r of await o())n.push(r),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 r of await s())n.push(r),n.length===t&&(e.push(n),n=[]);return n.length&&e.push(n),e}}}return new Ai(n)},vh=(e,t)=>new Ai({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),yh=async(e,t,n=wi)=>{let r;switch(r=nh(e,n?e=>n(t,e):e=>e===t),r.type){case 0:return(await r.generator()).some((e=>e));case 1:return(await Promise.all(r.generator())).some((e=>e));case 2:return(await Promise.all(await r.generator())).some((e=>e))}},mh=async(e,t,n)=>{const r=oh(e,(e=>n(t,e)));switch(r.type){case 1:return(await Promise.all(r.generator())).some((e=>e));case 2:return(await Promise.all(await r.generator())).some((e=>e))}},wh=(e,t)=>t?Ah(e,t):Sh(e),Sh=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},Ah=async(e,t)=>{const n=await e.toArray();let r=0;for(let e=0;e<n.length;e++)!0===t(n[e])&&r++;return r},_h=async(e,t)=>{const n=oh(e,t);let r;switch(n.type){case 1:r=Promise.all(n.generator());break;case 2:r=Promise.all(await n.generator())}let o=0;for(const e of await r)e&&o++;return o},Ch=(e,t)=>{const n=e.dataFunc,r=t instanceof Promise;let o;switch(n.type){case 0:o={generator:()=>n.generator().then((e=>e.length?e:r?t.then((e=>[e])):[t])),type:n.type};break;case 1:o={generator:()=>{const e=n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type};break;case 2:o={generator:async()=>{const e=await n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type}}return new Ai(o)},Th=(e,t=wi)=>new Ai({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),Dh=(e,t)=>new Ai({generator:async()=>{const n=[];e:for(const r of await e.toArray()){for(const e of n)if(await t(e,r))continue e;n.push(r)}return n},type:0}),kh=(e,t)=>new Ai(nh(e,(e=>(t(e),e)))),Eh=(e,t)=>{const n=oh(e,(async e=>(await t(e),e)));return new Ai(n)},bh=async(e,t)=>{if(t<0)throw new vi("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new vi("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new vi("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new vi("index");return await e[t]}}},Ih=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]}}},Gh=(e,t,n=wi)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of r){let t=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),Nh=(e,t,n)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of r){let t=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===await n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),Rh=e=>hh(e.dataFunc),Ph=(e,t)=>t?Uh(e,t):Oh(e),Oh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[0]}}},Uh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===t(e))return e;throw new mi(yi.NoMatch)},Mh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===await t(e))return e;throw new mi(yi.NoMatch)},xh=(e,t)=>t?Lh(e,t):Fh(e),Fh=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]}}},Lh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===t(e))return e;return null},Bh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===await t(e))return e;return null},Wh=(e,t,n)=>n?qh(e,t,n):$h(e,t),$h=(e,t)=>new Ai({generator:async()=>{const n={};for(const r of await e.toArray()){const e=t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),qh=(e,t,n)=>new Ai({generator:async()=>{const r=new Array;for(const o of await e.toArray()){const e=t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}const o=new Array;for(const e of r)o.push(e);return o},type:0}),Vh=(e,t,n)=>n?Hh(e,t,n):Kh(e,t),Hh=(e,t,n)=>new Ai({generator:async()=>{const r=oh(e,(async e=>[await t(e),e]));let o;switch(r.type){case 1:o=await Promise.all(r.generator());break;case 2:o=await Promise.all(await r.generator())}const s=new Array;for(const[e,t]of o){let r=!1;for(let o=0;o<s.length;o++){const i=s[o];if(!0===await n(i.key,e)){i.push(t),r=!0;break}}!1===r&&s.push(new ha(e,t))}const i=new Array;for(const e of s)i.push(e);return i},type:0}),Kh=(e,t)=>new Ai({generator:async()=>{const n=oh(e,(async e=>[await t(e),e]));let r;switch(n.type){case 1:r=await Promise.all(n.generator());break;case 2:r=await Promise.all(await n.generator())}const o={};for(const[e,t]of r){const n=o[e];n?n.push(t):o[e]=new ha(e,t)}const s=new Array;for(const e in o)s.push(o[e]);return s},type:0}),jh=(e,t,n,r)=>r?zh(e,t,n,r):Jh(e,t,n),zh=(e,t,n,r)=>new Ai({generator:async()=>{const o=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<o.length;t++){const a=o[t];if(r(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);o.push(new ha(e,t))}}const s=new Array;for(const e of o)s.push(e);return s},type:0}),Jh=(e,t,n)=>new Ai({generator:async()=>{const r={};for(const o of await e.toArray()){const e=t(o),s=r[e],i=n(o);s?s.push(i):r[e]=new ha(e,i)}const o=new Array;for(const e in r)o.push(r[e]);return o},type:0}),Xh=(e,t,n,r,o,s)=>{const i=s?Yh(e,t,n,r,o,s):Qh(e,t,n,r,o);return new Ai({generator:i,type:0})},Yh=(e,t,n,r,o,s)=>async()=>{const i=[];for await(const e of t){const t=r(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=>{const t=n(e),r=i.find((e=>s(e.key,t)))??{key:t,values:[]};return o(e,r.values)}))},Qh=(e,t,n,r,o)=>async()=>{const s=new Map;for await(const e of t){const t=r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}return(await e.toArray()).map((e=>{const t=n(e),r=s.get(t)??[];return o(e,r)}))},Zh=(e,t,n,r,o,s)=>{const i=s?eg(e,t,n,r,o,s):tg(e,t,n,r,o);return new Ai({generator:i,type:0})},eg=(e,t,n,r,o,s)=>async()=>{const i=[];for await(const e of t){const t=await r(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=>{const t=await n(e),r=i.find((e=>s(e.key,t)))??{key:t,values:[]};return o(e,r.values)}));return await Promise.all(a)},tg=(e,t,n,r,o)=>async()=>{const s=new Map;for await(const e of t){const t=await r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}const i=(await e.toArray()).map((async e=>{const t=await n(e),r=s.get(t)??[];return o(e,r)}));return await Promise.all(i)},ng=(e,t,n=wi)=>new Ai({generator:async()=>{const r=await e.distinct(n).toArray();if(0===r.length)return[];const o=await t.toArray(),s=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===n(t,r)){s.push(t);break}}}return s},type:0}),rg=(e,t,n)=>new Ai({generator:async()=>{const r=await e.distinctAsync(n).toArray();if(0===r.length)return[];const o=await t.toArray(),s=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===await n(t,r)){s.push(t);break}}}return s},type:0}),og=(e,t,n,r,o,s=wi)=>new Ai({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=r(n);!0===s(t,i)&&c.push(o(e,n))}}return c},type:0}),sg=(e,t)=>t?ag(e,t):ig(e),ig=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[e.length-1]}}},ag=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 r=e[n];if(t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}}throw new mi(yi.NoMatch)},cg=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 r=e[n];if(!0===await t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}}throw new mi(yi.NoMatch)},ug=(e,t)=>t?dg(e,t):lg(e),lg=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]}}},dg=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 r=e[n];if(t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}}return null},hg=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 r=e[n];if(!0===await t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}}return null},gg=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.max.apply(null,r)},pg=async(e,t)=>{const n=oh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.max.apply(null,r)},fg=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.min.apply(null,r)},vg=async(e,t)=>{const n=oh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.min.apply(null,r)},yg=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Ai({generator:async()=>{const t=nh(e,n),r=await hh(t),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0})};async function*mg(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}async function*wg(e,t,n,r){const o=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}class Sg extends Ai{orderedPairs;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,r){let o;return o=e instanceof Sg?async function*(){for await(const o of e.orderedPairs())yield*mg(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Sg(o)}static generate(e,t,n,r){let o;return o=e instanceof Sg?async function*(){for await(const o of e.orderedPairs())yield*wg(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Sg(o)}thenBy(e,t){return Sg.generate(this,e,!0,t)}thenByAsync(e,t){return Sg.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Sg.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Sg.generateAsync(this,e,!1,t)}}const Ag=(e,t)=>Sg.generate(e,(e=>e),!0,t),_g=(e,t,n)=>Sg.generate(e,t,!0,n),Cg=(e,t,n)=>Sg.generateAsync(e,t,!0,n),Tg=(e,t,n)=>Sg.generate(e,t,!1,n),Dg=(e,t,n)=>Sg.generateAsync(e,t,!1,n),kg=(e,t)=>Sg.generate(e,(e=>e),!1,t),Eg=async(e,t)=>{const n=nh(e,(e=>[t(e),e])),r=await hh(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},bg=async(e,t)=>{const n=oh(e,(async e=>[await t(e),e])),r=await hh(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},Ig=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ai({generator:()=>{const e=n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 2:return new Ai({generator:async()=>{const e=await n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 0:return new Ai({generator:async()=>{const e=await n.generator();return e.unshift(t),e},type:n.type})}},Gg=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Ai({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Ai({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Ng=(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 r=0;r<e.length;r++)n[r]=t(e[r],r);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then((e=>t(e,n)));return r},type:1};case 2:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then((e=>t(e,n)));return r},type:2}}},Rg=(e,t)=>"function"==typeof t?1===t.length?new Ai(nh(e,t)):new Ai(Ng(e,t)):new Ai(nh(e,(e=>e[t]))),Pg=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=t(e[n],n);return r},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}}},Og=(e,t)=>{let n;return n="function"==typeof t?1===t.length?oh(e,t):Pg(e,t):oh(e,(e=>e[t])),new Ai(n)},Ug=(e,t)=>new Ai({generator:async()=>{let n;n="function"==typeof t?1===t.length?nh(e,t):Ng(e,t):nh(e,(e=>e[t]));const r=[];switch(n.type){case 0:for(const e of await n.generator())for(const t of e)r.push(t);break;case 1:for(const e of n.generator())for(const t of await e)r.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)r.push(t)}return r},type:0}),Mg=(e,t)=>new Ai({generator:async()=>{let n;n=1===t.length?oh(e,t):Pg(e,t);const r=[];switch(n.type){case 1:for(const e of n.generator())for(const t of await e)r.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)r.push(t)}return r},type:0}),xg=async(e,t,n=wi)=>{const r=await e.toArray(),o=await t.toArray();if(r.length!==o.length)return!1;for(let e=0;e<r.length;e++)if(!1===n(r[e],o[e]))return!1;return!0},Fg=async(e,t,n)=>{const r=await e.toArray(),o=await t.toArray();if(r.length!==o.length)return!1;for(let e=0;e<r.length;e++){const t=r[e],s=o[e];if(!1===await n(t,s))return!1}return!0},Lg=(e,t)=>t?Wg(e,t):Bg(e),Bg=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return await e[0]}}},Wg=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new mi(yi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new mi(yi.NoMatch);return o},$g=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new mi(yi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new mi(yi.NoMatch);return o},qg=(e,t)=>t?Hg(e,t):Vg(e),Vg=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:await e[0]}}},Hg=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new mi(yi.MoreThanOneElement);r=!0,o=e}return o},Kg=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new mi(yi.MoreThanOneElement);r=!0,o=e}return o},jg=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Ai({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Ai({generator:()=>n.generator().slice(t),type:1});case 2:return new Ai({generator:async()=>(await n.generator()).slice(t),type:2})}},zg=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray();let r=0;for(;r<n.length;r++){const e=n[r];if(!1===t(e,r))break}const o=[];for(;r<n.length;r++)o.push(n[r]);return o},type:0}),Jg=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray();let r=0;for(;r<n.length;r++){const e=n[r];if(!1===await t(e,r))break}const o=[];for(;r<n.length;r++)o.push(n[r]);return o},type:0}),Xg=(e,t)=>t?Qg(e,t):Yg(e),Yg=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},Qg=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},Zg=async(e,t)=>{const n=oh(e,t),r=await hh(n);let o=0;for(const e of r)o+=e;return o},ep=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Ai({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Ai({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Ai({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},tp=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray(),r=new Array;if(1===t.length)for(const e of n){if(!0!==t(e))break;r.push(e)}else for(let e=0;e<n.length;e++){const o=n[e];if(!0!==t(o,e))break;r.push(o)}return r},type:0}),np=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray(),r=new Array;if(1===t.length){const e=t;for(const t of n){if(!0!==await e(t))break;r.push(t)}}else for(let e=0;e<n.length;e++){const o=n[e];if(!0!==await t(o,e))break;r.push(o)}return r},type:0}),rp=async(e,t)=>{const n=new Map,r=nh(e,(e=>[t(e),e])),o=await hh(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},op=async(e,t)=>{const n=new Map,r=oh(e,(async e=>[await t(e),e])),o=await hh(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},sp=async(e,t)=>{const n=e.dataFunc,r=await hh(n),o={};for(const e of r)o[t(e)]=e;return o},ip=async(e,t)=>{const n=oh(e,(async e=>[await t(e),e])),r=await hh(n),o={};for(const[e,t]of r)o[e]=t;return o},ap=async e=>{const t=e.dataFunc,n=await hh(t);return new Set(n)},cp=(e,t,n)=>n?lp(e,t,n):up(e,t),up=(e,t)=>new Ai({generator:async()=>{const n=new Set,r=t.toArray();for await(const t of e)!1===n.has(t)&&n.add(t);const o=await r;for(const e of o)!1===n.has(e)&&n.add(e);return[...n.keys()]},type:0}),lp=(e,t,n)=>new Ai({generator:async()=>{const r=[],o=await Promise.all([e.toArray(),t.toArray()]);for(const e of o)for(const t of e){let e=!1;for(const o of r)if(!0===n(t,o)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),dp=(e,t,n)=>new Ai({generator:async()=>{const r=[],o=await Promise.all([e.toArray(),t.toArray()]);for(const e of o)for(const t of e){let e=!1;for(const o of r)if(!0===await n(t,o)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),hp=(e,t)=>new Ai({generator:async()=>(await e.toArray()).filter(t),type:0}),gp=(e,t)=>new Ai({generator:async()=>{const n=Pg(e,(async(e,n)=>[await t(e,n),e])),r=await hh(n),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0}),pp=(e,t,n)=>n?vp(e,t,n):fp(e,t),fp=(e,t)=>new Ai({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]),o=n.length<r.length?n.length:r.length,s=new Array(o);for(let e=0;e<o;e++){const t=n[e],o=r[e];s[e]=[t,o]}return s},type:0}),vp=(e,t,n)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=r.length<o.length?r.length:o.length,i=new Array(s);for(let e=0;e<s;e++){const t=r[e],s=o[e];i[e]=n(t,s)}return i},type:0}),yp=(e,t,n)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=r.length<o.length?r.length:o.length,i=new Array(s);for(let e=0;e<s;e++){const t=r[e],s=o[e];i[e]=n(t,s)}return Promise.all(i)},type:0}),mp=e=>{const t=Ci.prototype,n=e.prototype,r=Object.getOwnPropertyNames(t);for(const e of r)n[e]=n[e]??t[e]};fu(_i),(e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(vu,"aggregate"),n(Su,"all"),n(Au,"allAsync"),n(_u,"append"),n(Cu,"any"),n(ku,"anyAsync"),n(Eu,"asParallel"),n(bu,"average"),n(Iu,"averageAsync"),n(Gu,"chunk"),n(Nu,"concatenate"),n(Ru,"contains"),n(Pu,"containsAsync"),n(Ou,"count"),n(xu,"countAsync"),n(Fu,"defaultIfEmpty"),n(Lu,"distinct"),n(Bu,"distinctAsync"),n(Wu,"each"),n($u,"eachAsync"),n(qu,"elementAt"),n(Vu,"elementAtOrDefault"),n(Hu,"except"),n(Ku,"exceptAsync"),n(ju,"first"),n(Xu,"firstAsync"),n(Yu,"firstOrDefault"),n(el,"firstOrDefaultAsync"),n(tl,"groupBy"),n(ol,"groupByAsync"),n(al,"groupByWithSel"),n(ll,"groupJoin"),n(gl,"groupJoinAsync"),n(vl,"intersect"),n(yl,"intersectAsync"),n(ml,"joinByKey"),n(wl,"last"),n(_l,"lastAsync"),n(Cl,"lastOrDefault"),n(kl,"lastOrDefaultAsync"),n(El,"max"),n(Gl,"maxAsync"),n(Nl,"min"),n(Ol,"minAsync"),n(Ul,"ofType"),n(Ml,"order"),n(xl,"orderBy"),n(Fl,"orderByAsync"),n(Ll,"orderByDescending"),n(Bl,"orderByDescendingAsync"),n(Wl,"orderDescending"),n($l,"partition"),n(ql,"partitionAsync"),n(Vl,"prepend"),n(Hl,"reverse"),n(Kl,"select"),n(Xl,"selectAsync"),n(Zl,"selectMany"),n(rd,"selectManyAsync"),n(od,"sequenceEquals"),n(sd,"sequenceEqualsAsync"),n(id,"single"),n(ud,"singleAsync"),n(ld,"singleOrDefault"),n(gd,"singleOrDefaultAsync"),n(pd,"skip"),n(fd,"skipWhile"),n(md,"skipWhileAsync"),n(Ad,"sum"),n(Td,"sumAsync"),n(Dd,"take"),n(kd,"takeWhile"),n(Id,"takeWhileAsync"),n(Rd,"toArray"),n(Pd,"toMap"),n(Od,"toMapAsync"),n(Ud,"toObject"),n(Md,"toObjectAsync"),n(xd,"toSet"),n(Fd,"union"),n(Wd,"unionAsync"),n($d,"where"),n(Hd,"whereAsync"),n(zd,"zip"),n(Yd,"zipAsync")})(Si),(e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(Qd,"aggregate"),n(rh,"all"),n(sh,"allAsync"),n(ih,"append"),n(ah,"any"),n(lh,"anyAsync"),n(dh,"asAsync"),n(gh,"average"),n(ph,"averageAsync"),n(fh,"chunk"),n(vh,"concatenate"),n(yh,"contains"),n(mh,"containsAsync"),n(wh,"count"),n(_h,"countAsync"),n(Ch,"defaultIfEmpty"),n(Th,"distinct"),n(Dh,"distinctAsync"),n(kh,"each"),n(Eh,"eachAsync"),n(bh,"elementAt"),n(Ih,"elementAtOrDefault"),n(Gh,"except"),n(Nh,"exceptAsync"),n(Ph,"first"),n(Mh,"firstAsync"),n(xh,"firstOrDefault"),n(Bh,"firstOrDefaultAsync"),n(Wh,"groupBy"),n(Vh,"groupByAsync"),n(jh,"groupByWithSel"),n(Xh,"groupJoin"),n(Zh,"groupJoinAsync"),n(Xh,"groupJoin"),n(Zh,"groupJoinAsync"),n(ng,"intersect"),n(rg,"intersectAsync"),n(og,"joinByKey"),n(sg,"last"),n(cg,"lastAsync"),n(ug,"lastOrDefault"),n(hg,"lastOrDefaultAsync"),n(gg,"max"),n(pg,"maxAsync"),n(fg,"min"),n(vg,"minAsync"),n(yg,"ofType"),n(Ag,"order"),n(_g,"orderBy"),n(Cg,"orderByAsync"),n(Tg,"orderByDescending"),n(Dg,"orderByDescendingAsync"),n(kg,"orderDescending"),n(Eg,"partition"),n(bg,"partitionAsync"),n(Ig,"prepend"),n(Gg,"reverse"),n(Rg,"select"),n(Og,"selectAsync"),n(Ug,"selectMany"),n(Mg,"selectManyAsync"),n(xg,"sequenceEquals"),n(Fg,"sequenceEqualsAsync"),n(Lg,"single"),n($g,"singleAsync"),n(qg,"singleOrDefault"),n(Kg,"singleOrDefaultAsync"),n(jg,"skip"),n(zg,"skipWhile"),n(Jg,"skipWhileAsync"),n(Xg,"sum"),n(Zg,"sumAsync"),n(ep,"take"),n(tp,"takeWhile"),n(np,"takeWhileAsync"),n(Rh,"toArray"),n(rp,"toMap"),n(op,"toMapAsync"),n(sp,"toObject"),n(ip,"toObjectAsync"),n(ap,"toSet"),n(cp,"union"),n(dp,"unionAsync"),n(hp,"where"),n(gp,"whereAsync"),n(pp,"zip"),n(yp,"zipAsync")})(Ai),(()=>{const{prototype:e}=Ci,t=Object.getOwnPropertyNames(_i.prototype);for(const n of t)e[n]=e[n]??_i.prototype[n];e.all=function(e){return this.every(e)},e.any=function(e){return e?this.some(e):0!==this.length},e.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},e.elementAt=function(e){if(e<0||e>=this.length)throw new vi("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]??null},e.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new mi(yi.NoMatch);return t}if(0===this.length)throw new mi(yi.NoElements);return this[0]},e.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},e.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 mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[this.length-1]},e.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]},e.max=function(e){if(0===this.length)throw new mi(yi.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)},e.min=function(e){if(0===this.length)throw new mi(yi.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)},e.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var wp,Sp;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(wp||(wp={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(Sp||(Sp={}));class Ap{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Ap._devicesService&&(Ap._devicesService=Qv.Get(Ys.ServiceName))}GetDevicesChannelsInGroupAsync(){return e=this,t=arguments,r=function*(e=!1){let t=[],n=[];const r=yield Ap._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){Qv.Get(c.ServiceName).Error("Old controller API fallback to old groups API.");for(let e of r)for(let t of e.Channels.where((e=>e.ChannelGroups.any((e=>e===this._guid)))))n.push(t);return n}const o=Object.keys(this._objectsOrder).map(Number).sort(((e,t)=>e-t));Object.values(this._objectsOrder).forEach((e=>{const n=r.select((t=>t.Channels.where((t=>t.ChannelId===e))));if(null!==n)for(let e of n)for(let n of e)t.push(n)}));for(let e of o){const r=t.firstOrDefault((t=>t.ChannelId===this._objectsOrder[e]));null!==r&&n.push(r)}return n},new((n=void 0)||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}));var e,t,n,r}get Guid(){return this._guid}set Guid(e){this._guid=e}get Name(){return this._name}set Name(e){this._name=e}get IconName(){return this._iconName}set IconName(e){this._iconName=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 Qv.Get(Op.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return Qv.Get(Op.ServiceName).ChangeGroupIconNameAsync(this,e)}}var _p,Cp,Tp,Dp,kp,Ep,bp,Ip,Gp,Np,Rp,Pp=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Op{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._objectsGroupingSupported=!1,this._configurationService=Qv.Get(it.ServiceName),this._connection=Qv.Get(_t.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{Qv.Get(Je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Pp(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}SetObjectsInGroupAndOrderAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r;let o=[],s=[];for(let e of t)if(this.IsDevice(e)){for(let t of e.Channels)o.push(`${t.ChannelId}`);s.push(`${e.Guid}`)}else{if(!this.IsDeviceChannel(e))throw new Error("Passed object is not a device or device channel!");o.push(`${e.ChannelId}`),s.push(`${e.ChannelId}`)}const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new xp(e,s),15e3,!1);switch(null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetObjectsInGroupAndOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),null==i?void 0:i.Status){case ce.OK:return new Ee(wp.Success,"");case ce.NotSupportedMethod:case ce.ResourceDoesNotExists:case ce.ResourceIsNotAvailable:return new Ee(wp.FunctionNotSupported,"");case ce.WrongData:return"GroupDoesNotExists"===i.Data?new Ee(wp.GroupDoesNotExists,i.Data):new Ee(wp.FatalError,i.Data);case ce.Error:case ce.FatalError:default:return new Ee(wp.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=Qv.Get(c.ServiceName);e.forEach(((e,n)=>{t.Debug(Op.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=Qv.Get(c.ServiceName);n.Debug(Op.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(Op.ServiceName,`Channel ${e.Name} order position [on array]: ${t} channelId: ${e.ChannelId}`)}));for(const[t,r]of Object.entries(e.ObjectsOrder))n.Debug(`new order [GROUP ${e.Name}] Order: [${t}] = ${r}`)}ChangeGroupsOrderAsync(e){return Pp(this,void 0,void 0,(function*(){var t,n;const r=e.select((e=>e.Guid)).toArray(),o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Mp(r),15e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeGroupsOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ce.OK?(yield this.GetGroupsAsync(!1),ce.OK):(Qv.Get(c.ServiceName).Error(Op.ServiceName,`Failed to change groups order, controller responded with error ${null==o?void 0:o.Status} data: ${null==o?void 0:o.Data}`),this.LogGroupsOrder(e),null==o?void 0:o.Status)}))}ChangeObjectsPositionsInGroupAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;const s=t.select((e=>e.ChannelId)).toArray(),i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Wp(e.Guid,s),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeObjectsPositionsInGroupAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ce.OK?(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),ce.OK):(null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to change objects positions in group, controller responded with error ${null==i?void 0:i.Status} data: ${null==i?void 0:i.Data}`),this.LogObjectsInGroupOrder(e,t),null==i?void 0:i.Status)}))}IsGroupsAndObjectsOrderingAvailable(){return this._objectsGroupingSupported}MoveGroupPositionAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Up(e.Guid,t),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ce.OK?(yield this.GetGroupsAsync(!1),ce.OK):(null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to move group position, controller responded with error ${null==s?void 0:s.Status} data: ${null==s?void 0:s.Data}`),null==s?void 0:s.Status)}))}MoveObjectInGroupPositionAsync(e,t,n){return Pp(this,void 0,void 0,(function*(){var r,o,s;const i=`${t.GetDevice().Guid}_${t.Number}`,a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Bp(e.Guid,i,n),15e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveObjectInGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==a?void 0:a.Status)===ce.OK?(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),ce.OK):(null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,`Failed to move object in group position, controller responded with error ${null==a?void 0:a.Status} data: ${null==a?void 0:a.Data}`),null==a?void 0:a.Status)}))}AddDeviceChannelToGroupByGuidAsync(e,t){return Pp(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s,i;const a=new jp;if(a.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");a.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,a.Data.GroupGuid=t;const c=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(a,15e3,!1);return null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddDeviceChannelToGroupByGuidAsync()"),this._configurationService.ExitConfigurationModeAsync(),null!=c&&null!=c.Status?(c.Status==ce.OK?e.ChannelGroups.push(t):null===(i=u.Log)||void 0===i||i.Error(Op.ServiceName,`Failed to add device channel ${e.Name} to group ${t}, controller responded with error ${c.Status} data: ${c.Data}`),n||(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync()),c.Status):(n||(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync()),ce.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){return Pp(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s;const i=new zp;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");i.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,i.Data.Channel=e.Number,i.Data.GroupGuid=t;const a=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(i,15e3,!1);return n||this._configurationService.ExitConfigurationModeAsync(),null!=a&&null!=a.Status?(a.Status==ce.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,`Failed to remove device channel ${e.Name} from group ${t}, controller responded with error ${a.Status} data: ${a.Data}`),n||(yield this.GetGroupsAsync(!1)),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),a.Status):(n||(yield this.GetGroupsAsync(!1)),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),ce.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupWithIconAsync(e.Name,e.IconName);if(!(t instanceof Ap))return t instanceof Ee?t:new Ee(Sp.UnknownError,"");e=t}for(let r of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(r,e,!0);if(t!==ce.OK)return null===(n=u.Log)||void 0===n||n.Error(Op.ServiceName,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`),new Ee(Sp.UnknownError,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`)}let s=yield Qv.Get(Ys.ServiceName).GetDevicesAsync();for(let n of s)for(let s of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var i of s.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(s,e,!0);if(t!==ce.OK)return null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,`Failed to remove device channel ${s.Name} from group ${e.Name}, controller responded with error ${t}`),null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpsertGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),new Ee(Sp.UnknownError,`Failed to remove device channel ${s.Name} from group ${e.Name}, controller responded with error ${t}`)}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o,s;for(let o of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(o,e,!0);if(t!==ce.OK)return null===(n=u.Log)||void 0===n||n.Error(Op.ServiceName,`Failed to add device channel ${o.Name} to group ${e}, controller responded with error ${t}`),null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ce.FatalError}let i=yield Qv.Get(Ys.ServiceName).GetDevicesAsync();for(let n of i)for(let r of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var a of r.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(r,e,!0);if(t!==ce.OK)return null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to remove device channel ${r.Name} from group ${e}, controller responded with error ${t}`),null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ce.FatalError}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ce.OK}))}ChangeGroupNameByGuidAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r;let o=new Kp,s=new Jp,i=this._groups.first((t=>t.Guid===e));s.Guid=e,s.Name=t,s.IconName=i.IconName,null===(n=o.Data)||void 0===n||n.push(s);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return new Ee(Sp.Success,"");case ce.WrongData:switch(a.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sp.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){return Pp(this,void 0,void 0,(function*(){var r,o;let s=new Kp,i=new Jp,a=this._groups.first((t=>t.Guid===e));i.Guid=e,i.Name=t,i.IconName=n,i.ObjectsOrder=a.ObjectsOrder,null===(r=s.Data)||void 0===r||r.push(i);const c=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(s,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=c&&null!=c.Status)switch(c.Status){case ce.OK:return new Ee(Sp.Success,"");case ce.WrongData:switch(c.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Ee(Sp.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r;let o=new Kp,s=new Jp,i=this._groups.first((t=>t.Guid===e));s.Guid=e,s.Name=i.Name,s.IconName=t,null===(n=o.Data)||void 0===n||n.push(s);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return new Ee(Sp.Success,"");case ce.WrongData:switch(a.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sp.UnknownError,"")}))}GetServiceName(){return Op.ServiceName}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}GetGroupByGuid(e){return this._groups.first((t=>t.Guid===e))}ChangeGroupNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}ChangeGroupIconNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}RemoveGroupAsync(e){return this.RemoveGroupByGuidAsync(e.Guid)}RemoveGroupByGuidAsync(e){return Pp(this,void 0,void 0,(function*(){var t;let n=new Vp;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=r&&null!=r.Status?null==r?void 0:r.Status:ce.Error}))}GetGroupsAsync(){return Pp(this,arguments,void 0,(function*(e=!0){var t,n;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Hp,15e3,e);let o=[];if((null==r?void 0:r.Status)===ce.OK){let t=0,s=Qv.Get(c.ServiceName),i=yield Qv.Get(Ys.ServiceName).GetDevicesAsync();return null===(n=r.Data)||void 0===n||n.forEach((n=>{t++;let r=new Ap;if(r.Guid=n.Guid,r.Name=n.Name,r.IconName=n.IconName,r.ObjectsOrder=n.ObjectsOrder,r.OrderPosition=n.OrderPosition,null==r.OrderPosition&&(r.OrderPosition=t),null==r.ObjectsOrder){this._objectsGroupingSupported=!1,r.ObjectsOrder={};let e=i.selectMany((e=>e.Channels.where((e=>e.ChannelGroups.any((e=>e==r.Guid)))))),t=0;for(let n of e)t++,r.ObjectsOrder[t]=n.ChannelId}else this._objectsGroupingSupported=!0;e||s.Info(Op.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),o.push(r)})),this._groups=o,o}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,n=!1){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid,n)}RemoveDeviceChannelFromGroupAsync(e,t,n=!1){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid,n)}AddNewGroupAsync(e){return Pp(this,void 0,void 0,(function*(){var t,n,r;let o=new Kp,s=new Jp;s.Name=e,null===(t=o.Data)||void 0===t||t.push(s);const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=i&&null!=i.Status)switch(i.Status){case ce.OK:return this._groups.first((t=>t.Name===e));case ce.WrongData:switch(null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Ee(Sp.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;let s=new Kp,i=new Jp;i.Name=e,i.IconName=t,null===(n=s.Data)||void 0===n||n.push(i);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(s,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return this._groups.first((t=>t.Name===e));case ce.WrongData:switch(null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sp.UnknownError,"")}))}}Op.ServiceName="ChannelsGroupsService";class Up extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ue.Post,this.Data=new Lp,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Mp extends ae{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ue.Post,this.Data=e}}class xp extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=ue.Post,this.Data=new Fp,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Fp{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Lp{constructor(){this.GroupGuid="",this.NewPosition=0}}class Bp extends ae{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ue.Post,this.Data=new $p,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Wp extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ue.Post,this.Data=new qp,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class $p{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class qp{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Vp extends ae{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ue.Delete}}class Hp extends ae{constructor(){super(),this.Resource="/devices/groups/",this.Method=ue.Get}}class Kp extends ae{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ue.Put,this.Data=[]}}class jp extends ae{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ue.Put,this.Data=new Xp}}class zp extends ae{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ue.Delete,this.Data=new Xp}}class Jp{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class Xp{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Yp{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class Qp{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class Zp{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class ef{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(_p||(_p={})),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"}(Cp||(Cp={})),(Rp=Tp||(Tp={}))[Rp.WaitingForUser=1]="WaitingForUser",Rp[Rp.Downloading=2]="Downloading",Rp[Rp.Unpackaging=3]="Unpackaging",Rp[Rp.CheckingApplicability=4]="CheckingApplicability",Rp[Rp.MigratingData=5]="MigratingData",Rp[Rp.CreatingBackup=6]="CreatingBackup",Rp[Rp.Deploying=7]="Deploying",Rp[Rp.Installing=8]="Installing",Rp[Rp.Removing=9]="Removing",Rp[Rp.Error=10]="Error",Rp[Rp.ReadyToDownload=11]="ReadyToDownload",Rp[Rp.PreparingSystem=12]="PreparingSystem",Rp[Rp.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",Rp[Rp.CheckingIntegrity=14]="CheckingIntegrity",Rp[Rp.UndoingInstallation=15]="UndoingInstallation",Rp[Rp.Installed=16]="Installed",(Np=Dp||(Dp={}))[Np.Ignore=0]="Ignore",Np[Np.Cancel=1]="Cancel",Np[Np.Install=2]="Install";class tf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=Cp.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class nf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=bp.Unknown}}class rf{constructor(){this.BulkUpdateStatus=kp.Success,this.DevicesUpdateResults=new Map}}!function(e){e[e.Success=0]="Success",e[e.PartialSuccess=1]="PartialSuccess",e[e.UpdatesNotFound=2]="UpdatesNotFound",e[e.CannotUnpairRetransmitters=3]="CannotUnpairRetransmitters",e[e.CannotPairRetransmitters=4]="CannotPairRetransmitters"}(kp||(kp={})),function(e){e[e.Unknown=0]="Unknown",e[e.Updated=1]="Updated",e[e.InsufficientConnection=2]="InsufficientConnection",e[e.Error=3]="Error",e[e.UnknownError=4]="UnknownError",e[e.ControllerSoftwareTooOld=5]="ControllerSoftwareTooOld"}(Ep||(Ep={})),function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate"}(bp||(bp={})),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",e[e.RetransmitterFound=10]="RetransmitterFound",e[e.ProtocolRadioUnsupported=11]="ProtocolRadioUnsupported",e[e.FeatureUnsupportedInCurrentVersion=12]="FeatureUnsupportedInCurrentVersion",e[e.CannotGetUpdatesBranch=13]="CannotGetUpdatesBranch",e[e.CannotSetUpdatesBranch=14]="CannotSetUpdatesBranch",e[e.UpdateAlreadyDownloaded=15]="UpdateAlreadyDownloaded",e[e.UpdateDownloadFailed=16]="UpdateDownloadFailed",e[e.UpdateAlreadyInstalled=17]="UpdateAlreadyInstalled",e[e.CannotGetCurrentControllerVersionTimeout=18]="CannotGetCurrentControllerVersionTimeout",e[e.CannotGetCurrentControllerVersion=19]="CannotGetCurrentControllerVersion",e[e.InstallerFileSignCheckFailed=20]="InstallerFileSignCheckFailed",e[e.UpdateFileSignCheckFailed=21]="UpdateFileSignCheckFailed",e[e.UpdateFileCheckFailed=22]="UpdateFileCheckFailed",e[e.UpdateInstallationFailed=23]="UpdateInstallationFailed"}(Ip||(Ip={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(Gp||(Gp={}));var of,sf,af,cf,uf,lf,df,hf,gf=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class pf{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=15,this._updateProviders=Qv.Get(os.ServiceName),this._logger=Qv.Get(c.ServiceName),this._connection=Qv.Get(_t.ServiceName),this._appStateService=Qv.Get(Js.ServiceName),this._extensionService=Qv.Get(tt.ServiceName)}GetAutomaticControllerUpdateDownloadStatusAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new Gf,1e4,!1);return!(r.Status!=ce.OK||!r.Data)}))}GetServiceName(){return pf.ServiceName}CheckDeviceVersionAsync(e){return gf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(Ip.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ee(Ip.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Io.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){return gf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(Ip.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ee(Ip.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Io.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const o=new yf;o.CurrentResourceVersion=r.CurrentResourceVersion,o.NewResourceVersion=r.Update.Version,o.UpdatedResourceName=r.UpdatedResourceName,o.UpdateResourceGuid=r.Update.ResourceGuid,o.UpdateDescription=new Map([["pl-PL",r.Update.Description]]);let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(n.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}return o.Protocol=s,o.ProtocolGuid=n.ProtocolGuid,(yield Qv.Get(Ys.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(o.IsUpdateSafe=!1),o}))}CheckDeviceUpdatesBulkAsync(e){return gf(this,void 0,void 0,(function*(){const t=yield yield this._updateProviders.GetUpdatesProvidersAsync(Io.Device),n=[];for(var r of t){const t=yield r.CheckUpdateBulkAsync(e);if(t instanceof Ee)return t;t.map((e=>gf(this,void 0,void 0,(function*(){const t=new yf;t.CurrentResourceVersion=e.CurrentResourceVersion,t.NewResourceVersion=e.Update.Version,t.UpdatedResourceName=e.UpdatedResourceName,t.UpdateDescription=e.UpdateDescription,t.IsUpdateSafe=!0;let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(r.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}t.Protocol=o,t.ProtocolGuid=r.ProtocolGuid,t.UpdateResourceGuid=e.Update.ResourceGuid,n.push(t)}))))}return n}))}InstallDeviceUpdateAsync(e,t,n){return gf(this,arguments,void 0,(function*(e,t,n,r=!1){var o;let s;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(Ip.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);s=t}else s=e;if(null==s.ProtocolGuid)return new Ee(Ip.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(o=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(s.ProtocolGuid,Io.Device)).first())||void 0===o?void 0:o.GetAvailableUpdateAsync(s);if(null!=i.Type)return i;this._appStateService.DisallowHibernation();const a=yield(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(s.ProtocolGuid,Io.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ce.OK)}))}InstallDevicesUpdateBulkAsync(e,t,n){return gf(this,void 0,void 0,(function*(){const r=(yield Qv.Get(Ys.ServiceName).GetDevicesAsync()).where((t=>e.includes(t.Guid))).groupBy((e=>e.ProtocolGuid)),o=[];this._appStateService.DisallowHibernation();const s=r.count();for(let e=0;e<s;e++){const i=r.elementAt(e),a=e*(100/s),c=(e+1)*(100/s),u=e=>{e.PercentageTotal=Math.floor(e.PercentageTotal/100*(c-a)+a),t(e)},l=yield yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(i.key,Io.Device),d=yield l.first().InstalUpdateBulkAsync(i.select((e=>e.Guid)).toArray(),u,n);if(d instanceof Ee)return d;o.push(d)}if(this._appStateService.AllowHibernation(),1==o.length)return o[0];{const e=new rf;o.some((e=>e.DevicesUpdateResults.count()>0))&&o.any((e=>e.BulkUpdateStatus!=kp.Success))?e.BulkUpdateStatus=kp.PartialSuccess:o.any((e=>e.BulkUpdateStatus!=kp.Success))?e.BulkUpdateStatus=o.first().BulkUpdateStatus:e.BulkUpdateStatus=kp.Success;for(const t of o)t.DevicesUpdateResults.forEach(((t,n)=>{e.DevicesUpdateResults.set(n,t)}));return e}}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return gf(this,void 0,void 0,(function*(){const e=Qv.Get(Je.ServiceName).User;if(null==e)return!1;if(""==e.SoftwareVersion||null==e.SoftwareVersion)return!0;const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<this._oldUpdateVersion||parseFloat(t)==this._oldUpdateVersion&&parseFloat(n)<=this._oldUpdateBuild)return!0;const r=yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1);if(null==r||r.Status!=ce.OK||null==r.Data)return!1;const[o,s]=r.Data.Update.Version.ContainerSoftwareVersion.toString().split(".");return parseInt(o)>parseInt(t)||parseInt(o)==parseInt(t)&&parseInt(s)>parseInt(n)}))}CanCancelFailedControllerUpdateOrGetPendingUpdateProgress(){return Qv.Get(it.ServiceName).CheckIfControllerSoftwareVersionIsEnough(6,66)}CancelFailedControllerUpdateAsync(){return gf(this,void 0,void 0,(function*(){switch((yield this._connection.SendAndWaitForResponseAsync(new Tf,1e4,!1)).Status){case ce.OK:return ce.OK;case ce.OperationNotPermitted:return ce.OperationNotPermitted;case ce.Error:default:return ce.Error}}))}CheckControllerPendingUpdateProgressAsync(e,t){return gf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>gf(this,void 0,void 0,(function*(){const o=Qv.Get(Je.ServiceName).User;if(null==o)return new Ee(Ip.UpdateActionsNotSupported,"No user data found, cannot check pending update progress.");if(""==o.SoftwareVersion||null==o.SoftwareVersion)return new Ee(Ip.CannotGetCurrentControllerVersion,"No software version data found, cannot check pending update progress.");const[s,i]=o.SoftwareVersion.split(".");if(parseFloat(s)<this._oldUpdateVersion||parseFloat(s)==this._oldUpdateVersion&&parseFloat(i)<=this._oldUpdateBuild)return new Ee(Ip.UnsupportedApiVersion,"Not supported API version, cannot check pending update progress.");let a=100;const c=60*this._updateOfflineStageTime*1e3;let u=0;const l=new tf;let d=new nf,h=new tf,g=!1;const p=n=>{let r=n.Data;switch(this._logger.Debug(`Update progress: ${r.UpdateStep}, ${r.StepProgressInPercentage}%, ${r.UpdateProgressInPercentage}% data frame status: ${n.Status}`),l.Percentage=Math.round(r.StepProgressInPercentage),l.PercentageTotal=Math.round(r.UpdateProgressInPercentage),d.SpeedMbps=r.DownloadSpeedInMbs,d.Percentage=Math.round(r.StepProgressInPercentage),d.PercentageTotal=Math.round(r.UpdateProgressInPercentage),h.AvailableUpdates=1,h.Percentage=r.StepProgressInPercentage,h.PercentageTotal=r.UpdateProgressInPercentage,h.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),u=r.StepProgressInPercentage,r.UpdateStep){case cf.DownloadingInstaller:d.CurrentTask=bp.DownloadingInstaller,h.Status=Cp.DownloadingPackage,t(d),e(h);break;case cf.DownloadingUpdate:d.CurrentTask=bp.DownloadingUpdate,h.Status=Cp.DownloadingPackage,t(d),e(h);break;case cf.CheckingUpdate:d.CurrentTask=bp.CheckingUpdate,h.Status=Cp.CheckingPackage,e(h);break;case cf.PreparingUpdate:h.Status=Cp.PreparingForUpgrade,d.CurrentTask=bp.CheckingUpdate,e(h);break;case cf.OfflineUpdateStep:case cf.InstallingUpdate:h.Status=Cp.Upgrading,e(h);break;case cf.InstallerFileSignCheckFailed:case cf.UpdateFileSignCheckFailed:h.Status=Cp.InstallationError,e(h);break;case cf.UpdateDownloadFailed:h.Status=Cp.InstallationStopped,e(h);break;case cf.UpdateInstallationFailed:h.Status=Cp.InstallationError,e(h);break;case cf.UpdateFileCheckFailed:h.Status=Cp.IncompatiblePackage,e(h);break;case cf.UpdateDownloaded:h.Status=Cp.CheckingPackage,e(h)}};let f=null;const v=t=>gf(this,void 0,void 0,(function*(){t==Os.Connected&&(clearInterval(f),l.Status=Cp.Upgraded,l.Percentage=100,l.PercentageTotal=100,e(l),clearInterval(f),yield se.Delay(5e3),n(ce.OK),Qv.Get(Js.ServiceName).OnAppStateChanged().Unsubscribe(v))}));yield this._connection.SendAndHandleResponseAsync(new Df,1e5,(t=>{var o,s,i;switch(t.Status){case ce.MultiDataResponseStart:g||(a=(null===(o=t.Data)||void 0===o?void 0:o.UpdateStep)==cf.UpdateDownloaded?100:50,g=!0),p(t);break;case ce.MultiDataResponse:p(t);break;case ce.MultiDataResponseStop:switch(null===(s=t.Data)||void 0===s?void 0:s.UpdateStep){case cf.UpdateInstallationFailed:h.Status=Cp.InstallationError,e(h),l.Percentage=0,l.PercentageTotal=0,e(l),n(new Ee(Ip.CannotProcessUpdate,"Update installation failed!"));break;case cf.InstallerFileSignCheckFailed:case cf.UpdateFileSignCheckFailed:case cf.UpdateDownloadFailed:case cf.UpdateFileCheckFailed:h.Status=Cp.DownloadingFailure,e(h),l.Percentage=0,l.PercentageTotal=0,e(l),n(new Ee(Ip.UpdateDownloadFailed,"Update download failed!"));break;case cf.OfflineUpdateStep:p(t),l.Percentage=Math.round(t.Data.StepProgressInPercentage),l.PercentageTotal=Math.round(t.Data.UpdateProgressInPercentage);let r=(100-l.PercentageTotal)/100,o=l.PercentageTotal;f=setInterval((()=>{u++,o+=r,o>100&&(o=100),u>=a?(l.Status=Cp.Upgraded,l.Percentage=100,l.PercentageTotal=100,e(l),clearInterval(f),n(ce.OK)):(l.Status=Cp.Upgrading,l.Percentage=Math.round(u),l.PercentageTotal=Math.round(o),e(l))}),c/(a-u)),Qv.Get(Js.ServiceName).OnAppStateChanged().Subscribe(v);break;case cf.UpdateDownloaded:l.Status=Cp.DownloadingPackage,l.Percentage=100,l.PercentageTotal=100,e(l),n(ce.OK);break;default:p(t),n(new Ee(Ip.CannotProcessUpdate,`Update installation failed, received UpdateStep code: ${null===(i=t.Data)||void 0===i?void 0:i.UpdateStep}!`))}break;default:r(new Ee(Ip.CannotGetUpdates,`Cannot get pending update progress, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`))}}),!0)}))))}))}CheckDevicesUpdatesAvailabilityAsync(){return gf(this,void 0,void 0,(function*(){const e=Qv.Get(Je.ServiceName).User;if(null==e)return[];if(""==e.SoftwareVersion||null==e.SoftwareVersion)return[];const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<6||6==parseFloat(t)&&parseFloat(n)<=4)return[];const r=yield this._connection.SendAndWaitForResponseAsync(new Of,1e4,!1),o=[];return null==r||(null==r?void 0:r.Status)!=ce.OK||null==(null==r?void 0:r.Data)?[]:(null==r||r.Data.forEach((e=>{if(!e.IsAvailable)return;const t=new Yp;t.DeviceGuid=e.DeviceGuid,t.CurrentVersion=e.CurrentVersion,t.NewVersion=e.NewVersion,o.push(t)})),o)}))}CheckControllerUpdatesAsync(){return gf(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new Qp,n=yield this.getRuntimeInfoAsync();if(n instanceof Ee){const e=new ff;return e.UpdateType=_p.SoftwareUpdate,e.ResponseResult=n,t.UpdatesNotAvailable.push(e),t}const r=parseInt(n.SoftwareVersion.toString().split(".")[0]),o=parseInt(n.SoftwareVersion.toString().split(".")[1]);try{e=yield this._updateProviders.GetUpdatesProvidersAsync(Io.Controller)}catch(e){if(!(e instanceof Fo))throw e;this._logger.Warning("Cannot get update providers for controller protocols! Avaliable only controller software updates!")}for(let n=0;n<e.length;n++){const r=yield e[n].GetAvailableRadioUpdateAsync();if(null!=r.Type){const o=new ff;o.ResponseResult=r,o.UpdateType=_p.RadioUpdate;let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(e[n].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}o.UpdatedResourceName=new Map([["pl-PL",s],["en-US",s]]),o.CurrentResourceVersion=yield e[n].GetCurrentRadioVersionAsync(),t.UpdatesNotAvailable.push(o)}else{const o=r,s=new vf;s.UpdatedResourceName=new Map([["pl-PL",o.UpdatedResourceName],["en-US",o.UpdatedResourceName]]),s.CurrentResourceVersion=o.CurrentResourceVersion,s.NewResourceVersion=o.Update.Version,s.UpdateDescription=new Map([["pl-PL",o.Update.Description]]),s.UpdateType=_p.RadioUpdate,s.UpdateIdentifier=oe.GenerateUUID(),s.UpdateIsDownloading=!1,s.DownloadProgress=100,s.UpdateCreationTime=null,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},o),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:e[n].GetUpdateProviderName(),UpdateType:_p.RadioUpdate}))}}let s=!0;if((r<this._oldUpdateVersion||r===this._oldUpdateVersion&&o<=this._oldUpdateBuild)&&(s=!1),s){const e=yield this._connection.SendAndWaitForResponseAsync(new kf,15e3,!1);if(null==e||e.Status!=ce.OK&&e.Status!=ce.NoData)throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);if(null!=e.Data){const r=new xo;r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,r.UpdateDescription=ie(e.Data.Update.UpdateDescription),r.UpdatedResourceName=ie(e.Data.Update.UpdateName).get("en-US");const o=new vf;o.UpdatedResourceName=ie(e.Data.Update.UpdateName),o.UpdateDescription=ie(e.Data.Update.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.NewResourceVersion=`${e.Data.Update.Version.BaseRuntime}.${e.Data.Update.Version.ContainerSoftwareVersion}`,o.UpdateType=_p.SoftwareUpdate,o.UpdateIdentifier=e.Data.Update.Guid,o.UpdateIsDownloading=e.Data.UpdateStep==cf.DownloadingInstaller||e.Data.UpdateStep==cf.DownloadingUpdate||e.Data.UpdateStep==cf.CheckingUpdate,o.DownloadProgress=e.Data.DownloadProgress,o.UpdateCreationTime=e.Data.Update.Creationtime,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:pf.ServiceName,UpdateType:_p.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Ef,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ce.NoData:const r=new ff;r.UpdateType=_p.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ee(Ip.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ce.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const o=new xo;o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateDescription=ie(e.Data.UpdateDescription),o.UpdatedResourceName=ie(e.Data.UpdateName).get("en-US");const s=new vf;s.UpdatedResourceName=ie(e.Data.UpdateName),s.UpdateDescription=ie(e.Data.UpdateDescription),s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateType=_p.SoftwareUpdate,s.UpdateIdentifier=e.Data.Guid,s.NewResourceVersion=`${e.Data.Version.BaseRuntime}.${e.Data.Version.ContainerSoftwareVersion}`,s.UpdateIsDownloading=!1,s.DownloadProgress=0,s.UpdateCreationTime=e.Data.Creationtime,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},o),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:pf.ServiceName,UpdateType:_p.SoftwareUpdate}));break;default:throw new Error(`Cannot check updates! Response status is not OK. Status: ${e.Status}`)}}}else{const e=`https://exalus-updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const r=yield fetch(e);let o,s=new xo;const i=new ff;switch(i.UpdateType=_p.SoftwareUpdate,i.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.status){case 200:null!=r.body&&(o=yield r.json());break;case 404:i.ResponseResult=new Ee(Ip.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Ee(Ip.CannotGetUpdates,`Response status code does not indicate success. Status: ${r.status}`),t.UpdatesNotAvailable.push(i)}if(null!=o){s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.Update=o;const e=new vf;e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.CurrentResourceVersion=s.CurrentResourceVersion,e.NewResourceVersion=s.Update.Version,e.UpdateDescription=new Map([["pl-PL",s.Update.Description]]),e.UpdateType=_p.SoftwareUpdate,e.UpdateIdentifier=oe.GenerateUUID(),e.DownloadProgress=100,e.UpdateIsDownloading=!1,e.UpdateCreationTime=null,t.UpdatesAvailable.push(e),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:e.UpdateIdentifier,ProviderName:pf.ServiceName,UpdateType:_p.SoftwareUpdate}))}else if(200==r.status)throw new Error(`Cannot get Update Data from response. Status: ${r.status}`)}catch(e){const n=yield this.getRuntimeInfoAsync();if(n instanceof Ee){const e=new ff;e.UpdateType=_p.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new ff;r.UpdateType=_p.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ee(Ip.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Io.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Ee)return t;const n=[];let r;r=new ef,r.Resource="Controller software",r.Type=_p.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new ef,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=_p.RadioUpdate;let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(e[t].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}r.Resource=o,n.push(r)}return n}))}GetControllerUpdateBranchAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new _f,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ce.OK)return new Ee(Ip.CannotGetUpdatesBranch,`Cannot get update branch, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data){case 0:return Gp.Public;case 1:return Gp.Beta;case 2:return Gp.Development;default:return new Ee(Ip.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return gf(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Ee)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);if(n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const o=yield this._connection.SendAndWaitForResponseAsync(new Cf(e),1e4,!1);return null==o||(null==o?void 0:o.Status)!=ce.OK?new Ee(Ip.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`):ce.OK}))}EnableAutomaticControllerUpdateDownloadAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Nf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ce.OK?new Ee(Ip.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ce.OK}))}DisableAutomaticControllerUpdateDownloadAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Rf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ce.OK?new Ee(Ip.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ce.OK}))}GetControllerUpdatesHistoryAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Pf,1e4,!1);if(null==r)return new Ee(Ip.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ce.OK:return null!=r.Data?r.Data.map((e=>{const t=new Zp;return t.UpdatedResourceName=ie(e.UpdateName),t.UpdateDescription=ie(e.UpdateDescription),t.UpdateCreationTime=e.Creationtime,t.UpdateChannel=e.UpdateChannel,t.Version=`${e.Version.BaseRuntime}.${e.Version.ContainerSoftwareVersion}`,t})):new Ee(Ip.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ce.NoData:return[];default:return new Ee(Ip.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,o){return gf(this,void 0,void 0,(function*(){const s=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),i=this._controllerUpdates.length,a=yield this.getRuntimeInfoAsync();if(a instanceof Ee)return a;const c=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ee(Ip.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if("string"!=typeof n||!s.test(n)){const o=[1],s=t=>{t.UpdateNumber=o[0],t.AvailableUpdates=i,e(t)},a=e=>gf(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==_p.RadioUpdate)).toArray(),d=[];this._appStateService.DisallowHibernation();for(let e=0;e<l.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(l[e].ProviderName)).InstallRadioUpdateAsync(l[e],s,n);yield a(5e3),t==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=l[e].UpdateIdentifier))),d.push(t),o[0]++}const h=this._controllerUpdates.find((e=>e.UpdateType==_p.SoftwareUpdate));if(null!=h)if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,s);e==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=h.UpdateIdentifier))),d.push(e),o[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(s,t,r);this._appStateService.AllowHibernation(),e==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),d.push(e),o[0]++}const g=d.where((e=>e instanceof Ee)).toArray();if(null!=g&&0!=g.length){let e="";return g.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),g.any((e=>e.Type==Ip.UpdateDownloadFailed))?new Ee(Ip.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ee(Ip.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ce.OK}{let s;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Ee(Ip.CannotGetUpdates,`Update with requested guid (${n}) not found.`);switch(this._logger.Debug(`Installing single update type: ${i.Update.UpdateType}, resource: ${i.UpdatedResourceName}, version: ${i.Update.Version}`),this._appStateService.DisallowHibernation(),i.UpdateType){case _p.RadioUpdate:return r?new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it."):(s=yield(yield this._updateProviders.GetUpdatesProviderAsync(i.ProviderName)).InstallRadioUpdateAsync(i,e,o),this._appStateService.AllowHibernation(),s==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),s);case _p.SoftwareUpdate:if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");s=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),s==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else s=yield this.UpdateControllerUsingApiAsync(e,t,r),this._appStateService.AllowHibernation(),s==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)));return s;default:return new Ee(Ip.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){return gf(this,void 0,void 0,(function*(){var n,r,o,s,i,a;switch(e.UpdateType){case Go.Container:case Go.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new mf(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new tf;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ce.MultiDataResponseStart:r.Status=Cp.PreparingForUpgrade;break;case ce.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(pf.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case Tp.CheckingApplicability:case Tp.CheckingIntegrity:case Tp.CheckingPackageIntegrity:r.Status=Cp.CheckingPackage;break;case Tp.CreatingBackup:case Tp.MigratingData:case Tp.Removing:r.Status=Cp.MovingData;break;case Tp.Deploying:case Tp.Installing:r.Status=Cp.Upgrading;break;case Tp.Downloading:r.Status=Cp.DownloadingPackage;break;case Tp.Error:r.Status=Cp.Error;break;case Tp.Installed:r.Status=Cp.Upgraded;break;case Tp.PreparingSystem:case Tp.ReadyToDownload:r.Status=Cp.PreparingForUpgrade;break;case Tp.UndoingInstallation:r.Status=Cp.InstallationStopped;break;case Tp.Unpackaging:r.Status=Cp.MovingData;break;case Tp.WaitingForUser:r.Status=Cp.Upgrading}break;case ce.MultiDataResponseStop:r.Status=Cp.OK;break;case ce.Error:case ce.FatalError:r.Status=Cp.Error}t(r)}),!1),ce.OK}catch(e){return new Ee(Ip.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case Go.RuntimeFixingScript:var c=10;let d="n/a";try{d=(yield this._extensionService.GetExtensionsInfoAsync()).first((e=>"f4f45dac-beda-441a-8d29-efc6dc977cd1"==e.ExtensionGuid)).ExtensionVersion}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}var u=d;const h=yield this.getRuntimeInfoAsync();if(h instanceof Ee)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield Qv.Get(Ys.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(pf.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new tf;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=Cp.PreparingForUpgrade,t(r);let o=2;const s=Date.now(),i=900*c+8e5,a=i/100,u=s+i,l=new Promise(((s,c)=>gf(this,void 0,void 0,(function*(){var c;try{const l=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(l),Date.now()>u)clearInterval(n),this._logger.Debug("Update already finished!"),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgraded,t(r),s(ce.OK);else{var e=u-Date.now();e<i?o=95-e/a:(clearInterval(n),n=setInterval((()=>{clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgraded,t(r),s(ce.OK)}),e))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),n=setInterval((()=>{if(o>99)clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgraded,t(r),s(ce.OK);else{var e=o;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgrading,t(r))}o++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new wf(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ce.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.InstallationError,t(r),this._logger.Debug(pf.ServiceName,`Update failed with error. Update response status: ${d.Status}`),s(new Ee(Ip.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(pf.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Error,t(r),clearInterval(n),s(new Ee(Ip.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new tf;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Ee(Ip.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Sf({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ce.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n);let r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Af("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ce.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n),r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Af(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ce.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Af("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ce.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgrading,t(n);let e,r=0;const o=.95,s=Date.now(),i=900*c+15e5,a=i/95,u=s+i,l=new Promise(((s,c)=>gf(this,void 0,void 0,(function*(){var c;try{const l=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(l),Date.now()>u)clearInterval(e),this._logger.Debug("Update already finished!"),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgraded,t(n),s(ce.OK);else{var o=u-Date.now();o<i?r=95-o/a:(clearInterval(e),e=setInterval((()=>{clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgraded,t(n),s(ce.OK)}),o))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),e=setInterval((()=>{if(r>99)clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgraded,t(n),s(ce.OK);else{var i=5+r*o;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Af("/runtime/tmp/update.sh"),12e3,!1)}catch(e){s(new Ee(Ip.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.InstallationError,t(n),new Ee(Ip.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Af("/runtime/scripts/restart_all.sh"),12e3,!1),new Ee(Ip.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Ee(Ip.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Ee(Ip.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Ee(Ip.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}DownloadControllerUpdateNewApiAsync(e,t,n,r){return gf(this,void 0,void 0,(function*(){return new Promise(((t,o)=>gf(this,void 0,void 0,(function*(){yield this._connection.SendAndHandleResponseAsync(new bf,this._updateRequestTimeout,(o=>{var s,i,a,c;const u=new nf;switch(u.UpdatedResourceName=ie(e.Update.UpdateName),o.Status){case ce.MultiDataResponseStart:u.Percentage=0,u.SpeedMbps=0,u.PercentageTotal=0,u.CurrentTask=bp.DownloadingInstaller,n(u);break;case ce.MultiDataResponse:if(null!=o.Data){switch(u.Percentage=o.Data.StepProgressInPercentage,u.SpeedMbps=o.Data.DownloadSpeedInMbs,u.PercentageTotal=r?Math.round(2*(null===(s=o.Data)||void 0===s?void 0:s.UpdateProgressInPercentage)):Math.round(null===(i=o.Data)||void 0===i?void 0:i.UpdateProgressInPercentage),o.Data.UpdateStep){case cf.DownloadingInstaller:u.CurrentTask=bp.DownloadingInstaller;break;case cf.DownloadingUpdate:u.CurrentTask=bp.DownloadingUpdate;break;default:u.CurrentTask=bp.CheckingUpdate}n(u)}break;case ce.MultiDataResponseStop:if(null!=o.Data)switch(o.Data.UpdateStep){case cf.UpdateDownloaded:u.Percentage=100,u.PercentageTotal=r?Math.round(2*(null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)):Math.round(null===(c=o.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),u.SpeedMbps=0,u.CurrentTask=bp.CheckingUpdate,n(u),t(ce.OK);break;case cf.UpdateDownloadFailed:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=bp.Unknown,n(u),t(new Ee(Ip.UpdateDownloadFailed,"Update download failed!"))}break;case ce.Error:case ce.FatalError:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=bp.Unknown,n(u),t(new Ee(Ip.CannotProcessUpdate,"Update download failed!"))}}),!1)}))))}))}InstallUpdateNewApiAsync(e,t,n,r){return gf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>gf(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let o=0;const s=new tf;let i=null;const a=e=>gf(this,void 0,void 0,(function*(){e==Os.Connected&&(clearInterval(i),s.Status=Cp.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),yield se.Delay(5e3),n(ce.OK),Qv.Get(Js.ServiceName).OnAppStateChanged().Unsubscribe(a))}));yield this._connection.SendAndHandleResponseAsync(new If,this._updateRequestTimeout,(c=>{var u,l;switch(s.UpdatedResourceName=ie(e.Update.UpdateName),c.Status){case ce.MultiDataResponseStart:s.Status=Cp.PreparingForUpgrade,s.Percentage=null===(u=c.Data)||void 0===u?void 0:u.StepProgressInPercentage,s.PercentageTotal=null===(l=c.Data)||void 0===l?void 0:l.UpdateProgressInPercentage,t(s);break;case ce.MultiDataResponse:null!=c.Data&&(s.Status=Cp.Upgrading,s.Percentage=Math.round(c.Data.StepProgressInPercentage),s.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage),o=c.Data.StepProgressInPercentage,t(s));break;case ce.MultiDataResponseStop:if(null!=c.Data)switch(c.Data.UpdateStep){case cf.UpdateInstallationFailed:s.Status=Cp.InstallationError,s.Percentage=0,s.PercentageTotal=0,t(s),n(new Ee(Ip.CannotProcessUpdate,"Update installation failed!"));break;case cf.OfflineUpdateStep:{s.Percentage=Math.round(c.Data.StepProgressInPercentage),s.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage);let e=(100-s.PercentageTotal)/100,u=s.PercentageTotal;i=setInterval((()=>{o++,u+=e,u>100&&(u=100),o>=100?(s.Status=Cp.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),n(ce.OK)):(s.Status=Cp.Upgrading,s.Percentage=Math.round(o),s.PercentageTotal=Math.round(u),t(s))}),r/(100-o)),Qv.Get(Js.ServiceName).OnAppStateChanged().Subscribe(a)}}break;case ce.Error:case ce.FatalError:s.Status=Cp.Error,s.Percentage=0,s.PercentageTotal=0,t(s),n(new Ee(Ip.CannotProcessUpdate,"Update installation failed!"))}}),!1)}))))}))}UpdateControllerUsingApiAsync(e,t,n){return gf(this,void 0,void 0,(function*(){if(n){const r=yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1);if((null==r?void 0:r.Status)==ce.NoData)return new Ee(Ip.DeviceIsUpToDate,"No updates available!");if(null==r||(null==r?void 0:r.Status)!=ce.OK||null==(null==r?void 0:r.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data.UpdateStep){case cf.DownloadingInstaller:case cf.DownloadingUpdate:case cf.UpdateDownloaded:return new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case cf.InstallingUpdate:case cf.PreparingUpdate:return new Ee(Ip.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield this.DownloadControllerUpdateNewApiAsync(r.Data,e,t,n)}}else{const o=yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1);if((null==o?void 0:o.Status)==ce.NoData)return new Ee(Ip.DeviceIsUpToDate,"No updates available!");if(null==o||(null==o?void 0:o.Status)!=ce.OK||null==(null==o?void 0:o.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`);switch(o.Data.UpdateStep){case cf.DownloadingInstaller:case cf.DownloadingUpdate:return new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded, or download in progress.");case cf.InstallingUpdate:case cf.PreparingUpdate:return new Ee(Ip.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case cf.UpdateDownloaded:return yield this.InstallUpdateNewApiAsync(o.Data,e,t,n);default:var r=yield this.DownloadControllerUpdateNewApiAsync(o.Data,e,t,n);return r!=ce.OK?r:yield this.InstallUpdateNewApiAsync(o.Data,e,t,n)}}}))}getRuntimeInfoAsync(){return gf(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof us&&e.code==Lo.Timeout?new Ee(Ip.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Ee(Ip.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}pf.ServiceName="UpdatesService";class ff{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class vf{constructor(){this._updateIdentifier="",this._updateResourceName=new Map,this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map,this._updateIsDownloading=!1,this._updateCheckDownloadProgress=0,this._updateCreationTime=null}get UpdateCreationTime(){return this._updateCreationTime}get DownloadProgress(){return this._updateCheckDownloadProgress}get UpdateDescription(){return this._updateDescription}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}get UpdateIsDownloading(){return this._updateIsDownloading}set UpdateCreationTime(e){this._updateCreationTime=e}set DownloadProgress(e){this._updateCheckDownloadProgress=e}set UpdateDescription(e){this._updateDescription=e}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}set UpdateIsDownloading(e){this._updateIsDownloading=e}}class yf{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 mf extends ae{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=ue.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"}(of||(of={})),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"}(sf||(sf={})),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"}(af||(af={})),function(e){e[e.InstallerFileSignCheckFailed=-5]="InstallerFileSignCheckFailed",e[e.UpdateFileSignCheckFailed=-4]="UpdateFileSignCheckFailed",e[e.UpdateInstallationFailed=-3]="UpdateInstallationFailed",e[e.UpdateDownloadFailed=-2]="UpdateDownloadFailed",e[e.UpdateFileCheckFailed=-1]="UpdateFileCheckFailed",e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.CheckingUpdate=2]="CheckingUpdate",e[e.PreparingUpdate=3]="PreparingUpdate",e[e.InstallingUpdate=4]="InstallingUpdate",e[e.DownloadingInstaller=5]="DownloadingInstaller",e[e.UpdateDownloaded=6]="UpdateDownloaded",e[e.OfflineUpdateStep=7]="OfflineUpdateStep"}(cf||(cf={}));class wf extends ae{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ue.Put,this.Data=e}}class Sf extends ae{constructor(e){super(),this.Resource="/users/user/login",this.Method=ue.Put,this.Data=e}}class Af extends ae{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ue.Post,this.Data=e}}class _f extends ae{constructor(){super(),this.Resource="/updates/branch",this.Method=ue.Get}}class Cf extends ae{constructor(e){super(),this.Resource="/updates/branch",this.Method=ue.Put,this.Data=e}}class Tf extends ae{constructor(){super(),this.Resource="/updates/failed/cancel",this.Method=ue.Put}}class Df extends ae{constructor(){super(),this.Resource="/updates/pending/progress",this.Method=ue.Get}}class kf extends ae{constructor(){super(),this.Resource="/updates/pending",this.Method=ue.Get}}class Ef extends ae{constructor(){super(),this.Resource="/updates/check",this.Method=ue.Get}}class bf extends ae{constructor(){super(),this.Resource="/updates/download",this.Method=ue.Post}}class If extends ae{constructor(){super(),this.Resource="/updates/install",this.Method=ue.Post}}class Gf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=ue.Get}}class Nf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=ue.Put}}class Rf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=ue.Put}}class Pf extends ae{constructor(){super(),this.Resource="/updates/history",this.Method=ue.Get}}class Of extends ae{constructor(){super(),this.Resource="/updates/devices/availability",this.Method=ue.Get}}!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"}(uf||(uf={})),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"}(lf||(lf={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(df||(df={}));class Uf{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"}(hf||(hf={}));var Mf,xf,Ff,Lf,Bf,Wf,$f,qf=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Vf{constructor(){this._connection=null,this._connection=Qv.Get(_t.ServiceName)}GetServiceName(){return Vf.ServiceName}GetStatesByIntervalAsync(e,t,n,r,o,s){return qf(this,arguments,void 0,(function*(e,t,n,r,o,s,i=!1){var a;try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Ee(uf.FunctionalityNotSupported,"State history data is not supported with this version of controller software, update software to get this functionality.");let c;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(uf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new Ee(uf.InvalidChannelNumber,`Given channel not found in device with guid: ${c.Guid}.`);if(!c.Channels.any((e=>e.Number==t&&e.AvailableResponseTypes.any((e=>e.Type==n)))))return new Ee(uf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new Kf;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.Range=r,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=o,u.Offset=s;const l=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new Hf(u),2e4,!1);if(null==l)return new Ee(uf.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case ce.WrongData:switch(l.Data){case"IncorrectLimitValue":return new Ee(uf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ee(uf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ee(uf.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Ee(uf.OtherError,"Cannot get state history data - unknown error!")}case ce.FatalError:return new Ee(uf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ce.ResourceDoesNotExists:return new Ee(uf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ce.OK:if(null==l.Data)return new Ee(uf.NoData,"Controller responede with status OK, but response does not contain data!");if(l.Data.AggregateDataList=l.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===bt.MeasuredEnergy){const e=l.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return l.Data.Data=e,l.Data}return l.Data;default:return new Ee(uf.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new Ee(uf.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){return qf(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new jf,12e3,!1);return null==t?new Ee(uf.OtherError,"Cannot get available states - response is null."):t.Status!=ce.OK?new Ee(uf.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Ee(uf.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Uf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Ee(uf.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return qf(this,void 0,void 0,(function*(){return!(parseFloat((yield Qv.Get(os.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}GetAvailableStatesPerChannelAsync(e,t){return qf(this,void 0,void 0,(function*(){var n;let r;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(uf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);r=t}else r=e;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new zf(new Jf(r.Guid,t)),8e3,!1);if(null==o)return new Ee(uf.OtherError,"Cannot get available states - response is null.");switch(o.Status){case ce.ResourceDoesNotExists:switch(o.Data){case"DeviceNotFound":return new Ee(uf.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Ee(uf.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Ee(uf.OtherError,"Cannot get available states - unknown error!")}case ce.OK:{if(null==o.Data)return new Ee(uf.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!");const e=o.Data.AvailableStates.map((e=>{const t=new Uf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return o.Data.AvailableStates=e,o.Data}default:return new Ee(uf.OtherError,`Cannot get available states - controller responded with response code ${o.Status}`)}}))}}Vf.ServiceName="StatesHistoryService";class Hf extends ae{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ue.Get,this.Data=e}}class Kf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=lf.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class jf extends ae{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ue.Get}}class zf extends ae{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=ue.Get,this.Data=e}}class Jf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}($f=Mf||(Mf={}))[$f.User=0]="User",$f[$f.Controller=1]="Controller",$f[$f.Marketing=2]="Marketing",(Wf=xf||(xf={}))[Wf.Notification=0]="Notification",Wf[Wf.Message=1]="Message",Wf[Wf.Alarm=2]="Alarm",Wf[Wf.Warning=3]="Warning",Wf[Wf.Info=4]="Info",(Bf=Ff||(Ff={}))[Bf.Other=0]="Other",Bf[Bf.UserLoggedIn=1]="UserLoggedIn",Bf[Bf.UserLoggedOut=2]="UserLoggedOut",Bf[Bf.FoundNewDevice=3]="FoundNewDevice",Bf[Bf.DoorBellPress=4]="DoorBellPress",Bf[Bf.AddedNewDevice=5]="AddedNewDevice",Bf[Bf.RemovedDevice=6]="RemovedDevice",Bf[Bf.RegisteredNewUser=7]="RegisteredNewUser",Bf[Bf.GotAccessToTheInternet=8]="GotAccessToTheInternet",Bf[Bf.LostAccessToTheInternet=9]="LostAccessToTheInternet",Bf[Bf.RemovedUser=10]="RemovedUser",Bf[Bf.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(Lf||(Lf={}));var Xf=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Yf{constructor(){this._chatSubscriptions=[],this._connection=Qv.Get(_t.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==xf.Message)return;const n=new Qf;n.DateTime=t.DateTime,n.Guid=t.Guid,n.MessageSource=t.MessageSource,n.MessageText=t.MessageText,n.MessageType=t.MessageType,n.RecipientUserGuid=t.RecipientUserGuid?t.RecipientUserGuid:"n/a",n.Sender=t.Sender,n.SenderName=t.SenderName?t.SenderName:"n/a",n.SenderUserGuid=t.SenderUserGuid?t.SenderUserGuid:"n/a",n.TextToSpeechMessage=t.TextToSpeechMessage?t.TextToSpeechMessage:"";for(let[e,r]of Object.entries(t.MessageActions))n.MessageActions.set(Lf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return Xf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Zf,12e3,!1);if(null==e)return new Ee(lv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ce.OK)return new Ee(lv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ee(lv.NoData,"Cannot get messages - controller responded with status OK, but response does not contain data!");const t=[];return e.Data.forEach((e=>{if(null==e.RecipientUserGuid&&e.MessageType==xf.Message)return;const n=new Qf;n.DateTime=e.DateTime,n.Guid=e.Guid,n.MessageSource=e.MessageSource,n.MessageText=e.MessageText,n.MessageType=e.MessageType,n.RecipientUserGuid=e.RecipientUserGuid?e.RecipientUserGuid:"n/a",n.Sender=e.Sender,n.SenderName=e.SenderName?e.SenderName:"n/a",n.SenderUserGuid=e.SenderUserGuid?e.SenderUserGuid:"n/a",n.TextToSpeechMessage=e.TextToSpeechMessage?e.TextToSpeechMessage:"";for(let[t,r]of Object.entries(e.MessageActions))n.MessageActions.set(Lf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new Ee(lv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return Xf(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new ev(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class Qf{constructor(){this._sender=Mf.Controller,this._messageType=xf.Info,this._messageSource=Ff.Other,this._senderUserGuid="",this._recipientUserGuid="",this._textToSpeechMessage="",this._messageActions=new Map,this._messageActionsData=new Map,this._guid="",this._senderName="",this._messageText="",this._dateTime=(new Date).toDateString()}get Sender(){return this._sender}get MessageType(){return this._messageType}get MessageSource(){return this._messageSource}get SenderUserGuid(){return this._senderUserGuid}get RecipientUserGuid(){return this._recipientUserGuid}get TextToSpeechMessage(){return this._textToSpeechMessage}get MessageActions(){return this._messageActions}get MessageActionsData(){return this._messageActionsData}get Guid(){return this._guid}get SenderName(){return this._senderName}get MessageText(){return this._messageText}get DateTime(){return this._dateTime}set Sender(e){this._sender=e}set MessageType(e){this._messageType=e}set MessageSource(e){this._messageSource=e}set SenderUserGuid(e){this._senderUserGuid=e}set RecipientUserGuid(e){this._recipientUserGuid=e}set TextToSpeechMessage(e){this._textToSpeechMessage=e}set MessageActions(e){this._messageActions=e}set MessageActionsData(e){this._messageActionsData=e}set Guid(e){this._guid=e}set SenderName(e){this._senderName=e}set MessageText(e){this._messageText=e}set DateTime(e){this._dateTime=e}}class Zf extends ae{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ue.Get}}class ev extends ae{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ue.Put,this.Data=e}}var tv,nv,rv,ov=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class sv{constructor(){this._chatSubscriptions=[],this._connection=Qv.Get(_t.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{if("/homemessaging/notify/message/new"===e.Resource){const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==xf.Message){const e=new iv;e.DateTime=t.DateTime,e.Guid=t.Guid,e.MessageText=t.MessageText,e.SenderName=t.SenderName?t.SenderName:"n/a",this._chatSubscriptions.forEach((t=>{t(e)}))}}}))}GetCachedMessagesAsync(){return ov(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new cv,12e3,!1);if(null==e)return new Ee(lv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ce.OK)return new Ee(lv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ee(lv.NoData,"Cannot get messages - controller responded with status OK, but response does not contain data!");const t=[];return e.Data.forEach((e=>{if(null==e.RecipientUserGuid&&e.MessageType==xf.Message){const n=new iv;n.DateTime=e.DateTime,n.Guid=e.Guid,n.MessageText=e.MessageText,n.SenderName=e.SenderName?e.SenderName:"n/a",t.push(n)}})),t}catch(e){return new Ee(lv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return ov(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new av(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class iv{constructor(){this._guid="",this._senderName="",this._messageText="",this._dateTime=""}get Guid(){return this._guid}get SenderName(){return this._senderName}get MessageText(){return this._messageText}get DateTime(){return this._dateTime}set Guid(e){this._guid=e}set SenderName(e){this._senderName=e}set MessageText(e){this._messageText=e}set DateTime(e){this._dateTime=e}}class av extends ae{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ue.Put,this.Data=e}}class cv extends ae{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ue.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(tv||(tv={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(nv||(nv={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(rv||(rv={}));var uv,lv,dv,hv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class gv{constructor(){this._chatSubscriptions=[],this._connection=Qv.Get(_t.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new yv;if(n.DateTime=t.DateTime,n.Guid=t.Guid,n.MessageText=t.MessageText?t.MessageText:"",n.SenderName=t.SenderName?t.SenderName:"n/a",null!=t.ControllerActivities)for(let[e,r]of Object.entries(t.ControllerActivities)){const t=tv[e],o=new Map;for(let[e,t]of Object.entries(r))o.set(e,t);n.ControllerActivities.set(t,o)}if(null!=t.Errors)for(let[e,r]of Object.entries(t.Errors))n.Errors.set(rv[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return hv(this,void 0,void 0,(function*(){return(yield Qv.Get(tt.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return hv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new fv,8e3,!1);return null==e||null==e.Status?new Ee(lv.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ce.OK?new Ee(lv.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Ee(lv.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Ee(lv.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return hv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new vv(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot set chat configuration! ${e}`),ce.FatalError}}))}SendMessageAsync(e){return hv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new pv(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){var t;null===(t=this._chatSubscriptions)||void 0===t||t.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class pv extends ae{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=ue.Put,this.Data=e}}class fv extends ae{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ue.Get}}class vv extends ae{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ue.Put,this.Data=e}}class yv{constructor(){this._messageActions=new Map,this._errors=new Map,this._guid="",this._senderName="",this._messageText="",this._dateTime=""}get ControllerActivities(){return this._messageActions}get Errors(){return this._errors}get Guid(){return this._guid}get SenderName(){return this._senderName}get MessageText(){return this._messageText}get DateTime(){return this._dateTime}set ControllerActivities(e){this._messageActions=e}set Errors(e){this._errors=e}set Guid(e){this._guid=e}set SenderName(e){this._senderName=e}set MessageText(e){this._messageText=e}set DateTime(e){this._dateTime=e}}!function(e){e[e.ControllerChat=0]="ControllerChat",e[e.FamilyChat=1]="FamilyChat",e[e.GptChat=2]="GptChat"}(uv||(uv={}));class mv{constructor(){this._services={ControllerChat:new Yf,GptChat:new gv,FamillyChat:new sv}}GetServiceName(){return mv.ServiceName}GetChatImplementation(e){switch(e){case uv.ControllerChat:return this._services.ControllerChat;case uv.FamilyChat:return this._services.FamillyChat;case uv.GptChat:return this._services.GptChat;default:throw new wv(`Chat with type ${e} not implemented!`)}}}mv.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(lv||(lv={}));class wv extends Error{constructor(e){super(e),this.message=e,this.name="ChatNotImplementedException"}}!function(e){e[e.ResourceIsNotAvailable=-11]="ResourceIsNotAvailable",e[e.AnotherAppWithGivenAccessTokenAlreadyExists=-10]="AnotherAppWithGivenAccessTokenAlreadyExists",e[e.AppGuidDoesNotExists=-7]="AppGuidDoesNotExists",e[e.AppUrlToShort=-6]="AppUrlToShort",e[e.AppUserNameToShort=-5]="AppUserNameToShort",e[e.AppUserIdToShort=-4]="AppUserIdToShort",e[e.AccessTokenToShort=-3]="AccessTokenToShort",e[e.AppNameToShort=-2]="AppNameToShort",e[e.UnkownError=0]="UnkownError",e[e.Changed=1]="Changed"}(dv||(dv={}));var Sv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Av{constructor(){this._connection=Qv.Get(_t.ServiceName),this._log=Qv.Get(c.ServiceName)}GetServiceName(){return Av.ServiceName}IsSupportedAsync(){return Sv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new _v,2e3,!0);return this._log.Debug(Av.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ce.WrongData}))}GetConnectedAppsAsync(){return Sv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Cv,2e3,!0);return(null==e?void 0:e.Status)===ce.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Sv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Dv(e),2e3,!1);switch(null==t?void 0:t.Status){case ce.OK:return new Ee(dv.Changed,"");case ce.WrongData:switch(t.Data){case"AccessTokenToShort":return new Ee(dv.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Ee(dv.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Ee(dv.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Ee(dv.AppNameToShort,t.Data);case"AppUrlToShort":return new Ee(dv.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Ee(dv.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Ee(dv.AppUserNameToShort,t.Data);default:return new Ee(dv.UnkownError,t.Data)}case ce.ResourceDoesNotExists:case ce.ResourceIsNotAvailable:return new Ee(dv.ResourceIsNotAvailable,t.Data);default:return new Ee(dv.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Sv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Tv(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}Av.ServiceName="ConnectedAppsService";class _v extends ae{constructor(){super(),this.Resource="/applications/app/auth",this.Method=ue.Put,this.Data=""}}class Cv extends ae{constructor(){super(),this.Resource="/applications/get",this.Method=ue.Get}}class Tv extends ae{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=ue.Delete,this.Data=e}}class Dv extends ae{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=ue.Put,this.Data=e}}var kv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ev{constructor(){try{const e=window.location.href,t=new URL(e),n=new URLSearchParams(t.search),r=n.get("mig_c_enc"),o=n.get("mig_controllers"),s=n.get("mig_lang");if(null!==r){const e=decodeURIComponent(this.b64DecodeUnicode(decodeURIComponent(r)));localStorage.setItem(Ev.AppUserControllersKeyName,e)}null!==o&&localStorage.setItem(Ev.AppUserControllersKeyName,decodeURIComponent(o)),null!==s&&localStorage.setItem(Ev.AppSelectedLanguageKeyName,s)}catch(e){console.error(e)}}waitForNavigatorObject(e){return new Promise(((t,n)=>{setTimeout((()=>{n(new Error(`Timed out waiting for navigator.${e}`))}),1e4),function n(){navigator[e]?t(navigator[e]):requestAnimationFrame(n)}()}))}b64DecodeUnicode(e){return decodeURIComponent(Array.prototype.map.call(atob(e),(function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))}decodeUriJsonData(e){return JSON.parse(decodeURIComponent(e))}encodeUriJsonData(e){return encodeURIComponent(JSON.stringify(e))}IsExalusNativeMigrationAvailable(){return void 0!==navigator.exalusMigration}GetServiceName(){return Ev.ServiceName}IsMigrationDataAvailableAsync(){return kv(this,void 0,void 0,(function*(){try{if(this.isIosNavtie()){var e=yield Ev.GetIosMigrationStatus();return null!==e&&e}if(!navigator.userAgent.endsWith("LavvaAndroidNative")||void 0!==navigator.exalusMigration&&null!==navigator.exalusMigration||(yield this.waitForNavigatorObject("exalusMigration")),this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.IsMigrationDataAvailableAsync();return null!=e&&e.DataMigrated}return null!==localStorage.getItem(Ev.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Ev.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return kv(this,void 0,void 0,(function*(){try{if(this.isIosNavtie()){let e=yield Ev.GetIosControllerList();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetControllersDataAsync();return void 0===e?null:e}let e=localStorage.getItem(Ev.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return kv(this,void 0,void 0,(function*(){try{if(this.isIosNavtie()){let e=yield Ev.GetIosDefaultLanguage();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetLanguageCodeAsync();return void 0===e?null:e}let e=localStorage.getItem(Ev.AppSelectedLanguageKeyName);return null!=e?e:null}}catch(e){return console.error(e),null}}))}static GetIosMigrationStatus(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.isMigrationAvaliable=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("IsMigrationAvaliable")}catch(e){r(e)}}))}static GetIosControllerList(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleControllers=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetControllers")}catch(e){r(e)}}))}static GetIosDefaultLanguage(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleLanguage=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetDefaultLanguage")}catch(e){r(e)}}))}isIosNavtie(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusControllerData);return t&&n}}Ev.AppSelectedLanguageKeyName="App___SelectedLanguage",Ev.AppUserControllersKeyName="App___UserControllersListDatabase",Ev.ServiceName="DataMigrationService";var bv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Iv{constructor(){this._localIpAddress=null,this._publicIpAddress=null,this._gatewayIpAddress=null,this._macAddress=null,this._isInLocalNetwork=!1,this.nativeFindControllerApi=null,void 0!==navigator.findEfcController&&(this.nativeFindControllerApi=navigator.findEfcController),this._connection=Qv.Get(_t.ServiceName),this._logger=Qv.Get(c.ServiceName),this._storage=Qv.Get(l.ServiceName),Qv.Get(Je.ServiceName).OnUserLoggedInEvent().Subscribe((e=>bv(this,void 0,void 0,(function*(){var e;try{yield se.Delay(5e3);const t=yield this.GetControllerNetworkConfigurationAsync();if(null!=t){this._localIpAddress=t.LocalIPv4,this._publicIpAddress=t.PublicIPv4,this._gatewayIpAddress=t.GatewayIPv4,this._macAddress=t.MAC,this._storage.Save(Iv.ServiceName,"LocalIpAddress",this._localIpAddress);const n=this.GetControllerHostName(this._connection.GetControllerSerialNumber());this._logger.Debug(`Looking for controller in local network with host name: ${n}`);let r=null;this.isIosNative()?r=yield this.getIosControllerIpAsync(n):null!==this.nativeFindControllerApi&&(r=yield null===(e=this.nativeFindControllerApi)||void 0===e?void 0:e.FindControllerAsync(n)),null!=r&&""!=r?(this._isInLocalNetwork=!0,this._logger.Debug(Iv.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(Iv.ServiceName,"Controller not found in local network."))}else this._logger.Error(Iv.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(Iv.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return bv(this,void 0,void 0,(function*(){if(this.isIosNative()){const t=yield this.getIosControllerIpAsync(e);return""==t?null:t}return null!==this.nativeFindControllerApi?this.nativeFindControllerApi.FindControllerAsync(e):Promise.resolve(null)}))}GetLastKnownControllerLocalIpAddress(){return null!==this._localIpAddress?this._localIpAddress:this._storage.Read(Iv.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){return bv(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Gv,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(Iv.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return Iv.ServiceName}isIosNative(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusFindController);return t&&n}getIosControllerIpAsync(e,t=2e4){let n;return new Promise(((r,o)=>{n=setTimeout((()=>{this._logger.Error("Cannot find controller in local network, timeout!"),r("")}),t);try{window.nativeEvent.exalusFindController.handleFindController=e=>{clearTimeout(n),r(e)},window.webkit.messageHandlers.exalusFindController.postMessage(e)}catch(e){this._logger.Error(`Cannot find controller in local network, error: ${e}`),r("")}}))}}Iv.ServiceName="FindControllerService";class Gv extends ae{constructor(){super(),this.Resource="/network/lan/",this.Method=ue.Get}}var Nv,Rv,Pv,Ov=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Uv{constructor(){this._errorOccuredEvent=new a,this._connectionStateChangedEvent=new a,this._dataReceivedEvent=new a,this._onMessageReceived=new a,this._log=Qv.Get(c.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._logPackets=!0,this.socket=null,this._address=null,this._port="81",this._isOpen=!1,this._pin=void 0,this._serial=void 0,this._auth=null,this._initialized=!1,this._pingInterval=5e3,this._pingIntervalId=null,this._lastReceivedPacketTime=Date.now()}SendAndHandleStreamAsync(e,t,n){throw new Error("Method not implemented.")}Initialize(){this._initialized||(this._initialized=!0,this._controllerConfiguration=Qv.Get(it.ServiceName),this._cache=Qv.Get(Le.ServiceName),this._session=Qv.Get(Je.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return Ov(this,void 0,void 0,(function*(){const t=`http://${window.location.hostname}/controller_info`;let n=yield fetch(t,{method:"GET"});return!!n.ok&&(yield n.text())===`${e.SerialNumber}:${e.PIN}`}))}PingControllerAsync(){return Ov(this,void 0,void 0,(function*(){var e;if((null===(e=this.socket)||void 0===e?void 0:e.readyState)!==WebSocket.OPEN)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new ae;return t.Resource="/system/ping",t.Method=ue.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}GetControllerSerialNumber(){return this._serial}GetControllerPin(){return this._pin}SetServersBrokerAddress(e){throw new Error("Method not implemented.")}SetDefaultPacketsBrokerAddress(e){throw new Error("Method not implemented.")}GetServerAddressAsync(){return Qv.IsRunningFromLocalNetwork()&&(this._address=`${window.location.hostname}:${this._port}`),Promise.resolve(this._address)}ConnectAsync(e){return new Promise(((t,n)=>{var r;this.Initialize(),null===(r=this.socket)||void 0===r||r.close(),this.socket=new WebSocket(`ws://${e}/api`),this._log.Debug(Uv.ServiceName,`Connecting to the WebSockets server ${e}`),this.socket.onerror=t=>(this._log.Debug(Uv.ServiceName,`Error occured in the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._errorOccuredEvent.Invoke(["WebSockets",t.toString()]),n(de.FailedToConnect)),this.socket.onopen=n=>(this._log.Debug(Uv.ServiceName,`Connected to the WebSockets server ${e} info: \n${JSON.stringify(n)}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(he.Connected),this._pingIntervalId=setInterval((()=>Ov(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval),t(de.Connected)),this.socket.onclose=t=>{this._log.Debug(Uv.ServiceName,`Disconnected from the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(he.Disconnected)},this.socket.onmessage=t=>{this._log.Debug(Uv.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);try{let e=JSON.parse(t.data);this._log.Debug(Uv.ServiceName,`Received data frame: ${e.Status}`),this._dataReceivedEvent.Invoke(e)}catch(e){this._log.Error(Uv.ServiceName,`Failed to parse message: ${t.data}`)}},this._connectionStateChangedEvent.Invoke(he.Connecting)}))}AuthorizeAsync(e){return Ov(this,void 0,void 0,(function*(){return Qv.WorksInContextOf=e.SerialNumber,!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Uv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,this._connectionStateChangedEvent.Invoke(he.ConnectedAndAuthorized),!0)}))}ConnectAndAuthorizeAsync(e){return Ov(this,void 0,void 0,(function*(){if(Qv.WorksInContextOf=e.SerialNumber,this._log.Debug(Uv.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`),!(yield this.AuthorizeAsync(e)))return de.AuthorizationFailed;let t=yield this.GetServerAddressAsync();return null==t?de.FailedToConnectToServer:yield this.ConnectAsync(t)}))}DisconnectAsync(){var e;return this._log.Debug(Uv.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._connectionStateChangedEvent.Invoke(he.Disconnecting),null!==this._pingIntervalId&&clearInterval(this._pingIntervalId),null===(e=this.socket)||void 0===e||e.close(),Promise.resolve()}IsConnected(){return this._isOpen}EnablePacketsLogging(){this._log.Debug(Uv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Uv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Uv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.socket)||void 0===n||n.send(r):this._log.Error(Uv.ServiceName,`Failed to send data frame: ${r}`),this._isOpen}SendAsync(e){return this._isOpen?Promise.resolve(this.SendData(e,this._logPackets)):Promise.resolve(!1)}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,r)}SendAndHandleResponseAsync(e,t,n,r){return Ov(this,void 0,void 0,(function*(){var o;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===(o=this._session)||void 0===o?void 0:o.WaitForSessionCreationAsync()),new Promise(((o,a)=>Ov(this,void 0,void 0,(function*(){const c=()=>window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(u);let t=`Response timeout, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;this._log.Error(Uv.ServiceName,t),a(new Error(t))}),t);let u=l=>Ov(this,void 0,void 0,(function*(){var d,h,g;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(s);const p=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Uv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${p}ms`),(null==l?void 0:l.Status)===ce.UserIsNotLoggedIn&&(this._dataReceivedEvent.Unsubscribe(u),(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(),o(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ce.MultiDataResponseStart:case ce.MultiDataResponse:n(l),s=c();break;case ce.MultiDataResponseStop:case ce.FatalError:case ce.Error:n(l),this._dataReceivedEvent.Unsubscribe(u),o();break;default:let t=`Failed to process MultiDataResponse - recived incorrect response status: ${null==l?void 0:l.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(u),s=c(),!this.SendData(e,r)){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;a(new Error(t))}}))))}))}SendAndWaitForResponseWithRepeatAsync(e,t,n){return Ov(this,arguments,void 0,(function*(e,t,n,r=!0,o=!0){var s,i,a;if(e.Method===ue.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 u=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)=>Ov(this,void 0,void 0,(function*(){let a=i=>Ov(this,void 0,void 0,(function*(){var l,d,h,g;if((null==i?void 0:i.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const p=Date.now()-u;o&&this._log.Debug(Uv.ServiceName,`Received response for: ${null==i?void 0:i.Resource} ${null==i?void 0:i.Method} id: ${null==i?void 0:i.TransactionId} in ${p}ms`),e.Method===ue.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ce.UserIsNotLoggedIn&&r&&((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,o))),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(Uv.ServiceName,t),i(new Error(t))}),t),!this.SendData(e,o)){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;i(new Error(t))}}))))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}GetAuthorizationInfo(){return this._auth}GetServiceName(){return Uv.ServiceName}}Uv.ServiceName="ExalusConnectionService";class Mv{constructor(){var e,t;this.OnEnteredPictureInPicture=new De,this.OnExitedPictureInPicture=new De,this._nativeApi=null,this.IsSupported()?(this._nativeApi=navigator.pip,null===(e=this._nativeApi)||void 0===e||e.OnEnteredPictureInPicture.Subscribe((()=>this.OnEnteredPictureInPicture.Invoke())),null===(t=this._nativeApi)||void 0===t||t.OnExitedPictureInPicture.Subscribe((()=>this.OnExitedPictureInPicture.Invoke()))):navigator.pip=null}IsSupported(){return void 0!==navigator.pip&&null!==navigator.pip}RequestPictureInPictureAsync(){return this.IsSupported()?this._nativeApi.RequestPictureInPictureAsync():Promise.resolve(!1)}GetServiceName(){return Mv.ServiceName}}Mv.ServiceName="PictureInPictureService",(Pv=Nv||(Nv={}))[Pv.Unknown=-1]="Unknown",Pv[Pv.Web=0]="Web",Pv[Pv.Android=1]="Android",Pv[Pv.iOS=2]="iOS";class xv{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=Nv.Unknown,this.TokenGuid="",this.Token="",this.RegistrationDate=new Date}}!function(e){e.FeatureUnsupported="FeatureUnsupported",e.UnknownError="UnknownError",e.NoData="NoData",e.IncorrectGuid="IncorrectGuid",e.IdentityIsEmpty="IdentityIsEmpty",e.DeviceTokenIsEmpty="DeviceTokenIsEmpty",e.ClientNameIsEmpty="ClientNameIsEmpty",e.LavvaUserNameIsEmpty="LavvaUserNameIsEmpty",e.TokenNotFound="TokenNotFound",e.TokensNotFoundForLavvaUser="TokensNotFoundForLavvaUser"}(Rv||(Rv={}));var Fv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Lv{constructor(){this._connection=Qv.Get(_t.ServiceName),this._logger=Qv.Get(c.ServiceName)}GetServiceName(){return Lv.ServiceName}RegisterNotificationsClientAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=new Bv({ClientName:e.ClientName,DeviceToken:e.DeviceToken,LavvaUserName:e.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:e.EnableNotifications}),r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,8e3,!1);if(null==r||null==r.Status)return new Ee(Rv.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ce.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:Rv.UnknownError;return new Ee(e,"Cannot register notifications client - wrong data!")}case ce.ResourceDoesNotExists:return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");case ce.OK:return"string"==typeof r.Data?r.Data:new Ee(Rv.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ee(Rv.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new Ee(Rv.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){return Fv(this,void 0,void 0,(function*(){var n;try{const r=new Wv({ClientName:t.ClientName,DeviceToken:t.DeviceToken,LavvaUserName:t.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:t.EnableNotifications,Guid:e}),o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,8e3,!1);if(null==o||null==o.Status)return new Ee(Rv.UnknownError,"Cannot update notifications client - unknown error!");switch(o.Status){case ce.WrongData:{const e=this.isValidErrorCode(o.Data)?o.Data:Rv.UnknownError;return new Ee(e,"Cannot update notifications client - wrong data!")}case ce.ResourceDoesNotExists:return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");case ce.OK:return"string"==typeof o.Data?o.Data==e?ce.OK:new Ee(Rv.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${o.Data}`):new Ee(Rv.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ee(Rv.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new Ee(Rv.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(e){return Fv(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new $v,8e3,!1);return null==t||null==t.Status?new Ee(Rv.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ce.ResourceDoesNotExists?new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ce.OK?new Ee(Rv.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new Ee(Rv.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new xv;return t.ClientName=e.ClientName,t.LavvaUserName=e.LavvaUserName,t.ClientType=e.ClientType,t.TokenGuid=e.TokenGuid,t.Token=e.Token,t.RegistrationDate=new Date(e.RegistrationDate),t}))}catch(e){return this._logger.Error(`Cannot get notifications clients metadata - error: ${e}`),new Ee(Rv.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotificationsEnabledForAllUserTokensAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new zv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:case ce.WrongData:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot get notifications status!")}case ce.OK:return"boolean"==typeof n.Data?n.Data:new Ee(Rv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ee(Rv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ee(Rv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}IsNotificationsEnabledAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new qv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot get notifications status - resource not exists!")}case ce.OK:return"boolean"==typeof n.Data?n.Data:new Ee(Rv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ee(Rv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ee(Rv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Vv(n),8e3,!1);if(null==r||null==r.Status)return new Ee(Rv.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ce.ResourceDoesNotExists:if(null==r.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Rv.UnknownError;return new Ee(e,"Cannot enable notifications - resource not exists!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new Ee(Rv.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}EnableNotificationsForAllUserTokensAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Kv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot enable notifications - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:case ce.WrongData:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot enable notifications!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot enable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot enable notifications for lavva user ${e} - error: ${t}`),new Ee(Rv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DisableNotificationsAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Hv(n),8e3,!1);if(null==r||null==r.Status)return new Ee(Rv.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ce.ResourceDoesNotExists:if(null==r.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Rv.UnknownError;return new Ee(e,"Cannot disable notifications - resource not exists!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new Ee(Rv.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}DisableNotificationsForAllUserTokensAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new jv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot disable notifications - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:case ce.WrongData:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot disable notifications!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot disable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot disable notifications for lavva user ${e} - error: ${t}`),new Ee(Rv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DeleteNotificationsTokenAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Jv(e),8e3,!1);return null==n||null==n.Status?new Ee(Rv.UnknownError,"Cannot delete notifications token - unknown error!"):n.Status==ce.OK?ce.OK:new Ee(Rv.UnknownError,`Cannot delete notifications token - response code ${n.Status}!`)}catch(e){return this._logger.Error(`Cannot delete notifications token - error: ${e}`),new Ee(Rv.UnknownError,`Cannot delete notifications token - error: ${e}`)}}))}getClientType(){return this.isIos()?Nv.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?Nv.Android:Nv.Web}isValidErrorCode(e){return Object.values(Rv).includes(e)}isIos(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusFindController);return t&&n}}Lv.ServiceName="NotificationsService";class Bv extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Post,this.Data=e}}class Wv extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Put,this.Data=e}}class $v extends ae{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=ue.Get}}class qv extends ae{constructor(e){super(),this.Resource="/notifications/status",this.Method=ue.Get,this.Data={TokenIdentity:e}}}class Vv extends ae{constructor(e){super(),this.Resource="/notifications/enable",this.Method=ue.Post,this.Data=e}}class Hv extends ae{constructor(e){super(),this.Resource="/notifications/disable",this.Method=ue.Post,this.Data=e}}class Kv extends ae{constructor(e){super(),this.Resource="/notifications/enable/for/lavva/user",this.Method=ue.Post,this.Data=e}}class jv extends ae{constructor(e){super(),this.Resource="/notifications/disable/for/lavva/user",this.Method=ue.Post,this.Data=e}}class zv extends ae{constructor(e){super(),this.Resource="/notifications/status/for/lavva/user",this.Method=ue.Get,this.Data=e}}class Jv extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Delete,this.Data=e}}class Xv{CheckLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.CheckLocationPermissionAsync():Promise.resolve(!1)}RequestLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.RequestLocationPermissionAsync():Promise.resolve(!1)}IsAndroidLocationAvailable(){return void 0!==navigator.AndroidLocation}GetServiceName(){return Xv.ServiceName}}Xv.ServiceName="AndroidLocationService";class Yv{IsAndroidNotificationsAvailable(){return void 0!==navigator.AndroidNotifications}CheckNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.CheckNotificationPermissionAsync():Promise.resolve(!1)}RequestNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.RequestNotificationPermissionAsync():Promise.resolve(!1)}GetDeviceFirebaseTokenAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetDeviceFirebaseTokenAsync():Promise.resolve(null)}GetServiceName(){return Yv.ServiceName}}Yv.ServiceName="AndroidNotificationsService",fu(Map),fu(Set),(()=>{const e=String.prototype,t=Object.getOwnPropertyNames(_i.prototype);for(const n of t)e[n]=e[n]??_i.prototype[n];e.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 mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[0]},e.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]},e.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},e.elementAt=function(e){if(e<0||e>=this.length)throw new vi("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]||null},e.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 mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[this.length-1]},e.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]},e.reverse=function(){const e=this;return new _i((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),mp(Array),mp(Int8Array),mp(Int16Array),mp(Int32Array),mp(Uint8Array),mp(Uint8ClampedArray),mp(Uint16Array),mp(Uint32Array),mp(Float32Array),mp(Float64Array);class Qv{static Init(){if(u.IsInitialized)return;let e=u.Instance;try{e.RegisterService(new Ev),e.RegisterService(new l),e.RegisterService(new Js),e.RegisterService(new Le),e.RegisterService(new Je),e.RegisterService(new Mv),Qv.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Uv)):e.RegisterService(new _t),e.RegisterService(new Xv),e.RegisterService(new Yv),e.RegisterService(new _o),e.RegisterService(new _o),e.RegisterService(new Ro),e.RegisterService(new it),e.RegisterService(new Iv),e.RegisterService(new mo),e.RegisterService(new tt),e.RegisterService(new Ge),e.RegisterService(new We),e.RegisterService(new Ys),e.RegisterService(new Op),e.RegisterService(new os),e.RegisterService(new pf),e.RegisterService(new Av),e.RegisterService(new Vf),e.RegisterService(new Ms),e.RegisterService(new mv),e.RegisterService(new Lv)}catch(e){console.error(e)}}static IsAppServedFromControllerAsync(){const e=`http://${window.location.hostname}/controller_info`;return fetch(e,{method:"GET"}).then((e=>!!e.ok)).catch((e=>!1))}static IsRunningFromLocalNetwork(e=window.location.hostname){return e.startsWith("192.168.")||e.startsWith("10.")}static GetAsync(e,t){return u.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return u.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return u.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}static ExportStringAsFileToDownload(e,t){const n=new Blob([t],{type:"text/plain"}),r=document.createElement("a"),o=window.URL.createObjectURL(n);return r.href=o,r.download=e,r}}Qv.WorksInContextOf="",Qv.Version=1})();
|
|
1
|
+
(()=>{"use strict";var e,t,n,r,o,s,i={d:(e,t)=>{for(var n in t)i.o(t,n)&&!i.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}};i.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),i.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),i.d({},{j:()=>Qv});class a{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=u.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.None=4]="None"}(e||(e={}));class c{constructor(){this._blockedServices=[],this._logLevel=e.Debug,void 0!==window.loglevel&&null!==window.loglevel&&(this._logLevel=window.loglevel),window.logger=this}EnableStackTrace(){c.DoesThrowStackTrace=!0}DisableStackTrace(){c.DoesThrowStackTrace=!1}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(c.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(c.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return c.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;case e.None: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(t,n){switch(this._logLevel){case e.Warning:case e.Info:case e.Debug:case e.Error:break;case e.None:default:return}null!=t&&(null==n?console.error(`${this.GetTimeStamp()}[ERROR] ${t}`):console.error(`${this.GetTimeStamp()}[ERROR] [${t}] ${n}`))}Info(t,n){switch(this._logLevel){case e.Info:case e.Debug:break;case e.None: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){switch(this._logLevel){case e.Debug:break;case e.None:default:return}void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.debug(`${this.GetTimeStamp()}[DEBUG] ${t}`):c.DoesThrowStackTrace||!0===window.stacktrace?console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n} \nstack:\n${(new Error).stack}}`):console.debug(`${this.GetTimeStamp()}[DEBUG] [${t}] ${n}`))}Log(t,n){this._logLevel!==e.None&&(void 0===t||this.IsBlocked(t)||null!=t&&(null==n?console.log(`${this.GetTimeStamp()}[LOG] ${t}`):console.log(`${this.GetTimeStamp()}[LOG] [${t}] ${n}`)))}}c.ServiceName="LoggerService",c.DoesThrowStackTrace=!1;class u{constructor(){this._services={},this._serviceRegistrationEvent=new a}set DebugCalls(e){u._debugCalls=e,localStorage.setItem("_exalus_DependencyContainer_debugCalls",e.toString())}static get Instance(){if(null!=u._instance)return u._instance;const e=localStorage.getItem("_exalus_DependencyContainer_debugCalls");return u._debugCalls=e===(!0).toString(),u._instance=new u,this.Log=new c,this.Log.Warning("Initializing DependencyContainer"),u._instance.RegisterService(this.Log),this.IsInitialized=!0,window.services=this,u._instance}RegisterService(e){var t;if(null===(t=u.Log)||void 0===t||t.Debug("DependencyContainer",`Registering new service: ${e.GetServiceName()}`),u._debugCalls)try{throw new Error(`Registering new service: ${e.GetServiceName()}`)}catch(e){console.error(e)}this._services[e.GetServiceName()]=e,this._serviceRegistrationEvent.Invoke(e)}GetService(e){var t;if(null===(t=u.Log)||void 0===t||t.Debug("DependencyContainer",`Getting service [${e}] by GetService<T>()`),u._debugCalls)try{throw new Error(`Getting service: ${e}`)}catch(e){console.error(e)}return this._services[e]}GetServiceAsync(e,t){var n,r;if(null===(n=u.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service availability [${e}] by GetServiceAsync<T>()`),u._debugCalls)try{throw new Error(`Waiting for service availability: ${e}`)}catch(e){console.error(e)}return this._services.hasOwnProperty(e)?(null===(r=u.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,r)=>{var o=t=>{var r;(null==t?void 0:t.GetServiceName())===e&&(null===(r=u.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),n(t))},s=()=>{var n;null===(n=u.Log)||void 0===n||n.Debug("DependencyContainer",`Cancelled service [${e}] retrieval by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),null==t||t.CancellationEvent.Unsubscribe(s),r(new Error("Operation cancelled!"))};null==t||t.CancellationEvent.Subscribe(s),this._serviceRegistrationEvent.Subscribe(o)}))}GetServiceWithTimeoutAsync(e,t){var n,r;if(null===(n=u.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service[${e}] availability by GetServiceWithTimeoutAsync<T>()`),u._debugCalls)try{throw new Error(`Waiting for service availability: ${e}`)}catch(e){console.error(e)}return this._services.hasOwnProperty(e)?(null===(r=u.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),Promise.resolve(this._services[e])):new Promise(((n,r)=>{let o=0,s=e=>{var t;(null==e?void 0:e.GetClassName())===e&&(null===(t=u.Log)||void 0===t||t.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(s),n(e))};o=window.setTimeout((()=>{var t;window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(s),null===(t=u.Log)||void 0===t||t.Error("DependencyContainer",`Failed to get service [${e}] in time by GetServiceWithTimeoutAsync<T>()`),r(new Error("Operation cancelled!"))}),t),this._serviceRegistrationEvent.Subscribe(s)}))}}u.IsInitialized=!1,u._debugCalls=!1;class l{GetServiceName(){return l.ServiceName}GetResourceName(e,t){return`_exalus_${Qv.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),r=localStorage.getItem(n);return null==r?null:JSON.parse(r)}catch(r){return null===(n=u.Log)||void 0===n||n.Error(l.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}l.ServiceName="LocalStorageService",function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(t||(t={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(n||(n={})),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"}(r||(r={}));class d{static write(e){return`${e}${d.RecordSeparator}`}static parse(e){if(e[e.length-1]!==d.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(d.RecordSeparator);return t.pop(),t}}d.RecordSeparatorCode=30,d.RecordSeparator=String.fromCharCode(d.RecordSeparatorCode);class h{constructor(){}log(e,t){}}h.instance=new h;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 p{static get isBrowser(){return!p.isNode&&"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return!p.isNode&&"object"==typeof self&&"importScripts"in self}static get isReactNative(){return!p.isNode&&"object"==typeof window&&void 0===window.document}static get isNode(){return"undefined"!=typeof process&&process.release&&"node"===process.release.name}}function f(e,t){let n="";return v(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 v(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function y(e,t,n,o,s,i){const a={},[c,u]=S();a[c]=u,e.log(r.Trace,`(${t} transport) sending data. ${f(s,i.logMessageContent)}.`);const l=v(s)?"arraybuffer":"text",d=await n.post(o,{content:s,headers:{...a,...i.headers},responseType:l,timeout:i.timeout,withCredentials:i.withCredentials});e.log(r.Trace,`(${t} transport) request complete. Response status: ${d.statusCode}.`)}class m{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 w{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${r[e]}: ${t}`;switch(e){case r.Critical:case r.Error:this.out.error(n);break;case r.Warning:this.out.warn(n);break;case r.Information:this.out.info(n);break;default:this.out.log(n)}}}}function S(){let e="X-SignalR-User-Agent";return p.isNode&&(e="User-Agent"),[e,A("8.0.7",_(),p.isNode?"NodeJS":"Browser",C())]}function A(e,t,n,r){let o="Microsoft SignalR/";const s=e.split(".");return o+=`${s[0]}.${s[1]}`,o+=` (${e}; `,o+=t&&""!==t?`${t}; `:"Unknown OS; ",o+=`${n}`,o+=r?`; ${r}`:"; Unknown Runtime Version",o+=")",o}function _(){if(!p.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function C(){if(p.isNode)return process.versions.node}function T(e){return e.stack?e.stack:e.message?e.message:`${e}`}class D{writeHandshakeRequest(e){return d.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(v(e)){const r=new Uint8Array(e),o=r.indexOf(d.RecordSeparatorCode);if(-1===o)throw new Error("Message is incomplete.");const s=o+1;t=String.fromCharCode.apply(null,Array.prototype.slice.call(r.slice(0,s))),n=r.byteLength>s?r.slice(s).buffer:null}else{const r=e,o=r.indexOf(d.RecordSeparator);if(-1===o)throw new Error("Message is incomplete.");const s=o+1;t=r.substring(0,s),n=r.length>s?r.substring(s):null}const r=d.parse(t),o=JSON.parse(r[0]);if(o.type)throw new Error("Expected a handshake response from the server.");return[n,o]}}class k extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class E extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class b extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class I extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class G extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class N extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class R extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class P extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}!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",e[e.Ack=8]="Ack",e[e.Sequence=9]="Sequence"}(o||(o={}));class O{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 m(this,e)}}class U{constructor(e,t,n){this._bufferSize=1e5,this._messages=[],this._totalMessageCount=0,this._waitForSequenceMessage=!1,this._nextReceivingSequenceId=1,this._latestReceivedSequenceId=0,this._bufferedByteCount=0,this._reconnectInProgress=!1,this._protocol=e,this._connection=t,this._bufferSize=n}async _send(e){const t=this._protocol.writeMessage(e);let n=Promise.resolve();if(this._isInvocationMessage(e)){this._totalMessageCount++;let e=()=>{},r=()=>{};v(t)?this._bufferedByteCount+=t.byteLength:this._bufferedByteCount+=t.length,this._bufferedByteCount>=this._bufferSize&&(n=new Promise(((t,n)=>{e=t,r=n}))),this._messages.push(new M(t,this._totalMessageCount,e,r))}try{this._reconnectInProgress||await this._connection.send(t)}catch{this._disconnected()}await n}_ack(e){let t=-1;for(let n=0;n<this._messages.length;n++){const r=this._messages[n];if(r._id<=e.sequenceId)t=n,v(r._message)?this._bufferedByteCount-=r._message.byteLength:this._bufferedByteCount-=r._message.length,r._resolver();else{if(!(this._bufferedByteCount<this._bufferSize))break;r._resolver()}}-1!==t&&(this._messages=this._messages.slice(t+1))}_shouldProcessMessage(e){if(this._waitForSequenceMessage)return e.type===o.Sequence&&(this._waitForSequenceMessage=!1,!0);if(!this._isInvocationMessage(e))return!0;const t=this._nextReceivingSequenceId;return this._nextReceivingSequenceId++,t<=this._latestReceivedSequenceId?(t===this._latestReceivedSequenceId&&this._ackTimer(),!1):(this._latestReceivedSequenceId=t,this._ackTimer(),!0)}_resetSequence(e){e.sequenceId>this._nextReceivingSequenceId?this._connection.stop(new Error("Sequence ID greater than amount of messages we've received.")):this._nextReceivingSequenceId=e.sequenceId}_disconnected(){this._reconnectInProgress=!0,this._waitForSequenceMessage=!0}async _resend(){const e=0!==this._messages.length?this._messages[0]._id:this._totalMessageCount+1;await this._connection.send(this._protocol.writeMessage({type:o.Sequence,sequenceId:e}));const t=this._messages;for(const e of t)await this._connection.send(e._message);this._reconnectInProgress=!1}_dispose(e){null!=e||(e=new Error("Unable to reconnect to server."));for(const t of this._messages)t._rejector(e)}_isInvocationMessage(e){switch(e.type){case o.Invocation:case o.StreamItem:case o.Completion:case o.StreamInvocation:case o.CancelInvocation:return!0;case o.Close:case o.Sequence:case o.Ping:case o.Ack:return!1}}_ackTimer(){void 0===this._ackTimerHandle&&(this._ackTimerHandle=setTimeout((async()=>{try{this._reconnectInProgress||await this._connection.send(this._protocol.writeMessage({type:o.Ack,sequenceId:this._latestReceivedSequenceId}))}catch{}clearTimeout(this._ackTimerHandle),this._ackTimerHandle=void 0}),1e3))}}class M{constructor(e,t,n,r){this._message=e,this._id=t,this._resolver=n,this._rejector=r}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(s||(s={}));class x{static create(e,t,n,r,o,s,i){return new x(e,t,n,r,o,s,i)}constructor(e,t,n,i,a,c,u){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(r.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://learn.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},g.isRequired(e,"connection"),g.isRequired(t,"logger"),g.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=null!=a?a:3e4,this.keepAliveIntervalInMilliseconds=null!=c?c:15e3,this._statefulReconnectBufferSize=null!=u?u:1e5,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=i,this._handshakeProtocol=new D,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=s.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:o.Ping})}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!==s.Disconnected&&this._connectionState!==s.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!==s.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=s.Connecting,this._logger.log(r.Debug,"Starting HubConnection.");try{await this._startInternal(),p.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=s.Connected,this._connectionStarted=!0,this._logger.log(r.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=s.Disconnected,this._logger.log(r.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{let t=this._protocol.version;this.connection.features.reconnect||(t=1);const n={protocol:this._protocol.name,version:t};if(this._logger.log(r.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(n)),this._logger.log(r.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;!!this.connection.features.reconnect&&(this._messageBuffer=new U(this._protocol,this.connection,this._statefulReconnectBufferSize),this.connection.features.disconnected=this._messageBuffer._disconnected.bind(this._messageBuffer),this.connection.features.resend=()=>{if(this._messageBuffer)return this._messageBuffer._resend()}),this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(r.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.connection.features.reconnect=!1,this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){if(this._connectionState===s.Disconnected)return this._logger.log(r.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve();if(this._connectionState===s.Disconnecting)return this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise;const t=this._connectionState;return this._connectionState=s.Disconnecting,this._logger.log(r.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(r.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(t===s.Connected&&this._sendCloseMessage(),this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new b("The connection was stopped before the hub handshake could complete."),this.connection.stop(e))}async _sendCloseMessage(){try{await this._sendWithProtocol(this._createCloseMessage())}catch{}}stream(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._createStreamInvocation(e,t,r);let i;const a=new O;return a.cancelCallback=()=>{const e=this._createCancelInvocation(s.invocationId);return delete this._callbacks[s.invocationId],i.then((()=>this._sendWithProtocol(e)))},this._callbacks[s.invocationId]=(e,t)=>{t?a.error(t):e&&(e.type===o.Completion?e.error?a.error(new Error(e.error)):a.complete():a.next(e.item))},i=this._sendWithProtocol(s).catch((e=>{a.error(e),delete this._callbacks[s.invocationId]})),this._launchStreams(n,i),a}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._messageBuffer?this._messageBuffer._send(e):this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,r]=this._replaceStreamingParams(t),o=this._sendWithProtocol(this._createInvocation(e,t,!0,r));return this._launchStreams(n,o),o}invoke(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._createInvocation(e,t,!1,r);return new Promise(((e,t)=>{this._callbacks[s.invocationId]=(n,r)=>{r?t(r):n&&(n.type===o.Completion?n.error?t(new Error(n.error)):e(n.result):t(new Error(`Unexpected message type: ${n.type}`)))};const r=this._sendWithProtocol(s).catch((e=>{t(e),delete this._callbacks[s.invocationId]}));this._launchStreams(n,r)}))}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 r=n.indexOf(t);-1!==r&&(n.splice(r,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)if(!this._messageBuffer||this._messageBuffer._shouldProcessMessage(e))switch(e.type){case o.Invocation:this._invokeClientMethod(e).catch((e=>{this._logger.log(r.Error,`Invoke client method threw error: ${T(e)}`)}));break;case o.StreamItem:case o.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===o.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(r.Error,`Stream callback threw error: ${T(e)}`)}}break}case o.Ping:break;case o.Close:{this._logger.log(r.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}case o.Ack:this._messageBuffer&&this._messageBuffer._ack(e);break;case o.Sequence:this._messageBuffer&&this._messageBuffer._resetSequence(e);break;default:this._logger.log(r.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(r.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(r.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(r.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===s.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(r.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(r.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(),s=!!e.invocationId;let i,a,c;for(const n of o)try{const o=i;i=await n.apply(this,e.arguments),s&&i&&o&&(this._logger.log(r.Error,`Multiple results provided for '${t}'. Sending error to server.`),c=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),a=void 0}catch(e){a=e,this._logger.log(r.Error,`A callback for the method '${t}' threw error '${e}'.`)}c?await this._sendWithProtocol(c):s?(a?c=this._createCompletionMessage(e.invocationId,`${a}`,null):void 0!==i?c=this._createCompletionMessage(e.invocationId,null,i):(this._logger.log(r.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),c=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(c)):i&&this._logger.log(r.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(r.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new b("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===s.Disconnecting?this._completeClose(e):this._connectionState===s.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===s.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=s.Disconnected,this._connectionStarted=!1,this._messageBuffer&&(this._messageBuffer._dispose(null!=e?e:new Error("Connection closed.")),this._messageBuffer=void 0),p.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.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."),i=this._getNextRetryDelay(n++,0,o);if(null===i)return this._logger.log(r.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=s.Reconnecting,e?this._logger.log(r.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(r.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==s.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==i;){if(this._logger.log(r.Information,`Reconnect attempt number ${n} will start in ${i} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,i)})),this._reconnectDelayHandle=void 0,this._connectionState!==s.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=s.Connected,this._logger.log(r.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(r.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(r.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==s.Reconnecting)return this._logger.log(r.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===s.Disconnecting&&this._completeClose());o=e instanceof Error?e:new Error(e.toString()),i=this._getNextRetryDelay(n++,Date.now()-t,o)}}this._logger.log(r.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(r.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(r.Error,`Stream 'error' callback called with '${e}' threw error: ${T(t)}`)}}))}_cleanupPingTimer(){this._pingServerHandle&&(clearTimeout(this._pingServerHandle),this._pingServerHandle=void 0)}_cleanupTimeout(){this._timeoutHandle&&clearTimeout(this._timeoutHandle)}_createInvocation(e,t,n,r){if(n)return 0!==r.length?{arguments:t,streamIds:r,target:e,type:o.Invocation}:{arguments:t,target:e,type:o.Invocation};{const n=this._invocationId;return this._invocationId++,0!==r.length?{arguments:t,invocationId:n.toString(),streamIds:r,target:e,type:o.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:o.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 r;r=e instanceof Error?e.message:e&&e.toString?e.toString():"Unknown error",t=t.then((()=>this._sendWithProtocol(this._createCompletionMessage(n,r))))},next:e=>{t=t.then((()=>this._sendWithProtocol(this._createStreamItemMessage(n,e))))}})}}_replaceStreamingParams(e){const t=[],n=[];for(let r=0;r<e.length;r++){const o=e[r];if(this._isObservable(o)){const s=this._invocationId;this._invocationId++,t[s]=o,n.push(s.toString()),e.splice(r,1)}}return[t,n]}_isObservable(e){return e&&e.subscribe&&"function"==typeof e.subscribe}_createStreamInvocation(e,t,n){const r=this._invocationId;return this._invocationId++,0!==n.length?{arguments:t,invocationId:r.toString(),streamIds:n,target:e,type:o.StreamInvocation}:{arguments:t,invocationId:r.toString(),target:e,type:o.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:o.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:o.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:o.Completion}:{invocationId:e,result:n,type:o.Completion}}_createCloseMessage(){return{type:o.Close}}}const F=[0,2e3,1e4,3e4,null];class L{constructor(e){this._retryDelays=void 0!==e?[...e,null]:F}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class B{}B.Authorization="Authorization",B.Cookie="Cookie";class W{constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class ${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 q extends ${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[B.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[B.Authorization]&&delete e.headers[B.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class V extends ${constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch||p.isNode){const e=require;this._jar=new(e("tough-cookie").CookieJar),"undefined"==typeof fetch?this._fetchType=e("node-fetch"):this._fetchType=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!==i.g)return i.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 b;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 b});let o,s=null;if(e.timeout){const o=e.timeout;s=setTimeout((()=>{t.abort(),this._logger.log(r.Warning,"Timeout from HTTP request."),n=new E}),o)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},v(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(r.Warning,`Error from HTTP request. ${e}.`),e}finally{s&&clearTimeout(s),e.abortSignal&&(e.abortSignal.onabort=null)}if(!o.ok){const e=await H(o,"text");throw new k(e||o.statusText,o.status)}const i=H(o,e.responseType),a=await i;return new W(o.status,o.statusText,a)}getCookieString(e){let t="";return p.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function H(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 K extends ${constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new b):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&&(v(e.content)?o.setRequestHeader("Content-Type","application/octet-stream"):o.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const s=e.headers;s&&Object.keys(s).forEach((e=>{o.setRequestHeader(e,s[e])})),e.responseType&&(o.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{o.abort(),n(new b)}),e.timeout&&(o.timeout=e.timeout),o.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),o.status>=200&&o.status<300?t(new W(o.status,o.statusText,o.response||o.responseText)):n(new k(o.response||o.responseText||o.statusText,o.status))},o.onerror=()=>{this._logger.log(r.Warning,`Error from HTTP request. ${o.status}: ${o.statusText}.`),n(new k(o.statusText,o.status))},o.ontimeout=()=>{this._logger.log(r.Warning,"Timeout from HTTP request."),n(new E)},o.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class j extends ${constructor(e){if(super(),"undefined"!=typeof fetch||p.isNode)this._httpClient=new V(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new K(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new b):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)}}class z{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 J{get pollAborted(){return this._pollAbort.aborted}constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new z,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}async connect(e,t){if(g.isRequired(e,"url"),g.isRequired(t,"transferFormat"),g.isIn(t,n,"transferFormat"),this._url=e,this._logger.log(r.Trace,"(LongPolling transport) Connecting."),t===n.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[o,s]=S(),i={[o]:s,...this._options.headers},a={abortSignal:this._pollAbort.signal,headers:i,timeout:1e5,withCredentials:this._options.withCredentials};t===n.Binary&&(a.responseType="arraybuffer");const c=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${c}.`);const u=await this._httpClient.get(c,a);200!==u.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${u.statusCode}.`),this._closeError=new k(u.statusText||"",u.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,a)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${n}.`);const o=await this._httpClient.get(n,t);204===o.statusCode?(this._logger.log(r.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==o.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${o.statusCode}.`),this._closeError=new k(o.statusText||"",o.statusCode),this._running=!1):o.content?(this._logger.log(r.Trace,`(LongPolling transport) data received. ${f(o.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(o.content)):this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof E?this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(r.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(r.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?y(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(r.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(r.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=S();e[t]=n;const o={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};let s;try{await this._httpClient.delete(this._url,o)}catch(e){s=e}s?s instanceof k&&(404===s.statusCode?this._logger.log(r.Trace,"(LongPolling transport) A 404 response was returned from sending a DELETE request."):this._logger.log(r.Trace,`(LongPolling transport) Error sending a DELETE request: ${s}`)):this._logger.log(r.Trace,"(LongPolling transport) DELETE request accepted.")}finally{this._logger.log(r.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(r.Trace,e),this.onclose(this._closeError)}}}class X{constructor(e,t,n,r){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=r,this.onreceive=null,this.onclose=null}async connect(e,t){return g.isRequired(e,"url"),g.isRequired(t,"transferFormat"),g.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((o,s)=>{let i,a=!1;if(t===n.Text){if(p.isBrowser||p.isWebWorker)i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[r,o]=S();n[r]=o,i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{i.onmessage=e=>{if(this.onreceive)try{this._logger.log(r.Trace,`(SSE transport) data received. ${f(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},i.onerror=e=>{a?this._close():s(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."))},i.onopen=()=>{this._logger.log(r.Information,`SSE connected to ${this._url}`),this._eventSource=i,a=!0,o()}}catch(e){return void s(e)}}else s(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?y(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 Y{constructor(e,t,n,r,o,s){this._logger=n,this._accessTokenFactory=t,this._logMessageContent=r,this._webSocketConstructor=o,this._httpClient=e,this.onreceive=null,this.onclose=null,this._headers=s}async connect(e,t){let o;return g.isRequired(e,"url"),g.isRequired(t,"transferFormat"),g.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(o=await this._accessTokenFactory()),new Promise(((s,i)=>{let a;e=e.replace(/^http/,"ws");const c=this._httpClient.getCookieString(e);let u=!1;if(p.isNode||p.isReactNative){const t={},[n,r]=S();t[n]=r,o&&(t[B.Authorization]=`Bearer ${o}`),c&&(t[B.Cookie]=c),a=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else o&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(o)}`);a||(a=new this._webSocketConstructor(e)),t===n.Binary&&(a.binaryType="arraybuffer"),a.onopen=t=>{this._logger.log(r.Information,`WebSocket connected to ${e}.`),this._webSocket=a,u=!0,s()},a.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(r.Information,`(WebSockets transport) ${t}.`)},a.onmessage=e=>{if(this._logger.log(r.Trace,`(WebSockets transport) data received. ${f(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},a.onclose=e=>{if(u)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.",i(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(r.Trace,`(WebSockets transport) sending data. ${f(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(r.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 Q{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 w(r.Information):null===n?h.instance:void 0!==n.log?n:new w(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,s=null;if(p.isNode){const e=require;o=e("ws"),s=e("eventsource")}p.isNode||"undefined"==typeof WebSocket||t.WebSocket?p.isNode&&!t.WebSocket&&o&&(t.WebSocket=o):t.WebSocket=WebSocket,p.isNode||"undefined"==typeof EventSource||t.EventSource?p.isNode&&!t.EventSource&&void 0!==s&&(t.EventSource=s):t.EventSource=EventSource,this._httpClient=new q(t.httpClient||new j(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||n.Binary,g.isIn(e,n,"transferFormat"),this._logger.log(r.Debug,`Starting connection with transfer format '${n[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(r.Error,e),await this._stopPromise,Promise.reject(new b(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(r.Error,e),Promise.reject(new b(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(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(r.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(r.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(r.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let n=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==t.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(t.WebSockets),await this._startTransport(n,e)}else{let t=null,r=0;do{if(t=await this._getNegotiationResponse(n),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new b("The connection was stopped during negotiation.");if(t.error)throw new Error(t.error);if(t.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(t.url&&(n=t.url),t.accessToken){const e=t.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}r++}while(t.url&&r<100);if(100===r&&t.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(n,this._options.transport,t,e)}this.transport instanceof J&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(r.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(r.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]=S();t[n]=o;const s=this._resolveNegotiateUrl(e);this._logger.log(r.Debug,`Sending negotiation request: ${s}.`);try{const e=await this._httpClient.post(s,{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.useStatefulReconnect&&!0!==this._options._useStatefulReconnect?Promise.reject(new R("Client didn't negotiate Stateful Reconnect but the server did.")):n}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof k&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(r.Error,t),Promise.reject(new R(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,n,o,s){let i=this._createConnectUrl(e,o.connectionToken);if(this._isITransport(n))return this._logger.log(r.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=n,await this._startTransport(i,s),void(this.connectionId=o.connectionId);const a=[],c=o.availableTransports||[];let u=o;for(const o of c){const c=this._resolveTransportOrError(o,n,s,!0===(null==u?void 0:u.useStatefulReconnect));if(c instanceof Error)a.push(`${o.transport} failed:`),a.push(c);else if(this._isITransport(c)){if(this.transport=c,!u){try{u=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}i=this._createConnectUrl(e,u.connectionToken)}try{return await this._startTransport(i,s),void(this.connectionId=u.connectionId)}catch(e){if(this._logger.log(r.Error,`Failed to start the transport '${o.transport}': ${e}`),u=void 0,a.push(new N(`${o.transport} failed: ${e}`,t[o.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(r.Debug,e),Promise.reject(new b(e))}}}}return a.length>0?Promise.reject(new P(`Unable to connect to the server with any of the available transports. ${a.join(" ")}`,a)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case t.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new Y(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case t.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new X(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case t.LongPolling:return new J(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.features.reconnect?this.transport.onclose=async n=>{let r=!1;if(this.features.reconnect){try{this.features.disconnected(),await this.transport.connect(e,t),await this.features.resend()}catch{r=!0}r&&this._stopConnection(n)}else this._stopConnection(n)}:this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,o,s,i){const a=t[e.transport];if(null==a)return this._logger.log(r.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||!!(t&e)}(o,a))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it was disabled by the client.`),new G(`'${t[a]}' is disabled by the client.`,a);if(!(e.transferFormats.map((e=>n[e])).indexOf(s)>=0))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it does not support the requested transfer format '${n[s]}'.`),new Error(`'${t[a]}' does not support ${n[s]}.`);if(a===t.WebSockets&&!this._options.WebSocket||a===t.ServerSentEvents&&!this._options.EventSource)return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it is not supported in your environment.'`),new I(`'${t[a]}' is not supported in your environment.`,a);this._logger.log(r.Debug,`Selecting transport '${t[a]}'.`);try{return this.features.reconnect=a===t.WebSockets?i:void 0,this._constructTransport(a)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(r.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(r.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(r.Error,`Connection disconnected with error '${e}'.`):this._logger.log(r.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(r.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(r.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(r.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(!p.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(r.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=new URL(e);t.pathname.endsWith("/")?t.pathname+="negotiate":t.pathname+="/negotiate";const n=new URLSearchParams(t.searchParams);return n.has("negotiateVersion")||n.append("negotiateVersion",this._negotiateVersion.toString()),n.has("useStatefulReconnect")?"true"===n.get("useStatefulReconnect")&&(this._options._useStatefulReconnect=!0):!0===this._options._useStatefulReconnect&&n.append("useStatefulReconnect","true"),t.search=n.toString(),t.toString()}}class Z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new ee,this._transportResult=new ee,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new ee),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 ee;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 r=0;for(const t of e)n.set(new Uint8Array(t),r),r+=t.byteLength;return n.buffer}}class ee{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class te{constructor(){this.name="json",this.version=2,this.transferFormat=n.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=h.instance);const n=d.parse(e),s=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case o.Invocation:this._isInvocationMessage(n);break;case o.StreamItem:this._isStreamItemMessage(n);break;case o.Completion:this._isCompletionMessage(n);break;case o.Ping:case o.Close:break;case o.Ack:this._isAckMessage(n);break;case o.Sequence:this._isSequenceMessage(n);break;default:t.log(r.Information,"Unknown message type '"+n.type+"' ignored.");continue}s.push(n)}return s}writeMessage(e){return d.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.")}_isAckMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Ack message.")}_isSequenceMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Sequence message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const ne={trace:r.Trace,debug:r.Debug,info:r.Information,information:r.Information,warn:r.Warning,warning:r.Warning,error:r.Error,critical:r.Critical,none:r.None};class re{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=ne[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new w(t)}else this.logger=new w(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 L(e):this.reconnectPolicy=e:this.reconnectPolicy=new L,this}withServerTimeout(e){return g.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return g.isRequired(e,"milliseconds"),this._keepAliveIntervalInMilliseconds=e,this}withStatefulReconnect(e){return void 0===this.httpConnectionOptions&&(this.httpConnectionOptions={}),this.httpConnectionOptions._useStatefulReconnect=!0,this._statefulReconnectBufferSize=null==e?void 0:e.bufferSize,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 Q(this.url,e);return x.create(t,this.logger||h.instance,this.protocol||new te,this.reconnectPolicy,this._serverTimeoutInMilliseconds,this._keepAliveIntervalInMilliseconds,this._statefulReconnectBufferSize)}}class oe{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 r=16*Math.random();return e>0?(r=(e+r)%16|0,e=Math.floor(e/16)):(r=(t+r)%16|0,t=Math.floor(t/16)),("x"===n?r:3&r|8).toString(16)}))}static GenerateMd5(e){let t="0123456789abcdef";function n(e){let n,r="";for(n=0;n<=3;n++)r+=t.charAt(e>>8*n+4&15)+t.charAt(e>>8*n&15);return r}function r(e,t){let n=(65535&e)+(65535&t);return(e>>16)+(t>>16)+(n>>16)<<16|65535&n}function o(e,t,n,o,s,i){return r(function(e,t){return e<<t|e>>>32-t}(r(r(t,e),r(o,i)),s),n)}function s(e,t,n,r,s,i,a){return o(t&n|~t&r,e,t,s,i,a)}function i(e,t,n,r,s,i,a){return o(t&r|n&~r,e,t,s,i,a)}function a(e,t,n,r,s,i,a){return o(t^n^r,e,t,s,i,a)}function c(e,t,n,r,s,i,a){return o(n^(t|~r),e,t,s,i,a)}let u,l,d,h,g,p=function(e){let t,n=1+(e.length+8>>6),r=new Array(16*n);for(t=0;t<16*n;t++)r[t]=0;for(t=0;t<e.length;t++)r[t>>2]|=e.charCodeAt(t)<<t%4*8;return r[t>>2]|=128<<t%4*8,r[16*n-2]=8*e.length,r}(""+e),f=1732584193,v=-271733879,y=-1732584194,m=271733878;for(u=0;u<p.length;u+=16)l=f,d=v,h=y,g=m,f=s(f,v,y,m,p[u+0],7,-680876936),m=s(m,f,v,y,p[u+1],12,-389564586),y=s(y,m,f,v,p[u+2],17,606105819),v=s(v,y,m,f,p[u+3],22,-1044525330),f=s(f,v,y,m,p[u+4],7,-176418897),m=s(m,f,v,y,p[u+5],12,1200080426),y=s(y,m,f,v,p[u+6],17,-1473231341),v=s(v,y,m,f,p[u+7],22,-45705983),f=s(f,v,y,m,p[u+8],7,1770035416),m=s(m,f,v,y,p[u+9],12,-1958414417),y=s(y,m,f,v,p[u+10],17,-42063),v=s(v,y,m,f,p[u+11],22,-1990404162),f=s(f,v,y,m,p[u+12],7,1804603682),m=s(m,f,v,y,p[u+13],12,-40341101),y=s(y,m,f,v,p[u+14],17,-1502002290),v=s(v,y,m,f,p[u+15],22,1236535329),f=i(f,v,y,m,p[u+1],5,-165796510),m=i(m,f,v,y,p[u+6],9,-1069501632),y=i(y,m,f,v,p[u+11],14,643717713),v=i(v,y,m,f,p[u+0],20,-373897302),f=i(f,v,y,m,p[u+5],5,-701558691),m=i(m,f,v,y,p[u+10],9,38016083),y=i(y,m,f,v,p[u+15],14,-660478335),v=i(v,y,m,f,p[u+4],20,-405537848),f=i(f,v,y,m,p[u+9],5,568446438),m=i(m,f,v,y,p[u+14],9,-1019803690),y=i(y,m,f,v,p[u+3],14,-187363961),v=i(v,y,m,f,p[u+8],20,1163531501),f=i(f,v,y,m,p[u+13],5,-1444681467),m=i(m,f,v,y,p[u+2],9,-51403784),y=i(y,m,f,v,p[u+7],14,1735328473),v=i(v,y,m,f,p[u+12],20,-1926607734),f=a(f,v,y,m,p[u+5],4,-378558),m=a(m,f,v,y,p[u+8],11,-2022574463),y=a(y,m,f,v,p[u+11],16,1839030562),v=a(v,y,m,f,p[u+14],23,-35309556),f=a(f,v,y,m,p[u+1],4,-1530992060),m=a(m,f,v,y,p[u+4],11,1272893353),y=a(y,m,f,v,p[u+7],16,-155497632),v=a(v,y,m,f,p[u+10],23,-1094730640),f=a(f,v,y,m,p[u+13],4,681279174),m=a(m,f,v,y,p[u+0],11,-358537222),y=a(y,m,f,v,p[u+3],16,-722521979),v=a(v,y,m,f,p[u+6],23,76029189),f=a(f,v,y,m,p[u+9],4,-640364487),m=a(m,f,v,y,p[u+12],11,-421815835),y=a(y,m,f,v,p[u+15],16,530742520),v=a(v,y,m,f,p[u+2],23,-995338651),f=c(f,v,y,m,p[u+0],6,-198630844),m=c(m,f,v,y,p[u+7],10,1126891415),y=c(y,m,f,v,p[u+14],15,-1416354905),v=c(v,y,m,f,p[u+5],21,-57434055),f=c(f,v,y,m,p[u+12],6,1700485571),m=c(m,f,v,y,p[u+3],10,-1894986606),y=c(y,m,f,v,p[u+10],15,-1051523),v=c(v,y,m,f,p[u+1],21,-2054922799),f=c(f,v,y,m,p[u+8],6,1873313359),m=c(m,f,v,y,p[u+15],10,-30611744),y=c(y,m,f,v,p[u+6],15,-1560198380),v=c(v,y,m,f,p[u+13],21,1309151649),f=c(f,v,y,m,p[u+4],6,-145523070),m=c(m,f,v,y,p[u+11],10,-1120210379),y=c(y,m,f,v,p[u+2],15,718787259),v=c(v,y,m,f,p[u+9],21,-343485551),f=r(f,l),v=r(v,d),y=r(y,h),m=r(m,g);return n(f)+n(v)+n(y)+n(m)}}class se{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function ie(e){return new Map(Object.entries(e))}class ae{constructor(){this.TransactionId=oe.GenerateUUID()}}var ce,ue,le,de,he,ge,pe,fe,ve,ye,me,we,Se,Ae,_e;(Se=ce||(ce={}))[Se.OK=0]="OK",Se[Se.UnknownError=1]="UnknownError",Se[Se.FatalError=2]="FatalError",Se[Se.WrongData=3]="WrongData",Se[Se.ResourceDoesNotExists=4]="ResourceDoesNotExists",Se[Se.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",Se[Se.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",Se[Se.OperationNotPermitted=7]="OperationNotPermitted",Se[Se.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",Se[Se.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",Se[Se.Error=10]="Error",Se[Se.NoData=11]="NoData",Se[Se.NotSupportedMethod=12]="NotSupportedMethod",Se[Se.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",Se[Se.MultiDataResponseStart=14]="MultiDataResponseStart",Se[Se.MultiDataResponse=15]="MultiDataResponse",Se[Se.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"}(ue||(ue={}));class Ce{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"}(le||(le={})),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"}(de||(de={})),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",e[e.ConnectedAndAuthorized=7]="ConnectedAndAuthorized"}(he||(he={}));class Te extends Error{constructor(e){super(e),this.name="StreamError"}}class De{constructor(){this._log=Qv.Get(c.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)}}))}}!function(e){e.CannotExportConfiguration="CannotExportConfiguration"}(ge||(ge={})),(_e=pe||(pe={}))[_e.Any=0]="Any",_e[_e.Guest=10]="Guest",_e[_e.Standard=20]="Standard",_e[_e.Admin=30]="Admin",_e[_e.Installator=40]="Installator",_e[_e.Support=50]="Support",(Ae=fe||(fe={}))[Ae.Unknown=0]="Unknown",Ae[Ae.Men=1]="Men",Ae[Ae.Woman=2]="Woman",Ae[Ae.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(ve||(ve={})),function(e){e[e.Unknown=0]="Unknown",e[e.WrongAuthData=1]="WrongAuthData",e[e.NoResponseFromController=2]="NoResponseFromController",e[e.AuthDisabled=3]="AuthDisabled",e[e.MethodNotSupported=4]="MethodNotSupported"}(ye||(ye={}));class ke{constructor(e,t){this._type=me.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 Ee{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.ResourceDoesNotExists=-6]="ResourceDoesNotExists",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"}(me||(me={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(we||(we={}));class be{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=we.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 Ie=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ge{constructor(){this._imageExistsCaseNumber=0,this._connection=Qv.Get(_t.ServiceName),this._logger=Qv.Get(c.ServiceName)}GetServiceName(){return Ge.ServiceName}AddPictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t,n;try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ge.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ce.WrongData;let r=new Image;const o=new Promise(((t,n)=>{r.src=e.Base64Image,r.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield o))return this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ce.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ce.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot add picture - Guid must be empty."),ce.WrongData;const s=new Re;s.Guid=oe.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 Oe(s.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(Ge.ServiceName,"Cannot add picture - unknown error!"),ce.UnknownError;if(i.Status==ce.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new xe(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(Ge.ServiceName,"Cannot add picture - unknown error!"),ce.UnknownError):e.Status}return i.Status==ce.OK?(this._logger.Warning(Ge.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ce.UnknownError):(this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot get current picture status."),ce.Error)}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot add picture! ${e}`),ce.FatalError}}))}EditPictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t,n,r,o;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - guid is empty."),ce.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ce.WrongData;let s=new Image;const i=new Promise(((t,n)=>{s.src=e.Base64Image,s.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield i))return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ce.WrongData;if(0===s.height||0===s.width)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ce.WrongData;const a=new Re;a.DateTime=(new Date).toISOString(),a.ImageType=e.ImageType,a.Base64Image=e.Base64Image,a.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?a.OwnerGuid=e.OwnerGuid:a.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const c=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Oe(a.Guid),8e3,!1);if(null===(n=u.Log)||void 0===n||n.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==c||null==c.Status)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - unknown error!"),ce.UnknownError;if(c.Status==ce.ResourceDoesNotExists)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - picture not exists."),ce.OperationNotPermitted;if(c.Status==ce.OK){const e=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new xe(a),8e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(Ge.ServiceName,"Cannot edit picture - unknown error!"),ce.UnknownError):e.Status}return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot get current picture status."),ce.Error}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot edit picture! ${e}`),ce.FatalError}}))}DeletePictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t,n;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot delete picture - guid is empty."),ce.WrongData;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Fe(e.Guid),8e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DeletePictureAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==r||null==r.Status?(this._logger.Error(Ge.ServiceName,"Cannot delete picture - unknown error!"),ce.UnknownError):r.Status}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot delete picture! ${e}`),ce.FatalError}}))}GetPicturesInfoAsync(){return Ie(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ue,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ge.ServiceName,"Cannot get pictures info - unknown error!"),new Ee(ce.UnknownError,"NoDataInResult")):t.Status!=ce.OK?(this._logger.Error(Ge.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Ee(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ge.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Ee(ce.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Pe;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(Ge.ServiceName,`Cannot get picture info! ${e}`),new Ee(ce.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){return Ie(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Oe(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(Ge.ServiceName,"Cannot get picture - unknown error!"),new Ee(ce.UnknownError,"NoDataInResult");switch(n.Status){case ce.ResourceDoesNotExists:return new Ee(ce.ResourceDoesNotExists,"PictureNotFound");case ce.OK:if(null==n.Data)return new Ee(ce.Error,"RespondedWithOKButNoData");const e=new Ne;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 Ee(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot get picture! ${e}`),new Ee(ce.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){return Ie(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Me,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ge.ServiceName,"Cannot get pictures - unknown error!"),new Ee(ce.UnknownError,"NoDataInResult")):t.Status!=ce.OK?(this._logger.Error(Ge.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Ee(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ge.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Ee(ce.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ne;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(Ge.ServiceName,`Cannot get pictures! ${e}`),new Ee(ce.FatalError,"ExceptionOccurred")}}))}}Ge.ServiceName="PictureService";class Ne extends be{set DateTime(e){this._dateTime=e}}class Re{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=we.Device,this.DateTime=""}}class Pe{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 Oe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Get,this.Data=e}}class Ue extends ae{constructor(){super(),this.Resource="/pictures/info",this.Method=ue.Get}}class Me extends ae{constructor(){super(),this.Resource="/pictures/list",this.Method=ue.Get}}class xe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Put,this.Data=e}}class Fe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Delete,this.Data=e}}class Le{constructor(){this._log=Qv.Get(c.ServiceName),Le._localStorageService=Qv.Get(l.ServiceName)}GetServiceName(){return Le.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ce.OK&&(this._log.Debug(Le.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Le._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Le._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Le.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Le._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Le.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Le._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Le.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Le._localStorageService=null,Le.ServiceName="WebApiCacheService";var Be=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class We{constructor(){this._connection=null,this._connection=Qv.Get(_t.ServiceName),this._pictureService=Qv.Get(Ge.ServiceName),this._sessionService=Qv.Get(Je.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 pe.Support:return n===pe.Support;case pe.Installator:return n>=pe.Installator;case pe.Admin:default:return n>=pe.Admin}}GetServiceName(){return We.ServiceName}GetUsersAsync(){return Be(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new He,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ce.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new je;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)==ce.NoData)return Promise.resolve([]);throw null===(t=u.Log)||void 0===t||t.Debug(We.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){return Be(this,void 0,void 0,(function*(){var t,n;if(""===e)return Promise.resolve(null);null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new $e(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ce.OK)return null===(n=u.Log)||void 0===n||n.Debug(We.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const o=new je;return o.AccessLevel=r.Data.AccessLevel,o.Email=r.Data.Email,o.Gender=r.Data.Gender,o.Guid=r.Data.Guid,o.IsAccountOnline=r.Data.IsAccountOnline,o.Name=r.Data.Name,o.IsActive=r.Data.IsActive,o.IsBanned=r.Data.IsBanned,o.Phone=r.Data.Phone,o.Surname=r.Data.Surname,o}))}CreateUserAsync(e,t){return Be(this,void 0,void 0,(function*(){var n;if(null!=e.Guid&&""!=e.Guid)return new Ee(ce.WrongData,"GuidMustBeEmpty");const r=new qe;r.Name=e.Name.trim(),r.Surname=e.Surname.trim(),r.Email=e.Email.trim(),r.Password=t.trim(),r.Phone=e.Phone.trim(),r.Gender=e.Gender,r.AccessLevel=e.AccessLevel;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ve(r),2e4,!1);return Qv.Get(Le.ServiceName).ClearCache(),null==o||null==o.Status?new Ee(ce.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Ee(o.Status,o.Data))}))}UpdateUserAsync(e){return Be(this,void 0,void 0,(function*(){var t;if(null==e.Guid||""==e.Guid)return new Ee(ce.WrongData,"GuidCannotBeEmpty");const n=new qe;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 r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ve(n),2e4,!1);return Qv.Get(Le.ServiceName).ClearCache(),null==r||null==r.Status?new Ee(ce.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Ee(r.Status,r.Data))}))}ChangePasswordAsync(e,t){return Be(this,void 0,void 0,(function*(){var n;if(null==e.Guid||""==e.Guid)return new Ee(ce.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Ee(ce.ResourceIsNotAvailable,"CannotGetUser");const o=new qe;o.Guid=e.Guid,o.Password=t,o.AccessLevel=r.AccessLevel,o.Email=r.Email;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ve(o),2e4,!1);return null==s||null==s.Status?new Ee(ce.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Ee(s.Status,s.Data))}))}DeleteUserAsync(e){return Be(this,void 0,void 0,(function*(){var t,n;if(""===e)return ce.WrongData;null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ke(e),2e4,!1);return Qv.Get(Le.ServiceName).ClearCache(),null==r||null==r.Status?ce.FatalError:(r.Status!=ce.OK&&(null===(n=u.Log)||void 0===n||n.Debug(We.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}))}GetUserProfilePictureAsync(e){return Be(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ee(ce.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 Qv.Get(Le.ServiceName).ClearCache(),null!=e.Type?t:e}return new Ee(ce.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return Be(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ee(ce.WrongData,"GuidCannotBeEmpty");let n=new be;n.ImageType=we.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(Qv.Get(Le.ServiceName).ClearCache(),r.Type==ce.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ce.OK?new Ee(ce.OK,"PictureSet"):new Ee(e,"PictureServiceError")}if(null!=r.Type)return new Ee(ce.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ce.OK?new Ee(ce.OK,"PictureSet"):new Ee(e,"PictureServiceError")}}))}}We.ServiceName="UsersService";class $e extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Get,this.Data=e}}class qe{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=fe.Unknown,this.AccessLevel=pe.Any}}class Ve extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Put,this.Data=e}}class He extends ae{constructor(){super(),this.Resource="/users/list",this.Method=ue.Get}}class Ke extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Delete,this.Data=e}}class je{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=fe.Unknown,this._accessLevel=pe.Any,this._localization=ve.En_Us,this._softwareVersion=""}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}get SoftwareVersion(){return this._softwareVersion}set SoftwareVersion(e){this._softwareVersion=e}GetUserProfilePictureAsync(){return Qv.Get(We.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return Qv.Get(We.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var ze=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Je{constructor(){this._onUserLoggedInEvent=new a,this._onUserLoggedOutEvent=new a,this._email="",this._password="",this._authToken="",this._loginTaskCompletionSource=this.CreateSessionCompletionSourceAsync(),this._alreadySubsribedToNetworkEvents=!1,this._user=null}CreateSessionCompletionSourceAsync(){return ze(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(Je.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{this.OnUserLoggedInEvent().Subscribe((t=>{var n;null===(n=u.Log)||void 0===n||n.Debug(Je.ServiceName,`Logged in as ${t.Name}, completing CreateSessionCompletionSourceAsync()`),e()}))}))}))}RestoreSessionAsync(){return ze(this,void 0,void 0,(function*(){var e,t;if(null===(e=u.Log)||void 0===e||e.Debug(Je.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0===this._user||null===this._user)return;const n=Qv.Get(_t.ServiceName),r=n.GetAuthorizationInfo();null!==r?(yield n.AuthorizeAsync(r),yield this.UserLogInAsync(this._email,this._password)):null===(t=u.Log)||void 0===t||t.Error(Je.ServiceName,"RestoreSessionAsync failed, no authorization info")}))}WaitForSessionCreationAsync(){return ze(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){return ze(this,void 0,void 0,(function*(){var e,t,n=new ae;n.Resource="/users/user/logout",n.Method=ue.Put,this._email="",this._password="",(yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ce.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=u.Log)||void 0===e||e.Debug(Je.ServiceName,"User has been logged out.")):null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return ze(this,void 0,void 0,(function*(){switch(e){case he.Disconnected:case he.Failed:break;case he.Connected:Qv.Get(Je.ServiceName).RestoreSessionAsync()}}))}AuthorizeAppAsync(e){return ze(this,void 0,void 0,(function*(){var t,n,r,o,s=Qv.Get(_t.ServiceName);const i=yield s.SendAndWaitForResponseAsync(new Ye(e),2e4,!1);if(i.Status==ce.OK&&null!=i.Data){this._authToken=e;var a=new je;return this._user=a,a.AccessLevel=i.Data.AccessLevel,a.Email=i.Data.Email,this._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,a.SoftwareVersion=i.Data.SoftwareVersion,void 0!==i.Data.ConfigurationTime&&(it.ConfigurationTimeRetrieved=new Date(i.Data.ConfigurationTime)),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,s.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged),Qv.Get(_t.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>ze(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user)}))))),null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,`Did logging in succeded?: ${i.Status==ce.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return i.Status===ce.OperationNotPermitted?(null===(n=u.Log)||void 0===n||n.Debug(Je.ServiceName,`App login response: ${i.Data}`),ye.AuthDisabled):i.Status===ce.ResourceDoesNotExists?(null===(r=u.Log)||void 0===r||r.Debug(Je.ServiceName,`App login response: ${i.Data}`),ye.MethodNotSupported):(null===(o=u.Log)||void 0===o||o.Debug(Je.ServiceName,`App login response: ${i.Data}`),ye.WrongAuthData)}))}UserLogInAsync(e,t){return ze(this,void 0,void 0,(function*(){var n,r,o=Qv.Get(_t.ServiceName);const s=yield o.SendAndWaitForResponseAsync(new Qe(e,t),2e4,!1);if(s.Status==ce.OK&&null!=s.Data){this._email=e,this._password=t;var i=new je;return this._user=i,i.AccessLevel=s.Data.AccessLevel,i.Email=s.Data.Email,i.Gender=s.Data.Gender,i.Guid=s.Data.Guid,i.IsAccountOnline=s.Data.IsAccountOnline,i.Name=s.Data.Name,i.IsActive=s.Data.IsActive,i.IsBanned=s.Data.IsBanned,i.Phone=s.Data.Phone,i.Surname=s.Data.Surname,i.SoftwareVersion=s.Data.SoftwareVersion,void 0!==s.Data.ConfigurationTime&&(it.ConfigurationTimeRetrieved=new Date(s.Data.ConfigurationTime)),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,o.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged),Qv.Get(_t.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>ze(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Je.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user)}))))),null===(n=u.Log)||void 0===n||n.Debug(Je.ServiceName,`Did logging in succeded?: ${s.Status==ce.OK}`),this._onUserLoggedInEvent.Invoke(this._user),i}return null===(r=u.Log)||void 0===r||r.Debug(Je.ServiceName,`User login response: ${s.Data}`),ye.WrongAuthData}))}GetServiceName(){return Je.ServiceName}}Je.ServiceName="SessionService";class Xe{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class Ye extends ae{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=ue.Put}}class Qe extends ae{constructor(e,t){super(),this.Data=new Xe(e,t),this.Resource="/users/user/login",this.Method=ue.Put}}class Ze{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 et=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class tt{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new Ze(1)}GetServiceName(){return tt.ServiceName}GetExtensionsInfoAsync(e){return et(this,arguments,void 0,(function*(e,t=!1){var n;null===(n=u.Log)||void 0===n||n.Debug(tt.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);var r=yield this._semaphore.AcquireAsync();if(this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync()),r.Release(),0==[...this._extensionInfoCache.values()].length)return[];if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new ot("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e){return et(this,arguments,void 0,(function*(e,t=!1,n=!1){var r;if(null===(r=u.Log)||void 0===r||r.Debug(tt.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 ot("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 ot("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return et(this,void 0,void 0,(function*(){const e=new nt,t=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(e,16e3,!0);if(null==t||null==t.Status)throw new ot("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ce.OK)throw new ot(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new ot("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 et(this,void 0,void 0,(function*(){var e;const t=new rt,n=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(t,16e3,!0);if(null==n||null==n.Status)throw new ot("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(n.Status){case ce.OK:if(null==n.Data)throw new ot("Cannot get ProtocolInfo from controller, controller response does not contain data!");n.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ce.ResourceDoesNotExists:null===(e=u.Log)||void 0===e||e.Debug(tt.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new ot(`Cannot get ProtocolInfo from controller! Response status: ${n.Status}`)}}))}}tt.ServiceName="StatisticsInfoService";class nt extends ae{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ue.Get}}class rt extends ae{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ue.Get}}class ot extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var st=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class it{GetServiceName(){return it.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new De,this._onExitedConfigurationEvent=new De,this._onConfigurationTimeCheckedEvent=new a,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{Qv.Get(Je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>st(this,void 0,void 0,(function*(){null!==it.ConfigurationTimeRetrieved?this._didConfigurationChange=yield this.CheckIfConfigurationTimeHasChangedAsync(it.ConfigurationTimeRetrieved):this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),this._didConfigurationChange&&Qv.Get(Le.ServiceName).ClearCache(),e()}))))})),this._connection=Qv.Get(_t.ServiceName),this._session=Qv.Get(Je.ServiceName),this._localStorage=Qv.Get(l.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke()}))}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,o;const s=null!==(o=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==o?o:null;if(!s||!s.includes("."))return!1;const i=s.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}ImportControllerConfigurationAsync(e){return st(this,void 0,void 0,(function*(){var t,n,r;let o=yield e.text(),s=this.SplitStringBySize(o),i=new at("");i.Status=ce.MultiDataResponseStart;let a=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(i,6e3,!1);if(void 0===a||(null==a?void 0:a.Status)!=ce.OK)return ce.Error;for(const e of s){let t=new at(e);t.Status=ce.MultiDataResponse;let r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(t,6e3,!1);if(void 0===r||(null==r?void 0:r.Status)!=ce.OK)return ce.Error}i.Status=ce.MultiDataResponseStop;let c=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(i,12e4,!1);return void 0===c||(null==c?void 0:c.Status)!=ce.OK?ce.Error:ce.OK}))}SplitStringBySize(e,t=1e5){const n=Math.floor(t/2),r=[];let o=0;for(;o<e.length;){let s=e.slice(o,o+n);for(;new Blob([s]).size>t;)s=s.slice(0,-1);r.push(s),o+=s.length}return r}GetControllerSystemTimeAsync(){return st(this,void 0,void 0,(function*(){var e,t;try{var n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ft,8e3,!1);return null==n||null==n.Status?ce.Error:n.Status!=ce.OK?n.Status:null==n.Data?ce.ResourceIsNotAvailable:new Date(n.Data)}catch(e){return null===(t=u.Log)||void 0===t||t.Error(it.ServiceName,`Cannot get current controller time! ${e}`),ce.FatalError}}))}SetControllerSystemTimeAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{var r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new vt(e.toISOString()),8e3,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(e){return null===(n=u.Log)||void 0===n||n.Error(it.ServiceName,`Cannot set current controller time! ${e}`),ce.FatalError}}))}StartNtpTimeSynchronizationAsync(){return st(this,void 0,void 0,(function*(){var e,t;try{var n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new yt,8e3,!1);return null==n||null==n.Status?ce.Error:n.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(it.ServiceName,`Cannot set current controller time! ${e}`),ce.FatalError}}))}FactoryResetAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{Qv.Get(Le.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new lt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=300,n=0,r=100/t,o=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Qv.Get(Le.ServiceName).ClearCache(),clearInterval(o),ce.OK}return r}catch(e){return ce.FatalError}}))}RollbackLastUpdateAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{Qv.Get(Le.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new dt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=420,n=0,r=100/t,o=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Qv.Get(Le.ServiceName).ClearCache(),clearInterval(o),ce.OK}return r}catch(e){return ce.FatalError}}))}RestartControllerAsync(e){return st(this,void 0,void 0,(function*(){var t,n;try{Qv.Get(Le.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ut,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=240,n=0,r=100/t,o=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Qv.Get(Le.ServiceName).ClearCache(),clearInterval(o),ce.OK}return r}catch(e){return ce.FatalError}}))}DidCofigurationChangeAsync(){return st(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(){return st(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,Qv.Get(Le.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ht,2e4,!1)}))}ExitConfigurationModeAsync(){return st(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,Qv.Get(Le.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new gt,2e4,!1),this._didConfigurationChange=!0,Qv.Get(Le.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._didConfigurationChange=!0,this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){return st(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new pt,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ce.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return st(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),Qv.Get(Le.ServiceName).ClearCache(),!0)}))}CheckIfConfigurationTimeHasChangedAsync(e){return st(this,void 0,void 0,(function*(){return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),Qv.Get(Le.ServiceName).ClearCache(),!0)}))}CanExportOrImportControllerConfigurationAsync(){return st(this,void 0,void 0,(function*(){try{let e=yield Qv.Get(tt.ServiceName).GetExtensionsInfoAsync(),t=Qv.Get(Je.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=pe.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){return st(this,void 0,void 0,(function*(){var e;let t=[],n=null;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndHandleResponseAsync(new ct,3e4,(e=>{switch(e.Status){case ce.MultiDataResponseStart:break;case ce.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);break;case ce.MultiDataResponseStop:break;case ce.Error:case ce.FatalError:n=new Ee(ge.CannotExportConfiguration,"Cannot export configuration! Controller returned error!")}}),!0);let r=JSON.stringify(JSON.parse(t.join("")),null,2);return console.log(r),null!=n?n:Qv.ExportStringAsFileToDownload(this.GetCurrentTimestampedFilename(),r)}))}GetCurrentTimestampedFilename(){var e,t;const n=new Date,r=n.getHours().toString().padStart(2,"0"),o=n.getMinutes().toString().padStart(2,"0"),s=n.getDate().toString().padStart(2,"0"),i=(n.getMonth()+1).toString().padStart(2,"0"),a=n.getFullYear().toString();return`${null===(t=null===(e=this._connection)||void 0===e?void 0:e.GetAuthorizationInfo())||void 0===t?void 0:t.SerialNumber}_${r}-${o}-${s}-${i}-${a}-config.cexp`}}it.ServiceName="ControllerConfigurationService",it.ConfigurationTimeRetrieved=null;class at extends ae{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=ue.Put,this.Data=e}}class ct extends ae{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=ue.Get}}class ut extends ae{constructor(){super(),this.Resource="/controller/restart",this.Method=ue.Post}}class lt extends ae{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ue.Post}}class dt extends ae{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ue.Post}}class ht extends ae{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ue.Put}}class gt extends ae{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ue.Put}}class pt extends ae{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ue.Get}}class ft extends ae{constructor(){super(),this.Resource="/system/time",this.Method=ue.Get}}class vt extends ae{constructor(e){super(),this.Resource="/system/time",this.Method=ue.Put,this.Data=e}}class yt extends ae{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=ue.Put}}var mt=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class wt{nextRetryDelayInMilliseconds(){return 1e3}}const St=[t.WebSockets,t.ServerSentEvents,t.LongPolling];class At{constructor(){this._log=Qv.Get(c.ServiceName)}log(e,t){if(!(e<_t.SignalRLogLevel))switch(t=`[SignalR] ${t}`,e){case r.Critical:case r.Error:this._log.Error(t);break;case r.Warning:this._log.Warning(t);break;case r.Information:this._log.Info(t);break;default:this._log.Debug(t)}}}class _t{constructor(){this._connectTask=null,this._pingTimerId=null,this._consecutivePingFailures=0,this._disconnectedOnPurpose=!1,this._address="packets-broker1.tr7.pl",this._serversBrokerAddress="https://servers-broker.tr7.pl",this._serversBrokerAddressList=["https://servers-broker.tr7.pl","https://broker.tr7.pl","https://dev-broker.tr7.pl"],this._allBrokersChecked=!1,this._packetsBrokerServers=["packets-broker1.tr7.pl","packets-broker2.tr7.pl"],this._lastReceivedPacket=Date.now(),this._everConnected=!1,this._pendingRequests=new Map,this._log=Qv.Get(c.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._dataReceivedEvent=new a,this._pongReceivedEvent=new De,this._authorizationReceivedEvent=new a,this._registrationReceivedEvent=new a,this._streamStartedEvent=new a,this._connectionStateChangedEvent=new a,this._errorOccuredEvent=new a,this._tryReconnect=()=>{navigator.onLine&&this.validateConnectionToController().then((e=>{e||(this._log.Debug(_t.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._onVisibility=()=>{"visible"===document.visibilityState&&(this._log.Debug(_t.ServiceName,"Page visible → connection check"),this.validateConnectionToController().then((e=>{e||(this._log.Debug(_t.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())})))},this._onHidden=()=>{},this._onVisible=()=>{this.validateConnectionToController().then((e=>{e||(this._log.Debug(_t.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))}}GetServiceName(){return _t.ServiceName}GetAuthorizationInfo(){return this._serialId&&this._PIN?new Ce(this._serialId,this._PIN):null}GetControllerSerialNumber(){return this._serialId}GetControllerPin(){return this._PIN}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._address=e}EnablePacketsLogging(){window.packets=!0}DisablePacketsLogging(){window.packets=!1}SubscribeTo(e,t){const n=n=>{n.Resource===e&&t(n)};return this._dataReceivedEvent.Subscribe(n),()=>this._dataReceivedEvent.Unsubscribe(n)}GetServerAddressAsync(){return mt(this,void 0,void 0,(function*(){if(!this._serialId)return this._log.Warning(_t.ServiceName,"GetServerAddressAsync() – serialId nieustawiony"),null;const e=`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`;try{const t=yield fetch(e);switch(t.status){case 200:{const e=(yield t.text()).trim();return e?(this._log.Debug(_t.ServiceName,`Broker address resolved: ${e}`),e):(this._log.Warning(_t.ServiceName,"Broker returned empty address"),null)}case 204:return this._allBrokersChecked?(this._log.Error(_t.ServiceName,"All brokers checkt but controller not found! Controller probably offline!"),null):(this._log.Warning(_t.ServiceName,`Broker controller ${this._serversBrokerAddress} returned 204 (no content) – controller not found on given server`),yield this.rotateServersBroker(),this.GetServerAddressAsync());default:return this._log.Warning(_t.ServiceName,`GetServerAddressAsync() – HTTP ${t.status}`),null}}catch(e){return this._log.Error(_t.ServiceName,String(e)),null}}))}rotateServersBroker(){return mt(this,void 0,void 0,(function*(){const e=this._serversBrokerAddressList.indexOf(this._serversBrokerAddress),t=e+1<this._serversBrokerAddressList.length?e+1:0;this._serversBrokerAddress=this._serversBrokerAddressList[t],this._allBrokersChecked=0===t,this._log.Info(_t.ServiceName,`Switching servers‑broker to: ${this._serversBrokerAddress}`)}))}ConnectAsync(e){return mt(this,void 0,void 0,(function*(){return this._address=e,this.serialisedConnect()}))}ConnectAndAuthorizeAsync(e){return mt(this,void 0,void 0,(function*(){this._serialId=e.serialNumber,this._PIN=e.pin,Qv.WorksInContextOf=this._serialId;let t=yield this.GetServerAddressAsync();if(t&&(this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===de.Connected&&(yield this.AuthorizeAsync(e))))return de.Connected;for(const t of this._packetsBrokerServers)if(this._log.Info(_t.ServiceName,`Fallback broker: ${t}`),this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===de.Connected&&(yield this.AuthorizeAsync(e)))return de.Connected;return de.FailedToConnect}))}AuthorizeAsync(e){return mt(this,void 0,void 0,(function*(){return new Promise((t=>mt(this,void 0,void 0,(function*(){var n;const r=window.setTimeout((()=>{this._authorizationReceivedEvent.Unsubscribe(o),t(!1)}),2e3),o=e=>{clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(o),this._log.Debug(_t.ServiceName,`Authorization → ${e}`),e&&this._connectionStateChangedEvent.Invoke(he.ConnectedAndAuthorized),t(e)};this._authorizationReceivedEvent.Subscribe(o),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)}))))}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===s.Connected}DisconnectAsync(){return mt(this,void 0,void 0,(function*(){var e;this._disconnectedOnPurpose=!0,this._log.Debug(_t.ServiceName,"Disconnecting..."),yield null===(e=this._connection)||void 0===e?void 0:e.stop(),this.cleanup()}))}SendAsync(e){return mt(this,arguments,void 0,(function*(e,t=!1){if(!this.IsConnected())throw new Error("Not connected");const n=!0===window.packets;(n||t)&&this._log.Debug(_t.ServiceName,`⇢ ${e.Resource} ${e.Method} ${e.TransactionId}`+(n?`\n${JSON.stringify(e,null,2)}`:""));try{return yield this._connection.invoke("SendTo",this._serialId,e),!0}catch(e){return this._log.Error(_t.ServiceName,String(e)),!1}}))}SendAndWaitForResponseAsync(e,t,n){return mt(this,arguments,void 0,(function*(e,t,n,r=!0){var o,s,i;if(e.Method===ue.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.DidCofigurationChangeAsync())){const t=null===(s=this._cache)||void 0===s?void 0:s.GetCache(e);if(t)return t}if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(i=this._session)||void 0===i?void 0:i.WaitForSessionCreationAsync()),new Promise(((o,s)=>mt(this,void 0,void 0,(function*(){const i=window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(a),this._pendingRequests.delete(e.TransactionId),s(new E("Response timeout"))}),t),a=s=>{var c,u;s.TransactionId===e.TransactionId&&(clearTimeout(i),this._dataReceivedEvent.Unsubscribe(a),this._pendingRequests.delete(e.TransactionId),e.Method===ue.Get&&n&&(null===(c=this._cache)||void 0===c||c.Cache(s)),n||s.Status!==ce.UserIsNotLoggedIn?o(s):null===(u=this._session)||void 0===u||u.RestoreSessionAsync().then((()=>o(this.SendAndWaitForResponseAsync(e,t,n,r)))))};this._dataReceivedEvent.Subscribe(a),this._pendingRequests.set(e.TransactionId,{resolve:e=>o(e),reject:s,timeoutId:i}),(yield this.SendAsync(e,r))||(clearTimeout(i),this._dataReceivedEvent.Unsubscribe(a),this._pendingRequests.delete(e.TransactionId),s(new Error("Failed to send request")))}))))}))}SendAndHandleResponseAsync(e,t,n){return mt(this,arguments,void 0,(function*(e,t,n,r=!0){var o;if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(o=this._session)||void 0===o?void 0:o.WaitForSessionCreationAsync()),new Promise(((o,s)=>mt(this,void 0,void 0,(function*(){const i=()=>window.setTimeout((()=>{c(),s(new E("MultiDataResponse timeout"))}),t);let a=i();const c=()=>{clearTimeout(a),this._dataReceivedEvent.Unsubscribe(u),this._pendingRequests.delete(e.TransactionId)},u=t=>{if(t.TransactionId===e.TransactionId)switch(clearTimeout(a),t.Status){case ce.MultiDataResponseStart:case ce.MultiDataResponse:n(t),a=i();break;case ce.MultiDataResponseStop:case ce.OK:n(t),c(),o();break;default:c(),s(new Error(`Unexpected status ${t.Status}`))}};this._dataReceivedEvent.Subscribe(u),this._pendingRequests.set(e.TransactionId,{resolve:()=>o(),reject:s,timeoutId:a}),(yield this.SendAsync(e,r))||(c(),s(new Error("Failed to send request")))}))))}))}SendAndHandleStreamAsync(e,t){return mt(this,arguments,void 0,(function*(e,t,n=!0){var r;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,o)=>mt(this,void 0,void 0,(function*(){const s=window.setTimeout((()=>{this._streamStartedEvent.Unsubscribe(i),o(new E("Stream registration timeout"))}),8e3),i=n=>{n===e.TransactionId&&(clearTimeout(s),this._streamStartedEvent.Unsubscribe(i),this._connection.stream("WatchStream",n).subscribe({next:e=>t.Next(e),complete:()=>{t.Complete(),r()},error:e=>{t.Error(e),o(new Te(String(e)))}}))};this._streamStartedEvent.Subscribe(i),(yield this.SendAsync(e,n))||(clearTimeout(s),this._streamStartedEvent.Unsubscribe(i),o(new Error("Failed to send request")))}))))}))}PingControllerAsync(){return mt(this,void 0,void 0,(function*(){if(!this.IsConnected())return!1;if(Date.now()-this._lastReceivedPacket<_t.PING_INTERVAL_MS)return!1;const e=new ae;e.Resource="/system/ping",e.Method=ue.Get;try{return yield this.SendAndWaitForResponseAsync(e,2e3,!1,!1),!0}catch(e){return!1}}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}serialisedConnect(){return this._connectTask||(this._connectTask=this.connectCore().finally((()=>this._connectTask=null))),this._connectTask}connectCore(){return mt(this,void 0,void 0,(function*(){var n,o,i,a,c;if(!this._address)return de.ControllerIsNotConnected;if((null===(n=this._connection)||void 0===n?void 0:n.state)===s.Reconnecting){this._log.Info(_t.ServiceName,"Connection is already in reconnecting state - letting automatic reconnect handle it");try{return yield this.waitForReconnection(),this._log.Info(_t.ServiceName,"Automatic reconnect successful"),de.Connected}catch(e){this._log.Warning(_t.ServiceName,`Automatic reconnect failed: ${e} trying to reconnect by creting new connection`)}}(null===(o=this._connection)||void 0===o?void 0:o.state)!=s.Disconnected&&(this._log.Info(_t.ServiceName,"connectCore() was called, but connection curently exists! Disconnecting..."),yield null===(i=this._connection)||void 0===i?void 0:i.stop()),this.initializeServices(),this.cleanup();for(const n of St){var u=(new re).withAutomaticReconnect(new wt).configureLogging(new At).withStatefulReconnect({bufferSize:256e3}).withServerTimeout(_t.SERVER_TIMOUT_MS).withUrl(`https://${this._address}/broker`,{skipNegotiation:n===t.WebSockets,transport:n});this._log.LogLevel===e.Debug&&u.configureLogging(r.Debug),this._connection=u.build(),this.wireConnectionEvents();try{return yield this._connection.start(),this.startPingLoop(),this._connectionStateChangedEvent.Invoke(he.Connected),de.Connected}catch(e){this._log.Warning(_t.ServiceName,`Transport ${t[n]} failed (${null==e?void 0:e.message}).`),yield this._connection.stop().catch((()=>{})),null===(c=(a=this._connection).off)||void 0===c||c.call(a)}}return this._connectionStateChangedEvent.Invoke(he.Failed),de.FailedToConnect}))}waitForReconnection(e=0){return new Promise(((t,n)=>{if(!this._connection||this._connection.state!==s.Reconnecting)return void n(new Error("Connection is not in reconnecting state"));let r;e>0&&(r=window.setTimeout((()=>{this._connectionStateChangedEvent.Unsubscribe(o),n(new Error("Reconnection timeout"))}),e));const o=e=>{e===he.Connected?(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),t()):e!==he.Disconnected&&e!==he.Failed||(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),n(new Error("Connection closed during reconnection")))};this._connectionStateChangedEvent.Subscribe(o),this._connection.state!==s.Reconnecting&&(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),this._connection.state===s.Connected?t():n(new Error(`Connection is in unexpected state: ${this._connection.state}`)))}))}initializeServices(){this._controllerConfiguration=Qv.Get(it.ServiceName),this._cache=Qv.Get(Le.ServiceName),this._session=Qv.Get(Je.ServiceName)}wireConnectionEvents(){this._connection&&(this._connection.on("Pong",(()=>{this._lastReceivedPacket=Date.now(),this._pongReceivedEvent.Invoke()})),this._connection.on("Authorization",(e=>this._authorizationReceivedEvent.Invoke(e))),this._connection.on("Registration",(e=>this._registrationReceivedEvent.Invoke(e))),this._connection.on("SendError",((e,t)=>{e.startsWith("NotAuthorized:")?this.AuthorizeAsync(new Ce(this._serialId,this._PIN)):this._errorOccuredEvent.Invoke([e,t])})),this._connection.on("Data",((e,t)=>{this._lastReceivedPacket=Date.now(),!0===window.packets&&this._log.Debug(_t.ServiceName,`Received: ${JSON.stringify(JSON.parse(t),null,2)}`),this._dataReceivedEvent.Invoke(JSON.parse(t))})),this._connection.onclose((()=>{this.cleanup(),this._connectionStateChangedEvent.Invoke(he.Disconnected)})),this._connection.onreconnecting((()=>this._connectionStateChangedEvent.Invoke(he.Reconnecting))),this._connection.onreconnected((()=>this._connectionStateChangedEvent.Invoke(he.Connected))))}startPingLoop(){null!==this._pingTimerId&&clearInterval(this._pingTimerId),this._pingTimerId=window.setInterval((()=>{this.pingOnce()}),_t.PING_INTERVAL_MS),window.addEventListener("online",this._tryReconnect),window.addEventListener("offline",this._tryReconnect),document.addEventListener("visibilitychange",this._onVisibility,!0),window.addEventListener("pagehide",this._onHidden,!0),window.addEventListener("pageshow",this._onVisible,!0)}pingOnce(){return mt(this,void 0,void 0,(function*(){this.IsConnected()&&(Date.now()-this._lastReceivedPacket<_t.PING_INTERVAL_MS||((yield this.PingControllerAsync())?this._consecutivePingFailures=0:++this._consecutivePingFailures>=_t.MAX_CONSECUTIVE_PING_FAILURES&&(this._consecutivePingFailures=0,this._log.Warning(_t.ServiceName,"Ping failed too many times → reconnecting..."),_t.SERVER_TIMOUT_MS<_t.PING_INTERVAL_MS*_t.MAX_CONSECUTIVE_PING_FAILURES&&this._log.Error("Server timeout is shorter than ping interval! SignalR automatic reconnect will not work!."),this.serialisedConnect())))}))}validateConnectionToController(){return mt(this,void 0,void 0,(function*(){var e;if(!this.IsConnected())return this._log.Warning(_t.ServiceName,"Connection was lost."),!1;{const n=new ae;n.Resource="/system/ping",n.Method=ue.Get;try{var t=yield this.SendAndWaitForResponseAsync(n,_t.SERVER_TIMOUT_MS+1e3,!1,!1);return(null==t?void 0:t.Status)!==ce.OK?(this._log.Warning(_t.ServiceName,"Connection check failed, "+(null==t?"result is null":`status: ${t.Status}`)),!1):(null===(e=this._connection)||void 0===e?void 0:e.state)==s.Reconnecting?(this._log.Warning(_t.ServiceName,"Connection check failed, but connection is in reconnecting state!"),!1):(this._log.Info(_t.ServiceName,"Connection still active!"),!0)}catch(e){return!1}}}))}cleanup(){var e,t;null!==this._pingTimerId&&(clearInterval(this._pingTimerId),this._pingTimerId=null);for(const[,e]of this._pendingRequests)clearTimeout(e.timeoutId),e.reject(new Error("Connection lost"));this._pendingRequests.clear(),window.removeEventListener("online",this._tryReconnect),window.removeEventListener("offline",this._tryReconnect),document.removeEventListener("visibilitychange",this._onVisibility,!0),window.removeEventListener("pagehide",this._onHidden,!0),window.removeEventListener("pageshow",this._onVisible,!0),null===(t=null===(e=this._connection)||void 0===e?void 0:e.off)||void 0===t||t.call(e),this._connection=void 0}}var Ct,Tt,Dt,kt,Et,bt,It,Gt,Nt,Rt,Pt,Ot,Ut,Mt,xt,Ft;_t.PING_INTERVAL_MS=5e3,_t.MAX_CONSECUTIVE_PING_FAILURES=6,_t.SERVER_TIMOUT_MS=1e4,_t.SignalRLogLevel=r.Warning,_t.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(Ct||(Ct={})),(Ot=Tt||(Tt={}))[Ot.Default=0]="Default",Ot[Ot.Monostable=1]="Monostable",Ot[Ot.Bistable=2]="Bistable",Ot[Ot.Gate=3]="Gate",Ot[Ot.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"}(Dt||(Dt={}));class Lt{constructor(){this._type=Et.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Ut=kt||(kt={}))[Ut.Unknown=0]="Unknown",Ut[Ut.BlindMotor=1]="BlindMotor",Ut[Ut.DinModule=2]="DinModule",Ut[Ut.DinModuleWithAntenna=3]="DinModuleWithAntenna",Ut[Ut.Remote=4]="Remote",Ut[Ut.RemoteForBlinds=5]="RemoteForBlinds",Ut[Ut.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",Ut[Ut.MovementSensor=7]="MovementSensor",Ut[Ut.TemperatureSensor=8]="TemperatureSensor",Ut[Ut.HumiditySensor=9]="HumiditySensor",Ut[Ut.DinPowerMeter=10]="DinPowerMeter",Ut[Ut.Intercom=11]="Intercom",Ut[Ut.SecurityCamera=12]="SecurityCamera",Ut[Ut.Multisensor=13]="Multisensor",Ut[Ut.FloodSensor=14]="FloodSensor",Ut[Ut.FlushMountedReceiver=15]="FlushMountedReceiver",Ut[Ut.FlushMountedBlindController=16]="FlushMountedBlindController",Ut[Ut.FlushMountedDimmer=17]="FlushMountedDimmer",Ut[Ut.FlushMountedRelay=18]="FlushMountedRelay",Ut[Ut.FlushMountedGateController=19]="FlushMountedGateController",Ut[Ut.WindSensor=20]="WindSensor",Ut[Ut.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",Ut[Ut.AirPressureSensor=22]="AirPressureSensor",Ut[Ut.LightBrightnessSensor=23]="LightBrightnessSensor",Ut[Ut.ReedSensor=24]="ReedSensor",Ut[Ut.FlushMountedTransceiver=25]="FlushMountedTransceiver",Ut[Ut.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",Ut[Ut.WallMountedThermoregulator=27]="WallMountedThermoregulator",Ut[Ut.ImpulseCounter=28]="ImpulseCounter",Ut[Ut.FlushMountedFacadeController=29]="FlushMountedFacadeController",Ut[Ut.WallMountedGateController=30]="WallMountedGateController",Ut[Ut.WallMountedRGBLightController=31]="WallMountedRGBLightController",Ut[Ut.WallMountedDimmer=32]="WallMountedDimmer",Ut[Ut.WallMountedRemote=33]="WallMountedRemote",Ut[Ut.DinRelay=34]="DinRelay",Ut[Ut.DinReceiver=35]="DinReceiver",Ut[Ut.DinBlindController=36]="DinBlindController",Ut[Ut.DinTransceiver=37]="DinTransceiver",Ut[Ut.SocketPlugIn=38]="SocketPlugIn",Ut[Ut.WallMountedRelay=39]="WallMountedRelay",Ut[Ut.Retransmitter=40]="Retransmitter",function(e){e.Unknown="Unknown",e.SetBlindPosition="IBlindPosition",e.SetBlindPositionSimple="IBlindPositionSimple",e.SetBlindMicroventilation="IMicroventilation",e.TurnOff="IChannelOff",e.TurnOn="IChannelOn",e.TurnOnWithTime="IChannelOnWithTime",e.TogleState="IChannelSwitchState",e.SetLightBrightnessDynamicly="IDynamicLightBrightness",e.SetLightBrightness="ILightBrightness",e.SetLightColor="ILightColor",e.SetLightTemperature="ILightTemperature",e.PairDevice="IPair",e.UnpairDevice="IUnpair",e.IdentifyDevice="IIdentifyDevice",e.GetChannelsState="IGetDeviceState",e.GetPowerMeasurements="IGetPowerMeasurements",e.GetAvailableData="IGetAvailableData",e.MultipleDataRequest="IMultipleDataRequest",e.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",e.SetTemperature="IChangeTemperature",e.SetGatePosition="IGatePosition",e.SetGatewayPosition="IGatewayPosition",e.ChangeGatePositionPulse="IGatePulse",e.ChangeGatewayPositionPulse="IGatewayPulse",e.SetFacadePosition="IFacadePosition",e.GetFacadeType="IGetFacadeType",e.LightRGBW="ILightRGBW",e.PreciseGateControl="IPreciseGateControl"}(Et||(Et={}));class Bt{constructor(){this._type=bt.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.BlindErrorState="IBlindError",e.MeasuredBrightness="IBrightness",e.RemoteButtonState="IButtonState",e.ChannelOnOffState="IChannelOnOff",e.IntercomState="IIntercom",e.DoorBellState="IDoorBell",e.FacadeRemoteButtonState="IFacadeControlButton",e.FacadePosition="IFacadeState",e.FacadeType="IFacadeType",e.FloodSensorState="IFloodSensor",e.GatePosition="IGatePosition",e.GatewayPosition="IGatewayPosition",e.GateControllerHealth="IGateControllerHealth",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",e.SceneExecuted="ISceneExecuted",e.HallState="IHallState",e.Intercom="IIntercom"}(bt||(bt={})),(Ft=It||(It={}))[Ft.NotResponding=0]="NotResponding",Ft[Ft.Working=1]="Working",Ft[Ft.Broken=2]="Broken",Ft[Ft.FirmareUpgradeMode=3]="FirmareUpgradeMode",(xt=Gt||(Gt={}))[xt.TwoWay=1]="TwoWay",xt[xt.OneWay=2]="OneWay",xt[xt.ConditionalTwoWay=3]="ConditionalTwoWay",(Mt=Nt||(Nt={}))[Mt.Unknown=-1]="Unknown",Mt[Mt.Multipurpose=0]="Multipurpose",Mt[Mt.Controller=1]="Controller",Mt[Mt.Driver=2]="Driver",Mt[Mt.Receiver=3]="Receiver",Mt[Mt.Remote=4]="Remote",Mt[Mt.Sensor=5]="Sensor",Mt[Mt.Scene=6]="Scene";class Wt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=Ct.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"}(Rt||(Rt={})),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"}(Pt||(Pt={}));class $t{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=Pt.Unknown}}var qt,Vt,Ht,Kt,jt,zt,Jt,Xt,Yt,Qt,Zt,en,tn,nn,rn,on,sn,an,cn,un,ln,dn,hn,gn,pn,fn,vn,yn,mn,wn,Sn;class An{constructor(){this._type="",this._data=null,this._typeAsEnum=bt.Unknown,this._serializedDataWithoutTime=""}get Data(){return this._data}set Data(e){this._data=e;let{Time:t}=e,n=function(e,t){var n={};for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var o=0;for(r=Object.getOwnPropertySymbols(e);o<r.length;o++)t.indexOf(r[o])<0&&Object.prototype.propertyIsEnumerable.call(e,r[o])&&(n[r[o]]=e[r[o]])}return n}(e,["Time"]);this._serializedDataWithoutTime=JSON.stringify(n)}get Type(){return this._type}set Type(e){this._type=e}get TypeAsEnum(){return this._typeAsEnum}set TypeAsEnum(e){this._typeAsEnum=e}get StatesComparisonData(){return this._serializedDataWithoutTime}}(Sn=qt||(qt={}))[Sn.Confident=0]="Confident",Sn[Sn.Unconfident=1]="Unconfident";class _n extends An{constructor(e){super(),this.TypeAsEnum=bt.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class Cn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Vt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Vt||(Vt={}));class Tn extends An{constructor(e){super(),this.TypeAsEnum=bt.HallState,this.Type="IHallState",this.Data=e.state}}class Dn extends An{constructor(e){super(),this.TypeAsEnum=bt.SceneExecuted,this.Type="ISceneExecuted",this.Data=e.state}}class kn extends An{constructor(e){super(),this.TypeAsEnum=bt.IntercomState,this.Type="IntercomState",this.Data=e.state}}!function(e){e[e.Idle=0]="Idle",e[e.IncomingCall=1]="IncomingCall",e[e.AnsweringCall=2]="AnsweringCall",e[e.Busy=3]="Busy",e[e.NoAnswerToCall=4]="NoAnswerToCall",e[e.Unknown=5]="Unknown"}(Ht||(Ht={}));class En extends An{constructor(e){super(),this.TypeAsEnum=bt.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class bn extends An{constructor(e){super(),this.TypeAsEnum=bt.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class In{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Kt.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(Kt||(Kt={}));class Gn extends An{constructor(e){super(),this.TypeAsEnum=bt.ReedState,this.Type="ReedState",this.Data=e.state}}class Nn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=!1,this.Time=""}}class Rn extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return jt.UnableToMove;case 201:return jt.MotorOverheatedPleaseWait;default:return jt.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(jt||(jt={}));class Pn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class On extends An{constructor(e){super(),this.TypeAsEnum=bt.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class Un{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=zt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(zt||(zt={}));class Mn extends An{constructor(e){super(),this.TypeAsEnum=bt.LightColor,this.Type="LightColorState",this.Data=e.state}}class xn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class Fn extends An{constructor(e){super(),this.TypeAsEnum=bt.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class Ln{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Temperature=0,this.Time=""}}class Bn extends An{constructor(e){super(),this.TypeAsEnum=bt.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class Wn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class $n extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class qn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Temperature=0,this.Type=Jt.InsideTemperature,this.Time=""}}!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"}(Jt||(Jt={}));class Vn extends An{constructor(e){super(),this.TypeAsEnum=bt.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Hn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Xt.Half,this.Percentage=-1,this.Time=""}}!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"}(Xt||(Xt={}));class Kn extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class jn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class zn extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class Jn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Time="",this.MeasurementParameters=new Map}}!function(e){e.Voltage="Voltage",e.Current="Current",e.PhaseShift="PhaseShift",e.ActivePower="ActivePower",e.ReactivePower="ReactivePower",e.ApparentPower="ApparentPower",e.PowerFactor="PowerFactor",e.ActiveForwardEnergy="ActiveForwardEnergy",e.ActiveReverseEnergy="ActiveReverseEnergy",e.ApparentEnergy="ApparentEnergy",e.ReactiveForwardEnergy="ReactiveForwardEnergy",e.ReactiveReverseEnergy="ReactiveReverseEnergy",e.Frequency="Frequency",e.SPIErrorRate="SPIErrorRate",e.CRCErrorRate="CRCErrorRate",e.Timestamp="Timestamp",e.FailedMeasurementsRate="FailedMeasurementsRate",e.FundamentalActivePower="FundamentalActivePower",e.HarmonicActivePower="HarmonicActivePower"}(Yt||(Yt={}));class Xn extends An{constructor(e){super(),this.TypeAsEnum=bt.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Qt||(Qt={}));class Yn extends An{constructor(e){super(),this.TypeAsEnum=bt.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Qn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Intensity=0,this.Movement=Zt.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Zt||(Zt={}));class Zn extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class er{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=en.StopReleased,this.Time=""}}!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"}(en||(en={}));class tr extends An{constructor(e){super(),this.TypeAsEnum=bt.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class nr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=tn.StopReleased,this.Time=""}}!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"}(tn||(tn={}));class rr extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(nn||(nn={}));class or extends An{constructor(e){super(),this.TypeAsEnum=bt.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class sr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.PositionType=rn.Unknown,this.Position=0,this.Time=""}}!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",e[e.Percentage=6]="Percentage"}(rn||(rn={}));class ir extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(on||(on={}));class ar extends An{constructor(e){super(),this.TypeAsEnum=bt.GateControllerHealth,this.Type="GateControllerHealthState",this.Data=e.state}}!function(e){e[e.Unknown=-1]="Unknown",e[e.Inactive=0]="Inactive",e[e.Active=1]="Active",e[e.UnconnectedOrMalfunction=2]="UnconnectedOrMalfunction"}(sn||(sn={}));class cr extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(an||(an={}));class ur extends An{constructor(e){super(),this.TypeAsEnum=bt.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class lr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Type=cn.AirHumidity,this.Humidity=0,this.Time=""}}!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"}(cn||(cn={}));class dr extends An{constructor(e){super(),this.TypeAsEnum=bt.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(un||(un={}));class hr extends An{constructor(e){super(),this.TypeAsEnum=bt.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class gr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=ln.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(ln||(ln={}));class pr extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(dn||(dn={}));class fr extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class vr extends An{constructor(e){super(),this.TypeAsEnum=bt.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class yr extends An{constructor(e){super(),this.TypeAsEnum=bt.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class mr extends An{constructor(e){super(),this.TypeAsEnum=bt.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class wr extends An{constructor(e){super(),this.TypeAsEnum=bt.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Sr extends An{constructor(e){super(),this.TypeAsEnum=bt.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class Ar{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.WindThreshold=hn.Unknown,this.Time=""}}!function(e){e[e.Unknown=0]="Unknown",e[e.Below=1]="Below",e[e.Exceeded=2]="Exceeded",e[e.Inactive=3]="Inactive"}(hn||(hn={}));class _r extends An{constructor(e){super(),this.TypeAsEnum=bt.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"}(gn||(gn={}));class Cr extends An{constructor(e){super(),this.TypeAsEnum=bt.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class Tr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Value=0,this.Time=""}}class Dr extends An{constructor(e){super(),this.TypeAsEnum=bt.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class kr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=pn.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(pn||(pn={})),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"}(fn||(fn={}));class Er extends An{constructor(e){super(),this.TypeAsEnum=bt.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class br{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Pressure=0,this.Time="",this.PressureType=vn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(vn||(vn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(yn||(yn={}));class Ir extends An{constructor(e){super(),this.TypeAsEnum=bt.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(mn||(mn={}));class Gr extends An{constructor(e){super(),this.TypeAsEnum=bt.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Nr extends An{constructor(e){super(),this.TypeAsEnum=bt.BlindErrorState,this.Type="BlindError",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.ObstacleDetected=1]="ObstacleDetected",e[e.MotorFailure=2]="MotorFailure"}(wn||(wn={}));class Rr{constructor(){this._onDeviceStateChangedEvent=new a,this._onDeviceStateRefreshedOrChangedEvent=new a,this._onDeviceTasksExecutionChangedOnChannelsEvent=new a,this._onDeviceFirmwareVersionChangedEvent=new a,this._iconType=kt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=It.Working,this._deviceType=Nt.Unknown,this._communicationWay=Gt.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==Rr._devicesService&&(Rr._devicesService=Qv.Get(Ys.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Rr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Rr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),Rr._devicesService.OnDevicesTasksExecutionChangeEvent().Subscribe((e=>{t.Invoke(e.filter((e=>e.DeviceGuid==this._guid)).map((e=>e.Channel)))}))}OnDeviceFirmwareVersionChangedEvent(){return this._onDeviceFirmwareVersionChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}get ShouldChannelsBeGrouped(){if(this._deviceType===Nt.Remote)switch(this._modelGuid){case"afea26ac-d5de-4aa9-8e74-ff69679d097b":case"908a71ec-ca46-4431-9504-05b7801e77f8":case"d8fea502-541e-42d9-8ece-a1bcfaaa93f9":return!1;default:return this._availableTasksTypes.all((e=>e.Type!==Et.SetBlindPositionSimple))}return!1}get States(){return c.DoesThrowStackTrace?Qv.Get(Ys.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Rr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Rr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Rr._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 IconType(){return this._iconType}set IconType(e){this._iconType=e}get Name(){return null==this._name?"":this._name}set Name(e){this._name=e}set SoftwareVersion(e){this._softwareVersion=e}get SoftwareVersion(){return this._softwareVersion}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,o=function*(){var t;try{const n=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new Pr(this,e),2e4,!1);switch(n.Status){case ce.OK:return this._name=e,null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeDeviceNameAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),new ke(me.Changed,"");case ce.WrongData:if("DeviceNotFound"==n.Data)return new ke(me.Failed,"DeviceNotFound");break;case ce.NoPermissionsToCallGivenResource:return new ke(me.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new ke(me.ControllerResponseTimeout,""):new ke(me.UnknownError,"")}return new ke(me.Unknown,"")},new((r=void 0)||(r=Promise))((function(e,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(t){var n;t.done?e(t.value):(n=t.value,n instanceof r?n:new r((function(e){e(n)}))).then(i,a)}c((o=o.apply(t,n||[])).next())}));var t,n,r,o}ExecuteTaskAsync(e){return Rr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class Pr extends ae{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ue.Put;const n=new Or;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class Or{constructor(){this.DeviceGuid="",this.Name=""}}var Ur,Mr,xr,Fr,Lr,Br=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Wr{constructor(){this._device=new Rr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=Tt.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this._configurations={},this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new a,this._onChannelStateChangedEvent=new a,this._onChannelStateRefreshedOrChangedEvent=new a,null==Wr._devicesService&&(Wr._devicesService=Qv.Get(Ys.ServiceName))}OnChannelStateChangedEvent(){return this._onChannelStateChangedEvent}OnChannelStateRefreshedOrChangedEvent(){return this._onChannelStateRefreshedOrChangedEvent}get Configurations(){return this._configurations}set Configurations(e){this._configurations=e}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}`,this._device.OnDeviceStateChangedEvent().Subscribe((e=>{e.Data.Channel==this.Number&&this._onChannelStateChangedEvent.Invoke(e)})),this._device.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Data.Channel==this.Number&&this._onChannelStateRefreshedOrChangedEvent.Invoke(e)}))}GetDevice(){return this._device}SetCustomDataAsync(e,t){return Br(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new $r;return r.DeviceGuid=this._device.Guid,r.ChannelConfiguration=n,this.ChangeConfigurationAsync(r)}))}RemoveCustomDataAsync(e){const t=this.GetChannelConfigurationData();delete t.CustomData[e],delete this._customData[e];const n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new qr;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();this._isHidden=!0,e.Hidden=!0;const t=new $r;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ShowAsync(){const e=this.GetChannelConfigurationData();e.Hidden=!1,this._isHidden=!1;const t=new $r;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,t.ChannelName=e,this._name=e,this.ChangeConfigurationAsync(n)}ChangeIconNameAsync(e){const t=this.GetChannelConfigurationData();t.IconName=e;const n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._iconName=e,this.ChangeConfigurationAsync(n)}ChangeGroupsAsync(e){const t=this.GetChannelConfigurationData();t.GroupsGuids=e;const n=new $r;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){return Br(this,void 0,void 0,(function*(){var t,n;try{const r=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new Vr(e),2e4,!1);switch(null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeConfigurationAsync()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),r.Status){case ce.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,this._configurations=e.ChannelConfiguration.Configurations,new ke(me.Changed,"");case ce.WrongData:if("DeviceNotFound"===r.Data)return null===(n=u.Log)||void 0===n||n.Error("Failed to change channel configuration, referenced device does not exist!"),new ke(me.WrongData,"DeviceNotFound");break;case ce.FatalError:return new ke(me.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new ke(me.ControllerResponseTimeout,"")}return new ke(me.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 c.DoesThrowStackTrace?Qv.Get(Ys.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Wr._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,Wr._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(Pt.Failed)}}Wr._devicesService=null;class $r{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new qr}}class qr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=Tt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class Vr extends ae{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ue.Put,this.Data=e}}!function(e){e[e.TurnOn=0]="TurnOn",e[e.TurnOff=1]="TurnOff",e[e.ToggleState=2]="ToggleState",e[e.SetBlindPosition=3]="SetBlindPosition",e[e.SetLightColor=4]="SetLightColor",e[e.SetLightTemperature=5]="SetLightTemperature",e[e.SetLightBrightness=6]="SetLightBrightness",e[e.SetTemperature=7]="SetTemperature",e[e.GetState=8]="GetState",e[e.TurnOnWithTimeout=9]="TurnOnWithTimeout",e[e.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",e[e.IdentifyDevice=11]="IdentifyDevice",e[e.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",e[e.SetBlindMicroventilation=13]="SetBlindMicroventilation",e[e.GatewayPulse=25]="GatewayPulse",e[e.GatePulse=26]="GatePulse",e[e.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",e[e.GetFacadeType=30]="GetFacadeType",e[e.LightRGBW=31]="LightRGBW",e[e.SetGatePositionPrecise=32]="SetGatePositionPrecise"}(Ur||(Ur={}));class Hr{static NewGuid(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){var t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)}))}}class Kr{constructor(){this._taskType=Et.GetChannelsState,this._featureType=Ur.GetState,this._channel=0,this._guid=Hr.NewGuid(),this._deviceGuid=""}get TaskType(){return this._taskType}set TaskType(e){this._taskType=e}get FeatureType(){return this._featureType}set FeatureType(e){this._featureType=e}get Guid(){return this._guid}set Guid(e){this._guid=e}get DeviceGuid(){return this._deviceGuid}set DeviceGuid(e){this._deviceGuid=e}get Channel(){return this._channel}set Channel(e){this._channel=e}}class jr extends Kr{constructor(){super(),this.Temperature=0,this.FeatureType=Ur.SetTemperature,this.TaskType=Et.SetTemperature}}class zr extends Kr{constructor(){super(),this.FeatureType=Ur.TurnOff,this.TaskType=Et.TurnOff}}class Jr extends Kr{constructor(){super(),this.FeatureType=Ur.TurnOn,this.TaskType=Et.TurnOn}}class Xr extends Kr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=Ur.TurnOnWithTimeout,this.TaskType=Et.TurnOnWithTime}}class Yr extends Kr{constructor(){super(),this.Brightness=0,this.FeatureType=Ur.SetLightBrightness,this.TaskType=Et.SetLightBrightness}}class Qr extends Kr{constructor(){super(),this.FeatureType=Ur.ToggleState,this.TaskType=Et.TogleState}}class Zr extends Kr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=Ur.SetLightColor,this.TaskType=Et.SetLightColor}}class eo extends Kr{constructor(){super(),this.Temperature=0,this.FeatureType=Ur.SetLightTemperature,this.TaskType=Et.SetLightTemperature}}class to extends Kr{constructor(){super(),this.Action=Mr.Stop,this.Position=0,this.FeatureType=Ur.SetBlindPosition,this.TaskType=Et.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Mr||(Mr={}));class no extends Kr{constructor(){super(),this.GateControlAction=xr.Stop,this.Position=0,this.FeatureType=Ur.SetGatePositionPrecise,this.TaskType=Et.PreciseGateControl}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(xr||(xr={}));class ro extends Kr{constructor(){super(),this.Action=Fr.Stop,this.Position=0,this.FeatureType=Ur.SetBlindPosition,this.TaskType=Et.SetBlindPositionSimple}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Fr||(Fr={}));class oo extends Kr{constructor(){super(),this.Brightness=0,this.FeatureType=Ur.SetLightBrightnessDynamicly,this.TaskType=Et.SetLightBrightnessDynamicly}}class so extends Kr{constructor(){super(),this.FeatureType=Ur.IdentifyDevice,this.TaskType=Et.IdentifyDevice}}class io extends Kr{constructor(){super(),this.Data=new ao,this.FeatureType=Ur.SetBlindOpenCloseTime,this.TaskType=Et.SetBlindOpenCloseTime}}class ao{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class co extends Kr{constructor(){super(),this.FeatureType=Ur.GetState,this.TaskType=Et.GetChannelsState}}class uo extends Kr{constructor(){super(),this.Position=0,this.FeatureType=Ur.SetBlindMicroventilation,this.TaskType=Et.SetBlindMicroventilation}}class lo extends Kr{constructor(){super(),this.FeatureType=Ur.GatePulse,this.TaskType=Et.ChangeGatewayPositionPulse}}class ho extends Kr{constructor(){super(),this.FeatureType=Ur.GatewayPulse,this.TaskType=Et.ChangeGatewayPositionPulse}}class go extends Kr{constructor(){super(),this.FacadeAction=Lr.Stop,this.Tilt=0,this.Position=0,this.FeatureType=Ur.SetFacadePositionAndTilt,this.TaskType=Et.SetFacadePosition}}class po extends Kr{constructor(){super(),this.FeatureType=Ur.GetFacadeType,this.TaskType=Et.GetFacadeType}}!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"}(Lr||(Lr={}));class fo{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class vo extends Kr{constructor(){super(),this.Data=new fo,this.FeatureType=Ur.LightRGBW,this.TaskType=Et.LightRGBW}}var yo=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class mo{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return mo.ServiceName}RegisterManuallyPairedDevicesProtocol(e){var t;null===(t=u.Log)||void 0===t||t.Debug(mo.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return yo(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()],n=[];if(null!=e)if(Array.isArray(e))for(let r=0;r<t.length;r++)e.any((e=>e==t[r].ProtocolExtensionGuid))&&n.push(...yield t[r].GetDevicesForManualPairingAsync());else{const r=t.find((t=>t.ProtocolExtensionGuid==e));null!=r&&n.push(...yield r.GetDevicesForManualPairingAsync())}else for(let e=0;e<t.length;e++)n.push(...yield t[e].GetDevicesForManualPairingAsync());return n}))}AddManuallyPairedDeviceAsync(e){return yo(this,void 0,void 0,(function*(){var t;const n=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=n?n.AddManuallyPairedDeviceAsync(e):(null===(t=u.Log)||void 0===t||t.Error(mo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDeviceAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),Pt.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}mo.ServiceName="ManualDeviceService";class wo{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var So,Ao=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class _o{constructor(){this._connection=null,this._localDb=null,this._connection=Qv.Get(_t.ServiceName),this._localDb=Qv.Get(l.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return Ao(this,void 0,void 0,(function*(){let r=new Co(e,t,n),o=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(o.Status===ce.OK){const r=new ko;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(_o.ServiceName,this.GetLocalDbName(e,t),r)}return o.Status}))}ReadAsync(e,t,n){return Ao(this,void 0,void 0,(function*(){let r=new To(e,t);if(!n){const n=this._localDb.Read(_o.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new wo;return t.Data=JSON.parse(e.Data),t.IsGlobal=e.IsGlobal,t.ResourceGuid=e.ResourceGuid,t}}let o=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(o.Status===ce.OK){const e=new wo;return e.ResourceGuid=o.ResourceGuid,e.Data=JSON.parse(o.Data),e.IsGlobal=o.IsGlobal,e}return o.Status}))}RemoveAsync(e,t){return Ao(this,void 0,void 0,(function*(){let n=new Do(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return _o.ServiceName}}_o.ServiceName="RemoteStorageService";class Co extends ae{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class To extends ae{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Get,this.ResourceGuid=e,this.Global=t}}class Do extends ae{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Delete,this.ResourceGuid=e,this.Global=t}}class ko extends ae{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class Eo{constructor(){this.Longitude=0,this.Latitude=0}}class bo{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"}(So||(So={}));var Io,Go,No=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ro{IsControllerGeolocationSetAsync(){return No(this,void 0,void 0,(function*(){let e=new Po,t=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ce.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return No(this,void 0,void 0,(function*(){return new Promise(((e,t)=>No(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){return No(this,void 0,void 0,(function*(){var t,n,r;let o=new Uo;o.Data.Latitude=e.Latitude,o.Data.Longitude=e.Longitude,null===(t=u.Log)||void 0===t||t.Warning(Ro.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(o)}`);let s=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(o,15e3,!1);switch(null===(n=u.Log)||void 0===n||n.Warning(Ro.ServiceName,`${JSON.stringify(s)}`),null===(r=u.Log)||void 0===r||r.Error(Ro.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetControllerGeolocationAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),null==s?void 0:s.Status){case ce.OK:return new Ee(So.OK,"");case ce.NoPermissionToPerformThisOperation:case ce.NoPermissionsToCallGivenResource:return new Ee(So.NoPermissions,"");case ce.UserIsNotLoggedIn:return new Ee(So.UserIsNotLoggedIn,"");default:return new Ee(So.UnknownError,"")}}))}GetControlllerGeolocationAsync(){return No(this,void 0,void 0,(function*(){var e,t;let n=new Oo;null===(e=u.Log)||void 0===e||e.Warning(Ro.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=u.Log)||void 0===t||t.Warning(Ro.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ce.OK){let e=new bo;return e.IsNetworkBased=(null==r?void 0:r.Data).IsNetworkBased,e.Latitude=(null==r?void 0:r.Data).Latitude,e.Longitude=(null==r?void 0:r.Data).Longitude,e}return null==r?void 0:r.Status}))}GetServiceName(){return Ro.ServiceName}}Ro.ServiceName="GeolocationService";class Po extends ae{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ue.Get}}class Oo extends ae{constructor(){super(),this.Resource="/geolocation/get",this.Method=ue.Get}}class Uo extends ae{constructor(){super(),this.Data=new Eo,this.Resource="/geolocation/save",this.Method=ue.Put}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Io||(Io={}));class Mo{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=Go.Unknown,this.ResourceGuid=""}}class xo{constructor(){this.UpdateDescription=new Map,this.Update=new Mo,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"}(Go||(Go={}));class Fo extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var Lo,Bo,Wo,$o,qo,Vo,Ho,Ko,jo,zo,Jo,Xo,Yo,Qo,Zo,es,ts,ns,rs=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class os{constructor(){this._services=new Map,this._runtimeInfo=new ss,this._hardwareInfo=new as,this._semaphore=new Ze(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return os.ServiceName}RegisterUpdatesProvider(e){var t;null===(t=u.Log)||void 0===t||t.Debug(os.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return rs(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(os.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const n=this._services.get(e);if(null==n)throw new Fo("Cannot get update provider! Requested update provider has not been registered.");return n}))}GetUpdatesProvidersAsync(e){return rs(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(os.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let n=[];if(n=[...this._services.values()].filter((t=>t.ProviderType==e)),0==n.length)throw new Fo("Cannot get update providers! Requested update providers has not been registered.");return n}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return rs(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(os.ServiceName,`Getting update providers with protocol guid: [${e}] by GetUpdateProvidersByProtocolAsync<T>()`);let o=[];if(o=null!=n?[...this._services.values()].filter((r=>r.ProtocolGuid==e&&r.ProviderType==t&&r.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ProtocolGuid==e&&n.ProviderType==t)),0==o.length)throw new Fo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Fo("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return rs(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(os.ServiceName,`Getting update providers with extension guid: [${e}] by GetUpdateProvidersByExtensionAsync<T>()`);let o=[];if(o=null!=n?[...this._services.values()].filter((r=>r.ExtensionGuid==e&&r.ProviderType==t&&r.AvailableExtensionVersion==n)):[...this._services.values()].filter((n=>n.ExtensionGuid==e&&n.ProviderType==t)),0==o.length)throw new Fo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Fo("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(){return rs(this,arguments,void 0,(function*(e=!1){var t=yield this._semaphore.AcquireAsync();return!this._isRuntimeInfoInitialized||e?(yield this.GetRuntimeControllerInfoAsync(),t.Release(),this._runtimeInfo):(t.Release(),this._runtimeInfo)}))}GetRuntimeControllerInfoAsync(){return rs(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(os.ServiceName,"Getting runtime version info from controller.");try{const e=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new is,16e3,!1);if(null==e||null==e.Status)throw new us('Cannot get runtime info, controller response result is empty."',Lo.EmptyResponse);if(e.Status!=ce.OK)throw new us(`Cannot get runtime info, controller responded with status ${e.Status}.`,Lo.WrongResponseStatus);if(null==e.Data)throw new us("Cannot get runtime info, controller responded with status OK but response does not contains data.",Lo.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof E?new us("Cannot get runtime info, controller response timeout.",Lo.Timeout):e}}))}GetHardwareInfoAsync(){return rs(this,arguments,void 0,(function*(e=!1){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return rs(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(os.ServiceName,"Getting hardware info from controller.");const t=yield Qv.Get(_t.ServiceName).SendAndWaitForResponseAsync(new cs,8e3,!1);if(null==t||null==t.Status)throw new us('Cannot get hardware info, controller response result is empty."',Lo.EmptyResponse);if(t.Status!=ce.OK)throw new us(`Cannot get hardware info, controller responded with status ${t.Status}.`,Lo.WrongResponseStatus);if(null==t.Data)throw new us("Cannot get hardware info, controller responded with status OK but response does not contains data.",Lo.NoDataInResponse);this._hardwareInfo=t.Data,this._isRuntimeInfoInitialized=!0}))}}os.ServiceName="UpdateProvider";class ss{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class is extends ae{constructor(){super(),this.Resource="/controller/software/info",this.Method=ue.Get}}class as{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class cs extends ae{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ue.Get}}class us extends Error{constructor(e,t){super(e),this.message=e,this.code=0,this.name="CannotGetRuntimeInfo",this.code=t}}!function(e){e[e.Unknown=0]="Unknown",e[e.EmptyResponse=1]="EmptyResponse",e[e.NoDataInResponse=2]="NoDataInResponse",e[e.WrongResponseStatus=3]="WrongResponseStatus",e[e.Timeout=4]="Timeout"}(Lo||(Lo={})),function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(Bo||(Bo={}));class ls{constructor(){this._comparisonParams=new Map,this.Type=bt.Unknown,this.DeviceGuid="",this.ComparisonMethod=Wo.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Hn&&(this.Type=bt.BatteryState),e instanceof gr&&(this.Type=bt.BinarySensorState),e instanceof Pn&&(this.Type=bt.BlindPosition),e instanceof Wn&&(this.Type=bt.LightBrightness),e instanceof jn&&(this.Type=bt.MeasuredBrightness),e instanceof Un&&(this.Type=bt.RemoteButtonState),e instanceof Cn&&(this.Type=bt.ChannelOnOffState),e instanceof In&&(this.Type=bt.DoorBellState),e instanceof Jn&&(this.Type=bt.MeasuredEnergy),e instanceof kr&&(this.Type=bt.FloodSensorState),e instanceof sr&&(this.Type=bt.GatePosition),e instanceof xn&&(this.Type=bt.LightColor),e instanceof Ln&&(this.Type=bt.LightWarmth),e instanceof Nn&&(this.Type=bt.ReedState),e instanceof qn&&(this.Type=bt.MeasuredTemperature),e instanceof lr&&(this.Type=bt.HumiditySensorState),e instanceof er&&(this.Type=bt.BlindRemoteButtonState),e instanceof nr&&(this.Type=bt.FacadeRemoteButtonState),e instanceof Qn&&(this.Type=bt.MovementSensorState),e instanceof Jn&&(this.Type=bt.MeasuredEnergy),e instanceof br&&(this.Type=bt.PressureSensorState),e instanceof Tr&&(this.Type=bt.WindSpeedState),e instanceof Ar&&(this.Type=bt.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class ds{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class hs{constructor(...e){this._value="00:00:00",e.length>1?this.SetTimeSpan(e[0],e[1],e[2],e[3]):this._value=e[0]}SetTimeSpan(e,t,n,r){this._value=r<=0?`${n.toString().padStart(2,"0")}:${t.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`:`${r}.${n.toString().padStart(2,"0")}:${t.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`}get Value(){return this._value}}!function(e){e[e.Default=0]="Default",e[e.Delta=1]="Delta",e[e.StateRepeat=2]="StateRepeat"}(Wo||(Wo={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}($o||($o={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(qo||(qo={}));class gs{constructor(){this.DeviceGuid=""}}!function(e){e[e.Unknown=-1]="Unknown",e[e.DeviceTask=0]="DeviceTask",e[e.DelayTask=1]="DelayTask",e[e.NotifyTask=2]="NotifyTask",e[e.LockExecution=3]="LockExecution"}(Vo||(Vo={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(Ho||(Ho={})),(ns=Ko||(Ko={}))[ns.Unknown=0]="Unknown",ns[ns.Second=1]="Second",ns[ns.Minute=2]="Minute",ns[ns.Hour=3]="Hour",ns[ns.Day=4]="Day",ns[ns.DayOfWeek=5]="DayOfWeek",ns[ns.Month=6]="Month",ns[ns.Year=7]="Year",ns[ns.Date=8]="Date",ns[ns.Time=9]="Time",ns[ns.WeatherType=11]="WeatherType",ns[ns.CompareNumbers=12]="CompareNumbers",ns[ns.CompareBooleans=13]="CompareBooleans",ns[ns.DeviceState=14]="DeviceState",ns[ns.Timer=15]="Timer",ns[ns.Temperature=17]="Temperature",ns[ns.DaysOfWeek=18]="DaysOfWeek",ns[ns.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",ns[ns.SceneExecuted=20]="SceneExecuted",(ts=jo||(jo={}))[ts.Unknown=0]="Unknown",ts[ts.Equal=1]="Equal",ts[ts.NotEqueal=2]="NotEqueal",ts[ts.BiggerThan=3]="BiggerThan",ts[ts.SmallerThan=4]="SmallerThan",ts[ts.BiggerThanOrEqual=5]="BiggerThanOrEqual",ts[ts.SmallerThanOrEqual=6]="SmallerThanOrEqual",ts[ts.OneOfBothIsTrue=7]="OneOfBothIsTrue",ts[ts.BothAreTrue=8]="BothAreTrue",function(e){e[e.Unknown=0]="Unknown",e[e.BatteryState=1]="BatteryState",e[e.BinarySensor=2]="BinarySensor",e[e.BlindPosition=3]="BlindPosition",e[e.Brightness=4]="Brightness",e[e.ButtonState=5]="ButtonState",e[e.ChannelOnOff=6]="ChannelOnOff",e[e.DoorBell=7]="DoorBell",e[e.Energy=8]="Energy",e[e.FloodSensor=9]="FloodSensor",e[e.GatePosition=10]="GatePosition",e[e.HeatSensor=11]="HeatSensor",e[e.LightBrightness=12]="LightBrightness",e[e.LightColor=13]="LightColor",e[e.LightTemperature=14]="LightTemperature",e[e.MeasuredCurrent=15]="MeasuredCurrent",e[e.MeasuredPower=16]="MeasuredPower",e[e.MeasuredVoltage=17]="MeasuredVoltage",e[e.ReedState=18]="ReedState",e[e.SmokeSensor=19]="SmokeSensor",e[e.Temperature=20]="Temperature",e[e.BlindsControlButton=21]="BlindsControlButton",e[e.Movement=22]="Movement",e[e.WindSpeed=24]="WindSpeed",e[e.Humidity=25]="Humidity",e[e.AirPressure=26]="AirPressure",e[e.WindThreshold=31]="WindThreshold",e[e.FacadeControlButton=36]="FacadeControlButton"}(zo||(zo={})),function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(Jo||(Jo={})),(es=Xo||(Xo={})).Null="Null",es.Condition="Condition",es.ConditionGroup="ConditionGroup",es.ArgumentAsInt="ArgumentAsInt",es.ArgumentAsTimeSpan="ArgumentAsTimeSpan",es.ArgumentAsBoolean="ArgumentAsBoolean",es.ArgumentAsTimeout="ArgumentAsTimeout",es.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",es.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",es.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",es.ArgumentAsTime="ArgumentAsTime",es.ArgumentAsDeviceState="ArgumentAsDeviceState",es.ArgumentAsNumber="ArgumentAsNumber",es.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",es.ArgumentAsConditionInfo="ArgumentAsConditionInfo",function(e){e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.LockExecutionTask="LockExecutionTask",e.NotifyTaskAppNotify="NotifyTaskAppNotify",e.NotifyTaskEmailNotify="NotifyTaskEmailNotify"}(Yo||(Yo={}));class ps extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedScenesDeviceState"}}!function(e){e[e.None=0]="None",e[e.AppNotification=1]="AppNotification",e[e.Email=2]="Email"}(Qo||(Qo={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(Zo||(Zo={}));var fs,vs,ys;class ms{constructor(e,t="Cube"){this._result=null,this._tmp=new ws,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=Qv.Get(Ms.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Hr.NewGuid())}SetSequenceName(e){const t=n=>{if(n.RightArgumentType!=ys.Null)return t(n.RightArgument);n.Tasks.ControllerTasks.where((e=>e.TaskType==Vo.NotifyTask)).toArray().forEach((t=>{t.Title=e}))};this._sequenceName=e,this._editingExistingSequence&&null!=this._result&&(this._result.Name=e,t(this._result))}SetSequenceIcon(e){this._sequenceIcon=e,this._editingExistingSequence&&null!=this._result&&(this._result.Icon=e)}GetNext(){if(null==this._result)return null;if(""==this._currentSeqGuid)return this._currentSeqGuid=this._result.Guid,this._service.MapSequence(JSON.parse(JSON.stringify(this._result)),!0);{const e=this.FindArgumentWithGuid(this._result,this._currentSeqGuid);return null==e?null:e.RightArgumentType==ys.Condition?(this._prevSeqGuid=this._currentSeqGuid,this._currentSeqGuid=e.RightArgument.Guid,this._service.MapSequence(JSON.parse(JSON.stringify(e.RightArgument)),!0)):null}}CloneCurrentBuilder(){var e=new ms;return e._currentSeqGuid="",e._prevSeqGuid="",e._editingExistingSequence=structuredClone(this._editingExistingSequence),e._rawExistingSequenceTasks=structuredClone(this._rawExistingSequenceTasks),e._result=structuredClone(this._result),e._sequenceIcon=structuredClone(this._sequenceIcon),e._sequenceName=structuredClone(this._sequenceName),e._tmp=structuredClone(this._tmp),(e=>{const t=e=>{e.Guid=Hr.NewGuid(),e.RightArgumentType==ys.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Hr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==ys.Condition?(e=n.Guid,t(n.RightArgument,r)):null;if(null==this._result)return null;if(""==this._currentSeqGuid||""==this._prevSeqGuid)return null;const n=t(this._result,this._prevSeqGuid);return null==n?null:(this._currentSeqGuid=n.sequence.Guid,this._prevSeqGuid=n.prevGuid,this._service.MapSequence(JSON.parse(JSON.stringify(n.sequence)),!0))}GetByGuid(e){if(null==this._result)return null;const t=this.FindArgumentWithGuid(this._result,e);return null==t?null:this._service.MapSequence(t)}EditCurrentSequence(e){const t=e=>{if(e.RightArgumentType!=ys.Null)return t(e.RightArgument);this._rawExistingSequenceTasks=JSON.parse(JSON.stringify(e.Tasks))};return this._editingExistingSequence=!0,t(e._rawRequestData),Object.hasOwn(e._rawRequestData,"Condition")?this._result=e._rawRequestData.Condition:this._result=e._rawRequestData,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequence:e=>this.RemoveSequenceByGuid(e),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),RemoveTask:e=>this.RemoveTask(e)}}ArgumentAsAstronomicalClockWithOffset(e,t,n){if(this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=ys.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=jo.Equal)throw new Is("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new Is("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=jo.Equal;else{if(null==n)throw new Is("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.Unknown,this._tmp.LeftArgumentType=ys.Null,this._tmp.ConditionType=jo.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=ys.Null,this._tmp.Name=this._sequenceName,this._tmp.Icon=this._sequenceIcon,this._tmp.AtMeetCondition=!1,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDaysOfWeek(e,t,n=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.DaysOfWeek,this._tmp.LeftArgumentType=ys.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.Timer,this._tmp.LeftArgumentType=ys.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.Time,this._tmp.LeftArgumentType=ys.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ys.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=jo.Equal){return this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.DeviceState,this._tmp.LeftArgumentType=ys.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=ys.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Hr.NewGuid(),this._tmp.HandledType=Ko.SceneExecuted,this._tmp.LeftArgumentType=ys.ArgumentAsConditionInfo,this._tmp.ConditionType=jo.Equal,this._tmp.AtMeetCondition=!0;const t=new gs;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=ys.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new _s;t.Channel=e.GetCheckDeviceState().Channel,t.ComparisonMethod=e.ComparisonMethod;let n={},r=e.GetComparisonParams().entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[$o[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case bt.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case bt.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case bt.LightBrightness:case bt.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case bt.RemoteButtonState:case bt.ChannelOnOffState:case bt.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[Yt[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case bt.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case bt.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case bt.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case bt.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.SmokeSensorState:throw new ps("Unsupported device state!");case bt.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case bt.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case bt.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.LightRGBWState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B,t.CheckedDeviceState.W=n.W;break}case bt.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case bt.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case bt.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case bt.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case bt.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case bt.Unknown:t.CheckedDeviceState={};break;default:throw new ps("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case bt.BatteryState:return zo.BatteryState;case bt.BinarySensorState:return zo.BinarySensor;case bt.BlindPosition:return zo.BlindPosition;case bt.LightBrightness:return zo.LightBrightness;case bt.RemoteButtonState:return zo.ButtonState;case bt.ChannelOnOffState:return zo.ChannelOnOff;case bt.DoorBellState:return zo.DoorBell;case bt.MeasuredEnergy:return zo.Energy;case bt.FloodSensorState:return zo.FloodSensor;case bt.GatePosition:return zo.GatePosition;case bt.MeasuredBrightness:return zo.Brightness;case bt.LightColor:return zo.LightColor;case bt.LightWarmth:return zo.LightTemperature;case bt.ReedState:return zo.ReedState;case bt.SmokeSensorState:return zo.SmokeSensor;case bt.MeasuredTemperature:return zo.Temperature;case bt.HumiditySensorState:return zo.Humidity;case bt.BlindRemoteButtonState:return zo.BlindsControlButton;case bt.FacadeRemoteButtonState:return zo.FacadeControlButton;case bt.MovementSensorState:return zo.Movement;case bt.PressureSensorState:return zo.AirPressure;case bt.WindSpeedState:return zo.WindSpeed;case bt.CurrentWindThreshold:return zo.WindThreshold;default:return zo.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=ys.Null)return e(t.RightArgument,n);t.RightArgumentType=ys.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Cs)};null==this._result?(this._tmp.Name=this._sequenceName,this._tmp.Icon=this._sequenceIcon,this._result=this._tmp,this._result.AtMeetCondition=!0):e(this._result,this._tmp);const t=this._service.MapSequence(JSON.parse(JSON.stringify(this._tmp)));return this._tmp=new ws,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),SequenceData:t}}EditSequence(e){const t=(n,r)=>{if(n.Guid!=e||n.ObjectType!=ys.Condition){if(n.RightArgumentType==ys.Condition)return t(n.RightArgument,r);throw new Gs(`Cannot edit sequence with given GUID ${e} - sequence not foud in chain`)}n.AtMeetCondition=r.AtMeetCondition,n.ConditionTimeout=r.ConditionTimeout,n.ConditionType=r.ConditionType,n.ExecuteOnce=r.ExecuteOnce,n.HandledType=r.HandledType,n.IsDisabled=r.IsDisabled,n.LeftArgument=r.LeftArgument,n.LeftArgumentType=r.LeftArgumentType,n.ObjectType=r.ObjectType,n.Tasks=r.Tasks,r.Guid=n.Guid,r.Icon=n.Icon,r.Name=n.Name};if(null==this._result)throw new Gs(`Cannot edit sequence with given GUID ${e} - sequence not initialized (no root element)`);t(this._result,this._tmp);const n=this._service.MapSequence(JSON.parse(JSON.stringify(this._tmp)));return this._tmp=new ws,console.log(`new tmp guid: ${this._tmp.Guid}`),this._result.AtMeetCondition||(this._result.AtMeetCondition=!0),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),SequenceData:n}}RemoveSequenceByGuid(e){let t;const n=(e,n)=>{""==this._currentSeqGuid&&""==this._prevSeqGuid||(this._currentSeqGuid==n?(this._currentSeqGuid=e.RightArgumentType==ys.Condition?e.RightArgument.Guid:"",this._prevSeqGuid=null!=t?t.Guid:""):this._prevSeqGuid==n&&(this._prevSeqGuid=null!=t?t.Guid:""))},r=(e,o)=>{if(e.Guid!=o){if(t=e,e.RightArgumentType==ys.Null)throw new Gs(`Cannot remove sequence, sequence with given guid ${o} not found!`);return r(e.RightArgument,o)}null==t?this._result=null:(t.RightArgument=e.RightArgument,t.RightArgumentType=e.RightArgumentType),n(e,o)};if(null==this._result)throw new Gs("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=ys.Null?(this._result.RightArgument.Name=this._result.Name,this._result.RightArgument.Icon=this._result.Icon,this._result.RightArgument.Guid=this._result.Guid,this._result=this._result.RightArgument,this._result.AtMeetCondition=!0,n(this._result,e)):r(this._result,e),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=jo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=jo.Equal)=>this.ArgumentAsTime(e,t,n),ArgumentAsTimeSpan:(e,t)=>this.ArgumentAsTimeSpan(e,t),ArgumentAsSceneExecuted:e=>this.ArgumentAsSceneExecuted(e),SequenceData:null}}Commit(){const e=t=>{if(t.RightArgumentType!=ys.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new Gs("Sequence are not initialized! Not found root sequence.");return this._editingExistingSequence&&e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}DeviceTask(e){if(this._tmpTask=this.ParseDeviceTask(e),null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(this._tmpTask))}}ParseDeviceTask(e){const t=new Ds;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==Et.SetBlindPosition||e instanceof to?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==Et.SetBlindPositionSimple||e instanceof ro?(t.Data.Action=e.Action,t.Data.Position=0):e.TaskType==Et.SetLightColor||e instanceof Zr?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==Et.SetLightTemperature||e instanceof eo?t.Data.Temperature=e.Temperature:e.TaskType==Et.SetLightBrightness||e instanceof Yr?t.Data.Brightness=e.Brightness:e.TaskType==Et.SetTemperature||e instanceof jr?t.Data.Temperature=e.Temperature:e.TaskType==Et.TurnOnWithTime||e instanceof Xr?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==Et.SetLightBrightnessDynamicly||e instanceof oo?t.Data.Brightness=e.Brightness:e.TaskType==Et.SetBlindOpenCloseTime||e instanceof io?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==Et.SetBlindMicroventilation||e instanceof uo?t.Data.Position=e.Position:e.TaskType==Et.SetFacadePosition||e instanceof go?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):e.TaskType==Et.LightRGBW||e instanceof vo?(t.Data.R=e.Data.R,t.Data.G=e.Data.G,t.Data.B=e.Data.B,t.Data.W=e.Data.W,t.Data.Brightness=e.Data.Brightness):(e.TaskType==Et.PreciseGateControl||e instanceof no)&&(t.Data.Position=e.Position,t.Data.GateControlAction=e.GateControlAction),t}DelayTask(e){const t=new ks;if("00:00:00"==e.Delay.Value)throw new Is("Delay must be other than 00:00:00!");if(t.Delay=e.Delay.Value,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(t))}}NotifyTask(e){if(e.NotifyType==Qo.Email)throw new Rs("NotifyType 'Email' is not supported!");if(e.NotifyType==Qo.None)throw new Error("NotifyType mus be set!");if(""==e.Message)throw new Is("Message must be set!");if(e.Message.length>1e3)throw new Is("Message is too long! Max length is 1000 characters.");const t=new bs;if(t.NotifyType=e.NotifyType,t.Message=e.Message,t.NotificationClients=e.NotificationClients,t.Title=this._sequenceName,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(t))}}LockExecutionTask(e){const t=new Es;if(t.LockType=e.LockType,t.LockType==Zo.Timeout&&"00:00:00"!=t.LockEndHour)throw new Rs("Parameter LockEndHour at lock type `Timeout` must be default!");if(t.LockStartHour=e.LockStartHour.Value,t.LockEndHour=e.LockEndHour.Value,t.ResetLockScenesGuids=e.ResetLockScenesGuids,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:oe.GenerateMd5(JSON.stringify(t))}}AddTask(){const e=t=>{var n;if(t.RightArgumentType!=ys.Null)return e(t.RightArgument);if(null==this._tmpTask)throw Error("No task context!");void 0!==t.Tasks.DevicesTasks&&null!==t.Tasks.DevicesTasks||(t.Tasks.DevicesTasks=[]),this._tmpTask instanceof Ds&&t.Tasks.DevicesTasks.push(structuredClone(this._tmpTask)),t.Tasks.ControllerTasks.push(structuredClone(this._tmpTask)),this._tmpTask=null,null===(n=u.Log)||void 0===n||n.Debug(`Task added to sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(t.Tasks)}`)};if(null==this._result)throw new Error("No context!");return e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}EditTask(e){const t=n=>{var r;if(n.RightArgumentType!=ys.Null)return t(n.RightArgument);if(null==this._tmpTask)throw Error("No task context!");if(null==n.Tasks.ControllerTasks||0==n.Tasks.ControllerTasks.length)throw new Ns("Task not found, cannot edit!");this._tmpTask instanceof Ds&&null!=n.Tasks.DevicesTasks&&(n.Tasks.DevicesTasks=n.Tasks.DevicesTasks.map((t=>oe.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t))),n.Tasks.ControllerTasks=n.Tasks.ControllerTasks.map((t=>oe.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t)),this._tmpTask=null,null===(r=u.Log)||void 0===r||r.Debug(`Task edited in sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(n.Tasks)}`)};if(null==this._result)throw new Error("No context!");return t(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}RemoveTask(e){const t=(e,n)=>{var r,o;if(e.RightArgumentType!=ys.Null)return t(e.RightArgument,n);{const t=e.Tasks.ControllerTasks.filter((e=>oe.GenerateMd5(JSON.stringify(e))!=n));if(e.Tasks.ControllerTasks=null==t?[]:t,null===(o=null===(r=e.Tasks)||void 0===r?void 0:r.DevicesTasks)||void 0===o?void 0:o.any()){const t=e.Tasks.DevicesTasks.filter((e=>oe.GenerateMd5(JSON.stringify(e))!=n));e.Tasks.DevicesTasks=null==t?[]:t}}};if(null==this._result)throw Error("Cannot remove task, sequence not configured!");t(this._result,e)}MapTaskTypeToControlFeature(e){switch(e){case Et.Unknown:throw new Is("Unsupported task type!");case Et.SetBlindPosition:case Et.SetBlindPositionSimple:return Ur.SetBlindPosition;case Et.SetBlindMicroventilation:return Ur.SetBlindMicroventilation;case Et.TurnOff:return Ur.TurnOff;case Et.TurnOn:return Ur.TurnOn;case Et.TurnOnWithTime:return Ur.TurnOnWithTimeout;case Et.TogleState:return Ur.ToggleState;case Et.SetLightBrightnessDynamicly:return Ur.SetLightBrightnessDynamicly;case Et.SetLightBrightness:return Ur.SetLightBrightness;case Et.SetLightColor:return Ur.SetLightColor;case Et.SetLightTemperature:return Ur.SetLightTemperature;case Et.PairDevice:case Et.UnpairDevice:throw new Is("Unsupported task type!");case Et.IdentifyDevice:return Ur.IdentifyDevice;case Et.GetChannelsState:return Ur.GetState;case Et.GetPowerMeasurements:case Et.GetAvailableData:case Et.MultipleDataRequest:throw new Is("Unsupported task type!");case Et.SetBlindOpenCloseTime:return Ur.SetBlindOpenCloseTime;case Et.SetTemperature:return Ur.SetTemperature;case Et.ChangeGatePositionPulse:return Ur.GatePulse;case Et.ChangeGatewayPositionPulse:return Ur.GatewayPulse;case Et.SetFacadePosition:case Et.GetFacadeType:return Ur.SetFacadePositionAndTilt;case Et.LightRGBW:return Ur.LightRGBW;case Et.PreciseGateControl:return Ur.SetGatePositionPrecise;default:throw new Is("Unsupported task type!")}}GetSupportedTaskTypesAsync(){return e=this,t=void 0,r=function*(){const e=yield Qv.Get(os.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Yo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Yo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Yo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Yo.NotifyTaskAppNotify),r},new((n=void 0)||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}));var e,t,n,r}Build(){const e=t=>{if(t.RightArgumentType!=ys.Null)return e(t.RightArgument);t.Tasks.ControllerTasks=t.Tasks.ControllerTasks.map((e=>(Object.hasOwn(e,"_taskGuid")&&delete e._taskGuid,e)))};if(null!=this._result)return e(this._result),this._result;throw Error("Cannot build sequence, sequence not configured!")}FindArgumentWithGuid(e,t){return e.Guid==t?e:e.RightArgumentType==ys.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}GetAllowedArguments(){const e=[];return null==this._result?(e.push({ArgumentType:vs.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:vs.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1})):null!=this._result&&(null==this._result.RightArgument||this._result.RightArgument instanceof Ss)&&(this._result.LeftArgumentType==ys.ArgumentAsDaysOfWeek&&(e.push({ArgumentType:vs.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),e.push({ArgumentType:vs.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0})),this._result.LeftArgumentType==ys.ArgumentAsTime&&e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1}),this._result.LeftArgumentType==ys.ArgumentAsAstronomicalClockWithOffset&&e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1})),0==e.any((e=>e.ArgumentType==vs.ArgumentAsAstronomicalClockWithOffset))&&e.push({ArgumentType:vs.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsDaysOfWeek))&&e.push({ArgumentType:vs.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsDeviceState))&&e.push({ArgumentType:vs.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsSceneExecuted))&&e.push({ArgumentType:vs.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsTime))&&e.push({ArgumentType:vs.ArgumentAsTime,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==vs.ArgumentAsTimeSpan))&&e.push({ArgumentType:vs.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e}ValidateScene(){var e,t,n,r;if(null==this._result)throw new Error("No context!");const o=[],s=(e,t,n)=>e.RightArgumentType==ys.Null?e.LeftArgumentType==t&&e.AtMeetCondition==n?e:null:e.LeftArgumentType==t&&e.AtMeetCondition==n?e:s(e.RightArgument,t,n),i=s(this._result,ys.ArgumentAsDaysOfWeek,!0);null!=i&&((null===(e=i.RightArgument)||void 0===e?void 0:e.LeftArgumentType)==ys.ArgumentAsTime||(null===(t=i.RightArgument)||void 0===t?void 0:t.LeftArgumentType)==ys.ArgumentAsAstronomicalClockWithOffset)&&o.push(fs.OptimizeDayOfWeekArgument);const a=s(this._result,ys.ArgumentAsTime,!0);return null!=a&&(null===(n=a.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ys.ArgumentAsDaysOfWeek&&(null===(r=a.RightArgument)||void 0===r?void 0:r.AtMeetCondition)&&o.push(fs.OptimizeAtInDayOfWeekArgument),{IsValid:0==o.length,Errors:o,TryFix:()=>this.TryFix(o),Ignore:()=>this.Commit()}}TryFix(e){if(null==this._result)throw new Error("No context!");if(e.includes(fs.OptimizeDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ys.ArgumentAsDaysOfWeek?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ys.ArgumentAsTime||(null===(r=t.RightArgument)||void 0===r?void 0:r.LeftArgumentType)==ys.ArgumentAsAstronomicalClockWithOffset?t:e(t.RightArgument):t.RightArgumentType==ys.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)throw new Error("Something wrong! Cannot find 'days of week' argument! Cannot fix!");const n=structuredClone(t),r=t.RightArgument;t.LeftArgument=r.LeftArgument,t.LeftArgumentType=r.LeftArgumentType,t.HandledType=r.HandledType,r.LeftArgument=n.LeftArgument,r.LeftArgumentType=n.LeftArgumentType,r.HandledType=n.HandledType,r.AtMeetCondition=!1}if(e.includes(fs.OptimizeAtInDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ys.ArgumentAsTime?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ys.ArgumentAsDaysOfWeek&&(null===(r=t.RightArgument)||void 0===r?void 0:r.AtMeetCondition)?t:e(t.RightArgument):t.RightArgumentType==ys.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)throw new Error("Something wrong! Cannot find 'time' argument! Cannot fix!");t.RightArgument.AtMeetCondition=!1}return this.Commit()}}!function(e){e.OptimizeDayOfWeekArgument="OptimizeDayOfWeekArgument",e.OptimizeAtInDayOfWeekArgument="OptimizeAtInDayOfWeekArgument"}(fs||(fs={})),function(e){e.Unknown="Unknown",e.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",e.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",e.ArgumentAsTimeSpan="ArgumentAsTimeSpan",e.ArgumentAsTime="ArgumentAsTime",e.ArgumentAsDeviceState="ArgumentAsDeviceState",e.ArgumentAsSceneExecuted="ArgumentAsSceneExecuted"}(vs||(vs={}));class ws{constructor(){this.Tasks=new Cs,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=Ko.Unknown,this.ConditionType=jo.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=ys.Null,this.RightArgumentType=ys.Null,this.LeftArgument=new As({},ys.Null),this.RightArgument=new Ss}}class Ss{constructor(){this.HandledType=0,this.Argument=null}}class As{constructor(e,t){this.Argument=e,this.HandledType=t}}class _s{constructor(){this.DeviceStateType=zo.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=Wo.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Cs{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Ts{constructor(){this.Guid=Hr.NewGuid(),this.RunParallel=!1,this.TaskType=Vo.Unknown}}class Ds extends Ts{constructor(){super(...arguments),this.TaskType=Vo.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=Ur.TurnOn}}class ks extends Ts{constructor(){super(...arguments),this.TaskType=Vo.DelayTask,this.Delay="00:00:00"}}class Es extends Ts{constructor(){super(...arguments),this.TaskType=Vo.LockExecution,this.LockType=Zo.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}class bs extends Ts{constructor(){super(...arguments),this.TaskType=Vo.NotifyTask,this.Title="",this.Message="",this.NotifyType=Qo.None,this.NotificationClients=[]}}!function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(ys||(ys={}));class Is extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class Gs extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class Ns extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class Rs extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var Ps,Os,Us=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ms{constructor(){this._connection=Qv.Get(_t.ServiceName),this._configurationService=Qv.Get(it.ServiceName)}GetServiceName(){return Ms.ServiceName}GetSequencesListAsync(){return Us(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new xs,12e3,!1);return null===(t=u.Log)||void 0===t||t.Debug(`GetSequencesListAsync result:\n ${JSON.stringify(n)}}`),null==n?new Ee(Bo.OtherError,"Cannot get sequences list - response is null."):n.Status!=ce.OK?new Ee(Bo.OtherError,`Cannot get sequences list - controller responded with response code ${n.Status}.`):null==n.Data?new Ee(Bo.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):n.Data}))}GetSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Fs(n),12e3,!1);if(null==r)return new Ee(Bo.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ce.OK)return new Ee(Bo.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Ee(Bo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");const o=r.Data;let s=this.MapSequence(o);if("string"==typeof e){let e=yield this.GetSequencesListAsync();if(e instanceof Ee){let t=e;console.warn(`Cannot get sequence - response is null. Error: ${t.Data} ${t.Type}`)}else{const t=e.find((e=>e.Guid==n));if(!t)return new Ee(Bo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");s.IsDisabled=t.IsDisabled}}else{const e=o;s.IsDisabled=e.IsDisabled}return s}))}GetSequenceBuilder(e,t){return new ms(e,t)}CreateSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t,n,r,o;try{yield this._configurationService.EnterConfigurationModeAsync(),null===(t=u.Log)||void 0===t||t.Debug(`Creating sequence ${e.Name} json: \n${JSON.stringify(e)}`);const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new $s(e),2e4,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(t){return null===(r=u.Log)||void 0===r||r.Error(`Creating sequence ${e.Name} error: ${t}`),ce.FatalError}finally{null===(o=u.Log)||void 0===o||o.Error(Ms.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! CreateSequenceAsync()"),yield this._configurationService.ExitConfigurationModeAsync(),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(!0)}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;try{let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ls(n),12e3,!1);if(null==r)return new Ee(Bo.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ce.WrongData:return new Ee(Bo.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ce.OK:return null==r.Data?new Ee(Bo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Ee(Bo.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Ee(Bo.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;try{let n="";n="string"==typeof e?e:e.Guid,yield this._configurationService.EnterConfigurationModeAsync();const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Vs(n),12e3,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(e){return ce.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(!0)}}))}EditSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t,n;try{const n={Guid:e.Guid,Icon:e.Icon,Name:e.Name,Condition:e};var r=n.Condition.IsDisabled;n.Condition.IsDisabled=!1,yield this._configurationService.EnterConfigurationModeAsync();const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new qs(n),2e4,!1);return n.Condition.IsDisabled=r,null==o||null==o.Status?ce.Error:o.Status}catch(t){return null===(n=u.Log)||void 0===n||n.Error(`Editing sequence ${e.Name} error: ${t}`),ce.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(!0)}}))}EnableSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Hs(n),12e3,!1);return yield this._configurationService.ExitConfigurationModeAsync(),null==r||null==r.Status?ce.Error:r.Status}))}DisableSequenceAsync(e){return Us(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ks(n),12e3,!1);return yield this._configurationService.ExitConfigurationModeAsync(),null==r||null==r.Status?ce.Error:r.Status}))}RunSequenceAsync(e){return Us(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ce.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ce.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new Jr;switch(n.Channel=1,n.DeviceGuid=t,yield Qv.Get(Ys.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case Pt.Executed:return ce.OK;case Pt.DeviceNotFound:return ce.WrongData;default:return ce.Error}}))}GetUtilsAsync(){return Us(this,void 0,void 0,(function*(){const e=yield this.SunCalculatorAsync();return{GetSunRiseTime:e.GetSunRiseTime,GetSunSetTime:e.GetSunSetTime,ParseLinearScaleToLux:this._parseLinearScaleToLux,ParseLuxToLinearScale:this._parseLuxToLinearScale}}))}_parseLinearScaleToLux(e){if(!(e<0||e>1))return Math.round(Math.pow(10,5*e))}_parseLuxToLinearScale(e){if(e<=0)return 0;const t=Math.log10(e)/5;return t>1?1:t}SunCalculatorAsync(){return Us(this,void 0,void 0,(function*(){var e;const t=Qv.Get(Ro.ServiceName),n=new Eo;let r=!1;n.Latitude=49.9958888026741,n.Longitude=18.9172596008914;try{if(yield t.IsControllerGeolocationSetAsync()){const e=yield t.GetControlllerGeolocationAsync();e instanceof bo&&(n.Latitude=e.Latitude,n.Longitude=e.Longitude)}}catch(t){null===(e=u.Log)||void 0===e||e.Warning(`Cannot get localization data, using default values: 49.9958888026741, 18.9172596008914. Error: ${t}`)}const o=e=>{let t=7.95204*Math.sin(.01768*e+3.03217)+9.98906*Math.sin(.03383*e+3.4687)+4*(n.Longitude-15*Math.round(n.Longitude/15));return((e=new Date)=>{const t=new Date(e.getFullYear(),0,1).getTimezoneOffset(),n=new Date(e.getFullYear(),6,1).getTimezoneOffset();return Math.max(t,n)!==e.getTimezoneOffset()})()&&(t-=60),t},s=e=>Math.asin(-.39795*Math.cos(2*Math.PI*(e+10)/365)),i=e=>{const t=n.Latitude*Math.PI/180;let r=Math.sin(t)*Math.sin(e)/(Math.cos(t)*Math.cos(e));return r=(e=>(e<-1&&(e=-1),e>1&&(e=1),e))(r),r},a=e=>{const t=Math.ceil(e/60),n=e-60*t,r=new Date;return new Date(r.getFullYear(),r.getMonth(),r.getDate(),t,n)},c=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(u=t,Math.floor((u.valueOf()-new Date(u.getFullYear(),0,0).valueOf())/1e3/60/60/24));var u;const l=o(n),d=s(n),h=((e,t)=>{let n=720-720/Math.PI*Math.acos(-e)-t;return n<0&&(n+=1440),n})(i(d),l),g=a(h);return new Date>g&&!r?(r=!0,c(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))},l=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(c=t,Math.floor((c.valueOf()-new Date(c.getFullYear(),0,0).valueOf())/1e3/60/60/24));var c;const u=o(n),d=s(n),h=i(d),g=Math.floor(((e,t)=>{let n=720+720/Math.PI*Math.acos(-e)-t;return n>1439&&(n-=1439),n})(h,u)),p=a(g);return new Date>p&&!r?(r=!0,l(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>l(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=Ps.Null)return!Object.hasOwn(e.Tasks,"ControllerTasks")&&Object.hasOwn(e.Tasks,"DevicesTasks")&&delete Object.assign(e.Tasks,{ControllerTasks:e.Tasks.DevicesTasks}).DevicesTasks,r(e.RightArgument);!Object.hasOwn(e.Tasks,"ControllerTasks")&&Object.hasOwn(e.Tasks,"DevicesTasks")&&(delete Object.assign(e.Tasks,{ControllerTasks:e.Tasks.DevicesTasks}).DevicesTasks,e.Tasks.ControllerTasks.map((e=>{e.TaskType=Vo.DeviceTask,e.RunParallel=!1}))),null!=e.Tasks.ControllerTasks&&e.Tasks.ControllerTasks.map((e=>{null==(null==e?void 0:e.Guid)&&(e.Guid=Hr.NewGuid())}))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=Xo.Null):(n.RightArgumentType=this.MapArgumentType(e.RightArgumentType),n.RightArgument=this.MapRightArgument(e.RightArgument,n.RightArgumentType)),n.LeftArgumentType=this.MapArgumentType(e.LeftArgumentType),n.LeftArgument=this.MapLeftArgument(e.LeftArgument,n.LeftArgumentType),n.Tasks.ControllerTasks=this.MapControllerTasks(e.Tasks.ControllerTasks),void 0===n.DoesHaveTriggers&&(n.DoesHaveTriggers=n.LeftArgumentType==Xo.Null),n}MapRightArgument(e,t){return 0==e.HandledType||(e.LeftArgumentType=this.MapArgumentType(e.LeftArgumentType),e.LeftArgument=this.MapLeftArgument(e.LeftArgument,e.LeftArgumentType),e.Tasks.ControllerTasks=this.MapControllerTasks(e.Tasks.ControllerTasks),Object.hasOwn(e.Tasks,"DevicesTasks")&&delete e.Tasks.DevicesTasks,t===Xo.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new Bs;switch(n.HandledType=e.HandledType,t){case Xo.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case Xo.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case Xo.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case Xo.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case Xo.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case Xo.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case Xo.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case Xo.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case Xo.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case Xo.ArgumentAsDeviceState:{const t=new ls;t.Type=this.MapDeviceStateTypeToResponseType(e.Argument.DeviceStateType),t.SetCheckDeviceState(this.CreateDeviceState(e.Argument.CheckedDeviceState,e.Argument.Channel,t.Type)),t.DeviceGuid=e.Argument.DeviceGuid,t.ComparisonMethod=null==e.Argument.ComparisonMethod?Wo.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam($o[e[0]],new ds(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam($o[e[0]],new hs(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case Xo.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return Xo[Ps[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case zo.BatteryState:return bt.BatteryState;case zo.BinarySensor:return bt.BinarySensorState;case zo.BlindPosition:return bt.BlindPosition;case zo.Brightness:return bt.MeasuredBrightness;case zo.ButtonState:return bt.RemoteButtonState;case zo.ChannelOnOff:return bt.ChannelOnOffState;case zo.DoorBell:return bt.DoorBellState;case zo.Energy:return bt.MeasuredEnergy;case zo.FloodSensor:return bt.FloodSensorState;case zo.GatePosition:return bt.GatePosition;case zo.LightBrightness:return bt.LightBrightness;case zo.LightColor:return bt.LightColor;case zo.LightTemperature:return bt.LightWarmth;case zo.ReedState:return bt.ReedState;case zo.SmokeSensor:return bt.SmokeSensorState;case zo.Temperature:return bt.MeasuredTemperature;case zo.Humidity:return bt.HumiditySensorState;case zo.BlindsControlButton:return bt.BlindRemoteButtonState;case zo.FacadeControlButton:return bt.FacadeRemoteButtonState;case zo.Movement:return bt.MovementSensorState;case zo.AirPressure:return bt.PressureSensorState;case zo.WindSpeed:return bt.WindSpeedState;case zo.WindThreshold:return bt.CurrentWindThreshold;default:return bt.Unknown}}CreateDeviceState(e,t,n){switch(n){case bt.BatteryState:return{Channel:t,StateReliability:qt.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case bt.BinarySensorState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.BlindPosition:return{Channel:t,StateReliability:qt.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case bt.LightBrightness:case bt.MeasuredBrightness:return{Channel:t,StateReliability:qt.Unconfident,Brightness:e.Brightness,Time:""};case bt.RemoteButtonState:case bt.ChannelOnOffState:case bt.DoorBellState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(Yt[t],r);return{Channel:t,StateReliability:qt.Unconfident,MeasurementParameters:n,Time:""}}case bt.FloodSensorState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.GatePosition:return{Channel:t,StateReliability:qt.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case bt.LightColor:return{Channel:t,StateReliability:qt.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case bt.LightWarmth:return{Channel:t,StateReliability:qt.Unconfident,Temperature:e.Temperature,Time:""};case bt.ReedState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.SmokeSensorState:throw new ps("Unsupported device state!");case bt.MeasuredTemperature:return{Channel:t,StateReliability:qt.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case bt.HumiditySensorState:return{Channel:t,StateReliability:qt.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case bt.BlindRemoteButtonState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case bt.LightRGBWState:return{StateReliability:qt.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case bt.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,State:e.State};case bt.MovementSensorState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case bt.PressureSensorState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case bt.WindSpeedState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Value:e.Value};case bt.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:qt.Unconfident,WindThreshold:e.WindThreshold};case bt.Unknown:return new An;default:throw new ps("Unsupported device state!")}}MapDeviceTask(e){var t;let n=new Kr,r=e;switch(null===(t=u.Log)||void 0===t||t.Debug(`[TASK] object: ${JSON.stringify(r)}`),r.ControlFeature){case Ur.TurnOn:n=new Jr,n.TaskType=Et.TurnOn;break;case Ur.TurnOff:n=new zr,n.TaskType=Et.TurnOff;break;case Ur.ToggleState:n=new Qr,n.TaskType=Et.TogleState;break;case Ur.SetBlindPosition:{const e=Qv.Get(Ys.ServiceName).GetDevice(r.DeviceGuid);(null==e?void 0:e.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType)))?(n=new ro,n.TaskType=Et.SetBlindPositionSimple,n.Action=r.Data.Action):(n=new to,n.TaskType=Et.SetBlindPosition,n.Action=r.Data.Action,n.Position=r.Data.Position);break}case Ur.SetLightColor:n=new Zr,n.TaskType=Et.SetLightColor,n.R=r.Data.R,n.G=r.Data.G,n.B=r.Data.B;break;case Ur.SetLightTemperature:n=new eo,n.TaskType=Et.SetLightTemperature,n.Temperature=r.Data.Temperature;break;case Ur.SetLightBrightness:n=new Yr,n.TaskType=Et.SetLightBrightness,n.Brightness=r.Data.Brightness;break;case Ur.SetTemperature:n=new jr,n.TaskType=Et.SetTemperature,n.Temperature=r.Data.Temperature;break;case Ur.GetState:n=new co,n.TaskType=Et.GetChannelsState;break;case Ur.TurnOnWithTimeout:n=new Xr,n.TaskType=Et.TurnOnWithTime,n.SwitchOffDelaySeconds=r.Data.SwitchOffDelaySeconds;break;case Ur.SetLightBrightnessDynamicly:n=new oo,n.TaskType=Et.SetLightBrightnessDynamicly,n.Brightness=r.Data.Brightness;break;case Ur.IdentifyDevice:n=new so,n.TaskType=Et.IdentifyDevice;break;case Ur.SetBlindOpenCloseTime:n=new io,n.TaskType=Et.SetBlindOpenCloseTime,n.Data.CloseTime=r.Data;break;case Ur.SetBlindMicroventilation:n=new uo,n.TaskType=Et.SetBlindMicroventilation,n.Position=r.Data.Position;break;case Ur.GatewayPulse:n=new ho,n.TaskType=Et.ChangeGatewayPositionPulse;break;case Ur.GatePulse:n=new lo,n.TaskType=Et.ChangeGatePositionPulse;break;case Ur.SetFacadePositionAndTilt:n=new go,n.TaskType=Et.SetFacadePosition,n.Position=r.Data.Position,n.Tilt=r.Data.Tilt,n.FacadeAction=Lr.TiltAndPercentage;break;case Ur.GetFacadeType:n=new po,n.TaskType=Et.GetFacadeType;break;case Ur.LightRGBW:n=new vo,n.TaskType=Et.LightRGBW,n.Data=r.Data;break;case Ur.SetGatePositionPrecise:n=new no,n.TaskType=Et.PreciseGateControl,n.Position=r.Data.Position,n.GateControlAction=r.Data.GateControlAction}return n.Channel=r.Channel,n.DeviceGuid=r.DeviceGuid,n.FeatureType=r.ControlFeature,n.Guid=Hr.NewGuid(),n}MapControllerTasks(e){var t,n;const r=[];null===(t=u.Log)||void 0===t||t.Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let t of e){const e=new Ws;switch(e.Guid=t.Guid,e.TaskId=oe.GenerateMd5(JSON.stringify(t)),t.TaskType){case Vo.DeviceTask:e.TaskType=Ho.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(t);break;case Vo.DelayTask:e.TaskType=Ho.DelayTask,e.Task.DelayTask={Delay:new hs(t.Delay)};break;case Vo.NotifyTask:e.TaskType=Ho.NotifyTask,e.Task.NotifyTask={Message:t.Message,NotifyType:t.NotifyType,NotificationClients:t.NotificationClients};break;case Vo.LockExecution:case Vo.LockExecution:e.TaskType=Ho.LockExecution,null===(n=u.Log)||void 0===n||n.Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(t)}`),e.Task.LockExecution={LockStartHour:new hs(t.LockStartHour),LockEndHour:new hs(t.LockEndHour),LockType:t.LockType,ResetLockScenesGuids:t.ResetLockScenesGuids};case Vo.Unknown:}r.push(e)}return r}GetSupportedTaskTypesAsync(){return Us(this,void 0,void 0,(function*(){const e=yield Qv.Get(os.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Yo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Yo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Yo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Yo.NotifyTaskAppNotify),r}))}}Ms.ServiceName="ScenesService";class xs extends ae{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=ue.Get}}class Fs extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Get,this.Data=e}}class Ls extends ae{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=ue.Get,this.Data=e}}class Bs{constructor(){this.HandledType=Ps.Null,this.Argument={}}}!function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(Ps||(Ps={}));class Ws{constructor(){this.TaskId="",this.Guid="",this.TaskType=Ho.Unknown,this.Task={}}}class $s extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Put,this.Data=e}}class qs extends ae{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=ue.Put,this.Data=e}}class Vs extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Delete,this.Data=e}}class Hs extends ae{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=ue.Post,this.Data=e}}class Ks extends ae{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=ue.Post,this.Data=e}}!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"}(Os||(Os={}));class js{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}var zs=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Js{constructor(){this._isConnectedAndAuthorized=!1,this._syncLock=new js,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=Os.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new De,this._onSuspendedEvent=new De,this._onEnterLowPowerModeEvent=new De,this._onExitLowPowerModeEvent=new De,this._onBackButtonPressedEvent=new De,this._onForwardButtonPressedEvent=new De,this._onAppStateChanged=new a,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>zs(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,r,o;document.location,e.state&&("forward"==e.state.direction?(null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=u.Log)||void 0===r||r.Warning(Js.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return zs(this,void 0,void 0,(function*(){this._session=yield Qv.GetAsync("SessionService"),this._connection=yield Qv.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(Os.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(Os.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,o,s,i;switch(e){case he.ConnectedAndAuthorized:null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App state changed to: connected"),this._isConnectedAndAuthorized=!0,this._onAppStateChanged.Invoke(Os.Connected);break;case he.Disconnected:null===(n=u.Log)||void 0===n||n.Warning(Js.ServiceName,"App state changed to: disconnected"),this._isConnectedAndAuthorized&&this._onAppStateChanged.Invoke(Os.Disconnected),this._isConnectedAndAuthorized=!1;break;case he.Connecting:null===(r=u.Log)||void 0===r||r.Warning(Js.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(Os.Connecting);break;case he.Disconnecting:null===(o=u.Log)||void 0===o||o.Warning(Js.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(Os.Disconnecting);break;case he.Reconnecting:null===(s=u.Log)||void 0===s||s.Warning(Js.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(Os.Reconnecting);break;case he.Failed:null===(i=u.Log)||void 0===i||i.Warning(Js.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(Os.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(Os.Suspended),null===(e=u.Log)||void 0===e||e.Warning(Js.ServiceName,"App state changed to: suspended"),null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(Os.ReturnedFromSuspension),null===(e=u.Log)||void 0===e||e.Warning(Js.ServiceName,"App state changed to: returned from suspension"),null===(t=u.Log)||void 0===t||t.Warning(Js.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Os.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Os.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 Js.ServiceName}}Js.ServiceName="AppStateService";var Xs=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ys{constructor(){this._devices=[],this._onDevicesTasksChangedEvent=new a,this._onDeviceFoundEvent=new a,this._onDeviceRegisteredEvent=new a,this._onDeviceRemovedEvent=new a,this._onDeviceFirmwareVersionChangedEvent=new a,this._onDeviceStateChangedEvent=new a,this._onDeviceStateRefreshedOrChangedEvent=new a,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=Qv.Get(_t.ServiceName),this._session=Qv.Get(Je.ServiceName),this._controllerConfiguration=Qv.Get(it.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>Xs(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=>Xs(this,void 0,void 0,(function*(){var t;try{this._devices=yield this.GetPairedDevicesAsync(!0)}catch(e){null===(t=u.Log)||void 0===t||t.Error(Ys.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=>Xs(this,void 0,void 0,(function*(){var t;try{yield this.WaitForSynchronizationAsync(),yield this.SyncDevicesStatesAsync()}catch(e){null===(t=u.Log)||void 0===t||t.Error(Ys.ServiceName,`Failed to sync devices states: ${e}`)}this._synchronizedDevicesStates=!0,e()}))))})),Qv.Get(Js.ServiceName).OnAppStateChanged().Subscribe((e=>Xs(this,void 0,void 0,(function*(){switch(e){case Os.ReturnedFromSuspension:Qv.Get(_t.ServiceName).IsConnected()&&1==this._synchronizedDevicesStates&&this.SyncDevicesStatesAsync();break;case Os.Disconnected:break;case Os.Connected:1==this._synchronizedDevicesStates&&this.SyncDevicesStatesAsync()}})))),this._connection.SubscribeTo("/info/devices/tasks",(e=>{this.ParseDeviceTaskInfo(e.Data)})),this._connection.SubscribeTo("/info/devices/device/found",(e=>{this.MapApiDevices(e.Data).forEach((e=>{var t;e.DeviceType!=Nt.Scene&&(null===(t=u.Log)||void 0===t||t.Debug(Ys.ServiceName,`Found device: ${e.Name} guid: ${e.Guid}`),this._onDeviceFoundEvent.Invoke(e))}))})),this._connection.SubscribeTo("/info/devices/device/firmware/updated",(e=>{const t=e.Data.DeviceGuid,n=e.Data.Version,r=this._devices.find((e=>e.Guid==t));void 0!==r&&(this._onDeviceFirmwareVersionChangedEvent.Invoke({Device:r,FirmwareVersion:n}),r.SoftwareVersion=n,r.OnDeviceFirmwareVersionChangedEvent().Invoke({FirmwareVersion:n}))})),this._connection.SubscribeTo("/info/devices/device/state/changed",(e=>{var t;const n=e.Data,r=this._devices.filter((e=>e.Guid==n.DeviceGuid));if(r.length>0){const e=r[0],o=this.MapApiDeviceStateToDeviceState(e,n);if(null!=o){this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==bt.SignalStrength?e.Channels.forEach((t=>{let r=new rr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==bt.BatteryState&&e.Channels.forEach((t=>{let r=new Vn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})}));let r=e.States.find((e=>e.TypeAsEnum===o.TypeAsEnum&&e.Data.Channel===o.Data.Channel));if(r){let s=r.StatesComparisonData;if(o.TypeAsEnum==bt.BlindErrorState&&(null===(t=o.Data)||void 0===t?void 0:t.ErrorCode)!=r.Data.ErrorCode)return void this._onDeviceStateChangedEvent.Invoke({Device:e,State:o});r.Data=o.Data,s!==o.StatesComparisonData&&(this._onDeviceStateChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==bt.SignalStrength?e.Channels.forEach((t=>{let r=new rr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==bt.BatteryState&&e.Channels.forEach((t=>{let r=new Vn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})))}else e.States.push(o),this._onDeviceStateChangedEvent.Invoke({Device:e,State:o}),o.TypeAsEnum==bt.SignalStrength?e.Channels.forEach((t=>{let r=new rr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==bt.BatteryState&&e.Channels.forEach((t=>{let r=new Vn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Ys.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{Qv.Get(Le.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Ys.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}ProtocolGuidToProtocolName(e){switch(e){case"1fca7e8a-a2dc-4883-bd94-4e9b2012f685":return"ExtaLife";case"cd25bdff-628c-4dbc-a16a-648c96a819d4":return"Portos 433MHz";case"634c2bb2-1a4f-4db6-8dd4-d5fbaf92678e":return"Supla";case"194aeb81-990c-4a02-9236-59e902958fda":return"RTSP";case"b3e4644e-ab5b-494e-b3c5-66fabe7fff64":return"Wekta";case"247198e1-e360-4355-9886-232ac1456eea":return"Lavva Wi-Fi";default:return null}}CanDisplaySceneDevices(){return this.CheckIfControllerSoftwareVersionIsEnough(6,56)}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,o;const s=null!==(o=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==o?o:null;if(!s||!s.includes("."))return!1;const i=s.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}CheckIfDeviceUsedInScenesAsync(e){return Xs(this,void 0,void 0,(function*(){var t,n,r,o,s,i;try{let i;if("string"==typeof e){const n=this.GetDevice(e);if(null==n)return null===(t=u.Log)||void 0===t||t.Error("Cannot check if device is used in scenes! Device with given guid not exists"),ce.ResourceDoesNotExists;i=n}else i=e;const c=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new di(i.Guid),2e4,!1);if(null==c||null==c.Status)return null===(r=u.Log)||void 0===r||r.Error("Cannot check if device is used in scenes! Response or status is null!"),ce.FatalError;if(c.Status!=ce.OK)return c.Status;if(null==c.Data)return null===(o=u.Log)||void 0===o||o.Error("Cannot check if device is used in scenes! No data!"),ce.FatalError;var a=yield Qv.Get(Ms.ServiceName).GetSequencesListAsync();if(a instanceof Ee)return null===(s=u.Log)||void 0===s||s.Error(`Cannot check if device is used in scenes! Cannot get sequence list, ScenesServiceErrorCode: ${a.Type}`),ce.Error;const l=new fi;return l.DeviceGuid=i.Guid,c.Data.ConditionsAsCondition.forEach((e=>{const t=a.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),c.Data.ConditionsAsTask.forEach((e=>{const t=a.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),l}catch(e){return null===(i=u.Log)||void 0===i||i.Error(`Cannot check if device is used in scenes! ${e}`),ce.FatalError}}))}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)>=pe.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)>=pe.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return Xs(this,void 0,void 0,(function*(){var e;const t=Qv.Get(_o.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return null===(e=u.Log)||void 0===e||e.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EnableFastStatesSyncAsync()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),t}))}DisableFastStatesSyncAsync(){return Xs(this,void 0,void 0,(function*(){var e;const t=Qv.Get(_o.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return null===(e=u.Log)||void 0===e||e.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DisableFastStatesSyncAsync()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),t}))}IsFastStatesSyncEnabledAsync(){return Xs(this,void 0,void 0,(function*(){const e=yield Qv.Get(_o.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof wo?e.Data:e!=ce.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return Xs(this,void 0,void 0,(function*(){let t=Qv.Get(mo.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 Xs(this,void 0,void 0,(function*(){var t,n=yield Qv.Get(mo.ServiceName).AddManuallyPairedDeviceAsync(e);return null===(t=u.Log)||void 0===t||t.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDevice()"),yield Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),n}))}GetDeviceChannelStates(e,t){var n,r;return null!==(r=null===(n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===n?void 0:n.ChannelsStates.filter((e=>e.Channel==t)))&&void 0!==r?r:[]}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 r=new Qs;r.Channel=t.Data.Channel,r.States=[t],n={DeviceGuid:e.Guid,ChannelsStates:[r]},this._devicesChannelsStates.push(n)}else{let e=n.ChannelsStates.firstOrDefault((e=>e.Channel==t.Data.Channel));if(null==e)e=new Qs,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e);else{let n=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum));null!=n&&(n.TypeAsEnum==bt.BlindErrorState?e.States=e.States.where((e=>e.Data.ErrorCode!=t.Data.ErrorCode)).toArray():e.States=e.States.where((e=>e.TypeAsEnum!=t.TypeAsEnum)).toArray()),e.States.push(t)}}}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}WaitForDevicesStatesSynchronizationAsync(){return this._deviceStatesSynchronizationTaskCompletionSource}GetCurrentlyRunningTaksAsync(){return Xs(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new si,15e3,!1);(null==t?void 0:t.Status)==ce.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),r=new Wt;if(r.DeviceGuid=n[0],r.Channel=Number(n[1]),r.Status=Ct.ExecutingTasks,t.push(r),0===r.Channel){const e=this._devices.find((e=>e.Guid==r.DeviceGuid));void 0!==e&&e.Channels.forEach((n=>{const r=new Wt;r.DeviceGuid=e.Guid,r.Channel=n.Number,r.Status=Ct.ExecutingTasks,t.push(r)}))}})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new _n(t);case"DoorBell":return new bn(t);case"ReedPosition":return new Gn(t);case"BlindPosition":return new Rn(t);case"ButtonState":return new On(t);case"LightColor":return new Mn(t);case"LightTemperature":return new Fn(t);case"LightBrightness":return new Bn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new $n(t);case"BatteryState":return new Vn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new Kn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new zn(t);case"DistanceSensor":return new Xn(t);case"MovementSensor":return new Yn(t);case"BlindsControlButton":return new Zn(t);case"FacadeControlButton":return new tr(t);case"SignalStrength":return new rr(t);case"GatePosition":return new or(t);case"GatewayPosition":return new ir(t);case"GateControllerHealth":return new ar(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new cr(t);case"HumiditySensor":case"HumidityState":return new ur(t);case"VibrationSensor":return new dr(t);case"DigitalInputSensor":return new hr(t);case"ConfigurationState":return new pr(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new fr(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new vr(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new yr(t);case"FacadePosition":case"FacadeState":return new mr(t);case"FacadeTypeState":return new wr(t);case"CurrentWindThreshold":return new Sr(t);case"CurrentLightThreshold":return new _r(t);case"WindSpeed":return new Cr(t);case"FloodSensor":return new Dr(t);case"PressureState":return new Er(t);case"ITamperProtection":case"TamperProtection":return new Ir(t);case"ILightRGBW":case"LightRGBW":return new Gr(t);case"OnlineCamera":case"IOnlineCamera":return new En(t);case"BlindError":case"IBlindError":return t.state.ErrorData=ie(t.state.ErrorData),new Nr(t);case"HallState":return new Tn(t);case"SceneExecuted":return new Dn(t);case"Intercom":return new kn(t);default:null===(n=u.Log)||void 0===n||n.Debug(Ys.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return Ys.ServiceName}SyncDevicesStatesAsync(){return Xs(this,arguments,void 0,(function*(e=!1){var t,n,r;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ei,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync()){if(e){let e=new ti;e.Data=!0;const t=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ce.OK}return(null==o?void 0:o.Status)==ce.OK}{let e=new ti;e.Data=!0;const t=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ce.OK}}))}OnDevicesTasksExecutionChangeEvent(){return this._onDevicesTasksChangedEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}OnDeviceRegisteredEvent(){return this._onDeviceRegisteredEvent}OnDeviceRemovedEvent(){return this._onDeviceRemovedEvent}OnDeviceFoundEvent(){return this._onDeviceFoundEvent}MapApiDevices(e){const t=[];return null==e?[]:(e.forEach((e=>{var n,r,o,s,i=new Rr;i.Guid=e.Guid,i.Name=e.DeviceName,i.ChannelsAmount=e.ChannelsNumber,i.DeviceType=e.DeviceType,i.CommunicationWay=e.CommunicationWay,i.DeviceState=e.DeviceState,i.IsEnabled=e.IsEnabled,i.IsVirtual=e.IsVirtual,i.SerialNumber=e.DeviceSerialNumber,i.ManufacturerGuid=e.ManufacturerGuid,i.ModelGuid=e.DeviceModelGuid,i.Model=e.DeviceModel,i.Name=e.DeviceName,i.ProtocolGuid=e.ProtocolGuid,void 0!==e.IconType&&null!==e.IconType?i.IconType=e.IconType:i.IconType=kt.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Lt;if(i.CommunicationWay==Gt.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}i.AvailableTaskTypes.push(t)})),null===(r=e.AvailableResponses)||void 0===r||r.forEach((e=>{var t=new Bt;t.InterfaceType=e,i.AvailableResponseTypes.push(t)})),null===(o=e.ChannelsConfiguration)||void 0===o||o.forEach((e=>{var t,n,r;try{var o=new Wr;o.Number=e.Channel,i.Channels.push(o),o.SetDevice(i),o.Name=e.ChannelName,o.ChannelGroups=e.GroupsGuids,o.IconName=e.IconName,o.IsHidden=e.Hidden,o.Configurations=e.Configurations,o.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(o.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(o.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{var t=new Bt;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Lt;i.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType))?"IBlindPosition"==e&&(t.InterfaceType="IBlindPositionSimple"):t.InterfaceType=e,o.AvailableTaskTypes.push(t)}))}catch(e){null===(r=u.Log)||void 0===r||r.Error(e)}}))}catch(e){null===(s=u.Log)||void 0===s||s.Error(e)}t.push(i)})),t)}GetPairedDevicesAsync(){return Xs(this,arguments,void 0,(function*(e=!1){var t,n,r;if(this._synchronized&&!(yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync()))return e?Promise.resolve(this._devices):Promise.resolve(this._devices.filter((e=>e.DeviceType!=Nt.Scene)));const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Zs,15e3,!0);return null==o||void 0===o?[]:o.Status==ce.OK&&null!=o.Data?(this._devices=this.MapApiDevices(o.Data),e?this._devices:this._devices.filter((e=>e.DeviceType!=Nt.Scene))):(null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(){return Xs(this,arguments,void 0,(function*(e=!1){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){return Xs(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new oi,15e3,!1);return null==n?[]:n.Status==ce.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Nt.Scene)).toArray():(null===(t=u.Log)||void 0===t||t.Error(Ys.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){return Xs(this,void 0,void 0,(function*(){var e;Qv.Get(Le.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ni,35e3,!1)}))}StopSearchingForDevices(){return Xs(this,void 0,void 0,(function*(){var e;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ri,2e4,!1)}))}RegisterDeviceAsync(e){return Xs(this,void 0,void 0,(function*(){var t,n,r;try{const r=new ii;r.Data=e.Guid;const o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(r,2e4,!1);return null===(n=u.Log)||void 0===n||n.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RegisterDeviceAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==ce.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),Pt.Executed):Pt.Failed}catch(e){return null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,`Failed to paired devices: ${e}`),Pt.ControllerResponseTimeout}}))}RemoveDeviceAsync(e){return Xs(this,arguments,void 0,(function*(e,t=!1){var n,r,o=new ai;t&&(o=new ci),o.Data=e.Guid;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,35e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RemoveDeviceAsync()"),Qv.Get(it.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ce.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),Pt.Executed):Pt.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new hi;const r=t;switch(r.FeatureType){case Ur.SetTemperature:n.Data=r.Temperature;break;case Ur.SetLightBrightness:n.Data=r.Brightness;break;case Ur.SetLightColor:n=new gi;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case Ur.SetLightTemperature:n.Data=r.Temperature;break;case Ur.SetGatePositionPrecise:switch(r.GateControlAction){case xr.Open:n.Data=101;break;case xr.Close:n.Data=102;break;case xr.Stop:n.Data=103;break;case xr.Percentage:n.Data=r.Position}break;case Ur.SetBlindPosition:switch(r.Action){case Mr.Open:n.Data=101;break;case Mr.Close:n.Data=102;break;case Mr.Stop:n.Data=103;break;case Mr.Percentage:n.Data=r.Position}break;case Ur.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case Ur.SetBlindOpenCloseTime:n.Data=r.Data;break;case Ur.SetBlindMicroventilation:n.Data=r.Position;break;case Ur.SetFacadePositionAndTilt:n=new pi;const t=r;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case Ur.LightRGBW:n.Data=r.Data;break;case Ur.GatePulse:case Ur.GatewayPulse:n.Data=0;break;case Ur.TurnOnWithTimeout:n.Data=r.SwitchOffDelaySeconds}return n.Channel=r.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=r.FeatureType,n}ExecuteDeviceTaskAsync(e,t){return Xs(this,void 0,void 0,(function*(){var n,r,o,s,i,a,c,l;try{null===(n=u.Log)||void 0===n||n.Debug(Ys.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new ui(l);null===(r=u.Log)||void 0===r||r.Debug(Ys.ServiceName,`Sending device task for execution, device: ${l.DeviceGuid} task: ${l.ControlFeature} channel: ${l.Channel} request: ${JSON.stringify(e)}`);const t=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(e,15e3,!1);switch(null==t?void 0:t.Status){case ce.OK:return Pt.Executed;case ce.FatalError:return null===(s=u.Log)||void 0===s||s.Error(Ys.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),Pt.Failed;case ce.WrongData:if("DeviceNotFound"===t.Data)return Pt.DeviceNotFound;break;case ce.Error:return"DeviceResponseTimeout"===t.Data?Pt.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Ys.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),Pt.Failed)}}catch(e){return e.message.includes("timeout")?(null===(a=u.Log)||void 0===a||a.Error(Ys.ServiceName,`Failed to get controller response in time.\n${e}`),Pt.ControllerResponseTimeout):(null===(c=u.Log)||void 0===c||c.Error(Ys.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Pt.Failed)}return Pt.Unknown}catch(e){return null===(l=u.Log)||void 0===l||l.Error(Ys.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Pt.Failed}}))}ExecuteDevicesTasksAsync(e){return Xs(this,void 0,void 0,(function*(){var t,n,r,o;let s=[],i=[],a=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=a,a++,i.push(e)}const c=new li(i);try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(c,12e4,!1);let o=-1;null===(n=null==r?void 0:r.Data)||void 0===n||n.forEach((t=>{var n,i;o++;let a=Pt.Unknown;switch(t.Status){case ce.OK:return Pt.Executed;case ce.FatalError:null===(n=u.Log)||void 0===n||n.Error(Ys.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),a=Pt.Failed;break;case ce.WrongData:"DeviceNotFound"===t.Data&&(a=Pt.DeviceNotFound);break;case ce.Error:"DeviceResponseTimeout"===t.Data?a=Pt.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Ys.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),a=Pt.Failed)}let c=0,l=new $t;for(const[t,n]of e){if(c==o){l.Device=t,l.Task=n,l.Channel=n.Channel,s.push(l);break}c++}}))}catch(t){if(t.message.includes("timeout")){null===(r=u.Log)||void 0===r||r.Error(Ys.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new $t;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Pt.ControllerResponseTimeout}}else{null===(o=u.Log)||void 0===o||o.Error(Ys.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new $t;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Pt.Failed}}}return s}))}}Ys.ServiceName="DevicesService";class Qs{constructor(){this.Channel=0,this.States=[]}}class Zs extends ae{constructor(){super(),this.Resource="/devices/list",this.Method=ue.Get}}class ei extends ae{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ue.Get}}class ti extends ae{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ue.Get}}class ni extends ae{constructor(){super(),this.Resource="/devices/search",this.Method=ue.Post}}class ri extends ae{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ue.Post}}class oi extends ae{constructor(){super(),this.Resource="/devices/found/list",this.Method=ue.Get}}class si extends ae{constructor(){super(),this.Resource="/devices/tasks",this.Method=ue.Get}}class ii extends ae{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ue.Put}}class ai extends ae{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ue.Put}}class ci extends ae{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ue.Put}}class ui extends ae{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ue.Post,this.Data=e}}class li extends ae{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ue.Post,this.Data=e}}class di extends ae{constructor(e){super(),this.Resource="/logic/device/used",this.Method=ue.Get,this.Data=e}}class hi{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Ur.GetState,this.SequnceExecutionOrder=0}}class gi extends hi{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class pi extends hi{constructor(){super(...arguments),this.FacadeAction=Lr.Stop,this.Tilt=0,this.Position=0}}class fi{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class vi extends RangeError{paramName;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 yi=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 mi extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const wi=(e,t)=>e===t;class Si{iterator;constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Ai{dataFunc;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 _i{iterator;constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class Ci extends Array{}const Ti=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Ei(e,t,n,r)}return n?ki(e,t,n):Di(e,t)},Di=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},ki=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},Ei=(e,t,n,r)=>{let o=t;for(const t of e)o=n(o,t);return r(o)},bi=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},Ii=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Gi=(e,t)=>t?Ri(e,t):Ni(e),Ni=e=>{for(const t of e)return!0;return!1},Ri=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Pi=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},Oi=(e,t)=>new _i((function*(){yield*e,yield t})),Ui=e=>{if(Array.isArray(e)){if(0===e.length)throw new mi(yi.NoElements);return new Si((async function*(){for await(const t of e)yield t}))}return new Si(e)},Mi=e=>Ui((async function*(){for(const t of e)yield t})),xi=(e,t)=>new Ai({generator:t,type:e}),Fi=e=>xi(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Li=(e,t)=>{let n=0,r=0;if(t)for(const o of e)n+=t(o),r+=1;else for(const t of e)n+=t,r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Bi=async(e,t)=>{let n=0,r=0;for(const o of e)n+=await t(o),r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Wi=(e,t)=>{if(t<1)throw new vi("size");return new _i((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},$i=(e,t)=>new _i((function*(){yield*e,yield*t})),qi=(e,t,n=wi)=>{for(const r of e)if(n(t,r))return!0;return!1},Vi=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},Hi=(e,t)=>t?ji(e,t):Ki(e),Ki=e=>{let t=0;for(const n of e)t++;return t},ji=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},zi=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},Ji=(e,t)=>new _i((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),Xi=(e,t=wi)=>new _i((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Yi=(e,t)=>Ui((async function*(){const n=[];e:for(const r of e){for(const e of n)if(await t(e,r))continue e;n.push(r),yield r}})),Qi=(e,t)=>new _i((function*(){for(const n of e)t(n),yield n})),Zi=(e,t)=>Ui((async function*(){for(const n of e)await t(n),yield n})),ea=(e,t)=>{if(t<0)throw new vi("index");let n=0;for(const r of e)if(t===n++)return r;throw new vi("index")},ta=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},na=(e,t,n=wi)=>new _i((function*(){const r=[...t];for(const t of e){let e=!1;for(let o=0;o<r.length;o++)if(!0===n(t,r[o])){e=!0;break}!1===e&&(yield t)}})),ra=(e,t,n)=>Ui((async function*(){const r=[...t];for(const t of e){let e=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),oa=(e,t)=>t?ia(e,t):sa(e),sa=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new mi(yi.NoElements);return t.value},ia=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new mi(yi.NoMatch)},aa=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new mi(yi.NoMatch)},ca=(e,t)=>t?la(e,t):ua(e),ua=e=>e[Symbol.iterator]().next().value??null,la=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},da=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class ha extends Ci{key;constructor(e,t){super(1),this.key=e,this[0]=t}}const ga=(e,t,n)=>{let r;return r=n?((e,t,n)=>function*(){const r=new Array;for(const o of e){const e=t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})(e,t,n):((e,t)=>function*(){const n={};for(const r of e){const e=t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})(e,t),new _i(r)},pa=(e,t,n)=>n?va(e,t,n):fa(e,t),fa=(e,t)=>Ui((async function*(){const n={};for(const r of e){const e=await t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})),va=(e,t,n)=>Ui((async function*(){const r=new Array;for(const o of e){const e=await t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})),ya=(e,t,n,r)=>r?((e,t,n,r)=>new _i((function*(){const o=new Array;for(const s of e){const e=t(s);let i=!1;for(let t=0;t<o.length;t++){const a=o[t];if(r(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);o.push(new ha(e,t))}}for(const e of o)yield e})))(e,t,n,r):((e,t,n)=>new _i((function*(){const r={};for(const o of e){const e=t(o),s=r[e],i=n(o);s?s.push(i):r[e]=new ha(e,i)}for(const e in r)yield r[e]})))(e,t,n),ma=(e,t,n,r,o,s)=>{const i=s?wa(e,t,n,r,o,s):Sa(e,t,n,r,o);return new _i(i)},wa=(e,t,n,r,o,s)=>function*(){const i=[];for(const e of t){const t=r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for(const t of e){const e=n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},Sa=(e,t,n,r,o)=>function*(){const s=new Map;for(const e of t){const t=r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for(const t of e){const e=n(t),r=s.get(e)??[];yield o(t,r)}},Aa=(e,t,n,r,o,s)=>{const i=s?_a(e,t,n,r,o,s):Ca(e,t,n,r,o);return Ui(i)},_a=(e,t,n,r,o,s)=>async function*(){const i=[];for(const e of t){const t=await r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for(const t of e){const e=await n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},Ca=(e,t,n,r,o)=>async function*(){const s=new Map;for(const e of t){const t=await r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for(const t of e){const e=await n(t),r=s.get(e)??[];yield o(t,r)}},Ta=(e,t,n=wi)=>new _i((function*(){const r=[...e.distinct(n)];if(0===r.length)return;const o=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++)if(!0===n(t,o[e])){yield t;break}}})),Da=(e,t,n)=>Ui((async function*(){const r=[];for await(const t of e.distinctAsync(n))r.push(t);if(0===r.length)return;const o=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===await n(t,r)){yield t;break}}}})),ka=(e,t,n,r,o,s=wi)=>new _i((function*(){const i=[...t];for(const t of e){const e=n(t);for(const n of i){const i=r(n);!0===s(e,i)&&(yield o(t,n))}}})),Ea=(e,t)=>t?Ia(e,t):ba(e),ba=e=>{let t;for(const n of e)t=n;if(!t)throw new mi(yi.NoElements);return t},Ia=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Ga=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Na=(e,t)=>t?Pa(e,t):Ra(e),Ra=e=>{let t=null;for(const n of e)t=n;return t},Pa=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},Oa=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},Ua=(e,t)=>t?xa(e,t):Ma(e),Ma=e=>{let t=null;for(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},xa=(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Fa=async(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},La=(e,t)=>t?Wa(e,t):Ba(e),Ba=e=>{let t=null;for(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},Wa=(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},$a=async(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},qa=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new _i((function*(){for(const t of e)n(t)&&(yield t)}))};async function*Va(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}function*Ha(e,t,n,r){const o=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}class Ka extends Si{orderedPairs;constructor(e){super((async function*(){for await(const t of e())yield*t})),this.orderedPairs=e}static generateAsync(e,t,n,r){let o;return o=e instanceof Ka?async function*(){for await(const o of e.orderedPairs())yield*Va(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Ka(o)}static generate(e,t,n,r){let o;return o=e instanceof Ka?async function*(){for await(const o of e.orderedPairs())yield*Ha(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Ka(o)}thenBy(e,t){return Ka.generate(this,e,!0,t)}thenByAsync(e,t){return Ka.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Ka.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Ka.generateAsync(this,e,!1,t)}}function*ja(e,t,n,r){const o=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}async function*za(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}class Ja extends _i{orderedPairs;constructor(e){super((function*(){for(const t of e())yield*t})),this.orderedPairs=e}static generate(e,t,n,r){let o;return o=e instanceof Ja?function*(){for(const o of e.orderedPairs())yield*ja(o,t,n,r)}:()=>ja(e,t,n,r),new Ja(o)}static generateAsync(e,t,n,r){let o;return o=e instanceof Ja?async function*(){for(const o of e.orderedPairs())yield*za(o,t,n,r)}:()=>za(e,t,n,r),new Ka(o)}thenBy(e,t){return Ja.generate(this,e,!0,t)}thenByAsync(e,t){return Ja.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Ja.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Ja.generateAsync(this,e,!1,t)}}const Xa=(e,t)=>Ja.generate(e,(e=>e),!0,t),Ya=(e,t,n)=>Ja.generate(e,t,!0,n),Qa=(e,t,n)=>Ja.generateAsync(e,t,!0,n),Za=(e,t,n)=>Ja.generate(e,t,!1,n),ec=(e,t,n)=>Ja.generateAsync(e,t,!1,n),tc=(e,t)=>Ja.generate(e,(e=>e),!1,t),nc=(e,t)=>{const n=[],r=[];for(const o of e)!0===t(o)?r.push(o):n.push(o);return[r,n]},rc=async(e,t)=>{const n=[],r=[];for(const o of e)!0===await t(o)?r.push(o):n.push(o);return[r,n]},oc=(e,t)=>new _i((function*(){yield t,yield*e})),sc=e=>new _i((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),ic=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?ac(e,t):cc(e,t)}return uc(e,t)},ac=(e,t)=>new _i((function*(){for(const n of e)yield t(n)})),cc=(e,t)=>new _i((function*(){let n=0;for(const r of e)yield t(r,n),n++})),uc=(e,t)=>new _i((function*(){for(const n of e)yield n[t]})),lc=(e,t)=>"function"==typeof t?1===t.length?dc(e,t):hc(e,t):gc(e,t),dc=(e,t)=>Ui((async function*(){for(const n of e)yield t(n)})),hc=(e,t)=>Ui((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),gc=(e,t)=>Ui((async function*(){for(const n of e)yield n[t]})),pc=(e,t)=>"function"==typeof t?1===t.length?fc(e,t):vc(e,t):yc(e,t),fc=(e,t)=>new _i((function*(){for(const n of e)for(const e of t(n))yield e})),vc=(e,t)=>new _i((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),yc=(e,t)=>new _i((function*(){for(const n of e)for(const e of n[t])yield e})),mc=(e,t)=>1===t.length?wc(e,t):Sc(e,t),wc=(e,t)=>Ui((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Sc=(e,t)=>Ui((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),Ac=(e,t,n=wi)=>{const r=e[Symbol.iterator](),o=t[Symbol.iterator]();let s=r.next(),i=o.next();for(;!s.done&&!i.done;){if(!n(s.value,i.value))return!1;s=r.next(),i=o.next()}return!0===s.done&&!0===i.done},_c=async(e,t,n)=>{const r=e[Symbol.iterator](),o=t[Symbol.iterator]();let s=r.next(),i=o.next();for(;!s.done&&!i.done;){if(!1===await n(s.value,i.value))return!1;s=r.next(),i=o.next()}return!0===s.done&&!0===i.done},Cc=(e,t)=>t?Dc(e,t):Tc(e),Tc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new mi(yi.NoElements);return n},Dc=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},kc=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},Ec=(e,t)=>t?Ic(e,t):bc(e),bc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}return n},Ic=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}return r},Gc=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneElement);n=!0,r=o}return r},Nc=(e,t)=>new _i((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),Rc=(e,t)=>1===t.length?Pc(e,t):Oc(e,t),Pc=(e,t)=>new _i((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Oc=(e,t)=>new _i((function*(){let n=0,r=!0;for(const o of e)!1===r?yield o:!1===t(o,n)&&(r=!1,yield o),n++})),Uc=(e,t)=>1===t.length?Mc(e,t):xc(e,t),Mc=(e,t)=>Ui((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),xc=(e,t)=>Ui((async function*(){let n=0,r=!0;for(const o of e)!1===r?yield o:!1===await t(o,n)&&(r=!1,yield o),n++})),Fc=(e,t)=>t?Bc(e,t):Lc(e),Lc=e=>{let t=0;for(const n of e)t+=n;return t},Bc=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},Wc=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},$c=(e,t)=>new _i((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),qc=(e,t)=>1===t.length?Vc(e,t):Hc(e,t),Vc=(e,t)=>new _i((function*(){for(const n of e){if(!t(n))break;yield n}})),Hc=(e,t)=>new _i((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),Kc=(e,t)=>1===t.length?jc(e,t):zc(e,t),jc=(e,t)=>Ui((async function*(){for(const n of e){if(!await t(n))break;yield n}})),zc=(e,t)=>Ui((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),Jc=e=>[...e],Xc=(e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Yc=async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Qc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},Zc=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},eu=e=>new Set(e),tu=(e,t,n)=>n?ru(e,t,n):nu(e,t),nu=(e,t)=>new _i((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))})),ru=(e,t,n)=>new _i((function*(){const r=[];for(const o of[e,t])for(const e of o){let t=!1;for(const o of r)if(!0===n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),ou=(e,t,n)=>Ui((async function*(){const r=[];for(const o of[e,t])for(const e of o){let t=!1;for(const o of r)if(!0===await n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),su=(e,t)=>1===t.length?iu(e,t):au(e,t),iu=(e,t)=>new _i((function*(){for(const n of e)!0===t(n)&&(yield n)})),au=(e,t)=>new _i((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),cu=(e,t)=>1===t.length?uu(e,t):lu(e,t),uu=(e,t)=>Ui((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),lu=(e,t)=>Ui((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),du=(e,t,n)=>n?gu(e,t,n):hu(e,t),hu=(e,t)=>new _i((function*(){const n=e[Symbol.iterator](),r=t[Symbol.iterator]();for(;;){const e=n.next(),t=r.next();if(e.done||t.done)break;yield[e.value,t.value]}})),gu=(e,t,n)=>new _i((function*(){const r=e[Symbol.iterator](),o=t[Symbol.iterator]();for(;;){const e=r.next(),t=o.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),pu=(e,t,n)=>Ui((async function*(){const r=e[Symbol.iterator](),o=t[Symbol.iterator]();for(;;){const e=r.next(),t=o.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),fu=e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(Ti,"aggregate"),n(bi,"all"),n(Ii,"allAsync"),n(Gi,"any"),n(Pi,"anyAsync"),n(Oi,"append"),n(Mi,"asAsync"),n(Fi,"asParallel"),n(Li,"average"),n(Bi,"averageAsync"),n(Wi,"chunk"),n($i,"concatenate"),n(qi,"contains"),n(Vi,"containsAsync"),n(Hi,"count"),n(zi,"countAsync"),n(Ji,"defaultIfEmpty"),n(Xi,"distinct"),n(Yi,"distinctAsync"),n(Qi,"each"),n(Zi,"eachAsync"),n(ea,"elementAt"),n(ta,"elementAtOrDefault"),n(na,"except"),n(ra,"exceptAsync"),n(oa,"first"),n(aa,"firstAsync"),n(ca,"firstOrDefault"),n(da,"firstOrDefaultAsync"),n(ga,"groupBy"),n(pa,"groupByAsync"),n(ya,"groupByWithSel"),n(ma,"groupJoin"),n(Aa,"groupJoinAsync"),n(Ta,"intersect"),n(Da,"intersectAsync"),n(ka,"joinByKey"),n(Ea,"last"),n(Ga,"lastAsync"),n(Na,"lastOrDefault"),n(Oa,"lastOrDefaultAsync"),n(Ua,"max"),n(Fa,"maxAsync"),n(La,"min"),n($a,"minAsync"),n(qa,"ofType"),n(Xa,"order"),n(Ya,"orderBy"),n(Qa,"orderByAsync"),n(Za,"orderByDescending"),n(ec,"orderByDescendingAsync"),n(tc,"orderDescending"),n(oc,"prepend"),n(sc,"reverse"),n(ic,"select"),n(lc,"selectAsync"),n(pc,"selectMany"),n(mc,"selectManyAsync"),n(Ac,"sequenceEquals"),n(_c,"sequenceEqualsAsync"),n(Cc,"single"),n(kc,"singleAsync"),n(Ec,"singleOrDefault"),n(Gc,"singleOrDefaultAsync"),n(Nc,"skip"),n(Rc,"skipWhile"),n(Uc,"skipWhileAsync"),n(Fc,"sum"),n(Wc,"sumAsync"),n($c,"take"),n(qc,"takeWhile"),n(Kc,"takeWhileAsync"),n(Jc,"toArray"),n(Xc,"toMap"),n(Yc,"toMapAsync"),n(Qc,"toObject"),n(Zc,"toObjectAsync"),n(nc,"partition"),n(rc,"partitionAsync"),n(eu,"toSet"),n(tu,"union"),n(ou,"unionAsync"),n(su,"where"),n(cu,"whereAsync"),n(du,"zip"),n(pu,"zipAsync")},vu=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return wu(e,t,n,r)}return n?mu(e,t,n):yu(e,t)},yu=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},mu=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},wu=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},Su=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Au=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},_u=(e,t)=>new Si((async function*(){yield*e,yield t})),Cu=(e,t)=>t?Du(e,t):Tu(e),Tu=async e=>{for await(const t of e)return!0;return!1},Du=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},ku=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},Eu=e=>xi(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),bu=async(e,t)=>{let n=0,r=0;if(t)for await(const o of e)n+=t(o),r+=1;else for await(const t of e)n+=t,r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Iu=async(e,t)=>{let n=0,r=0;for await(const o of e)n+=await t(o),r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Gu=(e,t)=>{if(t<1)throw new vi("size");return new Si((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Nu=(e,t)=>new Si((async function*(){yield*e,yield*t})),Ru=async(e,t,n=wi)=>{for await(const r of e)if(n(t,r))return!0;return!1},Pu=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},Ou=(e,t)=>t?Mu(e,t):Uu(e),Uu=async e=>{let t=0;for await(const n of e)t++;return t},Mu=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},xu=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},Fu=(e,t)=>new Si((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),Lu=(e,t=wi)=>new Si((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Bu=(e,t)=>new Si((async function*(){const n=[];e:for await(const r of e){for(const e of n)if(await t(e,r))continue e;n.push(r),yield r}})),Wu=(e,t)=>new Si((async function*(){for await(const n of e)t(n),yield n})),$u=(e,t)=>new Si((async function*(){for await(const n of e)await t(n),yield n})),qu=async(e,t)=>{if(t<0)throw new vi("index");let n=0;for await(const r of e)if(t===n++)return r;throw new vi("index")},Vu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},Hu=(e,t,n=wi)=>new Si((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===n(t,s)){e=!0;break}}!1===e&&(yield t)}})),Ku=(e,t,n)=>new Si((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let o=0;o<r.length;o++){const s=r[o];if(!0===await n(t,s)){e=!0;break}}!1===e&&(yield t)}})),ju=(e,t)=>t?Ju(e,t):zu(e),zu=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new mi(yi.NoElements);return t.value},Ju=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new mi(yi.NoMatch)},Xu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new mi(yi.NoMatch)},Yu=(e,t)=>t?Zu(e,t):Qu(e),Qu=async e=>(await e[Symbol.asyncIterator]().next()).value??null,Zu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},el=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},tl=(e,t,n)=>n?nl(e,t,n):rl(e,t),nl=(e,t,n)=>new Si((async function*(){const r=new Array;for await(const o of e){const e=t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})),rl=(e,t)=>new Si((async function*(){const n={};for await(const r of e){const e=t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})),ol=(e,t,n)=>n?il(e,t,n):sl(e,t),sl=(e,t)=>new Si((async function*(){const n={};for await(const r of e){const e=await t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})),il=(e,t,n)=>new Si((async function*(){const r=new Array;for await(const o of e){const e=await t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}for(const e of r)yield e})),al=(e,t,n,r)=>r?ul(e,t,n,r):cl(e,t,n),cl=(e,t,n)=>new Si((async function*(){const r={};for await(const o of e){const e=t(o),s=r[e],i=n(o);s?s.push(i):r[e]=new ha(e,i)}for(const e in r)yield r[e]})),ul=(e,t,n,r)=>new Si((async function*(){const o=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<o.length;t++){const a=o[t];if(r(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);o.push(new ha(e,t))}}for(const e of o)yield e})),ll=(e,t,n,r,o,s)=>{const i=s?dl(e,t,n,r,o,s):hl(e,t,n,r,o);return new Si(i)},dl=(e,t,n,r,o,s)=>async function*(){const i=[];for await(const e of t){const t=r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for await(const t of e){const e=n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},hl=(e,t,n,r,o)=>async function*(){const s=new Map;for await(const e of t){const t=r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for await(const t of e){const e=n(t),r=s.get(e)??[];yield o(t,r)}},gl=(e,t,n,r,o,s)=>{const i=s?pl(e,t,n,r,o,s):fl(e,t,n,r,o);return new Si(i)},pl=(e,t,n,r,o,s)=>async function*(){const i=[];for await(const e of t){const t=await r(e),n=i.find((e=>s(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}for await(const t of e){const e=await n(t),r=i.find((t=>s(t.key,e)))??{key:e,values:[]};yield o(t,r.values)}},fl=(e,t,n,r,o)=>async function*(){const s=new Map;for await(const e of t){const t=await r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}for await(const t of e){const e=await n(t),r=s.get(e)??[];yield o(t,r)}},vl=(e,t,n=wi)=>new Si((async function*(){const r=await e.distinct(n).toArray();if(0===r.length)return;const o=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===n(t,r)){yield t;break}}}})),yl=(e,t,n)=>new Si((async function*(){const r=await e.distinctAsync(n).toArray();if(0===r.length)return;const o=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===await n(t,r)){yield t;break}}}})),ml=(e,t,n,r,o,s=wi)=>new Si((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=r(n);!0===s(e,i)&&(yield o(t,n))}}})),wl=(e,t)=>t?Al(e,t):Sl(e),Sl=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new mi(yi.NoElements);return t},Al=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},_l=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Cl=(e,t)=>t?Dl(e,t):Tl(e),Tl=async e=>{let t=null;for await(const n of e)t=n;return t},Dl=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},kl=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},El=(e,t)=>t?Il(e,t):bl(e),bl=async e=>{let t=null;for await(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},Il=async(e,t)=>{let n=null;for await(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Gl=async(e,t)=>{let n=null;for await(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},Nl=(e,t)=>t?Pl(e,t):Rl(e),Rl=async e=>{let t=null;for await(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},Pl=async(e,t)=>{let n=null;for await(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Ol=async(e,t)=>{let n=null;for await(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},Ul=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Si((async function*(){for await(const t of e)n(t)&&(yield t)}))},Ml=(e,t)=>Ka.generate(e,(e=>e),!0,t),xl=(e,t,n)=>Ka.generate(e,t,!0,n),Fl=(e,t,n)=>Ka.generateAsync(e,t,!0,n),Ll=(e,t,n)=>Ka.generate(e,t,!1,n),Bl=(e,t,n)=>Ka.generateAsync(e,t,!1,n),Wl=(e,t)=>Ka.generate(e,(e=>e),!1,t),$l=async(e,t)=>{const n=[],r=[];for await(const o of e)!0===t(o)?r.push(o):n.push(o);return[r,n]},ql=async(e,t)=>{const n=[],r=[];for await(const o of e)!0===await t(o)?r.push(o):n.push(o);return[r,n]},Vl=(e,t)=>new Si((async function*(){yield t,yield*e})),Hl=e=>new Si((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]})),Kl=(e,t)=>"function"==typeof t?1===t.length?jl(e,t):zl(e,t):Jl(e,t),jl=(e,t)=>new Si((async function*(){for await(const n of e)yield t(n)})),zl=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),Jl=(e,t)=>new Si((async function*(){for await(const n of e)yield n[t]})),Xl=(e,t)=>"string"==typeof t?Ql(e,t):Yl(e,t),Yl=(e,t)=>new Si((async function*(){for await(const n of e)yield t(n)})),Ql=(e,t)=>new Si((async function*(){for await(const n of e)yield n[t]})),Zl=(e,t)=>"function"==typeof t?1===t.length?ed(e,t):td(e,t):nd(e,t),ed=(e,t)=>new Si((async function*(){for await(const n of e)for(const e of t(n))yield e})),td=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),nd=(e,t)=>new Si((async function*(){for await(const n of e)for(const e of n[t])yield e})),rd=(e,t)=>1===t.length?new Si((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Si((async function*(){let n=0;for await(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),od=async(e,t,n=wi)=>{const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();let s=await Promise.all([r.next(),o.next()]),i=s[0],a=s[1];for(;!i.done&&!a.done;){if(!n(i.value,a.value))return!1;s=await Promise.all([r.next(),o.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},sd=async(e,t,n)=>{const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();let s=await Promise.all([r.next(),o.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([r.next(),o.next()]),i=s[0],a=s[1]}return!0===i.done&&!0===a.done},id=(e,t)=>t?cd(e,t):ad(e),ad=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new mi(yi.NoElements);return n},cd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},ud=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new mi(yi.NoMatch);return r},ld=(e,t)=>t?hd(e,t):dd(e),dd=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}return n},hd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}return r},gd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(await t(o)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=o}return r},pd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),fd=(e,t)=>1===t.length?vd(e,t):yd(e,t),vd=(e,t)=>new Si((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),yd=(e,t)=>new Si((async function*(){let n=0,r=!0;for await(const o of e)!1===r?yield o:!1===t(o,n)&&(r=!1,yield o),n++})),md=(e,t)=>1===t.length?wd(e,t):Sd(e,t),wd=(e,t)=>new Si((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Sd=(e,t)=>new Si((async function*(){let n=0,r=!0;for await(const o of e)!1===r?yield o:!1===await t(o,n)&&(r=!1,yield o),n++})),Ad=(e,t)=>t?Cd(e,t):_d(e),_d=async e=>{let t=0;for await(const n of e)t+=n;return t},Cd=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},Td=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},Dd=(e,t)=>new Si((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),kd=(e,t)=>1===t.length?Ed(e,t):bd(e,t),Ed=(e,t)=>new Si((async function*(){for await(const n of e){if(!t(n))break;yield n}})),bd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Id=(e,t)=>1===t.length?Gd(e,t):Nd(e,t),Gd=(e,t)=>new Si((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Nd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Rd=async e=>{const t=[];for await(const n of e)t.push(n);return t},Pd=async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Od=async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),o=n.get(e);void 0===o?n.set(e,[r]):o.push(r)}return n},Ud=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},Md=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},xd=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Fd=(e,t,n)=>n?Bd(e,t,n):Ld(e,t),Ld=(e,t)=>new Si((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))})),Bd=(e,t,n)=>new Si((async function*(){const r=[];for(const o of[e,t])for await(const e of o){let t=!1;for(const o of r)if(!0===n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),Wd=(e,t,n)=>new Si((async function*(){const r=[];for(const o of[e,t])for await(const e of o){let t=!1;for(const o of r)if(!0===await n(e,o)){t=!0;break}!1===t&&(yield e,r.push(e))}})),$d=(e,t)=>1===t.length?qd(e,t):Vd(e,t),qd=(e,t)=>new Si((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Vd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),Hd=(e,t)=>1===t.length?Kd(e,t):jd(e,t),Kd=(e,t)=>new Si((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),jd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),zd=(e,t,n)=>n?Xd(e,t,n):Jd(e,t),Jd=(e,t)=>new Si((async function*(){const n=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([n.next(),r.next()]);if(e.done||t.done)break;yield[e.value,t.value]}})),Xd=(e,t,n)=>new Si((async function*(){const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([r.next(),o.next()]);if(e.done||t.done)break;yield n(e.value,t.value)}})),Yd=(e,t,n)=>new Si((async function*(){const r=e[Symbol.asyncIterator](),o=t[Symbol.asyncIterator]();for(;;){const e=await Promise.all([r.next(),o.next()]),t=e[0],s=e[1];if(t.done||s.done)break;yield n(t.value,s.value)}})),Qd=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return th(e,t,n,r)}return n?eh(e,t,n):Zd(e,t)},Zd=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},eh=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},th=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},nh=(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 r=0;r<e.length;r++)n[r]=t(e[r]);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:1};case 2:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:2}}},rh=(e,t)=>{const n=nh(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))}},oh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=t(e[n]);return r},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}}},sh=(e,t)=>{const n=oh(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))}},ih=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ai({generator:()=>{const e=n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 2:return new Ai({generator:async()=>{const e=await n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 0:return new Ai({generator:async()=>{const e=await n.generator();return e.push(t),e},type:n.type})}},ah=(e,t)=>t?uh(e,t):ch(e),ch=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}},uh=async(e,t)=>{const n=nh(e,t);let r;switch(n.type){case 0:return r=await n.generator(),r.includes(!0);case 1:return r=await Promise.all(n.generator()),r.includes(!0);case 2:return r=await Promise.all(await n.generator()),r.includes(!0)}},lh=async(e,t)=>{const n=oh(e,t);let r;switch(n.type){case 1:return r=n.generator(),0!==r.length&&new Promise(((e,t)=>{let n=0;for(const o of r)o.then((t=>{n++,t?e(!0):n===r.length&&e(!1)}),t)}));case 2:return r=await n.generator(),0===Promise.length?!1:(await Promise.all(r)).includes(!0)}},dh=e=>Ui((async function*(){for await(const t of e)yield t})),hh=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)}},gh=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},ph=async(e,t)=>{const n=oh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},fh=(e,t)=>{if(t<1)throw new vi("size");let n;switch(e.dataFunc.type){case 1:const r=e.dataFunc.generator;n={type:1,generator:()=>{const e=[];let n=[];for(const o of r())n.push(o),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 2:const o=e.dataFunc.generator;n={type:2,generator:async()=>{const e=[];let n=[];for(const r of await o())n.push(r),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 r of await s())n.push(r),n.length===t&&(e.push(n),n=[]);return n.length&&e.push(n),e}}}return new Ai(n)},vh=(e,t)=>new Ai({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),yh=async(e,t,n=wi)=>{let r;switch(r=nh(e,n?e=>n(t,e):e=>e===t),r.type){case 0:return(await r.generator()).some((e=>e));case 1:return(await Promise.all(r.generator())).some((e=>e));case 2:return(await Promise.all(await r.generator())).some((e=>e))}},mh=async(e,t,n)=>{const r=oh(e,(e=>n(t,e)));switch(r.type){case 1:return(await Promise.all(r.generator())).some((e=>e));case 2:return(await Promise.all(await r.generator())).some((e=>e))}},wh=(e,t)=>t?Ah(e,t):Sh(e),Sh=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},Ah=async(e,t)=>{const n=await e.toArray();let r=0;for(let e=0;e<n.length;e++)!0===t(n[e])&&r++;return r},_h=async(e,t)=>{const n=oh(e,t);let r;switch(n.type){case 1:r=Promise.all(n.generator());break;case 2:r=Promise.all(await n.generator())}let o=0;for(const e of await r)e&&o++;return o},Ch=(e,t)=>{const n=e.dataFunc,r=t instanceof Promise;let o;switch(n.type){case 0:o={generator:()=>n.generator().then((e=>e.length?e:r?t.then((e=>[e])):[t])),type:n.type};break;case 1:o={generator:()=>{const e=n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type};break;case 2:o={generator:async()=>{const e=await n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type}}return new Ai(o)},Th=(e,t=wi)=>new Ai({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),Dh=(e,t)=>new Ai({generator:async()=>{const n=[];e:for(const r of await e.toArray()){for(const e of n)if(await t(e,r))continue e;n.push(r)}return n},type:0}),kh=(e,t)=>new Ai(nh(e,(e=>(t(e),e)))),Eh=(e,t)=>{const n=oh(e,(async e=>(await t(e),e)));return new Ai(n)},bh=async(e,t)=>{if(t<0)throw new vi("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new vi("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new vi("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new vi("index");return await e[t]}}},Ih=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]}}},Gh=(e,t,n=wi)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of r){let t=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),Nh=(e,t,n)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=[];for(const e of r){let t=!1;for(let r=0;r<o.length;r++){const s=o[r];if(!0===await n(e,s)){t=!0;break}}!1===t&&s.push(e)}return s},type:0}),Rh=e=>hh(e.dataFunc),Ph=(e,t)=>t?Uh(e,t):Oh(e),Oh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[0]}}},Uh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===t(e))return e;throw new mi(yi.NoMatch)},Mh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===await t(e))return e;throw new mi(yi.NoMatch)},xh=(e,t)=>t?Lh(e,t):Fh(e),Fh=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]}}},Lh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===t(e))return e;return null},Bh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===await t(e))return e;return null},Wh=(e,t,n)=>n?qh(e,t,n):$h(e,t),$h=(e,t)=>new Ai({generator:async()=>{const n={};for(const r of await e.toArray()){const e=t(r),o=n[e];o?o.push(r):n[e]=new ha(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),qh=(e,t,n)=>new Ai({generator:async()=>{const r=new Array;for(const o of await e.toArray()){const e=t(o);let s=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(o),s=!0;break}}!1===s&&r.push(new ha(e,o))}const o=new Array;for(const e of r)o.push(e);return o},type:0}),Vh=(e,t,n)=>n?Hh(e,t,n):Kh(e,t),Hh=(e,t,n)=>new Ai({generator:async()=>{const r=oh(e,(async e=>[await t(e),e]));let o;switch(r.type){case 1:o=await Promise.all(r.generator());break;case 2:o=await Promise.all(await r.generator())}const s=new Array;for(const[e,t]of o){let r=!1;for(let o=0;o<s.length;o++){const i=s[o];if(!0===await n(i.key,e)){i.push(t),r=!0;break}}!1===r&&s.push(new ha(e,t))}const i=new Array;for(const e of s)i.push(e);return i},type:0}),Kh=(e,t)=>new Ai({generator:async()=>{const n=oh(e,(async e=>[await t(e),e]));let r;switch(n.type){case 1:r=await Promise.all(n.generator());break;case 2:r=await Promise.all(await n.generator())}const o={};for(const[e,t]of r){const n=o[e];n?n.push(t):o[e]=new ha(e,t)}const s=new Array;for(const e in o)s.push(o[e]);return s},type:0}),jh=(e,t,n,r)=>r?zh(e,t,n,r):Jh(e,t,n),zh=(e,t,n,r)=>new Ai({generator:async()=>{const o=new Array;for await(const s of e){const e=t(s);let i=!1;for(let t=0;t<o.length;t++){const a=o[t];if(r(a.key,e)){a.push(n(s)),i=!0;break}}if(!1===i){const t=n(s);o.push(new ha(e,t))}}const s=new Array;for(const e of o)s.push(e);return s},type:0}),Jh=(e,t,n)=>new Ai({generator:async()=>{const r={};for(const o of await e.toArray()){const e=t(o),s=r[e],i=n(o);s?s.push(i):r[e]=new ha(e,i)}const o=new Array;for(const e in r)o.push(r[e]);return o},type:0}),Xh=(e,t,n,r,o,s)=>{const i=s?Yh(e,t,n,r,o,s):Qh(e,t,n,r,o);return new Ai({generator:i,type:0})},Yh=(e,t,n,r,o,s)=>async()=>{const i=[];for await(const e of t){const t=r(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=>{const t=n(e),r=i.find((e=>s(e.key,t)))??{key:t,values:[]};return o(e,r.values)}))},Qh=(e,t,n,r,o)=>async()=>{const s=new Map;for await(const e of t){const t=r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}return(await e.toArray()).map((e=>{const t=n(e),r=s.get(t)??[];return o(e,r)}))},Zh=(e,t,n,r,o,s)=>{const i=s?eg(e,t,n,r,o,s):tg(e,t,n,r,o);return new Ai({generator:i,type:0})},eg=(e,t,n,r,o,s)=>async()=>{const i=[];for await(const e of t){const t=await r(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=>{const t=await n(e),r=i.find((e=>s(e.key,t)))??{key:t,values:[]};return o(e,r.values)}));return await Promise.all(a)},tg=(e,t,n,r,o)=>async()=>{const s=new Map;for await(const e of t){const t=await r(e),n=s.get(t);n?n.push(e):s.set(t,[e])}const i=(await e.toArray()).map((async e=>{const t=await n(e),r=s.get(t)??[];return o(e,r)}));return await Promise.all(i)},ng=(e,t,n=wi)=>new Ai({generator:async()=>{const r=await e.distinct(n).toArray();if(0===r.length)return[];const o=await t.toArray(),s=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===n(t,r)){s.push(t);break}}}return s},type:0}),rg=(e,t,n)=>new Ai({generator:async()=>{const r=await e.distinctAsync(n).toArray();if(0===r.length)return[];const o=await t.toArray(),s=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<o.length;e++){const r=o[e];if(!0===await n(t,r)){s.push(t);break}}}return s},type:0}),og=(e,t,n,r,o,s=wi)=>new Ai({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=r(n);!0===s(t,i)&&c.push(o(e,n))}}return c},type:0}),sg=(e,t)=>t?ag(e,t):ig(e),ig=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[e.length-1]}}},ag=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 r=e[n];if(t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}}throw new mi(yi.NoMatch)},cg=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 r=e[n];if(!0===await t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}}throw new mi(yi.NoMatch)},ug=(e,t)=>t?dg(e,t):lg(e),lg=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]}}},dg=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 r=e[n];if(t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}}return null},hg=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 r=e[n];if(!0===await t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}}return null},gg=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.max.apply(null,r)},pg=async(e,t)=>{const n=oh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.max.apply(null,r)},fg=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.min.apply(null,r)},vg=async(e,t)=>{const n=oh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.min.apply(null,r)},yg=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Ai({generator:async()=>{const t=nh(e,n),r=await hh(t),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0})};async function*mg(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}async function*wg(e,t,n,r){const o=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}class Sg extends Ai{orderedPairs;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,r){let o;return o=e instanceof Sg?async function*(){for await(const o of e.orderedPairs())yield*mg(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Sg(o)}static generate(e,t,n,r){let o;return o=e instanceof Sg?async function*(){for await(const o of e.orderedPairs())yield*wg(o,t,n,r)}:()=>async function*(e,t,n,r){const o=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),o=n.get(e);o?o.push(r):n.set(e,[r])}return n})(e,t),s=[...o.keys()].sort(r||void 0);if(n)for(let e=0;e<s.length;e++)yield o.get(s[e]);else for(let e=s.length-1;e>=0;e--)yield o.get(s[e])}(e,t,n,r),new Sg(o)}thenBy(e,t){return Sg.generate(this,e,!0,t)}thenByAsync(e,t){return Sg.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Sg.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Sg.generateAsync(this,e,!1,t)}}const Ag=(e,t)=>Sg.generate(e,(e=>e),!0,t),_g=(e,t,n)=>Sg.generate(e,t,!0,n),Cg=(e,t,n)=>Sg.generateAsync(e,t,!0,n),Tg=(e,t,n)=>Sg.generate(e,t,!1,n),Dg=(e,t,n)=>Sg.generateAsync(e,t,!1,n),kg=(e,t)=>Sg.generate(e,(e=>e),!1,t),Eg=async(e,t)=>{const n=nh(e,(e=>[t(e),e])),r=await hh(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},bg=async(e,t)=>{const n=oh(e,(async e=>[await t(e),e])),r=await hh(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},Ig=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ai({generator:()=>{const e=n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 2:return new Ai({generator:async()=>{const e=await n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 0:return new Ai({generator:async()=>{const e=await n.generator();return e.unshift(t),e},type:n.type})}},Gg=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Ai({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Ai({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Ng=(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 r=0;r<e.length;r++)n[r]=t(e[r],r);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then((e=>t(e,n)));return r},type:1};case 2:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then((e=>t(e,n)));return r},type:2}}},Rg=(e,t)=>"function"==typeof t?1===t.length?new Ai(nh(e,t)):new Ai(Ng(e,t)):new Ai(nh(e,(e=>e[t]))),Pg=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=t(e[n],n);return r},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}}},Og=(e,t)=>{let n;return n="function"==typeof t?1===t.length?oh(e,t):Pg(e,t):oh(e,(e=>e[t])),new Ai(n)},Ug=(e,t)=>new Ai({generator:async()=>{let n;n="function"==typeof t?1===t.length?nh(e,t):Ng(e,t):nh(e,(e=>e[t]));const r=[];switch(n.type){case 0:for(const e of await n.generator())for(const t of e)r.push(t);break;case 1:for(const e of n.generator())for(const t of await e)r.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)r.push(t)}return r},type:0}),Mg=(e,t)=>new Ai({generator:async()=>{let n;n=1===t.length?oh(e,t):Pg(e,t);const r=[];switch(n.type){case 1:for(const e of n.generator())for(const t of await e)r.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)r.push(t)}return r},type:0}),xg=async(e,t,n=wi)=>{const r=await e.toArray(),o=await t.toArray();if(r.length!==o.length)return!1;for(let e=0;e<r.length;e++)if(!1===n(r[e],o[e]))return!1;return!0},Fg=async(e,t,n)=>{const r=await e.toArray(),o=await t.toArray();if(r.length!==o.length)return!1;for(let e=0;e<r.length;e++){const t=r[e],s=o[e];if(!1===await n(t,s))return!1}return!0},Lg=(e,t)=>t?Wg(e,t):Bg(e),Bg=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return await e[0]}}},Wg=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new mi(yi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new mi(yi.NoMatch);return o},$g=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new mi(yi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new mi(yi.NoMatch);return o},qg=(e,t)=>t?Hg(e,t):Vg(e),Vg=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:await e[0]}}},Hg=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new mi(yi.MoreThanOneElement);r=!0,o=e}return o},Kg=async(e,t)=>{const n=await Rh(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new mi(yi.MoreThanOneElement);r=!0,o=e}return o},jg=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Ai({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Ai({generator:()=>n.generator().slice(t),type:1});case 2:return new Ai({generator:async()=>(await n.generator()).slice(t),type:2})}},zg=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray();let r=0;for(;r<n.length;r++){const e=n[r];if(!1===t(e,r))break}const o=[];for(;r<n.length;r++)o.push(n[r]);return o},type:0}),Jg=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray();let r=0;for(;r<n.length;r++){const e=n[r];if(!1===await t(e,r))break}const o=[];for(;r<n.length;r++)o.push(n[r]);return o},type:0}),Xg=(e,t)=>t?Qg(e,t):Yg(e),Yg=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},Qg=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},Zg=async(e,t)=>{const n=oh(e,t),r=await hh(n);let o=0;for(const e of r)o+=e;return o},ep=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Ai({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Ai({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Ai({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},tp=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray(),r=new Array;if(1===t.length)for(const e of n){if(!0!==t(e))break;r.push(e)}else for(let e=0;e<n.length;e++){const o=n[e];if(!0!==t(o,e))break;r.push(o)}return r},type:0}),np=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray(),r=new Array;if(1===t.length){const e=t;for(const t of n){if(!0!==await e(t))break;r.push(t)}}else for(let e=0;e<n.length;e++){const o=n[e];if(!0!==await t(o,e))break;r.push(o)}return r},type:0}),rp=async(e,t)=>{const n=new Map,r=nh(e,(e=>[t(e),e])),o=await hh(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},op=async(e,t)=>{const n=new Map,r=oh(e,(async e=>[await t(e),e])),o=await hh(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},sp=async(e,t)=>{const n=e.dataFunc,r=await hh(n),o={};for(const e of r)o[t(e)]=e;return o},ip=async(e,t)=>{const n=oh(e,(async e=>[await t(e),e])),r=await hh(n),o={};for(const[e,t]of r)o[e]=t;return o},ap=async e=>{const t=e.dataFunc,n=await hh(t);return new Set(n)},cp=(e,t,n)=>n?lp(e,t,n):up(e,t),up=(e,t)=>new Ai({generator:async()=>{const n=new Set,r=t.toArray();for await(const t of e)!1===n.has(t)&&n.add(t);const o=await r;for(const e of o)!1===n.has(e)&&n.add(e);return[...n.keys()]},type:0}),lp=(e,t,n)=>new Ai({generator:async()=>{const r=[],o=await Promise.all([e.toArray(),t.toArray()]);for(const e of o)for(const t of e){let e=!1;for(const o of r)if(!0===n(t,o)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),dp=(e,t,n)=>new Ai({generator:async()=>{const r=[],o=await Promise.all([e.toArray(),t.toArray()]);for(const e of o)for(const t of e){let e=!1;for(const o of r)if(!0===await n(t,o)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),hp=(e,t)=>new Ai({generator:async()=>(await e.toArray()).filter(t),type:0}),gp=(e,t)=>new Ai({generator:async()=>{const n=Pg(e,(async(e,n)=>[await t(e,n),e])),r=await hh(n),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0}),pp=(e,t,n)=>n?vp(e,t,n):fp(e,t),fp=(e,t)=>new Ai({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]),o=n.length<r.length?n.length:r.length,s=new Array(o);for(let e=0;e<o;e++){const t=n[e],o=r[e];s[e]=[t,o]}return s},type:0}),vp=(e,t,n)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=r.length<o.length?r.length:o.length,i=new Array(s);for(let e=0;e<s;e++){const t=r[e],s=o[e];i[e]=n(t,s)}return i},type:0}),yp=(e,t,n)=>new Ai({generator:async()=>{const[r,o]=await Promise.all([e.toArray(),t.toArray()]),s=r.length<o.length?r.length:o.length,i=new Array(s);for(let e=0;e<s;e++){const t=r[e],s=o[e];i[e]=n(t,s)}return Promise.all(i)},type:0}),mp=e=>{const t=Ci.prototype,n=e.prototype,r=Object.getOwnPropertyNames(t);for(const e of r)n[e]=n[e]??t[e]};fu(_i),(e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(vu,"aggregate"),n(Su,"all"),n(Au,"allAsync"),n(_u,"append"),n(Cu,"any"),n(ku,"anyAsync"),n(Eu,"asParallel"),n(bu,"average"),n(Iu,"averageAsync"),n(Gu,"chunk"),n(Nu,"concatenate"),n(Ru,"contains"),n(Pu,"containsAsync"),n(Ou,"count"),n(xu,"countAsync"),n(Fu,"defaultIfEmpty"),n(Lu,"distinct"),n(Bu,"distinctAsync"),n(Wu,"each"),n($u,"eachAsync"),n(qu,"elementAt"),n(Vu,"elementAtOrDefault"),n(Hu,"except"),n(Ku,"exceptAsync"),n(ju,"first"),n(Xu,"firstAsync"),n(Yu,"firstOrDefault"),n(el,"firstOrDefaultAsync"),n(tl,"groupBy"),n(ol,"groupByAsync"),n(al,"groupByWithSel"),n(ll,"groupJoin"),n(gl,"groupJoinAsync"),n(vl,"intersect"),n(yl,"intersectAsync"),n(ml,"joinByKey"),n(wl,"last"),n(_l,"lastAsync"),n(Cl,"lastOrDefault"),n(kl,"lastOrDefaultAsync"),n(El,"max"),n(Gl,"maxAsync"),n(Nl,"min"),n(Ol,"minAsync"),n(Ul,"ofType"),n(Ml,"order"),n(xl,"orderBy"),n(Fl,"orderByAsync"),n(Ll,"orderByDescending"),n(Bl,"orderByDescendingAsync"),n(Wl,"orderDescending"),n($l,"partition"),n(ql,"partitionAsync"),n(Vl,"prepend"),n(Hl,"reverse"),n(Kl,"select"),n(Xl,"selectAsync"),n(Zl,"selectMany"),n(rd,"selectManyAsync"),n(od,"sequenceEquals"),n(sd,"sequenceEqualsAsync"),n(id,"single"),n(ud,"singleAsync"),n(ld,"singleOrDefault"),n(gd,"singleOrDefaultAsync"),n(pd,"skip"),n(fd,"skipWhile"),n(md,"skipWhileAsync"),n(Ad,"sum"),n(Td,"sumAsync"),n(Dd,"take"),n(kd,"takeWhile"),n(Id,"takeWhileAsync"),n(Rd,"toArray"),n(Pd,"toMap"),n(Od,"toMapAsync"),n(Ud,"toObject"),n(Md,"toObjectAsync"),n(xd,"toSet"),n(Fd,"union"),n(Wd,"unionAsync"),n($d,"where"),n(Hd,"whereAsync"),n(zd,"zip"),n(Yd,"zipAsync")})(Si),(e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(Qd,"aggregate"),n(rh,"all"),n(sh,"allAsync"),n(ih,"append"),n(ah,"any"),n(lh,"anyAsync"),n(dh,"asAsync"),n(gh,"average"),n(ph,"averageAsync"),n(fh,"chunk"),n(vh,"concatenate"),n(yh,"contains"),n(mh,"containsAsync"),n(wh,"count"),n(_h,"countAsync"),n(Ch,"defaultIfEmpty"),n(Th,"distinct"),n(Dh,"distinctAsync"),n(kh,"each"),n(Eh,"eachAsync"),n(bh,"elementAt"),n(Ih,"elementAtOrDefault"),n(Gh,"except"),n(Nh,"exceptAsync"),n(Ph,"first"),n(Mh,"firstAsync"),n(xh,"firstOrDefault"),n(Bh,"firstOrDefaultAsync"),n(Wh,"groupBy"),n(Vh,"groupByAsync"),n(jh,"groupByWithSel"),n(Xh,"groupJoin"),n(Zh,"groupJoinAsync"),n(Xh,"groupJoin"),n(Zh,"groupJoinAsync"),n(ng,"intersect"),n(rg,"intersectAsync"),n(og,"joinByKey"),n(sg,"last"),n(cg,"lastAsync"),n(ug,"lastOrDefault"),n(hg,"lastOrDefaultAsync"),n(gg,"max"),n(pg,"maxAsync"),n(fg,"min"),n(vg,"minAsync"),n(yg,"ofType"),n(Ag,"order"),n(_g,"orderBy"),n(Cg,"orderByAsync"),n(Tg,"orderByDescending"),n(Dg,"orderByDescendingAsync"),n(kg,"orderDescending"),n(Eg,"partition"),n(bg,"partitionAsync"),n(Ig,"prepend"),n(Gg,"reverse"),n(Rg,"select"),n(Og,"selectAsync"),n(Ug,"selectMany"),n(Mg,"selectManyAsync"),n(xg,"sequenceEquals"),n(Fg,"sequenceEqualsAsync"),n(Lg,"single"),n($g,"singleAsync"),n(qg,"singleOrDefault"),n(Kg,"singleOrDefaultAsync"),n(jg,"skip"),n(zg,"skipWhile"),n(Jg,"skipWhileAsync"),n(Xg,"sum"),n(Zg,"sumAsync"),n(ep,"take"),n(tp,"takeWhile"),n(np,"takeWhileAsync"),n(Rh,"toArray"),n(rp,"toMap"),n(op,"toMapAsync"),n(sp,"toObject"),n(ip,"toObjectAsync"),n(ap,"toSet"),n(cp,"union"),n(dp,"unionAsync"),n(hp,"where"),n(gp,"whereAsync"),n(pp,"zip"),n(yp,"zipAsync")})(Ai),(()=>{const{prototype:e}=Ci,t=Object.getOwnPropertyNames(_i.prototype);for(const n of t)e[n]=e[n]??_i.prototype[n];e.all=function(e){return this.every(e)},e.any=function(e){return e?this.some(e):0!==this.length},e.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},e.elementAt=function(e){if(e<0||e>=this.length)throw new vi("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]??null},e.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new mi(yi.NoMatch);return t}if(0===this.length)throw new mi(yi.NoElements);return this[0]},e.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},e.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 mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[this.length-1]},e.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]},e.max=function(e){if(0===this.length)throw new mi(yi.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)},e.min=function(e){if(0===this.length)throw new mi(yi.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)},e.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var wp,Sp;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(wp||(wp={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(Sp||(Sp={}));class Ap{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Ap._devicesService&&(Ap._devicesService=Qv.Get(Ys.ServiceName))}GetDevicesChannelsInGroupAsync(){return e=this,t=arguments,r=function*(e=!1){let t=[],n=[];const r=yield Ap._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){Qv.Get(c.ServiceName).Error("Old controller API fallback to old groups API.");for(let e of r)for(let t of e.Channels.where((e=>e.ChannelGroups.any((e=>e===this._guid)))))n.push(t);return n}const o=Object.keys(this._objectsOrder).map(Number).sort(((e,t)=>e-t));Object.values(this._objectsOrder).forEach((e=>{const n=r.select((t=>t.Channels.where((t=>t.ChannelId===e))));if(null!==n)for(let e of n)for(let n of e)t.push(n)}));for(let e of o){const r=t.firstOrDefault((t=>t.ChannelId===this._objectsOrder[e]));null!==r&&n.push(r)}return n},new((n=void 0)||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}));var e,t,n,r}get Guid(){return this._guid}set Guid(e){this._guid=e}get Name(){return this._name}set Name(e){this._name=e}get IconName(){return this._iconName}set IconName(e){this._iconName=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 Qv.Get(Op.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return Qv.Get(Op.ServiceName).ChangeGroupIconNameAsync(this,e)}}var _p,Cp,Tp,Dp,kp,Ep,bp,Ip,Gp,Np,Rp,Pp=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Op{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._objectsGroupingSupported=!1,this._configurationService=Qv.Get(it.ServiceName),this._connection=Qv.Get(_t.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{Qv.Get(Je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Pp(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}SetObjectsInGroupAndOrderAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r;let o=[],s=[];for(let e of t)if(this.IsDevice(e)){for(let t of e.Channels)o.push(`${t.ChannelId}`);s.push(`${e.Guid}`)}else{if(!this.IsDeviceChannel(e))throw new Error("Passed object is not a device or device channel!");o.push(`${e.ChannelId}`),s.push(`${e.ChannelId}`)}const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new xp(e,s),15e3,!1);switch(null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetObjectsInGroupAndOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),null==i?void 0:i.Status){case ce.OK:return new Ee(wp.Success,"");case ce.NotSupportedMethod:case ce.ResourceDoesNotExists:case ce.ResourceIsNotAvailable:return new Ee(wp.FunctionNotSupported,"");case ce.WrongData:return"GroupDoesNotExists"===i.Data?new Ee(wp.GroupDoesNotExists,i.Data):new Ee(wp.FatalError,i.Data);case ce.Error:case ce.FatalError:default:return new Ee(wp.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=Qv.Get(c.ServiceName);e.forEach(((e,n)=>{t.Debug(Op.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=Qv.Get(c.ServiceName);n.Debug(Op.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(Op.ServiceName,`Channel ${e.Name} order position [on array]: ${t} channelId: ${e.ChannelId}`)}));for(const[t,r]of Object.entries(e.ObjectsOrder))n.Debug(`new order [GROUP ${e.Name}] Order: [${t}] = ${r}`)}ChangeGroupsOrderAsync(e){return Pp(this,void 0,void 0,(function*(){var t,n;const r=e.select((e=>e.Guid)).toArray(),o=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Mp(r),15e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeGroupsOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ce.OK?(yield this.GetGroupsAsync(!1),ce.OK):(Qv.Get(c.ServiceName).Error(Op.ServiceName,`Failed to change groups order, controller responded with error ${null==o?void 0:o.Status} data: ${null==o?void 0:o.Data}`),this.LogGroupsOrder(e),null==o?void 0:o.Status)}))}ChangeObjectsPositionsInGroupAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;const s=t.select((e=>e.ChannelId)).toArray(),i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Wp(e.Guid,s),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeObjectsPositionsInGroupAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ce.OK?(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),ce.OK):(null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to change objects positions in group, controller responded with error ${null==i?void 0:i.Status} data: ${null==i?void 0:i.Data}`),this.LogObjectsInGroupOrder(e,t),null==i?void 0:i.Status)}))}IsGroupsAndObjectsOrderingAvailable(){return this._objectsGroupingSupported}MoveGroupPositionAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Up(e.Guid,t),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ce.OK?(yield this.GetGroupsAsync(!1),ce.OK):(null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to move group position, controller responded with error ${null==s?void 0:s.Status} data: ${null==s?void 0:s.Data}`),null==s?void 0:s.Status)}))}MoveObjectInGroupPositionAsync(e,t,n){return Pp(this,void 0,void 0,(function*(){var r,o,s;const i=`${t.GetDevice().Guid}_${t.Number}`,a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Bp(e.Guid,i,n),15e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveObjectInGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==a?void 0:a.Status)===ce.OK?(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),ce.OK):(null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,`Failed to move object in group position, controller responded with error ${null==a?void 0:a.Status} data: ${null==a?void 0:a.Data}`),null==a?void 0:a.Status)}))}AddDeviceChannelToGroupByGuidAsync(e,t){return Pp(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s,i;const a=new jp;if(a.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");a.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,a.Data.GroupGuid=t;const c=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(a,15e3,!1);return null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddDeviceChannelToGroupByGuidAsync()"),this._configurationService.ExitConfigurationModeAsync(),null!=c&&null!=c.Status?(c.Status==ce.OK?e.ChannelGroups.push(t):null===(i=u.Log)||void 0===i||i.Error(Op.ServiceName,`Failed to add device channel ${e.Name} to group ${t}, controller responded with error ${c.Status} data: ${c.Data}`),n||(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync()),c.Status):(n||(yield this.GetGroupsAsync(!1),yield Qv.Get(Ys.ServiceName).GetDevicesAsync()),ce.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){return Pp(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s;const i=new zp;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");i.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,i.Data.Channel=e.Number,i.Data.GroupGuid=t;const a=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(i,15e3,!1);return n||this._configurationService.ExitConfigurationModeAsync(),null!=a&&null!=a.Status?(a.Status==ce.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,`Failed to remove device channel ${e.Name} from group ${t}, controller responded with error ${a.Status} data: ${a.Data}`),n||(yield this.GetGroupsAsync(!1)),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),a.Status):(n||(yield this.GetGroupsAsync(!1)),yield Qv.Get(Ys.ServiceName).GetDevicesAsync(),ce.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupWithIconAsync(e.Name,e.IconName);if(!(t instanceof Ap))return t instanceof Ee?t:new Ee(Sp.UnknownError,"");e=t}for(let r of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(r,e,!0);if(t!==ce.OK)return null===(n=u.Log)||void 0===n||n.Error(Op.ServiceName,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`),new Ee(Sp.UnknownError,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`)}let s=yield Qv.Get(Ys.ServiceName).GetDevicesAsync();for(let n of s)for(let s of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var i of s.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(s,e,!0);if(t!==ce.OK)return null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,`Failed to remove device channel ${s.Name} from group ${e.Name}, controller responded with error ${t}`),null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpsertGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),new Ee(Sp.UnknownError,`Failed to remove device channel ${s.Name} from group ${e.Name}, controller responded with error ${t}`)}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o,s;for(let o of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(o,e,!0);if(t!==ce.OK)return null===(n=u.Log)||void 0===n||n.Error(Op.ServiceName,`Failed to add device channel ${o.Name} to group ${e}, controller responded with error ${t}`),null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ce.FatalError}let i=yield Qv.Get(Ys.ServiceName).GetDevicesAsync();for(let n of i)for(let r of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var a of r.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(r,e,!0);if(t!==ce.OK)return null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to remove device channel ${r.Name} from group ${e}, controller responded with error ${t}`),null===(s=u.Log)||void 0===s||s.Error(Op.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ce.FatalError}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ce.OK}))}ChangeGroupNameByGuidAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r;let o=new Kp,s=new Jp,i=this._groups.first((t=>t.Guid===e));s.Guid=e,s.Name=t,s.IconName=i.IconName,null===(n=o.Data)||void 0===n||n.push(s);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return new Ee(Sp.Success,"");case ce.WrongData:switch(a.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sp.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){return Pp(this,void 0,void 0,(function*(){var r,o;let s=new Kp,i=new Jp,a=this._groups.first((t=>t.Guid===e));i.Guid=e,i.Name=t,i.IconName=n,i.ObjectsOrder=a.ObjectsOrder,null===(r=s.Data)||void 0===r||r.push(i);const c=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(s,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=c&&null!=c.Status)switch(c.Status){case ce.OK:return new Ee(Sp.Success,"");case ce.WrongData:switch(c.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Ee(Sp.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r;let o=new Kp,s=new Jp,i=this._groups.first((t=>t.Guid===e));s.Guid=e,s.Name=i.Name,s.IconName=t,null===(n=o.Data)||void 0===n||n.push(s);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return new Ee(Sp.Success,"");case ce.WrongData:switch(a.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sp.UnknownError,"")}))}GetServiceName(){return Op.ServiceName}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}GetGroupByGuid(e){return this._groups.first((t=>t.Guid===e))}ChangeGroupNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}ChangeGroupIconNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}RemoveGroupAsync(e){return this.RemoveGroupByGuidAsync(e.Guid)}RemoveGroupByGuidAsync(e){return Pp(this,void 0,void 0,(function*(){var t;let n=new Vp;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=r&&null!=r.Status?null==r?void 0:r.Status:ce.Error}))}GetGroupsAsync(){return Pp(this,arguments,void 0,(function*(e=!0){var t,n;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Hp,15e3,e);let o=[];if((null==r?void 0:r.Status)===ce.OK){let t=0,s=Qv.Get(c.ServiceName),i=yield Qv.Get(Ys.ServiceName).GetDevicesAsync();return null===(n=r.Data)||void 0===n||n.forEach((n=>{t++;let r=new Ap;if(r.Guid=n.Guid,r.Name=n.Name,r.IconName=n.IconName,r.ObjectsOrder=n.ObjectsOrder,r.OrderPosition=n.OrderPosition,null==r.OrderPosition&&(r.OrderPosition=t),null==r.ObjectsOrder){this._objectsGroupingSupported=!1,r.ObjectsOrder={};let e=i.selectMany((e=>e.Channels.where((e=>e.ChannelGroups.any((e=>e==r.Guid)))))),t=0;for(let n of e)t++,r.ObjectsOrder[t]=n.ChannelId}else this._objectsGroupingSupported=!0;e||s.Info(Op.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),o.push(r)})),this._groups=o,o}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,n=!1){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid,n)}RemoveDeviceChannelFromGroupAsync(e,t,n=!1){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid,n)}AddNewGroupAsync(e){return Pp(this,void 0,void 0,(function*(){var t,n,r;let o=new Kp,s=new Jp;s.Name=e,null===(t=o.Data)||void 0===t||t.push(s);const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=i&&null!=i.Status)switch(i.Status){case ce.OK:return this._groups.first((t=>t.Name===e));case ce.WrongData:switch(null===(r=u.Log)||void 0===r||r.Error(Op.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Ee(Sp.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){return Pp(this,void 0,void 0,(function*(){var n,r,o;let s=new Kp,i=new Jp;i.Name=e,i.IconName=t,null===(n=s.Data)||void 0===n||n.push(i);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(s,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return this._groups.first((t=>t.Name===e));case ce.WrongData:switch(null===(o=u.Log)||void 0===o||o.Error(Op.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new Ee(Sp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sp.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sp.UnknownError,"")}))}}Op.ServiceName="ChannelsGroupsService";class Up extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ue.Post,this.Data=new Lp,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Mp extends ae{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ue.Post,this.Data=e}}class xp extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=ue.Post,this.Data=new Fp,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Fp{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Lp{constructor(){this.GroupGuid="",this.NewPosition=0}}class Bp extends ae{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ue.Post,this.Data=new $p,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Wp extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ue.Post,this.Data=new qp,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class $p{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class qp{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Vp extends ae{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ue.Delete}}class Hp extends ae{constructor(){super(),this.Resource="/devices/groups/",this.Method=ue.Get}}class Kp extends ae{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ue.Put,this.Data=[]}}class jp extends ae{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ue.Put,this.Data=new Xp}}class zp extends ae{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ue.Delete,this.Data=new Xp}}class Jp{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class Xp{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Yp{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class Qp{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class Zp{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class ef{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(_p||(_p={})),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"}(Cp||(Cp={})),(Rp=Tp||(Tp={}))[Rp.WaitingForUser=1]="WaitingForUser",Rp[Rp.Downloading=2]="Downloading",Rp[Rp.Unpackaging=3]="Unpackaging",Rp[Rp.CheckingApplicability=4]="CheckingApplicability",Rp[Rp.MigratingData=5]="MigratingData",Rp[Rp.CreatingBackup=6]="CreatingBackup",Rp[Rp.Deploying=7]="Deploying",Rp[Rp.Installing=8]="Installing",Rp[Rp.Removing=9]="Removing",Rp[Rp.Error=10]="Error",Rp[Rp.ReadyToDownload=11]="ReadyToDownload",Rp[Rp.PreparingSystem=12]="PreparingSystem",Rp[Rp.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",Rp[Rp.CheckingIntegrity=14]="CheckingIntegrity",Rp[Rp.UndoingInstallation=15]="UndoingInstallation",Rp[Rp.Installed=16]="Installed",(Np=Dp||(Dp={}))[Np.Ignore=0]="Ignore",Np[Np.Cancel=1]="Cancel",Np[Np.Install=2]="Install";class tf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=Cp.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class nf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=bp.Unknown}}class rf{constructor(){this.BulkUpdateStatus=kp.Success,this.DevicesUpdateResults=new Map}}!function(e){e[e.Success=0]="Success",e[e.PartialSuccess=1]="PartialSuccess",e[e.UpdatesNotFound=2]="UpdatesNotFound",e[e.CannotUnpairRetransmitters=3]="CannotUnpairRetransmitters",e[e.CannotPairRetransmitters=4]="CannotPairRetransmitters"}(kp||(kp={})),function(e){e[e.Unknown=0]="Unknown",e[e.Updated=1]="Updated",e[e.InsufficientConnection=2]="InsufficientConnection",e[e.Error=3]="Error",e[e.UnknownError=4]="UnknownError",e[e.ControllerSoftwareTooOld=5]="ControllerSoftwareTooOld"}(Ep||(Ep={})),function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate"}(bp||(bp={})),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",e[e.RetransmitterFound=10]="RetransmitterFound",e[e.ProtocolRadioUnsupported=11]="ProtocolRadioUnsupported",e[e.FeatureUnsupportedInCurrentVersion=12]="FeatureUnsupportedInCurrentVersion",e[e.CannotGetUpdatesBranch=13]="CannotGetUpdatesBranch",e[e.CannotSetUpdatesBranch=14]="CannotSetUpdatesBranch",e[e.UpdateAlreadyDownloaded=15]="UpdateAlreadyDownloaded",e[e.UpdateDownloadFailed=16]="UpdateDownloadFailed",e[e.UpdateAlreadyInstalled=17]="UpdateAlreadyInstalled",e[e.CannotGetCurrentControllerVersionTimeout=18]="CannotGetCurrentControllerVersionTimeout",e[e.CannotGetCurrentControllerVersion=19]="CannotGetCurrentControllerVersion",e[e.InstallerFileSignCheckFailed=20]="InstallerFileSignCheckFailed",e[e.UpdateFileSignCheckFailed=21]="UpdateFileSignCheckFailed",e[e.UpdateFileCheckFailed=22]="UpdateFileCheckFailed",e[e.UpdateInstallationFailed=23]="UpdateInstallationFailed"}(Ip||(Ip={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(Gp||(Gp={}));var of,sf,af,cf,uf,lf,df,hf,gf=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class pf{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=15,this._updateProviders=Qv.Get(os.ServiceName),this._logger=Qv.Get(c.ServiceName),this._connection=Qv.Get(_t.ServiceName),this._appStateService=Qv.Get(Js.ServiceName),this._extensionService=Qv.Get(tt.ServiceName)}GetAutomaticControllerUpdateDownloadStatusAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new Gf,1e4,!1);return!(r.Status!=ce.OK||!r.Data)}))}GetServiceName(){return pf.ServiceName}CheckDeviceVersionAsync(e){return gf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(Ip.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ee(Ip.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Io.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){return gf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(Ip.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ee(Ip.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Io.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const o=new yf;o.CurrentResourceVersion=r.CurrentResourceVersion,o.NewResourceVersion=r.Update.Version,o.UpdatedResourceName=r.UpdatedResourceName,o.UpdateResourceGuid=r.Update.ResourceGuid,o.UpdateDescription=new Map([["pl-PL",r.Update.Description]]);let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(n.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}return o.Protocol=s,o.ProtocolGuid=n.ProtocolGuid,(yield Qv.Get(Ys.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(o.IsUpdateSafe=!1),o}))}CheckDeviceUpdatesBulkAsync(e){return gf(this,void 0,void 0,(function*(){const t=yield yield this._updateProviders.GetUpdatesProvidersAsync(Io.Device),n=[];for(var r of t){const t=yield r.CheckUpdateBulkAsync(e);if(t instanceof Ee)return t;t.map((e=>gf(this,void 0,void 0,(function*(){const t=new yf;t.CurrentResourceVersion=e.CurrentResourceVersion,t.NewResourceVersion=e.Update.Version,t.UpdatedResourceName=e.UpdatedResourceName,t.UpdateDescription=e.UpdateDescription,t.IsUpdateSafe=!0;let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(r.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}t.Protocol=o,t.ProtocolGuid=r.ProtocolGuid,t.UpdateResourceGuid=e.Update.ResourceGuid,n.push(t)}))))}return n}))}InstallDeviceUpdateAsync(e,t,n){return gf(this,arguments,void 0,(function*(e,t,n,r=!1){var o;let s;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(Ip.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);s=t}else s=e;if(null==s.ProtocolGuid)return new Ee(Ip.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(o=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(s.ProtocolGuid,Io.Device)).first())||void 0===o?void 0:o.GetAvailableUpdateAsync(s);if(null!=i.Type)return i;this._appStateService.DisallowHibernation();const a=yield(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(s.ProtocolGuid,Io.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ce.OK)}))}InstallDevicesUpdateBulkAsync(e,t,n){return gf(this,void 0,void 0,(function*(){const r=(yield Qv.Get(Ys.ServiceName).GetDevicesAsync()).where((t=>e.includes(t.Guid))).groupBy((e=>e.ProtocolGuid)),o=[];this._appStateService.DisallowHibernation();const s=r.count();for(let e=0;e<s;e++){const i=r.elementAt(e),a=e*(100/s),c=(e+1)*(100/s),u=e=>{e.PercentageTotal=Math.floor(e.PercentageTotal/100*(c-a)+a),t(e)},l=yield yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(i.key,Io.Device),d=yield l.first().InstalUpdateBulkAsync(i.select((e=>e.Guid)).toArray(),u,n);if(d instanceof Ee)return d;o.push(d)}if(this._appStateService.AllowHibernation(),1==o.length)return o[0];{const e=new rf;o.some((e=>e.DevicesUpdateResults.count()>0))&&o.any((e=>e.BulkUpdateStatus!=kp.Success))?e.BulkUpdateStatus=kp.PartialSuccess:o.any((e=>e.BulkUpdateStatus!=kp.Success))?e.BulkUpdateStatus=o.first().BulkUpdateStatus:e.BulkUpdateStatus=kp.Success;for(const t of o)t.DevicesUpdateResults.forEach(((t,n)=>{e.DevicesUpdateResults.set(n,t)}));return e}}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return gf(this,void 0,void 0,(function*(){const e=Qv.Get(Je.ServiceName).User;if(null==e)return!1;if(""==e.SoftwareVersion||null==e.SoftwareVersion)return!0;const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<this._oldUpdateVersion||parseFloat(t)==this._oldUpdateVersion&&parseFloat(n)<=this._oldUpdateBuild)return!0;const r=yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1);if(null==r||r.Status!=ce.OK||null==r.Data)return!1;const[o,s]=r.Data.Update.Version.ContainerSoftwareVersion.toString().split(".");return parseInt(o)>parseInt(t)||parseInt(o)==parseInt(t)&&parseInt(s)>parseInt(n)}))}CanCancelFailedControllerUpdateOrGetPendingUpdateProgress(){return Qv.Get(it.ServiceName).CheckIfControllerSoftwareVersionIsEnough(6,66)}CancelFailedControllerUpdateAsync(){return gf(this,void 0,void 0,(function*(){switch((yield this._connection.SendAndWaitForResponseAsync(new Tf,1e4,!1)).Status){case ce.OK:return ce.OK;case ce.OperationNotPermitted:return ce.OperationNotPermitted;case ce.Error:default:return ce.Error}}))}CheckControllerPendingUpdateProgressAsync(e,t){return gf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>gf(this,void 0,void 0,(function*(){const o=Qv.Get(Je.ServiceName).User;if(null==o)return new Ee(Ip.UpdateActionsNotSupported,"No user data found, cannot check pending update progress.");if(""==o.SoftwareVersion||null==o.SoftwareVersion)return new Ee(Ip.CannotGetCurrentControllerVersion,"No software version data found, cannot check pending update progress.");const[s,i]=o.SoftwareVersion.split(".");if(parseFloat(s)<this._oldUpdateVersion||parseFloat(s)==this._oldUpdateVersion&&parseFloat(i)<=this._oldUpdateBuild)return new Ee(Ip.UnsupportedApiVersion,"Not supported API version, cannot check pending update progress.");let a=100;const c=60*this._updateOfflineStageTime*1e3;let u=0;const l=new tf;let d=new nf,h=new tf,g=!1;const p=n=>{let r=n.Data;switch(this._logger.Debug(`Update progress: ${r.UpdateStep}, ${r.StepProgressInPercentage}%, ${r.UpdateProgressInPercentage}% data frame status: ${n.Status}`),l.Percentage=Math.round(r.StepProgressInPercentage),l.PercentageTotal=Math.round(r.UpdateProgressInPercentage),d.SpeedMbps=r.DownloadSpeedInMbs,d.Percentage=Math.round(r.StepProgressInPercentage),d.PercentageTotal=Math.round(r.UpdateProgressInPercentage),h.AvailableUpdates=1,h.Percentage=r.StepProgressInPercentage,h.PercentageTotal=r.UpdateProgressInPercentage,h.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),u=r.StepProgressInPercentage,r.UpdateStep){case cf.DownloadingInstaller:d.CurrentTask=bp.DownloadingInstaller,h.Status=Cp.DownloadingPackage,t(d);break;case cf.DownloadingUpdate:d.CurrentTask=bp.DownloadingUpdate,h.Status=Cp.DownloadingPackage,t(d);break;case cf.CheckingUpdate:d.CurrentTask=bp.CheckingUpdate,h.Status=Cp.CheckingPackage,e(h);break;case cf.PreparingUpdate:h.Status=Cp.PreparingForUpgrade,d.CurrentTask=bp.CheckingUpdate,e(h);break;case cf.OfflineUpdateStep:case cf.InstallingUpdate:h.Status=Cp.Upgrading,e(h);break;case cf.InstallerFileSignCheckFailed:case cf.UpdateFileSignCheckFailed:h.Status=Cp.InstallationError,e(h);break;case cf.UpdateDownloadFailed:h.Status=Cp.InstallationStopped,e(h);break;case cf.UpdateInstallationFailed:h.Status=Cp.InstallationError,e(h);break;case cf.UpdateFileCheckFailed:h.Status=Cp.IncompatiblePackage,e(h);break;case cf.UpdateDownloaded:h.Status=Cp.CheckingPackage,e(h)}};let f=null;const v=t=>gf(this,void 0,void 0,(function*(){t==Os.Connected&&(clearInterval(f),l.Status=Cp.Upgraded,l.Percentage=100,l.PercentageTotal=100,e(l),clearInterval(f),yield se.Delay(5e3),n(ce.OK),Qv.Get(Js.ServiceName).OnAppStateChanged().Unsubscribe(v))}));yield this._connection.SendAndHandleResponseAsync(new Df,1e5,(t=>{var o,s,i;switch(t.Status){case ce.MultiDataResponseStart:g||(a=(null===(o=t.Data)||void 0===o?void 0:o.UpdateStep)==cf.UpdateDownloaded?100:50,g=!0),p(t);break;case ce.MultiDataResponse:p(t);break;case ce.MultiDataResponseStop:switch(null===(s=t.Data)||void 0===s?void 0:s.UpdateStep){case cf.UpdateInstallationFailed:h.Status=Cp.InstallationError,e(h),l.Percentage=0,l.PercentageTotal=0,e(l),n(new Ee(Ip.CannotProcessUpdate,"Update installation failed!"));break;case cf.InstallerFileSignCheckFailed:case cf.UpdateFileSignCheckFailed:case cf.UpdateDownloadFailed:case cf.UpdateFileCheckFailed:h.Status=Cp.DownloadingFailure,e(h),l.Percentage=0,l.PercentageTotal=0,e(l),n(new Ee(Ip.UpdateDownloadFailed,"Update download failed!"));break;case cf.OfflineUpdateStep:p(t),l.Percentage=Math.round(t.Data.StepProgressInPercentage),l.PercentageTotal=Math.round(t.Data.UpdateProgressInPercentage);let r=(100-l.PercentageTotal)/100,o=l.PercentageTotal;f=setInterval((()=>{u++,o+=r,o>100&&(o=100),u>=a?(l.Status=Cp.Upgraded,l.Percentage=100,l.PercentageTotal=100,e(l),clearInterval(f),n(ce.OK)):(l.Status=Cp.Upgrading,l.Percentage=Math.round(u),l.PercentageTotal=Math.round(o),e(l))}),c/(a-u)),Qv.Get(Js.ServiceName).OnAppStateChanged().Subscribe(v);break;case cf.UpdateDownloaded:l.Status=Cp.DownloadingPackage,l.Percentage=100,l.PercentageTotal=100,e(l),n(ce.OK);break;default:p(t),n(new Ee(Ip.CannotProcessUpdate,`Update installation failed, received UpdateStep code: ${null===(i=t.Data)||void 0===i?void 0:i.UpdateStep}!`))}break;default:r(new Ee(Ip.CannotGetUpdates,`Cannot get pending update progress, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`))}}),!0)}))))}))}CheckDevicesUpdatesAvailabilityAsync(){return gf(this,void 0,void 0,(function*(){const e=Qv.Get(Je.ServiceName).User;if(null==e)return[];if(""==e.SoftwareVersion||null==e.SoftwareVersion)return[];const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<6||6==parseFloat(t)&&parseFloat(n)<=4)return[];const r=yield this._connection.SendAndWaitForResponseAsync(new Of,1e4,!1),o=[];return null==r||(null==r?void 0:r.Status)!=ce.OK||null==(null==r?void 0:r.Data)?[]:(null==r||r.Data.forEach((e=>{if(!e.IsAvailable)return;const t=new Yp;t.DeviceGuid=e.DeviceGuid,t.CurrentVersion=e.CurrentVersion,t.NewVersion=e.NewVersion,o.push(t)})),o)}))}CheckControllerUpdatesAsync(){return gf(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new Qp,n=yield this.getRuntimeInfoAsync();if(n instanceof Ee){const e=new ff;return e.UpdateType=_p.SoftwareUpdate,e.ResponseResult=n,t.UpdatesNotAvailable.push(e),t}const r=parseInt(n.SoftwareVersion.toString().split(".")[0]),o=parseInt(n.SoftwareVersion.toString().split(".")[1]);try{e=yield this._updateProviders.GetUpdatesProvidersAsync(Io.Controller)}catch(e){if(!(e instanceof Fo))throw e;this._logger.Warning("Cannot get update providers for controller protocols! Avaliable only controller software updates!")}for(let n=0;n<e.length;n++){const r=yield e[n].GetAvailableRadioUpdateAsync();if(null!=r.Type){const o=new ff;o.ResponseResult=r,o.UpdateType=_p.RadioUpdate;let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(e[n].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}o.UpdatedResourceName=new Map([["pl-PL",s],["en-US",s]]),o.CurrentResourceVersion=yield e[n].GetCurrentRadioVersionAsync(),t.UpdatesNotAvailable.push(o)}else{const o=r,s=new vf;s.UpdatedResourceName=new Map([["pl-PL",o.UpdatedResourceName],["en-US",o.UpdatedResourceName]]),s.CurrentResourceVersion=o.CurrentResourceVersion,s.NewResourceVersion=o.Update.Version,s.UpdateDescription=new Map([["pl-PL",o.Update.Description]]),s.UpdateType=_p.RadioUpdate,s.UpdateIdentifier=oe.GenerateUUID(),s.UpdateIsDownloading=!1,s.DownloadProgress=100,s.UpdateCreationTime=null,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},o),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:e[n].GetUpdateProviderName(),UpdateType:_p.RadioUpdate}))}}let s=!0;if((r<this._oldUpdateVersion||r===this._oldUpdateVersion&&o<=this._oldUpdateBuild)&&(s=!1),s){const e=yield this._connection.SendAndWaitForResponseAsync(new kf,15e3,!1);if(null==e||e.Status!=ce.OK&&e.Status!=ce.NoData)throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);if(null!=e.Data){const r=new xo;r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,r.UpdateDescription=ie(e.Data.Update.UpdateDescription),r.UpdatedResourceName=ie(e.Data.Update.UpdateName).get("en-US");const o=new vf;o.UpdatedResourceName=ie(e.Data.Update.UpdateName),o.UpdateDescription=ie(e.Data.Update.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.NewResourceVersion=`${e.Data.Update.Version.BaseRuntime}.${e.Data.Update.Version.ContainerSoftwareVersion}`,o.UpdateType=_p.SoftwareUpdate,o.UpdateIdentifier=e.Data.Update.Guid,o.UpdateIsDownloading=e.Data.UpdateStep==cf.DownloadingInstaller||e.Data.UpdateStep==cf.DownloadingUpdate||e.Data.UpdateStep==cf.CheckingUpdate,o.DownloadProgress=e.Data.DownloadProgress,o.UpdateCreationTime=e.Data.Update.Creationtime,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:pf.ServiceName,UpdateType:_p.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Ef,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ce.NoData:const r=new ff;r.UpdateType=_p.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ee(Ip.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ce.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const o=new xo;o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateDescription=ie(e.Data.UpdateDescription),o.UpdatedResourceName=ie(e.Data.UpdateName).get("en-US");const s=new vf;s.UpdatedResourceName=ie(e.Data.UpdateName),s.UpdateDescription=ie(e.Data.UpdateDescription),s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateType=_p.SoftwareUpdate,s.UpdateIdentifier=e.Data.Guid,s.NewResourceVersion=`${e.Data.Version.BaseRuntime}.${e.Data.Version.ContainerSoftwareVersion}`,s.UpdateIsDownloading=!1,s.DownloadProgress=0,s.UpdateCreationTime=e.Data.Creationtime,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},o),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:pf.ServiceName,UpdateType:_p.SoftwareUpdate}));break;default:throw new Error(`Cannot check updates! Response status is not OK. Status: ${e.Status}`)}}}else{const e=`https://exalus-updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const r=yield fetch(e);let o,s=new xo;const i=new ff;switch(i.UpdateType=_p.SoftwareUpdate,i.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.status){case 200:null!=r.body&&(o=yield r.json());break;case 404:i.ResponseResult=new Ee(Ip.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Ee(Ip.CannotGetUpdates,`Response status code does not indicate success. Status: ${r.status}`),t.UpdatesNotAvailable.push(i)}if(null!=o){s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.Update=o;const e=new vf;e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.CurrentResourceVersion=s.CurrentResourceVersion,e.NewResourceVersion=s.Update.Version,e.UpdateDescription=new Map([["pl-PL",s.Update.Description]]),e.UpdateType=_p.SoftwareUpdate,e.UpdateIdentifier=oe.GenerateUUID(),e.DownloadProgress=100,e.UpdateIsDownloading=!1,e.UpdateCreationTime=null,t.UpdatesAvailable.push(e),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:e.UpdateIdentifier,ProviderName:pf.ServiceName,UpdateType:_p.SoftwareUpdate}))}else if(200==r.status)throw new Error(`Cannot get Update Data from response. Status: ${r.status}`)}catch(e){const n=yield this.getRuntimeInfoAsync();if(n instanceof Ee){const e=new ff;e.UpdateType=_p.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new ff;r.UpdateType=_p.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ee(Ip.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Io.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Ee)return t;const n=[];let r;r=new ef,r.Resource="Controller software",r.Type=_p.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new ef,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=_p.RadioUpdate;let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(e[t].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}r.Resource=o,n.push(r)}return n}))}GetControllerUpdateBranchAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new _f,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ce.OK)return new Ee(Ip.CannotGetUpdatesBranch,`Cannot get update branch, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data){case 0:return Gp.Public;case 1:return Gp.Beta;case 2:return Gp.Development;default:return new Ee(Ip.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return gf(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Ee)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);if(n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const o=yield this._connection.SendAndWaitForResponseAsync(new Cf(e),1e4,!1);return null==o||(null==o?void 0:o.Status)!=ce.OK?new Ee(Ip.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`):ce.OK}))}EnableAutomaticControllerUpdateDownloadAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Nf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ce.OK?new Ee(Ip.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ce.OK}))}DisableAutomaticControllerUpdateDownloadAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Rf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ce.OK?new Ee(Ip.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ce.OK}))}GetControllerUpdatesHistoryAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(Ip.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Pf,1e4,!1);if(null==r)return new Ee(Ip.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ce.OK:return null!=r.Data?r.Data.map((e=>{const t=new Zp;return t.UpdatedResourceName=ie(e.UpdateName),t.UpdateDescription=ie(e.UpdateDescription),t.UpdateCreationTime=e.Creationtime,t.UpdateChannel=e.UpdateChannel,t.Version=`${e.Version.BaseRuntime}.${e.Version.ContainerSoftwareVersion}`,t})):new Ee(Ip.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ce.NoData:return[];default:return new Ee(Ip.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,o){return gf(this,void 0,void 0,(function*(){const s=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),i=this._controllerUpdates.length,a=yield this.getRuntimeInfoAsync();if(a instanceof Ee)return a;const c=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ee(Ip.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if("string"!=typeof n||!s.test(n)){const o=[1],s=t=>{t.UpdateNumber=o[0],t.AvailableUpdates=i,e(t)},a=e=>gf(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==_p.RadioUpdate)).toArray(),d=[];this._appStateService.DisallowHibernation();for(let e=0;e<l.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(l[e].ProviderName)).InstallRadioUpdateAsync(l[e],s,n);yield a(5e3),t==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=l[e].UpdateIdentifier))),d.push(t),o[0]++}const h=this._controllerUpdates.find((e=>e.UpdateType==_p.SoftwareUpdate));if(null!=h)if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,s);e==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=h.UpdateIdentifier))),d.push(e),o[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(s,t,r);this._appStateService.AllowHibernation(),e==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),d.push(e),o[0]++}const g=d.where((e=>e instanceof Ee)).toArray();if(null!=g&&0!=g.length){let e="";return g.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),g.any((e=>e.Type==Ip.UpdateDownloadFailed))?new Ee(Ip.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ee(Ip.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ce.OK}{let s;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Ee(Ip.CannotGetUpdates,`Update with requested guid (${n}) not found.`);switch(this._logger.Debug(`Installing single update type: ${i.Update.UpdateType}, resource: ${i.UpdatedResourceName}, version: ${i.Update.Version}`),this._appStateService.DisallowHibernation(),i.UpdateType){case _p.RadioUpdate:return r?new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it."):(s=yield(yield this._updateProviders.GetUpdatesProviderAsync(i.ProviderName)).InstallRadioUpdateAsync(i,e,o),this._appStateService.AllowHibernation(),s==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),s);case _p.SoftwareUpdate:if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");s=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),s==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else s=yield this.UpdateControllerUsingApiAsync(e,t,r),this._appStateService.AllowHibernation(),s==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)));return s;default:return new Ee(Ip.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){return gf(this,void 0,void 0,(function*(){var n,r,o,s,i,a;switch(e.UpdateType){case Go.Container:case Go.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new mf(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new tf;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ce.MultiDataResponseStart:r.Status=Cp.PreparingForUpgrade;break;case ce.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(pf.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case Tp.CheckingApplicability:case Tp.CheckingIntegrity:case Tp.CheckingPackageIntegrity:r.Status=Cp.CheckingPackage;break;case Tp.CreatingBackup:case Tp.MigratingData:case Tp.Removing:r.Status=Cp.MovingData;break;case Tp.Deploying:case Tp.Installing:r.Status=Cp.Upgrading;break;case Tp.Downloading:r.Status=Cp.DownloadingPackage;break;case Tp.Error:r.Status=Cp.Error;break;case Tp.Installed:r.Status=Cp.Upgraded;break;case Tp.PreparingSystem:case Tp.ReadyToDownload:r.Status=Cp.PreparingForUpgrade;break;case Tp.UndoingInstallation:r.Status=Cp.InstallationStopped;break;case Tp.Unpackaging:r.Status=Cp.MovingData;break;case Tp.WaitingForUser:r.Status=Cp.Upgrading}break;case ce.MultiDataResponseStop:r.Status=Cp.OK;break;case ce.Error:case ce.FatalError:r.Status=Cp.Error}t(r)}),!1),ce.OK}catch(e){return new Ee(Ip.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case Go.RuntimeFixingScript:var c=10;let d="n/a";try{d=(yield this._extensionService.GetExtensionsInfoAsync()).first((e=>"f4f45dac-beda-441a-8d29-efc6dc977cd1"==e.ExtensionGuid)).ExtensionVersion}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}var u=d;const h=yield this.getRuntimeInfoAsync();if(h instanceof Ee)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield Qv.Get(Ys.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(pf.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new tf;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=Cp.PreparingForUpgrade,t(r);let o=2;const s=Date.now(),i=900*c+8e5,a=i/100,u=s+i,l=new Promise(((s,c)=>gf(this,void 0,void 0,(function*(){var c;try{const l=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(l),Date.now()>u)clearInterval(n),this._logger.Debug("Update already finished!"),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgraded,t(r),s(ce.OK);else{var e=u-Date.now();e<i?o=95-e/a:(clearInterval(n),n=setInterval((()=>{clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgraded,t(r),s(ce.OK)}),e))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),n=setInterval((()=>{if(o>99)clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgraded,t(r),s(ce.OK);else{var e=o;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Upgrading,t(r))}o++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new wf(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ce.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.InstallationError,t(r),this._logger.Debug(pf.ServiceName,`Update failed with error. Update response status: ${d.Status}`),s(new Ee(Ip.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(pf.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cp.Error,t(r),clearInterval(n),s(new Ee(Ip.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new tf;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Ee(Ip.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Sf({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ce.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n);let r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Af("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ce.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n),r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Af(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ce.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Af("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ce.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgrading,t(n);let e,r=0;const o=.95,s=Date.now(),i=900*c+15e5,a=i/95,u=s+i,l=new Promise(((s,c)=>gf(this,void 0,void 0,(function*(){var c;try{const l=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(l),Date.now()>u)clearInterval(e),this._logger.Debug("Update already finished!"),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgraded,t(n),s(ce.OK);else{var o=u-Date.now();o<i?r=95-o/a:(clearInterval(e),e=setInterval((()=>{clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgraded,t(n),s(ce.OK)}),o))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),e=setInterval((()=>{if(r>99)clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgraded,t(n),s(ce.OK);else{var i=5+r*o;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Af("/runtime/tmp/update.sh"),12e3,!1)}catch(e){s(new Ee(Ip.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cp.InstallationError,t(n),new Ee(Ip.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Af("/runtime/scripts/restart_all.sh"),12e3,!1),new Ee(Ip.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Ee(Ip.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Ee(Ip.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Ee(Ip.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}DownloadControllerUpdateNewApiAsync(e,t,n,r){return gf(this,void 0,void 0,(function*(){return new Promise(((t,o)=>gf(this,void 0,void 0,(function*(){yield this._connection.SendAndHandleResponseAsync(new bf,this._updateRequestTimeout,(o=>{var s,i,a,c;const u=new nf;switch(u.UpdatedResourceName=ie(e.Update.UpdateName),o.Status){case ce.MultiDataResponseStart:u.Percentage=0,u.SpeedMbps=0,u.PercentageTotal=0,u.CurrentTask=bp.DownloadingInstaller,n(u);break;case ce.MultiDataResponse:if(null!=o.Data){switch(u.Percentage=o.Data.StepProgressInPercentage,u.SpeedMbps=o.Data.DownloadSpeedInMbs,u.PercentageTotal=r?Math.round(2*(null===(s=o.Data)||void 0===s?void 0:s.UpdateProgressInPercentage)):Math.round(null===(i=o.Data)||void 0===i?void 0:i.UpdateProgressInPercentage),o.Data.UpdateStep){case cf.DownloadingInstaller:u.CurrentTask=bp.DownloadingInstaller;break;case cf.DownloadingUpdate:u.CurrentTask=bp.DownloadingUpdate;break;default:u.CurrentTask=bp.CheckingUpdate}n(u)}break;case ce.MultiDataResponseStop:if(null!=o.Data)switch(o.Data.UpdateStep){case cf.UpdateDownloaded:u.Percentage=100,u.PercentageTotal=r?Math.round(2*(null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)):Math.round(null===(c=o.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),u.SpeedMbps=0,u.CurrentTask=bp.CheckingUpdate,n(u),t(ce.OK);break;case cf.UpdateDownloadFailed:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=bp.Unknown,n(u),t(new Ee(Ip.UpdateDownloadFailed,"Update download failed!"))}break;case ce.Error:case ce.FatalError:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=bp.Unknown,n(u),t(new Ee(Ip.CannotProcessUpdate,"Update download failed!"))}}),!1)}))))}))}InstallUpdateNewApiAsync(e,t,n,r){return gf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>gf(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let o=0;const s=new tf;let i=null;const a=e=>gf(this,void 0,void 0,(function*(){e==Os.Connected&&(clearInterval(i),s.Status=Cp.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),yield se.Delay(5e3),n(ce.OK),Qv.Get(Js.ServiceName).OnAppStateChanged().Unsubscribe(a))}));yield this._connection.SendAndHandleResponseAsync(new If,this._updateRequestTimeout,(c=>{var u,l;switch(s.UpdatedResourceName=ie(e.Update.UpdateName),c.Status){case ce.MultiDataResponseStart:s.Status=Cp.PreparingForUpgrade,s.Percentage=null===(u=c.Data)||void 0===u?void 0:u.StepProgressInPercentage,s.PercentageTotal=null===(l=c.Data)||void 0===l?void 0:l.UpdateProgressInPercentage,t(s);break;case ce.MultiDataResponse:null!=c.Data&&(s.Status=Cp.Upgrading,s.Percentage=Math.round(c.Data.StepProgressInPercentage),s.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage),o=c.Data.StepProgressInPercentage,t(s));break;case ce.MultiDataResponseStop:if(null!=c.Data)switch(c.Data.UpdateStep){case cf.UpdateInstallationFailed:s.Status=Cp.InstallationError,s.Percentage=0,s.PercentageTotal=0,t(s),n(new Ee(Ip.CannotProcessUpdate,"Update installation failed!"));break;case cf.OfflineUpdateStep:{s.Percentage=Math.round(c.Data.StepProgressInPercentage),s.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage);let e=(100-s.PercentageTotal)/100,u=s.PercentageTotal;i=setInterval((()=>{o++,u+=e,u>100&&(u=100),o>=100?(s.Status=Cp.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),n(ce.OK)):(s.Status=Cp.Upgrading,s.Percentage=Math.round(o),s.PercentageTotal=Math.round(u),t(s))}),r/(100-o)),Qv.Get(Js.ServiceName).OnAppStateChanged().Subscribe(a)}}break;case ce.Error:case ce.FatalError:s.Status=Cp.Error,s.Percentage=0,s.PercentageTotal=0,t(s),n(new Ee(Ip.CannotProcessUpdate,"Update installation failed!"))}}),!1)}))))}))}UpdateControllerUsingApiAsync(e,t,n){return gf(this,void 0,void 0,(function*(){if(n){const r=yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1);if((null==r?void 0:r.Status)==ce.NoData)return new Ee(Ip.DeviceIsUpToDate,"No updates available!");if(null==r||(null==r?void 0:r.Status)!=ce.OK||null==(null==r?void 0:r.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data.UpdateStep){case cf.DownloadingInstaller:case cf.DownloadingUpdate:case cf.UpdateDownloaded:return new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case cf.InstallingUpdate:case cf.PreparingUpdate:return new Ee(Ip.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield this.DownloadControllerUpdateNewApiAsync(r.Data,e,t,n)}}else{const o=yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1);if((null==o?void 0:o.Status)==ce.NoData)return new Ee(Ip.DeviceIsUpToDate,"No updates available!");if(null==o||(null==o?void 0:o.Status)!=ce.OK||null==(null==o?void 0:o.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`);switch(o.Data.UpdateStep){case cf.DownloadingInstaller:case cf.DownloadingUpdate:return new Ee(Ip.UpdateAlreadyDownloaded,"Update already downloaded, or download in progress.");case cf.InstallingUpdate:case cf.PreparingUpdate:return new Ee(Ip.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case cf.UpdateDownloaded:return yield this.InstallUpdateNewApiAsync(o.Data,e,t,n);default:var r=yield this.DownloadControllerUpdateNewApiAsync(o.Data,e,t,n);return r!=ce.OK?r:yield this.InstallUpdateNewApiAsync(o.Data,e,t,n)}}}))}getRuntimeInfoAsync(){return gf(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof us&&e.code==Lo.Timeout?new Ee(Ip.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Ee(Ip.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}pf.ServiceName="UpdatesService";class ff{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class vf{constructor(){this._updateIdentifier="",this._updateResourceName=new Map,this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map,this._updateIsDownloading=!1,this._updateCheckDownloadProgress=0,this._updateCreationTime=null}get UpdateCreationTime(){return this._updateCreationTime}get DownloadProgress(){return this._updateCheckDownloadProgress}get UpdateDescription(){return this._updateDescription}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}get UpdateIsDownloading(){return this._updateIsDownloading}set UpdateCreationTime(e){this._updateCreationTime=e}set DownloadProgress(e){this._updateCheckDownloadProgress=e}set UpdateDescription(e){this._updateDescription=e}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}set UpdateIsDownloading(e){this._updateIsDownloading=e}}class yf{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 mf extends ae{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=ue.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"}(of||(of={})),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"}(sf||(sf={})),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"}(af||(af={})),function(e){e[e.InstallerFileSignCheckFailed=-5]="InstallerFileSignCheckFailed",e[e.UpdateFileSignCheckFailed=-4]="UpdateFileSignCheckFailed",e[e.UpdateInstallationFailed=-3]="UpdateInstallationFailed",e[e.UpdateDownloadFailed=-2]="UpdateDownloadFailed",e[e.UpdateFileCheckFailed=-1]="UpdateFileCheckFailed",e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.CheckingUpdate=2]="CheckingUpdate",e[e.PreparingUpdate=3]="PreparingUpdate",e[e.InstallingUpdate=4]="InstallingUpdate",e[e.DownloadingInstaller=5]="DownloadingInstaller",e[e.UpdateDownloaded=6]="UpdateDownloaded",e[e.OfflineUpdateStep=7]="OfflineUpdateStep"}(cf||(cf={}));class wf extends ae{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ue.Put,this.Data=e}}class Sf extends ae{constructor(e){super(),this.Resource="/users/user/login",this.Method=ue.Put,this.Data=e}}class Af extends ae{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ue.Post,this.Data=e}}class _f extends ae{constructor(){super(),this.Resource="/updates/branch",this.Method=ue.Get}}class Cf extends ae{constructor(e){super(),this.Resource="/updates/branch",this.Method=ue.Put,this.Data=e}}class Tf extends ae{constructor(){super(),this.Resource="/updates/failed/cancel",this.Method=ue.Put}}class Df extends ae{constructor(){super(),this.Resource="/updates/pending/progress",this.Method=ue.Get}}class kf extends ae{constructor(){super(),this.Resource="/updates/pending",this.Method=ue.Get}}class Ef extends ae{constructor(){super(),this.Resource="/updates/check",this.Method=ue.Get}}class bf extends ae{constructor(){super(),this.Resource="/updates/download",this.Method=ue.Post}}class If extends ae{constructor(){super(),this.Resource="/updates/install",this.Method=ue.Post}}class Gf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=ue.Get}}class Nf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=ue.Put}}class Rf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=ue.Put}}class Pf extends ae{constructor(){super(),this.Resource="/updates/history",this.Method=ue.Get}}class Of extends ae{constructor(){super(),this.Resource="/updates/devices/availability",this.Method=ue.Get}}!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"}(uf||(uf={})),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"}(lf||(lf={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(df||(df={}));class Uf{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"}(hf||(hf={}));var Mf,xf,Ff,Lf,Bf,Wf,$f,qf=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Vf{constructor(){this._connection=null,this._connection=Qv.Get(_t.ServiceName)}GetServiceName(){return Vf.ServiceName}GetStatesByIntervalAsync(e,t,n,r,o,s){return qf(this,arguments,void 0,(function*(e,t,n,r,o,s,i=!1){var a;try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Ee(uf.FunctionalityNotSupported,"State history data is not supported with this version of controller software, update software to get this functionality.");let c;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(uf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new Ee(uf.InvalidChannelNumber,`Given channel not found in device with guid: ${c.Guid}.`);if(!c.Channels.any((e=>e.Number==t&&e.AvailableResponseTypes.any((e=>e.Type==n)))))return new Ee(uf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new Kf;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.Range=r,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=o,u.Offset=s;const l=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new Hf(u),2e4,!1);if(null==l)return new Ee(uf.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case ce.WrongData:switch(l.Data){case"IncorrectLimitValue":return new Ee(uf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ee(uf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ee(uf.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Ee(uf.OtherError,"Cannot get state history data - unknown error!")}case ce.FatalError:return new Ee(uf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ce.ResourceDoesNotExists:return new Ee(uf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ce.OK:if(null==l.Data)return new Ee(uf.NoData,"Controller responede with status OK, but response does not contain data!");if(l.Data.AggregateDataList=l.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===bt.MeasuredEnergy){const e=l.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return l.Data.Data=e,l.Data}return l.Data;default:return new Ee(uf.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new Ee(uf.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){return qf(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new jf,12e3,!1);return null==t?new Ee(uf.OtherError,"Cannot get available states - response is null."):t.Status!=ce.OK?new Ee(uf.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Ee(uf.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Uf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Ee(uf.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return qf(this,void 0,void 0,(function*(){return!(parseFloat((yield Qv.Get(os.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}GetAvailableStatesPerChannelAsync(e,t){return qf(this,void 0,void 0,(function*(){var n;let r;if("string"==typeof e){const t=yield Qv.Get(Ys.ServiceName).GetDevice(e);if(null==t)return new Ee(uf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);r=t}else r=e;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new zf(new Jf(r.Guid,t)),8e3,!1);if(null==o)return new Ee(uf.OtherError,"Cannot get available states - response is null.");switch(o.Status){case ce.ResourceDoesNotExists:switch(o.Data){case"DeviceNotFound":return new Ee(uf.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Ee(uf.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Ee(uf.OtherError,"Cannot get available states - unknown error!")}case ce.OK:{if(null==o.Data)return new Ee(uf.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!");const e=o.Data.AvailableStates.map((e=>{const t=new Uf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return o.Data.AvailableStates=e,o.Data}default:return new Ee(uf.OtherError,`Cannot get available states - controller responded with response code ${o.Status}`)}}))}}Vf.ServiceName="StatesHistoryService";class Hf extends ae{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ue.Get,this.Data=e}}class Kf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=lf.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class jf extends ae{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ue.Get}}class zf extends ae{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=ue.Get,this.Data=e}}class Jf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}($f=Mf||(Mf={}))[$f.User=0]="User",$f[$f.Controller=1]="Controller",$f[$f.Marketing=2]="Marketing",(Wf=xf||(xf={}))[Wf.Notification=0]="Notification",Wf[Wf.Message=1]="Message",Wf[Wf.Alarm=2]="Alarm",Wf[Wf.Warning=3]="Warning",Wf[Wf.Info=4]="Info",(Bf=Ff||(Ff={}))[Bf.Other=0]="Other",Bf[Bf.UserLoggedIn=1]="UserLoggedIn",Bf[Bf.UserLoggedOut=2]="UserLoggedOut",Bf[Bf.FoundNewDevice=3]="FoundNewDevice",Bf[Bf.DoorBellPress=4]="DoorBellPress",Bf[Bf.AddedNewDevice=5]="AddedNewDevice",Bf[Bf.RemovedDevice=6]="RemovedDevice",Bf[Bf.RegisteredNewUser=7]="RegisteredNewUser",Bf[Bf.GotAccessToTheInternet=8]="GotAccessToTheInternet",Bf[Bf.LostAccessToTheInternet=9]="LostAccessToTheInternet",Bf[Bf.RemovedUser=10]="RemovedUser",Bf[Bf.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(Lf||(Lf={}));var Xf=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Yf{constructor(){this._chatSubscriptions=[],this._connection=Qv.Get(_t.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==xf.Message)return;const n=new Qf;n.DateTime=t.DateTime,n.Guid=t.Guid,n.MessageSource=t.MessageSource,n.MessageText=t.MessageText,n.MessageType=t.MessageType,n.RecipientUserGuid=t.RecipientUserGuid?t.RecipientUserGuid:"n/a",n.Sender=t.Sender,n.SenderName=t.SenderName?t.SenderName:"n/a",n.SenderUserGuid=t.SenderUserGuid?t.SenderUserGuid:"n/a",n.TextToSpeechMessage=t.TextToSpeechMessage?t.TextToSpeechMessage:"";for(let[e,r]of Object.entries(t.MessageActions))n.MessageActions.set(Lf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return Xf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Zf,12e3,!1);if(null==e)return new Ee(lv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ce.OK)return new Ee(lv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ee(lv.NoData,"Cannot get messages - controller responded with status OK, but response does not contain data!");const t=[];return e.Data.forEach((e=>{if(null==e.RecipientUserGuid&&e.MessageType==xf.Message)return;const n=new Qf;n.DateTime=e.DateTime,n.Guid=e.Guid,n.MessageSource=e.MessageSource,n.MessageText=e.MessageText,n.MessageType=e.MessageType,n.RecipientUserGuid=e.RecipientUserGuid?e.RecipientUserGuid:"n/a",n.Sender=e.Sender,n.SenderName=e.SenderName?e.SenderName:"n/a",n.SenderUserGuid=e.SenderUserGuid?e.SenderUserGuid:"n/a",n.TextToSpeechMessage=e.TextToSpeechMessage?e.TextToSpeechMessage:"";for(let[t,r]of Object.entries(e.MessageActions))n.MessageActions.set(Lf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new Ee(lv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return Xf(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new ev(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class Qf{constructor(){this._sender=Mf.Controller,this._messageType=xf.Info,this._messageSource=Ff.Other,this._senderUserGuid="",this._recipientUserGuid="",this._textToSpeechMessage="",this._messageActions=new Map,this._messageActionsData=new Map,this._guid="",this._senderName="",this._messageText="",this._dateTime=(new Date).toDateString()}get Sender(){return this._sender}get MessageType(){return this._messageType}get MessageSource(){return this._messageSource}get SenderUserGuid(){return this._senderUserGuid}get RecipientUserGuid(){return this._recipientUserGuid}get TextToSpeechMessage(){return this._textToSpeechMessage}get MessageActions(){return this._messageActions}get MessageActionsData(){return this._messageActionsData}get Guid(){return this._guid}get SenderName(){return this._senderName}get MessageText(){return this._messageText}get DateTime(){return this._dateTime}set Sender(e){this._sender=e}set MessageType(e){this._messageType=e}set MessageSource(e){this._messageSource=e}set SenderUserGuid(e){this._senderUserGuid=e}set RecipientUserGuid(e){this._recipientUserGuid=e}set TextToSpeechMessage(e){this._textToSpeechMessage=e}set MessageActions(e){this._messageActions=e}set MessageActionsData(e){this._messageActionsData=e}set Guid(e){this._guid=e}set SenderName(e){this._senderName=e}set MessageText(e){this._messageText=e}set DateTime(e){this._dateTime=e}}class Zf extends ae{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ue.Get}}class ev extends ae{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ue.Put,this.Data=e}}var tv,nv,rv,ov=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class sv{constructor(){this._chatSubscriptions=[],this._connection=Qv.Get(_t.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{if("/homemessaging/notify/message/new"===e.Resource){const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==xf.Message){const e=new iv;e.DateTime=t.DateTime,e.Guid=t.Guid,e.MessageText=t.MessageText,e.SenderName=t.SenderName?t.SenderName:"n/a",this._chatSubscriptions.forEach((t=>{t(e)}))}}}))}GetCachedMessagesAsync(){return ov(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new cv,12e3,!1);if(null==e)return new Ee(lv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ce.OK)return new Ee(lv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ee(lv.NoData,"Cannot get messages - controller responded with status OK, but response does not contain data!");const t=[];return e.Data.forEach((e=>{if(null==e.RecipientUserGuid&&e.MessageType==xf.Message){const n=new iv;n.DateTime=e.DateTime,n.Guid=e.Guid,n.MessageText=e.MessageText,n.SenderName=e.SenderName?e.SenderName:"n/a",t.push(n)}})),t}catch(e){return new Ee(lv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return ov(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new av(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class iv{constructor(){this._guid="",this._senderName="",this._messageText="",this._dateTime=""}get Guid(){return this._guid}get SenderName(){return this._senderName}get MessageText(){return this._messageText}get DateTime(){return this._dateTime}set Guid(e){this._guid=e}set SenderName(e){this._senderName=e}set MessageText(e){this._messageText=e}set DateTime(e){this._dateTime=e}}class av extends ae{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ue.Put,this.Data=e}}class cv extends ae{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ue.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(tv||(tv={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(nv||(nv={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(rv||(rv={}));var uv,lv,dv,hv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class gv{constructor(){this._chatSubscriptions=[],this._connection=Qv.Get(_t.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new yv;if(n.DateTime=t.DateTime,n.Guid=t.Guid,n.MessageText=t.MessageText?t.MessageText:"",n.SenderName=t.SenderName?t.SenderName:"n/a",null!=t.ControllerActivities)for(let[e,r]of Object.entries(t.ControllerActivities)){const t=tv[e],o=new Map;for(let[e,t]of Object.entries(r))o.set(e,t);n.ControllerActivities.set(t,o)}if(null!=t.Errors)for(let[e,r]of Object.entries(t.Errors))n.Errors.set(rv[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return hv(this,void 0,void 0,(function*(){return(yield Qv.Get(tt.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return hv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new fv,8e3,!1);return null==e||null==e.Status?new Ee(lv.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ce.OK?new Ee(lv.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Ee(lv.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Ee(lv.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return hv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new vv(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot set chat configuration! ${e}`),ce.FatalError}}))}SendMessageAsync(e){return hv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new pv(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(mv.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){var t;null===(t=this._chatSubscriptions)||void 0===t||t.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class pv extends ae{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=ue.Put,this.Data=e}}class fv extends ae{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ue.Get}}class vv extends ae{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ue.Put,this.Data=e}}class yv{constructor(){this._messageActions=new Map,this._errors=new Map,this._guid="",this._senderName="",this._messageText="",this._dateTime=""}get ControllerActivities(){return this._messageActions}get Errors(){return this._errors}get Guid(){return this._guid}get SenderName(){return this._senderName}get MessageText(){return this._messageText}get DateTime(){return this._dateTime}set ControllerActivities(e){this._messageActions=e}set Errors(e){this._errors=e}set Guid(e){this._guid=e}set SenderName(e){this._senderName=e}set MessageText(e){this._messageText=e}set DateTime(e){this._dateTime=e}}!function(e){e[e.ControllerChat=0]="ControllerChat",e[e.FamilyChat=1]="FamilyChat",e[e.GptChat=2]="GptChat"}(uv||(uv={}));class mv{constructor(){this._services={ControllerChat:new Yf,GptChat:new gv,FamillyChat:new sv}}GetServiceName(){return mv.ServiceName}GetChatImplementation(e){switch(e){case uv.ControllerChat:return this._services.ControllerChat;case uv.FamilyChat:return this._services.FamillyChat;case uv.GptChat:return this._services.GptChat;default:throw new wv(`Chat with type ${e} not implemented!`)}}}mv.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(lv||(lv={}));class wv extends Error{constructor(e){super(e),this.message=e,this.name="ChatNotImplementedException"}}!function(e){e[e.ResourceIsNotAvailable=-11]="ResourceIsNotAvailable",e[e.AnotherAppWithGivenAccessTokenAlreadyExists=-10]="AnotherAppWithGivenAccessTokenAlreadyExists",e[e.AppGuidDoesNotExists=-7]="AppGuidDoesNotExists",e[e.AppUrlToShort=-6]="AppUrlToShort",e[e.AppUserNameToShort=-5]="AppUserNameToShort",e[e.AppUserIdToShort=-4]="AppUserIdToShort",e[e.AccessTokenToShort=-3]="AccessTokenToShort",e[e.AppNameToShort=-2]="AppNameToShort",e[e.UnkownError=0]="UnkownError",e[e.Changed=1]="Changed"}(dv||(dv={}));var Sv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Av{constructor(){this._connection=Qv.Get(_t.ServiceName),this._log=Qv.Get(c.ServiceName)}GetServiceName(){return Av.ServiceName}IsSupportedAsync(){return Sv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new _v,2e3,!0);return this._log.Debug(Av.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ce.WrongData}))}GetConnectedAppsAsync(){return Sv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Cv,2e3,!0);return(null==e?void 0:e.Status)===ce.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Sv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Dv(e),2e3,!1);switch(null==t?void 0:t.Status){case ce.OK:return new Ee(dv.Changed,"");case ce.WrongData:switch(t.Data){case"AccessTokenToShort":return new Ee(dv.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Ee(dv.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Ee(dv.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Ee(dv.AppNameToShort,t.Data);case"AppUrlToShort":return new Ee(dv.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Ee(dv.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Ee(dv.AppUserNameToShort,t.Data);default:return new Ee(dv.UnkownError,t.Data)}case ce.ResourceDoesNotExists:case ce.ResourceIsNotAvailable:return new Ee(dv.ResourceIsNotAvailable,t.Data);default:return new Ee(dv.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Sv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Tv(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}Av.ServiceName="ConnectedAppsService";class _v extends ae{constructor(){super(),this.Resource="/applications/app/auth",this.Method=ue.Put,this.Data=""}}class Cv extends ae{constructor(){super(),this.Resource="/applications/get",this.Method=ue.Get}}class Tv extends ae{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=ue.Delete,this.Data=e}}class Dv extends ae{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=ue.Put,this.Data=e}}var kv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ev{constructor(){try{const e=window.location.href,t=new URL(e),n=new URLSearchParams(t.search),r=n.get("mig_c_enc"),o=n.get("mig_controllers"),s=n.get("mig_lang");if(null!==r){const e=decodeURIComponent(this.b64DecodeUnicode(decodeURIComponent(r)));localStorage.setItem(Ev.AppUserControllersKeyName,e)}null!==o&&localStorage.setItem(Ev.AppUserControllersKeyName,decodeURIComponent(o)),null!==s&&localStorage.setItem(Ev.AppSelectedLanguageKeyName,s)}catch(e){console.error(e)}}waitForNavigatorObject(e){return new Promise(((t,n)=>{setTimeout((()=>{n(new Error(`Timed out waiting for navigator.${e}`))}),1e4),function n(){navigator[e]?t(navigator[e]):requestAnimationFrame(n)}()}))}b64DecodeUnicode(e){return decodeURIComponent(Array.prototype.map.call(atob(e),(function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))}decodeUriJsonData(e){return JSON.parse(decodeURIComponent(e))}encodeUriJsonData(e){return encodeURIComponent(JSON.stringify(e))}IsExalusNativeMigrationAvailable(){return void 0!==navigator.exalusMigration}GetServiceName(){return Ev.ServiceName}IsMigrationDataAvailableAsync(){return kv(this,void 0,void 0,(function*(){try{if(this.isIosNavtie()){var e=yield Ev.GetIosMigrationStatus();return null!==e&&e}if(!navigator.userAgent.endsWith("LavvaAndroidNative")||void 0!==navigator.exalusMigration&&null!==navigator.exalusMigration||(yield this.waitForNavigatorObject("exalusMigration")),this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.IsMigrationDataAvailableAsync();return null!=e&&e.DataMigrated}return null!==localStorage.getItem(Ev.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Ev.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return kv(this,void 0,void 0,(function*(){try{if(this.isIosNavtie()){let e=yield Ev.GetIosControllerList();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetControllersDataAsync();return void 0===e?null:e}let e=localStorage.getItem(Ev.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return kv(this,void 0,void 0,(function*(){try{if(this.isIosNavtie()){let e=yield Ev.GetIosDefaultLanguage();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetLanguageCodeAsync();return void 0===e?null:e}let e=localStorage.getItem(Ev.AppSelectedLanguageKeyName);return null!=e?e:null}}catch(e){return console.error(e),null}}))}static GetIosMigrationStatus(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.isMigrationAvaliable=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("IsMigrationAvaliable")}catch(e){r(e)}}))}static GetIosControllerList(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleControllers=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetControllers")}catch(e){r(e)}}))}static GetIosDefaultLanguage(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleLanguage=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetDefaultLanguage")}catch(e){r(e)}}))}isIosNavtie(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusControllerData);return t&&n}}Ev.AppSelectedLanguageKeyName="App___SelectedLanguage",Ev.AppUserControllersKeyName="App___UserControllersListDatabase",Ev.ServiceName="DataMigrationService";var bv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Iv{constructor(){this._localIpAddress=null,this._publicIpAddress=null,this._gatewayIpAddress=null,this._macAddress=null,this._isInLocalNetwork=!1,this.nativeFindControllerApi=null,void 0!==navigator.findEfcController&&(this.nativeFindControllerApi=navigator.findEfcController),this._connection=Qv.Get(_t.ServiceName),this._logger=Qv.Get(c.ServiceName),this._storage=Qv.Get(l.ServiceName),Qv.Get(Je.ServiceName).OnUserLoggedInEvent().Subscribe((e=>bv(this,void 0,void 0,(function*(){var e;try{yield se.Delay(5e3);const t=yield this.GetControllerNetworkConfigurationAsync();if(null!=t){this._localIpAddress=t.LocalIPv4,this._publicIpAddress=t.PublicIPv4,this._gatewayIpAddress=t.GatewayIPv4,this._macAddress=t.MAC,this._storage.Save(Iv.ServiceName,"LocalIpAddress",this._localIpAddress);const n=this.GetControllerHostName(this._connection.GetControllerSerialNumber());this._logger.Debug(`Looking for controller in local network with host name: ${n}`);let r=null;this.isIosNative()?r=yield this.getIosControllerIpAsync(n):null!==this.nativeFindControllerApi&&(r=yield null===(e=this.nativeFindControllerApi)||void 0===e?void 0:e.FindControllerAsync(n)),null!=r&&""!=r?(this._isInLocalNetwork=!0,this._logger.Debug(Iv.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(Iv.ServiceName,"Controller not found in local network."))}else this._logger.Error(Iv.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(Iv.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return bv(this,void 0,void 0,(function*(){if(this.isIosNative()){const t=yield this.getIosControllerIpAsync(e);return""==t?null:t}return null!==this.nativeFindControllerApi?this.nativeFindControllerApi.FindControllerAsync(e):Promise.resolve(null)}))}GetLastKnownControllerLocalIpAddress(){return null!==this._localIpAddress?this._localIpAddress:this._storage.Read(Iv.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){return bv(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Gv,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(Iv.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return Iv.ServiceName}isIosNative(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusFindController);return t&&n}getIosControllerIpAsync(e,t=2e4){let n;return new Promise(((r,o)=>{n=setTimeout((()=>{this._logger.Error("Cannot find controller in local network, timeout!"),r("")}),t);try{window.nativeEvent.exalusFindController.handleFindController=e=>{clearTimeout(n),r(e)},window.webkit.messageHandlers.exalusFindController.postMessage(e)}catch(e){this._logger.Error(`Cannot find controller in local network, error: ${e}`),r("")}}))}}Iv.ServiceName="FindControllerService";class Gv extends ae{constructor(){super(),this.Resource="/network/lan/",this.Method=ue.Get}}var Nv,Rv,Pv,Ov=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Uv{constructor(){this._errorOccuredEvent=new a,this._connectionStateChangedEvent=new a,this._dataReceivedEvent=new a,this._onMessageReceived=new a,this._log=Qv.Get(c.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._logPackets=!0,this.socket=null,this._address=null,this._port="81",this._isOpen=!1,this._pin=void 0,this._serial=void 0,this._auth=null,this._initialized=!1,this._pingInterval=5e3,this._pingIntervalId=null,this._lastReceivedPacketTime=Date.now()}SendAndHandleStreamAsync(e,t,n){throw new Error("Method not implemented.")}Initialize(){this._initialized||(this._initialized=!0,this._controllerConfiguration=Qv.Get(it.ServiceName),this._cache=Qv.Get(Le.ServiceName),this._session=Qv.Get(Je.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return Ov(this,void 0,void 0,(function*(){const t=`http://${window.location.hostname}/controller_info`;let n=yield fetch(t,{method:"GET"});return!!n.ok&&(yield n.text())===`${e.SerialNumber}:${e.PIN}`}))}PingControllerAsync(){return Ov(this,void 0,void 0,(function*(){var e;if((null===(e=this.socket)||void 0===e?void 0:e.readyState)!==WebSocket.OPEN)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new ae;return t.Resource="/system/ping",t.Method=ue.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}GetControllerSerialNumber(){return this._serial}GetControllerPin(){return this._pin}SetServersBrokerAddress(e){throw new Error("Method not implemented.")}SetDefaultPacketsBrokerAddress(e){throw new Error("Method not implemented.")}GetServerAddressAsync(){return Qv.IsRunningFromLocalNetwork()&&(this._address=`${window.location.hostname}:${this._port}`),Promise.resolve(this._address)}ConnectAsync(e){return new Promise(((t,n)=>{var r;this.Initialize(),null===(r=this.socket)||void 0===r||r.close(),this.socket=new WebSocket(`ws://${e}/api`),this._log.Debug(Uv.ServiceName,`Connecting to the WebSockets server ${e}`),this.socket.onerror=t=>(this._log.Debug(Uv.ServiceName,`Error occured in the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._errorOccuredEvent.Invoke(["WebSockets",t.toString()]),n(de.FailedToConnect)),this.socket.onopen=n=>(this._log.Debug(Uv.ServiceName,`Connected to the WebSockets server ${e} info: \n${JSON.stringify(n)}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(he.Connected),this._pingIntervalId=setInterval((()=>Ov(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval),t(de.Connected)),this.socket.onclose=t=>{this._log.Debug(Uv.ServiceName,`Disconnected from the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(he.Disconnected)},this.socket.onmessage=t=>{this._log.Debug(Uv.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);try{let e=JSON.parse(t.data);this._log.Debug(Uv.ServiceName,`Received data frame: ${e.Status}`),this._dataReceivedEvent.Invoke(e)}catch(e){this._log.Error(Uv.ServiceName,`Failed to parse message: ${t.data}`)}},this._connectionStateChangedEvent.Invoke(he.Connecting)}))}AuthorizeAsync(e){return Ov(this,void 0,void 0,(function*(){return Qv.WorksInContextOf=e.SerialNumber,!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Uv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,this._connectionStateChangedEvent.Invoke(he.ConnectedAndAuthorized),!0)}))}ConnectAndAuthorizeAsync(e){return Ov(this,void 0,void 0,(function*(){if(Qv.WorksInContextOf=e.SerialNumber,this._log.Debug(Uv.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`),!(yield this.AuthorizeAsync(e)))return de.AuthorizationFailed;let t=yield this.GetServerAddressAsync();return null==t?de.FailedToConnectToServer:yield this.ConnectAsync(t)}))}DisconnectAsync(){var e;return this._log.Debug(Uv.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._connectionStateChangedEvent.Invoke(he.Disconnecting),null!==this._pingIntervalId&&clearInterval(this._pingIntervalId),null===(e=this.socket)||void 0===e||e.close(),Promise.resolve()}IsConnected(){return this._isOpen}EnablePacketsLogging(){this._log.Debug(Uv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Uv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Uv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.socket)||void 0===n||n.send(r):this._log.Error(Uv.ServiceName,`Failed to send data frame: ${r}`),this._isOpen}SendAsync(e){return this._isOpen?Promise.resolve(this.SendData(e,this._logPackets)):Promise.resolve(!1)}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,r)}SendAndHandleResponseAsync(e,t,n,r){return Ov(this,void 0,void 0,(function*(){var o;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===(o=this._session)||void 0===o?void 0:o.WaitForSessionCreationAsync()),new Promise(((o,a)=>Ov(this,void 0,void 0,(function*(){const c=()=>window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(u);let t=`Response timeout, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;this._log.Error(Uv.ServiceName,t),a(new Error(t))}),t);let u=l=>Ov(this,void 0,void 0,(function*(){var d,h,g;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(s);const p=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Uv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${p}ms`),(null==l?void 0:l.Status)===ce.UserIsNotLoggedIn&&(this._dataReceivedEvent.Unsubscribe(u),(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(),o(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ce.MultiDataResponseStart:case ce.MultiDataResponse:n(l),s=c();break;case ce.MultiDataResponseStop:case ce.FatalError:case ce.Error:n(l),this._dataReceivedEvent.Unsubscribe(u),o();break;default:let t=`Failed to process MultiDataResponse - recived incorrect response status: ${null==l?void 0:l.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(u),s=c(),!this.SendData(e,r)){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;a(new Error(t))}}))))}))}SendAndWaitForResponseWithRepeatAsync(e,t,n){return Ov(this,arguments,void 0,(function*(e,t,n,r=!0,o=!0){var s,i,a;if(e.Method===ue.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 u=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)=>Ov(this,void 0,void 0,(function*(){let a=i=>Ov(this,void 0,void 0,(function*(){var l,d,h,g;if((null==i?void 0:i.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const p=Date.now()-u;o&&this._log.Debug(Uv.ServiceName,`Received response for: ${null==i?void 0:i.Resource} ${null==i?void 0:i.Method} id: ${null==i?void 0:i.TransactionId} in ${p}ms`),e.Method===ue.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ce.UserIsNotLoggedIn&&r&&((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,o))),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(Uv.ServiceName,t),i(new Error(t))}),t),!this.SendData(e,o)){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;i(new Error(t))}}))))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}GetAuthorizationInfo(){return this._auth}GetServiceName(){return Uv.ServiceName}}Uv.ServiceName="ExalusConnectionService";class Mv{constructor(){var e,t;this.OnEnteredPictureInPicture=new De,this.OnExitedPictureInPicture=new De,this._nativeApi=null,this.IsSupported()?(this._nativeApi=navigator.pip,null===(e=this._nativeApi)||void 0===e||e.OnEnteredPictureInPicture.Subscribe((()=>this.OnEnteredPictureInPicture.Invoke())),null===(t=this._nativeApi)||void 0===t||t.OnExitedPictureInPicture.Subscribe((()=>this.OnExitedPictureInPicture.Invoke()))):navigator.pip=null}IsSupported(){return void 0!==navigator.pip&&null!==navigator.pip}RequestPictureInPictureAsync(){return this.IsSupported()?this._nativeApi.RequestPictureInPictureAsync():Promise.resolve(!1)}GetServiceName(){return Mv.ServiceName}}Mv.ServiceName="PictureInPictureService",(Pv=Nv||(Nv={}))[Pv.Unknown=-1]="Unknown",Pv[Pv.Web=0]="Web",Pv[Pv.Android=1]="Android",Pv[Pv.iOS=2]="iOS";class xv{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=Nv.Unknown,this.TokenGuid="",this.Token="",this.RegistrationDate=new Date}}!function(e){e.FeatureUnsupported="FeatureUnsupported",e.UnknownError="UnknownError",e.NoData="NoData",e.IncorrectGuid="IncorrectGuid",e.IdentityIsEmpty="IdentityIsEmpty",e.DeviceTokenIsEmpty="DeviceTokenIsEmpty",e.ClientNameIsEmpty="ClientNameIsEmpty",e.LavvaUserNameIsEmpty="LavvaUserNameIsEmpty",e.TokenNotFound="TokenNotFound",e.TokensNotFoundForLavvaUser="TokensNotFoundForLavvaUser"}(Rv||(Rv={}));var Fv=function(e,t,n,r){return new(n||(n=Promise))((function(o,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(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Lv{constructor(){this._connection=Qv.Get(_t.ServiceName),this._logger=Qv.Get(c.ServiceName)}GetServiceName(){return Lv.ServiceName}RegisterNotificationsClientAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=new Bv({ClientName:e.ClientName,DeviceToken:e.DeviceToken,LavvaUserName:e.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:e.EnableNotifications}),r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,8e3,!1);if(null==r||null==r.Status)return new Ee(Rv.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ce.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:Rv.UnknownError;return new Ee(e,"Cannot register notifications client - wrong data!")}case ce.ResourceDoesNotExists:return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");case ce.OK:return"string"==typeof r.Data?r.Data:new Ee(Rv.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ee(Rv.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new Ee(Rv.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){return Fv(this,void 0,void 0,(function*(){var n;try{const r=new Wv({ClientName:t.ClientName,DeviceToken:t.DeviceToken,LavvaUserName:t.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:t.EnableNotifications,Guid:e}),o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,8e3,!1);if(null==o||null==o.Status)return new Ee(Rv.UnknownError,"Cannot update notifications client - unknown error!");switch(o.Status){case ce.WrongData:{const e=this.isValidErrorCode(o.Data)?o.Data:Rv.UnknownError;return new Ee(e,"Cannot update notifications client - wrong data!")}case ce.ResourceDoesNotExists:return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");case ce.OK:return"string"==typeof o.Data?o.Data==e?ce.OK:new Ee(Rv.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${o.Data}`):new Ee(Rv.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ee(Rv.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new Ee(Rv.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(e){return Fv(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new $v,8e3,!1);return null==t||null==t.Status?new Ee(Rv.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ce.ResourceDoesNotExists?new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ce.OK?new Ee(Rv.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new Ee(Rv.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new xv;return t.ClientName=e.ClientName,t.LavvaUserName=e.LavvaUserName,t.ClientType=e.ClientType,t.TokenGuid=e.TokenGuid,t.Token=e.Token,t.RegistrationDate=new Date(e.RegistrationDate),t}))}catch(e){return this._logger.Error(`Cannot get notifications clients metadata - error: ${e}`),new Ee(Rv.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotificationsEnabledForAllUserTokensAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new zv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:case ce.WrongData:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot get notifications status!")}case ce.OK:return"boolean"==typeof n.Data?n.Data:new Ee(Rv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ee(Rv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ee(Rv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}IsNotificationsEnabledAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new qv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot get notifications status - resource not exists!")}case ce.OK:return"boolean"==typeof n.Data?n.Data:new Ee(Rv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ee(Rv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ee(Rv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Vv(n),8e3,!1);if(null==r||null==r.Status)return new Ee(Rv.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ce.ResourceDoesNotExists:if(null==r.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Rv.UnknownError;return new Ee(e,"Cannot enable notifications - resource not exists!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new Ee(Rv.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}EnableNotificationsForAllUserTokensAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Kv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot enable notifications - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:case ce.WrongData:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot enable notifications!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot enable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot enable notifications for lavva user ${e} - error: ${t}`),new Ee(Rv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DisableNotificationsAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Hv(n),8e3,!1);if(null==r||null==r.Status)return new Ee(Rv.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ce.ResourceDoesNotExists:if(null==r.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Rv.UnknownError;return new Ee(e,"Cannot disable notifications - resource not exists!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new Ee(Rv.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}DisableNotificationsForAllUserTokensAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new jv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Rv.UnknownError,"Cannot disable notifications - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:case ce.WrongData:if(null==n.Data)return new Ee(Rv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Rv.UnknownError;return new Ee(e,"Cannot disable notifications!")}case ce.OK:return ce.OK;default:return new Ee(Rv.UnknownError,`Cannot disable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot disable notifications for lavva user ${e} - error: ${t}`),new Ee(Rv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DeleteNotificationsTokenAsync(e){return Fv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Jv(e),8e3,!1);return null==n||null==n.Status?new Ee(Rv.UnknownError,"Cannot delete notifications token - unknown error!"):n.Status==ce.OK?ce.OK:new Ee(Rv.UnknownError,`Cannot delete notifications token - response code ${n.Status}!`)}catch(e){return this._logger.Error(`Cannot delete notifications token - error: ${e}`),new Ee(Rv.UnknownError,`Cannot delete notifications token - error: ${e}`)}}))}getClientType(){return this.isIos()?Nv.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?Nv.Android:Nv.Web}isValidErrorCode(e){return Object.values(Rv).includes(e)}isIos(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusFindController);return t&&n}}Lv.ServiceName="NotificationsService";class Bv extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Post,this.Data=e}}class Wv extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Put,this.Data=e}}class $v extends ae{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=ue.Get}}class qv extends ae{constructor(e){super(),this.Resource="/notifications/status",this.Method=ue.Get,this.Data={TokenIdentity:e}}}class Vv extends ae{constructor(e){super(),this.Resource="/notifications/enable",this.Method=ue.Post,this.Data=e}}class Hv extends ae{constructor(e){super(),this.Resource="/notifications/disable",this.Method=ue.Post,this.Data=e}}class Kv extends ae{constructor(e){super(),this.Resource="/notifications/enable/for/lavva/user",this.Method=ue.Post,this.Data=e}}class jv extends ae{constructor(e){super(),this.Resource="/notifications/disable/for/lavva/user",this.Method=ue.Post,this.Data=e}}class zv extends ae{constructor(e){super(),this.Resource="/notifications/status/for/lavva/user",this.Method=ue.Get,this.Data=e}}class Jv extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Delete,this.Data=e}}class Xv{CheckLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.CheckLocationPermissionAsync():Promise.resolve(!1)}RequestLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.RequestLocationPermissionAsync():Promise.resolve(!1)}IsAndroidLocationAvailable(){return void 0!==navigator.AndroidLocation}GetServiceName(){return Xv.ServiceName}}Xv.ServiceName="AndroidLocationService";class Yv{IsAndroidNotificationsAvailable(){return void 0!==navigator.AndroidNotifications}CheckNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.CheckNotificationPermissionAsync():Promise.resolve(!1)}RequestNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.RequestNotificationPermissionAsync():Promise.resolve(!1)}GetDeviceFirebaseTokenAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetDeviceFirebaseTokenAsync():Promise.resolve(null)}GetServiceName(){return Yv.ServiceName}}Yv.ServiceName="AndroidNotificationsService",fu(Map),fu(Set),(()=>{const e=String.prototype,t=Object.getOwnPropertyNames(_i.prototype);for(const n of t)e[n]=e[n]??_i.prototype[n];e.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 mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[0]},e.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]},e.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},e.elementAt=function(e){if(e<0||e>=this.length)throw new vi("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]||null},e.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 mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[this.length-1]},e.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]},e.reverse=function(){const e=this;return new _i((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),mp(Array),mp(Int8Array),mp(Int16Array),mp(Int32Array),mp(Uint8Array),mp(Uint8ClampedArray),mp(Uint16Array),mp(Uint32Array),mp(Float32Array),mp(Float64Array);class Qv{static Init(){if(u.IsInitialized)return;let e=u.Instance;try{e.RegisterService(new Ev),e.RegisterService(new l),e.RegisterService(new Js),e.RegisterService(new Le),e.RegisterService(new Je),e.RegisterService(new Mv),Qv.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Uv)):e.RegisterService(new _t),e.RegisterService(new Xv),e.RegisterService(new Yv),e.RegisterService(new _o),e.RegisterService(new _o),e.RegisterService(new Ro),e.RegisterService(new it),e.RegisterService(new Iv),e.RegisterService(new mo),e.RegisterService(new tt),e.RegisterService(new Ge),e.RegisterService(new We),e.RegisterService(new Ys),e.RegisterService(new Op),e.RegisterService(new os),e.RegisterService(new pf),e.RegisterService(new Av),e.RegisterService(new Vf),e.RegisterService(new Ms),e.RegisterService(new mv),e.RegisterService(new Lv)}catch(e){console.error(e)}}static IsAppServedFromControllerAsync(){const e=`http://${window.location.hostname}/controller_info`;return fetch(e,{method:"GET"}).then((e=>!!e.ok)).catch((e=>!1))}static IsRunningFromLocalNetwork(e=window.location.hostname){return e.startsWith("192.168.")||e.startsWith("10.")}static GetAsync(e,t){return u.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return u.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return u.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}static ExportStringAsFileToDownload(e,t){const n=new Blob([t],{type:"text/plain"}),r=document.createElement("a"),o=window.URL.createObjectURL(n);return r.href=o,r.download=e,r}}Qv.WorksInContextOf="",Qv.Version=1})();
|
|
2
2
|
//# sourceMappingURL=exalushome-library-bundle.js.map
|