lavva.exalushome 2.0.236 → 2.0.239
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/exalushome-library-bundle.js +1 -1
- package/build/exalushome-library-bundle.js.map +1 -1
- package/build/js/AsyncSemaphore.d.ts +2 -1
- package/build/js/AsyncSemaphore.js +6 -0
- package/build/js/AsyncSemaphore.js.map +1 -1
- package/build/js/Services/Controller/ControllerConfigurationService.d.ts +2 -1
- package/build/js/Services/Controller/ControllerConfigurationService.js +30 -18
- package/build/js/Services/Controller/ControllerConfigurationService.js.map +1 -1
- package/build/js/Services/Devices/ChannelsGroupsService.d.ts +4 -2
- package/build/js/Services/Devices/ChannelsGroupsService.js +31 -12
- package/build/js/Services/Devices/ChannelsGroupsService.js.map +1 -1
- package/build/js/Services/Devices/DevicesService.d.ts +6 -4
- package/build/js/Services/Devices/DevicesService.js +64 -66
- package/build/js/Services/Devices/DevicesService.js.map +1 -1
- package/build/js/Services/Session/SessionService.d.ts +0 -1
- package/build/js/Services/Session/SessionService.js +12 -19
- package/build/js/Services/Session/SessionService.js.map +1 -1
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
|
@@ -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:()=>ry});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_${ry.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 p{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 g{static get isBrowser(){return!g.isNode&&"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return!g.isNode&&"object"==typeof self&&"importScripts"in self}static get isReactNative(){return!g.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 g.isNode&&(e="User-Agent"),[e,A("8.0.7",_(),g.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(!g.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(g.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 U{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 O{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")},p.isRequired(e,"connection"),p.isRequired(t,"logger"),p.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(),g.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 O(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 U;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),g.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 V 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 q extends ${constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch||g.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 g.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||g.isNode)this._httpClient=new q(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(p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.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 p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.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(g.isBrowser||g.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 p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.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(g.isNode||g.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,p.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(g.isNode){const e=require;o=e("ws"),s=e("eventsource")}g.isNode||"undefined"==typeof WebSocket||t.WebSocket?g.isNode&&!t.WebSocket&&o&&(t.WebSocket=o):t.WebSocket=WebSocket,g.isNode||"undefined"==typeof EventSource||t.EventSource?g.isNode&&!t.EventSource&&void 0!==s&&(t.EventSource=s):t.EventSource=EventSource,this._httpClient=new V(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,p.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(!g.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(p.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 p.isRequired(e,"url"),p.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return p.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 p.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return p.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,p,g=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<g.length;u+=16)l=f,d=v,h=y,p=m,f=s(f,v,y,m,g[u+0],7,-680876936),m=s(m,f,v,y,g[u+1],12,-389564586),y=s(y,m,f,v,g[u+2],17,606105819),v=s(v,y,m,f,g[u+3],22,-1044525330),f=s(f,v,y,m,g[u+4],7,-176418897),m=s(m,f,v,y,g[u+5],12,1200080426),y=s(y,m,f,v,g[u+6],17,-1473231341),v=s(v,y,m,f,g[u+7],22,-45705983),f=s(f,v,y,m,g[u+8],7,1770035416),m=s(m,f,v,y,g[u+9],12,-1958414417),y=s(y,m,f,v,g[u+10],17,-42063),v=s(v,y,m,f,g[u+11],22,-1990404162),f=s(f,v,y,m,g[u+12],7,1804603682),m=s(m,f,v,y,g[u+13],12,-40341101),y=s(y,m,f,v,g[u+14],17,-1502002290),v=s(v,y,m,f,g[u+15],22,1236535329),f=i(f,v,y,m,g[u+1],5,-165796510),m=i(m,f,v,y,g[u+6],9,-1069501632),y=i(y,m,f,v,g[u+11],14,643717713),v=i(v,y,m,f,g[u+0],20,-373897302),f=i(f,v,y,m,g[u+5],5,-701558691),m=i(m,f,v,y,g[u+10],9,38016083),y=i(y,m,f,v,g[u+15],14,-660478335),v=i(v,y,m,f,g[u+4],20,-405537848),f=i(f,v,y,m,g[u+9],5,568446438),m=i(m,f,v,y,g[u+14],9,-1019803690),y=i(y,m,f,v,g[u+3],14,-187363961),v=i(v,y,m,f,g[u+8],20,1163531501),f=i(f,v,y,m,g[u+13],5,-1444681467),m=i(m,f,v,y,g[u+2],9,-51403784),y=i(y,m,f,v,g[u+7],14,1735328473),v=i(v,y,m,f,g[u+12],20,-1926607734),f=a(f,v,y,m,g[u+5],4,-378558),m=a(m,f,v,y,g[u+8],11,-2022574463),y=a(y,m,f,v,g[u+11],16,1839030562),v=a(v,y,m,f,g[u+14],23,-35309556),f=a(f,v,y,m,g[u+1],4,-1530992060),m=a(m,f,v,y,g[u+4],11,1272893353),y=a(y,m,f,v,g[u+7],16,-155497632),v=a(v,y,m,f,g[u+10],23,-1094730640),f=a(f,v,y,m,g[u+13],4,681279174),m=a(m,f,v,y,g[u+0],11,-358537222),y=a(y,m,f,v,g[u+3],16,-722521979),v=a(v,y,m,f,g[u+6],23,76029189),f=a(f,v,y,m,g[u+9],4,-640364487),m=a(m,f,v,y,g[u+12],11,-421815835),y=a(y,m,f,v,g[u+15],16,530742520),v=a(v,y,m,f,g[u+2],23,-995338651),f=c(f,v,y,m,g[u+0],6,-198630844),m=c(m,f,v,y,g[u+7],10,1126891415),y=c(y,m,f,v,g[u+14],15,-1416354905),v=c(v,y,m,f,g[u+5],21,-57434055),f=c(f,v,y,m,g[u+12],6,1700485571),m=c(m,f,v,y,g[u+3],10,-1894986606),y=c(y,m,f,v,g[u+10],15,-1051523),v=c(v,y,m,f,g[u+1],21,-2054922799),f=c(f,v,y,m,g[u+8],6,1873313359),m=c(m,f,v,y,g[u+15],10,-30611744),y=c(y,m,f,v,g[u+6],15,-1560198380),v=c(v,y,m,f,g[u+13],21,1309151649),f=c(f,v,y,m,g[u+4],6,-145523070),m=c(m,f,v,y,g[u+11],10,-1120210379),y=c(y,m,f,v,g[u+2],15,718787259),v=c(v,y,m,f,g[u+9],21,-343485551),f=r(f,l),v=r(v,d),y=r(y,h),m=r(m,p);return n(f)+n(v)+n(y)+n(m)}static 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}}class se{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function ie(e){return new Map(Object.entries(e))}function ae(e,t="export.csv"){const n=new Blob(["\ufeff",e],{type:"text/csv;charset=utf-8;"}),r=URL.createObjectURL(n),o=document.createElement("a");o.href=r,o.download=t,o.style.display="none",document.body.appendChild(o),o.click(),document.body.removeChild(o),URL.revokeObjectURL(r)}class ce{constructor(){this.TransactionId=oe.GenerateUUID()}}var ue,le,de,he,pe,ge,fe,ve,ye,me,we,Se,Ae,_e,Ce;(Ae=ue||(ue={}))[Ae.OK=0]="OK",Ae[Ae.UnknownError=1]="UnknownError",Ae[Ae.FatalError=2]="FatalError",Ae[Ae.WrongData=3]="WrongData",Ae[Ae.ResourceDoesNotExists=4]="ResourceDoesNotExists",Ae[Ae.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",Ae[Ae.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",Ae[Ae.OperationNotPermitted=7]="OperationNotPermitted",Ae[Ae.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",Ae[Ae.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",Ae[Ae.Error=10]="Error",Ae[Ae.NoData=11]="NoData",Ae[Ae.NotSupportedMethod=12]="NotSupportedMethod",Ae[Ae.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",Ae[Ae.MultiDataResponseStart=14]="MultiDataResponseStart",Ae[Ae.MultiDataResponse=15]="MultiDataResponse",Ae[Ae.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"}(le||(le={}));class Te{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"}(de||(de={})),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"}(he||(he={})),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"}(pe||(pe={}));class De extends Error{constructor(e){super(e),this.name="StreamError"}}class ke{constructor(){this._log=ry.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={})),(Ce=fe||(fe={}))[Ce.Any=0]="Any",Ce[Ce.Guest=10]="Guest",Ce[Ce.Standard=20]="Standard",Ce[Ce.Admin=30]="Admin",Ce[Ce.Installator=40]="Installator",Ce[Ce.Support=50]="Support",(_e=ve||(ve={}))[_e.Unknown=0]="Unknown",_e[_e.Men=1]="Men",_e[_e.Woman=2]="Woman",_e[_e.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(ye||(ye={})),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"}(me||(me={}));class Ee{constructor(e,t){this._type=we.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 be{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"}(we||(we={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(Se||(Se={}));class Ie{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=Se.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 Ge=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 Ne{constructor(){this._imageExistsCaseNumber=0,this._connection=ry.Get(Ct.ServiceName),this._logger=ry.Get(c.ServiceName)}GetServiceName(){return Ne.ServiceName}AddPictureAsync(e){return Ge(this,void 0,void 0,(function*(){var t,n;try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ne.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ue.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(Ne.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Ne.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot add picture - Guid must be empty."),ue.WrongData;const s=new Pe;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(Ne.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError;if(i.Status==ue.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Fe(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(Ne.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError):e.Status}return i.Status==ue.OK?(this._logger.Warning(Ne.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ue.UnknownError):(this._logger.Error(Ne.ServiceName,"Cannot add picture - cannot get current picture status."),ue.Error)}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot add picture! ${e}`),ue.FatalError}}))}EditPictureAsync(e){return Ge(this,void 0,void 0,(function*(){var t,n,r,o;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - guid is empty."),ue.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ue.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(Ne.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===s.height||0===s.width)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;const a=new Pe;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(Ne.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==c||null==c.Status)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError;if(c.Status==ue.ResourceDoesNotExists)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - picture not exists."),ue.OperationNotPermitted;if(c.Status==ue.OK){const e=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Fe(a),8e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Ne.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(Ne.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError):e.Status}return this._logger.Error(Ne.ServiceName,"Cannot edit picture - cannot get current picture status."),ue.Error}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot edit picture! ${e}`),ue.FatalError}}))}DeletePictureAsync(e){return Ge(this,void 0,void 0,(function*(){var t,n;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot delete picture - guid is empty."),ue.WrongData;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e.Guid),8e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Ne.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DeletePictureAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==r||null==r.Status?(this._logger.Error(Ne.ServiceName,"Cannot delete picture - unknown error!"),ue.UnknownError):r.Status}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot delete picture! ${e}`),ue.FatalError}}))}GetPicturesInfoAsync(){return Ge(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(Ne.ServiceName,"Cannot get pictures info - unknown error!"),new be(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Ne.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new be(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ne.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new be(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ue;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(Ne.ServiceName,`Cannot get picture info! ${e}`),new be(ue.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){return Ge(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(Ne.ServiceName,"Cannot get picture - unknown error!"),new be(ue.UnknownError,"NoDataInResult");switch(n.Status){case ue.ResourceDoesNotExists:return new be(ue.ResourceDoesNotExists,"PictureNotFound");case ue.OK:if(null==n.Data)return new be(ue.Error,"RespondedWithOKButNoData");const e=new Re;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 be(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot get picture! ${e}`),new be(ue.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){return Ge(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new xe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ne.ServiceName,"Cannot get pictures - unknown error!"),new be(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Ne.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new be(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ne.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new be(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Re;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(Ne.ServiceName,`Cannot get pictures! ${e}`),new be(ue.FatalError,"ExceptionOccurred")}}))}}Ne.ServiceName="PictureService";class Re extends Ie{set DateTime(e){this._dateTime=e}}class Pe{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=Se.Device,this.DateTime=""}}class Ue{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 ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Get,this.Data=e}}class Me extends ce{constructor(){super(),this.Resource="/pictures/info",this.Method=le.Get}}class xe extends ce{constructor(){super(),this.Resource="/pictures/list",this.Method=le.Get}}class Fe extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Put,this.Data=e}}class Le extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Delete,this.Data=e}}class Be{constructor(){this._log=ry.Get(c.ServiceName),Be._localStorageService=ry.Get(l.ServiceName)}GetServiceName(){return Be.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ue.OK&&(this._log.Debug(Be.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Be._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Be._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Be.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Be._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Be.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Be._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Be.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Be._localStorageService=null,Be.ServiceName="WebApiCacheService";var We=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 $e{constructor(){this._connection=null,this._connection=ry.Get(Ct.ServiceName),this._pictureService=ry.Get(Ne.ServiceName),this._sessionService=ry.Get(Xe.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 fe.Support:return n===fe.Support;case fe.Installator:return n>=fe.Installator;case fe.Admin:default:return n>=fe.Admin}}GetServiceName(){return $e.ServiceName}GetUsersAsync(){return We(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ke,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ue.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new ze;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)==ue.NoData)return Promise.resolve([]);throw null===(t=u.Log)||void 0===t||t.Debug($e.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){return We(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 Ve(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ue.OK)return null===(n=u.Log)||void 0===n||n.Debug($e.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const o=new ze;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 We(this,void 0,void 0,(function*(){var n;if(null!=e.Guid&&""!=e.Guid)return new be(ue.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 He(r),2e4,!1);return ry.Get(Be.ServiceName).ClearCache(),null==o||null==o.Status?new be(ue.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new be(o.Status,o.Data))}))}UpdateUserAsync(e){return We(this,void 0,void 0,(function*(){var t;if(null==e.Guid||""==e.Guid)return new be(ue.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 He(n),2e4,!1);return ry.Get(Be.ServiceName).ClearCache(),null==r||null==r.Status?new be(ue.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new be(r.Status,r.Data))}))}ChangePasswordAsync(e,t){return We(this,void 0,void 0,(function*(){var n;if(null==e.Guid||""==e.Guid)return new be(ue.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new be(ue.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 He(o),2e4,!1);return null==s||null==s.Status?new be(ue.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new be(s.Status,s.Data))}))}DeleteUserAsync(e){return We(this,void 0,void 0,(function*(){var t,n;if(""===e)return ue.WrongData;null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new je(e),2e4,!1);return ry.Get(Be.ServiceName).ClearCache(),null==r||null==r.Status?ue.FatalError:(r.Status!=ue.OK&&(null===(n=u.Log)||void 0===n||n.Debug($e.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}))}GetUserProfilePictureAsync(e){return We(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new be(ue.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 ry.Get(Be.ServiceName).ClearCache(),null!=e.Type?t:e}return new be(ue.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return We(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new be(ue.WrongData,"GuidCannotBeEmpty");let n=new Ie;n.ImageType=Se.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(ry.Get(Be.ServiceName).ClearCache(),r.Type==ue.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ue.OK?new be(ue.OK,"PictureSet"):new be(e,"PictureServiceError")}if(null!=r.Type)return new be(ue.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ue.OK?new be(ue.OK,"PictureSet"):new be(e,"PictureServiceError")}}))}}$e.ServiceName="UsersService";class Ve extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Get,this.Data=e}}class qe{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=ve.Unknown,this.AccessLevel=fe.Any}}class He extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Put,this.Data=e}}class Ke extends ce{constructor(){super(),this.Resource="/users/list",this.Method=le.Get}}class je extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Delete,this.Data=e}}class ze{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=ve.Unknown,this._accessLevel=fe.Any,this._localization=ye.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 ry.Get($e.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return ry.Get($e.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var Je=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 Xe{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 Je(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{this.OnUserLoggedInEvent().Subscribe((t=>{var n;null===(n=u.Log)||void 0===n||n.Debug(Xe.ServiceName,`Logged in as ${t.Name}, completing CreateSessionCompletionSourceAsync()`),e()}))}))}))}isLoginError(e){return"number"==typeof e&&void 0!==me[e]}RestoreSessionAsync(){return Je(this,void 0,void 0,(function*(){var e,t,n,r,o;if(null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0===this._user||null===this._user)return!1;const s=ry.Get(Ct.ServiceName),i=s.GetAuthorizationInfo();return null===i?(null===(t=u.Log)||void 0===t||t.Error(Xe.ServiceName,"RestoreSessionAsync failed, no authorization info"),!1):(yield s.AuthorizeAsync(i))?this.isLoginError(yield this.UserLogInAsync(this._email,this._password))?(null===(r=u.Log)||void 0===r||r.Error(Xe.ServiceName,"RestoreSessionAsync failed, user login failed"),!1):(null===(o=u.Log)||void 0===o||o.Debug(Xe.ServiceName,"RestoreSessionAsync completed successfully"),!0):(null===(n=u.Log)||void 0===n||n.Error(Xe.ServiceName,"RestoreSessionAsync failed, authorization failed"),!1)}))}WaitForSessionCreationAsync(){return Je(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){return Je(this,void 0,void 0,(function*(){var e,t,n=new ce;n.Resource="/users/user/logout",n.Method=le.Put,this._email="",this._password="",(yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ue.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,"User has been logged out.")):null===(t=u.Log)||void 0===t||t.Debug(Xe.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return Je(this,void 0,void 0,(function*(){switch(e){case pe.Disconnected:case pe.Failed:case pe.ConnectedAndAuthorized:case pe.Connected:}}))}AuthorizeAppAsync(e){return Je(this,void 0,void 0,(function*(){var t,n,r,o,s=ry.Get(Ct.ServiceName);const i=yield s.SendAndWaitForResponseAsync(new Qe(e),2e4,!1);if(i.Status==ue.OK&&null!=i.Data){this._authToken=e;var a=new ze;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&&(at.ConfigurationTimeRetrieved=new Date(i.Data.ConfigurationTime)),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,s.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged),ry.Get(Ct.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Je(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Xe.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(Xe.ServiceName,`Did logging in succeded?: ${i.Status==ue.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return i.Status===ue.OperationNotPermitted?(null===(n=u.Log)||void 0===n||n.Debug(Xe.ServiceName,`App login response: ${i.Data}`),me.AuthDisabled):i.Status===ue.ResourceDoesNotExists?(null===(r=u.Log)||void 0===r||r.Debug(Xe.ServiceName,`App login response: ${i.Data}`),me.MethodNotSupported):(null===(o=u.Log)||void 0===o||o.Debug(Xe.ServiceName,`App login response: ${i.Data}`),me.WrongAuthData)}))}UserLogInAsync(e,t){return Je(this,void 0,void 0,(function*(){var n,r,o=ry.Get(Ct.ServiceName);const s=yield o.SendAndWaitForResponseAsync(new Ze(e,t),2e4,!1);if(s.Status==ue.OK&&null!=s.Data){this._email=e,this._password=t;var i=new ze;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&&(at.ConfigurationTimeRetrieved=new Date(s.Data.ConfigurationTime)),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,o.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged),ry.Get(Ct.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Je(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Xe.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(Xe.ServiceName,`Did logging in succeded?: ${s.Status==ue.OK}`),this._onUserLoggedInEvent.Invoke(this._user),i}return null===(r=u.Log)||void 0===r||r.Debug(Xe.ServiceName,`User login response: ${s.Data}`),me.WrongAuthData}))}GetServiceName(){return Xe.ServiceName}}Xe.ServiceName="SessionService";class Ye{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class Qe extends ce{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=le.Put}}class Ze extends ce{constructor(e,t){super(),this.Data=new Ye(e,t),this.Resource="/users/user/login",this.Method=le.Put}}class et{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 tt=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 nt{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new et(1)}GetServiceName(){return nt.ServiceName}GetExtensionsInfoAsync(e){return tt(this,arguments,void 0,(function*(e,t=!1){var n;null===(n=u.Log)||void 0===n||n.Debug(nt.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 st("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e){return tt(this,arguments,void 0,(function*(e,t=!1,n=!1){var r;if(null===(r=u.Log)||void 0===r||r.Debug(nt.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 st("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 st("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return tt(this,void 0,void 0,(function*(){const e=new rt,t=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(e,16e3,!0);if(null==t||null==t.Status)throw new st("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ue.OK)throw new st(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new st("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 tt(this,void 0,void 0,(function*(){var e;const t=new ot,n=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(t,16e3,!0);if(null==n||null==n.Status)throw new st("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(n.Status){case ue.OK:if(null==n.Data)throw new st("Cannot get ProtocolInfo from controller, controller response does not contain data!");n.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ue.ResourceDoesNotExists:null===(e=u.Log)||void 0===e||e.Debug(nt.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new st(`Cannot get ProtocolInfo from controller! Response status: ${n.Status}`)}}))}}nt.ServiceName="StatisticsInfoService";class rt extends ce{constructor(){super(),this.Resource="/controller/extensions/",this.Method=le.Get}}class ot extends ce{constructor(){super(),this.Resource="/controller/protocols/",this.Method=le.Get}}class st extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var it=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 at{OnConfigurationChangedEvent(){return this._onConfigurationChangedEvent}GetServiceName(){return at.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new ke,this._onExitedConfigurationEvent=new ke,this._onConfigurationTimeCheckedEvent=new a,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{ry.Get(Xe.ServiceName).OnUserLoggedInEvent().Subscribe((t=>it(this,void 0,void 0,(function*(){null!==at.ConfigurationTimeRetrieved?this._didConfigurationChange=yield this.CheckIfConfigurationTimeHasChangedAsync(at.ConfigurationTimeRetrieved):this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),this._didConfigurationChange&&ry.Get(Be.ServiceName).ClearCache(),e()}))))})),this._onConfigurationChangedEvent=new ke,this._connection=ry.Get(Ct.ServiceName),this._session=ry.Get(Xe.ServiceName),this._localStorage=ry.Get(l.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{ry.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{var t;ry.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke(),null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.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 it(this,void 0,void 0,(function*(){var t,n,r;let o=yield e.text(),s=this.SplitStringBySize(o),i=new ct("");i.Status=ue.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)!=ue.OK)return ue.Error;for(const e of s){let t=new ct(e);t.Status=ue.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)!=ue.OK)return ue.Error}i.Status=ue.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)!=ue.OK?ue.Error:ue.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 it(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 vt,8e3,!1);return null==n||null==n.Status?ue.Error:n.Status!=ue.OK?n.Status:null==n.Data?ue.ResourceIsNotAvailable:new Date(n.Data)}catch(e){return null===(t=u.Log)||void 0===t||t.Error(at.ServiceName,`Cannot get current controller time! ${e}`),ue.FatalError}}))}SetControllerSystemTimeAsync(e){return it(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 yt(e.toISOString()),8e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return null===(n=u.Log)||void 0===n||n.Error(at.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}StartNtpTimeSynchronizationAsync(){return it(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 mt,8e3,!1);return null==n||null==n.Status?ue.Error:n.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(at.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}FactoryResetAsync(e){return it(this,void 0,void 0,(function*(){var t,n;try{ry.Get(Be.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==ue.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),ry.Get(Be.ServiceName).ClearCache(),clearInterval(o),ue.OK}return r}catch(e){return ue.FatalError}}))}RollbackLastUpdateAsync(e){return it(this,void 0,void 0,(function*(){var t,n;try{ry.Get(Be.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ht,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.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),ry.Get(Be.ServiceName).ClearCache(),clearInterval(o),ue.OK}return r}catch(e){return ue.FatalError}}))}RestartControllerAsync(e){return it(this,void 0,void 0,(function*(){var t,n;try{ry.Get(Be.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==ue.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),ry.Get(Be.ServiceName).ClearCache(),clearInterval(o),ue.OK}return r}catch(e){return ue.FatalError}}))}DidCofigurationChangeAsync(){return it(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 it(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,ry.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new pt,2e4,!1)}))}ExitConfigurationModeAsync(){return it(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,ry.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new gt,2e4,!1),this._didConfigurationChange=!0,ry.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._didConfigurationChange=!0,this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){return it(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ft,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ue.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return it(this,void 0,void 0,(function*(){var e,t;const n=yield this.GetLastConfigurationChangeTimeAsync();return null===(e=u.Log)||void 0===e||e.Info(at.ServiceName,`Checking if configuration time has changed. Current: ${n.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=n.toString()&&(this.SaveLastConfigurationChangeTime(n),ry.Get(Be.ServiceName).ClearCache(),null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(n),!0)}))}CheckIfConfigurationTimeHasChangedAsync(e){return it(this,void 0,void 0,(function*(){var t,n;return null===(t=u.Log)||void 0===t||t.Info(at.ServiceName,`Checking if configuration time has changed. Current: ${e.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),ry.Get(Be.ServiceName).ClearCache(),null===(n=this.OnConfigurationChangedEvent())||void 0===n||n.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(e),!0)}))}CanExportOrImportControllerConfigurationAsync(){return it(this,void 0,void 0,(function*(){try{let e=yield ry.Get(nt.ServiceName).GetExtensionsInfoAsync(),t=ry.Get(Xe.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=fe.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){return it(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 ut,3e4,(e=>{switch(e.Status){case ue.MultiDataResponseStart:break;case ue.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);break;case ue.MultiDataResponseStop:break;case ue.Error:case ue.FatalError:n=new be(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:ry.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`}}at.ServiceName="ControllerConfigurationService",at.ConfigurationTimeRetrieved=null;class ct extends ce{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=le.Put,this.Data=e}}class ut extends ce{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=le.Get}}class lt extends ce{constructor(){super(),this.Resource="/controller/restart",this.Method=le.Post}}class dt extends ce{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=le.Post}}class ht extends ce{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=le.Post}}class pt extends ce{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=le.Put}}class gt extends ce{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=le.Put}}class ft extends ce{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=le.Get}}class vt extends ce{constructor(){super(),this.Resource="/system/time",this.Method=le.Get}}class yt extends ce{constructor(e){super(),this.Resource="/system/time",this.Method=le.Put,this.Data=e}}class mt extends ce{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=le.Put}}var wt=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 St{nextRetryDelayInMilliseconds(){return 1e3}}const At=[t.WebSockets,t.ServerSentEvents,t.LongPolling];class _t{constructor(){this._log=ry.Get(c.ServiceName)}log(e,t){if(!(e<Ct.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 Ct{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=ry.Get(c.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._dataReceivedEvent=new a,this._pongReceivedEvent=new ke,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(Ct.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._onVisibility=()=>{"visible"===document.visibilityState&&(this._log.Debug(Ct.ServiceName,"Page visible → connection check"),this.validateConnectionToController().then((e=>{e||(this._log.Debug(Ct.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())})))},this._onHidden=()=>{},this._onVisible=()=>{this.validateConnectionToController().then((e=>{e||(this._log.Debug(Ct.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))}}GetServiceName(){return Ct.ServiceName}GetAuthorizationInfo(){return this._serialId&&this._PIN?new Te(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 wt(this,void 0,void 0,(function*(){if(!this._serialId)return this._log.Warning(Ct.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(Ct.ServiceName,`Broker address resolved: ${e}`),e):(this._log.Warning(Ct.ServiceName,"Broker returned empty address"),null)}case 204:return this._allBrokersChecked?(this._log.Error(Ct.ServiceName,"All brokers checkt but controller not found! Controller probably offline!"),null):(this._log.Warning(Ct.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(Ct.ServiceName,`GetServerAddressAsync() – HTTP ${t.status}`),null}}catch(e){return this._log.Error(Ct.ServiceName,String(e)),null}}))}rotateServersBroker(){return wt(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(Ct.ServiceName,`Switching servers‑broker to: ${this._serversBrokerAddress}`)}))}ConnectAsync(e){return wt(this,void 0,void 0,(function*(){return this._address=e,this.serialisedConnect()}))}ConnectAndAuthorizeAsync(e){return wt(this,void 0,void 0,(function*(){this._serialId=e.serialNumber,this._PIN=e.pin,ry.WorksInContextOf=this._serialId;let t=yield this.GetServerAddressAsync();if(t&&(this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e))))return he.Connected;for(const t of this._packetsBrokerServers)if(this._log.Info(Ct.ServiceName,`Fallback broker: ${t}`),this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e)))return he.Connected;return he.FailedToConnect}))}AuthorizeAsync(e){return wt(this,void 0,void 0,(function*(){return new Promise((t=>wt(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(Ct.ServiceName,`Authorization → ${e}`),e&&this._connectionStateChangedEvent.Invoke(pe.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 wt(this,void 0,void 0,(function*(){var e;this._disconnectedOnPurpose=!0,this._log.Debug(Ct.ServiceName,"Disconnecting..."),yield null===(e=this._connection)||void 0===e?void 0:e.stop(),this.cleanup()}))}SendAsync(e){return wt(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(Ct.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(Ct.ServiceName,String(e)),!1}}))}SendAndWaitForResponseAsync(e,t,n){return wt(this,arguments,void 0,(function*(e,t,n,r=!0){var o,s,i;if(e.Method===le.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)=>wt(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===le.Get&&n&&(null===(c=this._cache)||void 0===c||c.Cache(s)),n||s.Status!==ue.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 wt(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)=>wt(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 ue.MultiDataResponseStart:case ue.MultiDataResponse:n(t),a=i();break;case ue.MultiDataResponseStop:case ue.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 wt(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)=>wt(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 De(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 wt(this,void 0,void 0,(function*(){if(!this.IsConnected())return!1;if(Date.now()-this._lastReceivedPacket<Ct.PING_INTERVAL_MS)return!1;const e=new ce;e.Resource="/system/ping",e.Method=le.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 wt(this,void 0,void 0,(function*(){var n,o,i,a,c;if(!this._address)return he.ControllerIsNotConnected;if((null===(n=this._connection)||void 0===n?void 0:n.state)===s.Reconnecting){this._log.Info(Ct.ServiceName,"Connection is already in reconnecting state - letting automatic reconnect handle it");try{return yield this.waitForReconnection(),this._log.Info(Ct.ServiceName,"Automatic reconnect successful"),he.Connected}catch(e){this._log.Warning(Ct.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(Ct.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 At){var u=(new re).withAutomaticReconnect(new St).configureLogging(new _t).withStatefulReconnect({bufferSize:256e3}).withServerTimeout(Ct.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(pe.Connected),he.Connected}catch(e){this._log.Warning(Ct.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(pe.Failed),he.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===pe.Connected?(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),t()):e!==pe.Disconnected&&e!==pe.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=ry.Get(at.ServiceName),this._cache=ry.Get(Be.ServiceName),this._session=ry.Get(Xe.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 Te(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(Ct.ServiceName,`Received: ${JSON.stringify(JSON.parse(t),null,2)}`),this._dataReceivedEvent.Invoke(JSON.parse(t))})),this._connection.onclose((()=>{this.cleanup(),this._connectionStateChangedEvent.Invoke(pe.Disconnected)})),this._connection.onreconnecting((()=>this._connectionStateChangedEvent.Invoke(pe.Reconnecting))),this._connection.onreconnected((()=>this._connectionStateChangedEvent.Invoke(pe.Connected))))}startPingLoop(){null!==this._pingTimerId&&clearInterval(this._pingTimerId),this._pingTimerId=window.setInterval((()=>{this.pingOnce()}),Ct.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 wt(this,void 0,void 0,(function*(){this.IsConnected()&&(Date.now()-this._lastReceivedPacket<Ct.PING_INTERVAL_MS||((yield this.PingControllerAsync())?this._consecutivePingFailures=0:++this._consecutivePingFailures>=Ct.MAX_CONSECUTIVE_PING_FAILURES&&(this._consecutivePingFailures=0,this._log.Warning(Ct.ServiceName,"Ping failed too many times → reconnecting..."),Ct.SERVER_TIMOUT_MS<Ct.PING_INTERVAL_MS*Ct.MAX_CONSECUTIVE_PING_FAILURES&&this._log.Error("Server timeout is shorter than ping interval! SignalR automatic reconnect will not work!."),this.serialisedConnect())))}))}validateConnectionToController(){return wt(this,void 0,void 0,(function*(){var e;if(!this.IsConnected())return this._log.Warning(Ct.ServiceName,"Connection was lost."),!1;{const n=new ce;n.Resource="/system/ping",n.Method=le.Get;try{var t=yield this.SendAndWaitForResponseAsync(n,Ct.SERVER_TIMOUT_MS+1e3,!1,!1);return(null==t?void 0:t.Status)!==ue.OK?(this._log.Warning(Ct.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(Ct.ServiceName,"Connection check failed, but connection is in reconnecting state!"),!1):(this._log.Info(Ct.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 Tt,Dt,kt,Et,bt,It,Gt,Nt,Rt,Pt,Ut,Ot,Mt,xt,Ft,Lt;Ct.PING_INTERVAL_MS=5e3,Ct.MAX_CONSECUTIVE_PING_FAILURES=6,Ct.SERVER_TIMOUT_MS=1e4,Ct.SignalRLogLevel=r.Warning,Ct.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(Tt||(Tt={})),(Ot=Dt||(Dt={}))[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"}(kt||(kt={}));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}}(Mt=Et||(Et={}))[Mt.Unknown=0]="Unknown",Mt[Mt.BlindMotor=1]="BlindMotor",Mt[Mt.DinModule=2]="DinModule",Mt[Mt.DinModuleWithAntenna=3]="DinModuleWithAntenna",Mt[Mt.Remote=4]="Remote",Mt[Mt.RemoteForBlinds=5]="RemoteForBlinds",Mt[Mt.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",Mt[Mt.MovementSensor=7]="MovementSensor",Mt[Mt.TemperatureSensor=8]="TemperatureSensor",Mt[Mt.HumiditySensor=9]="HumiditySensor",Mt[Mt.DinPowerMeter=10]="DinPowerMeter",Mt[Mt.Intercom=11]="Intercom",Mt[Mt.SecurityCamera=12]="SecurityCamera",Mt[Mt.Multisensor=13]="Multisensor",Mt[Mt.FloodSensor=14]="FloodSensor",Mt[Mt.FlushMountedReceiver=15]="FlushMountedReceiver",Mt[Mt.FlushMountedBlindController=16]="FlushMountedBlindController",Mt[Mt.FlushMountedDimmer=17]="FlushMountedDimmer",Mt[Mt.FlushMountedRelay=18]="FlushMountedRelay",Mt[Mt.FlushMountedGateController=19]="FlushMountedGateController",Mt[Mt.WindSensor=20]="WindSensor",Mt[Mt.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",Mt[Mt.AirPressureSensor=22]="AirPressureSensor",Mt[Mt.LightBrightnessSensor=23]="LightBrightnessSensor",Mt[Mt.ReedSensor=24]="ReedSensor",Mt[Mt.FlushMountedTransceiver=25]="FlushMountedTransceiver",Mt[Mt.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",Mt[Mt.WallMountedThermoregulator=27]="WallMountedThermoregulator",Mt[Mt.ImpulseCounter=28]="ImpulseCounter",Mt[Mt.FlushMountedFacadeController=29]="FlushMountedFacadeController",Mt[Mt.WallMountedGateController=30]="WallMountedGateController",Mt[Mt.WallMountedRGBLightController=31]="WallMountedRGBLightController",Mt[Mt.WallMountedDimmer=32]="WallMountedDimmer",Mt[Mt.WallMountedRemote=33]="WallMountedRemote",Mt[Mt.DinRelay=34]="DinRelay",Mt[Mt.DinReceiver=35]="DinReceiver",Mt[Mt.DinBlindController=36]="DinBlindController",Mt[Mt.DinTransceiver=37]="DinTransceiver",Mt[Mt.SocketPlugIn=38]="SocketPlugIn",Mt[Mt.WallMountedRelay=39]="WallMountedRelay",Mt[Mt.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"}(bt||(bt={}));class Wt{constructor(){this._type=It.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"}(It||(It={})),(Lt=Gt||(Gt={}))[Lt.NotResponding=0]="NotResponding",Lt[Lt.Working=1]="Working",Lt[Lt.Broken=2]="Broken",Lt[Lt.FirmareUpgradeMode=3]="FirmareUpgradeMode",(Ft=Nt||(Nt={}))[Ft.TwoWay=1]="TwoWay",Ft[Ft.OneWay=2]="OneWay",Ft[Ft.ConditionalTwoWay=3]="ConditionalTwoWay",(xt=Rt||(Rt={}))[xt.Unknown=-1]="Unknown",xt[xt.Multipurpose=0]="Multipurpose",xt[xt.Controller=1]="Controller",xt[xt.Driver=2]="Driver",xt[xt.Receiver=3]="Receiver",xt[xt.Remote=4]="Remote",xt[xt.Sensor=5]="Sensor",xt[xt.Scene=6]="Scene";class $t{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=Tt.NoTasksExecuting}}!function(e){e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed",e[e.ResponseTimeout=2]="ResponseTimeout",e[e.TaskRepeatedAndExecuted=3]="TaskRepeatedAndExecuted",e[e.TaskRepeatedResponseTimeout=4]="TaskRepeatedResponseTimeout",e[e.FlowControlNotAvailable=5]="FlowControlNotAvailable",e[e.ExecutionError=6]="ExecutionError"}(Pt||(Pt={})),function(e){e[e.ControllerResponseTimeout=-4]="ControllerResponseTimeout",e[e.DeviceNotFound=-3]="DeviceNotFound",e[e.DeviceResponseTimeout=-2]="DeviceResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed"}(Ut||(Ut={}));class Vt{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=Ut.Unknown}}var qt,Ht,Kt,jt,zt,Jt,Xt,Yt,Qt,Zt,en,tn,nn,rn,on,sn,an,cn,un,ln,dn,hn,pn,gn,fn,vn,yn,mn,wn,Sn,An;class _n{constructor(){this._type="",this._data=null,this._typeAsEnum=It.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}}(An=qt||(qt={}))[An.Confident=0]="Confident",An[An.Unconfident=1]="Unconfident";class Cn extends _n{constructor(e){super(),this.TypeAsEnum=It.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class Tn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Ht.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Ht||(Ht={}));class Dn extends _n{constructor(e){super(),this.TypeAsEnum=It.HallState,this.Type="IHallState",this.Data=e.state}}class kn extends _n{constructor(e){super(),this.TypeAsEnum=It.SceneExecuted,this.Type="ISceneExecuted",this.Data=e.state}}class En extends _n{constructor(e){super(),this.TypeAsEnum=It.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"}(Kt||(Kt={}));class bn extends _n{constructor(e){super(),this.TypeAsEnum=It.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class In extends _n{constructor(e){super(),this.TypeAsEnum=It.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class Gn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=jt.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(jt||(jt={}));class Nn extends _n{constructor(e){super(),this.TypeAsEnum=It.ReedState,this.Type="ReedState",this.Data=e.state}}class Rn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=!1,this.Time=""}}class Pn extends _n{constructor(e){super(),this.TypeAsEnum=It.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return zt.UnableToMove;case 201:return zt.MotorOverheatedPleaseWait;default:return zt.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(zt||(zt={}));class Un{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class On extends _n{constructor(e){super(),this.TypeAsEnum=It.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class Mn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Jt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(Jt||(Jt={}));class xn extends _n{constructor(e){super(),this.TypeAsEnum=It.LightColor,this.Type="LightColorState",this.Data=e.state}}class Fn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class Ln extends _n{constructor(e){super(),this.TypeAsEnum=It.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class Bn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Temperature=0,this.Time=""}}class Wn extends _n{constructor(e){super(),this.TypeAsEnum=It.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class $n{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class Vn extends _n{constructor(e){super(),this.TypeAsEnum=It.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class qn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Temperature=0,this.Type=Xt.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"}(Xt||(Xt={}));class Hn extends _n{constructor(e){super(),this.TypeAsEnum=It.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Kn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Yt.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"}(Yt||(Yt={}));class jn extends _n{constructor(e){super(),this.TypeAsEnum=It.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class zn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class Jn extends _n{constructor(e){super(),this.TypeAsEnum=It.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class Xn{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"}(Qt||(Qt={}));class Yn extends _n{constructor(e){super(),this.TypeAsEnum=It.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Zt||(Zt={}));class Qn extends _n{constructor(e){super(),this.TypeAsEnum=It.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Zn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Intensity=0,this.Movement=en.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(en||(en={}));class er extends _n{constructor(e){super(),this.TypeAsEnum=It.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class tr{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 nr extends _n{constructor(e){super(),this.TypeAsEnum=It.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class rr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=nn.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"}(nn||(nn={}));class or extends _n{constructor(e){super(),this.TypeAsEnum=It.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"}(rn||(rn={}));class sr extends _n{constructor(e){super(),this.TypeAsEnum=It.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class ir{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.PositionType=on.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"}(on||(on={}));class ar extends _n{constructor(e){super(),this.TypeAsEnum=It.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"}(sn||(sn={}));class cr extends _n{constructor(e){super(),this.TypeAsEnum=It.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"}(an||(an={}));class ur extends _n{constructor(e){super(),this.TypeAsEnum=It.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"}(cn||(cn={}));class lr extends _n{constructor(e){super(),this.TypeAsEnum=It.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class dr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Type=un.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"}(un||(un={}));class hr extends _n{constructor(e){super(),this.TypeAsEnum=It.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(ln||(ln={}));class pr extends _n{constructor(e){super(),this.TypeAsEnum=It.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class gr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=dn.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(dn||(dn={}));class fr extends _n{constructor(e){super(),this.TypeAsEnum=It.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"}(hn||(hn={}));class vr extends _n{constructor(e){super(),this.TypeAsEnum=It.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class yr extends _n{constructor(e){super(),this.TypeAsEnum=It.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class mr extends _n{constructor(e){super(),this.TypeAsEnum=It.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class wr extends _n{constructor(e){super(),this.TypeAsEnum=It.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class Sr extends _n{constructor(e){super(),this.TypeAsEnum=It.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Ar extends _n{constructor(e){super(),this.TypeAsEnum=It.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class _r{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.WindThreshold=pn.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"}(pn||(pn={}));class Cr extends _n{constructor(e){super(),this.TypeAsEnum=It.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 Tr extends _n{constructor(e){super(),this.TypeAsEnum=It.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class Dr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Value=0,this.Time=""}}class kr extends _n{constructor(e){super(),this.TypeAsEnum=It.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class Er{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=fn.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(fn||(fn={})),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"}(vn||(vn={}));class br extends _n{constructor(e){super(),this.TypeAsEnum=It.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class Ir{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Pressure=0,this.Time="",this.PressureType=yn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(yn||(yn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(mn||(mn={}));class Gr extends _n{constructor(e){super(),this.TypeAsEnum=It.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(wn||(wn={}));class Nr extends _n{constructor(e){super(),this.TypeAsEnum=It.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Rr extends _n{constructor(e){super(),this.TypeAsEnum=It.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"}(Sn||(Sn={}));class Pr{constructor(){this._onDeviceStateChangedEvent=new a,this._onDeviceStateRefreshedOrChangedEvent=new a,this._onDeviceTasksExecutionChangedOnChannelsEvent=new a,this._onDeviceFirmwareVersionChangedEvent=new a,this._iconType=Et.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=Gt.Working,this._deviceType=Rt.Unknown,this._communicationWay=Nt.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==Pr._devicesService&&(Pr._devicesService=ry.Get(Qs.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Pr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Pr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),Pr._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===Rt.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!==bt.SetBlindPositionSimple))}return!1}get States(){return c.DoesThrowStackTrace?ry.Get(Qs.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Pr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Pr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Pr._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 ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new Ur(this,e),2e4,!1);switch(n.Status){case ue.OK:return this._name=e,null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeDeviceNameAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),new Ee(we.Changed,"");case ue.WrongData:if("DeviceNotFound"==n.Data)return new Ee(we.Failed,"DeviceNotFound");break;case ue.NoPermissionsToCallGivenResource:return new Ee(we.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new Ee(we.ControllerResponseTimeout,""):new Ee(we.UnknownError,"")}return new Ee(we.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 Pr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class Ur extends ce{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=le.Put;const n=new Or;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class Or{constructor(){this.DeviceGuid="",this.Name=""}}var Mr,xr,Fr,Lr,Br,Wr=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 $r{constructor(){this._device=new Pr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=Dt.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==$r._devicesService&&($r._devicesService=ry.Get(Qs.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 Wr(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new Vr;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 Vr;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 Vr;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 Vr;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Vr;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 Vr;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 Vr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){return Wr(this,void 0,void 0,(function*(){var t,n;try{const r=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new Hr(e),2e4,!1);switch(null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeConfigurationAsync()"),yield ry.Get(at.ServiceName).ExitConfigurationModeAsync(),r.Status){case ue.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 Ee(we.Changed,"");case ue.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 Ee(we.WrongData,"DeviceNotFound");break;case ue.FatalError:return new Ee(we.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new Ee(we.ControllerResponseTimeout,"")}return new Ee(we.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?ry.Get(Qs.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():$r._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,$r._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(Ut.Failed)}}$r._devicesService=null;class Vr{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new qr}}class qr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=Dt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class Hr extends ce{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=le.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"}(Mr||(Mr={}));class Kr{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 jr{constructor(){this._taskType=bt.GetChannelsState,this._featureType=Mr.GetState,this._channel=0,this._guid=Kr.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 zr extends jr{constructor(){super(),this.Temperature=0,this.FeatureType=Mr.SetTemperature,this.TaskType=bt.SetTemperature}}class Jr extends jr{constructor(){super(),this.FeatureType=Mr.TurnOff,this.TaskType=bt.TurnOff}}class Xr extends jr{constructor(){super(),this.FeatureType=Mr.TurnOn,this.TaskType=bt.TurnOn}}class Yr extends jr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=Mr.TurnOnWithTimeout,this.TaskType=bt.TurnOnWithTime}}class Qr extends jr{constructor(){super(),this.Brightness=0,this.FeatureType=Mr.SetLightBrightness,this.TaskType=bt.SetLightBrightness}}class Zr extends jr{constructor(){super(),this.FeatureType=Mr.ToggleState,this.TaskType=bt.TogleState}}class eo extends jr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=Mr.SetLightColor,this.TaskType=bt.SetLightColor}}class to extends jr{constructor(){super(),this.Temperature=0,this.FeatureType=Mr.SetLightTemperature,this.TaskType=bt.SetLightTemperature}}class no extends jr{constructor(){super(),this.Action=xr.Stop,this.Position=0,this.FeatureType=Mr.SetBlindPosition,this.TaskType=bt.SetBlindPosition}}!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 jr{constructor(){super(),this.GateControlAction=Fr.Stop,this.Position=0,this.FeatureType=Mr.SetGatePositionPrecise,this.TaskType=bt.PreciseGateControl}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Fr||(Fr={}));class oo extends jr{constructor(){super(),this.Action=Lr.Stop,this.Position=0,this.FeatureType=Mr.SetBlindPosition,this.TaskType=bt.SetBlindPositionSimple}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Lr||(Lr={}));class so extends jr{constructor(){super(),this.Brightness=0,this.FeatureType=Mr.SetLightBrightnessDynamicly,this.TaskType=bt.SetLightBrightnessDynamicly}}class io extends jr{constructor(){super(),this.FeatureType=Mr.IdentifyDevice,this.TaskType=bt.IdentifyDevice}}class ao extends jr{constructor(){super(),this.Data=new co,this.FeatureType=Mr.SetBlindOpenCloseTime,this.TaskType=bt.SetBlindOpenCloseTime}}class co{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class uo extends jr{constructor(){super(),this.FeatureType=Mr.GetState,this.TaskType=bt.GetChannelsState}}class lo extends jr{constructor(){super(),this.Position=0,this.FeatureType=Mr.SetBlindMicroventilation,this.TaskType=bt.SetBlindMicroventilation}}class ho extends jr{constructor(){super(),this.FeatureType=Mr.GatePulse,this.TaskType=bt.ChangeGatewayPositionPulse}}class po extends jr{constructor(){super(),this.FeatureType=Mr.GatewayPulse,this.TaskType=bt.ChangeGatewayPositionPulse}}class go extends jr{constructor(){super(),this.FacadeAction=Br.Stop,this.Tilt=0,this.Position=0,this.FeatureType=Mr.SetFacadePositionAndTilt,this.TaskType=bt.SetFacadePosition}}class fo extends jr{constructor(){super(),this.FeatureType=Mr.GetFacadeType,this.TaskType=bt.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"}(Br||(Br={}));class vo{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class yo extends jr{constructor(){super(),this.Data=new vo,this.FeatureType=Mr.LightRGBW,this.TaskType=bt.LightRGBW}}var mo=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 wo{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return wo.ServiceName}RegisterManuallyPairedDevicesProtocol(e){var t;null===(t=u.Log)||void 0===t||t.Debug(wo.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return mo(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 mo(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(wo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDeviceAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),Ut.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}wo.ServiceName="ManualDeviceService";class So{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var Ao,_o=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 Co{constructor(){this._connection=null,this._localDb=null,this._connection=ry.Get(Ct.ServiceName),this._localDb=ry.Get(l.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return _o(this,void 0,void 0,(function*(){let r=new To(e,t,n),o=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(o.Status===ue.OK){const r=new Eo;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(Co.ServiceName,this.GetLocalDbName(e,t),r)}return o.Status}))}ReadAsync(e,t,n){return _o(this,void 0,void 0,(function*(){let r=new Do(e,t);if(!n){const n=this._localDb.Read(Co.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new So;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===ue.OK){const e=new So;return e.ResourceGuid=o.ResourceGuid,e.Data=JSON.parse(o.Data),e.IsGlobal=o.IsGlobal,e}return o.Status}))}RemoveAsync(e,t){return _o(this,void 0,void 0,(function*(){let n=new ko(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return Co.ServiceName}}Co.ServiceName="RemoteStorageService";class To extends ce{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class Do extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Get,this.ResourceGuid=e,this.Global=t}}class ko extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Delete,this.ResourceGuid=e,this.Global=t}}class Eo extends ce{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class bo{constructor(){this.Longitude=0,this.Latitude=0}}class Io{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"}(Ao||(Ao={}));var Go,No,Ro=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 Po{IsControllerGeolocationSetAsync(){return Ro(this,void 0,void 0,(function*(){let e=new Uo,t=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ue.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return Ro(this,void 0,void 0,(function*(){return new Promise(((e,t)=>Ro(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){return Ro(this,void 0,void 0,(function*(){var t,n,r;let o=new Mo;o.Data.Latitude=e.Latitude,o.Data.Longitude=e.Longitude,null===(t=u.Log)||void 0===t||t.Warning(Po.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(o)}`);let s=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(o,15e3,!1);switch(null===(n=u.Log)||void 0===n||n.Warning(Po.ServiceName,`${JSON.stringify(s)}`),null===(r=u.Log)||void 0===r||r.Error(Po.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetControllerGeolocationAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==s?void 0:s.Status){case ue.OK:return new be(Ao.OK,"");case ue.NoPermissionToPerformThisOperation:case ue.NoPermissionsToCallGivenResource:return new be(Ao.NoPermissions,"");case ue.UserIsNotLoggedIn:return new be(Ao.UserIsNotLoggedIn,"");default:return new be(Ao.UnknownError,"")}}))}GetControlllerGeolocationAsync(){return Ro(this,void 0,void 0,(function*(){var e,t;let n=new Oo;null===(e=u.Log)||void 0===e||e.Warning(Po.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=u.Log)||void 0===t||t.Warning(Po.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ue.OK){let e=new Io;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 Po.ServiceName}}Po.ServiceName="GeolocationService";class Uo extends ce{constructor(){super(),this.Resource="/geolocation/isset",this.Method=le.Get}}class Oo extends ce{constructor(){super(),this.Resource="/geolocation/get",this.Method=le.Get}}class Mo extends ce{constructor(){super(),this.Data=new bo,this.Resource="/geolocation/save",this.Method=le.Put}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Go||(Go={}));class xo{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=No.Unknown,this.ResourceGuid=""}}class Fo{constructor(){this.UpdateDescription=new Map,this.Update=new xo,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"}(No||(No={}));class Lo extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var Bo,Wo,$o,Vo,qo,Ho,Ko,jo,zo,Jo,Xo,Yo,Qo,Zo,es,ts,ns,rs,os=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 ss{constructor(){this._services=new Map,this._runtimeInfo=new is,this._hardwareInfo=new cs,this._semaphore=new et(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return ss.ServiceName}RegisterUpdatesProvider(e){var t;null===(t=u.Log)||void 0===t||t.Debug(ss.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return os(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(ss.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const n=this._services.get(e);if(null==n)throw new Lo("Cannot get update provider! Requested update provider has not been registered.");return n}))}GetUpdatesProvidersAsync(e){return os(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(ss.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 Lo("Cannot get update providers! Requested update providers has not been registered.");return n}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return os(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(ss.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 Lo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Lo("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return os(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(ss.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 Lo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Lo("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(){return os(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 os(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(ss.ServiceName,"Getting runtime version info from controller.");try{const e=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new as,16e3,!1);if(null==e||null==e.Status)throw new ls('Cannot get runtime info, controller response result is empty."',Bo.EmptyResponse);if(e.Status!=ue.OK)throw new ls(`Cannot get runtime info, controller responded with status ${e.Status}.`,Bo.WrongResponseStatus);if(null==e.Data)throw new ls("Cannot get runtime info, controller responded with status OK but response does not contains data.",Bo.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof E?new ls("Cannot get runtime info, controller response timeout.",Bo.Timeout):e}}))}GetHardwareInfoAsync(){return os(this,arguments,void 0,(function*(e=!1){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return os(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(ss.ServiceName,"Getting hardware info from controller.");const t=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new us,8e3,!1);if(null==t||null==t.Status)throw new ls('Cannot get hardware info, controller response result is empty."',Bo.EmptyResponse);if(t.Status!=ue.OK)throw new ls(`Cannot get hardware info, controller responded with status ${t.Status}.`,Bo.WrongResponseStatus);if(null==t.Data)throw new ls("Cannot get hardware info, controller responded with status OK but response does not contains data.",Bo.NoDataInResponse);this._hardwareInfo=t.Data,this._isRuntimeInfoInitialized=!0}))}}ss.ServiceName="UpdateProvider";class is{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class as extends ce{constructor(){super(),this.Resource="/controller/software/info",this.Method=le.Get}}class cs{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class us extends ce{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=le.Get}}class ls 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"}(Bo||(Bo={})),function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(Wo||(Wo={}));class ds{constructor(){this._comparisonParams=new Map,this.Type=It.Unknown,this.DeviceGuid="",this.ComparisonMethod=$o.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Kn&&(this.Type=It.BatteryState),e instanceof gr&&(this.Type=It.BinarySensorState),e instanceof Un&&(this.Type=It.BlindPosition),e instanceof $n&&(this.Type=It.LightBrightness),e instanceof zn&&(this.Type=It.MeasuredBrightness),e instanceof Mn&&(this.Type=It.RemoteButtonState),e instanceof Tn&&(this.Type=It.ChannelOnOffState),e instanceof Gn&&(this.Type=It.DoorBellState),e instanceof Xn&&(this.Type=It.MeasuredEnergy),e instanceof Er&&(this.Type=It.FloodSensorState),e instanceof ir&&(this.Type=It.GatePosition),e instanceof Fn&&(this.Type=It.LightColor),e instanceof Bn&&(this.Type=It.LightWarmth),e instanceof Rn&&(this.Type=It.ReedState),e instanceof qn&&(this.Type=It.MeasuredTemperature),e instanceof dr&&(this.Type=It.HumiditySensorState),e instanceof tr&&(this.Type=It.BlindRemoteButtonState),e instanceof rr&&(this.Type=It.FacadeRemoteButtonState),e instanceof Zn&&(this.Type=It.MovementSensorState),e instanceof Xn&&(this.Type=It.MeasuredEnergy),e instanceof Ir&&(this.Type=It.PressureSensorState),e instanceof Dr&&(this.Type=It.WindSpeedState),e instanceof _r&&(this.Type=It.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class hs{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class ps{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"}($o||($o={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(Vo||(Vo={})),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"}(Ho||(Ho={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(Ko||(Ko={})),(rs=jo||(jo={}))[rs.Unknown=0]="Unknown",rs[rs.Second=1]="Second",rs[rs.Minute=2]="Minute",rs[rs.Hour=3]="Hour",rs[rs.Day=4]="Day",rs[rs.DayOfWeek=5]="DayOfWeek",rs[rs.Month=6]="Month",rs[rs.Year=7]="Year",rs[rs.Date=8]="Date",rs[rs.Time=9]="Time",rs[rs.WeatherType=11]="WeatherType",rs[rs.CompareNumbers=12]="CompareNumbers",rs[rs.CompareBooleans=13]="CompareBooleans",rs[rs.DeviceState=14]="DeviceState",rs[rs.Timer=15]="Timer",rs[rs.Temperature=17]="Temperature",rs[rs.DaysOfWeek=18]="DaysOfWeek",rs[rs.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",rs[rs.SceneExecuted=20]="SceneExecuted",(ns=zo||(zo={}))[ns.Unknown=0]="Unknown",ns[ns.Equal=1]="Equal",ns[ns.NotEqueal=2]="NotEqueal",ns[ns.BiggerThan=3]="BiggerThan",ns[ns.SmallerThan=4]="SmallerThan",ns[ns.BiggerThanOrEqual=5]="BiggerThanOrEqual",ns[ns.SmallerThanOrEqual=6]="SmallerThanOrEqual",ns[ns.OneOfBothIsTrue=7]="OneOfBothIsTrue",ns[ns.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"}(Jo||(Jo={})),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"}(Xo||(Xo={})),(ts=Yo||(Yo={})).Null="Null",ts.Condition="Condition",ts.ConditionGroup="ConditionGroup",ts.ArgumentAsInt="ArgumentAsInt",ts.ArgumentAsTimeSpan="ArgumentAsTimeSpan",ts.ArgumentAsBoolean="ArgumentAsBoolean",ts.ArgumentAsTimeout="ArgumentAsTimeout",ts.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",ts.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",ts.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",ts.ArgumentAsTime="ArgumentAsTime",ts.ArgumentAsDeviceState="ArgumentAsDeviceState",ts.ArgumentAsNumber="ArgumentAsNumber",ts.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",ts.ArgumentAsConditionInfo="ArgumentAsConditionInfo",function(e){e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.LockExecutionTask="LockExecutionTask",e.NotifyTaskAppNotify="NotifyTaskAppNotify",e.NotifyTaskEmailNotify="NotifyTaskEmailNotify"}(Qo||(Qo={}));class fs 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"}(Zo||(Zo={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(es||(es={}));var vs,ys,ms;class ws{constructor(e,t="Cube"){this._result=null,this._tmp=new Ss,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=ry.Get(xs.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Kr.NewGuid())}SetSequenceName(e){const t=n=>{if(n.RightArgumentType!=ms.Null)return t(n.RightArgument);n.Tasks.ControllerTasks.where((e=>e.TaskType==Ho.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==ms.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 ws;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=Kr.NewGuid(),e.RightArgumentType==ms.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Kr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==ms.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!=ms.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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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=Kr.NewGuid(),this._tmp.HandledType=jo.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=ms.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=zo.Equal)throw new Gs("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new Gs("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=zo.Equal;else{if(null==n)throw new Gs("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.Unknown,this._tmp.LeftArgumentType=ms.Null,this._tmp.ConditionType=zo.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=ms.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=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.DaysOfWeek,this._tmp.LeftArgumentType=ms.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.Timer,this._tmp.LeftArgumentType=ms.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.Time,this._tmp.LeftArgumentType=ms.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.DeviceState,this._tmp.LeftArgumentType=ms.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=ms.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.SceneExecuted,this._tmp.LeftArgumentType=ms.ArgumentAsConditionInfo,this._tmp.ConditionType=zo.Equal,this._tmp.AtMeetCondition=!0;const t=new gs;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=ms.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new Cs;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),{[Vo[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case It.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case It.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case It.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case It.LightBrightness:case It.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case It.RemoteButtonState:case It.ChannelOnOffState:case It.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case It.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[Qt[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case It.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case It.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case It.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case It.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case It.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case It.SmokeSensorState:throw new fs("Unsupported device state!");case It.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case It.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case It.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case It.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 It.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case It.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case It.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case It.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case It.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case It.Unknown:t.CheckedDeviceState={};break;default:throw new fs("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case It.BatteryState:return Jo.BatteryState;case It.BinarySensorState:return Jo.BinarySensor;case It.BlindPosition:return Jo.BlindPosition;case It.LightBrightness:return Jo.LightBrightness;case It.RemoteButtonState:return Jo.ButtonState;case It.ChannelOnOffState:return Jo.ChannelOnOff;case It.DoorBellState:return Jo.DoorBell;case It.MeasuredEnergy:return Jo.Energy;case It.FloodSensorState:return Jo.FloodSensor;case It.GatePosition:return Jo.GatePosition;case It.MeasuredBrightness:return Jo.Brightness;case It.LightColor:return Jo.LightColor;case It.LightWarmth:return Jo.LightTemperature;case It.ReedState:return Jo.ReedState;case It.SmokeSensorState:return Jo.SmokeSensor;case It.MeasuredTemperature:return Jo.Temperature;case It.HumiditySensorState:return Jo.Humidity;case It.BlindRemoteButtonState:return Jo.BlindsControlButton;case It.FacadeRemoteButtonState:return Jo.FacadeControlButton;case It.MovementSensorState:return Jo.Movement;case It.PressureSensorState:return Jo.AirPressure;case It.WindSpeedState:return Jo.WindSpeed;case It.CurrentWindThreshold:return Jo.WindThreshold;default:return Jo.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=ms.Null)return e(t.RightArgument,n);t.RightArgumentType=ms.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Ts)};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 Ss,{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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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!=ms.Condition){if(n.RightArgumentType==ms.Condition)return t(n.RightArgument,r);throw new Ns(`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 Ns(`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 Ss,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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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==ms.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==ms.Null)throw new Ns(`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 Ns("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=ms.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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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!=ms.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new Ns("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 ks;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==bt.SetBlindPosition||e instanceof no?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==bt.SetBlindPositionSimple||e instanceof oo?(t.Data.Action=e.Action,t.Data.Position=0):e.TaskType==bt.SetLightColor||e instanceof eo?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==bt.SetLightTemperature||e instanceof to?t.Data.Temperature=e.Temperature:e.TaskType==bt.SetLightBrightness||e instanceof Qr?t.Data.Brightness=e.Brightness:e.TaskType==bt.SetTemperature||e instanceof zr?t.Data.Temperature=e.Temperature:e.TaskType==bt.TurnOnWithTime||e instanceof Yr?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==bt.SetLightBrightnessDynamicly||e instanceof so?t.Data.Brightness=e.Brightness:e.TaskType==bt.SetBlindOpenCloseTime||e instanceof ao?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==bt.SetBlindMicroventilation||e instanceof lo?t.Data.Position=e.Position:e.TaskType==bt.SetFacadePosition||e instanceof go?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):e.TaskType==bt.LightRGBW||e instanceof yo?(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==bt.PreciseGateControl||e instanceof ro)&&(t.Data.Position=e.Position,t.Data.GateControlAction=e.GateControlAction),t}DelayTask(e){const t=new Es;if("00:00:00"==e.Delay.Value)throw new Gs("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==Zo.Email)throw new Ps("NotifyType 'Email' is not supported!");if(e.NotifyType==Zo.None)throw new Error("NotifyType mus be set!");if(""==e.Message)throw new Gs("Message must be set!");if(e.Message.length>1e3)throw new Gs("Message is too long! Max length is 1000 characters.");const t=new Is;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 bs;if(t.LockType=e.LockType,t.LockType==es.Timeout&&"00:00:00"!=t.LockEndHour)throw new Ps("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!=ms.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 ks&&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!=ms.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 Rs("Task not found, cannot edit!");this._tmpTask instanceof ks&&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!=ms.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 bt.Unknown:throw new Gs("Unsupported task type!");case bt.SetBlindPosition:case bt.SetBlindPositionSimple:return Mr.SetBlindPosition;case bt.SetBlindMicroventilation:return Mr.SetBlindMicroventilation;case bt.TurnOff:return Mr.TurnOff;case bt.TurnOn:return Mr.TurnOn;case bt.TurnOnWithTime:return Mr.TurnOnWithTimeout;case bt.TogleState:return Mr.ToggleState;case bt.SetLightBrightnessDynamicly:return Mr.SetLightBrightnessDynamicly;case bt.SetLightBrightness:return Mr.SetLightBrightness;case bt.SetLightColor:return Mr.SetLightColor;case bt.SetLightTemperature:return Mr.SetLightTemperature;case bt.PairDevice:case bt.UnpairDevice:throw new Gs("Unsupported task type!");case bt.IdentifyDevice:return Mr.IdentifyDevice;case bt.GetChannelsState:return Mr.GetState;case bt.GetPowerMeasurements:case bt.GetAvailableData:case bt.MultipleDataRequest:throw new Gs("Unsupported task type!");case bt.SetBlindOpenCloseTime:return Mr.SetBlindOpenCloseTime;case bt.SetTemperature:return Mr.SetTemperature;case bt.ChangeGatePositionPulse:return Mr.GatePulse;case bt.ChangeGatewayPositionPulse:return Mr.GatewayPulse;case bt.SetFacadePosition:case bt.GetFacadeType:return Mr.SetFacadePositionAndTilt;case bt.LightRGBW:return Mr.LightRGBW;case bt.PreciseGateControl:return Mr.SetGatePositionPrecise;default:throw new Gs("Unsupported task type!")}}GetSupportedTaskTypesAsync(){return e=this,t=void 0,r=function*(){const e=yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Qo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Qo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Qo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Qo.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!=ms.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==ms.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}GetAllowedArguments(){const e=[];return null==this._result?(e.push({ArgumentType:ys.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1})):null!=this._result&&(null==this._result.RightArgument||this._result.RightArgument instanceof As)&&(this._result.LeftArgumentType==ms.ArgumentAsDaysOfWeek&&(e.push({ArgumentType:ys.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),e.push({ArgumentType:ys.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0})),this._result.LeftArgumentType==ms.ArgumentAsTime&&e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1}),this._result.LeftArgumentType==ms.ArgumentAsAstronomicalClockWithOffset&&e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1})),0==e.any((e=>e.ArgumentType==ys.ArgumentAsAstronomicalClockWithOffset))&&e.push({ArgumentType:ys.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsDaysOfWeek))&&e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsDeviceState))&&e.push({ArgumentType:ys.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsSceneExecuted))&&e.push({ArgumentType:ys.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsTime))&&e.push({ArgumentType:ys.ArgumentAsTime,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsTimeSpan))&&e.push({ArgumentType:ys.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==ms.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,ms.ArgumentAsDaysOfWeek,!0);null!=i&&((null===(e=i.RightArgument)||void 0===e?void 0:e.LeftArgumentType)==ms.ArgumentAsTime||(null===(t=i.RightArgument)||void 0===t?void 0:t.LeftArgumentType)==ms.ArgumentAsAstronomicalClockWithOffset)&&o.push(vs.OptimizeDayOfWeekArgument);const a=s(this._result,ms.ArgumentAsTime,!0);return null!=a&&(null===(n=a.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ms.ArgumentAsDaysOfWeek&&(null===(r=a.RightArgument)||void 0===r?void 0:r.AtMeetCondition)&&o.push(vs.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(vs.OptimizeDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ms.ArgumentAsDaysOfWeek?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ms.ArgumentAsTime||(null===(r=t.RightArgument)||void 0===r?void 0:r.LeftArgumentType)==ms.ArgumentAsAstronomicalClockWithOffset?t:e(t.RightArgument):t.RightArgumentType==ms.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(vs.OptimizeAtInDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ms.ArgumentAsTime?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ms.ArgumentAsDaysOfWeek&&(null===(r=t.RightArgument)||void 0===r?void 0:r.AtMeetCondition)?t:e(t.RightArgument):t.RightArgumentType==ms.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"}(vs||(vs={})),function(e){e.Unknown="Unknown",e.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",e.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",e.ArgumentAsTimeSpan="ArgumentAsTimeSpan",e.ArgumentAsTime="ArgumentAsTime",e.ArgumentAsDeviceState="ArgumentAsDeviceState",e.ArgumentAsSceneExecuted="ArgumentAsSceneExecuted"}(ys||(ys={}));class Ss{constructor(){this.Tasks=new Ts,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=jo.Unknown,this.ConditionType=zo.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=ms.Null,this.RightArgumentType=ms.Null,this.LeftArgument=new _s({},ms.Null),this.RightArgument=new As}}class As{constructor(){this.HandledType=0,this.Argument=null}}class _s{constructor(e,t){this.Argument=e,this.HandledType=t}}class Cs{constructor(){this.DeviceStateType=Jo.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=$o.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Ts{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Ds{constructor(){this.Guid=Kr.NewGuid(),this.RunParallel=!1,this.TaskType=Ho.Unknown}}class ks extends Ds{constructor(){super(...arguments),this.TaskType=Ho.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=Mr.TurnOn}}class Es extends Ds{constructor(){super(...arguments),this.TaskType=Ho.DelayTask,this.Delay="00:00:00"}}class bs extends Ds{constructor(){super(...arguments),this.TaskType=Ho.LockExecution,this.LockType=es.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}class Is extends Ds{constructor(){super(...arguments),this.TaskType=Ho.NotifyTask,this.Title="",this.Message="",this.NotifyType=Zo.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"}(ms||(ms={}));class Gs extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class Ns extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class Rs extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class Ps extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var Us,Os,Ms=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 xs{constructor(){this._connection=ry.Get(Ct.ServiceName),this._configurationService=ry.Get(at.ServiceName)}GetServiceName(){return xs.ServiceName}GetSequencesListAsync(){return Ms(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Fs,12e3,!1);return null===(t=u.Log)||void 0===t||t.Debug(`GetSequencesListAsync result:\n ${JSON.stringify(n)}}`),null==n?new be(Wo.OtherError,"Cannot get sequences list - response is null."):n.Status!=ue.OK?new be(Wo.OtherError,`Cannot get sequences list - controller responded with response code ${n.Status}.`):null==n.Data?new be(Wo.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):n.Data}))}GetSequenceAsync(e){return Ms(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 Ls(n),12e3,!1);if(null==r)return new be(Wo.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ue.OK)return new be(Wo.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new be(Wo.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 be){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 be(Wo.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 ws(e,t)}CreateSequenceAsync(e){return Ms(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 Vs(e),2e4,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(t){return null===(r=u.Log)||void 0===r||r.Error(`Creating sequence ${e.Name} error: ${t}`),ue.FatalError}finally{null===(o=u.Log)||void 0===o||o.Error(xs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! CreateSequenceAsync()"),yield this._configurationService.ExitConfigurationModeAsync(),yield ry.Get(Qs.ServiceName).GetDevicesAsync(!0)}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){return Ms(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 Bs(n),12e3,!1);if(null==r)return new be(Wo.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ue.WrongData:return new be(Wo.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ue.OK:return null==r.Data?new be(Wo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new be(Wo.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new be(Wo.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){return Ms(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 Hs(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield ry.Get(Qs.ServiceName).GetDevicesAsync(!0)}}))}EditSequenceAsync(e){return Ms(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?ue.Error:o.Status}catch(t){return null===(n=u.Log)||void 0===n||n.Error(`Editing sequence ${e.Name} error: ${t}`),ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield ry.Get(Qs.ServiceName).GetDevicesAsync(!0)}}))}EnableSequenceAsync(e){return Ms(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?ue.Error:r.Status}))}DisableSequenceAsync(e){return Ms(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 js(n),12e3,!1);return yield this._configurationService.ExitConfigurationModeAsync(),null==r||null==r.Status?ue.Error:r.Status}))}RunSequenceAsync(e){return Ms(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ue.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ue.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new Xr;switch(n.Channel=1,n.DeviceGuid=t,yield ry.Get(Qs.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case Ut.Executed:return ue.OK;case Ut.DeviceNotFound:return ue.WrongData;default:return ue.Error}}))}GetUtilsAsync(){return Ms(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 Ms(this,void 0,void 0,(function*(){var e;const t=ry.Get(Po.ServiceName),n=new bo;let r=!1;n.Latitude=49.9958888026741,n.Longitude=18.9172596008914;try{if(yield t.IsControllerGeolocationSetAsync()){const e=yield t.GetControlllerGeolocationAsync();e instanceof Io&&(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),p=a(h);return new Date>p&&!r?(r=!0,c(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.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),p=Math.floor(((e,t)=>{let n=720+720/Math.PI*Math.acos(-e)-t;return n>1439&&(n-=1439),n})(h,u)),g=a(p);return new Date>g&&!r?(r=!0,l(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>l(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=Us.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=Ho.DeviceTask,e.RunParallel=!1}))),null!=e.Tasks.ControllerTasks&&e.Tasks.ControllerTasks.map((e=>{null==(null==e?void 0:e.Guid)&&(e.Guid=Kr.NewGuid())}))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=Yo.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==Yo.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===Yo.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new Ws;switch(n.HandledType=e.HandledType,t){case Yo.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case Yo.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case Yo.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case Yo.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case Yo.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case Yo.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case Yo.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case Yo.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case Yo.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case Yo.ArgumentAsDeviceState:{const t=new ds;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?$o.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(Vo[e[0]],new hs(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(Vo[e[0]],new ps(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case Yo.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return Yo[Us[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case Jo.BatteryState:return It.BatteryState;case Jo.BinarySensor:return It.BinarySensorState;case Jo.BlindPosition:return It.BlindPosition;case Jo.Brightness:return It.MeasuredBrightness;case Jo.ButtonState:return It.RemoteButtonState;case Jo.ChannelOnOff:return It.ChannelOnOffState;case Jo.DoorBell:return It.DoorBellState;case Jo.Energy:return It.MeasuredEnergy;case Jo.FloodSensor:return It.FloodSensorState;case Jo.GatePosition:return It.GatePosition;case Jo.LightBrightness:return It.LightBrightness;case Jo.LightColor:return It.LightColor;case Jo.LightTemperature:return It.LightWarmth;case Jo.ReedState:return It.ReedState;case Jo.SmokeSensor:return It.SmokeSensorState;case Jo.Temperature:return It.MeasuredTemperature;case Jo.Humidity:return It.HumiditySensorState;case Jo.BlindsControlButton:return It.BlindRemoteButtonState;case Jo.FacadeControlButton:return It.FacadeRemoteButtonState;case Jo.Movement:return It.MovementSensorState;case Jo.AirPressure:return It.PressureSensorState;case Jo.WindSpeed:return It.WindSpeedState;case Jo.WindThreshold:return It.CurrentWindThreshold;default:return It.Unknown}}CreateDeviceState(e,t,n){switch(n){case It.BatteryState:return{Channel:t,StateReliability:qt.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case It.BinarySensorState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case It.BlindPosition:return{Channel:t,StateReliability:qt.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case It.LightBrightness:case It.MeasuredBrightness:return{Channel:t,StateReliability:qt.Unconfident,Brightness:e.Brightness,Time:""};case It.RemoteButtonState:case It.ChannelOnOffState:case It.DoorBellState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case It.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(Qt[t],r);return{Channel:t,StateReliability:qt.Unconfident,MeasurementParameters:n,Time:""}}case It.FloodSensorState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case It.GatePosition:return{Channel:t,StateReliability:qt.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case It.LightColor:return{Channel:t,StateReliability:qt.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case It.LightWarmth:return{Channel:t,StateReliability:qt.Unconfident,Temperature:e.Temperature,Time:""};case It.ReedState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case It.SmokeSensorState:throw new fs("Unsupported device state!");case It.MeasuredTemperature:return{Channel:t,StateReliability:qt.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case It.HumiditySensorState:return{Channel:t,StateReliability:qt.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case It.BlindRemoteButtonState:return{Channel:t,StateReliability:qt.Unconfident,State:e.State,Time:""};case It.LightRGBWState:return{StateReliability:qt.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case It.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,State:e.State};case It.MovementSensorState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case It.PressureSensorState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case It.WindSpeedState:return{Channel:t,Time:"",StateReliability:qt.Unconfident,Value:e.Value};case It.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:qt.Unconfident,WindThreshold:e.WindThreshold};case It.Unknown:return new _n;default:throw new fs("Unsupported device state!")}}MapDeviceTask(e){var t;let n=new jr,r=e;switch(null===(t=u.Log)||void 0===t||t.Debug(`[TASK] object: ${JSON.stringify(r)}`),r.ControlFeature){case Mr.TurnOn:n=new Xr,n.TaskType=bt.TurnOn;break;case Mr.TurnOff:n=new Jr,n.TaskType=bt.TurnOff;break;case Mr.ToggleState:n=new Zr,n.TaskType=bt.TogleState;break;case Mr.SetBlindPosition:{const e=ry.Get(Qs.ServiceName).GetDevice(r.DeviceGuid);(null==e?void 0:e.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType)))?(n=new oo,n.TaskType=bt.SetBlindPositionSimple,n.Action=r.Data.Action):(n=new no,n.TaskType=bt.SetBlindPosition,n.Action=r.Data.Action,n.Position=r.Data.Position);break}case Mr.SetLightColor:n=new eo,n.TaskType=bt.SetLightColor,n.R=r.Data.R,n.G=r.Data.G,n.B=r.Data.B;break;case Mr.SetLightTemperature:n=new to,n.TaskType=bt.SetLightTemperature,n.Temperature=r.Data.Temperature;break;case Mr.SetLightBrightness:n=new Qr,n.TaskType=bt.SetLightBrightness,n.Brightness=r.Data.Brightness;break;case Mr.SetTemperature:n=new zr,n.TaskType=bt.SetTemperature,n.Temperature=r.Data.Temperature;break;case Mr.GetState:n=new uo,n.TaskType=bt.GetChannelsState;break;case Mr.TurnOnWithTimeout:n=new Yr,n.TaskType=bt.TurnOnWithTime,n.SwitchOffDelaySeconds=r.Data.SwitchOffDelaySeconds;break;case Mr.SetLightBrightnessDynamicly:n=new so,n.TaskType=bt.SetLightBrightnessDynamicly,n.Brightness=r.Data.Brightness;break;case Mr.IdentifyDevice:n=new io,n.TaskType=bt.IdentifyDevice;break;case Mr.SetBlindOpenCloseTime:n=new ao,n.TaskType=bt.SetBlindOpenCloseTime,n.Data.CloseTime=r.Data;break;case Mr.SetBlindMicroventilation:n=new lo,n.TaskType=bt.SetBlindMicroventilation,n.Position=r.Data.Position;break;case Mr.GatewayPulse:n=new po,n.TaskType=bt.ChangeGatewayPositionPulse;break;case Mr.GatePulse:n=new ho,n.TaskType=bt.ChangeGatePositionPulse;break;case Mr.SetFacadePositionAndTilt:n=new go,n.TaskType=bt.SetFacadePosition,n.Position=r.Data.Position,n.Tilt=r.Data.Tilt,n.FacadeAction=Br.TiltAndPercentage;break;case Mr.GetFacadeType:n=new fo,n.TaskType=bt.GetFacadeType;break;case Mr.LightRGBW:n=new yo,n.TaskType=bt.LightRGBW,n.Data=r.Data;break;case Mr.SetGatePositionPrecise:n=new ro,n.TaskType=bt.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=Kr.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 $s;switch(e.Guid=t.Guid,e.TaskId=oe.GenerateMd5(JSON.stringify(t)),t.TaskType){case Ho.DeviceTask:e.TaskType=Ko.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(t);break;case Ho.DelayTask:e.TaskType=Ko.DelayTask,e.Task.DelayTask={Delay:new ps(t.Delay)};break;case Ho.NotifyTask:e.TaskType=Ko.NotifyTask,e.Task.NotifyTask={Message:t.Message,NotifyType:t.NotifyType,NotificationClients:t.NotificationClients};break;case Ho.LockExecution:case Ho.LockExecution:e.TaskType=Ko.LockExecution,null===(n=u.Log)||void 0===n||n.Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(t)}`),e.Task.LockExecution={LockStartHour:new ps(t.LockStartHour),LockEndHour:new ps(t.LockEndHour),LockType:t.LockType,ResetLockScenesGuids:t.ResetLockScenesGuids};case Ho.Unknown:}r.push(e)}return r}GetSupportedTaskTypesAsync(){return Ms(this,void 0,void 0,(function*(){const e=yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Qo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Qo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Qo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Qo.NotifyTaskAppNotify),r}))}}xs.ServiceName="ScenesService";class Fs extends ce{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=le.Get}}class Ls extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Get,this.Data=e}}class Bs extends ce{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=le.Get,this.Data=e}}class Ws{constructor(){this.HandledType=Us.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"}(Us||(Us={}));class $s{constructor(){this.TaskId="",this.Guid="",this.TaskType=Ko.Unknown,this.Task={}}}class Vs extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Put,this.Data=e}}class qs extends ce{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=le.Put,this.Data=e}}class Hs extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Delete,this.Data=e}}class Ks extends ce{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=le.Post,this.Data=e}}class js extends ce{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=le.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 zs{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}var Js=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 Xs{constructor(){this._isConnectedAndAuthorized=!1,this._syncLock=new zs,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=Os.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new ke,this._onSuspendedEvent=new ke,this._onEnterLowPowerModeEvent=new ke,this._onExitLowPowerModeEvent=new ke,this._onBackButtonPressedEvent=new ke,this._onForwardButtonPressedEvent=new ke,this._onAppStateChanged=new a,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>Js(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(Xs.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=u.Log)||void 0===r||r.Warning(Xs.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return Js(this,void 0,void 0,(function*(){this._session=yield ry.GetAsync("SessionService"),this._connection=yield ry.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Xs.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(Xs.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 pe.ConnectedAndAuthorized:null===(t=u.Log)||void 0===t||t.Warning(Xs.ServiceName,"App state changed to: connected"),this._isConnectedAndAuthorized=!0,this._onAppStateChanged.Invoke(Os.Connected);break;case pe.Disconnected:null===(n=u.Log)||void 0===n||n.Warning(Xs.ServiceName,"App state changed to: disconnected"),this._isConnectedAndAuthorized&&this._onAppStateChanged.Invoke(Os.Disconnected),this._isConnectedAndAuthorized=!1;break;case pe.Connecting:null===(r=u.Log)||void 0===r||r.Warning(Xs.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(Os.Connecting);break;case pe.Disconnecting:null===(o=u.Log)||void 0===o||o.Warning(Xs.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(Os.Disconnecting);break;case pe.Reconnecting:null===(s=u.Log)||void 0===s||s.Warning(Xs.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(Os.Reconnecting);break;case pe.Failed:null===(i=u.Log)||void 0===i||i.Warning(Xs.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(Xs.ServiceName,"App state changed to: suspended"),null===(t=u.Log)||void 0===t||t.Warning(Xs.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(Xs.ServiceName,"App state changed to: returned from suspension"),null===(t=u.Log)||void 0===t||t.Warning(Xs.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 Xs.ServiceName}}Xs.ServiceName="AppStateService";var Ys=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 Qs{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=ry.Get(Ct.ServiceName),this._session=ry.Get(Xe.ServiceName),this._controllerConfiguration=ry.Get(at.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>Ys(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),ry.Get(at.ServiceName).OnExitedConfigurationEvent().Subscribe((()=>Ys(this,void 0,void 0,(function*(){yield this.GetDevicesAsync(!0)})))),this._synchronizationTaskCompletionSource=new Promise((e=>{var t;null===(t=this._session)||void 0===t||t.OnUserLoggedInEvent().Subscribe((t=>Ys(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(Qs.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=>Ys(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(Qs.ServiceName,`Failed to sync devices states: ${e}`)}this._synchronizedDevicesStates=!0,e()}))))})),ry.Get(Xs.ServiceName).OnAppStateChanged().Subscribe((e=>Ys(this,void 0,void 0,(function*(){switch(e){case Os.ReturnedFromSuspension:ry.Get(Ct.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!=Rt.Scene&&(null===(t=u.Log)||void 0===t||t.Debug(Qs.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==It.SignalStrength?e.Channels.forEach((t=>{let r=new or(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==It.BatteryState&&e.Channels.forEach((t=>{let r=new Hn(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==It.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==It.SignalStrength?e.Channels.forEach((t=>{let r=new or(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==It.BatteryState&&e.Channels.forEach((t=>{let r=new Hn(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==It.SignalStrength?e.Channels.forEach((t=>{let r=new or(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):o.TypeAsEnum==It.BatteryState&&e.Channels.forEach((t=>{let r=new Hn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{ry.Get(Be.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Qs.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{ry.Get(Be.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Qs.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 Ys(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"),ue.ResourceDoesNotExists;i=n}else i=e;const c=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new hi(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!"),ue.FatalError;if(c.Status!=ue.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!"),ue.FatalError;var a=yield ry.Get(xs.ServiceName).GetSequencesListAsync();if(a instanceof be)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}`),ue.Error;const l=new vi;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}`),ue.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)>=fe.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)>=fe.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return Ys(this,void 0,void 0,(function*(){var e;const t=ry.Get(Co.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return null===(e=u.Log)||void 0===e||e.Error(Qs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EnableFastStatesSyncAsync()"),yield ry.Get(at.ServiceName).ExitConfigurationModeAsync(),t}))}DisableFastStatesSyncAsync(){return Ys(this,void 0,void 0,(function*(){var e;const t=ry.Get(Co.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return null===(e=u.Log)||void 0===e||e.Error(Qs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DisableFastStatesSyncAsync()"),yield ry.Get(at.ServiceName).ExitConfigurationModeAsync(),t}))}IsFastStatesSyncEnabledAsync(){return Ys(this,void 0,void 0,(function*(){const e=yield ry.Get(Co.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof So?e.Data:e!=ue.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return Ys(this,void 0,void 0,(function*(){let t=ry.Get(wo.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 Ys(this,void 0,void 0,(function*(){var t,n=yield ry.Get(wo.ServiceName).AddManuallyPairedDeviceAsync(e);return null===(t=u.Log)||void 0===t||t.Error(Qs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDevice()"),yield ry.Get(at.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 Zs;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 Zs,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==It.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 Ys(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ii,15e3,!1);(null==t?void 0:t.Status)==ue.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),r=new $t;if(r.DeviceGuid=n[0],r.Channel=Number(n[1]),r.Status=Tt.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 $t;r.DeviceGuid=e.Guid,r.Channel=n.Number,r.Status=Tt.ExecutingTasks,t.push(r)}))}})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new Cn(t);case"DoorBell":return new In(t);case"ReedPosition":return new Nn(t);case"BlindPosition":return new Pn(t);case"ButtonState":return new On(t);case"LightColor":return new xn(t);case"LightTemperature":return new Ln(t);case"LightBrightness":return new Wn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new Vn(t);case"BatteryState":return new Hn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new jn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new Jn(t);case"DistanceSensor":return new Yn(t);case"MovementSensor":return new Qn(t);case"BlindsControlButton":return new er(t);case"FacadeControlButton":return new nr(t);case"SignalStrength":return new or(t);case"GatePosition":return new sr(t);case"GatewayPosition":return new ar(t);case"GateControllerHealth":return new cr(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new ur(t);case"HumiditySensor":case"HumidityState":return new lr(t);case"VibrationSensor":return new hr(t);case"DigitalInputSensor":return new pr(t);case"ConfigurationState":return new fr(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new vr(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new yr(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new mr(t);case"FacadePosition":case"FacadeState":return new wr(t);case"FacadeTypeState":return new Sr(t);case"CurrentWindThreshold":return new Ar(t);case"CurrentLightThreshold":return new Cr(t);case"WindSpeed":return new Tr(t);case"FloodSensor":return new kr(t);case"PressureState":return new br(t);case"ITamperProtection":case"TamperProtection":return new Gr(t);case"ILightRGBW":case"LightRGBW":return new Nr(t);case"OnlineCamera":case"IOnlineCamera":return new bn(t);case"BlindError":case"IBlindError":return t.state.ErrorData=ie(t.state.ErrorData),new Rr(t);case"HallState":return new Dn(t);case"SceneExecuted":return new kn(t);case"Intercom":return new En(t);default:null===(n=u.Log)||void 0===n||n.Debug(Qs.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return Qs.ServiceName}SyncDevicesStatesAsync(){return Ys(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 ti,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync()){if(e){let e=new ni;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)==ue.OK}return(null==o?void 0:o.Status)==ue.OK}{let e=new ni;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)==ue.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 Pr;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=Et.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Bt;if(i.CommunicationWay==Nt.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 Wt;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 $r;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 Wt;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Bt;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 Ys(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!=Rt.Scene)));const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new ei,15e3,!0);return null==o||void 0===o?[]:o.Status==ue.OK&&null!=o.Data?(this._devices=this.MapApiDevices(o.Data),e?this._devices:this._devices.filter((e=>e.DeviceType!=Rt.Scene))):(null===(r=u.Log)||void 0===r||r.Error(Qs.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(){return Ys(this,arguments,void 0,(function*(e=!1){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){return Ys(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new si,15e3,!1);return null==n?[]:n.Status==ue.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Rt.Scene)).toArray():(null===(t=u.Log)||void 0===t||t.Error(Qs.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){return Ys(this,void 0,void 0,(function*(){var e;ry.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ri,35e3,!1)}))}StopSearchingForDevices(){return Ys(this,void 0,void 0,(function*(){var e;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new oi,2e4,!1)}))}RegisterDeviceAsync(e){return Ys(this,void 0,void 0,(function*(){var t,n,r;try{const r=new ai;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(Qs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RegisterDeviceAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==ue.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),Ut.Executed):Ut.Failed}catch(e){return null===(r=u.Log)||void 0===r||r.Error(Qs.ServiceName,`Failed to paired devices: ${e}`),Ut.ControllerResponseTimeout}}))}RemoveDeviceAsync(e){return Ys(this,arguments,void 0,(function*(e,t=!1){var n,r,o=new ci;t&&(o=new ui),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(Qs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RemoveDeviceAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ue.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),Ut.Executed):Ut.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new pi;const r=t;switch(r.FeatureType){case Mr.SetTemperature:n.Data=r.Temperature;break;case Mr.SetLightBrightness:n.Data=r.Brightness;break;case Mr.SetLightColor:n=new gi;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case Mr.SetLightTemperature:n.Data=r.Temperature;break;case Mr.SetGatePositionPrecise:switch(r.GateControlAction){case Fr.Open:n.Data=101;break;case Fr.Close:n.Data=102;break;case Fr.Stop:n.Data=103;break;case Fr.Percentage:n.Data=r.Position}break;case Mr.SetBlindPosition:switch(r.Action){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 Mr.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case Mr.SetBlindOpenCloseTime:n.Data=r.Data;break;case Mr.SetBlindMicroventilation:n.Data=r.Position;break;case Mr.SetFacadePositionAndTilt:n=new fi;const t=r;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case Mr.LightRGBW:n.Data=r.Data;break;case Mr.GatePulse:case Mr.GatewayPulse:n.Data=0;break;case Mr.TurnOnWithTimeout:n.Data=r.SwitchOffDelaySeconds}return n.Channel=r.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=r.FeatureType,n}ExecuteDeviceTaskAsync(e,t){return Ys(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(Qs.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new li(l);null===(r=u.Log)||void 0===r||r.Debug(Qs.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 ue.OK:return Ut.Executed;case ue.FatalError:return null===(s=u.Log)||void 0===s||s.Error(Qs.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),Ut.Failed;case ue.WrongData:if("DeviceNotFound"===t.Data)return Ut.DeviceNotFound;break;case ue.Error:return"DeviceResponseTimeout"===t.Data?Ut.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Qs.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),Ut.Failed)}}catch(e){return e.message.includes("timeout")?(null===(a=u.Log)||void 0===a||a.Error(Qs.ServiceName,`Failed to get controller response in time.\n${e}`),Ut.ControllerResponseTimeout):(null===(c=u.Log)||void 0===c||c.Error(Qs.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Ut.Failed)}return Ut.Unknown}catch(e){return null===(l=u.Log)||void 0===l||l.Error(Qs.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Ut.Failed}}))}ExecuteDevicesTasksAsync(e){return Ys(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 di(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=Ut.Unknown;switch(t.Status){case ue.OK:return Ut.Executed;case ue.FatalError:null===(n=u.Log)||void 0===n||n.Error(Qs.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),a=Ut.Failed;break;case ue.WrongData:"DeviceNotFound"===t.Data&&(a=Ut.DeviceNotFound);break;case ue.Error:"DeviceResponseTimeout"===t.Data?a=Ut.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Qs.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),a=Ut.Failed)}let c=0,l=new Vt;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(Qs.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new Vt;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Ut.ControllerResponseTimeout}}else{null===(o=u.Log)||void 0===o||o.Error(Qs.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new Vt;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Ut.Failed}}}return s}))}}Qs.ServiceName="DevicesService";class Zs{constructor(){this.Channel=0,this.States=[]}}class ei extends ce{constructor(){super(),this.Resource="/devices/list",this.Method=le.Get}}class ti extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=le.Get}}class ni extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=le.Get}}class ri extends ce{constructor(){super(),this.Resource="/devices/search",this.Method=le.Post}}class oi extends ce{constructor(){super(),this.Resource="/devices/search/stop",this.Method=le.Post}}class si extends ce{constructor(){super(),this.Resource="/devices/found/list",this.Method=le.Get}}class ii extends ce{constructor(){super(),this.Resource="/devices/tasks",this.Method=le.Get}}class ai extends ce{constructor(){super(),this.Resource="/devices/device/pair",this.Method=le.Put}}class ci extends ce{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=le.Put}}class ui extends ce{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=le.Put}}class li extends ce{constructor(e){super(),this.Resource="/devices/device/control",this.Method=le.Post,this.Data=e}}class di extends ce{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=le.Post,this.Data=e}}class hi extends ce{constructor(e){super(),this.Resource="/logic/device/used",this.Method=le.Get,this.Data=e}}class pi{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Mr.GetState,this.SequnceExecutionOrder=0}}class gi extends pi{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class fi extends pi{constructor(){super(...arguments),this.FacadeAction=Br.Stop,this.Tilt=0,this.Position=0}}class vi{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class yi 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 mi=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 wi extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Si=(e,t)=>e===t;class Ai{iterator;constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class _i{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 Ci{iterator;constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class Ti extends Array{}const Di=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return bi(e,t,n,r)}return n?Ei(e,t,n):ki(e,t)},ki=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new wi(mi.NoElements);return n},Ei=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},bi=(e,t,n,r)=>{let o=t;for(const t of e)o=n(o,t);return r(o)},Ii=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},Gi=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Ni=(e,t)=>t?Pi(e,t):Ri(e),Ri=e=>{for(const t of e)return!0;return!1},Pi=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Ui=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},Oi=(e,t)=>new Ci((function*(){yield*e,yield t})),Mi=e=>{if(Array.isArray(e)){if(0===e.length)throw new wi(mi.NoElements);return new Ai((async function*(){for await(const t of e)yield t}))}return new Ai(e)},xi=e=>Mi((async function*(){for(const t of e)yield t})),Fi=(e,t)=>new _i({generator:t,type:e}),Li=e=>Fi(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Bi=(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 wi(mi.NoElements);return n/r},Wi=async(e,t)=>{let n=0,r=0;for(const o of e)n+=await t(o),r+=1;if(0===r)throw new wi(mi.NoElements);return n/r},$i=(e,t)=>{if(t<1)throw new yi("size");return new Ci((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Vi=(e,t)=>new Ci((function*(){yield*e,yield*t})),qi=(e,t,n=Si)=>{for(const r of e)if(n(t,r))return!0;return!1},Hi=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},Ki=(e,t)=>t?zi(e,t):ji(e),ji=e=>{let t=0;for(const n of e)t++;return t},zi=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},Ji=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},Xi=(e,t)=>new Ci((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),Yi=(e,t=Si)=>new Ci((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Qi=(e,t)=>Mi((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}})),Zi=(e,t)=>new Ci((function*(){for(const n of e)t(n),yield n})),ea=(e,t)=>Mi((async function*(){for(const n of e)await t(n),yield n})),ta=(e,t)=>{if(t<0)throw new yi("index");let n=0;for(const r of e)if(t===n++)return r;throw new yi("index")},na=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},ra=(e,t,n=Si)=>new Ci((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)}})),oa=(e,t,n)=>Mi((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)}})),sa=(e,t)=>t?aa(e,t):ia(e),ia=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new wi(mi.NoElements);return t.value},aa=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new wi(mi.NoMatch)},ca=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new wi(mi.NoMatch)},ua=(e,t)=>t?da(e,t):la(e),la=e=>e[Symbol.iterator]().next().value??null,da=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},ha=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class pa extends Ti{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 pa(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 pa(e,r)}for(const e in n)yield n[e]})(e,t),new Ci(r)},fa=(e,t,n)=>n?ya(e,t,n):va(e,t),va=(e,t)=>Mi((async function*(){const n={};for(const r of e){const e=await t(r),o=n[e];o?o.push(r):n[e]=new pa(e,r)}for(const e in n)yield n[e]})),ya=(e,t,n)=>Mi((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 pa(e,o))}for(const e of r)yield e})),ma=(e,t,n,r)=>r?((e,t,n,r)=>new Ci((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 pa(e,t))}}for(const e of o)yield e})))(e,t,n,r):((e,t,n)=>new Ci((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 pa(e,i)}for(const e in r)yield r[e]})))(e,t,n),wa=(e,t,n,r,o,s)=>{const i=s?Sa(e,t,n,r,o,s):Aa(e,t,n,r,o);return new Ci(i)},Sa=(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)}},Aa=(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)}},_a=(e,t,n,r,o,s)=>{const i=s?Ca(e,t,n,r,o,s):Ta(e,t,n,r,o);return Mi(i)},Ca=(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)}},Ta=(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)}},Da=(e,t,n=Si)=>new Ci((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}}})),ka=(e,t,n)=>Mi((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}}}})),Ea=(e,t,n,r,o,s=Si)=>new Ci((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))}}})),ba=(e,t)=>t?Ga(e,t):Ia(e),Ia=e=>{let t;for(const n of e)t=n;if(!t)throw new wi(mi.NoElements);return t},Ga=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new wi(mi.NoMatch);return n},Na=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new wi(mi.NoMatch);return n},Ra=(e,t)=>t?Ua(e,t):Pa(e),Pa=e=>{let t=null;for(const n of e)t=n;return t},Ua=(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},Ma=(e,t)=>t?Fa(e,t):xa(e),xa=e=>{let t=null;for(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new wi(mi.NoElements);return t},Fa=(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new wi(mi.NoElements);return n},La=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 wi(mi.NoElements);return n},Ba=(e,t)=>t?$a(e,t):Wa(e),Wa=e=>{let t=null;for(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new wi(mi.NoElements);return t},$a=(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new wi(mi.NoElements);return n},Va=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 wi(mi.NoElements);return n},qa=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Ci((function*(){for(const t of e)n(t)&&(yield t)}))};async function*Ha(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*Ka(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 ja extends Ai{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 ja?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=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 ja(o)}static generate(e,t,n,r){let o;return o=e instanceof ja?async function*(){for await(const o of e.orderedPairs())yield*Ka(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 ja(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)}}function*za(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*Ja(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 Xa extends Ci{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 Xa?function*(){for(const o of e.orderedPairs())yield*za(o,t,n,r)}:()=>za(e,t,n,r),new Xa(o)}static generateAsync(e,t,n,r){let o;return o=e instanceof Xa?async function*(){for(const o of e.orderedPairs())yield*Ja(o,t,n,r)}:()=>Ja(e,t,n,r),new ja(o)}thenBy(e,t){return Xa.generate(this,e,!0,t)}thenByAsync(e,t){return Xa.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Xa.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Xa.generateAsync(this,e,!1,t)}}const Ya=(e,t)=>Xa.generate(e,(e=>e),!0,t),Qa=(e,t,n)=>Xa.generate(e,t,!0,n),Za=(e,t,n)=>Xa.generateAsync(e,t,!0,n),ec=(e,t,n)=>Xa.generate(e,t,!1,n),tc=(e,t,n)=>Xa.generateAsync(e,t,!1,n),nc=(e,t)=>Xa.generate(e,(e=>e),!1,t),rc=(e,t)=>{const n=[],r=[];for(const o of e)!0===t(o)?r.push(o):n.push(o);return[r,n]},oc=async(e,t)=>{const n=[],r=[];for(const o of e)!0===await t(o)?r.push(o):n.push(o);return[r,n]},sc=(e,t)=>new Ci((function*(){yield t,yield*e})),ic=e=>new Ci((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),ac=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?cc(e,t):uc(e,t)}return lc(e,t)},cc=(e,t)=>new Ci((function*(){for(const n of e)yield t(n)})),uc=(e,t)=>new Ci((function*(){let n=0;for(const r of e)yield t(r,n),n++})),lc=(e,t)=>new Ci((function*(){for(const n of e)yield n[t]})),dc=(e,t)=>"function"==typeof t?1===t.length?hc(e,t):pc(e,t):gc(e,t),hc=(e,t)=>Mi((async function*(){for(const n of e)yield t(n)})),pc=(e,t)=>Mi((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),gc=(e,t)=>Mi((async function*(){for(const n of e)yield n[t]})),fc=(e,t)=>"function"==typeof t?1===t.length?vc(e,t):yc(e,t):mc(e,t),vc=(e,t)=>new Ci((function*(){for(const n of e)for(const e of t(n))yield e})),yc=(e,t)=>new Ci((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),mc=(e,t)=>new Ci((function*(){for(const n of e)for(const e of n[t])yield e})),wc=(e,t)=>1===t.length?Sc(e,t):Ac(e,t),Sc=(e,t)=>Mi((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Ac=(e,t)=>Mi((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),_c=(e,t,n=Si)=>{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},Cc=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},Tc=(e,t)=>t?kc(e,t):Dc(e),Dc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new wi(mi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new wi(mi.NoElements);return n},kc=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new wi(mi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new wi(mi.NoMatch);return r},Ec=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new wi(mi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new wi(mi.NoMatch);return r},bc=(e,t)=>t?Gc(e,t):Ic(e),Ic=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new wi(mi.MoreThanOneElement);t=!0,n=r}return n},Gc=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new wi(mi.MoreThanOneMatchingElement);n=!0,r=o}return r},Nc=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new wi(mi.MoreThanOneElement);n=!0,r=o}return r},Rc=(e,t)=>new Ci((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),Pc=(e,t)=>1===t.length?Uc(e,t):Oc(e,t),Uc=(e,t)=>new Ci((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Oc=(e,t)=>new Ci((function*(){let n=0,r=!0;for(const o of e)!1===r?yield o:!1===t(o,n)&&(r=!1,yield o),n++})),Mc=(e,t)=>1===t.length?xc(e,t):Fc(e,t),xc=(e,t)=>Mi((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Fc=(e,t)=>Mi((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++})),Lc=(e,t)=>t?Wc(e,t):Bc(e),Bc=e=>{let t=0;for(const n of e)t+=n;return t},Wc=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},$c=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},Vc=(e,t)=>new Ci((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),qc=(e,t)=>1===t.length?Hc(e,t):Kc(e,t),Hc=(e,t)=>new Ci((function*(){for(const n of e){if(!t(n))break;yield n}})),Kc=(e,t)=>new Ci((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),jc=(e,t)=>1===t.length?zc(e,t):Jc(e,t),zc=(e,t)=>Mi((async function*(){for(const n of e){if(!await t(n))break;yield n}})),Jc=(e,t)=>Mi((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),Xc=e=>[...e],Yc=(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},Qc=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},Zc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},eu=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},tu=e=>new Set(e),nu=(e,t,n)=>n?ou(e,t,n):ru(e,t),ru=(e,t)=>new Ci((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))})),ou=(e,t,n)=>new Ci((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))}})),su=(e,t,n)=>Mi((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))}})),iu=(e,t)=>1===t.length?au(e,t):cu(e,t),au=(e,t)=>new Ci((function*(){for(const n of e)!0===t(n)&&(yield n)})),cu=(e,t)=>new Ci((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),uu=(e,t)=>1===t.length?lu(e,t):du(e,t),lu=(e,t)=>Mi((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),du=(e,t)=>Mi((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),hu=(e,t,n)=>n?gu(e,t,n):pu(e,t),pu=(e,t)=>new Ci((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 Ci((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,t,n)=>Mi((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)}})),vu=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(Di,"aggregate"),n(Ii,"all"),n(Gi,"allAsync"),n(Ni,"any"),n(Ui,"anyAsync"),n(Oi,"append"),n(xi,"asAsync"),n(Li,"asParallel"),n(Bi,"average"),n(Wi,"averageAsync"),n($i,"chunk"),n(Vi,"concatenate"),n(qi,"contains"),n(Hi,"containsAsync"),n(Ki,"count"),n(Ji,"countAsync"),n(Xi,"defaultIfEmpty"),n(Yi,"distinct"),n(Qi,"distinctAsync"),n(Zi,"each"),n(ea,"eachAsync"),n(ta,"elementAt"),n(na,"elementAtOrDefault"),n(ra,"except"),n(oa,"exceptAsync"),n(sa,"first"),n(ca,"firstAsync"),n(ua,"firstOrDefault"),n(ha,"firstOrDefaultAsync"),n(ga,"groupBy"),n(fa,"groupByAsync"),n(ma,"groupByWithSel"),n(wa,"groupJoin"),n(_a,"groupJoinAsync"),n(Da,"intersect"),n(ka,"intersectAsync"),n(Ea,"joinByKey"),n(ba,"last"),n(Na,"lastAsync"),n(Ra,"lastOrDefault"),n(Oa,"lastOrDefaultAsync"),n(Ma,"max"),n(La,"maxAsync"),n(Ba,"min"),n(Va,"minAsync"),n(qa,"ofType"),n(Ya,"order"),n(Qa,"orderBy"),n(Za,"orderByAsync"),n(ec,"orderByDescending"),n(tc,"orderByDescendingAsync"),n(nc,"orderDescending"),n(sc,"prepend"),n(ic,"reverse"),n(ac,"select"),n(dc,"selectAsync"),n(fc,"selectMany"),n(wc,"selectManyAsync"),n(_c,"sequenceEquals"),n(Cc,"sequenceEqualsAsync"),n(Tc,"single"),n(Ec,"singleAsync"),n(bc,"singleOrDefault"),n(Nc,"singleOrDefaultAsync"),n(Rc,"skip"),n(Pc,"skipWhile"),n(Mc,"skipWhileAsync"),n(Lc,"sum"),n($c,"sumAsync"),n(Vc,"take"),n(qc,"takeWhile"),n(jc,"takeWhileAsync"),n(Xc,"toArray"),n(Yc,"toMap"),n(Qc,"toMapAsync"),n(Zc,"toObject"),n(eu,"toObjectAsync"),n(rc,"partition"),n(oc,"partitionAsync"),n(tu,"toSet"),n(nu,"union"),n(su,"unionAsync"),n(iu,"where"),n(uu,"whereAsync"),n(hu,"zip"),n(fu,"zipAsync")},yu=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Su(e,t,n,r)}return n?wu(e,t,n):mu(e,t)},mu=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new wi(mi.NoElements);return n},wu=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Su=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},Au=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},_u=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},Cu=(e,t)=>new Ai((async function*(){yield*e,yield t})),Tu=(e,t)=>t?ku(e,t):Du(e),Du=async e=>{for await(const t of e)return!0;return!1},ku=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Eu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},bu=e=>Fi(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),Iu=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 wi(mi.NoElements);return n/r},Gu=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 wi(mi.NoElements);return n/r},Nu=(e,t)=>{if(t<1)throw new yi("size");return new Ai((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Ru=(e,t)=>new Ai((async function*(){yield*e,yield*t})),Pu=async(e,t,n=Si)=>{for await(const r of e)if(n(t,r))return!0;return!1},Uu=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},Ou=(e,t)=>t?xu(e,t):Mu(e),Mu=async e=>{let t=0;for await(const n of e)t++;return t},xu=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},Fu=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},Lu=(e,t)=>new Ai((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),Bu=(e,t=Si)=>new Ai((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Wu=(e,t)=>new Ai((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}})),$u=(e,t)=>new Ai((async function*(){for await(const n of e)t(n),yield n})),Vu=(e,t)=>new Ai((async function*(){for await(const n of e)await t(n),yield n})),qu=async(e,t)=>{if(t<0)throw new yi("index");let n=0;for await(const r of e)if(t===n++)return r;throw new yi("index")},Hu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},Ku=(e,t,n=Si)=>new Ai((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)}})),ju=(e,t,n)=>new Ai((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)}})),zu=(e,t)=>t?Xu(e,t):Ju(e),Ju=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new wi(mi.NoElements);return t.value},Xu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new wi(mi.NoMatch)},Yu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new wi(mi.NoMatch)},Qu=(e,t)=>t?el(e,t):Zu(e),Zu=async e=>(await e[Symbol.asyncIterator]().next()).value??null,el=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},tl=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},nl=(e,t,n)=>n?rl(e,t,n):ol(e,t),rl=(e,t,n)=>new Ai((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 pa(e,o))}for(const e of r)yield e})),ol=(e,t)=>new Ai((async function*(){const n={};for await(const r of e){const e=t(r),o=n[e];o?o.push(r):n[e]=new pa(e,r)}for(const e in n)yield n[e]})),sl=(e,t,n)=>n?al(e,t,n):il(e,t),il=(e,t)=>new Ai((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 pa(e,r)}for(const e in n)yield n[e]})),al=(e,t,n)=>new Ai((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 pa(e,o))}for(const e of r)yield e})),cl=(e,t,n,r)=>r?ll(e,t,n,r):ul(e,t,n),ul=(e,t,n)=>new Ai((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 pa(e,i)}for(const e in r)yield r[e]})),ll=(e,t,n,r)=>new Ai((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 pa(e,t))}}for(const e of o)yield e})),dl=(e,t,n,r,o,s)=>{const i=s?hl(e,t,n,r,o,s):pl(e,t,n,r,o);return new Ai(i)},hl=(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)}},pl=(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?fl(e,t,n,r,o,s):vl(e,t,n,r,o);return new Ai(i)},fl=(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)}},vl=(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)}},yl=(e,t,n=Si)=>new Ai((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}}}})),ml=(e,t,n)=>new Ai((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}}}})),wl=(e,t,n,r,o,s=Si)=>new Ai((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))}}})),Sl=(e,t)=>t?_l(e,t):Al(e),Al=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new wi(mi.NoElements);return t},_l=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new wi(mi.NoMatch);return n},Cl=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new wi(mi.NoMatch);return n},Tl=(e,t)=>t?kl(e,t):Dl(e),Dl=async e=>{let t=null;for await(const n of e)t=n;return t},kl=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},El=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},bl=(e,t)=>t?Gl(e,t):Il(e),Il=async e=>{let t=null;for await(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new wi(mi.NoElements);return t},Gl=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 wi(mi.NoElements);return n},Nl=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 wi(mi.NoElements);return n},Rl=(e,t)=>t?Ul(e,t):Pl(e),Pl=async e=>{let t=null;for await(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new wi(mi.NoElements);return t},Ul=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 wi(mi.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 wi(mi.NoElements);return n},Ml=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Ai((async function*(){for await(const t of e)n(t)&&(yield t)}))},xl=(e,t)=>ja.generate(e,(e=>e),!0,t),Fl=(e,t,n)=>ja.generate(e,t,!0,n),Ll=(e,t,n)=>ja.generateAsync(e,t,!0,n),Bl=(e,t,n)=>ja.generate(e,t,!1,n),Wl=(e,t,n)=>ja.generateAsync(e,t,!1,n),$l=(e,t)=>ja.generate(e,(e=>e),!1,t),Vl=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]},Hl=(e,t)=>new Ai((async function*(){yield t,yield*e})),Kl=e=>new Ai((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]})),jl=(e,t)=>"function"==typeof t?1===t.length?zl(e,t):Jl(e,t):Xl(e,t),zl=(e,t)=>new Ai((async function*(){for await(const n of e)yield t(n)})),Jl=(e,t)=>new Ai((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),Xl=(e,t)=>new Ai((async function*(){for await(const n of e)yield n[t]})),Yl=(e,t)=>"string"==typeof t?Zl(e,t):Ql(e,t),Ql=(e,t)=>new Ai((async function*(){for await(const n of e)yield t(n)})),Zl=(e,t)=>new Ai((async function*(){for await(const n of e)yield n[t]})),ed=(e,t)=>"function"==typeof t?1===t.length?td(e,t):nd(e,t):rd(e,t),td=(e,t)=>new Ai((async function*(){for await(const n of e)for(const e of t(n))yield e})),nd=(e,t)=>new Ai((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),rd=(e,t)=>new Ai((async function*(){for await(const n of e)for(const e of n[t])yield e})),od=(e,t)=>1===t.length?new Ai((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Ai((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++}})),sd=async(e,t,n=Si)=>{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},id=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},ad=(e,t)=>t?ud(e,t):cd(e),cd=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new wi(mi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new wi(mi.NoElements);return n},ud=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new wi(mi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new wi(mi.NoMatch);return r},ld=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(await t(o)){if(!0===n)throw new wi(mi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new wi(mi.NoMatch);return r},dd=(e,t)=>t?pd(e,t):hd(e),hd=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new wi(mi.MoreThanOneElement);t=!0,n=r}return n},pd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new wi(mi.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 wi(mi.MoreThanOneMatchingElement);n=!0,r=o}return r},fd=(e,t)=>new Ai((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),vd=(e,t)=>1===t.length?yd(e,t):md(e,t),yd=(e,t)=>new Ai((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),md=(e,t)=>new Ai((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++})),wd=(e,t)=>1===t.length?Sd(e,t):Ad(e,t),Sd=(e,t)=>new Ai((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Ad=(e,t)=>new Ai((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++})),_d=(e,t)=>t?Td(e,t):Cd(e),Cd=async e=>{let t=0;for await(const n of e)t+=n;return t},Td=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},Dd=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},kd=(e,t)=>new Ai((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Ed=(e,t)=>1===t.length?bd(e,t):Id(e,t),bd=(e,t)=>new Ai((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Id=(e,t)=>new Ai((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Gd=(e,t)=>1===t.length?Nd(e,t):Rd(e,t),Nd=(e,t)=>new Ai((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Rd=(e,t)=>new Ai((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Pd=async e=>{const t=[];for await(const n of e)t.push(n);return t},Ud=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},Md=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},xd=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},Fd=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Ld=(e,t,n)=>n?Wd(e,t,n):Bd(e,t),Bd=(e,t)=>new Ai((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))})),Wd=(e,t,n)=>new Ai((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))}})),$d=(e,t,n)=>new Ai((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))}})),Vd=(e,t)=>1===t.length?qd(e,t):Hd(e,t),qd=(e,t)=>new Ai((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Hd=(e,t)=>new Ai((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),Kd=(e,t)=>1===t.length?jd(e,t):zd(e,t),jd=(e,t)=>new Ai((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),zd=(e,t)=>new Ai((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),Jd=(e,t,n)=>n?Yd(e,t,n):Xd(e,t),Xd=(e,t)=>new Ai((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]}})),Yd=(e,t,n)=>new Ai((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)}})),Qd=(e,t,n)=>new Ai((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)}})),Zd=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return nh(e,t,n,r)}return n?th(e,t,n):eh(e,t)},eh=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new wi(mi.NoElements);return n},th=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},nh=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},rh=(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}}},oh=(e,t)=>{const n=rh(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))}},sh=(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}}},ih=(e,t)=>{const n=sh(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))}},ah=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new _i({generator:()=>{const e=n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 2:return new _i({generator:async()=>{const e=await n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 0:return new _i({generator:async()=>{const e=await n.generator();return e.push(t),e},type:n.type})}},ch=(e,t)=>t?lh(e,t):uh(e),uh=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}},lh=async(e,t)=>{const n=rh(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)}},dh=async(e,t)=>{const n=sh(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)}},hh=e=>Mi((async function*(){for await(const t of e)yield t})),ph=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?rh(e,t):e.dataFunc;const r=await ph(n);if(0===r.length)throw new wi(mi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},fh=async(e,t)=>{const n=sh(e,t),r=await ph(n);if(0===r.length)throw new wi(mi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},vh=(e,t)=>{if(t<1)throw new yi("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 _i(n)},yh=(e,t)=>new _i({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),mh=async(e,t,n=Si)=>{let r;switch(r=rh(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))}},wh=async(e,t,n)=>{const r=sh(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))}},Sh=(e,t)=>t?_h(e,t):Ah(e),Ah=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},_h=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},Ch=async(e,t)=>{const n=sh(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},Th=(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 _i(o)},Dh=(e,t=Si)=>new _i({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),kh=(e,t)=>new _i({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}),Eh=(e,t)=>new _i(rh(e,(e=>(t(e),e)))),bh=(e,t)=>{const n=sh(e,(async e=>(await t(e),e)));return new _i(n)},Ih=async(e,t)=>{if(t<0)throw new yi("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new yi("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new yi("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new yi("index");return await e[t]}}},Gh=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]}}},Nh=(e,t,n=Si)=>new _i({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}),Rh=(e,t,n)=>new _i({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}),Ph=e=>ph(e.dataFunc),Uh=(e,t)=>t?Mh(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 wi(mi.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new wi(mi.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new wi(mi.NoElements);return await e[0]}}},Mh=async(e,t)=>{const n=await Ph(e);for(const e of n)if(!0===t(e))return e;throw new wi(mi.NoMatch)},xh=async(e,t)=>{const n=await Ph(e);for(const e of n)if(!0===await t(e))return e;throw new wi(mi.NoMatch)},Fh=(e,t)=>t?Bh(e,t):Lh(e),Lh=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]}}},Bh=async(e,t)=>{const n=await Ph(e);for(const e of n)if(!0===t(e))return e;return null},Wh=async(e,t)=>{const n=await Ph(e);for(const e of n)if(!0===await t(e))return e;return null},$h=(e,t,n)=>n?qh(e,t,n):Vh(e,t),Vh=(e,t)=>new _i({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 pa(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),qh=(e,t,n)=>new _i({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 pa(e,o))}const o=new Array;for(const e of r)o.push(e);return o},type:0}),Hh=(e,t,n)=>n?Kh(e,t,n):jh(e,t),Kh=(e,t,n)=>new _i({generator:async()=>{const r=sh(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 pa(e,t))}const i=new Array;for(const e of s)i.push(e);return i},type:0}),jh=(e,t)=>new _i({generator:async()=>{const n=sh(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 pa(e,t)}const s=new Array;for(const e in o)s.push(o[e]);return s},type:0}),zh=(e,t,n,r)=>r?Jh(e,t,n,r):Xh(e,t,n),Jh=(e,t,n,r)=>new _i({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 pa(e,t))}}const s=new Array;for(const e of o)s.push(e);return s},type:0}),Xh=(e,t,n)=>new _i({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 pa(e,i)}const o=new Array;for(const e in r)o.push(r[e]);return o},type:0}),Yh=(e,t,n,r,o,s)=>{const i=s?Qh(e,t,n,r,o,s):Zh(e,t,n,r,o);return new _i({generator:i,type:0})},Qh=(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)}))},Zh=(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)}))},ep=(e,t,n,r,o,s)=>{const i=s?tp(e,t,n,r,o,s):np(e,t,n,r,o);return new _i({generator:i,type:0})},tp=(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)},np=(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)},rp=(e,t,n=Si)=>new _i({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}),op=(e,t,n)=>new _i({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}),sp=(e,t,n,r,o,s=Si)=>new _i({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}),ip=(e,t)=>t?cp(e,t):ap(e),ap=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new wi(mi.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new wi(mi.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new wi(mi.NoElements);return await e[e.length-1]}}},cp=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 wi(mi.NoMatch)},up=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 wi(mi.NoMatch)},lp=(e,t)=>t?hp(e,t):dp(e),dp=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]}}},hp=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},pp=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},gp=async(e,t)=>{let n;n=t?rh(e,t):e.dataFunc;const r=await ph(n);if(0===r.length)throw new wi(mi.NoElements);return Math.max.apply(null,r)},fp=async(e,t)=>{const n=sh(e,t),r=await ph(n);if(0===r.length)throw new wi(mi.NoElements);return Math.max.apply(null,r)},vp=async(e,t)=>{let n;n=t?rh(e,t):e.dataFunc;const r=await ph(n);if(0===r.length)throw new wi(mi.NoElements);return Math.min.apply(null,r)},yp=async(e,t)=>{const n=sh(e,t),r=await ph(n);if(0===r.length)throw new wi(mi.NoElements);return Math.min.apply(null,r)},mp=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new _i({generator:async()=>{const t=rh(e,n),r=await ph(t),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0})};async function*wp(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*Sp(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 Ap extends _i{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 Ap?async function*(){for await(const o of e.orderedPairs())yield*wp(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 Ap(o)}static generate(e,t,n,r){let o;return o=e instanceof Ap?async function*(){for await(const o of e.orderedPairs())yield*Sp(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 Ap(o)}thenBy(e,t){return Ap.generate(this,e,!0,t)}thenByAsync(e,t){return Ap.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Ap.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Ap.generateAsync(this,e,!1,t)}}const _p=(e,t)=>Ap.generate(e,(e=>e),!0,t),Cp=(e,t,n)=>Ap.generate(e,t,!0,n),Tp=(e,t,n)=>Ap.generateAsync(e,t,!0,n),Dp=(e,t,n)=>Ap.generate(e,t,!1,n),kp=(e,t,n)=>Ap.generateAsync(e,t,!1,n),Ep=(e,t)=>Ap.generate(e,(e=>e),!1,t),bp=async(e,t)=>{const n=rh(e,(e=>[t(e),e])),r=await ph(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},Ip=async(e,t)=>{const n=sh(e,(async e=>[await t(e),e])),r=await ph(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},Gp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new _i({generator:()=>{const e=n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 2:return new _i({generator:async()=>{const e=await n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 0:return new _i({generator:async()=>{const e=await n.generator();return e.unshift(t),e},type:n.type})}},Np=e=>{const t=e.dataFunc;switch(t.type){case 1:return new _i({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new _i({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Rp=(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}}},Pp=(e,t)=>"function"==typeof t?1===t.length?new _i(rh(e,t)):new _i(Rp(e,t)):new _i(rh(e,(e=>e[t]))),Up=(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}}},Op=(e,t)=>{let n;return n="function"==typeof t?1===t.length?sh(e,t):Up(e,t):sh(e,(e=>e[t])),new _i(n)},Mp=(e,t)=>new _i({generator:async()=>{let n;n="function"==typeof t?1===t.length?rh(e,t):Rp(e,t):rh(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}),xp=(e,t)=>new _i({generator:async()=>{let n;n=1===t.length?sh(e,t):Up(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}),Fp=async(e,t,n=Si)=>{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},Lp=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},Bp=(e,t)=>t?$p(e,t):Wp(e),Wp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new wi(mi.MoreThanOneElement);if(0===e.length)throw new wi(mi.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new wi(mi.MoreThanOneElement);if(0===e.length)throw new wi(mi.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new wi(mi.MoreThanOneElement);if(0===e.length)throw new wi(mi.NoElements);return await e[0]}}},$p=async(e,t)=>{const n=await Ph(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new wi(mi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new wi(mi.NoMatch);return o},Vp=async(e,t)=>{const n=await Ph(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new wi(mi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new wi(mi.NoMatch);return o},qp=(e,t)=>t?Kp(e,t):Hp(e),Hp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new wi(mi.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new wi(mi.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new wi(mi.MoreThanOneElement);return 0===e.length?null:await e[0]}}},Kp=async(e,t)=>{const n=await Ph(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new wi(mi.MoreThanOneElement);r=!0,o=e}return o},jp=async(e,t)=>{const n=await Ph(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new wi(mi.MoreThanOneElement);r=!0,o=e}return o},zp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new _i({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new _i({generator:()=>n.generator().slice(t),type:1});case 2:return new _i({generator:async()=>(await n.generator()).slice(t),type:2})}},Jp=(e,t)=>new _i({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}),Xp=(e,t)=>new _i({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}),Yp=(e,t)=>t?Zp(e,t):Qp(e),Qp=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},Zp=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},eg=async(e,t)=>{const n=sh(e,t),r=await ph(n);let o=0;for(const e of r)o+=e;return o},tg=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new _i({generator:()=>r.generator().splice(0,n),type:1});case 2:return new _i({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new _i({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},ng=(e,t)=>new _i({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}),rg=(e,t)=>new _i({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}),og=async(e,t)=>{const n=new Map,r=rh(e,(e=>[t(e),e])),o=await ph(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},sg=async(e,t)=>{const n=new Map,r=sh(e,(async e=>[await t(e),e])),o=await ph(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},ig=async(e,t)=>{const n=e.dataFunc,r=await ph(n),o={};for(const e of r)o[t(e)]=e;return o},ag=async(e,t)=>{const n=sh(e,(async e=>[await t(e),e])),r=await ph(n),o={};for(const[e,t]of r)o[e]=t;return o},cg=async e=>{const t=e.dataFunc,n=await ph(t);return new Set(n)},ug=(e,t,n)=>n?dg(e,t,n):lg(e,t),lg=(e,t)=>new _i({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}),dg=(e,t,n)=>new _i({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}),hg=(e,t,n)=>new _i({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}),pg=(e,t)=>new _i({generator:async()=>(await e.toArray()).filter(t),type:0}),gg=(e,t)=>new _i({generator:async()=>{const n=Up(e,(async(e,n)=>[await t(e,n),e])),r=await ph(n),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0}),fg=(e,t,n)=>n?yg(e,t,n):vg(e,t),vg=(e,t)=>new _i({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}),yg=(e,t,n)=>new _i({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}),mg=(e,t,n)=>new _i({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}),wg=e=>{const t=Ti.prototype,n=e.prototype,r=Object.getOwnPropertyNames(t);for(const e of r)n[e]=n[e]??t[e]};vu(Ci),(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(yu,"aggregate"),n(Au,"all"),n(_u,"allAsync"),n(Cu,"append"),n(Tu,"any"),n(Eu,"anyAsync"),n(bu,"asParallel"),n(Iu,"average"),n(Gu,"averageAsync"),n(Nu,"chunk"),n(Ru,"concatenate"),n(Pu,"contains"),n(Uu,"containsAsync"),n(Ou,"count"),n(Fu,"countAsync"),n(Lu,"defaultIfEmpty"),n(Bu,"distinct"),n(Wu,"distinctAsync"),n($u,"each"),n(Vu,"eachAsync"),n(qu,"elementAt"),n(Hu,"elementAtOrDefault"),n(Ku,"except"),n(ju,"exceptAsync"),n(zu,"first"),n(Yu,"firstAsync"),n(Qu,"firstOrDefault"),n(tl,"firstOrDefaultAsync"),n(nl,"groupBy"),n(sl,"groupByAsync"),n(cl,"groupByWithSel"),n(dl,"groupJoin"),n(gl,"groupJoinAsync"),n(yl,"intersect"),n(ml,"intersectAsync"),n(wl,"joinByKey"),n(Sl,"last"),n(Cl,"lastAsync"),n(Tl,"lastOrDefault"),n(El,"lastOrDefaultAsync"),n(bl,"max"),n(Nl,"maxAsync"),n(Rl,"min"),n(Ol,"minAsync"),n(Ml,"ofType"),n(xl,"order"),n(Fl,"orderBy"),n(Ll,"orderByAsync"),n(Bl,"orderByDescending"),n(Wl,"orderByDescendingAsync"),n($l,"orderDescending"),n(Vl,"partition"),n(ql,"partitionAsync"),n(Hl,"prepend"),n(Kl,"reverse"),n(jl,"select"),n(Yl,"selectAsync"),n(ed,"selectMany"),n(od,"selectManyAsync"),n(sd,"sequenceEquals"),n(id,"sequenceEqualsAsync"),n(ad,"single"),n(ld,"singleAsync"),n(dd,"singleOrDefault"),n(gd,"singleOrDefaultAsync"),n(fd,"skip"),n(vd,"skipWhile"),n(wd,"skipWhileAsync"),n(_d,"sum"),n(Dd,"sumAsync"),n(kd,"take"),n(Ed,"takeWhile"),n(Gd,"takeWhileAsync"),n(Pd,"toArray"),n(Ud,"toMap"),n(Od,"toMapAsync"),n(Md,"toObject"),n(xd,"toObjectAsync"),n(Fd,"toSet"),n(Ld,"union"),n($d,"unionAsync"),n(Vd,"where"),n(Kd,"whereAsync"),n(Jd,"zip"),n(Qd,"zipAsync")})(Ai),(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(Zd,"aggregate"),n(oh,"all"),n(ih,"allAsync"),n(ah,"append"),n(ch,"any"),n(dh,"anyAsync"),n(hh,"asAsync"),n(gh,"average"),n(fh,"averageAsync"),n(vh,"chunk"),n(yh,"concatenate"),n(mh,"contains"),n(wh,"containsAsync"),n(Sh,"count"),n(Ch,"countAsync"),n(Th,"defaultIfEmpty"),n(Dh,"distinct"),n(kh,"distinctAsync"),n(Eh,"each"),n(bh,"eachAsync"),n(Ih,"elementAt"),n(Gh,"elementAtOrDefault"),n(Nh,"except"),n(Rh,"exceptAsync"),n(Uh,"first"),n(xh,"firstAsync"),n(Fh,"firstOrDefault"),n(Wh,"firstOrDefaultAsync"),n($h,"groupBy"),n(Hh,"groupByAsync"),n(zh,"groupByWithSel"),n(Yh,"groupJoin"),n(ep,"groupJoinAsync"),n(Yh,"groupJoin"),n(ep,"groupJoinAsync"),n(rp,"intersect"),n(op,"intersectAsync"),n(sp,"joinByKey"),n(ip,"last"),n(up,"lastAsync"),n(lp,"lastOrDefault"),n(pp,"lastOrDefaultAsync"),n(gp,"max"),n(fp,"maxAsync"),n(vp,"min"),n(yp,"minAsync"),n(mp,"ofType"),n(_p,"order"),n(Cp,"orderBy"),n(Tp,"orderByAsync"),n(Dp,"orderByDescending"),n(kp,"orderByDescendingAsync"),n(Ep,"orderDescending"),n(bp,"partition"),n(Ip,"partitionAsync"),n(Gp,"prepend"),n(Np,"reverse"),n(Pp,"select"),n(Op,"selectAsync"),n(Mp,"selectMany"),n(xp,"selectManyAsync"),n(Fp,"sequenceEquals"),n(Lp,"sequenceEqualsAsync"),n(Bp,"single"),n(Vp,"singleAsync"),n(qp,"singleOrDefault"),n(jp,"singleOrDefaultAsync"),n(zp,"skip"),n(Jp,"skipWhile"),n(Xp,"skipWhileAsync"),n(Yp,"sum"),n(eg,"sumAsync"),n(tg,"take"),n(ng,"takeWhile"),n(rg,"takeWhileAsync"),n(Ph,"toArray"),n(og,"toMap"),n(sg,"toMapAsync"),n(ig,"toObject"),n(ag,"toObjectAsync"),n(cg,"toSet"),n(ug,"union"),n(hg,"unionAsync"),n(pg,"where"),n(gg,"whereAsync"),n(fg,"zip"),n(mg,"zipAsync")})(_i),(()=>{const{prototype:e}=Ti,t=Object.getOwnPropertyNames(Ci.prototype);for(const n of t)e[n]=e[n]??Ci.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 yi("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 wi(mi.NoMatch);return t}if(0===this.length)throw new wi(mi.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 wi(mi.NoMatch)}if(0===this.length)throw new wi(mi.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 wi(mi.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 wi(mi.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 Sg,Ag;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(Sg||(Sg={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(Ag||(Ag={}));class _g{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==_g._devicesService&&(_g._devicesService=ry.Get(Qs.ServiceName))}GetDevicesChannelsInGroupAsync(){return e=this,t=arguments,r=function*(e=!1){let t=[],n=[];const r=yield _g._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){ry.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 ry.Get(Og.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return ry.Get(Og.ServiceName).ChangeGroupIconNameAsync(this,e)}}var Cg,Tg,Dg,kg,Eg,bg,Ig,Gg,Ng,Rg,Pg,Ug=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 Og{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._objectsGroupingSupported=!1,this._configurationService=ry.Get(at.ServiceName),this._connection=ry.Get(Ct.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{ry.Get(Xe.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Ug(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))})),ry.Get(at.ServiceName).OnExitedConfigurationEvent().Subscribe((()=>Ug(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!1)}))))}SetObjectsInGroupAndOrderAsync(e,t){return Ug(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 Fg(e,s),15e3,!1);switch(null===(r=u.Log)||void 0===r||r.Error(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetObjectsInGroupAndOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),yield ry.Get(Qs.ServiceName).GetDevicesAsync(),null==i?void 0:i.Status){case ue.OK:return new be(Sg.Success,"");case ue.NotSupportedMethod:case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new be(Sg.FunctionNotSupported,"");case ue.WrongData:return"GroupDoesNotExists"===i.Data?new be(Sg.GroupDoesNotExists,i.Data):new be(Sg.FatalError,i.Data);case ue.Error:case ue.FatalError:default:return new be(Sg.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=ry.Get(c.ServiceName);e.forEach(((e,n)=>{t.Debug(Og.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=ry.Get(c.ServiceName);n.Debug(Og.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(Og.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 Ug(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 xg(r),15e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeGroupsOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(ry.Get(c.ServiceName).Error(Og.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 Ug(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 $g(e.Guid,s),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeObjectsPositionsInGroupAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield ry.Get(Qs.ServiceName).GetDevicesAsync(),ue.OK):(null===(o=u.Log)||void 0===o||o.Error(Og.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 Ug(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 Mg(e.Guid,t),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(null===(o=u.Log)||void 0===o||o.Error(Og.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 Ug(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 Wg(e.Guid,i,n),15e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveObjectInGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==a?void 0:a.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield ry.Get(Qs.ServiceName).GetDevicesAsync(),ue.OK):(null===(s=u.Log)||void 0===s||s.Error(Og.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 Ug(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s,i;const a=new zg;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(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddDeviceChannelToGroupByGuidAsync()"),this._configurationService.ExitConfigurationModeAsync(),null!=c&&null!=c.Status?(c.Status==ue.OK?e.ChannelGroups.push(t):null===(i=u.Log)||void 0===i||i.Error(Og.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 ry.Get(Qs.ServiceName).GetDevicesAsync()),c.Status):(n||(yield this.GetGroupsAsync(!1),yield ry.Get(Qs.ServiceName).GetDevicesAsync()),ue.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){return Ug(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s;const i=new Jg;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==ue.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():null===(s=u.Log)||void 0===s||s.Error(Og.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 ry.Get(Qs.ServiceName).GetDevicesAsync(),a.Status):(n||(yield this.GetGroupsAsync(!1)),yield ry.Get(Qs.ServiceName).GetDevicesAsync(),ue.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Ug(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 _g))return t instanceof be?t:new be(Ag.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!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Og.ServiceName,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`),new be(Ag.UnknownError,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`)}let s=yield ry.Get(Qs.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!==ue.OK)return null===(r=u.Log)||void 0===r||r.Error(Og.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(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpsertGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),new be(Ag.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 Ug(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!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Og.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(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}let i=yield ry.Get(Qs.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!==ue.OK)return null===(o=u.Log)||void 0===o||o.Error(Og.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(Og.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.OK}))}ChangeGroupNameByGuidAsync(e,t){return Ug(this,void 0,void 0,(function*(){var n,r;let o=new jg,s=new Xg,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 ue.OK:return new be(Ag.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new be(Ag.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new be(Ag.NameAlreadyExists,"Group with this name already exists");default:return new be(Ag.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new be(Ag.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new be(Ag.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){return Ug(this,void 0,void 0,(function*(){var r,o;let s=new jg,i=new Xg,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 ue.OK:return new be(Ag.Success,"");case ue.WrongData:switch(c.Data){case"NameToShort":return new be(Ag.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new be(Ag.NameAlreadyExists,"Group with this name already exists");default:return new be(Ag.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new be(Ag.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new be(Ag.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){return Ug(this,void 0,void 0,(function*(){var n,r;let o=new jg,s=new Xg,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 ue.OK:return new be(Ag.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new be(Ag.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new be(Ag.NameAlreadyExists,"Group with this name already exists");default:return new be(Ag.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new be(Ag.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new be(Ag.UnknownError,"")}))}GetServiceName(){return Og.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 Ug(this,void 0,void 0,(function*(){var t;let n=new Hg;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:ue.Error}))}GetGroupsAsync(){return Ug(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 Kg,15e3,e);let o=[];if((null==r?void 0:r.Status)===ue.OK){let t=0,s=ry.Get(c.ServiceName),i=yield ry.Get(Qs.ServiceName).GetDevicesAsync();return null===(n=r.Data)||void 0===n||n.forEach((n=>{t++;let r=new _g;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(Og.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),o.push(r)})),this._groups=o,o}return this.GetGroupsAsync(e)}))}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 Ug(this,void 0,void 0,(function*(){var t,n,r;let o=new jg,s=new Xg;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 ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(r=u.Log)||void 0===r||r.Error(Og.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new be(Ag.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new be(Ag.NameAlreadyExists,"Group with this name already exists");default:return new be(Ag.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new be(Ag.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new be(Ag.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){return Ug(this,void 0,void 0,(function*(){var n,r,o;let s=new jg,i=new Xg;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 ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(o=u.Log)||void 0===o||o.Error(Og.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new be(Ag.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new be(Ag.NameAlreadyExists,"Group with this name already exists");default:return new be(Ag.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new be(Ag.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new be(Ag.UnknownError,"")}))}}Og.ServiceName="ChannelsGroupsService";class Mg extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=le.Post,this.Data=new Bg,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class xg extends ce{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=le.Post,this.Data=e}}class Fg extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=le.Post,this.Data=new Lg,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Lg{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Bg{constructor(){this.GroupGuid="",this.NewPosition=0}}class Wg extends ce{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=le.Post,this.Data=new Vg,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class $g extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=le.Post,this.Data=new qg,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class Vg{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class qg{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Hg extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Delete}}class Kg extends ce{constructor(){super(),this.Resource="/devices/groups/",this.Method=le.Get}}class jg extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Put,this.Data=[]}}class zg extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Put,this.Data=new Yg}}class Jg extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Delete,this.Data=new Yg}}class Xg{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class Yg{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Qg{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class Zg{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class ef{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class tf{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(Cg||(Cg={})),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"}(Tg||(Tg={})),(Pg=Dg||(Dg={}))[Pg.WaitingForUser=1]="WaitingForUser",Pg[Pg.Downloading=2]="Downloading",Pg[Pg.Unpackaging=3]="Unpackaging",Pg[Pg.CheckingApplicability=4]="CheckingApplicability",Pg[Pg.MigratingData=5]="MigratingData",Pg[Pg.CreatingBackup=6]="CreatingBackup",Pg[Pg.Deploying=7]="Deploying",Pg[Pg.Installing=8]="Installing",Pg[Pg.Removing=9]="Removing",Pg[Pg.Error=10]="Error",Pg[Pg.ReadyToDownload=11]="ReadyToDownload",Pg[Pg.PreparingSystem=12]="PreparingSystem",Pg[Pg.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",Pg[Pg.CheckingIntegrity=14]="CheckingIntegrity",Pg[Pg.UndoingInstallation=15]="UndoingInstallation",Pg[Pg.Installed=16]="Installed",(Rg=kg||(kg={}))[Rg.Ignore=0]="Ignore",Rg[Rg.Cancel=1]="Cancel",Rg[Rg.Install=2]="Install";class nf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=Tg.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class rf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=Ig.Unknown,this.DownloadOnly=!1}}class of{constructor(){this.BulkUpdateStatus=Eg.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"}(Eg||(Eg={})),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"}(bg||(bg={})),function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate",e[e.UpdateDownloadedAndChecked=4]="UpdateDownloadedAndChecked"}(Ig||(Ig={})),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"}(Gg||(Gg={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(Ng||(Ng={}));var sf,af,cf,uf,lf,df,hf,pf,gf,ff=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._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=15,this._updateProviders=ry.Get(ss.ServiceName),this._logger=ry.Get(c.ServiceName),this._connection=ry.Get(Ct.ServiceName),this._appStateService=ry.Get(Xs.ServiceName),this._extensionService=ry.Get(nt.ServiceName)}IsBranchAndAutomaticUpdatesSettingSupportedAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof be)return!1;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);return!(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)}))}DownloadControllerUpdateAsync(e){return ff(this,void 0,void 0,(function*(){try{const t=yield this.getRuntimeInfoAsync();if(t instanceof be)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);return n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild?new be(Gg.FeatureUnsupportedInCurrentVersion,`Cannot download update, feature unsupported in current version. Current version: ${t}`):yield this.DownloadControllerUpdateUsingApiAsync((()=>{}),e,!0)}catch(e){return new be(Gg.CannotProcessUpdate,`Failed to download controller update: ${e}`)}}))}InstallControllerOrRadioUpdateAsync(e,t,n){return ff(this,void 0,void 0,(function*(){const r=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),o=this._controllerUpdates.length,s=yield this.getRuntimeInfoAsync();if(s instanceof be)return s;const i=parseInt(s.SoftwareVersion.toString().split(".")[0]),a=parseInt(s.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new be(Gg.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if(void 0===n||"string"!=typeof n||!r.test(n)){const r=[1],s=t=>{t.UpdateNumber=r[0],t.AvailableUpdates=o,e(t)},c=e=>ff(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let u=this._controllerUpdates.where((e=>e.UpdateType==Cg.RadioUpdate)).toArray(),l=[];this._appStateService.DisallowHibernation();for(let e=0;e<u.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(u[e].ProviderName)).InstallRadioUpdateAsync(u[e],s);yield c(5e3),t==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=u[e].UpdateIdentifier))),l.push(t),r[0]++}const d=this._controllerUpdates.find((e=>e.UpdateType==Cg.SoftwareUpdate));if(null!=d)if(i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(d.Update,s);e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=d.UpdateIdentifier))),l.push(e),r[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(s,t,!1);this._appStateService.AllowHibernation(),e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),l.push(e),r[0]++}const h=l.where((e=>e instanceof be)).toArray();if(null!=h&&0!=h.length){let e="";return h.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),h.any((e=>e.Type==Gg.UpdateDownloadFailed))?new be(Gg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new be(Gg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let r;const o=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==o)return new be(Gg.CannotGetUpdates,`Update with requested guid (${n}) not found.`);switch(this._logger.Debug(`Installing single update type: ${o.Update.UpdateType}, resource: ${o.UpdatedResourceName}, version: ${o.Update.Version}`),this._appStateService.DisallowHibernation(),o.UpdateType){case Cg.RadioUpdate:return r=yield(yield this._updateProviders.GetUpdatesProviderAsync(o.ProviderName)).InstallRadioUpdateAsync(o,e),this._appStateService.AllowHibernation(),this._logger.Debug(`Radio update result: ${r}`),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),r;case Cg.SoftwareUpdate:return i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild?(r=yield this.UpdateControllerUsingScriptAsync(o.Update,e),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))):(yield this.CheckControllerUpdatesAsync(),r=yield this.UpdateControllerUsingApiAsync(e,t,!1),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))),r;default:return new be(Gg.CannotProcessUpdate,`Update with type ${o.UpdateType} is not supported by UpdateService.`)}}}))}GetAutomaticControllerUpdateDownloadStatusAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof be)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 be(Gg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new Rf,1e4,!1);return!(r.Status!=ue.OK||!r.Data)}))}GetServiceName(){return vf.ServiceName}CheckDeviceVersionAsync(e){return ff(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield ry.Get(Qs.ServiceName).GetDevice(e);if(null==t)return new be(Gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new be(Gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Go.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){return ff(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield ry.Get(Qs.ServiceName).GetDevice(e);if(null==t)return new be(Gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new be(Gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Go.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const o=new wf;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 ry.Get(Qs.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(o.IsUpdateSafe=!1),o}))}CheckDeviceUpdatesBulkAsync(e){return ff(this,void 0,void 0,(function*(){const t=yield yield this._updateProviders.GetUpdatesProvidersAsync(Go.Device),n=[];for(var r of t){const t=yield r.CheckUpdateBulkAsync(e);if(t instanceof be)return t;t.map((e=>ff(this,void 0,void 0,(function*(){const t=new wf;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 ff(this,arguments,void 0,(function*(e,t,n,r=!1){var o;let s;if("string"==typeof e){const t=yield ry.Get(Qs.ServiceName).GetDevice(e);if(null==t)return new be(Gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);s=t}else s=e;if(null==s.ProtocolGuid)return new be(Gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(o=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(s.ProtocolGuid,Go.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,Go.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ue.OK)}))}InstallDevicesUpdateBulkAsync(e,t,n){return ff(this,void 0,void 0,(function*(){const r=(yield ry.Get(Qs.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,Go.Device),d=yield l.first().InstalUpdateBulkAsync(i.select((e=>e.Guid)).toArray(),u,n);if(d instanceof be)return d;o.push(d)}if(this._appStateService.AllowHibernation(),1==o.length)return o[0];{const e=new of;o.some((e=>e.DevicesUpdateResults.count()>0))&&o.any((e=>e.BulkUpdateStatus!=Eg.Success))?e.BulkUpdateStatus=Eg.PartialSuccess:o.any((e=>e.BulkUpdateStatus!=Eg.Success))?e.BulkUpdateStatus=o.first().BulkUpdateStatus:e.BulkUpdateStatus=Eg.Success;for(const t of o)t.DevicesUpdateResults.forEach(((t,n)=>{e.DevicesUpdateResults.set(n,t)}));return e}}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return ff(this,void 0,void 0,(function*(){const e=ry.Get(Xe.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 bf,1e4,!1);if(null==r||r.Status!=ue.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 ry.Get(at.ServiceName).CheckIfControllerSoftwareVersionIsEnough(6,66)}CancelFailedControllerUpdateAsync(){return ff(this,void 0,void 0,(function*(){switch((yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1)).Status){case ue.OK:return ue.OK;case ue.OperationNotPermitted:return ue.OperationNotPermitted;case ue.Error:default:return ue.Error}}))}CheckControllerPendingUpdateProgressAsync(e,t){return ff(this,void 0,void 0,(function*(){return new Promise(((n,r)=>ff(this,void 0,void 0,(function*(){var o;const s=ry.Get(Xe.ServiceName).User;if(null==s)return new be(Gg.UpdateActionsNotSupported,"No user data found, cannot check pending update progress.");if(""==s.SoftwareVersion||null==s.SoftwareVersion)return new be(Gg.CannotGetCurrentControllerVersion,"No software version data found, cannot check pending update progress.");const[i,a]=s.SoftwareVersion.split(".");if(parseFloat(i)<this._oldUpdateVersion||parseFloat(i)==this._oldUpdateVersion&&parseFloat(a)<=this._oldUpdateBuild)return new be(Gg.UnsupportedApiVersion,"Not supported API version, cannot check pending update progress.");const c=yield this._connection.SendAndWaitForResponseAsync(new bf,1e4,!1);if(c.Status!=ue.OK)return new be(Gg.CannotGetUpdates,"No pending updates found.");let u=null===(o=c.Data)||void 0===o?void 0:o.DownloadOnly,l=100;const d=60*this._updateOfflineStageTime*1e3;let h=0;const p=new nf;let g=50,f=new rf,v=new nf,y=!1;u||(f.DownloadOnly=u,g=100);let m=100/g;const w=n=>{let r=n.Data;switch(this._logger.Debug(`Update progress: ${r.UpdateStep}, ${r.StepProgressInPercentage}%, ${r.UpdateProgressInPercentage}% data frame status: ${n.Status}`),p.Percentage=Math.round(r.StepProgressInPercentage),p.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=r.DownloadSpeedInMbs,f.Percentage=Math.round(r.StepProgressInPercentage),f.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),v.AvailableUpdates=1,v.Percentage=r.StepProgressInPercentage,v.PercentageTotal=r.UpdateProgressInPercentage,v.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),h=r.StepProgressInPercentage,r.UpdateStep){case uf.DownloadingInstaller:f.CurrentTask=Ig.DownloadingInstaller,v.Status=Tg.DownloadingPackage,t(f);break;case uf.DownloadingUpdate:f.CurrentTask=Ig.DownloadingUpdate,v.Status=Tg.DownloadingPackage,t(f);break;case uf.CheckingUpdate:f.CurrentTask=Ig.CheckingUpdate,v.Status=Tg.CheckingPackage,e(v);break;case uf.PreparingUpdate:v.Status=Tg.PreparingForUpgrade,f.CurrentTask=Ig.CheckingUpdate,e(v);break;case uf.OfflineUpdateStep:case uf.InstallingUpdate:v.Status=Tg.Upgrading,e(v);break;case uf.InstallerFileSignCheckFailed:case uf.UpdateFileSignCheckFailed:v.Status=Tg.InstallationError,e(v);break;case uf.UpdateDownloadFailed:v.Status=Tg.InstallationStopped,e(v);break;case uf.UpdateInstallationFailed:v.Status=Tg.InstallationError,e(v);break;case uf.UpdateFileCheckFailed:v.Status=Tg.IncompatiblePackage,e(v);break;case uf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round(r.UpdateProgressInPercentage*m):Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Ig.CheckingUpdate,t(f),f.CurrentTask=Ig.UpdateDownloadedAndChecked,t(f)}};let S=null;const A=t=>ff(this,void 0,void 0,(function*(){t==Os.Connected&&(clearInterval(S),p.Status=Tg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),yield se.Delay(5e3),n(ue.OK),ry.Get(Xs.ServiceName).OnAppStateChanged().Unsubscribe(A))}));yield this._connection.SendAndHandleResponseAsync(new Ef,1e5,(o=>{var s,i,a,c,g;switch(o.Status){case ue.MultiDataResponseStart:y||(l=(null===(s=o.Data)||void 0===s?void 0:s.UpdateStep)==uf.UpdateDownloaded?100:50,y=!0),w(o);break;case ue.MultiDataResponse:w(o);break;case ue.MultiDataResponseStop:switch(null===(i=o.Data)||void 0===i?void 0:i.UpdateStep){case uf.UpdateInstallationFailed:v.Status=Tg.InstallationError,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new be(Gg.CannotProcessUpdate,"Update installation failed!"));break;case uf.InstallerFileSignCheckFailed:case uf.UpdateFileSignCheckFailed:case uf.UpdateDownloadFailed:case uf.UpdateFileCheckFailed:v.Status=Tg.DownloadingFailure,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new be(Gg.UpdateDownloadFailed,"Update download failed!"));break;case uf.OfflineUpdateStep:w(o),p.Percentage=Math.round(o.Data.StepProgressInPercentage),p.PercentageTotal=Math.round(o.Data.UpdateProgressInPercentage);let r=(100-p.PercentageTotal)/100,s=p.PercentageTotal;S=setInterval((()=>{h++,s+=r,s>100&&(s=100),h>=l?(p.Status=Tg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),n(ue.OK)):(p.Status=Tg.Upgrading,p.Percentage=Math.round(h),p.PercentageTotal=Math.round(s),e(p))}),d/(l-h)),ry.Get(Xs.ServiceName).OnAppStateChanged().Subscribe(A);break;case uf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round((null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)*m):Math.round(null===(c=o.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Ig.CheckingUpdate,t(f),f.CurrentTask=Ig.UpdateDownloadedAndChecked,t(f),u&&n(ue.OK);break;default:w(o),n(new be(Gg.CannotProcessUpdate,`Update installation failed, received UpdateStep code: ${null===(g=o.Data)||void 0===g?void 0:g.UpdateStep}!`))}break;default:r(new be(Gg.CannotGetUpdates,`Cannot get pending update progress, response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`))}}),!0)}))))}))}CheckDevicesUpdatesAvailabilityAsync(){return ff(this,void 0,void 0,(function*(){const e=ry.Get(Xe.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 Mf,1e4,!1),o=[];return null==r||(null==r?void 0:r.Status)!=ue.OK||null==(null==r?void 0:r.Data)?[]:(null==r||r.Data.forEach((e=>{if(!e.IsAvailable)return;const t=new Qg;t.DeviceGuid=e.DeviceGuid,t.CurrentVersion=e.CurrentVersion,t.NewVersion=e.NewVersion,o.push(t)})),o)}))}CheckControllerUpdatesAsync(){return ff(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new Zg,n=yield this.getRuntimeInfoAsync();if(n instanceof be){const e=new yf;return e.UpdateType=Cg.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(Go.Controller)}catch(e){if(!(e instanceof Lo))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 yf;o.ResponseResult=r,o.UpdateType=Cg.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 mf;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=Cg.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:Cg.RadioUpdate}))}}let s=!0;if((r<this._oldUpdateVersion||r===this._oldUpdateVersion&&o<=this._oldUpdateBuild)&&(s=!1),s){const e=yield this._connection.SendAndWaitForResponseAsync(new bf,15e3,!1);if(null==e||e.Status!=ue.OK&&e.Status!=ue.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 Fo;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 mf;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=Cg.SoftwareUpdate,o.UpdateIdentifier=e.Data.Update.Guid,o.UpdateIsDownloading=e.Data.UpdateStep==uf.DownloadingInstaller||e.Data.UpdateStep==uf.DownloadingUpdate||e.Data.UpdateStep==uf.CheckingUpdate,o.DownloadProgress=e.Data.DownloadProgress,o.UpdateCreationTime=e.Data.Update.Creationtime,o.IsDownloadOnly=e.Data.DownloadOnly,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:vf.ServiceName,UpdateType:Cg.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new If,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ue.NoData:const r=new yf;r.UpdateType=Cg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new be(Gg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ue.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const o=new Fo;o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateDescription=ie(e.Data.UpdateDescription),o.UpdatedResourceName=ie(e.Data.UpdateName).get("en-US");const s=new mf;s.UpdatedResourceName=ie(e.Data.UpdateName),s.UpdateDescription=ie(e.Data.UpdateDescription),s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateType=Cg.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:vf.ServiceName,UpdateType:Cg.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 Fo;const i=new yf;switch(i.UpdateType=Cg.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 be(Gg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new be(Gg.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 mf;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=Cg.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:vf.ServiceName,UpdateType:Cg.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 be){const e=new yf;e.UpdateType=Cg.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new yf;r.UpdateType=Cg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new be(Gg.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Go.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof be)return t;const n=[];let r;r=new tf,r.Resource="Controller software",r.Type=Cg.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new tf,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=Cg.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 ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof be)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 be(Gg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Tf,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ue.OK)return new be(Gg.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 Ng.Public;case 1:return Ng.Beta;case 2:return Ng.Development;default:return new be(Gg.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return ff(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof be)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 be(Gg.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const o=yield this._connection.SendAndWaitForResponseAsync(new Df(e),1e4,!1);return null==o||(null==o?void 0:o.Status)!=ue.OK?new be(Gg.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`):ue.OK}))}EnableAutomaticControllerUpdateDownloadAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof be)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 be(Gg.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Pf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ue.OK?new be(Gg.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}DisableAutomaticControllerUpdateDownloadAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof be)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 be(Gg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Uf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ue.OK?new be(Gg.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}GetControllerUpdatesHistoryAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof be)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 be(Gg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Of,1e4,!1);if(null==r)return new be(Gg.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ue.OK:return null!=r.Data?r.Data.map((e=>{const t=new ef;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 be(Gg.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ue.NoData:return[];default:return new be(Gg.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,o){return ff(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 be)return a;const c=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new be(Gg.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=>ff(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==Cg.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==ue.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==Cg.SoftwareUpdate));if(null!=h)if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,s);e==ue.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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),d.push(e),o[0]++}const p=d.where((e=>e instanceof be)).toArray();if(null!=p&&0!=p.length){let e="";return p.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),p.any((e=>e.Type==Gg.UpdateDownloadFailed))?new be(Gg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new be(Gg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let s;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new be(Gg.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 Cg.RadioUpdate:return r?new be(Gg.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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),s);case Cg.SoftwareUpdate:if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new be(Gg.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");s=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),s==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else{let o=(yield this.CheckControllerUpdatesAsync()).UpdatesAvailable.any((e=>e.IsDownloadOnly));s=yield this.UpdateControllerUsingApiAsync(e,t,!o&&r),this._appStateService.AllowHibernation(),s==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}return s;default:return new be(Gg.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){return ff(this,void 0,void 0,(function*(){var n,r,o,s,i,a;switch(e.UpdateType){case No.Container:case No.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Sf(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new nf;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ue.MultiDataResponseStart:r.Status=Tg.PreparingForUpgrade;break;case ue.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(vf.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case Dg.CheckingApplicability:case Dg.CheckingIntegrity:case Dg.CheckingPackageIntegrity:r.Status=Tg.CheckingPackage;break;case Dg.CreatingBackup:case Dg.MigratingData:case Dg.Removing:r.Status=Tg.MovingData;break;case Dg.Deploying:case Dg.Installing:r.Status=Tg.Upgrading;break;case Dg.Downloading:r.Status=Tg.DownloadingPackage;break;case Dg.Error:r.Status=Tg.Error;break;case Dg.Installed:r.Status=Tg.Upgraded;break;case Dg.PreparingSystem:case Dg.ReadyToDownload:r.Status=Tg.PreparingForUpgrade;break;case Dg.UndoingInstallation:r.Status=Tg.InstallationStopped;break;case Dg.Unpackaging:r.Status=Tg.MovingData;break;case Dg.WaitingForUser:r.Status=Tg.Upgrading}break;case ue.MultiDataResponseStop:r.Status=Tg.OK;break;case ue.Error:case ue.FatalError:r.Status=Tg.Error}t(r)}),!1),ue.OK}catch(e){return new be(Gg.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case No.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 be)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield ry.Get(Qs.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(vf.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new nf;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=Tg.PreparingForUpgrade,t(r);let o=2;const s=Date.now(),i=900*c+16e5,a=i/100,u=s+i,l=new Promise(((s,c)=>ff(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=Tg.Upgraded,t(r),s(ue.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=Tg.Upgraded,t(r),s(ue.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=Tg.Upgraded,t(r),s(ue.OK);else{var e=o;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=Tg.Upgrading,t(r))}o++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Af(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ue.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Tg.InstallationError,t(r),this._logger.Debug(vf.ServiceName,`Update failed with error. Update response status: ${d.Status}`),s(new be(Gg.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(vf.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Tg.Error,t(r),clearInterval(n),s(new be(Gg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new nf;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Tg.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new be(Gg.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new _f({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ue.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Tg.PreparingForUpgrade,t(n);let r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Cf("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ue.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=Tg.PreparingForUpgrade,t(n),r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Cf(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ue.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Tg.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Cf("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ue.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Tg.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)=>ff(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=Tg.Upgraded,t(n),s(ue.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=Tg.Upgraded,t(n),s(ue.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=Tg.Upgraded,t(n),s(ue.OK);else{var i=5+r*o;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=Tg.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Cf("/runtime/tmp/update.sh"),12e3,!1)}catch(e){s(new be(Gg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=Tg.InstallationError,t(n),new be(Gg.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Cf("/runtime/scripts/restart_all.sh"),12e3,!1),new be(Gg.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new be(Gg.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new be(Gg.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new be(Gg.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}DownloadControllerUpdateNewApiAsync(e,t,n,r){return ff(this,void 0,void 0,(function*(){return new Promise(((t,o)=>ff(this,void 0,void 0,(function*(){let o=50;r||(o=100);let s=100/o;yield this._connection.SendAndHandleResponseAsync(new Gf,this._updateRequestTimeout,(o=>{var i,a,c,u,l,d;const h=new rf;switch(h.DownloadOnly=r,h.UpdatedResourceName=ie(e.Update.UpdateName),o.Status){case ue.MultiDataResponseStart:h.Percentage=0,h.SpeedMbps=0,h.PercentageTotal=0,h.CurrentTask=Ig.DownloadingInstaller,n(h);break;case ue.MultiDataResponse:if(null!=o.Data){switch(h.Percentage=o.Data.StepProgressInPercentage,h.SpeedMbps=o.Data.DownloadSpeedInMbs,h.PercentageTotal=r?Math.round((null===(i=o.Data)||void 0===i?void 0:i.UpdateProgressInPercentage)*s):Math.round(null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage),o.Data.UpdateStep){case uf.DownloadingInstaller:h.CurrentTask=Ig.DownloadingInstaller;break;case uf.DownloadingUpdate:h.CurrentTask=Ig.DownloadingUpdate;break;case uf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(c=o.Data)||void 0===c?void 0:c.UpdateProgressInPercentage)*s):Math.round(null===(u=o.Data)||void 0===u?void 0:u.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Ig.CheckingUpdate,n(h),h.CurrentTask=Ig.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;default:h.CurrentTask=Ig.CheckingUpdate}n(h)}break;case ue.MultiDataResponseStop:if(null!=o.Data)switch(o.Data.UpdateStep){case uf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(l=o.Data)||void 0===l?void 0:l.UpdateProgressInPercentage)*s):Math.round(null===(d=o.Data)||void 0===d?void 0:d.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Ig.CheckingUpdate,n(h),h.CurrentTask=Ig.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;case uf.UpdateDownloadFailed:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Ig.Unknown,n(h),t(new be(Gg.UpdateDownloadFailed,"Update download failed!"))}break;case ue.Error:case ue.FatalError:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Ig.Unknown,n(h),t(new be(Gg.CannotProcessUpdate,"Update download failed!"))}}),!1)}))))}))}InstallUpdateNewApiAsync(e,t,n,r){return ff(this,void 0,void 0,(function*(){return new Promise(((n,r)=>ff(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let o=0;const s=new nf;let i=null;e.DownloadOnly=!1;const a=e=>ff(this,void 0,void 0,(function*(){e==Os.Connected&&(clearInterval(i),s.Status=Tg.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),yield se.Delay(5e3),n(ue.OK),ry.Get(Xs.ServiceName).OnAppStateChanged().Unsubscribe(a))}));yield this._connection.SendAndHandleResponseAsync(new Nf,this._updateRequestTimeout,(c=>{var u,l;switch(s.UpdatedResourceName=ie(e.Update.UpdateName),c.Status){case ue.MultiDataResponseStart:s.Status=Tg.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 ue.MultiDataResponse:null!=c.Data&&(s.Status=Tg.Upgrading,s.Percentage=Math.round(c.Data.StepProgressInPercentage),s.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage),o=c.Data.StepProgressInPercentage,t(s));break;case ue.MultiDataResponseStop:if(null!=c.Data)switch(c.Data.UpdateStep){case uf.UpdateInstallationFailed:s.Status=Tg.InstallationError,s.Percentage=0,s.PercentageTotal=0,t(s),n(new be(Gg.CannotProcessUpdate,"Update installation failed!"));break;case uf.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=Tg.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),n(ue.OK)):(s.Status=Tg.Upgrading,s.Percentage=Math.round(o),s.PercentageTotal=Math.round(u),t(s))}),r/(100-o)),ry.Get(Xs.ServiceName).OnAppStateChanged().Subscribe(a)}}break;case ue.Error:case ue.FatalError:s.Status=Tg.Error,s.Percentage=0,s.PercentageTotal=0,t(s),n(new be(Gg.CannotProcessUpdate,"Update installation failed!"))}}),!1)}))))}))}InstallControllerUpdateUsingApiAsync(e,t){return ff(this,void 0,void 0,(function*(){const n=yield this._connection.SendAndWaitForResponseAsync(new bf,1e4,!1);if((null==n?void 0:n.Status)==ue.NoData)return new be(Gg.DeviceIsUpToDate,"No updates available!");if(null==n||(null==n?void 0:n.Status)!=ue.OK||null==(null==n?void 0:n.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==n?void 0:n.Status}`);switch(n.Data.UpdateStep){case uf.DownloadingInstaller:case uf.DownloadingUpdate:return new be(Gg.UpdateAlreadyDownloaded,"Update already downloaded, or download in progress.");case uf.InstallingUpdate:case uf.PreparingUpdate:return new be(Gg.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case uf.UpdateDownloaded:return n.Data.DownloadOnly=!1,yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1);default:this._logger.Debug(vf.ServiceName,`Installing update using new API. Update step: ${n.Data.UpdateStep} downloadOnly: false`),n.Data.DownloadOnly=!1;var r=yield this.DownloadControllerUpdateNewApiAsync(n.Data,e,t,!1);return r!=ue.OK?r:yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1)}}))}DownloadControllerUpdateUsingApiAsync(e,t,n){return ff(this,void 0,void 0,(function*(){const r=yield this._connection.SendAndWaitForResponseAsync(new bf,1e4,!1);if((null==r?void 0:r.Status)==ue.NoData)return new be(Gg.DeviceIsUpToDate,"No updates available!");if(null==r||(null==r?void 0:r.Status)!=ue.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 uf.DownloadingInstaller:case uf.DownloadingUpdate:case uf.UpdateDownloaded:return new be(Gg.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case uf.InstallingUpdate:case uf.PreparingUpdate:return new be(Gg.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield this.DownloadControllerUpdateNewApiAsync(r.Data,e,t,n)}}))}UpdateControllerUsingApiAsync(e,t,n){return ff(this,void 0,void 0,(function*(){return n?yield this.DownloadControllerUpdateUsingApiAsync(e,t,!0):yield this.InstallControllerUpdateUsingApiAsync(e,t)}))}getRuntimeInfoAsync(){return ff(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof ls&&e.code==Bo.Timeout?new be(Gg.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new be(Gg.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}vf.ServiceName="UpdatesService";class yf{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class mf{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,this._isDownloadOnly=!1}get IsDownloadOnly(){return this._isDownloadOnly}set IsDownloadOnly(e){this._isDownloadOnly=e}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 wf{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 Sf extends ce{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=le.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"}(sf||(sf={})),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"}(af||(af={})),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"}(cf||(cf={})),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"}(uf||(uf={}));class Af extends ce{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=le.Put,this.Data=e}}class _f extends ce{constructor(e){super(),this.Resource="/users/user/login",this.Method=le.Put,this.Data=e}}class Cf extends ce{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=le.Post,this.Data=e}}class Tf extends ce{constructor(){super(),this.Resource="/updates/branch",this.Method=le.Get}}class Df extends ce{constructor(e){super(),this.Resource="/updates/branch",this.Method=le.Put,this.Data=e}}class kf extends ce{constructor(){super(),this.Resource="/updates/failed/cancel",this.Method=le.Put}}class Ef extends ce{constructor(){super(),this.Resource="/updates/pending/progress",this.Method=le.Get}}class bf extends ce{constructor(){super(),this.Resource="/updates/pending",this.Method=le.Get}}class If extends ce{constructor(){super(),this.Resource="/updates/check",this.Method=le.Get}}class Gf extends ce{constructor(){super(),this.Resource="/updates/download",this.Method=le.Post}}class Nf extends ce{constructor(){super(),this.Resource="/updates/install",this.Method=le.Post}}class Rf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=le.Get}}class Pf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=le.Put}}class Uf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=le.Put}}class Of extends ce{constructor(){super(),this.Resource="/updates/history",this.Method=le.Get}}class Mf extends ce{constructor(){super(),this.Resource="/updates/devices/availability",this.Method=le.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"}(lf||(lf={})),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",e[e.ThisHour=7]="ThisHour",e[e.ThisDay=8]="ThisDay",e[e.ThisWeek=9]="ThisWeek",e[e.ThisMonth=10]="ThisMonth",e[e.ThisYear=11]="ThisYear"}(df||(df={})),function(e){e[e.Day=0]="Day",e[e.Week=1]="Week",e[e.Month=2]="Month",e[e.Year=3]="Year",e[e.Hour=4]="Hour"}(hf||(hf={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(pf||(pf={}));class xf{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"}(gf||(gf={}));var Ff,Lf,Bf,Wf,$f,Vf,qf,Hf=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 Kf{constructor(){this.DELIM=";",this._connection=null,this._connection=ry.Get(Ct.ServiceName)}numToCsv(e){const t="string"==typeof e?Number(e.replace(",",".")):e;return Number.isFinite(t)?t.toLocaleString("en-US",{useGrouping:!1}):""}quoteIfNeeded(e){return e.includes(this.DELIM)||e.includes('"')?`"${e.replace(/"/g,'""')}"`:e}ExportPressureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`PressureHistory_${e.Name}_${t}.csv`)}ExportBrightnessToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return;const o=[],s=(n.Data[0],["Time","AggregatedBy"]);s.push("LuxValue","LuxToLinearScale","LightCondition"),o.push(s.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r;const s=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(s.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LuxValue)),s.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.LuxToLinearScale)),s.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.LightCondition))),o.push(s.join(this.DELIM))})),ae(o.join("\n"),`BrightnessHistory_${e.Name}_${t}.csv`)}ExportHumidityToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`HumidityHistory_${e.Name}_${t}.csv`)}ExportWindSpeedToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`WindSpeedHistory_${e.Name}_${t}.csv`)}ExportTemperatureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`TemperatureHistory_${e.Name}_${t}.csv`)}ExportAveragingStateValuesToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return"";const o=[],s=(n.Data[0],["Time","AggregatedBy"]);return s.push("LastValue","Average","Mode","Min","Max"),o.push(s.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r,s,i;const a=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(a.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LastValue)),a.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.Average)),a.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.Mode)),a.push(this.numToCsv(null===(s=e.Values)||void 0===s?void 0:s.Min)),a.push(this.numToCsv(null===(i=e.Values)||void 0===i?void 0:i.Max))),o.push(a.join(this.DELIM))})),o.join("\n")}ExportEnergyToCsv(e,t,n){var r,o;let s=n.Data;if(!(null==s?void 0:s.length))return;const i=[],a=s[0],c=["Time","AggregatedBy"];null===(r=a.Values)||void 0===r||r.MeasurementAveragingParameters.forEach(((e,t)=>{c.push(`${t}:LastValue`,`${t}:Average`,`${t}:Mode`,`${t}:Min`,`${t}:Max`)})),null===(o=a.Values)||void 0===o||o.MeasurementNonAveragingParmeters.forEach(((e,t)=>c.push(`${t}`))),i.push(c.join(this.DELIM)),s.forEach((e=>{var t,n;const r=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null===(t=e.Values)||void 0===t||t.MeasurementAveragingParameters.forEach((e=>{r.push(this.numToCsv(e.LastValue),this.numToCsv(e.Average),this.numToCsv(e.Mode),this.numToCsv(e.Min),this.numToCsv(e.Max))})),null===(n=e.Values)||void 0===n||n.MeasurementNonAveragingParmeters.forEach((e=>r.push(this.numToCsv(e)))),i.push(r.join(this.DELIM))})),ae(i.join("\n"),`EnergyHistory_${e.Name}_${t}.csv`)}GetStatesByTimeRangeAsync(e,t,n,r,o,s,i){return Hf(this,arguments,void 0,(function*(e,t,n,r,o,s,i,a=!1){var c;try{if(!(yield this.DoesSupportPreciseTimeFramesAsync()))return new be(lf.FunctionalityNotSupported,"State history data in time range is not supported with this version of controller software, update software to get this functionality.");let u;if("string"==typeof e){const t=yield ry.Get(Qs.ServiceName).GetDevice(e);if(null==t)return new be(lf.CannotFindDevice,`Device with specified GUID ${e} does not exist.`);u=t}else u=e;if(!u.Channels.any((e=>e.Number===t)))return new be(lf.InvalidChannelNumber,`Given channel not found in device with guid: ${u.Guid}.`);if(!u.Channels.any((e=>e.Number===t&&e.AvailableResponseTypes.any((e=>e.Type===n)))))return new be(lf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const l=new Xf;l.DeviceGuid=u.Guid,l.DeviceChannel=t,l.StateInterfaceType=n,l.ReverseOrder=a,l.DataRange=r,l.Time=o,l.Limit=s,l.Offset=i;const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Jf(l),3e4,!1);if(null==d)return new be(lf.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new be(lf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new be(lf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new be(lf.OtherError,"Cannot get state history data - some parameters are incorrect!");case"UnsupportedRange":return new be(lf.OtherError,"Cannot get state history data - time range is incorrect!");default:return new be(lf.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new be(lf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new be(lf.ResponseTypeNotSupported,`Device or channel not supporting requested DeviceResponseType or device/channel does not exist. ${d.Data}`);case ue.OK:if(null==d.Data)return new be(lf.NoData,"Controller responded with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===It.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new be(lf.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new be(lf.FatalError,`Cannot get state history data - exception occurs! ${e}`)}}))}GetServiceName(){return Kf.ServiceName}DoesSupportPreciseTimeFramesAsync(){return Hf(this,void 0,void 0,(function*(){let e=(yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>6||6===Number(e[0])&&Number(e[1])>=101}))}GetStatesByIntervalAsync(e,t,n,r,o,s){return Hf(this,arguments,void 0,(function*(e,t,n,r,o,s,i=!1){var a;try{if(!(yield this.IsFunctionalitySupportedAsync()))return new be(lf.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 ry.Get(Qs.ServiceName).GetDevice(e);if(null==t)return new be(lf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new be(lf.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 be(lf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new zf;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=o,u.Offset=s;let l=(yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");if(Number(l[0])>6||6===Number(l[0])&&Number(l[1])>=101)switch(r){case df.ThisHour:u.Range=df.Hour;break;case df.ThisDay:u.Range=df.Day;break;case df.ThisWeek:u.Range=df.Week;break;case df.ThisMonth:u.Range=df.Month;break;case df.ThisYear:u.Range=df.Year}else u.Range=r;const d=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new jf(u),3e4,!1);if(null==d)return new be(lf.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new be(lf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new be(lf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new be(lf.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new be(lf.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new be(lf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new be(lf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ue.OK:if(null==d.Data)return new be(lf.NoData,"Controller responede with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===It.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new be(lf.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new be(lf.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){return Hf(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Yf,12e3,!1);return null==t?new be(lf.OtherError,"Cannot get available states - response is null."):t.Status!=ue.OK?new be(lf.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new be(lf.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new xf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new be(lf.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return Hf(this,void 0,void 0,(function*(){let e=(yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>3||3===Number(e[0])&&Number(e[1])>=42}))}GetAvailableStatesPerChannelAsync(e,t){return Hf(this,void 0,void 0,(function*(){var n;let r;if("string"==typeof e){const t=yield ry.Get(Qs.ServiceName).GetDevice(e);if(null==t)return new be(lf.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 Qf(new Zf(r.Guid,t)),8e3,!1);if(null==o)return new be(lf.OtherError,"Cannot get available states - response is null.");switch(o.Status){case ue.ResourceDoesNotExists:switch(o.Data){case"DeviceNotFound":return new be(lf.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new be(lf.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new be(lf.OtherError,"Cannot get available states - unknown error!")}case ue.OK:{if(null==o.Data)return new be(lf.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 xf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return o.Data.AvailableStates=e,o.Data}default:return new be(lf.OtherError,`Cannot get available states - controller responded with response code ${o.Status}`)}}))}}Kf.ServiceName="StatesHistoryService";class jf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=le.Get,this.Data=e}}class zf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=df.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class Jf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/timerange",this.Method=le.Get,this.Data=e}}class Xf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.DataRange=hf.Day,this.Time=new Date,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class Yf extends ce{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=le.Get}}class Qf extends ce{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=le.Get,this.Data=e}}class Zf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(qf=Ff||(Ff={}))[qf.User=0]="User",qf[qf.Controller=1]="Controller",qf[qf.Marketing=2]="Marketing",(Vf=Lf||(Lf={}))[Vf.Notification=0]="Notification",Vf[Vf.Message=1]="Message",Vf[Vf.Alarm=2]="Alarm",Vf[Vf.Warning=3]="Warning",Vf[Vf.Info=4]="Info",($f=Bf||(Bf={}))[$f.Other=0]="Other",$f[$f.UserLoggedIn=1]="UserLoggedIn",$f[$f.UserLoggedOut=2]="UserLoggedOut",$f[$f.FoundNewDevice=3]="FoundNewDevice",$f[$f.DoorBellPress=4]="DoorBellPress",$f[$f.AddedNewDevice=5]="AddedNewDevice",$f[$f.RemovedDevice=6]="RemovedDevice",$f[$f.RegisteredNewUser=7]="RegisteredNewUser",$f[$f.GotAccessToTheInternet=8]="GotAccessToTheInternet",$f[$f.LostAccessToTheInternet=9]="LostAccessToTheInternet",$f[$f.RemovedUser=10]="RemovedUser",$f[$f.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(Wf||(Wf={}));var ev=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 tv{constructor(){this._chatSubscriptions=[],this._connection=ry.Get(Ct.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==Lf.Message)return;const n=new nv;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(Wf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return ev(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new rv,12e3,!1);if(null==e)return new be(gv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new be(gv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new be(gv.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==Lf.Message)return;const n=new nv;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(Wf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new be(gv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return ev(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new ov(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class nv{constructor(){this._sender=Ff.Controller,this._messageType=Lf.Info,this._messageSource=Bf.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 rv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}class ov extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}var sv,iv,av,cv=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._chatSubscriptions=[],this._connection=ry.Get(Ct.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==Lf.Message){const e=new lv;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 cv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new hv,12e3,!1);if(null==e)return new be(gv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new be(gv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new be(gv.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==Lf.Message){const n=new lv;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 be(gv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return cv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new dv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class lv{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 dv extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}class hv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(sv||(sv={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(iv||(iv={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(av||(av={}));var pv,gv,fv,vv=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 yv{constructor(){this._chatSubscriptions=[],this._connection=ry.Get(Ct.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new Av;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=sv[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(av[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return vv(this,void 0,void 0,(function*(){return(yield ry.Get(nt.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return vv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new wv,8e3,!1);return null==e||null==e.Status?new be(gv.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ue.OK?new be(gv.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new be(gv.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new be(gv.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return vv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new Sv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot set chat configuration! ${e}`),ue.FatalError}}))}SendMessageAsync(e){return vv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new mv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot send message! ${e}`),ue.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 mv extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=le.Put,this.Data=e}}class wv extends ce{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Get}}class Sv extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Put,this.Data=e}}class Av{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"}(pv||(pv={}));class _v{constructor(){this._services={ControllerChat:new tv,GptChat:new yv,FamillyChat:new uv}}GetServiceName(){return _v.ServiceName}GetChatImplementation(e){switch(e){case pv.ControllerChat:return this._services.ControllerChat;case pv.FamilyChat:return this._services.FamillyChat;case pv.GptChat:return this._services.GptChat;default:throw new Cv(`Chat with type ${e} not implemented!`)}}}_v.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(gv||(gv={}));class Cv 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"}(fv||(fv={}));var Tv=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 Dv{constructor(){this._connection=ry.Get(Ct.ServiceName),this._log=ry.Get(c.ServiceName)}GetServiceName(){return Dv.ServiceName}IsSupportedAsync(){return Tv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new kv,2e3,!0);return this._log.Debug(Dv.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ue.WrongData}))}GetConnectedAppsAsync(){return Tv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Ev,2e3,!0);return(null==e?void 0:e.Status)===ue.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Tv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Iv(e),2e3,!1);switch(null==t?void 0:t.Status){case ue.OK:return new be(fv.Changed,"");case ue.WrongData:switch(t.Data){case"AccessTokenToShort":return new be(fv.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new be(fv.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new be(fv.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new be(fv.AppNameToShort,t.Data);case"AppUrlToShort":return new be(fv.AppUrlToShort,t.Data);case"AppUserIdToShort":return new be(fv.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new be(fv.AppUserNameToShort,t.Data);default:return new be(fv.UnkownError,t.Data)}case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new be(fv.ResourceIsNotAvailable,t.Data);default:return new be(fv.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Tv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new bv(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}Dv.ServiceName="ConnectedAppsService";class kv extends ce{constructor(){super(),this.Resource="/applications/app/auth",this.Method=le.Put,this.Data=""}}class Ev extends ce{constructor(){super(),this.Resource="/applications/get",this.Method=le.Get}}class bv extends ce{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=le.Delete,this.Data=e}}class Iv extends ce{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=le.Put,this.Data=e}}var Gv=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 Nv{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(Nv.AppUserControllersKeyName,e)}null!==o&&localStorage.setItem(Nv.AppUserControllersKeyName,decodeURIComponent(o)),null!==s&&localStorage.setItem(Nv.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 Nv.ServiceName}IsMigrationDataAvailableAsync(){return Gv(this,void 0,void 0,(function*(){try{if(oe.IsIosNative()){var e=yield Nv.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(Nv.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Nv.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return Gv(this,void 0,void 0,(function*(){try{if(oe.IsIosNative()){let e=yield Nv.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(Nv.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return Gv(this,void 0,void 0,(function*(){try{if(oe.IsIosNative()){let e=yield Nv.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(Nv.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)}}))}}Nv.AppSelectedLanguageKeyName="App___SelectedLanguage",Nv.AppUserControllersKeyName="App___UserControllersListDatabase",Nv.ServiceName="DataMigrationService";var Rv=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 Pv{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=ry.Get(Ct.ServiceName),this._logger=ry.Get(c.ServiceName),this._storage=ry.Get(l.ServiceName),ry.Get(Xe.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Rv(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(Pv.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;oe.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(Pv.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(Pv.ServiceName,"Controller not found in local network."))}else this._logger.Error(Pv.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(Pv.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return Rv(this,void 0,void 0,(function*(){if(oe.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(Pv.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){return Rv(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Uv,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(Pv.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return Pv.ServiceName}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("")}}))}}Pv.ServiceName="FindControllerService";class Uv extends ce{constructor(){super(),this.Resource="/network/lan/",this.Method=le.Get}}var Ov,Mv,xv,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._errorOccuredEvent=new a,this._connectionStateChangedEvent=new a,this._dataReceivedEvent=new a,this._onMessageReceived=new a,this._log=ry.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=ry.Get(at.ServiceName),this._cache=ry.Get(Be.ServiceName),this._session=ry.Get(Xe.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return Fv(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 Fv(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 ce;return t.Resource="/system/ping",t.Method=le.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 ry.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(Lv.ServiceName,`Connecting to the WebSockets server ${e}`),this.socket.onerror=t=>(this._log.Debug(Lv.ServiceName,`Error occured in the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._errorOccuredEvent.Invoke(["WebSockets",t.toString()]),n(he.FailedToConnect)),this.socket.onopen=n=>(this._log.Debug(Lv.ServiceName,`Connected to the WebSockets server ${e} info: \n${JSON.stringify(n)}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(pe.Connected),this._pingIntervalId=setInterval((()=>Fv(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval),t(he.Connected)),this.socket.onclose=t=>{this._log.Debug(Lv.ServiceName,`Disconnected from the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(pe.Disconnected)},this.socket.onmessage=t=>{this._log.Debug(Lv.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(Lv.ServiceName,`Received data frame: ${e.Status}`),this._dataReceivedEvent.Invoke(e)}catch(e){this._log.Error(Lv.ServiceName,`Failed to parse message: ${t.data}`)}},this._connectionStateChangedEvent.Invoke(pe.Connecting)}))}AuthorizeAsync(e){return Fv(this,void 0,void 0,(function*(){return ry.WorksInContextOf=e.SerialNumber,!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Lv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,this._connectionStateChangedEvent.Invoke(pe.ConnectedAndAuthorized),!0)}))}ConnectAndAuthorizeAsync(e){return Fv(this,void 0,void 0,(function*(){if(ry.WorksInContextOf=e.SerialNumber,this._log.Debug(Lv.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`),!(yield this.AuthorizeAsync(e)))return he.AuthorizationFailed;let t=yield this.GetServerAddressAsync();return null==t?he.FailedToConnectToServer:yield this.ConnectAsync(t)}))}DisconnectAsync(){var e;return this._log.Debug(Lv.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._connectionStateChangedEvent.Invoke(pe.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(Lv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Lv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Lv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.socket)||void 0===n||n.send(r):this._log.Error(Lv.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 Fv(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)=>Fv(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(Lv.ServiceName,t),a(new Error(t))}),t);let u=l=>Fv(this,void 0,void 0,(function*(){var d,h,p;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(s);const g=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Lv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${g}ms`),(null==l?void 0:l.Status)===ue.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===(p=this._session)||void 0===p?void 0:p.RestoreSessionAsync(),o(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ue.MultiDataResponseStart:case ue.MultiDataResponse:n(l),s=c();break;case ue.MultiDataResponseStop:case ue.FatalError:case ue.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 Fv(this,arguments,void 0,(function*(e,t,n,r=!0,o=!0){var s,i,a;if(e.Method===le.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)=>Fv(this,void 0,void 0,(function*(){let a=i=>Fv(this,void 0,void 0,(function*(){var l,d,h,p;if((null==i?void 0:i.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const g=Date.now()-u;o&&this._log.Debug(Lv.ServiceName,`Received response for: ${null==i?void 0:i.Resource} ${null==i?void 0:i.Method} id: ${null==i?void 0:i.TransactionId} in ${g}ms`),e.Method===le.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ue.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===(p=this._session)||void 0===p?void 0:p.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(Lv.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 Lv.ServiceName}}Lv.ServiceName="ExalusConnectionService";class Bv{constructor(){var e,t;this.OnEnteredPictureInPicture=new ke,this.OnExitedPictureInPicture=new ke,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 Bv.ServiceName}}Bv.ServiceName="PictureInPictureService",(xv=Ov||(Ov={}))[xv.Unknown=-1]="Unknown",xv[xv.Web=0]="Web",xv[xv.Android=1]="Android",xv[xv.iOS=2]="iOS";class Wv{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=Ov.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"}(Mv||(Mv={}));var $v=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 Vv{constructor(){this._connection=ry.Get(Ct.ServiceName),this._logger=ry.Get(c.ServiceName)}GetServiceName(){return Vv.ServiceName}RegisterNotificationsClientAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=new qv({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 be(Mv.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ue.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:Mv.UnknownError;return new be(e,"Cannot register notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof r.Data?r.Data:new be(Mv.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new be(Mv.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new be(Mv.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){return $v(this,void 0,void 0,(function*(){var n;try{const r=new Hv({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 be(Mv.UnknownError,"Cannot update notifications client - unknown error!");switch(o.Status){case ue.WrongData:{const e=this.isValidErrorCode(o.Data)?o.Data:Mv.UnknownError;return new be(e,"Cannot update notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof o.Data?o.Data==e?ue.OK:new be(Mv.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${o.Data}`):new be(Mv.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new be(Mv.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new be(Mv.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(e){return $v(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Kv,8e3,!1);return null==t||null==t.Status?new be(Mv.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ue.ResourceDoesNotExists?new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ue.OK?new be(Mv.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new be(Mv.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new Wv;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 be(Mv.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotificationsEnabledForAllUserTokensAsync(e){return $v(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 be(Mv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new be(e,"Cannot get notifications status!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new be(Mv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new be(Mv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new be(Mv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}IsNotificationsEnabledAsync(e){return $v(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 be(Mv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:if(null==n.Data)return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new be(e,"Cannot get notifications status - resource not exists!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new be(Mv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new be(Mv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new be(Mv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){return $v(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 zv(n),8e3,!1);if(null==r||null==r.Status)return new be(Mv.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Mv.UnknownError;return new be(e,"Cannot enable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new be(Mv.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new be(Mv.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}EnableNotificationsForAllUserTokensAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Xv(e),8e3,!1);if(null==n||null==n.Status)return new be(Mv.UnknownError,"Cannot enable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new be(e,"Cannot enable notifications!")}case ue.OK:return ue.OK;default:return new be(Mv.UnknownError,`Cannot enable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot enable notifications for lavva user ${e} - error: ${t}`),new be(Mv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DisableNotificationsAsync(e){return $v(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 Jv(n),8e3,!1);if(null==r||null==r.Status)return new be(Mv.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Mv.UnknownError;return new be(e,"Cannot disable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new be(Mv.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new be(Mv.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}DisableNotificationsForAllUserTokensAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Yv(e),8e3,!1);if(null==n||null==n.Status)return new be(Mv.UnknownError,"Cannot disable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new be(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new be(e,"Cannot disable notifications!")}case ue.OK:return ue.OK;default:return new be(Mv.UnknownError,`Cannot disable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot disable notifications for lavva user ${e} - error: ${t}`),new be(Mv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DeleteNotificationsTokenAsync(e){return $v(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);return null==n||null==n.Status?new be(Mv.UnknownError,"Cannot delete notifications token - unknown error!"):n.Status==ue.OK?ue.OK:new be(Mv.UnknownError,`Cannot delete notifications token - response code ${n.Status}!`)}catch(e){return this._logger.Error(`Cannot delete notifications token - error: ${e}`),new be(Mv.UnknownError,`Cannot delete notifications token - error: ${e}`)}}))}getClientType(){return oe.IsIosNative()?Ov.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?Ov.Android:Ov.Web}isValidErrorCode(e){return Object.values(Mv).includes(e)}}Vv.ServiceName="NotificationsService";class qv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Post,this.Data=e}}class Hv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Put,this.Data=e}}class Kv extends ce{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=le.Get}}class jv extends ce{constructor(e){super(),this.Resource="/notifications/status",this.Method=le.Get,this.Data={TokenIdentity:e}}}class zv extends ce{constructor(e){super(),this.Resource="/notifications/enable",this.Method=le.Post,this.Data=e}}class Jv extends ce{constructor(e){super(),this.Resource="/notifications/disable",this.Method=le.Post,this.Data=e}}class Xv extends ce{constructor(e){super(),this.Resource="/notifications/enable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Yv extends ce{constructor(e){super(),this.Resource="/notifications/disable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Qv extends ce{constructor(e){super(),this.Resource="/notifications/status/for/lavva/user",this.Method=le.Get,this.Data=e}}class Zv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Delete,this.Data=e}}class ey{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 ey.ServiceName}}ey.ServiceName="AndroidLocationService";class ty{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)}GetNotificationsQueueAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetNotificationsQueueAsync():Promise.resolve(null)}GetServiceName(){return ty.ServiceName}}ty.ServiceName="AndroidNotificationsService";class ny{OpenRateDialogAsync(){if(oe.IsIosNative())try{if(null!=window.webkit.messageHandlers.rateApp)return window.webkit.messageHandlers.rateApp.postMessage(!0),Promise.resolve()}catch(e){return Promise.reject(new Error(`Rate dialog is not available on this platform. Error: ${e}`))}else if(this.IsAvailable())return navigator.AndroidAppRate.OpenRateDialogAsync();return Promise.reject(new Error("AppRateService is not available on this platform."))}IsAvailable(){var e,t;return void 0!==navigator.AndroidAppRate||void 0!==(null===(t=null===(e=window.webkit)||void 0===e?void 0:e.messageHandlers)||void 0===t?void 0:t.rateApp)}GetServiceName(){return ny.ServiceName}}ny.ServiceName="AppRateService",vu(Map),vu(Set),(()=>{const e=String.prototype,t=Object.getOwnPropertyNames(Ci.prototype);for(const n of t)e[n]=e[n]??Ci.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 wi(mi.NoMatch)}if(0===this.length)throw new wi(mi.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 yi("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 wi(mi.NoMatch)}if(0===this.length)throw new wi(mi.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 Ci((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),wg(Array),wg(Int8Array),wg(Int16Array),wg(Int32Array),wg(Uint8Array),wg(Uint8ClampedArray),wg(Uint16Array),wg(Uint32Array),wg(Float32Array),wg(Float64Array);class ry{static Init(){if(u.IsInitialized)return;let e=u.Instance;try{e.RegisterService(new Nv),e.RegisterService(new l),e.RegisterService(new Xs),e.RegisterService(new Be),e.RegisterService(new Xe),e.RegisterService(new Bv),e.RegisterService(new ny),ry.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Lv)):e.RegisterService(new Ct),e.RegisterService(new ey),e.RegisterService(new ty),e.RegisterService(new Co),e.RegisterService(new Co),e.RegisterService(new Po),e.RegisterService(new at),e.RegisterService(new Pv),e.RegisterService(new wo),e.RegisterService(new nt),e.RegisterService(new Ne),e.RegisterService(new $e),e.RegisterService(new Qs),e.RegisterService(new Og),e.RegisterService(new ss),e.RegisterService(new vf),e.RegisterService(new Dv),e.RegisterService(new Kf),e.RegisterService(new xs),e.RegisterService(new _v),e.RegisterService(new Vv)}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}}ry.WorksInContextOf="",ry.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:()=>ry});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_${ry.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 p{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 g{static get isBrowser(){return!g.isNode&&"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return!g.isNode&&"object"==typeof self&&"importScripts"in self}static get isReactNative(){return!g.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 g.isNode&&(e="User-Agent"),[e,A("8.0.7",_(),g.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(!g.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(g.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 I extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class b 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 U{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 O{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")},p.isRequired(e,"connection"),p.isRequired(t,"logger"),p.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(),g.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 O(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 I("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 U;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 I("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),g.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 V 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 q extends ${constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch||g.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 I;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 I});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 g.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 I):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 I)}),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||g.isNode)this._httpClient=new q(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 I):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(p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.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 p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.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(g.isBrowser||g.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 p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.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(g.isNode||g.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,p.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(g.isNode){const e=require;o=e("ws"),s=e("eventsource")}g.isNode||"undefined"==typeof WebSocket||t.WebSocket?g.isNode&&!t.WebSocket&&o&&(t.WebSocket=o):t.WebSocket=WebSocket,g.isNode||"undefined"==typeof EventSource||t.EventSource?g.isNode&&!t.EventSource&&void 0!==s&&(t.EventSource=s):t.EventSource=EventSource,this._httpClient=new V(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,p.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 I(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 I(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 I("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 I(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 b(`'${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(!g.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(p.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 p.isRequired(e,"url"),p.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return p.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 p.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return p.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,p,g=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<g.length;u+=16)l=f,d=v,h=y,p=m,f=s(f,v,y,m,g[u+0],7,-680876936),m=s(m,f,v,y,g[u+1],12,-389564586),y=s(y,m,f,v,g[u+2],17,606105819),v=s(v,y,m,f,g[u+3],22,-1044525330),f=s(f,v,y,m,g[u+4],7,-176418897),m=s(m,f,v,y,g[u+5],12,1200080426),y=s(y,m,f,v,g[u+6],17,-1473231341),v=s(v,y,m,f,g[u+7],22,-45705983),f=s(f,v,y,m,g[u+8],7,1770035416),m=s(m,f,v,y,g[u+9],12,-1958414417),y=s(y,m,f,v,g[u+10],17,-42063),v=s(v,y,m,f,g[u+11],22,-1990404162),f=s(f,v,y,m,g[u+12],7,1804603682),m=s(m,f,v,y,g[u+13],12,-40341101),y=s(y,m,f,v,g[u+14],17,-1502002290),v=s(v,y,m,f,g[u+15],22,1236535329),f=i(f,v,y,m,g[u+1],5,-165796510),m=i(m,f,v,y,g[u+6],9,-1069501632),y=i(y,m,f,v,g[u+11],14,643717713),v=i(v,y,m,f,g[u+0],20,-373897302),f=i(f,v,y,m,g[u+5],5,-701558691),m=i(m,f,v,y,g[u+10],9,38016083),y=i(y,m,f,v,g[u+15],14,-660478335),v=i(v,y,m,f,g[u+4],20,-405537848),f=i(f,v,y,m,g[u+9],5,568446438),m=i(m,f,v,y,g[u+14],9,-1019803690),y=i(y,m,f,v,g[u+3],14,-187363961),v=i(v,y,m,f,g[u+8],20,1163531501),f=i(f,v,y,m,g[u+13],5,-1444681467),m=i(m,f,v,y,g[u+2],9,-51403784),y=i(y,m,f,v,g[u+7],14,1735328473),v=i(v,y,m,f,g[u+12],20,-1926607734),f=a(f,v,y,m,g[u+5],4,-378558),m=a(m,f,v,y,g[u+8],11,-2022574463),y=a(y,m,f,v,g[u+11],16,1839030562),v=a(v,y,m,f,g[u+14],23,-35309556),f=a(f,v,y,m,g[u+1],4,-1530992060),m=a(m,f,v,y,g[u+4],11,1272893353),y=a(y,m,f,v,g[u+7],16,-155497632),v=a(v,y,m,f,g[u+10],23,-1094730640),f=a(f,v,y,m,g[u+13],4,681279174),m=a(m,f,v,y,g[u+0],11,-358537222),y=a(y,m,f,v,g[u+3],16,-722521979),v=a(v,y,m,f,g[u+6],23,76029189),f=a(f,v,y,m,g[u+9],4,-640364487),m=a(m,f,v,y,g[u+12],11,-421815835),y=a(y,m,f,v,g[u+15],16,530742520),v=a(v,y,m,f,g[u+2],23,-995338651),f=c(f,v,y,m,g[u+0],6,-198630844),m=c(m,f,v,y,g[u+7],10,1126891415),y=c(y,m,f,v,g[u+14],15,-1416354905),v=c(v,y,m,f,g[u+5],21,-57434055),f=c(f,v,y,m,g[u+12],6,1700485571),m=c(m,f,v,y,g[u+3],10,-1894986606),y=c(y,m,f,v,g[u+10],15,-1051523),v=c(v,y,m,f,g[u+1],21,-2054922799),f=c(f,v,y,m,g[u+8],6,1873313359),m=c(m,f,v,y,g[u+15],10,-30611744),y=c(y,m,f,v,g[u+6],15,-1560198380),v=c(v,y,m,f,g[u+13],21,1309151649),f=c(f,v,y,m,g[u+4],6,-145523070),m=c(m,f,v,y,g[u+11],10,-1120210379),y=c(y,m,f,v,g[u+2],15,718787259),v=c(v,y,m,f,g[u+9],21,-343485551),f=r(f,l),v=r(v,d),y=r(y,h),m=r(m,p);return n(f)+n(v)+n(y)+n(m)}static 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}}class se{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function ie(e){return new Map(Object.entries(e))}function ae(e,t="export.csv"){const n=new Blob(["\ufeff",e],{type:"text/csv;charset=utf-8;"}),r=URL.createObjectURL(n),o=document.createElement("a");o.href=r,o.download=t,o.style.display="none",document.body.appendChild(o),o.click(),document.body.removeChild(o),URL.revokeObjectURL(r)}class ce{constructor(){this.TransactionId=oe.GenerateUUID()}}var ue,le,de,he,pe,ge,fe,ve,ye,me,we,Se,Ae,_e,Ce;(Ae=ue||(ue={}))[Ae.OK=0]="OK",Ae[Ae.UnknownError=1]="UnknownError",Ae[Ae.FatalError=2]="FatalError",Ae[Ae.WrongData=3]="WrongData",Ae[Ae.ResourceDoesNotExists=4]="ResourceDoesNotExists",Ae[Ae.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",Ae[Ae.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",Ae[Ae.OperationNotPermitted=7]="OperationNotPermitted",Ae[Ae.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",Ae[Ae.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",Ae[Ae.Error=10]="Error",Ae[Ae.NoData=11]="NoData",Ae[Ae.NotSupportedMethod=12]="NotSupportedMethod",Ae[Ae.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",Ae[Ae.MultiDataResponseStart=14]="MultiDataResponseStart",Ae[Ae.MultiDataResponse=15]="MultiDataResponse",Ae[Ae.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"}(le||(le={}));class Te{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"}(de||(de={})),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"}(he||(he={})),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"}(pe||(pe={}));class De extends Error{constructor(e){super(e),this.name="StreamError"}}class ke{constructor(){this._log=ry.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={})),(Ce=fe||(fe={}))[Ce.Any=0]="Any",Ce[Ce.Guest=10]="Guest",Ce[Ce.Standard=20]="Standard",Ce[Ce.Admin=30]="Admin",Ce[Ce.Installator=40]="Installator",Ce[Ce.Support=50]="Support",(_e=ve||(ve={}))[_e.Unknown=0]="Unknown",_e[_e.Men=1]="Men",_e[_e.Woman=2]="Woman",_e[_e.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(ye||(ye={})),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"}(me||(me={}));class Ee{constructor(e,t){this._type=we.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 Ie{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"}(we||(we={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(Se||(Se={}));class be{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=Se.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 Ge=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 Ne{constructor(){this._imageExistsCaseNumber=0,this._connection=ry.Get(Ct.ServiceName),this._logger=ry.Get(c.ServiceName)}GetServiceName(){return Ne.ServiceName}AddPictureAsync(e){return Ge(this,void 0,void 0,(function*(){var t,n;try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ne.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ue.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(Ne.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Ne.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot add picture - Guid must be empty."),ue.WrongData;const s=new Pe;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(Ne.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError;if(i.Status==ue.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Fe(s),8e3,!1);return null==e||null==e.Status?(this._logger.Error(Ne.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError):e.Status}return i.Status==ue.OK?(this._logger.Warning(Ne.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ue.UnknownError):(this._logger.Error(Ne.ServiceName,"Cannot add picture - cannot get current picture status."),ue.Error)}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot add picture! ${e}`),ue.FatalError}}))}EditPictureAsync(e){return Ge(this,void 0,void 0,(function*(){var t,n,r,o;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - guid is empty."),ue.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ue.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(Ne.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===s.height||0===s.width)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;const a=new Pe;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(Ne.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==c||null==c.Status)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError;if(c.Status==ue.ResourceDoesNotExists)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - picture not exists."),ue.OperationNotPermitted;if(c.Status==ue.OK){const e=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Fe(a),8e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Ne.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(Ne.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError):e.Status}return this._logger.Error(Ne.ServiceName,"Cannot edit picture - cannot get current picture status."),ue.Error}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot edit picture! ${e}`),ue.FatalError}}))}DeletePictureAsync(e){return Ge(this,void 0,void 0,(function*(){var t,n;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot delete picture - guid is empty."),ue.WrongData;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e.Guid),8e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Ne.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DeletePictureAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==r||null==r.Status?(this._logger.Error(Ne.ServiceName,"Cannot delete picture - unknown error!"),ue.UnknownError):r.Status}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot delete picture! ${e}`),ue.FatalError}}))}GetPicturesInfoAsync(){return Ge(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(Ne.ServiceName,"Cannot get pictures info - unknown error!"),new Ie(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Ne.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Ie(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ne.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Ie(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ue;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(Ne.ServiceName,`Cannot get picture info! ${e}`),new Ie(ue.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){return Ge(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(Ne.ServiceName,"Cannot get picture - unknown error!"),new Ie(ue.UnknownError,"NoDataInResult");switch(n.Status){case ue.ResourceDoesNotExists:return new Ie(ue.ResourceDoesNotExists,"PictureNotFound");case ue.OK:if(null==n.Data)return new Ie(ue.Error,"RespondedWithOKButNoData");const e=new Re;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 Ie(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot get picture! ${e}`),new Ie(ue.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){return Ge(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new xe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ne.ServiceName,"Cannot get pictures - unknown error!"),new Ie(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Ne.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Ie(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ne.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Ie(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Re;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(Ne.ServiceName,`Cannot get pictures! ${e}`),new Ie(ue.FatalError,"ExceptionOccurred")}}))}}Ne.ServiceName="PictureService";class Re extends be{set DateTime(e){this._dateTime=e}}class Pe{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=Se.Device,this.DateTime=""}}class Ue{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 ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Get,this.Data=e}}class Me extends ce{constructor(){super(),this.Resource="/pictures/info",this.Method=le.Get}}class xe extends ce{constructor(){super(),this.Resource="/pictures/list",this.Method=le.Get}}class Fe extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Put,this.Data=e}}class Le extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Delete,this.Data=e}}class Be{constructor(){this._log=ry.Get(c.ServiceName),Be._localStorageService=ry.Get(l.ServiceName)}GetServiceName(){return Be.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ue.OK&&(this._log.Debug(Be.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Be._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Be._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Be.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Be._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Be.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Be._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Be.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Be._localStorageService=null,Be.ServiceName="WebApiCacheService";var We=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 $e{constructor(){this._connection=null,this._connection=ry.Get(Ct.ServiceName),this._pictureService=ry.Get(Ne.ServiceName),this._sessionService=ry.Get(Xe.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 fe.Support:return n===fe.Support;case fe.Installator:return n>=fe.Installator;case fe.Admin:default:return n>=fe.Admin}}GetServiceName(){return $e.ServiceName}GetUsersAsync(){return We(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ke,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ue.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new ze;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)==ue.NoData)return Promise.resolve([]);throw null===(t=u.Log)||void 0===t||t.Debug($e.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){return We(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 Ve(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ue.OK)return null===(n=u.Log)||void 0===n||n.Debug($e.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const o=new ze;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 We(this,void 0,void 0,(function*(){var n;if(null!=e.Guid&&""!=e.Guid)return new Ie(ue.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 He(r),2e4,!1);return ry.Get(Be.ServiceName).ClearCache(),null==o||null==o.Status?new Ie(ue.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Ie(o.Status,o.Data))}))}UpdateUserAsync(e){return We(this,void 0,void 0,(function*(){var t;if(null==e.Guid||""==e.Guid)return new Ie(ue.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 He(n),2e4,!1);return ry.Get(Be.ServiceName).ClearCache(),null==r||null==r.Status?new Ie(ue.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Ie(r.Status,r.Data))}))}ChangePasswordAsync(e,t){return We(this,void 0,void 0,(function*(){var n;if(null==e.Guid||""==e.Guid)return new Ie(ue.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Ie(ue.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 He(o),2e4,!1);return null==s||null==s.Status?new Ie(ue.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Ie(s.Status,s.Data))}))}DeleteUserAsync(e){return We(this,void 0,void 0,(function*(){var t,n;if(""===e)return ue.WrongData;null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new je(e),2e4,!1);return ry.Get(Be.ServiceName).ClearCache(),null==r||null==r.Status?ue.FatalError:(r.Status!=ue.OK&&(null===(n=u.Log)||void 0===n||n.Debug($e.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}))}GetUserProfilePictureAsync(e){return We(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ie(ue.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 ry.Get(Be.ServiceName).ClearCache(),null!=e.Type?t:e}return new Ie(ue.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return We(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ie(ue.WrongData,"GuidCannotBeEmpty");let n=new be;n.ImageType=Se.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(ry.Get(Be.ServiceName).ClearCache(),r.Type==ue.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ue.OK?new Ie(ue.OK,"PictureSet"):new Ie(e,"PictureServiceError")}if(null!=r.Type)return new Ie(ue.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ue.OK?new Ie(ue.OK,"PictureSet"):new Ie(e,"PictureServiceError")}}))}}$e.ServiceName="UsersService";class Ve extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Get,this.Data=e}}class qe{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=ve.Unknown,this.AccessLevel=fe.Any}}class He extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Put,this.Data=e}}class Ke extends ce{constructor(){super(),this.Resource="/users/list",this.Method=le.Get}}class je extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Delete,this.Data=e}}class ze{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=ve.Unknown,this._accessLevel=fe.Any,this._localization=ye.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 ry.Get($e.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return ry.Get($e.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var Je=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 Xe{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 Je(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{this.OnUserLoggedInEvent().Subscribe((t=>{var n;null===(n=u.Log)||void 0===n||n.Debug(Xe.ServiceName,`Logged in as ${t.Name}, completing CreateSessionCompletionSourceAsync()`),e()}))}))}))}isLoginError(e){return"number"==typeof e&&void 0!==me[e]}RestoreSessionAsync(){return Je(this,void 0,void 0,(function*(){var e,t,n,r,o;if(null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0===this._user||null===this._user)return!1;const s=ry.Get(Ct.ServiceName),i=s.GetAuthorizationInfo();return null===i?(null===(t=u.Log)||void 0===t||t.Error(Xe.ServiceName,"RestoreSessionAsync failed, no authorization info"),!1):(yield s.AuthorizeAsync(i))?this.isLoginError(yield this.UserLogInAsync(this._email,this._password))?(null===(r=u.Log)||void 0===r||r.Error(Xe.ServiceName,"RestoreSessionAsync failed, user login failed"),!1):(null===(o=u.Log)||void 0===o||o.Debug(Xe.ServiceName,"RestoreSessionAsync completed successfully"),!0):(null===(n=u.Log)||void 0===n||n.Error(Xe.ServiceName,"RestoreSessionAsync failed, authorization failed"),!1)}))}WaitForSessionCreationAsync(){return Je(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){return Je(this,void 0,void 0,(function*(){var e,t,n=new ce;n.Resource="/users/user/logout",n.Method=le.Put,this._email="",this._password="",(yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ue.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,"User has been logged out.")):null===(t=u.Log)||void 0===t||t.Debug(Xe.ServiceName,"Failed to logout user!")}))}AuthorizeAppAsync(e){return Je(this,void 0,void 0,(function*(){var t,n,r,o,s=ry.Get(Ct.ServiceName);const i=yield s.SendAndWaitForResponseAsync(new Qe(e),2e4,!1);if(i.Status==ue.OK&&null!=i.Data){this._authToken=e;var a=new ze;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;let n=ry.Get(at.ServiceName);return void 0!==i.Data.ConfigurationTime&&null!=i.Data.ConfigurationTime?(at.ConfigurationTimeRetrieved=new Date(i.Data.ConfigurationTime),yield n.CheckIfConfigurationTimeHasChangedAsync(new Date(i.Data.ConfigurationTime))):yield n.CheckIfConfigurationHasChangedAsync(),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,ry.Get(Ct.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Je(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Xe.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(Xe.ServiceName,`Did logging in succeded?: ${i.Status==ue.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return i.Status===ue.OperationNotPermitted?(null===(n=u.Log)||void 0===n||n.Debug(Xe.ServiceName,`App login response: ${i.Data}`),me.AuthDisabled):i.Status===ue.ResourceDoesNotExists?(null===(r=u.Log)||void 0===r||r.Debug(Xe.ServiceName,`App login response: ${i.Data}`),me.MethodNotSupported):(null===(o=u.Log)||void 0===o||o.Debug(Xe.ServiceName,`App login response: ${i.Data}`),me.WrongAuthData)}))}UserLogInAsync(e,t){return Je(this,void 0,void 0,(function*(){var n,r,o=ry.Get(Ct.ServiceName);const s=yield o.SendAndWaitForResponseAsync(new Ze(e,t),2e4,!1);if(s.Status==ue.OK&&null!=s.Data){this._email=e,this._password=t;var i=new ze;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;let r=ry.Get(at.ServiceName);return void 0!==s.Data.ConfigurationTime&&null!=s.Data.ConfigurationTime?(at.ConfigurationTimeRetrieved=new Date(s.Data.ConfigurationTime),yield r.CheckIfConfigurationTimeHasChangedAsync(new Date(s.Data.ConfigurationTime))):yield r.CheckIfConfigurationHasChangedAsync(),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,ry.Get(Ct.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Je(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Xe.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(Xe.ServiceName,`Did logging in succeded?: ${s.Status==ue.OK}`),this._onUserLoggedInEvent.Invoke(this._user),i}return null===(r=u.Log)||void 0===r||r.Debug(Xe.ServiceName,`User login response: ${s.Data}`),me.WrongAuthData}))}GetServiceName(){return Xe.ServiceName}}Xe.ServiceName="SessionService";class Ye{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class Qe extends ce{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=le.Put}}class Ze extends ce{constructor(e,t){super(),this.Data=new Ye(e,t),this.Resource="/users/user/login",this.Method=le.Put}}class et{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.IsAcquired=()=>this._running>0,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=()=>{if(0===this._running)throw new Error("Release called more times than AcquireAsync");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 tt=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 nt{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new et(1)}GetServiceName(){return nt.ServiceName}GetExtensionsInfoAsync(e){return tt(this,arguments,void 0,(function*(e,t=!1){var n;null===(n=u.Log)||void 0===n||n.Debug(nt.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 st("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e){return tt(this,arguments,void 0,(function*(e,t=!1,n=!1){var r;if(null===(r=u.Log)||void 0===r||r.Debug(nt.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 st("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 st("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return tt(this,void 0,void 0,(function*(){const e=new rt,t=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(e,16e3,!0);if(null==t||null==t.Status)throw new st("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ue.OK)throw new st(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new st("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 tt(this,void 0,void 0,(function*(){var e;const t=new ot,n=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(t,16e3,!0);if(null==n||null==n.Status)throw new st("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(n.Status){case ue.OK:if(null==n.Data)throw new st("Cannot get ProtocolInfo from controller, controller response does not contain data!");n.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ue.ResourceDoesNotExists:null===(e=u.Log)||void 0===e||e.Debug(nt.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new st(`Cannot get ProtocolInfo from controller! Response status: ${n.Status}`)}}))}}nt.ServiceName="StatisticsInfoService";class rt extends ce{constructor(){super(),this.Resource="/controller/extensions/",this.Method=le.Get}}class ot extends ce{constructor(){super(),this.Resource="/controller/protocols/",this.Method=le.Get}}class st extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var it=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 at{OnConfigurationChangedEvent(){return this._onConfigurationChangedEvent}GetServiceName(){return at.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new ke,this._onExitedConfigurationEvent=new ke,this._onConfigurationTimeCheckedEvent=new a,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!0,this._didSynchronization=!1,this._onSynchronized=new ke,this._onConfigurationChangedEvent=new ke,this._connection=ry.Get(Ct.ServiceName),this._session=ry.Get(Xe.ServiceName),this._localStorage=ry.Get(l.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{ry.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{var t;ry.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke(),null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.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 it(this,void 0,void 0,(function*(){var t,n,r;let o=yield e.text(),s=this.SplitStringBySize(o),i=new ct("");i.Status=ue.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)!=ue.OK)return ue.Error;for(const e of s){let t=new ct(e);t.Status=ue.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)!=ue.OK)return ue.Error}i.Status=ue.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)!=ue.OK?ue.Error:ue.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 it(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 vt,8e3,!1);return null==n||null==n.Status?ue.Error:n.Status!=ue.OK?n.Status:null==n.Data?ue.ResourceIsNotAvailable:new Date(n.Data)}catch(e){return null===(t=u.Log)||void 0===t||t.Error(at.ServiceName,`Cannot get current controller time! ${e}`),ue.FatalError}}))}SetControllerSystemTimeAsync(e){return it(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 yt(e.toISOString()),8e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return null===(n=u.Log)||void 0===n||n.Error(at.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}StartNtpTimeSynchronizationAsync(){return it(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 mt,8e3,!1);return null==n||null==n.Status?ue.Error:n.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(at.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}FactoryResetAsync(e){return it(this,void 0,void 0,(function*(){var t,n;try{ry.Get(Be.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==ue.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),ry.Get(Be.ServiceName).ClearCache(),clearInterval(o),ue.OK}return r}catch(e){return ue.FatalError}}))}RollbackLastUpdateAsync(e){return it(this,void 0,void 0,(function*(){var t,n;try{ry.Get(Be.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ht,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.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),ry.Get(Be.ServiceName).ClearCache(),clearInterval(o),ue.OK}return r}catch(e){return ue.FatalError}}))}RestartControllerAsync(e){return it(this,void 0,void 0,(function*(){var t,n;try{ry.Get(Be.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==ue.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),ry.Get(Be.ServiceName).ClearCache(),clearInterval(o),ue.OK}return r}catch(e){return ue.FatalError}}))}DidCofigurationChangeAsync(){return it(this,void 0,void 0,(function*(){return new Promise((e=>{var t;if(this._didSynchronization)return this._didConfigurationChange;null===(t=this._onSynchronized)||void 0===t||t.Subscribe((()=>{e(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 it(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,ry.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new pt,2e4,!1)}))}ExitConfigurationModeAsync(){return it(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,ry.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new gt,2e4,!1),this._didConfigurationChange=!0,ry.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._didConfigurationChange=!0,this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){return it(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ft,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ue.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return it(this,void 0,void 0,(function*(){var e,t,n,r;const o=yield this.GetLastConfigurationChangeTimeAsync();return null===(e=u.Log)||void 0===e||e.Info(at.ServiceName,`Checking if configuration time has changed. Current: ${o.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=o.toString()?(this.SaveLastConfigurationChangeTime(o),ry.Get(Be.ServiceName).ClearCache(),this._didSynchronization=!0,this._didConfigurationChange=!0,null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(o),null===(n=this._onSynchronized)||void 0===n||n.Invoke(),!0):(this._didSynchronization=!0,this._didConfigurationChange=!1,null===(r=this._onSynchronized)||void 0===r||r.Invoke(),!1)}))}CheckIfConfigurationTimeHasChangedAsync(e){return it(this,void 0,void 0,(function*(){var t,n,r,o;return null===(t=u.Log)||void 0===t||t.Info(at.ServiceName,`Checking if configuration time has changed. Current: ${e.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()?(this.SaveLastConfigurationChangeTime(e),ry.Get(Be.ServiceName).ClearCache(),this._didSynchronization=!0,this._didConfigurationChange=!0,null===(n=this.OnConfigurationChangedEvent())||void 0===n||n.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(e),null===(r=this._onSynchronized)||void 0===r||r.Invoke(),!0):(this._didSynchronization=!0,this._didConfigurationChange=!1,null===(o=this._onSynchronized)||void 0===o||o.Invoke(),!1)}))}CanExportOrImportControllerConfigurationAsync(){return it(this,void 0,void 0,(function*(){try{let e=yield ry.Get(nt.ServiceName).GetExtensionsInfoAsync(),t=ry.Get(Xe.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=fe.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){return it(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 ut,3e4,(e=>{switch(e.Status){case ue.MultiDataResponseStart:break;case ue.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);break;case ue.MultiDataResponseStop:break;case ue.Error:case ue.FatalError:n=new Ie(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:ry.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`}}at.ServiceName="ControllerConfigurationService",at.ConfigurationTimeRetrieved=null;class ct extends ce{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=le.Put,this.Data=e}}class ut extends ce{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=le.Get}}class lt extends ce{constructor(){super(),this.Resource="/controller/restart",this.Method=le.Post}}class dt extends ce{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=le.Post}}class ht extends ce{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=le.Post}}class pt extends ce{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=le.Put}}class gt extends ce{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=le.Put}}class ft extends ce{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=le.Get}}class vt extends ce{constructor(){super(),this.Resource="/system/time",this.Method=le.Get}}class yt extends ce{constructor(e){super(),this.Resource="/system/time",this.Method=le.Put,this.Data=e}}class mt extends ce{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=le.Put}}var wt=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 St{nextRetryDelayInMilliseconds(){return 1e3}}const At=[t.WebSockets,t.ServerSentEvents,t.LongPolling];class _t{constructor(){this._log=ry.Get(c.ServiceName)}log(e,t){if(!(e<Ct.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 Ct{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=ry.Get(c.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._dataReceivedEvent=new a,this._pongReceivedEvent=new ke,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(Ct.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._onVisibility=()=>{"visible"===document.visibilityState&&(this._log.Debug(Ct.ServiceName,"Page visible → connection check"),this.validateConnectionToController().then((e=>{e||(this._log.Debug(Ct.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())})))},this._onHidden=()=>{},this._onVisible=()=>{this.validateConnectionToController().then((e=>{e||(this._log.Debug(Ct.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))}}GetServiceName(){return Ct.ServiceName}GetAuthorizationInfo(){return this._serialId&&this._PIN?new Te(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 wt(this,void 0,void 0,(function*(){if(!this._serialId)return this._log.Warning(Ct.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(Ct.ServiceName,`Broker address resolved: ${e}`),e):(this._log.Warning(Ct.ServiceName,"Broker returned empty address"),null)}case 204:return this._allBrokersChecked?(this._log.Error(Ct.ServiceName,"All brokers checkt but controller not found! Controller probably offline!"),null):(this._log.Warning(Ct.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(Ct.ServiceName,`GetServerAddressAsync() – HTTP ${t.status}`),null}}catch(e){return this._log.Error(Ct.ServiceName,String(e)),null}}))}rotateServersBroker(){return wt(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(Ct.ServiceName,`Switching servers‑broker to: ${this._serversBrokerAddress}`)}))}ConnectAsync(e){return wt(this,void 0,void 0,(function*(){return this._address=e,this.serialisedConnect()}))}ConnectAndAuthorizeAsync(e){return wt(this,void 0,void 0,(function*(){this._serialId=e.serialNumber,this._PIN=e.pin,ry.WorksInContextOf=this._serialId;let t=yield this.GetServerAddressAsync();if(t&&(this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e))))return he.Connected;for(const t of this._packetsBrokerServers)if(this._log.Info(Ct.ServiceName,`Fallback broker: ${t}`),this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e)))return he.Connected;return he.FailedToConnect}))}AuthorizeAsync(e){return wt(this,void 0,void 0,(function*(){return new Promise((t=>wt(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(Ct.ServiceName,`Authorization → ${e}`),e&&this._connectionStateChangedEvent.Invoke(pe.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 wt(this,void 0,void 0,(function*(){var e;this._disconnectedOnPurpose=!0,this._log.Debug(Ct.ServiceName,"Disconnecting..."),yield null===(e=this._connection)||void 0===e?void 0:e.stop(),this.cleanup()}))}SendAsync(e){return wt(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(Ct.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(Ct.ServiceName,String(e)),!1}}))}SendAndWaitForResponseAsync(e,t,n){return wt(this,arguments,void 0,(function*(e,t,n,r=!0){var o,s,i;if(e.Method===le.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)=>wt(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===le.Get&&n&&(null===(c=this._cache)||void 0===c||c.Cache(s)),n||s.Status!==ue.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 wt(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)=>wt(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 ue.MultiDataResponseStart:case ue.MultiDataResponse:n(t),a=i();break;case ue.MultiDataResponseStop:case ue.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 wt(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)=>wt(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 De(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 wt(this,void 0,void 0,(function*(){if(!this.IsConnected())return!1;if(Date.now()-this._lastReceivedPacket<Ct.PING_INTERVAL_MS)return!1;const e=new ce;e.Resource="/system/ping",e.Method=le.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 wt(this,void 0,void 0,(function*(){var n,o,i,a,c;if(!this._address)return he.ControllerIsNotConnected;if((null===(n=this._connection)||void 0===n?void 0:n.state)===s.Reconnecting){this._log.Info(Ct.ServiceName,"Connection is already in reconnecting state - letting automatic reconnect handle it");try{return yield this.waitForReconnection(),this._log.Info(Ct.ServiceName,"Automatic reconnect successful"),he.Connected}catch(e){this._log.Warning(Ct.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(Ct.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 At){var u=(new re).withAutomaticReconnect(new St).configureLogging(new _t).withStatefulReconnect({bufferSize:256e3}).withServerTimeout(Ct.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(pe.Connected),he.Connected}catch(e){this._log.Warning(Ct.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(pe.Failed),he.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===pe.Connected?(r&&clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(o),t()):e!==pe.Disconnected&&e!==pe.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=ry.Get(at.ServiceName),this._cache=ry.Get(Be.ServiceName),this._session=ry.Get(Xe.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 Te(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(Ct.ServiceName,`Received: ${JSON.stringify(JSON.parse(t),null,2)}`),this._dataReceivedEvent.Invoke(JSON.parse(t))})),this._connection.onclose((()=>{this.cleanup(),this._connectionStateChangedEvent.Invoke(pe.Disconnected)})),this._connection.onreconnecting((()=>this._connectionStateChangedEvent.Invoke(pe.Reconnecting))),this._connection.onreconnected((()=>this._connectionStateChangedEvent.Invoke(pe.Connected))))}startPingLoop(){null!==this._pingTimerId&&clearInterval(this._pingTimerId),this._pingTimerId=window.setInterval((()=>{this.pingOnce()}),Ct.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 wt(this,void 0,void 0,(function*(){this.IsConnected()&&(Date.now()-this._lastReceivedPacket<Ct.PING_INTERVAL_MS||((yield this.PingControllerAsync())?this._consecutivePingFailures=0:++this._consecutivePingFailures>=Ct.MAX_CONSECUTIVE_PING_FAILURES&&(this._consecutivePingFailures=0,this._log.Warning(Ct.ServiceName,"Ping failed too many times → reconnecting..."),Ct.SERVER_TIMOUT_MS<Ct.PING_INTERVAL_MS*Ct.MAX_CONSECUTIVE_PING_FAILURES&&this._log.Error("Server timeout is shorter than ping interval! SignalR automatic reconnect will not work!."),this.serialisedConnect())))}))}validateConnectionToController(){return wt(this,void 0,void 0,(function*(){var e;if(!this.IsConnected())return this._log.Warning(Ct.ServiceName,"Connection was lost."),!1;{const n=new ce;n.Resource="/system/ping",n.Method=le.Get;try{var t=yield this.SendAndWaitForResponseAsync(n,Ct.SERVER_TIMOUT_MS+1e3,!1,!1);return(null==t?void 0:t.Status)!==ue.OK?(this._log.Warning(Ct.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(Ct.ServiceName,"Connection check failed, but connection is in reconnecting state!"),!1):(this._log.Info(Ct.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 Tt,Dt,kt,Et,It,bt,Gt,Nt,Rt,Pt,Ut,Ot,Mt,xt,Ft,Lt;Ct.PING_INTERVAL_MS=5e3,Ct.MAX_CONSECUTIVE_PING_FAILURES=6,Ct.SERVER_TIMOUT_MS=1e4,Ct.SignalRLogLevel=r.Warning,Ct.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(Tt||(Tt={})),(Ot=Dt||(Dt={}))[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"}(kt||(kt={}));class Bt{constructor(){this._type=It.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Mt=Et||(Et={}))[Mt.Unknown=0]="Unknown",Mt[Mt.BlindMotor=1]="BlindMotor",Mt[Mt.DinModule=2]="DinModule",Mt[Mt.DinModuleWithAntenna=3]="DinModuleWithAntenna",Mt[Mt.Remote=4]="Remote",Mt[Mt.RemoteForBlinds=5]="RemoteForBlinds",Mt[Mt.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",Mt[Mt.MovementSensor=7]="MovementSensor",Mt[Mt.TemperatureSensor=8]="TemperatureSensor",Mt[Mt.HumiditySensor=9]="HumiditySensor",Mt[Mt.DinPowerMeter=10]="DinPowerMeter",Mt[Mt.Intercom=11]="Intercom",Mt[Mt.SecurityCamera=12]="SecurityCamera",Mt[Mt.Multisensor=13]="Multisensor",Mt[Mt.FloodSensor=14]="FloodSensor",Mt[Mt.FlushMountedReceiver=15]="FlushMountedReceiver",Mt[Mt.FlushMountedBlindController=16]="FlushMountedBlindController",Mt[Mt.FlushMountedDimmer=17]="FlushMountedDimmer",Mt[Mt.FlushMountedRelay=18]="FlushMountedRelay",Mt[Mt.FlushMountedGateController=19]="FlushMountedGateController",Mt[Mt.WindSensor=20]="WindSensor",Mt[Mt.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",Mt[Mt.AirPressureSensor=22]="AirPressureSensor",Mt[Mt.LightBrightnessSensor=23]="LightBrightnessSensor",Mt[Mt.ReedSensor=24]="ReedSensor",Mt[Mt.FlushMountedTransceiver=25]="FlushMountedTransceiver",Mt[Mt.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",Mt[Mt.WallMountedThermoregulator=27]="WallMountedThermoregulator",Mt[Mt.ImpulseCounter=28]="ImpulseCounter",Mt[Mt.FlushMountedFacadeController=29]="FlushMountedFacadeController",Mt[Mt.WallMountedGateController=30]="WallMountedGateController",Mt[Mt.WallMountedRGBLightController=31]="WallMountedRGBLightController",Mt[Mt.WallMountedDimmer=32]="WallMountedDimmer",Mt[Mt.WallMountedRemote=33]="WallMountedRemote",Mt[Mt.DinRelay=34]="DinRelay",Mt[Mt.DinReceiver=35]="DinReceiver",Mt[Mt.DinBlindController=36]="DinBlindController",Mt[Mt.DinTransceiver=37]="DinTransceiver",Mt[Mt.SocketPlugIn=38]="SocketPlugIn",Mt[Mt.WallMountedRelay=39]="WallMountedRelay",Mt[Mt.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"}(It||(It={}));class Wt{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={})),(Lt=Gt||(Gt={}))[Lt.NotResponding=0]="NotResponding",Lt[Lt.Working=1]="Working",Lt[Lt.Broken=2]="Broken",Lt[Lt.FirmareUpgradeMode=3]="FirmareUpgradeMode",(Ft=Nt||(Nt={}))[Ft.TwoWay=1]="TwoWay",Ft[Ft.OneWay=2]="OneWay",Ft[Ft.ConditionalTwoWay=3]="ConditionalTwoWay",(xt=Rt||(Rt={}))[xt.Unknown=-1]="Unknown",xt[xt.Multipurpose=0]="Multipurpose",xt[xt.Controller=1]="Controller",xt[xt.Driver=2]="Driver",xt[xt.Receiver=3]="Receiver",xt[xt.Remote=4]="Remote",xt[xt.Sensor=5]="Sensor",xt[xt.Scene=6]="Scene";class $t{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=Tt.NoTasksExecuting}}!function(e){e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed",e[e.ResponseTimeout=2]="ResponseTimeout",e[e.TaskRepeatedAndExecuted=3]="TaskRepeatedAndExecuted",e[e.TaskRepeatedResponseTimeout=4]="TaskRepeatedResponseTimeout",e[e.FlowControlNotAvailable=5]="FlowControlNotAvailable",e[e.ExecutionError=6]="ExecutionError"}(Pt||(Pt={})),function(e){e[e.ControllerResponseTimeout=-4]="ControllerResponseTimeout",e[e.DeviceNotFound=-3]="DeviceNotFound",e[e.DeviceResponseTimeout=-2]="DeviceResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed"}(Ut||(Ut={}));class Vt{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=Ut.Unknown}}var qt,Ht,Kt,jt,zt,Jt,Xt,Yt,Qt,Zt,en,tn,nn,rn,on,sn,an,cn,un,ln,dn,hn,pn,gn,fn,vn,yn,mn,wn,Sn,An;class _n{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}}(An=qt||(qt={}))[An.Confident=0]="Confident",An[An.Unconfident=1]="Unconfident";class Cn extends _n{constructor(e){super(),this.TypeAsEnum=bt.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class Tn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Ht.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Ht||(Ht={}));class Dn extends _n{constructor(e){super(),this.TypeAsEnum=bt.HallState,this.Type="IHallState",this.Data=e.state}}class kn extends _n{constructor(e){super(),this.TypeAsEnum=bt.SceneExecuted,this.Type="ISceneExecuted",this.Data=e.state}}class En extends _n{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"}(Kt||(Kt={}));class In extends _n{constructor(e){super(),this.TypeAsEnum=bt.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class bn extends _n{constructor(e){super(),this.TypeAsEnum=bt.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class Gn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=jt.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(jt||(jt={}));class Nn extends _n{constructor(e){super(),this.TypeAsEnum=bt.ReedState,this.Type="ReedState",this.Data=e.state}}class Rn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=!1,this.Time=""}}class Pn extends _n{constructor(e){super(),this.TypeAsEnum=bt.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return zt.UnableToMove;case 201:return zt.MotorOverheatedPleaseWait;default:return zt.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(zt||(zt={}));class Un{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class On extends _n{constructor(e){super(),this.TypeAsEnum=bt.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class Mn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Jt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(Jt||(Jt={}));class xn extends _n{constructor(e){super(),this.TypeAsEnum=bt.LightColor,this.Type="LightColorState",this.Data=e.state}}class Fn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class Ln extends _n{constructor(e){super(),this.TypeAsEnum=bt.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class Bn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Temperature=0,this.Time=""}}class Wn extends _n{constructor(e){super(),this.TypeAsEnum=bt.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class $n{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class Vn extends _n{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=Xt.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"}(Xt||(Xt={}));class Hn extends _n{constructor(e){super(),this.TypeAsEnum=bt.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Kn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=Yt.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"}(Yt||(Yt={}));class jn extends _n{constructor(e){super(),this.TypeAsEnum=bt.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class zn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Brightness=0,this.Time=""}}class Jn extends _n{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 Xn{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"}(Qt||(Qt={}));class Yn extends _n{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"}(Zt||(Zt={}));class Qn extends _n{constructor(e){super(),this.TypeAsEnum=bt.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Zn{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Intensity=0,this.Movement=en.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(en||(en={}));class er extends _n{constructor(e){super(),this.TypeAsEnum=bt.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class tr{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 nr extends _n{constructor(e){super(),this.TypeAsEnum=bt.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class rr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=nn.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"}(nn||(nn={}));class or extends _n{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"}(rn||(rn={}));class sr extends _n{constructor(e){super(),this.TypeAsEnum=bt.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class ir{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.PositionType=on.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"}(on||(on={}));class ar extends _n{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"}(sn||(sn={}));class cr extends _n{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"}(an||(an={}));class ur extends _n{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"}(cn||(cn={}));class lr extends _n{constructor(e){super(),this.TypeAsEnum=bt.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class dr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Type=un.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"}(un||(un={}));class hr extends _n{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"}(ln||(ln={}));class pr extends _n{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=dn.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(dn||(dn={}));class fr extends _n{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"}(hn||(hn={}));class vr extends _n{constructor(e){super(),this.TypeAsEnum=bt.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class yr extends _n{constructor(e){super(),this.TypeAsEnum=bt.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class mr extends _n{constructor(e){super(),this.TypeAsEnum=bt.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class wr extends _n{constructor(e){super(),this.TypeAsEnum=bt.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class Sr extends _n{constructor(e){super(),this.TypeAsEnum=bt.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Ar extends _n{constructor(e){super(),this.TypeAsEnum=bt.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class _r{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.WindThreshold=pn.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"}(pn||(pn={}));class Cr extends _n{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 Tr extends _n{constructor(e){super(),this.TypeAsEnum=bt.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class Dr{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.Value=0,this.Time=""}}class kr extends _n{constructor(e){super(),this.TypeAsEnum=bt.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class Er{constructor(){this.Channel=0,this.StateReliability=qt.Unconfident,this.State=fn.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(fn||(fn={})),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"}(vn||(vn={}));class Ir extends _n{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=yn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(yn||(yn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(mn||(mn={}));class Gr extends _n{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"}(wn||(wn={}));class Nr extends _n{constructor(e){super(),this.TypeAsEnum=bt.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Rr extends _n{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"}(Sn||(Sn={}));class Pr{constructor(){this._onDeviceStateChangedEvent=new a,this._onDeviceStateRefreshedOrChangedEvent=new a,this._onDeviceTasksExecutionChangedOnChannelsEvent=new a,this._onDeviceFirmwareVersionChangedEvent=new a,this._iconType=Et.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=Gt.Working,this._deviceType=Rt.Unknown,this._communicationWay=Nt.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==Pr._devicesService&&(Pr._devicesService=ry.Get(zs.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Pr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Pr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),Pr._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===Rt.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!==It.SetBlindPositionSimple))}return!1}get States(){return c.DoesThrowStackTrace?ry.Get(zs.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Pr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Pr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Pr._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 ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new Ur(this,e),2e4,!1);switch(n.Status){case ue.OK:return this._name=e,null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeDeviceNameAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),new Ee(we.Changed,"");case ue.WrongData:if("DeviceNotFound"==n.Data)return new Ee(we.Failed,"DeviceNotFound");break;case ue.NoPermissionsToCallGivenResource:return new Ee(we.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new Ee(we.ControllerResponseTimeout,""):new Ee(we.UnknownError,"")}return new Ee(we.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 Pr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class Ur extends ce{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=le.Put;const n=new Or;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class Or{constructor(){this.DeviceGuid="",this.Name=""}}var Mr,xr,Fr,Lr,Br,Wr=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 $r{constructor(){this._device=new Pr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=Dt.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==$r._devicesService&&($r._devicesService=ry.Get(zs.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 Wr(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new Vr;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 Vr;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 Vr;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 Vr;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Vr;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 Vr;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 Vr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){return Wr(this,void 0,void 0,(function*(){var t,n;try{const r=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new Hr(e),2e4,!1);switch(null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeConfigurationAsync()"),yield ry.Get(at.ServiceName).ExitConfigurationModeAsync(),r.Status){case ue.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 Ee(we.Changed,"");case ue.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 Ee(we.WrongData,"DeviceNotFound");break;case ue.FatalError:return new Ee(we.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new Ee(we.ControllerResponseTimeout,"")}return new Ee(we.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?ry.Get(zs.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():$r._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,$r._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(Ut.Failed)}}$r._devicesService=null;class Vr{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new qr}}class qr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=Dt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class Hr extends ce{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=le.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"}(Mr||(Mr={}));class Kr{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 jr{constructor(){this._taskType=It.GetChannelsState,this._featureType=Mr.GetState,this._channel=0,this._guid=Kr.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 zr extends jr{constructor(){super(),this.Temperature=0,this.FeatureType=Mr.SetTemperature,this.TaskType=It.SetTemperature}}class Jr extends jr{constructor(){super(),this.FeatureType=Mr.TurnOff,this.TaskType=It.TurnOff}}class Xr extends jr{constructor(){super(),this.FeatureType=Mr.TurnOn,this.TaskType=It.TurnOn}}class Yr extends jr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=Mr.TurnOnWithTimeout,this.TaskType=It.TurnOnWithTime}}class Qr extends jr{constructor(){super(),this.Brightness=0,this.FeatureType=Mr.SetLightBrightness,this.TaskType=It.SetLightBrightness}}class Zr extends jr{constructor(){super(),this.FeatureType=Mr.ToggleState,this.TaskType=It.TogleState}}class eo extends jr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=Mr.SetLightColor,this.TaskType=It.SetLightColor}}class to extends jr{constructor(){super(),this.Temperature=0,this.FeatureType=Mr.SetLightTemperature,this.TaskType=It.SetLightTemperature}}class no extends jr{constructor(){super(),this.Action=xr.Stop,this.Position=0,this.FeatureType=Mr.SetBlindPosition,this.TaskType=It.SetBlindPosition}}!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 jr{constructor(){super(),this.GateControlAction=Fr.Stop,this.Position=0,this.FeatureType=Mr.SetGatePositionPrecise,this.TaskType=It.PreciseGateControl}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Fr||(Fr={}));class oo extends jr{constructor(){super(),this.Action=Lr.Stop,this.Position=0,this.FeatureType=Mr.SetBlindPosition,this.TaskType=It.SetBlindPositionSimple}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Lr||(Lr={}));class so extends jr{constructor(){super(),this.Brightness=0,this.FeatureType=Mr.SetLightBrightnessDynamicly,this.TaskType=It.SetLightBrightnessDynamicly}}class io extends jr{constructor(){super(),this.FeatureType=Mr.IdentifyDevice,this.TaskType=It.IdentifyDevice}}class ao extends jr{constructor(){super(),this.Data=new co,this.FeatureType=Mr.SetBlindOpenCloseTime,this.TaskType=It.SetBlindOpenCloseTime}}class co{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class uo extends jr{constructor(){super(),this.FeatureType=Mr.GetState,this.TaskType=It.GetChannelsState}}class lo extends jr{constructor(){super(),this.Position=0,this.FeatureType=Mr.SetBlindMicroventilation,this.TaskType=It.SetBlindMicroventilation}}class ho extends jr{constructor(){super(),this.FeatureType=Mr.GatePulse,this.TaskType=It.ChangeGatewayPositionPulse}}class po extends jr{constructor(){super(),this.FeatureType=Mr.GatewayPulse,this.TaskType=It.ChangeGatewayPositionPulse}}class go extends jr{constructor(){super(),this.FacadeAction=Br.Stop,this.Tilt=0,this.Position=0,this.FeatureType=Mr.SetFacadePositionAndTilt,this.TaskType=It.SetFacadePosition}}class fo extends jr{constructor(){super(),this.FeatureType=Mr.GetFacadeType,this.TaskType=It.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"}(Br||(Br={}));class vo{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class yo extends jr{constructor(){super(),this.Data=new vo,this.FeatureType=Mr.LightRGBW,this.TaskType=It.LightRGBW}}var mo=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 wo{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return wo.ServiceName}RegisterManuallyPairedDevicesProtocol(e){var t;null===(t=u.Log)||void 0===t||t.Debug(wo.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return mo(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 mo(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(wo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDeviceAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),Ut.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}wo.ServiceName="ManualDeviceService";class So{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var Ao,_o=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 Co{constructor(){this._connection=null,this._localDb=null,this._connection=ry.Get(Ct.ServiceName),this._localDb=ry.Get(l.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return _o(this,void 0,void 0,(function*(){let r=new To(e,t,n),o=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(o.Status===ue.OK){const r=new Eo;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(Co.ServiceName,this.GetLocalDbName(e,t),r)}return o.Status}))}ReadAsync(e,t,n){return _o(this,void 0,void 0,(function*(){let r=new Do(e,t);if(!n){const n=this._localDb.Read(Co.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new So;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===ue.OK){const e=new So;return e.ResourceGuid=o.ResourceGuid,e.Data=JSON.parse(o.Data),e.IsGlobal=o.IsGlobal,e}return o.Status}))}RemoveAsync(e,t){return _o(this,void 0,void 0,(function*(){let n=new ko(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return Co.ServiceName}}Co.ServiceName="RemoteStorageService";class To extends ce{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class Do extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Get,this.ResourceGuid=e,this.Global=t}}class ko extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Delete,this.ResourceGuid=e,this.Global=t}}class Eo extends ce{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class Io{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"}(Ao||(Ao={}));var Go,No,Ro=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 Po{IsControllerGeolocationSetAsync(){return Ro(this,void 0,void 0,(function*(){let e=new Uo,t=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ue.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return Ro(this,void 0,void 0,(function*(){return new Promise(((e,t)=>Ro(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){return Ro(this,void 0,void 0,(function*(){var t,n,r;let o=new Mo;o.Data.Latitude=e.Latitude,o.Data.Longitude=e.Longitude,null===(t=u.Log)||void 0===t||t.Warning(Po.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(o)}`);let s=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(o,15e3,!1);switch(null===(n=u.Log)||void 0===n||n.Warning(Po.ServiceName,`${JSON.stringify(s)}`),null===(r=u.Log)||void 0===r||r.Error(Po.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetControllerGeolocationAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),null==s?void 0:s.Status){case ue.OK:return new Ie(Ao.OK,"");case ue.NoPermissionToPerformThisOperation:case ue.NoPermissionsToCallGivenResource:return new Ie(Ao.NoPermissions,"");case ue.UserIsNotLoggedIn:return new Ie(Ao.UserIsNotLoggedIn,"");default:return new Ie(Ao.UnknownError,"")}}))}GetControlllerGeolocationAsync(){return Ro(this,void 0,void 0,(function*(){var e,t;let n=new Oo;null===(e=u.Log)||void 0===e||e.Warning(Po.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=u.Log)||void 0===t||t.Warning(Po.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ue.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 Po.ServiceName}}Po.ServiceName="GeolocationService";class Uo extends ce{constructor(){super(),this.Resource="/geolocation/isset",this.Method=le.Get}}class Oo extends ce{constructor(){super(),this.Resource="/geolocation/get",this.Method=le.Get}}class Mo extends ce{constructor(){super(),this.Data=new Io,this.Resource="/geolocation/save",this.Method=le.Put}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Go||(Go={}));class xo{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=No.Unknown,this.ResourceGuid=""}}class Fo{constructor(){this.UpdateDescription=new Map,this.Update=new xo,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"}(No||(No={}));class Lo extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var Bo,Wo,$o,Vo,qo,Ho,Ko,jo,zo,Jo,Xo,Yo,Qo,Zo,es,ts,ns,rs,os=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 ss{constructor(){this._services=new Map,this._runtimeInfo=new is,this._hardwareInfo=new cs,this._semaphore=new et(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return ss.ServiceName}RegisterUpdatesProvider(e){var t;null===(t=u.Log)||void 0===t||t.Debug(ss.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return os(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(ss.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const n=this._services.get(e);if(null==n)throw new Lo("Cannot get update provider! Requested update provider has not been registered.");return n}))}GetUpdatesProvidersAsync(e){return os(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(ss.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 Lo("Cannot get update providers! Requested update providers has not been registered.");return n}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return os(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(ss.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 Lo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Lo("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return os(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(ss.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 Lo("Cannot get update providers! Requested update providers has not been registered.");return o}throw new Lo("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(){return os(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 os(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(ss.ServiceName,"Getting runtime version info from controller.");try{const e=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new as,16e3,!1);if(null==e||null==e.Status)throw new ls('Cannot get runtime info, controller response result is empty."',Bo.EmptyResponse);if(e.Status!=ue.OK)throw new ls(`Cannot get runtime info, controller responded with status ${e.Status}.`,Bo.WrongResponseStatus);if(null==e.Data)throw new ls("Cannot get runtime info, controller responded with status OK but response does not contains data.",Bo.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof E?new ls("Cannot get runtime info, controller response timeout.",Bo.Timeout):e}}))}GetHardwareInfoAsync(){return os(this,arguments,void 0,(function*(e=!1){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return os(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(ss.ServiceName,"Getting hardware info from controller.");const t=yield ry.Get(Ct.ServiceName).SendAndWaitForResponseAsync(new us,8e3,!1);if(null==t||null==t.Status)throw new ls('Cannot get hardware info, controller response result is empty."',Bo.EmptyResponse);if(t.Status!=ue.OK)throw new ls(`Cannot get hardware info, controller responded with status ${t.Status}.`,Bo.WrongResponseStatus);if(null==t.Data)throw new ls("Cannot get hardware info, controller responded with status OK but response does not contains data.",Bo.NoDataInResponse);this._hardwareInfo=t.Data,this._isRuntimeInfoInitialized=!0}))}}ss.ServiceName="UpdateProvider";class is{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class as extends ce{constructor(){super(),this.Resource="/controller/software/info",this.Method=le.Get}}class cs{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class us extends ce{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=le.Get}}class ls 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"}(Bo||(Bo={})),function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(Wo||(Wo={}));class ds{constructor(){this._comparisonParams=new Map,this.Type=bt.Unknown,this.DeviceGuid="",this.ComparisonMethod=$o.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Kn&&(this.Type=bt.BatteryState),e instanceof gr&&(this.Type=bt.BinarySensorState),e instanceof Un&&(this.Type=bt.BlindPosition),e instanceof $n&&(this.Type=bt.LightBrightness),e instanceof zn&&(this.Type=bt.MeasuredBrightness),e instanceof Mn&&(this.Type=bt.RemoteButtonState),e instanceof Tn&&(this.Type=bt.ChannelOnOffState),e instanceof Gn&&(this.Type=bt.DoorBellState),e instanceof Xn&&(this.Type=bt.MeasuredEnergy),e instanceof Er&&(this.Type=bt.FloodSensorState),e instanceof ir&&(this.Type=bt.GatePosition),e instanceof Fn&&(this.Type=bt.LightColor),e instanceof Bn&&(this.Type=bt.LightWarmth),e instanceof Rn&&(this.Type=bt.ReedState),e instanceof qn&&(this.Type=bt.MeasuredTemperature),e instanceof dr&&(this.Type=bt.HumiditySensorState),e instanceof tr&&(this.Type=bt.BlindRemoteButtonState),e instanceof rr&&(this.Type=bt.FacadeRemoteButtonState),e instanceof Zn&&(this.Type=bt.MovementSensorState),e instanceof Xn&&(this.Type=bt.MeasuredEnergy),e instanceof br&&(this.Type=bt.PressureSensorState),e instanceof Dr&&(this.Type=bt.WindSpeedState),e instanceof _r&&(this.Type=bt.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class hs{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class ps{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"}($o||($o={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(Vo||(Vo={})),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"}(Ho||(Ho={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(Ko||(Ko={})),(rs=jo||(jo={}))[rs.Unknown=0]="Unknown",rs[rs.Second=1]="Second",rs[rs.Minute=2]="Minute",rs[rs.Hour=3]="Hour",rs[rs.Day=4]="Day",rs[rs.DayOfWeek=5]="DayOfWeek",rs[rs.Month=6]="Month",rs[rs.Year=7]="Year",rs[rs.Date=8]="Date",rs[rs.Time=9]="Time",rs[rs.WeatherType=11]="WeatherType",rs[rs.CompareNumbers=12]="CompareNumbers",rs[rs.CompareBooleans=13]="CompareBooleans",rs[rs.DeviceState=14]="DeviceState",rs[rs.Timer=15]="Timer",rs[rs.Temperature=17]="Temperature",rs[rs.DaysOfWeek=18]="DaysOfWeek",rs[rs.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",rs[rs.SceneExecuted=20]="SceneExecuted",(ns=zo||(zo={}))[ns.Unknown=0]="Unknown",ns[ns.Equal=1]="Equal",ns[ns.NotEqueal=2]="NotEqueal",ns[ns.BiggerThan=3]="BiggerThan",ns[ns.SmallerThan=4]="SmallerThan",ns[ns.BiggerThanOrEqual=5]="BiggerThanOrEqual",ns[ns.SmallerThanOrEqual=6]="SmallerThanOrEqual",ns[ns.OneOfBothIsTrue=7]="OneOfBothIsTrue",ns[ns.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"}(Jo||(Jo={})),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"}(Xo||(Xo={})),(ts=Yo||(Yo={})).Null="Null",ts.Condition="Condition",ts.ConditionGroup="ConditionGroup",ts.ArgumentAsInt="ArgumentAsInt",ts.ArgumentAsTimeSpan="ArgumentAsTimeSpan",ts.ArgumentAsBoolean="ArgumentAsBoolean",ts.ArgumentAsTimeout="ArgumentAsTimeout",ts.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",ts.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",ts.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",ts.ArgumentAsTime="ArgumentAsTime",ts.ArgumentAsDeviceState="ArgumentAsDeviceState",ts.ArgumentAsNumber="ArgumentAsNumber",ts.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",ts.ArgumentAsConditionInfo="ArgumentAsConditionInfo",function(e){e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.LockExecutionTask="LockExecutionTask",e.NotifyTaskAppNotify="NotifyTaskAppNotify",e.NotifyTaskEmailNotify="NotifyTaskEmailNotify"}(Qo||(Qo={}));class fs 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"}(Zo||(Zo={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(es||(es={}));var vs,ys,ms;class ws{constructor(e,t="Cube"){this._result=null,this._tmp=new Ss,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=ry.Get(Ms.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Kr.NewGuid())}SetSequenceName(e){const t=n=>{if(n.RightArgumentType!=ms.Null)return t(n.RightArgument);n.Tasks.ControllerTasks.where((e=>e.TaskType==Ho.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==ms.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 ws;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=Kr.NewGuid(),e.RightArgumentType==ms.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Kr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==ms.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!=ms.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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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=Kr.NewGuid(),this._tmp.HandledType=jo.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=ms.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=zo.Equal)throw new Gs("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new Gs("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=zo.Equal;else{if(null==n)throw new Gs("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.Unknown,this._tmp.LeftArgumentType=ms.Null,this._tmp.ConditionType=zo.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=ms.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=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.DaysOfWeek,this._tmp.LeftArgumentType=ms.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.Timer,this._tmp.LeftArgumentType=ms.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.Time,this._tmp.LeftArgumentType=ms.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=ms.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=zo.Equal){return this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.DeviceState,this._tmp.LeftArgumentType=ms.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=ms.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Kr.NewGuid(),this._tmp.HandledType=jo.SceneExecuted,this._tmp.LeftArgumentType=ms.ArgumentAsConditionInfo,this._tmp.ConditionType=zo.Equal,this._tmp.AtMeetCondition=!0;const t=new gs;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=ms.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new Cs;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),{[Vo[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),{[Qt[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 fs("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 fs("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case bt.BatteryState:return Jo.BatteryState;case bt.BinarySensorState:return Jo.BinarySensor;case bt.BlindPosition:return Jo.BlindPosition;case bt.LightBrightness:return Jo.LightBrightness;case bt.RemoteButtonState:return Jo.ButtonState;case bt.ChannelOnOffState:return Jo.ChannelOnOff;case bt.DoorBellState:return Jo.DoorBell;case bt.MeasuredEnergy:return Jo.Energy;case bt.FloodSensorState:return Jo.FloodSensor;case bt.GatePosition:return Jo.GatePosition;case bt.MeasuredBrightness:return Jo.Brightness;case bt.LightColor:return Jo.LightColor;case bt.LightWarmth:return Jo.LightTemperature;case bt.ReedState:return Jo.ReedState;case bt.SmokeSensorState:return Jo.SmokeSensor;case bt.MeasuredTemperature:return Jo.Temperature;case bt.HumiditySensorState:return Jo.Humidity;case bt.BlindRemoteButtonState:return Jo.BlindsControlButton;case bt.FacadeRemoteButtonState:return Jo.FacadeControlButton;case bt.MovementSensorState:return Jo.Movement;case bt.PressureSensorState:return Jo.AirPressure;case bt.WindSpeedState:return Jo.WindSpeed;case bt.CurrentWindThreshold:return Jo.WindThreshold;default:return Jo.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=ms.Null)return e(t.RightArgument,n);t.RightArgumentType=ms.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Ts)};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 Ss,{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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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!=ms.Condition){if(n.RightArgumentType==ms.Condition)return t(n.RightArgument,r);throw new Ns(`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 Ns(`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 Ss,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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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==ms.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==ms.Null)throw new Ns(`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 Ns("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=ms.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=zo.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=zo.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!=ms.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new Ns("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 ks;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==It.SetBlindPosition||e instanceof no?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==It.SetBlindPositionSimple||e instanceof oo?(t.Data.Action=e.Action,t.Data.Position=0):e.TaskType==It.SetLightColor||e instanceof eo?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==It.SetLightTemperature||e instanceof to?t.Data.Temperature=e.Temperature:e.TaskType==It.SetLightBrightness||e instanceof Qr?t.Data.Brightness=e.Brightness:e.TaskType==It.SetTemperature||e instanceof zr?t.Data.Temperature=e.Temperature:e.TaskType==It.TurnOnWithTime||e instanceof Yr?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==It.SetLightBrightnessDynamicly||e instanceof so?t.Data.Brightness=e.Brightness:e.TaskType==It.SetBlindOpenCloseTime||e instanceof ao?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==It.SetBlindMicroventilation||e instanceof lo?t.Data.Position=e.Position:e.TaskType==It.SetFacadePosition||e instanceof go?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):e.TaskType==It.LightRGBW||e instanceof yo?(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==It.PreciseGateControl||e instanceof ro)&&(t.Data.Position=e.Position,t.Data.GateControlAction=e.GateControlAction),t}DelayTask(e){const t=new Es;if("00:00:00"==e.Delay.Value)throw new Gs("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==Zo.Email)throw new Ps("NotifyType 'Email' is not supported!");if(e.NotifyType==Zo.None)throw new Error("NotifyType mus be set!");if(""==e.Message)throw new Gs("Message must be set!");if(e.Message.length>1e3)throw new Gs("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 Is;if(t.LockType=e.LockType,t.LockType==es.Timeout&&"00:00:00"!=t.LockEndHour)throw new Ps("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!=ms.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 ks&&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!=ms.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 Rs("Task not found, cannot edit!");this._tmpTask instanceof ks&&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!=ms.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 It.Unknown:throw new Gs("Unsupported task type!");case It.SetBlindPosition:case It.SetBlindPositionSimple:return Mr.SetBlindPosition;case It.SetBlindMicroventilation:return Mr.SetBlindMicroventilation;case It.TurnOff:return Mr.TurnOff;case It.TurnOn:return Mr.TurnOn;case It.TurnOnWithTime:return Mr.TurnOnWithTimeout;case It.TogleState:return Mr.ToggleState;case It.SetLightBrightnessDynamicly:return Mr.SetLightBrightnessDynamicly;case It.SetLightBrightness:return Mr.SetLightBrightness;case It.SetLightColor:return Mr.SetLightColor;case It.SetLightTemperature:return Mr.SetLightTemperature;case It.PairDevice:case It.UnpairDevice:throw new Gs("Unsupported task type!");case It.IdentifyDevice:return Mr.IdentifyDevice;case It.GetChannelsState:return Mr.GetState;case It.GetPowerMeasurements:case It.GetAvailableData:case It.MultipleDataRequest:throw new Gs("Unsupported task type!");case It.SetBlindOpenCloseTime:return Mr.SetBlindOpenCloseTime;case It.SetTemperature:return Mr.SetTemperature;case It.ChangeGatePositionPulse:return Mr.GatePulse;case It.ChangeGatewayPositionPulse:return Mr.GatewayPulse;case It.SetFacadePosition:case It.GetFacadeType:return Mr.SetFacadePositionAndTilt;case It.LightRGBW:return Mr.LightRGBW;case It.PreciseGateControl:return Mr.SetGatePositionPrecise;default:throw new Gs("Unsupported task type!")}}GetSupportedTaskTypesAsync(){return e=this,t=void 0,r=function*(){const e=yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Qo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Qo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Qo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Qo.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!=ms.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==ms.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}GetAllowedArguments(){const e=[];return null==this._result?(e.push({ArgumentType:ys.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:ys.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1})):null!=this._result&&(null==this._result.RightArgument||this._result.RightArgument instanceof As)&&(this._result.LeftArgumentType==ms.ArgumentAsDaysOfWeek&&(e.push({ArgumentType:ys.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),e.push({ArgumentType:ys.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0})),this._result.LeftArgumentType==ms.ArgumentAsTime&&e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1}),this._result.LeftArgumentType==ms.ArgumentAsAstronomicalClockWithOffset&&e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1})),0==e.any((e=>e.ArgumentType==ys.ArgumentAsAstronomicalClockWithOffset))&&e.push({ArgumentType:ys.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsDaysOfWeek))&&e.push({ArgumentType:ys.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsDeviceState))&&e.push({ArgumentType:ys.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsSceneExecuted))&&e.push({ArgumentType:ys.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsTime))&&e.push({ArgumentType:ys.ArgumentAsTime,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==ys.ArgumentAsTimeSpan))&&e.push({ArgumentType:ys.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==ms.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,ms.ArgumentAsDaysOfWeek,!0);null!=i&&((null===(e=i.RightArgument)||void 0===e?void 0:e.LeftArgumentType)==ms.ArgumentAsTime||(null===(t=i.RightArgument)||void 0===t?void 0:t.LeftArgumentType)==ms.ArgumentAsAstronomicalClockWithOffset)&&o.push(vs.OptimizeDayOfWeekArgument);const a=s(this._result,ms.ArgumentAsTime,!0);return null!=a&&(null===(n=a.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ms.ArgumentAsDaysOfWeek&&(null===(r=a.RightArgument)||void 0===r?void 0:r.AtMeetCondition)&&o.push(vs.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(vs.OptimizeDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ms.ArgumentAsDaysOfWeek?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ms.ArgumentAsTime||(null===(r=t.RightArgument)||void 0===r?void 0:r.LeftArgumentType)==ms.ArgumentAsAstronomicalClockWithOffset?t:e(t.RightArgument):t.RightArgumentType==ms.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(vs.OptimizeAtInDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==ms.ArgumentAsTime?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==ms.ArgumentAsDaysOfWeek&&(null===(r=t.RightArgument)||void 0===r?void 0:r.AtMeetCondition)?t:e(t.RightArgument):t.RightArgumentType==ms.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"}(vs||(vs={})),function(e){e.Unknown="Unknown",e.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",e.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",e.ArgumentAsTimeSpan="ArgumentAsTimeSpan",e.ArgumentAsTime="ArgumentAsTime",e.ArgumentAsDeviceState="ArgumentAsDeviceState",e.ArgumentAsSceneExecuted="ArgumentAsSceneExecuted"}(ys||(ys={}));class Ss{constructor(){this.Tasks=new Ts,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=jo.Unknown,this.ConditionType=zo.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=ms.Null,this.RightArgumentType=ms.Null,this.LeftArgument=new _s({},ms.Null),this.RightArgument=new As}}class As{constructor(){this.HandledType=0,this.Argument=null}}class _s{constructor(e,t){this.Argument=e,this.HandledType=t}}class Cs{constructor(){this.DeviceStateType=Jo.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=$o.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Ts{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Ds{constructor(){this.Guid=Kr.NewGuid(),this.RunParallel=!1,this.TaskType=Ho.Unknown}}class ks extends Ds{constructor(){super(...arguments),this.TaskType=Ho.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=Mr.TurnOn}}class Es extends Ds{constructor(){super(...arguments),this.TaskType=Ho.DelayTask,this.Delay="00:00:00"}}class Is extends Ds{constructor(){super(...arguments),this.TaskType=Ho.LockExecution,this.LockType=es.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}class bs extends Ds{constructor(){super(...arguments),this.TaskType=Ho.NotifyTask,this.Title="",this.Message="",this.NotifyType=Zo.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"}(ms||(ms={}));class Gs extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class Ns extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class Rs extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class Ps extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var Us,Os=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=ry.Get(Ct.ServiceName),this._configurationService=ry.Get(at.ServiceName)}GetServiceName(){return Ms.ServiceName}GetSequencesListAsync(){return Os(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 Ie(Wo.OtherError,"Cannot get sequences list - response is null."):n.Status!=ue.OK?new Ie(Wo.OtherError,`Cannot get sequences list - controller responded with response code ${n.Status}.`):null==n.Data?new Ie(Wo.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):n.Data}))}GetSequenceAsync(e){return Os(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 Ie(Wo.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ue.OK)return new Ie(Wo.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Ie(Wo.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 Ie){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 Ie(Wo.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 ws(e,t)}CreateSequenceAsync(e){return Os(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?ue.Error:r.Status}catch(t){return null===(r=u.Log)||void 0===r||r.Error(`Creating sequence ${e.Name} error: ${t}`),ue.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 ry.Get(zs.ServiceName).GetDevicesAsync(!0)}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){return Os(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 Ie(Wo.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ue.WrongData:return new Ie(Wo.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ue.OK:return null==r.Data?new Ie(Wo.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Ie(Wo.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Ie(Wo.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){return Os(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 qs(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield ry.Get(zs.ServiceName).GetDevicesAsync(!0)}}))}EditSequenceAsync(e){return Os(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 Vs(n),2e4,!1);return n.Condition.IsDisabled=r,null==o||null==o.Status?ue.Error:o.Status}catch(t){return null===(n=u.Log)||void 0===n||n.Error(`Editing sequence ${e.Name} error: ${t}`),ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield ry.Get(zs.ServiceName).GetDevicesAsync(!0)}}))}EnableSequenceAsync(e){return Os(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?ue.Error:r.Status}))}DisableSequenceAsync(e){return Os(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?ue.Error:r.Status}))}RunSequenceAsync(e){return Os(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ue.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ue.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new Xr;switch(n.Channel=1,n.DeviceGuid=t,yield ry.Get(zs.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case Ut.Executed:return ue.OK;case Ut.DeviceNotFound:return ue.WrongData;default:return ue.Error}}))}GetUtilsAsync(){return Os(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 Os(this,void 0,void 0,(function*(){var e;const t=ry.Get(Po.ServiceName),n=new Io;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),p=a(h);return new Date>p&&!r?(r=!0,c(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.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),p=Math.floor(((e,t)=>{let n=720+720/Math.PI*Math.acos(-e)-t;return n>1439&&(n-=1439),n})(h,u)),g=a(p);return new Date>g&&!r?(r=!0,l(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>l(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=Us.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=Ho.DeviceTask,e.RunParallel=!1}))),null!=e.Tasks.ControllerTasks&&e.Tasks.ControllerTasks.map((e=>{null==(null==e?void 0:e.Guid)&&(e.Guid=Kr.NewGuid())}))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=Yo.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==Yo.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===Yo.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 Yo.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case Yo.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case Yo.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case Yo.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case Yo.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case Yo.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case Yo.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case Yo.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case Yo.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case Yo.ArgumentAsDeviceState:{const t=new ds;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?$o.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(Vo[e[0]],new hs(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(Vo[e[0]],new ps(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case Yo.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return Yo[Us[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case Jo.BatteryState:return bt.BatteryState;case Jo.BinarySensor:return bt.BinarySensorState;case Jo.BlindPosition:return bt.BlindPosition;case Jo.Brightness:return bt.MeasuredBrightness;case Jo.ButtonState:return bt.RemoteButtonState;case Jo.ChannelOnOff:return bt.ChannelOnOffState;case Jo.DoorBell:return bt.DoorBellState;case Jo.Energy:return bt.MeasuredEnergy;case Jo.FloodSensor:return bt.FloodSensorState;case Jo.GatePosition:return bt.GatePosition;case Jo.LightBrightness:return bt.LightBrightness;case Jo.LightColor:return bt.LightColor;case Jo.LightTemperature:return bt.LightWarmth;case Jo.ReedState:return bt.ReedState;case Jo.SmokeSensor:return bt.SmokeSensorState;case Jo.Temperature:return bt.MeasuredTemperature;case Jo.Humidity:return bt.HumiditySensorState;case Jo.BlindsControlButton:return bt.BlindRemoteButtonState;case Jo.FacadeControlButton:return bt.FacadeRemoteButtonState;case Jo.Movement:return bt.MovementSensorState;case Jo.AirPressure:return bt.PressureSensorState;case Jo.WindSpeed:return bt.WindSpeedState;case Jo.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(Qt[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 fs("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 _n;default:throw new fs("Unsupported device state!")}}MapDeviceTask(e){var t;let n=new jr,r=e;switch(null===(t=u.Log)||void 0===t||t.Debug(`[TASK] object: ${JSON.stringify(r)}`),r.ControlFeature){case Mr.TurnOn:n=new Xr,n.TaskType=It.TurnOn;break;case Mr.TurnOff:n=new Jr,n.TaskType=It.TurnOff;break;case Mr.ToggleState:n=new Zr,n.TaskType=It.TogleState;break;case Mr.SetBlindPosition:{const e=ry.Get(zs.ServiceName).GetDevice(r.DeviceGuid);(null==e?void 0:e.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType)))?(n=new oo,n.TaskType=It.SetBlindPositionSimple,n.Action=r.Data.Action):(n=new no,n.TaskType=It.SetBlindPosition,n.Action=r.Data.Action,n.Position=r.Data.Position);break}case Mr.SetLightColor:n=new eo,n.TaskType=It.SetLightColor,n.R=r.Data.R,n.G=r.Data.G,n.B=r.Data.B;break;case Mr.SetLightTemperature:n=new to,n.TaskType=It.SetLightTemperature,n.Temperature=r.Data.Temperature;break;case Mr.SetLightBrightness:n=new Qr,n.TaskType=It.SetLightBrightness,n.Brightness=r.Data.Brightness;break;case Mr.SetTemperature:n=new zr,n.TaskType=It.SetTemperature,n.Temperature=r.Data.Temperature;break;case Mr.GetState:n=new uo,n.TaskType=It.GetChannelsState;break;case Mr.TurnOnWithTimeout:n=new Yr,n.TaskType=It.TurnOnWithTime,n.SwitchOffDelaySeconds=r.Data.SwitchOffDelaySeconds;break;case Mr.SetLightBrightnessDynamicly:n=new so,n.TaskType=It.SetLightBrightnessDynamicly,n.Brightness=r.Data.Brightness;break;case Mr.IdentifyDevice:n=new io,n.TaskType=It.IdentifyDevice;break;case Mr.SetBlindOpenCloseTime:n=new ao,n.TaskType=It.SetBlindOpenCloseTime,n.Data.CloseTime=r.Data;break;case Mr.SetBlindMicroventilation:n=new lo,n.TaskType=It.SetBlindMicroventilation,n.Position=r.Data.Position;break;case Mr.GatewayPulse:n=new po,n.TaskType=It.ChangeGatewayPositionPulse;break;case Mr.GatePulse:n=new ho,n.TaskType=It.ChangeGatePositionPulse;break;case Mr.SetFacadePositionAndTilt:n=new go,n.TaskType=It.SetFacadePosition,n.Position=r.Data.Position,n.Tilt=r.Data.Tilt,n.FacadeAction=Br.TiltAndPercentage;break;case Mr.GetFacadeType:n=new fo,n.TaskType=It.GetFacadeType;break;case Mr.LightRGBW:n=new yo,n.TaskType=It.LightRGBW,n.Data=r.Data;break;case Mr.SetGatePositionPrecise:n=new ro,n.TaskType=It.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=Kr.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 Ho.DeviceTask:e.TaskType=Ko.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(t);break;case Ho.DelayTask:e.TaskType=Ko.DelayTask,e.Task.DelayTask={Delay:new ps(t.Delay)};break;case Ho.NotifyTask:e.TaskType=Ko.NotifyTask,e.Task.NotifyTask={Message:t.Message,NotifyType:t.NotifyType,NotificationClients:t.NotificationClients};break;case Ho.LockExecution:case Ho.LockExecution:e.TaskType=Ko.LockExecution,null===(n=u.Log)||void 0===n||n.Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(t)}`),e.Task.LockExecution={LockStartHour:new ps(t.LockStartHour),LockEndHour:new ps(t.LockEndHour),LockType:t.LockType,ResetLockScenesGuids:t.ResetLockScenesGuids};case Ho.Unknown:}r.push(e)}return r}GetSupportedTaskTypesAsync(){return Os(this,void 0,void 0,(function*(){const e=yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[Qo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(Qo.DelayTask),(t>5||5==t&&n>=37)&&r.push(Qo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(Qo.NotifyTaskAppNotify),r}))}}Ms.ServiceName="ScenesService";class xs extends ce{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=le.Get}}class Fs extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Get,this.Data=e}}class Ls extends ce{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=le.Get,this.Data=e}}class Bs{constructor(){this.HandledType=Us.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"}(Us||(Us={}));class Ws{constructor(){this.TaskId="",this.Guid="",this.TaskType=Ko.Unknown,this.Task={}}}class $s extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Put,this.Data=e}}class Vs extends ce{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=le.Put,this.Data=e}}class qs extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Delete,this.Data=e}}class Hs extends ce{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=le.Post,this.Data=e}}class Ks extends ce{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=le.Post,this.Data=e}}var js=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 zs{constructor(){var e;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._onDevicesSynchronized=new ke,this._onDevicesStatesSynchronized=new ke,this._syncSemaphore=new et(1),this._connection=ry.Get(Ct.ServiceName),this._session=ry.Get(Xe.ServiceName),this._controllerConfiguration=ry.Get(at.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>js(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),null===(e=this._session)||void 0===e||e.OnUserLoggedInEvent().Subscribe((e=>js(this,void 0,void 0,(function*(){var e;try{yield this.ResyncDevicesAsync()}catch(t){null===(e=u.Log)||void 0===e||e.Error(zs.ServiceName,`Failed to sync devices and states: ${t}`)}})))),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!=Rt.Scene&&(null===(t=u.Log)||void 0===t||t.Debug(zs.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 or(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 Hn(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 or(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 Hn(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 or(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 Hn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{ry.Get(Be.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(zs.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{ry.Get(Be.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(zs.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}ResyncDevicesAsync(){return js(this,void 0,void 0,(function*(){var e,t,n;if(this._syncSemaphore.IsAcquired())return Promise.resolve();yield this._syncSemaphore.AcquireAsync(),this._synchronized=!1,this._synchronizedDevicesStates=!1;try{this._devices=yield this.GetPairedDevicesAsync(!0),this._synchronized=!0,null===(e=this._onDevicesSynchronized)||void 0===e||e.Invoke(),yield this.SyncDevicesStatesAsync(),this._synchronizedDevicesStates=!0,null===(t=this._onDevicesStatesSynchronized)||void 0===t||t.Invoke()}catch(e){null===(n=u.Log)||void 0===n||n.Error(zs.ServiceName,`Failed to get paired devices: ${e}`)}this._syncSemaphore.Release()}))}WaitForSynchronizationAsync(){return new Promise(((e,t)=>{if(1==this._synchronized)return e();const n=window.setTimeout((()=>{e()}),3e4);this._onDevicesSynchronized.Subscribe((()=>{clearTimeout(n),e()}))}))}WaitForDevicesStatesSynchronizationAsync(){return new Promise(((e,t)=>{if(1==this._synchronizedDevicesStates)return e();const n=window.setTimeout((()=>{e()}),12e4);this._onDevicesStatesSynchronized.Subscribe((()=>{clearTimeout(n),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 js(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"),ue.ResourceDoesNotExists;i=n}else i=e;const c=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new ci(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!"),ue.FatalError;if(c.Status!=ue.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!"),ue.FatalError;var a=yield ry.Get(Ms.ServiceName).GetSequencesListAsync();if(a instanceof Ie)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}`),ue.Error;const l=new hi;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}`),ue.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)>=fe.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)>=fe.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return js(this,void 0,void 0,(function*(){var e;const t=ry.Get(Co.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return null===(e=u.Log)||void 0===e||e.Error(zs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EnableFastStatesSyncAsync()"),yield ry.Get(at.ServiceName).ExitConfigurationModeAsync(),t}))}DisableFastStatesSyncAsync(){return js(this,void 0,void 0,(function*(){var e;const t=ry.Get(Co.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return null===(e=u.Log)||void 0===e||e.Error(zs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DisableFastStatesSyncAsync()"),yield ry.Get(at.ServiceName).ExitConfigurationModeAsync(),t}))}IsFastStatesSyncEnabledAsync(){return js(this,void 0,void 0,(function*(){const e=yield ry.Get(Co.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof So?e.Data:e!=ue.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return js(this,void 0,void 0,(function*(){let t=ry.Get(wo.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 js(this,void 0,void 0,(function*(){var t,n=yield ry.Get(wo.ServiceName).AddManuallyPairedDeviceAsync(e);return null===(t=u.Log)||void 0===t||t.Error(zs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDevice()"),yield ry.Get(at.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 Js;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 Js,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)}}}GetCurrentlyRunningTaksAsync(){return js(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ni,15e3,!1);(null==t?void 0:t.Status)==ue.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),r=new $t;if(r.DeviceGuid=n[0],r.Channel=Number(n[1]),r.Status=Tt.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 $t;r.DeviceGuid=e.Guid,r.Channel=n.Number,r.Status=Tt.ExecutingTasks,t.push(r)}))}})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new Cn(t);case"DoorBell":return new bn(t);case"ReedPosition":return new Nn(t);case"BlindPosition":return new Pn(t);case"ButtonState":return new On(t);case"LightColor":return new xn(t);case"LightTemperature":return new Ln(t);case"LightBrightness":return new Wn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new Vn(t);case"BatteryState":return new Hn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new jn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new Jn(t);case"DistanceSensor":return new Yn(t);case"MovementSensor":return new Qn(t);case"BlindsControlButton":return new er(t);case"FacadeControlButton":return new nr(t);case"SignalStrength":return new or(t);case"GatePosition":return new sr(t);case"GatewayPosition":return new ar(t);case"GateControllerHealth":return new cr(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new ur(t);case"HumiditySensor":case"HumidityState":return new lr(t);case"VibrationSensor":return new hr(t);case"DigitalInputSensor":return new pr(t);case"ConfigurationState":return new fr(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new vr(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new yr(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new mr(t);case"FacadePosition":case"FacadeState":return new wr(t);case"FacadeTypeState":return new Sr(t);case"CurrentWindThreshold":return new Ar(t);case"CurrentLightThreshold":return new Cr(t);case"WindSpeed":return new Tr(t);case"FloodSensor":return new kr(t);case"PressureState":return new Ir(t);case"ITamperProtection":case"TamperProtection":return new Gr(t);case"ILightRGBW":case"LightRGBW":return new Nr(t);case"OnlineCamera":case"IOnlineCamera":return new In(t);case"BlindError":case"IBlindError":return t.state.ErrorData=ie(t.state.ErrorData),new Rr(t);case"HallState":return new Dn(t);case"SceneExecuted":return new kn(t);case"Intercom":return new En(t);default:null===(n=u.Log)||void 0===n||n.Debug(zs.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return zs.ServiceName}SyncDevicesStatesAsync(){return js(this,arguments,void 0,(function*(e=!1){var t,n;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ys,15e3,!1);if((yield this.IsFastStatesSyncEnabledAsync())&&!e)return(null==r?void 0:r.Status)==ue.OK;{let e=new Qs;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)==ue.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 Pr;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=Et.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Bt;if(i.CommunicationWay==Nt.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 Wt;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 $r;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 Wt;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Bt;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 js(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!=Rt.Scene)));const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Xs,15e3,!0);return null==o||void 0===o?[]:o.Status==ue.OK&&null!=o.Data?(this._devices=this.MapApiDevices(o.Data),e?this._devices:this._devices.filter((e=>e.DeviceType!=Rt.Scene))):(null===(r=u.Log)||void 0===r||r.Error(zs.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(){return js(this,arguments,void 0,(function*(e=!1){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){return js(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ti,15e3,!1);return null==n?[]:n.Status==ue.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Rt.Scene)).toArray():(null===(t=u.Log)||void 0===t||t.Error(zs.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){return js(this,void 0,void 0,(function*(){var e;ry.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Zs,35e3,!1)}))}StopSearchingForDevices(){return js(this,void 0,void 0,(function*(){var e;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ei,2e4,!1)}))}RegisterDeviceAsync(e){return js(this,void 0,void 0,(function*(){var t,n,r;try{const r=new ri;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(zs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RegisterDeviceAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==ue.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),Ut.Executed):Ut.Failed}catch(e){return null===(r=u.Log)||void 0===r||r.Error(zs.ServiceName,`Failed to paired devices: ${e}`),Ut.ControllerResponseTimeout}}))}RemoveDeviceAsync(e){return js(this,arguments,void 0,(function*(e,t=!1){var n,r,o=new oi;t&&(o=new si),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(zs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RemoveDeviceAsync()"),ry.Get(at.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ue.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),Ut.Executed):Ut.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new ui;const r=t;switch(r.FeatureType){case Mr.SetTemperature:n.Data=r.Temperature;break;case Mr.SetLightBrightness:n.Data=r.Brightness;break;case Mr.SetLightColor:n=new li;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case Mr.SetLightTemperature:n.Data=r.Temperature;break;case Mr.SetGatePositionPrecise:switch(r.GateControlAction){case Fr.Open:n.Data=101;break;case Fr.Close:n.Data=102;break;case Fr.Stop:n.Data=103;break;case Fr.Percentage:n.Data=r.Position}break;case Mr.SetBlindPosition:switch(r.Action){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 Mr.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case Mr.SetBlindOpenCloseTime:n.Data=r.Data;break;case Mr.SetBlindMicroventilation:n.Data=r.Position;break;case Mr.SetFacadePositionAndTilt:n=new di;const t=r;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case Mr.LightRGBW:n.Data=r.Data;break;case Mr.GatePulse:case Mr.GatewayPulse:n.Data=0;break;case Mr.TurnOnWithTimeout:n.Data=r.SwitchOffDelaySeconds}return n.Channel=r.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=r.FeatureType,n}ExecuteDeviceTaskAsync(e,t){return js(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(zs.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new ii(l);null===(r=u.Log)||void 0===r||r.Debug(zs.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 ue.OK:return Ut.Executed;case ue.FatalError:return null===(s=u.Log)||void 0===s||s.Error(zs.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),Ut.Failed;case ue.WrongData:if("DeviceNotFound"===t.Data)return Ut.DeviceNotFound;break;case ue.Error:return"DeviceResponseTimeout"===t.Data?Ut.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(zs.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),Ut.Failed)}}catch(e){return e.message.includes("timeout")?(null===(a=u.Log)||void 0===a||a.Error(zs.ServiceName,`Failed to get controller response in time.\n${e}`),Ut.ControllerResponseTimeout):(null===(c=u.Log)||void 0===c||c.Error(zs.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Ut.Failed)}return Ut.Unknown}catch(e){return null===(l=u.Log)||void 0===l||l.Error(zs.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Ut.Failed}}))}ExecuteDevicesTasksAsync(e){return js(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 ai(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=Ut.Unknown;switch(t.Status){case ue.OK:return Ut.Executed;case ue.FatalError:null===(n=u.Log)||void 0===n||n.Error(zs.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),a=Ut.Failed;break;case ue.WrongData:"DeviceNotFound"===t.Data&&(a=Ut.DeviceNotFound);break;case ue.Error:"DeviceResponseTimeout"===t.Data?a=Ut.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(zs.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),a=Ut.Failed)}let c=0,l=new Vt;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(zs.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new Vt;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Ut.ControllerResponseTimeout}}else{null===(o=u.Log)||void 0===o||o.Error(zs.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new Vt;s.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Ut.Failed}}}return s}))}}zs.ServiceName="DevicesService";class Js{constructor(){this.Channel=0,this.States=[]}}class Xs extends ce{constructor(){super(),this.Resource="/devices/list",this.Method=le.Get}}class Ys extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=le.Get}}class Qs extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=le.Get}}class Zs extends ce{constructor(){super(),this.Resource="/devices/search",this.Method=le.Post}}class ei extends ce{constructor(){super(),this.Resource="/devices/search/stop",this.Method=le.Post}}class ti extends ce{constructor(){super(),this.Resource="/devices/found/list",this.Method=le.Get}}class ni extends ce{constructor(){super(),this.Resource="/devices/tasks",this.Method=le.Get}}class ri extends ce{constructor(){super(),this.Resource="/devices/device/pair",this.Method=le.Put}}class oi extends ce{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=le.Put}}class si extends ce{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=le.Put}}class ii extends ce{constructor(e){super(),this.Resource="/devices/device/control",this.Method=le.Post,this.Data=e}}class ai extends ce{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=le.Post,this.Data=e}}class ci extends ce{constructor(e){super(),this.Resource="/logic/device/used",this.Method=le.Get,this.Data=e}}class ui{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Mr.GetState,this.SequnceExecutionOrder=0}}class li extends ui{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class di extends ui{constructor(){super(...arguments),this.FacadeAction=Br.Stop,this.Tilt=0,this.Position=0}}class hi{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class pi 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 gi=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 fi extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const vi=(e,t)=>e===t;class yi{iterator;constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class mi{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 wi{iterator;constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class Si extends Array{}const Ai=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Ti(e,t,n,r)}return n?Ci(e,t,n):_i(e,t)},_i=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new fi(gi.NoElements);return n},Ci=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},Ti=(e,t,n,r)=>{let o=t;for(const t of e)o=n(o,t);return r(o)},Di=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},ki=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Ei=(e,t)=>t?bi(e,t):Ii(e),Ii=e=>{for(const t of e)return!0;return!1},bi=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Gi=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},Ni=(e,t)=>new wi((function*(){yield*e,yield t})),Ri=e=>{if(Array.isArray(e)){if(0===e.length)throw new fi(gi.NoElements);return new yi((async function*(){for await(const t of e)yield t}))}return new yi(e)},Pi=e=>Ri((async function*(){for(const t of e)yield t})),Ui=(e,t)=>new mi({generator:t,type:e}),Oi=e=>Ui(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Mi=(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 fi(gi.NoElements);return n/r},xi=async(e,t)=>{let n=0,r=0;for(const o of e)n+=await t(o),r+=1;if(0===r)throw new fi(gi.NoElements);return n/r},Fi=(e,t)=>{if(t<1)throw new pi("size");return new wi((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Li=(e,t)=>new wi((function*(){yield*e,yield*t})),Bi=(e,t,n=vi)=>{for(const r of e)if(n(t,r))return!0;return!1},Wi=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},$i=(e,t)=>t?qi(e,t):Vi(e),Vi=e=>{let t=0;for(const n of e)t++;return t},qi=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},Hi=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},Ki=(e,t)=>new wi((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),ji=(e,t=vi)=>new wi((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),zi=(e,t)=>Ri((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}})),Ji=(e,t)=>new wi((function*(){for(const n of e)t(n),yield n})),Xi=(e,t)=>Ri((async function*(){for(const n of e)await t(n),yield n})),Yi=(e,t)=>{if(t<0)throw new pi("index");let n=0;for(const r of e)if(t===n++)return r;throw new pi("index")},Qi=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},Zi=(e,t,n=vi)=>new wi((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)}})),ea=(e,t,n)=>Ri((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)}})),ta=(e,t)=>t?ra(e,t):na(e),na=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new fi(gi.NoElements);return t.value},ra=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new fi(gi.NoMatch)},oa=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new fi(gi.NoMatch)},sa=(e,t)=>t?aa(e,t):ia(e),ia=e=>e[Symbol.iterator]().next().value??null,aa=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},ca=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class ua extends Si{key;constructor(e,t){super(1),this.key=e,this[0]=t}}const la=(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 ua(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 ua(e,r)}for(const e in n)yield n[e]})(e,t),new wi(r)},da=(e,t,n)=>n?pa(e,t,n):ha(e,t),ha=(e,t)=>Ri((async function*(){const n={};for(const r of e){const e=await t(r),o=n[e];o?o.push(r):n[e]=new ua(e,r)}for(const e in n)yield n[e]})),pa=(e,t,n)=>Ri((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 ua(e,o))}for(const e of r)yield e})),ga=(e,t,n,r)=>r?((e,t,n,r)=>new wi((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 ua(e,t))}}for(const e of o)yield e})))(e,t,n,r):((e,t,n)=>new wi((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 ua(e,i)}for(const e in r)yield r[e]})))(e,t,n),fa=(e,t,n,r,o,s)=>{const i=s?va(e,t,n,r,o,s):ya(e,t,n,r,o);return new wi(i)},va=(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)}},ya=(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)}},ma=(e,t,n,r,o,s)=>{const i=s?wa(e,t,n,r,o,s):Sa(e,t,n,r,o);return Ri(i)},wa=(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)}},Sa=(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)}},Aa=(e,t,n=vi)=>new wi((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}}})),_a=(e,t,n)=>Ri((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}}}})),Ca=(e,t,n,r,o,s=vi)=>new wi((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))}}})),Ta=(e,t)=>t?ka(e,t):Da(e),Da=e=>{let t;for(const n of e)t=n;if(!t)throw new fi(gi.NoElements);return t},ka=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new fi(gi.NoMatch);return n},Ea=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new fi(gi.NoMatch);return n},Ia=(e,t)=>t?Ga(e,t):ba(e),ba=e=>{let t=null;for(const n of e)t=n;return t},Ga=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},Na=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},Ra=(e,t)=>t?Ua(e,t):Pa(e),Pa=e=>{let t=null;for(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new fi(gi.NoElements);return t},Ua=(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new fi(gi.NoElements);return n},Oa=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 fi(gi.NoElements);return n},Ma=(e,t)=>t?Fa(e,t):xa(e),xa=e=>{let t=null;for(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new fi(gi.NoElements);return t},Fa=(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new fi(gi.NoElements);return n},La=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 fi(gi.NoElements);return n},Ba=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new wi((function*(){for(const t of e)n(t)&&(yield t)}))};async function*Wa(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*$a(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 Va extends yi{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 Va?async function*(){for await(const o of e.orderedPairs())yield*Wa(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 Va(o)}static generate(e,t,n,r){let o;return o=e instanceof Va?async function*(){for await(const o of e.orderedPairs())yield*$a(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 Va(o)}thenBy(e,t){return Va.generate(this,e,!0,t)}thenByAsync(e,t){return Va.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Va.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Va.generateAsync(this,e,!1,t)}}function*qa(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*Ha(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 Ka extends wi{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 Ka?function*(){for(const o of e.orderedPairs())yield*qa(o,t,n,r)}:()=>qa(e,t,n,r),new Ka(o)}static generateAsync(e,t,n,r){let o;return o=e instanceof Ka?async function*(){for(const o of e.orderedPairs())yield*Ha(o,t,n,r)}:()=>Ha(e,t,n,r),new Va(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)}}const ja=(e,t)=>Ka.generate(e,(e=>e),!0,t),za=(e,t,n)=>Ka.generate(e,t,!0,n),Ja=(e,t,n)=>Ka.generateAsync(e,t,!0,n),Xa=(e,t,n)=>Ka.generate(e,t,!1,n),Ya=(e,t,n)=>Ka.generateAsync(e,t,!1,n),Qa=(e,t)=>Ka.generate(e,(e=>e),!1,t),Za=(e,t)=>{const n=[],r=[];for(const o of e)!0===t(o)?r.push(o):n.push(o);return[r,n]},ec=async(e,t)=>{const n=[],r=[];for(const o of e)!0===await t(o)?r.push(o):n.push(o);return[r,n]},tc=(e,t)=>new wi((function*(){yield t,yield*e})),nc=e=>new wi((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),rc=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?oc(e,t):sc(e,t)}return ic(e,t)},oc=(e,t)=>new wi((function*(){for(const n of e)yield t(n)})),sc=(e,t)=>new wi((function*(){let n=0;for(const r of e)yield t(r,n),n++})),ic=(e,t)=>new wi((function*(){for(const n of e)yield n[t]})),ac=(e,t)=>"function"==typeof t?1===t.length?cc(e,t):uc(e,t):lc(e,t),cc=(e,t)=>Ri((async function*(){for(const n of e)yield t(n)})),uc=(e,t)=>Ri((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),lc=(e,t)=>Ri((async function*(){for(const n of e)yield n[t]})),dc=(e,t)=>"function"==typeof t?1===t.length?hc(e,t):pc(e,t):gc(e,t),hc=(e,t)=>new wi((function*(){for(const n of e)for(const e of t(n))yield e})),pc=(e,t)=>new wi((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),gc=(e,t)=>new wi((function*(){for(const n of e)for(const e of n[t])yield e})),fc=(e,t)=>1===t.length?vc(e,t):yc(e,t),vc=(e,t)=>Ri((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),yc=(e,t)=>Ri((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),mc=(e,t,n=vi)=>{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},wc=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},Sc=(e,t)=>t?_c(e,t):Ac(e),Ac=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new fi(gi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new fi(gi.NoElements);return n},_c=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new fi(gi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new fi(gi.NoMatch);return r},Cc=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new fi(gi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new fi(gi.NoMatch);return r},Tc=(e,t)=>t?kc(e,t):Dc(e),Dc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new fi(gi.MoreThanOneElement);t=!0,n=r}return n},kc=(e,t)=>{let n=!1,r=null;for(const o of e)if(t(o)){if(!0===n)throw new fi(gi.MoreThanOneMatchingElement);n=!0,r=o}return r},Ec=async(e,t)=>{let n=!1,r=null;for(const o of e)if(await t(o)){if(!0===n)throw new fi(gi.MoreThanOneElement);n=!0,r=o}return r},Ic=(e,t)=>new wi((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),bc=(e,t)=>1===t.length?Gc(e,t):Nc(e,t),Gc=(e,t)=>new wi((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Nc=(e,t)=>new wi((function*(){let n=0,r=!0;for(const o of e)!1===r?yield o:!1===t(o,n)&&(r=!1,yield o),n++})),Rc=(e,t)=>1===t.length?Pc(e,t):Uc(e,t),Pc=(e,t)=>Ri((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Uc=(e,t)=>Ri((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++})),Oc=(e,t)=>t?xc(e,t):Mc(e),Mc=e=>{let t=0;for(const n of e)t+=n;return t},xc=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},Fc=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},Lc=(e,t)=>new wi((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),Bc=(e,t)=>1===t.length?Wc(e,t):$c(e,t),Wc=(e,t)=>new wi((function*(){for(const n of e){if(!t(n))break;yield n}})),$c=(e,t)=>new wi((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),Vc=(e,t)=>1===t.length?qc(e,t):Hc(e,t),qc=(e,t)=>Ri((async function*(){for(const n of e){if(!await t(n))break;yield n}})),Hc=(e,t)=>Ri((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),Kc=e=>[...e],jc=(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},zc=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},Jc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},Xc=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},Yc=e=>new Set(e),Qc=(e,t,n)=>n?eu(e,t,n):Zc(e,t),Zc=(e,t)=>new wi((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))})),eu=(e,t,n)=>new wi((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))}})),tu=(e,t,n)=>Ri((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))}})),nu=(e,t)=>1===t.length?ru(e,t):ou(e,t),ru=(e,t)=>new wi((function*(){for(const n of e)!0===t(n)&&(yield n)})),ou=(e,t)=>new wi((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),su=(e,t)=>1===t.length?iu(e,t):au(e,t),iu=(e,t)=>Ri((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),au=(e,t)=>Ri((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),cu=(e,t,n)=>n?lu(e,t,n):uu(e,t),uu=(e,t)=>new wi((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]}})),lu=(e,t,n)=>new wi((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)}})),du=(e,t,n)=>Ri((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)}})),hu=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(Ai,"aggregate"),n(Di,"all"),n(ki,"allAsync"),n(Ei,"any"),n(Gi,"anyAsync"),n(Ni,"append"),n(Pi,"asAsync"),n(Oi,"asParallel"),n(Mi,"average"),n(xi,"averageAsync"),n(Fi,"chunk"),n(Li,"concatenate"),n(Bi,"contains"),n(Wi,"containsAsync"),n($i,"count"),n(Hi,"countAsync"),n(Ki,"defaultIfEmpty"),n(ji,"distinct"),n(zi,"distinctAsync"),n(Ji,"each"),n(Xi,"eachAsync"),n(Yi,"elementAt"),n(Qi,"elementAtOrDefault"),n(Zi,"except"),n(ea,"exceptAsync"),n(ta,"first"),n(oa,"firstAsync"),n(sa,"firstOrDefault"),n(ca,"firstOrDefaultAsync"),n(la,"groupBy"),n(da,"groupByAsync"),n(ga,"groupByWithSel"),n(fa,"groupJoin"),n(ma,"groupJoinAsync"),n(Aa,"intersect"),n(_a,"intersectAsync"),n(Ca,"joinByKey"),n(Ta,"last"),n(Ea,"lastAsync"),n(Ia,"lastOrDefault"),n(Na,"lastOrDefaultAsync"),n(Ra,"max"),n(Oa,"maxAsync"),n(Ma,"min"),n(La,"minAsync"),n(Ba,"ofType"),n(ja,"order"),n(za,"orderBy"),n(Ja,"orderByAsync"),n(Xa,"orderByDescending"),n(Ya,"orderByDescendingAsync"),n(Qa,"orderDescending"),n(tc,"prepend"),n(nc,"reverse"),n(rc,"select"),n(ac,"selectAsync"),n(dc,"selectMany"),n(fc,"selectManyAsync"),n(mc,"sequenceEquals"),n(wc,"sequenceEqualsAsync"),n(Sc,"single"),n(Cc,"singleAsync"),n(Tc,"singleOrDefault"),n(Ec,"singleOrDefaultAsync"),n(Ic,"skip"),n(bc,"skipWhile"),n(Rc,"skipWhileAsync"),n(Oc,"sum"),n(Fc,"sumAsync"),n(Lc,"take"),n(Bc,"takeWhile"),n(Vc,"takeWhileAsync"),n(Kc,"toArray"),n(jc,"toMap"),n(zc,"toMapAsync"),n(Jc,"toObject"),n(Xc,"toObjectAsync"),n(Za,"partition"),n(ec,"partitionAsync"),n(Yc,"toSet"),n(Qc,"union"),n(tu,"unionAsync"),n(nu,"where"),n(su,"whereAsync"),n(cu,"zip"),n(du,"zipAsync")},pu=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return vu(e,t,n,r)}return n?fu(e,t,n):gu(e,t)},gu=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new fi(gi.NoElements);return n},fu=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},vu=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},yu=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},mu=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},wu=(e,t)=>new yi((async function*(){yield*e,yield t})),Su=(e,t)=>t?_u(e,t):Au(e),Au=async e=>{for await(const t of e)return!0;return!1},_u=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Cu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},Tu=e=>Ui(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),Du=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 fi(gi.NoElements);return n/r},ku=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 fi(gi.NoElements);return n/r},Eu=(e,t)=>{if(t<1)throw new pi("size");return new yi((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Iu=(e,t)=>new yi((async function*(){yield*e,yield*t})),bu=async(e,t,n=vi)=>{for await(const r of e)if(n(t,r))return!0;return!1},Gu=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},Nu=(e,t)=>t?Pu(e,t):Ru(e),Ru=async e=>{let t=0;for await(const n of e)t++;return t},Pu=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},Uu=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},Ou=(e,t)=>new yi((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),Mu=(e,t=vi)=>new yi((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),xu=(e,t)=>new yi((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}})),Fu=(e,t)=>new yi((async function*(){for await(const n of e)t(n),yield n})),Lu=(e,t)=>new yi((async function*(){for await(const n of e)await t(n),yield n})),Bu=async(e,t)=>{if(t<0)throw new pi("index");let n=0;for await(const r of e)if(t===n++)return r;throw new pi("index")},Wu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},$u=(e,t,n=vi)=>new yi((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)}})),Vu=(e,t,n)=>new yi((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)}})),qu=(e,t)=>t?Ku(e,t):Hu(e),Hu=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new fi(gi.NoElements);return t.value},Ku=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new fi(gi.NoMatch)},ju=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new fi(gi.NoMatch)},zu=(e,t)=>t?Xu(e,t):Ju(e),Ju=async e=>(await e[Symbol.asyncIterator]().next()).value??null,Xu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},Yu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},Qu=(e,t,n)=>n?Zu(e,t,n):el(e,t),Zu=(e,t,n)=>new yi((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 ua(e,o))}for(const e of r)yield e})),el=(e,t)=>new yi((async function*(){const n={};for await(const r of e){const e=t(r),o=n[e];o?o.push(r):n[e]=new ua(e,r)}for(const e in n)yield n[e]})),tl=(e,t,n)=>n?rl(e,t,n):nl(e,t),nl=(e,t)=>new yi((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 ua(e,r)}for(const e in n)yield n[e]})),rl=(e,t,n)=>new yi((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 ua(e,o))}for(const e of r)yield e})),ol=(e,t,n,r)=>r?il(e,t,n,r):sl(e,t,n),sl=(e,t,n)=>new yi((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 ua(e,i)}for(const e in r)yield r[e]})),il=(e,t,n,r)=>new yi((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 ua(e,t))}}for(const e of o)yield e})),al=(e,t,n,r,o,s)=>{const i=s?cl(e,t,n,r,o,s):ul(e,t,n,r,o);return new yi(i)},cl=(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)}},ul=(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)}},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 yi(i)},dl=(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)}},hl=(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)}},pl=(e,t,n=vi)=>new yi((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}}}})),gl=(e,t,n)=>new yi((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}}}})),fl=(e,t,n,r,o,s=vi)=>new yi((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))}}})),vl=(e,t)=>t?ml(e,t):yl(e),yl=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new fi(gi.NoElements);return t},ml=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new fi(gi.NoMatch);return n},wl=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new fi(gi.NoMatch);return n},Sl=(e,t)=>t?_l(e,t):Al(e),Al=async e=>{let t=null;for await(const n of e)t=n;return t},_l=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},Cl=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},Tl=(e,t)=>t?kl(e,t):Dl(e),Dl=async e=>{let t=null;for await(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new fi(gi.NoElements);return t},kl=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 fi(gi.NoElements);return n},El=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 fi(gi.NoElements);return n},Il=(e,t)=>t?Gl(e,t):bl(e),bl=async e=>{let t=null;for await(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new fi(gi.NoElements);return t},Gl=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 fi(gi.NoElements);return n},Nl=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 fi(gi.NoElements);return n},Rl=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new yi((async function*(){for await(const t of e)n(t)&&(yield t)}))},Pl=(e,t)=>Va.generate(e,(e=>e),!0,t),Ul=(e,t,n)=>Va.generate(e,t,!0,n),Ol=(e,t,n)=>Va.generateAsync(e,t,!0,n),Ml=(e,t,n)=>Va.generate(e,t,!1,n),xl=(e,t,n)=>Va.generateAsync(e,t,!1,n),Fl=(e,t)=>Va.generate(e,(e=>e),!1,t),Ll=async(e,t)=>{const n=[],r=[];for await(const o of e)!0===t(o)?r.push(o):n.push(o);return[r,n]},Bl=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]},Wl=(e,t)=>new yi((async function*(){yield t,yield*e})),$l=e=>new yi((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]})),Vl=(e,t)=>"function"==typeof t?1===t.length?ql(e,t):Hl(e,t):Kl(e,t),ql=(e,t)=>new yi((async function*(){for await(const n of e)yield t(n)})),Hl=(e,t)=>new yi((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),Kl=(e,t)=>new yi((async function*(){for await(const n of e)yield n[t]})),jl=(e,t)=>"string"==typeof t?Jl(e,t):zl(e,t),zl=(e,t)=>new yi((async function*(){for await(const n of e)yield t(n)})),Jl=(e,t)=>new yi((async function*(){for await(const n of e)yield n[t]})),Xl=(e,t)=>"function"==typeof t?1===t.length?Yl(e,t):Ql(e,t):Zl(e,t),Yl=(e,t)=>new yi((async function*(){for await(const n of e)for(const e of t(n))yield e})),Ql=(e,t)=>new yi((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),Zl=(e,t)=>new yi((async function*(){for await(const n of e)for(const e of n[t])yield e})),ed=(e,t)=>1===t.length?new yi((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new yi((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++}})),td=async(e,t,n=vi)=>{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},nd=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},rd=(e,t)=>t?sd(e,t):od(e),od=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new fi(gi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new fi(gi.NoElements);return n},sd=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new fi(gi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new fi(gi.NoMatch);return r},id=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(await t(o)){if(!0===n)throw new fi(gi.MoreThanOneMatchingElement);n=!0,r=o}if(!1===n)throw new fi(gi.NoMatch);return r},ad=(e,t)=>t?ud(e,t):cd(e),cd=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new fi(gi.MoreThanOneElement);t=!0,n=r}return n},ud=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(t(o)){if(!0===n)throw new fi(gi.MoreThanOneMatchingElement);n=!0,r=o}return r},ld=async(e,t)=>{let n=!1,r=null;for await(const o of e)if(await t(o)){if(!0===n)throw new fi(gi.MoreThanOneMatchingElement);n=!0,r=o}return r},dd=(e,t)=>new yi((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),hd=(e,t)=>1===t.length?pd(e,t):gd(e,t),pd=(e,t)=>new yi((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),gd=(e,t)=>new yi((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++})),fd=(e,t)=>1===t.length?vd(e,t):yd(e,t),vd=(e,t)=>new yi((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),yd=(e,t)=>new yi((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++})),md=(e,t)=>t?Sd(e,t):wd(e),wd=async e=>{let t=0;for await(const n of e)t+=n;return t},Sd=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},Ad=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},_d=(e,t)=>new yi((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Cd=(e,t)=>1===t.length?Td(e,t):Dd(e,t),Td=(e,t)=>new yi((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Dd=(e,t)=>new yi((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),kd=(e,t)=>1===t.length?Ed(e,t):Id(e,t),Ed=(e,t)=>new yi((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Id=(e,t)=>new yi((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),bd=async e=>{const t=[];for await(const n of e)t.push(n);return t},Gd=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},Nd=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},Rd=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},Pd=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},Ud=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Od=(e,t,n)=>n?xd(e,t,n):Md(e,t),Md=(e,t)=>new yi((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))})),xd=(e,t,n)=>new yi((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))}})),Fd=(e,t,n)=>new yi((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))}})),Ld=(e,t)=>1===t.length?Bd(e,t):Wd(e,t),Bd=(e,t)=>new yi((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Wd=(e,t)=>new yi((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),$d=(e,t)=>1===t.length?Vd(e,t):qd(e,t),Vd=(e,t)=>new yi((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),qd=(e,t)=>new yi((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),Hd=(e,t,n)=>n?jd(e,t,n):Kd(e,t),Kd=(e,t)=>new yi((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]}})),jd=(e,t,n)=>new yi((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)}})),zd=(e,t,n)=>new yi((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)}})),Jd=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Qd(e,t,n,r)}return n?Yd(e,t,n):Xd(e,t)},Xd=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new fi(gi.NoElements);return n},Yd=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Qd=async(e,t,n,r)=>{let o=t;for await(const t of e)o=n(o,t);return r(o)},Zd=(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}}},eh=(e,t)=>{const n=Zd(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))}},th=(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}}},nh=(e,t)=>{const n=th(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))}},rh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new mi({generator:()=>{const e=n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 2:return new mi({generator:async()=>{const e=await n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 0:return new mi({generator:async()=>{const e=await n.generator();return e.push(t),e},type:n.type})}},oh=(e,t)=>t?ih(e,t):sh(e),sh=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}},ih=async(e,t)=>{const n=Zd(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)}},ah=async(e,t)=>{const n=th(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)}},ch=e=>Ri((async function*(){for await(const t of e)yield t})),uh=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)}},lh=async(e,t)=>{let n;n=t?Zd(e,t):e.dataFunc;const r=await uh(n);if(0===r.length)throw new fi(gi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},dh=async(e,t)=>{const n=th(e,t),r=await uh(n);if(0===r.length)throw new fi(gi.NoElements);let o=0;for(const e of r)o+=e;return o/r.length},hh=(e,t)=>{if(t<1)throw new pi("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 mi(n)},ph=(e,t)=>new mi({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),gh=async(e,t,n=vi)=>{let r;switch(r=Zd(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))}},fh=async(e,t,n)=>{const r=th(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))}},vh=(e,t)=>t?mh(e,t):yh(e),yh=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},mh=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},wh=async(e,t)=>{const n=th(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},Sh=(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 mi(o)},Ah=(e,t=vi)=>new mi({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),_h=(e,t)=>new mi({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}),Ch=(e,t)=>new mi(Zd(e,(e=>(t(e),e)))),Th=(e,t)=>{const n=th(e,(async e=>(await t(e),e)));return new mi(n)},Dh=async(e,t)=>{if(t<0)throw new pi("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new pi("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new pi("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new pi("index");return await e[t]}}},kh=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]}}},Eh=(e,t,n=vi)=>new mi({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}),Ih=(e,t,n)=>new mi({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}),bh=e=>uh(e.dataFunc),Gh=(e,t)=>t?Rh(e,t):Nh(e),Nh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new fi(gi.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new fi(gi.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new fi(gi.NoElements);return await e[0]}}},Rh=async(e,t)=>{const n=await bh(e);for(const e of n)if(!0===t(e))return e;throw new fi(gi.NoMatch)},Ph=async(e,t)=>{const n=await bh(e);for(const e of n)if(!0===await t(e))return e;throw new fi(gi.NoMatch)},Uh=(e,t)=>t?Mh(e,t):Oh(e),Oh=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]}}},Mh=async(e,t)=>{const n=await bh(e);for(const e of n)if(!0===t(e))return e;return null},xh=async(e,t)=>{const n=await bh(e);for(const e of n)if(!0===await t(e))return e;return null},Fh=(e,t,n)=>n?Bh(e,t,n):Lh(e,t),Lh=(e,t)=>new mi({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 ua(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),Bh=(e,t,n)=>new mi({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 ua(e,o))}const o=new Array;for(const e of r)o.push(e);return o},type:0}),Wh=(e,t,n)=>n?$h(e,t,n):Vh(e,t),$h=(e,t,n)=>new mi({generator:async()=>{const r=th(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 ua(e,t))}const i=new Array;for(const e of s)i.push(e);return i},type:0}),Vh=(e,t)=>new mi({generator:async()=>{const n=th(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 ua(e,t)}const s=new Array;for(const e in o)s.push(o[e]);return s},type:0}),qh=(e,t,n,r)=>r?Hh(e,t,n,r):Kh(e,t,n),Hh=(e,t,n,r)=>new mi({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 ua(e,t))}}const s=new Array;for(const e of o)s.push(e);return s},type:0}),Kh=(e,t,n)=>new mi({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 ua(e,i)}const o=new Array;for(const e in r)o.push(r[e]);return o},type:0}),jh=(e,t,n,r,o,s)=>{const i=s?zh(e,t,n,r,o,s):Jh(e,t,n,r,o);return new mi({generator:i,type:0})},zh=(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)}))},Jh=(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)}))},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 mi({generator:i,type:0})},Yh=(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)},Qh=(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)},Zh=(e,t,n=vi)=>new mi({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}),ep=(e,t,n)=>new mi({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}),tp=(e,t,n,r,o,s=vi)=>new mi({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}),np=(e,t)=>t?op(e,t):rp(e),rp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new fi(gi.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new fi(gi.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new fi(gi.NoElements);return await e[e.length-1]}}},op=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 fi(gi.NoMatch)},sp=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 fi(gi.NoMatch)},ip=(e,t)=>t?cp(e,t):ap(e),ap=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]}}},cp=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},up=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},lp=async(e,t)=>{let n;n=t?Zd(e,t):e.dataFunc;const r=await uh(n);if(0===r.length)throw new fi(gi.NoElements);return Math.max.apply(null,r)},dp=async(e,t)=>{const n=th(e,t),r=await uh(n);if(0===r.length)throw new fi(gi.NoElements);return Math.max.apply(null,r)},hp=async(e,t)=>{let n;n=t?Zd(e,t):e.dataFunc;const r=await uh(n);if(0===r.length)throw new fi(gi.NoElements);return Math.min.apply(null,r)},pp=async(e,t)=>{const n=th(e,t),r=await uh(n);if(0===r.length)throw new fi(gi.NoElements);return Math.min.apply(null,r)},gp=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new mi({generator:async()=>{const t=Zd(e,n),r=await uh(t),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0})};async function*fp(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*vp(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 yp extends mi{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 yp?async function*(){for await(const o of e.orderedPairs())yield*fp(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 yp(o)}static generate(e,t,n,r){let o;return o=e instanceof yp?async function*(){for await(const o of e.orderedPairs())yield*vp(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 yp(o)}thenBy(e,t){return yp.generate(this,e,!0,t)}thenByAsync(e,t){return yp.generateAsync(this,e,!0,t)}thenByDescending(e,t){return yp.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return yp.generateAsync(this,e,!1,t)}}const mp=(e,t)=>yp.generate(e,(e=>e),!0,t),wp=(e,t,n)=>yp.generate(e,t,!0,n),Sp=(e,t,n)=>yp.generateAsync(e,t,!0,n),Ap=(e,t,n)=>yp.generate(e,t,!1,n),_p=(e,t,n)=>yp.generateAsync(e,t,!1,n),Cp=(e,t)=>yp.generate(e,(e=>e),!1,t),Tp=async(e,t)=>{const n=Zd(e,(e=>[t(e),e])),r=await uh(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},Dp=async(e,t)=>{const n=th(e,(async e=>[await t(e),e])),r=await uh(n),o=[],s=[];for(const[e,t]of r)e?s.push(t):o.push(t);return[s,o]},kp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new mi({generator:()=>{const e=n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 2:return new mi({generator:async()=>{const e=await n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 0:return new mi({generator:async()=>{const e=await n.generator();return e.unshift(t),e},type:n.type})}},Ep=e=>{const t=e.dataFunc;switch(t.type){case 1:return new mi({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new mi({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Ip=(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}}},bp=(e,t)=>"function"==typeof t?1===t.length?new mi(Zd(e,t)):new mi(Ip(e,t)):new mi(Zd(e,(e=>e[t]))),Gp=(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}}},Np=(e,t)=>{let n;return n="function"==typeof t?1===t.length?th(e,t):Gp(e,t):th(e,(e=>e[t])),new mi(n)},Rp=(e,t)=>new mi({generator:async()=>{let n;n="function"==typeof t?1===t.length?Zd(e,t):Ip(e,t):Zd(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}),Pp=(e,t)=>new mi({generator:async()=>{let n;n=1===t.length?th(e,t):Gp(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}),Up=async(e,t,n=vi)=>{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},Op=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},Mp=(e,t)=>t?Fp(e,t):xp(e),xp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new fi(gi.MoreThanOneElement);if(0===e.length)throw new fi(gi.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new fi(gi.MoreThanOneElement);if(0===e.length)throw new fi(gi.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new fi(gi.MoreThanOneElement);if(0===e.length)throw new fi(gi.NoElements);return await e[0]}}},Fp=async(e,t)=>{const n=await bh(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new fi(gi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new fi(gi.NoMatch);return o},Lp=async(e,t)=>{const n=await bh(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new fi(gi.MoreThanOneMatchingElement);r=!0,o=e}if(!1===r)throw new fi(gi.NoMatch);return o},Bp=(e,t)=>t?$p(e,t):Wp(e),Wp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new fi(gi.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new fi(gi.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new fi(gi.MoreThanOneElement);return 0===e.length?null:await e[0]}}},$p=async(e,t)=>{const n=await bh(e);let r=!1,o=null;for(const e of n)if(t(e)){if(!0===r)throw new fi(gi.MoreThanOneElement);r=!0,o=e}return o},Vp=async(e,t)=>{const n=await bh(e);let r=!1,o=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new fi(gi.MoreThanOneElement);r=!0,o=e}return o},qp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new mi({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new mi({generator:()=>n.generator().slice(t),type:1});case 2:return new mi({generator:async()=>(await n.generator()).slice(t),type:2})}},Hp=(e,t)=>new mi({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}),Kp=(e,t)=>new mi({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}),jp=(e,t)=>t?Jp(e,t):zp(e),zp=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},Jp=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},Xp=async(e,t)=>{const n=th(e,t),r=await uh(n);let o=0;for(const e of r)o+=e;return o},Yp=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new mi({generator:()=>r.generator().splice(0,n),type:1});case 2:return new mi({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new mi({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},Qp=(e,t)=>new mi({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}),Zp=(e,t)=>new mi({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}),eg=async(e,t)=>{const n=new Map,r=Zd(e,(e=>[t(e),e])),o=await uh(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},tg=async(e,t)=>{const n=new Map,r=th(e,(async e=>[await t(e),e])),o=await uh(r);for(const[e,t]of o){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},ng=async(e,t)=>{const n=e.dataFunc,r=await uh(n),o={};for(const e of r)o[t(e)]=e;return o},rg=async(e,t)=>{const n=th(e,(async e=>[await t(e),e])),r=await uh(n),o={};for(const[e,t]of r)o[e]=t;return o},og=async e=>{const t=e.dataFunc,n=await uh(t);return new Set(n)},sg=(e,t,n)=>n?ag(e,t,n):ig(e,t),ig=(e,t)=>new mi({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}),ag=(e,t,n)=>new mi({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}),cg=(e,t,n)=>new mi({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}),ug=(e,t)=>new mi({generator:async()=>(await e.toArray()).filter(t),type:0}),lg=(e,t)=>new mi({generator:async()=>{const n=Gp(e,(async(e,n)=>[await t(e,n),e])),r=await uh(n),o=[];for(const[e,t]of r)e&&o.push(t);return o},type:0}),dg=(e,t,n)=>n?pg(e,t,n):hg(e,t),hg=(e,t)=>new mi({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}),pg=(e,t,n)=>new mi({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}),gg=(e,t,n)=>new mi({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}),fg=e=>{const t=Si.prototype,n=e.prototype,r=Object.getOwnPropertyNames(t);for(const e of r)n[e]=n[e]??t[e]};hu(wi),(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(pu,"aggregate"),n(yu,"all"),n(mu,"allAsync"),n(wu,"append"),n(Su,"any"),n(Cu,"anyAsync"),n(Tu,"asParallel"),n(Du,"average"),n(ku,"averageAsync"),n(Eu,"chunk"),n(Iu,"concatenate"),n(bu,"contains"),n(Gu,"containsAsync"),n(Nu,"count"),n(Uu,"countAsync"),n(Ou,"defaultIfEmpty"),n(Mu,"distinct"),n(xu,"distinctAsync"),n(Fu,"each"),n(Lu,"eachAsync"),n(Bu,"elementAt"),n(Wu,"elementAtOrDefault"),n($u,"except"),n(Vu,"exceptAsync"),n(qu,"first"),n(ju,"firstAsync"),n(zu,"firstOrDefault"),n(Yu,"firstOrDefaultAsync"),n(Qu,"groupBy"),n(tl,"groupByAsync"),n(ol,"groupByWithSel"),n(al,"groupJoin"),n(ll,"groupJoinAsync"),n(pl,"intersect"),n(gl,"intersectAsync"),n(fl,"joinByKey"),n(vl,"last"),n(wl,"lastAsync"),n(Sl,"lastOrDefault"),n(Cl,"lastOrDefaultAsync"),n(Tl,"max"),n(El,"maxAsync"),n(Il,"min"),n(Nl,"minAsync"),n(Rl,"ofType"),n(Pl,"order"),n(Ul,"orderBy"),n(Ol,"orderByAsync"),n(Ml,"orderByDescending"),n(xl,"orderByDescendingAsync"),n(Fl,"orderDescending"),n(Ll,"partition"),n(Bl,"partitionAsync"),n(Wl,"prepend"),n($l,"reverse"),n(Vl,"select"),n(jl,"selectAsync"),n(Xl,"selectMany"),n(ed,"selectManyAsync"),n(td,"sequenceEquals"),n(nd,"sequenceEqualsAsync"),n(rd,"single"),n(id,"singleAsync"),n(ad,"singleOrDefault"),n(ld,"singleOrDefaultAsync"),n(dd,"skip"),n(hd,"skipWhile"),n(fd,"skipWhileAsync"),n(md,"sum"),n(Ad,"sumAsync"),n(_d,"take"),n(Cd,"takeWhile"),n(kd,"takeWhileAsync"),n(bd,"toArray"),n(Gd,"toMap"),n(Nd,"toMapAsync"),n(Rd,"toObject"),n(Pd,"toObjectAsync"),n(Ud,"toSet"),n(Od,"union"),n(Fd,"unionAsync"),n(Ld,"where"),n($d,"whereAsync"),n(Hd,"zip"),n(zd,"zipAsync")})(yi),(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(Jd,"aggregate"),n(eh,"all"),n(nh,"allAsync"),n(rh,"append"),n(oh,"any"),n(ah,"anyAsync"),n(ch,"asAsync"),n(lh,"average"),n(dh,"averageAsync"),n(hh,"chunk"),n(ph,"concatenate"),n(gh,"contains"),n(fh,"containsAsync"),n(vh,"count"),n(wh,"countAsync"),n(Sh,"defaultIfEmpty"),n(Ah,"distinct"),n(_h,"distinctAsync"),n(Ch,"each"),n(Th,"eachAsync"),n(Dh,"elementAt"),n(kh,"elementAtOrDefault"),n(Eh,"except"),n(Ih,"exceptAsync"),n(Gh,"first"),n(Ph,"firstAsync"),n(Uh,"firstOrDefault"),n(xh,"firstOrDefaultAsync"),n(Fh,"groupBy"),n(Wh,"groupByAsync"),n(qh,"groupByWithSel"),n(jh,"groupJoin"),n(Xh,"groupJoinAsync"),n(jh,"groupJoin"),n(Xh,"groupJoinAsync"),n(Zh,"intersect"),n(ep,"intersectAsync"),n(tp,"joinByKey"),n(np,"last"),n(sp,"lastAsync"),n(ip,"lastOrDefault"),n(up,"lastOrDefaultAsync"),n(lp,"max"),n(dp,"maxAsync"),n(hp,"min"),n(pp,"minAsync"),n(gp,"ofType"),n(mp,"order"),n(wp,"orderBy"),n(Sp,"orderByAsync"),n(Ap,"orderByDescending"),n(_p,"orderByDescendingAsync"),n(Cp,"orderDescending"),n(Tp,"partition"),n(Dp,"partitionAsync"),n(kp,"prepend"),n(Ep,"reverse"),n(bp,"select"),n(Np,"selectAsync"),n(Rp,"selectMany"),n(Pp,"selectManyAsync"),n(Up,"sequenceEquals"),n(Op,"sequenceEqualsAsync"),n(Mp,"single"),n(Lp,"singleAsync"),n(Bp,"singleOrDefault"),n(Vp,"singleOrDefaultAsync"),n(qp,"skip"),n(Hp,"skipWhile"),n(Kp,"skipWhileAsync"),n(jp,"sum"),n(Xp,"sumAsync"),n(Yp,"take"),n(Qp,"takeWhile"),n(Zp,"takeWhileAsync"),n(bh,"toArray"),n(eg,"toMap"),n(tg,"toMapAsync"),n(ng,"toObject"),n(rg,"toObjectAsync"),n(og,"toSet"),n(sg,"union"),n(cg,"unionAsync"),n(ug,"where"),n(lg,"whereAsync"),n(dg,"zip"),n(gg,"zipAsync")})(mi),(()=>{const{prototype:e}=Si,t=Object.getOwnPropertyNames(wi.prototype);for(const n of t)e[n]=e[n]??wi.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 pi("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 fi(gi.NoMatch);return t}if(0===this.length)throw new fi(gi.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 fi(gi.NoMatch)}if(0===this.length)throw new fi(gi.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 fi(gi.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 fi(gi.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 vg,yg;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(vg||(vg={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(yg||(yg={}));class mg{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==mg._devicesService&&(mg._devicesService=ry.Get(zs.ServiceName))}GetDevicesChannelsInGroupAsync(){return e=this,t=arguments,r=function*(e=!1){let t=[],n=[];const r=yield mg._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){ry.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 ry.Get(Ag.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return ry.Get(Ag.ServiceName).ChangeGroupIconNameAsync(this,e)}}var wg,Sg=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 Ag{constructor(){this._connection=null,this._synchronized=!1,this._onSynchronized=new ke,this._groups=[],this._objectsGroupingSupported=!1,this._configurationService=ry.Get(at.ServiceName),this._syncSemaphore=new et(1),this._connection=ry.Get(Ct.ServiceName),ry.Get(Xe.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Sg(this,void 0,void 0,(function*(){yield this.ResyncGroupsAsync()}))))}ResyncGroupsAsync(){return Sg(this,void 0,void 0,(function*(){var e;if(this._syncSemaphore.IsAcquired())return Promise.resolve();yield this._syncSemaphore.AcquireAsync(),this._synchronized=!1,yield this.GetGroupsAsync(!0),this._synchronized=!0,null===(e=this._onSynchronized)||void 0===e||e.Invoke(),this._syncSemaphore.Release()}))}WaitForSynchronizationAsync(){return new Promise(((e,t)=>{if(1==this._synchronized)return e();const n=window.setTimeout((()=>{e()}),3e4);this._onSynchronized.Subscribe((()=>{clearTimeout(n),e()}))}))}SetObjectsInGroupAndOrderAsync(e,t){return Sg(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 Tg(e,s),15e3,!1);switch(null===(r=u.Log)||void 0===r||r.Error(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetObjectsInGroupAndOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),yield ry.Get(zs.ServiceName).GetDevicesAsync(),null==i?void 0:i.Status){case ue.OK:return new Ie(vg.Success,"");case ue.NotSupportedMethod:case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new Ie(vg.FunctionNotSupported,"");case ue.WrongData:return"GroupDoesNotExists"===i.Data?new Ie(vg.GroupDoesNotExists,i.Data):new Ie(vg.FatalError,i.Data);case ue.Error:case ue.FatalError:default:return new Ie(vg.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=ry.Get(c.ServiceName);e.forEach(((e,n)=>{t.Debug(Ag.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=ry.Get(c.ServiceName);n.Debug(Ag.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(Ag.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 Sg(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 Cg(r),15e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeGroupsOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(ry.Get(c.ServiceName).Error(Ag.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 Sg(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 Ig(e.Guid,s),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeObjectsPositionsInGroupAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield ry.Get(zs.ServiceName).GetDevicesAsync(),ue.OK):(null===(o=u.Log)||void 0===o||o.Error(Ag.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 Sg(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 _g(e.Guid,t),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(null===(o=u.Log)||void 0===o||o.Error(Ag.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 Sg(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 Eg(e.Guid,i,n),15e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveObjectInGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==a?void 0:a.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield ry.Get(zs.ServiceName).GetDevicesAsync(),ue.OK):(null===(s=u.Log)||void 0===s||s.Error(Ag.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 Sg(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s,i;const a=new Ug;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(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddDeviceChannelToGroupByGuidAsync()"),this._configurationService.ExitConfigurationModeAsync(),null!=c&&null!=c.Status?(c.Status==ue.OK?e.ChannelGroups.push(t):null===(i=u.Log)||void 0===i||i.Error(Ag.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 ry.Get(zs.ServiceName).GetDevicesAsync()),c.Status):(n||(yield this.GetGroupsAsync(!1),yield ry.Get(zs.ServiceName).GetDevicesAsync()),ue.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){return Sg(this,arguments,void 0,(function*(e,t,n=!1){var r,o,s;const i=new Og;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==ue.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():null===(s=u.Log)||void 0===s||s.Error(Ag.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 ry.Get(zs.ServiceName).GetDevicesAsync(),a.Status):(n||(yield this.GetGroupsAsync(!1)),yield ry.Get(zs.ServiceName).GetDevicesAsync(),ue.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Sg(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 mg))return t instanceof Ie?t:new Ie(yg.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!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Ag.ServiceName,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`),new Ie(yg.UnknownError,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`)}let s=yield ry.Get(zs.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!==ue.OK)return null===(r=u.Log)||void 0===r||r.Error(Ag.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(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpsertGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),new Ie(yg.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 Sg(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!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Ag.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(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}let i=yield ry.Get(zs.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!==ue.OK)return null===(o=u.Log)||void 0===o||o.Error(Ag.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(Ag.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.OK}))}ChangeGroupNameByGuidAsync(e,t){return Sg(this,void 0,void 0,(function*(){var n,r;let o=new Pg,s=new Mg,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 ue.OK:return new Ie(yg.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new Ie(yg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ie(yg.NameAlreadyExists,"Group with this name already exists");default:return new Ie(yg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ie(yg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ie(yg.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){return Sg(this,void 0,void 0,(function*(){var r,o;let s=new Pg,i=new Mg,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 ue.OK:return new Ie(yg.Success,"");case ue.WrongData:switch(c.Data){case"NameToShort":return new Ie(yg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ie(yg.NameAlreadyExists,"Group with this name already exists");default:return new Ie(yg.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Ie(yg.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Ie(yg.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){return Sg(this,void 0,void 0,(function*(){var n,r;let o=new Pg,s=new Mg,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 ue.OK:return new Ie(yg.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new Ie(yg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ie(yg.NameAlreadyExists,"Group with this name already exists");default:return new Ie(yg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ie(yg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ie(yg.UnknownError,"")}))}GetServiceName(){return Ag.ServiceName}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 Sg(this,void 0,void 0,(function*(){var t;let n=new Ng;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:ue.Error}))}GetGroupsAsync(){return Sg(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 Rg,15e3,e);let o=[];if((null==r?void 0:r.Status)===ue.OK){let t=0,s=ry.Get(c.ServiceName),i=yield ry.Get(zs.ServiceName).GetDevicesAsync();return null===(n=r.Data)||void 0===n||n.forEach((n=>{t++;let r=new mg;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(Ag.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),o.push(r)})),this._groups=o,o}return this.GetGroupsAsync(e)}))}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 Sg(this,void 0,void 0,(function*(){var t,n,r;let o=new Pg,s=new Mg;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 ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(r=u.Log)||void 0===r||r.Error(Ag.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new Ie(yg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ie(yg.NameAlreadyExists,"Group with this name already exists");default:return new Ie(yg.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Ie(yg.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Ie(yg.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){return Sg(this,void 0,void 0,(function*(){var n,r,o;let s=new Pg,i=new Mg;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 ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(o=u.Log)||void 0===o||o.Error(Ag.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new Ie(yg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ie(yg.NameAlreadyExists,"Group with this name already exists");default:return new Ie(yg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ie(yg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ie(yg.UnknownError,"")}))}}Ag.ServiceName="ChannelsGroupsService";class _g extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=le.Post,this.Data=new kg,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Cg extends ce{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=le.Post,this.Data=e}}class Tg extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=le.Post,this.Data=new Dg,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Dg{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class kg{constructor(){this.GroupGuid="",this.NewPosition=0}}class Eg extends ce{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=le.Post,this.Data=new bg,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Ig extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=le.Post,this.Data=new Gg,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class bg{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Gg{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Ng extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Delete}}class Rg extends ce{constructor(){super(),this.Resource="/devices/groups/",this.Method=le.Get}}class Pg extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Put,this.Data=[]}}class Ug extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Put,this.Data=new xg}}class Og extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Delete,this.Data=new xg}}class Mg{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class xg{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Fg{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}!function(e){e[e.Suspended=1]="Suspended",e[e.ReturnedFromSuspension=2]="ReturnedFromSuspension",e[e.EnteredLowPowerMode=3]="EnteredLowPowerMode",e[e.ExitedLowPowerMode=4]="ExitedLowPowerMode",e[e.LoggedIn=5]="LoggedIn",e[e.LoggedOut=6]="LoggedOut",e[e.Connected=7]="Connected",e[e.Disconnected=8]="Disconnected",e[e.FailedToConnect=9]="FailedToConnect",e[e.Connecting=10]="Connecting",e[e.Disconnecting=11]="Disconnecting",e[e.Reconnecting=12]="Reconnecting"}(wg||(wg={}));var Lg,Bg,Wg,$g,Vg,qg,Hg,Kg,jg,zg,Jg,Xg=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 Yg{constructor(){this._isConnectedAndAuthorized=!1,this._syncLock=new Fg,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=wg.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new ke,this._onSuspendedEvent=new ke,this._onEnterLowPowerModeEvent=new ke,this._onExitLowPowerModeEvent=new ke,this._onBackButtonPressedEvent=new ke,this._onForwardButtonPressedEvent=new ke,this._onAppStateChanged=new a,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>Xg(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(Yg.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=u.Log)||void 0===r||r.Warning(Yg.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return Xg(this,void 0,void 0,(function*(){this._session=yield ry.GetAsync("SessionService"),this._connection=yield ry.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Yg.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(wg.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Yg.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(wg.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,o,s,i;switch(e){case pe.ConnectedAndAuthorized:null===(t=u.Log)||void 0===t||t.Warning(Yg.ServiceName,"App state changed to: connected"),this._isConnectedAndAuthorized=!0,this._onAppStateChanged.Invoke(wg.Connected);break;case pe.Disconnected:null===(n=u.Log)||void 0===n||n.Warning(Yg.ServiceName,"App state changed to: disconnected"),this._isConnectedAndAuthorized&&this._onAppStateChanged.Invoke(wg.Disconnected),this._isConnectedAndAuthorized=!1;break;case pe.Connecting:null===(r=u.Log)||void 0===r||r.Warning(Yg.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(wg.Connecting);break;case pe.Disconnecting:null===(o=u.Log)||void 0===o||o.Warning(Yg.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(wg.Disconnecting);break;case pe.Reconnecting:null===(s=u.Log)||void 0===s||s.Warning(Yg.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(wg.Reconnecting);break;case pe.Failed:null===(i=u.Log)||void 0===i||i.Warning(Yg.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(wg.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(wg.Suspended),null===(e=u.Log)||void 0===e||e.Warning(Yg.ServiceName,"App state changed to: suspended"),null===(t=u.Log)||void 0===t||t.Warning(Yg.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(wg.ReturnedFromSuspension),null===(e=u.Log)||void 0===e||e.Warning(Yg.ServiceName,"App state changed to: returned from suspension"),null===(t=u.Log)||void 0===t||t.Warning(Yg.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(wg.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(wg.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 Yg.ServiceName}}Yg.ServiceName="AppStateService";class Qg{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class Zg{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class ef{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class tf{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(Lg||(Lg={})),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"}(Bg||(Bg={})),(Jg=Wg||(Wg={}))[Jg.WaitingForUser=1]="WaitingForUser",Jg[Jg.Downloading=2]="Downloading",Jg[Jg.Unpackaging=3]="Unpackaging",Jg[Jg.CheckingApplicability=4]="CheckingApplicability",Jg[Jg.MigratingData=5]="MigratingData",Jg[Jg.CreatingBackup=6]="CreatingBackup",Jg[Jg.Deploying=7]="Deploying",Jg[Jg.Installing=8]="Installing",Jg[Jg.Removing=9]="Removing",Jg[Jg.Error=10]="Error",Jg[Jg.ReadyToDownload=11]="ReadyToDownload",Jg[Jg.PreparingSystem=12]="PreparingSystem",Jg[Jg.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",Jg[Jg.CheckingIntegrity=14]="CheckingIntegrity",Jg[Jg.UndoingInstallation=15]="UndoingInstallation",Jg[Jg.Installed=16]="Installed",(zg=$g||($g={}))[zg.Ignore=0]="Ignore",zg[zg.Cancel=1]="Cancel",zg[zg.Install=2]="Install";class nf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=Bg.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class rf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=Hg.Unknown,this.DownloadOnly=!1}}class of{constructor(){this.BulkUpdateStatus=Vg.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"}(Vg||(Vg={})),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"}(qg||(qg={})),function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate",e[e.UpdateDownloadedAndChecked=4]="UpdateDownloadedAndChecked"}(Hg||(Hg={})),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"}(Kg||(Kg={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(jg||(jg={}));var sf,af,cf,uf,lf,df,hf,pf,gf,ff=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._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=15,this._updateProviders=ry.Get(ss.ServiceName),this._logger=ry.Get(c.ServiceName),this._connection=ry.Get(Ct.ServiceName),this._appStateService=ry.Get(Yg.ServiceName),this._extensionService=ry.Get(nt.ServiceName)}IsBranchAndAutomaticUpdatesSettingSupportedAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ie)return!1;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);return!(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)}))}DownloadControllerUpdateAsync(e){return ff(this,void 0,void 0,(function*(){try{const t=yield this.getRuntimeInfoAsync();if(t instanceof Ie)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);return n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild?new Ie(Kg.FeatureUnsupportedInCurrentVersion,`Cannot download update, feature unsupported in current version. Current version: ${t}`):yield this.DownloadControllerUpdateUsingApiAsync((()=>{}),e,!0)}catch(e){return new Ie(Kg.CannotProcessUpdate,`Failed to download controller update: ${e}`)}}))}InstallControllerOrRadioUpdateAsync(e,t,n){return ff(this,void 0,void 0,(function*(){const r=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),o=this._controllerUpdates.length,s=yield this.getRuntimeInfoAsync();if(s instanceof Ie)return s;const i=parseInt(s.SoftwareVersion.toString().split(".")[0]),a=parseInt(s.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ie(Kg.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if(void 0===n||"string"!=typeof n||!r.test(n)){const r=[1],s=t=>{t.UpdateNumber=r[0],t.AvailableUpdates=o,e(t)},c=e=>ff(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let u=this._controllerUpdates.where((e=>e.UpdateType==Lg.RadioUpdate)).toArray(),l=[];this._appStateService.DisallowHibernation();for(let e=0;e<u.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(u[e].ProviderName)).InstallRadioUpdateAsync(u[e],s);yield c(5e3),t==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=u[e].UpdateIdentifier))),l.push(t),r[0]++}const d=this._controllerUpdates.find((e=>e.UpdateType==Lg.SoftwareUpdate));if(null!=d)if(i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(d.Update,s);e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=d.UpdateIdentifier))),l.push(e),r[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(s,t,!1);this._appStateService.AllowHibernation(),e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),l.push(e),r[0]++}const h=l.where((e=>e instanceof Ie)).toArray();if(null!=h&&0!=h.length){let e="";return h.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),h.any((e=>e.Type==Kg.UpdateDownloadFailed))?new Ie(Kg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ie(Kg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let r;const o=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==o)return new Ie(Kg.CannotGetUpdates,`Update with requested guid (${n}) not found.`);switch(this._logger.Debug(`Installing single update type: ${o.Update.UpdateType}, resource: ${o.UpdatedResourceName}, version: ${o.Update.Version}`),this._appStateService.DisallowHibernation(),o.UpdateType){case Lg.RadioUpdate:return r=yield(yield this._updateProviders.GetUpdatesProviderAsync(o.ProviderName)).InstallRadioUpdateAsync(o,e),this._appStateService.AllowHibernation(),this._logger.Debug(`Radio update result: ${r}`),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),r;case Lg.SoftwareUpdate:return i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild?(r=yield this.UpdateControllerUsingScriptAsync(o.Update,e),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))):(yield this.CheckControllerUpdatesAsync(),r=yield this.UpdateControllerUsingApiAsync(e,t,!1),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))),r;default:return new Ie(Kg.CannotProcessUpdate,`Update with type ${o.UpdateType} is not supported by UpdateService.`)}}}))}GetAutomaticControllerUpdateDownloadStatusAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ie)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 Ie(Kg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new Rf,1e4,!1);return!(r.Status!=ue.OK||!r.Data)}))}GetServiceName(){return vf.ServiceName}CheckDeviceVersionAsync(e){return ff(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield ry.Get(zs.ServiceName).GetDevice(e);if(null==t)return new Ie(Kg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ie(Kg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Go.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){return ff(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield ry.Get(zs.ServiceName).GetDevice(e);if(null==t)return new Ie(Kg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ie(Kg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Go.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const o=new wf;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 ry.Get(zs.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(o.IsUpdateSafe=!1),o}))}CheckDeviceUpdatesBulkAsync(e){return ff(this,void 0,void 0,(function*(){const t=yield yield this._updateProviders.GetUpdatesProvidersAsync(Go.Device),n=[];for(var r of t){const t=yield r.CheckUpdateBulkAsync(e);if(t instanceof Ie)return t;t.map((e=>ff(this,void 0,void 0,(function*(){const t=new wf;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 ff(this,arguments,void 0,(function*(e,t,n,r=!1){var o;let s;if("string"==typeof e){const t=yield ry.Get(zs.ServiceName).GetDevice(e);if(null==t)return new Ie(Kg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);s=t}else s=e;if(null==s.ProtocolGuid)return new Ie(Kg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(o=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(s.ProtocolGuid,Go.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,Go.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ue.OK)}))}InstallDevicesUpdateBulkAsync(e,t,n){return ff(this,void 0,void 0,(function*(){const r=(yield ry.Get(zs.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,Go.Device),d=yield l.first().InstalUpdateBulkAsync(i.select((e=>e.Guid)).toArray(),u,n);if(d instanceof Ie)return d;o.push(d)}if(this._appStateService.AllowHibernation(),1==o.length)return o[0];{const e=new of;o.some((e=>e.DevicesUpdateResults.count()>0))&&o.any((e=>e.BulkUpdateStatus!=Vg.Success))?e.BulkUpdateStatus=Vg.PartialSuccess:o.any((e=>e.BulkUpdateStatus!=Vg.Success))?e.BulkUpdateStatus=o.first().BulkUpdateStatus:e.BulkUpdateStatus=Vg.Success;for(const t of o)t.DevicesUpdateResults.forEach(((t,n)=>{e.DevicesUpdateResults.set(n,t)}));return e}}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return ff(this,void 0,void 0,(function*(){const e=ry.Get(Xe.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 If,1e4,!1);if(null==r||r.Status!=ue.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 ry.Get(at.ServiceName).CheckIfControllerSoftwareVersionIsEnough(6,66)}CancelFailedControllerUpdateAsync(){return ff(this,void 0,void 0,(function*(){switch((yield this._connection.SendAndWaitForResponseAsync(new kf,1e4,!1)).Status){case ue.OK:return ue.OK;case ue.OperationNotPermitted:return ue.OperationNotPermitted;case ue.Error:default:return ue.Error}}))}CheckControllerPendingUpdateProgressAsync(e,t){return ff(this,void 0,void 0,(function*(){return new Promise(((n,r)=>ff(this,void 0,void 0,(function*(){var o;const s=ry.Get(Xe.ServiceName).User;if(null==s)return new Ie(Kg.UpdateActionsNotSupported,"No user data found, cannot check pending update progress.");if(""==s.SoftwareVersion||null==s.SoftwareVersion)return new Ie(Kg.CannotGetCurrentControllerVersion,"No software version data found, cannot check pending update progress.");const[i,a]=s.SoftwareVersion.split(".");if(parseFloat(i)<this._oldUpdateVersion||parseFloat(i)==this._oldUpdateVersion&&parseFloat(a)<=this._oldUpdateBuild)return new Ie(Kg.UnsupportedApiVersion,"Not supported API version, cannot check pending update progress.");const c=yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1);if(c.Status!=ue.OK)return new Ie(Kg.CannotGetUpdates,"No pending updates found.");let u=null===(o=c.Data)||void 0===o?void 0:o.DownloadOnly,l=100;const d=60*this._updateOfflineStageTime*1e3;let h=0;const p=new nf;let g=50,f=new rf,v=new nf,y=!1;u||(f.DownloadOnly=u,g=100);let m=100/g;const w=n=>{let r=n.Data;switch(this._logger.Debug(`Update progress: ${r.UpdateStep}, ${r.StepProgressInPercentage}%, ${r.UpdateProgressInPercentage}% data frame status: ${n.Status}`),p.Percentage=Math.round(r.StepProgressInPercentage),p.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=r.DownloadSpeedInMbs,f.Percentage=Math.round(r.StepProgressInPercentage),f.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),v.AvailableUpdates=1,v.Percentage=r.StepProgressInPercentage,v.PercentageTotal=r.UpdateProgressInPercentage,v.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),h=r.StepProgressInPercentage,r.UpdateStep){case uf.DownloadingInstaller:f.CurrentTask=Hg.DownloadingInstaller,v.Status=Bg.DownloadingPackage,t(f);break;case uf.DownloadingUpdate:f.CurrentTask=Hg.DownloadingUpdate,v.Status=Bg.DownloadingPackage,t(f);break;case uf.CheckingUpdate:f.CurrentTask=Hg.CheckingUpdate,v.Status=Bg.CheckingPackage,e(v);break;case uf.PreparingUpdate:v.Status=Bg.PreparingForUpgrade,f.CurrentTask=Hg.CheckingUpdate,e(v);break;case uf.OfflineUpdateStep:case uf.InstallingUpdate:v.Status=Bg.Upgrading,e(v);break;case uf.InstallerFileSignCheckFailed:case uf.UpdateFileSignCheckFailed:v.Status=Bg.InstallationError,e(v);break;case uf.UpdateDownloadFailed:v.Status=Bg.InstallationStopped,e(v);break;case uf.UpdateInstallationFailed:v.Status=Bg.InstallationError,e(v);break;case uf.UpdateFileCheckFailed:v.Status=Bg.IncompatiblePackage,e(v);break;case uf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round(r.UpdateProgressInPercentage*m):Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Hg.CheckingUpdate,t(f),f.CurrentTask=Hg.UpdateDownloadedAndChecked,t(f)}};let S=null;const A=t=>ff(this,void 0,void 0,(function*(){t==wg.Connected&&(clearInterval(S),p.Status=Bg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),yield se.Delay(5e3),n(ue.OK),ry.Get(Yg.ServiceName).OnAppStateChanged().Unsubscribe(A))}));yield this._connection.SendAndHandleResponseAsync(new Ef,1e5,(o=>{var s,i,a,c,g;switch(o.Status){case ue.MultiDataResponseStart:y||(l=(null===(s=o.Data)||void 0===s?void 0:s.UpdateStep)==uf.UpdateDownloaded?100:50,y=!0),w(o);break;case ue.MultiDataResponse:w(o);break;case ue.MultiDataResponseStop:switch(null===(i=o.Data)||void 0===i?void 0:i.UpdateStep){case uf.UpdateInstallationFailed:v.Status=Bg.InstallationError,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new Ie(Kg.CannotProcessUpdate,"Update installation failed!"));break;case uf.InstallerFileSignCheckFailed:case uf.UpdateFileSignCheckFailed:case uf.UpdateDownloadFailed:case uf.UpdateFileCheckFailed:v.Status=Bg.DownloadingFailure,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new Ie(Kg.UpdateDownloadFailed,"Update download failed!"));break;case uf.OfflineUpdateStep:w(o),p.Percentage=Math.round(o.Data.StepProgressInPercentage),p.PercentageTotal=Math.round(o.Data.UpdateProgressInPercentage);let r=(100-p.PercentageTotal)/100,s=p.PercentageTotal;S=setInterval((()=>{h++,s+=r,s>100&&(s=100),h>=l?(p.Status=Bg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),n(ue.OK)):(p.Status=Bg.Upgrading,p.Percentage=Math.round(h),p.PercentageTotal=Math.round(s),e(p))}),d/(l-h)),ry.Get(Yg.ServiceName).OnAppStateChanged().Subscribe(A);break;case uf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round((null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)*m):Math.round(null===(c=o.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Hg.CheckingUpdate,t(f),f.CurrentTask=Hg.UpdateDownloadedAndChecked,t(f),u&&n(ue.OK);break;default:w(o),n(new Ie(Kg.CannotProcessUpdate,`Update installation failed, received UpdateStep code: ${null===(g=o.Data)||void 0===g?void 0:g.UpdateStep}!`))}break;default:r(new Ie(Kg.CannotGetUpdates,`Cannot get pending update progress, response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`))}}),!0)}))))}))}CheckDevicesUpdatesAvailabilityAsync(){return ff(this,void 0,void 0,(function*(){const e=ry.Get(Xe.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 Mf,1e4,!1),o=[];return null==r||(null==r?void 0:r.Status)!=ue.OK||null==(null==r?void 0:r.Data)?[]:(null==r||r.Data.forEach((e=>{if(!e.IsAvailable)return;const t=new Qg;t.DeviceGuid=e.DeviceGuid,t.CurrentVersion=e.CurrentVersion,t.NewVersion=e.NewVersion,o.push(t)})),o)}))}CheckControllerUpdatesAsync(){return ff(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new Zg,n=yield this.getRuntimeInfoAsync();if(n instanceof Ie){const e=new yf;return e.UpdateType=Lg.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(Go.Controller)}catch(e){if(!(e instanceof Lo))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 yf;o.ResponseResult=r,o.UpdateType=Lg.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 mf;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=Lg.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:Lg.RadioUpdate}))}}let s=!0;if((r<this._oldUpdateVersion||r===this._oldUpdateVersion&&o<=this._oldUpdateBuild)&&(s=!1),s){const e=yield this._connection.SendAndWaitForResponseAsync(new If,15e3,!1);if(null==e||e.Status!=ue.OK&&e.Status!=ue.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 Fo;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 mf;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=Lg.SoftwareUpdate,o.UpdateIdentifier=e.Data.Update.Guid,o.UpdateIsDownloading=e.Data.UpdateStep==uf.DownloadingInstaller||e.Data.UpdateStep==uf.DownloadingUpdate||e.Data.UpdateStep==uf.CheckingUpdate,o.DownloadProgress=e.Data.DownloadProgress,o.UpdateCreationTime=e.Data.Update.Creationtime,o.IsDownloadOnly=e.Data.DownloadOnly,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:vf.ServiceName,UpdateType:Lg.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new bf,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ue.NoData:const r=new yf;r.UpdateType=Lg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ie(Kg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ue.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const o=new Fo;o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateDescription=ie(e.Data.UpdateDescription),o.UpdatedResourceName=ie(e.Data.UpdateName).get("en-US");const s=new mf;s.UpdatedResourceName=ie(e.Data.UpdateName),s.UpdateDescription=ie(e.Data.UpdateDescription),s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateType=Lg.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:vf.ServiceName,UpdateType:Lg.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 Fo;const i=new yf;switch(i.UpdateType=Lg.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 Ie(Kg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Ie(Kg.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 mf;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=Lg.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:vf.ServiceName,UpdateType:Lg.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 Ie){const e=new yf;e.UpdateType=Lg.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new yf;r.UpdateType=Lg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ie(Kg.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Go.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Ie)return t;const n=[];let r;r=new tf,r.Resource="Controller software",r.Type=Lg.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new tf,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=Lg.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 ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ie)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 Ie(Kg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Tf,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ue.OK)return new Ie(Kg.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 jg.Public;case 1:return jg.Beta;case 2:return jg.Development;default:return new Ie(Kg.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return ff(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Ie)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 Ie(Kg.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const o=yield this._connection.SendAndWaitForResponseAsync(new Df(e),1e4,!1);return null==o||(null==o?void 0:o.Status)!=ue.OK?new Ie(Kg.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==o?void 0:o.Status}`):ue.OK}))}EnableAutomaticControllerUpdateDownloadAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ie)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 Ie(Kg.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Pf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ue.OK?new Ie(Kg.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}DisableAutomaticControllerUpdateDownloadAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ie)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 Ie(Kg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Uf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ue.OK?new Ie(Kg.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}GetControllerUpdatesHistoryAsync(){return ff(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ie)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 Ie(Kg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Of,1e4,!1);if(null==r)return new Ie(Kg.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ue.OK:return null!=r.Data?r.Data.map((e=>{const t=new ef;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 Ie(Kg.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ue.NoData:return[];default:return new Ie(Kg.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,o){return ff(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 Ie)return a;const c=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ie(Kg.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=>ff(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==Lg.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==ue.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==Lg.SoftwareUpdate));if(null!=h)if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,s);e==ue.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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),d.push(e),o[0]++}const p=d.where((e=>e instanceof Ie)).toArray();if(null!=p&&0!=p.length){let e="";return p.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),p.any((e=>e.Type==Kg.UpdateDownloadFailed))?new Ie(Kg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ie(Kg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let s;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Ie(Kg.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 Lg.RadioUpdate:return r?new Ie(Kg.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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),s);case Lg.SoftwareUpdate:if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new Ie(Kg.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");s=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),s==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else{let o=(yield this.CheckControllerUpdatesAsync()).UpdatesAvailable.any((e=>e.IsDownloadOnly));s=yield this.UpdateControllerUsingApiAsync(e,t,!o&&r),this._appStateService.AllowHibernation(),s==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}return s;default:return new Ie(Kg.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){return ff(this,void 0,void 0,(function*(){var n,r,o,s,i,a;switch(e.UpdateType){case No.Container:case No.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Sf(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new nf;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ue.MultiDataResponseStart:r.Status=Bg.PreparingForUpgrade;break;case ue.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(vf.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case Wg.CheckingApplicability:case Wg.CheckingIntegrity:case Wg.CheckingPackageIntegrity:r.Status=Bg.CheckingPackage;break;case Wg.CreatingBackup:case Wg.MigratingData:case Wg.Removing:r.Status=Bg.MovingData;break;case Wg.Deploying:case Wg.Installing:r.Status=Bg.Upgrading;break;case Wg.Downloading:r.Status=Bg.DownloadingPackage;break;case Wg.Error:r.Status=Bg.Error;break;case Wg.Installed:r.Status=Bg.Upgraded;break;case Wg.PreparingSystem:case Wg.ReadyToDownload:r.Status=Bg.PreparingForUpgrade;break;case Wg.UndoingInstallation:r.Status=Bg.InstallationStopped;break;case Wg.Unpackaging:r.Status=Bg.MovingData;break;case Wg.WaitingForUser:r.Status=Bg.Upgrading}break;case ue.MultiDataResponseStop:r.Status=Bg.OK;break;case ue.Error:case ue.FatalError:r.Status=Bg.Error}t(r)}),!1),ue.OK}catch(e){return new Ie(Kg.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case No.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 Ie)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield ry.Get(zs.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(vf.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new nf;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=Bg.PreparingForUpgrade,t(r);let o=2;const s=Date.now(),i=900*c+16e5,a=i/100,u=s+i,l=new Promise(((s,c)=>ff(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=Bg.Upgraded,t(r),s(ue.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=Bg.Upgraded,t(r),s(ue.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=Bg.Upgraded,t(r),s(ue.OK);else{var e=o;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=Bg.Upgrading,t(r))}o++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Af(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ue.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Bg.InstallationError,t(r),this._logger.Debug(vf.ServiceName,`Update failed with error. Update response status: ${d.Status}`),s(new Ie(Kg.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(vf.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Bg.Error,t(r),clearInterval(n),s(new Ie(Kg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new nf;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Bg.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Ie(Kg.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new _f({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ue.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Bg.PreparingForUpgrade,t(n);let r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Cf("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ue.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=Bg.PreparingForUpgrade,t(n),r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Cf(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ue.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Bg.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Cf("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ue.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Bg.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)=>ff(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=Bg.Upgraded,t(n),s(ue.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=Bg.Upgraded,t(n),s(ue.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=Bg.Upgraded,t(n),s(ue.OK);else{var i=5+r*o;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=Bg.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Cf("/runtime/tmp/update.sh"),12e3,!1)}catch(e){s(new Ie(Kg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=Bg.InstallationError,t(n),new Ie(Kg.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Cf("/runtime/scripts/restart_all.sh"),12e3,!1),new Ie(Kg.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Ie(Kg.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Ie(Kg.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Ie(Kg.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}DownloadControllerUpdateNewApiAsync(e,t,n,r){return ff(this,void 0,void 0,(function*(){return new Promise(((t,o)=>ff(this,void 0,void 0,(function*(){let o=50;r||(o=100);let s=100/o;yield this._connection.SendAndHandleResponseAsync(new Gf,this._updateRequestTimeout,(o=>{var i,a,c,u,l,d;const h=new rf;switch(h.DownloadOnly=r,h.UpdatedResourceName=ie(e.Update.UpdateName),o.Status){case ue.MultiDataResponseStart:h.Percentage=0,h.SpeedMbps=0,h.PercentageTotal=0,h.CurrentTask=Hg.DownloadingInstaller,n(h);break;case ue.MultiDataResponse:if(null!=o.Data){switch(h.Percentage=o.Data.StepProgressInPercentage,h.SpeedMbps=o.Data.DownloadSpeedInMbs,h.PercentageTotal=r?Math.round((null===(i=o.Data)||void 0===i?void 0:i.UpdateProgressInPercentage)*s):Math.round(null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage),o.Data.UpdateStep){case uf.DownloadingInstaller:h.CurrentTask=Hg.DownloadingInstaller;break;case uf.DownloadingUpdate:h.CurrentTask=Hg.DownloadingUpdate;break;case uf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(c=o.Data)||void 0===c?void 0:c.UpdateProgressInPercentage)*s):Math.round(null===(u=o.Data)||void 0===u?void 0:u.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Hg.CheckingUpdate,n(h),h.CurrentTask=Hg.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;default:h.CurrentTask=Hg.CheckingUpdate}n(h)}break;case ue.MultiDataResponseStop:if(null!=o.Data)switch(o.Data.UpdateStep){case uf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(l=o.Data)||void 0===l?void 0:l.UpdateProgressInPercentage)*s):Math.round(null===(d=o.Data)||void 0===d?void 0:d.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Hg.CheckingUpdate,n(h),h.CurrentTask=Hg.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;case uf.UpdateDownloadFailed:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Hg.Unknown,n(h),t(new Ie(Kg.UpdateDownloadFailed,"Update download failed!"))}break;case ue.Error:case ue.FatalError:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Hg.Unknown,n(h),t(new Ie(Kg.CannotProcessUpdate,"Update download failed!"))}}),!1)}))))}))}InstallUpdateNewApiAsync(e,t,n,r){return ff(this,void 0,void 0,(function*(){return new Promise(((n,r)=>ff(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let o=0;const s=new nf;let i=null;e.DownloadOnly=!1;const a=e=>ff(this,void 0,void 0,(function*(){e==wg.Connected&&(clearInterval(i),s.Status=Bg.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),yield se.Delay(5e3),n(ue.OK),ry.Get(Yg.ServiceName).OnAppStateChanged().Unsubscribe(a))}));yield this._connection.SendAndHandleResponseAsync(new Nf,this._updateRequestTimeout,(c=>{var u,l;switch(s.UpdatedResourceName=ie(e.Update.UpdateName),c.Status){case ue.MultiDataResponseStart:s.Status=Bg.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 ue.MultiDataResponse:null!=c.Data&&(s.Status=Bg.Upgrading,s.Percentage=Math.round(c.Data.StepProgressInPercentage),s.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage),o=c.Data.StepProgressInPercentage,t(s));break;case ue.MultiDataResponseStop:if(null!=c.Data)switch(c.Data.UpdateStep){case uf.UpdateInstallationFailed:s.Status=Bg.InstallationError,s.Percentage=0,s.PercentageTotal=0,t(s),n(new Ie(Kg.CannotProcessUpdate,"Update installation failed!"));break;case uf.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=Bg.Upgraded,s.Percentage=100,s.PercentageTotal=100,t(s),clearInterval(i),n(ue.OK)):(s.Status=Bg.Upgrading,s.Percentage=Math.round(o),s.PercentageTotal=Math.round(u),t(s))}),r/(100-o)),ry.Get(Yg.ServiceName).OnAppStateChanged().Subscribe(a)}}break;case ue.Error:case ue.FatalError:s.Status=Bg.Error,s.Percentage=0,s.PercentageTotal=0,t(s),n(new Ie(Kg.CannotProcessUpdate,"Update installation failed!"))}}),!1)}))))}))}InstallControllerUpdateUsingApiAsync(e,t){return ff(this,void 0,void 0,(function*(){const n=yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1);if((null==n?void 0:n.Status)==ue.NoData)return new Ie(Kg.DeviceIsUpToDate,"No updates available!");if(null==n||(null==n?void 0:n.Status)!=ue.OK||null==(null==n?void 0:n.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==n?void 0:n.Status}`);switch(n.Data.UpdateStep){case uf.DownloadingInstaller:case uf.DownloadingUpdate:return new Ie(Kg.UpdateAlreadyDownloaded,"Update already downloaded, or download in progress.");case uf.InstallingUpdate:case uf.PreparingUpdate:return new Ie(Kg.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case uf.UpdateDownloaded:return n.Data.DownloadOnly=!1,yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1);default:this._logger.Debug(vf.ServiceName,`Installing update using new API. Update step: ${n.Data.UpdateStep} downloadOnly: false`),n.Data.DownloadOnly=!1;var r=yield this.DownloadControllerUpdateNewApiAsync(n.Data,e,t,!1);return r!=ue.OK?r:yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1)}}))}DownloadControllerUpdateUsingApiAsync(e,t,n){return ff(this,void 0,void 0,(function*(){const r=yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1);if((null==r?void 0:r.Status)==ue.NoData)return new Ie(Kg.DeviceIsUpToDate,"No updates available!");if(null==r||(null==r?void 0:r.Status)!=ue.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 uf.DownloadingInstaller:case uf.DownloadingUpdate:case uf.UpdateDownloaded:return new Ie(Kg.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case uf.InstallingUpdate:case uf.PreparingUpdate:return new Ie(Kg.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield this.DownloadControllerUpdateNewApiAsync(r.Data,e,t,n)}}))}UpdateControllerUsingApiAsync(e,t,n){return ff(this,void 0,void 0,(function*(){return n?yield this.DownloadControllerUpdateUsingApiAsync(e,t,!0):yield this.InstallControllerUpdateUsingApiAsync(e,t)}))}getRuntimeInfoAsync(){return ff(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof ls&&e.code==Bo.Timeout?new Ie(Kg.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Ie(Kg.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}vf.ServiceName="UpdatesService";class yf{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class mf{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,this._isDownloadOnly=!1}get IsDownloadOnly(){return this._isDownloadOnly}set IsDownloadOnly(e){this._isDownloadOnly=e}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 wf{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 Sf extends ce{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=le.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"}(sf||(sf={})),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"}(af||(af={})),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"}(cf||(cf={})),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"}(uf||(uf={}));class Af extends ce{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=le.Put,this.Data=e}}class _f extends ce{constructor(e){super(),this.Resource="/users/user/login",this.Method=le.Put,this.Data=e}}class Cf extends ce{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=le.Post,this.Data=e}}class Tf extends ce{constructor(){super(),this.Resource="/updates/branch",this.Method=le.Get}}class Df extends ce{constructor(e){super(),this.Resource="/updates/branch",this.Method=le.Put,this.Data=e}}class kf extends ce{constructor(){super(),this.Resource="/updates/failed/cancel",this.Method=le.Put}}class Ef extends ce{constructor(){super(),this.Resource="/updates/pending/progress",this.Method=le.Get}}class If extends ce{constructor(){super(),this.Resource="/updates/pending",this.Method=le.Get}}class bf extends ce{constructor(){super(),this.Resource="/updates/check",this.Method=le.Get}}class Gf extends ce{constructor(){super(),this.Resource="/updates/download",this.Method=le.Post}}class Nf extends ce{constructor(){super(),this.Resource="/updates/install",this.Method=le.Post}}class Rf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=le.Get}}class Pf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=le.Put}}class Uf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=le.Put}}class Of extends ce{constructor(){super(),this.Resource="/updates/history",this.Method=le.Get}}class Mf extends ce{constructor(){super(),this.Resource="/updates/devices/availability",this.Method=le.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"}(lf||(lf={})),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",e[e.ThisHour=7]="ThisHour",e[e.ThisDay=8]="ThisDay",e[e.ThisWeek=9]="ThisWeek",e[e.ThisMonth=10]="ThisMonth",e[e.ThisYear=11]="ThisYear"}(df||(df={})),function(e){e[e.Day=0]="Day",e[e.Week=1]="Week",e[e.Month=2]="Month",e[e.Year=3]="Year",e[e.Hour=4]="Hour"}(hf||(hf={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(pf||(pf={}));class xf{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"}(gf||(gf={}));var Ff,Lf,Bf,Wf,$f,Vf,qf,Hf=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 Kf{constructor(){this.DELIM=";",this._connection=null,this._connection=ry.Get(Ct.ServiceName)}numToCsv(e){const t="string"==typeof e?Number(e.replace(",",".")):e;return Number.isFinite(t)?t.toLocaleString("en-US",{useGrouping:!1}):""}quoteIfNeeded(e){return e.includes(this.DELIM)||e.includes('"')?`"${e.replace(/"/g,'""')}"`:e}ExportPressureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`PressureHistory_${e.Name}_${t}.csv`)}ExportBrightnessToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return;const o=[],s=(n.Data[0],["Time","AggregatedBy"]);s.push("LuxValue","LuxToLinearScale","LightCondition"),o.push(s.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r;const s=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(s.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LuxValue)),s.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.LuxToLinearScale)),s.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.LightCondition))),o.push(s.join(this.DELIM))})),ae(o.join("\n"),`BrightnessHistory_${e.Name}_${t}.csv`)}ExportHumidityToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`HumidityHistory_${e.Name}_${t}.csv`)}ExportWindSpeedToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`WindSpeedHistory_${e.Name}_${t}.csv`)}ExportTemperatureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`TemperatureHistory_${e.Name}_${t}.csv`)}ExportAveragingStateValuesToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return"";const o=[],s=(n.Data[0],["Time","AggregatedBy"]);return s.push("LastValue","Average","Mode","Min","Max"),o.push(s.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r,s,i;const a=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(a.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LastValue)),a.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.Average)),a.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.Mode)),a.push(this.numToCsv(null===(s=e.Values)||void 0===s?void 0:s.Min)),a.push(this.numToCsv(null===(i=e.Values)||void 0===i?void 0:i.Max))),o.push(a.join(this.DELIM))})),o.join("\n")}ExportEnergyToCsv(e,t,n){var r,o;let s=n.Data;if(!(null==s?void 0:s.length))return;const i=[],a=s[0],c=["Time","AggregatedBy"];null===(r=a.Values)||void 0===r||r.MeasurementAveragingParameters.forEach(((e,t)=>{c.push(`${t}:LastValue`,`${t}:Average`,`${t}:Mode`,`${t}:Min`,`${t}:Max`)})),null===(o=a.Values)||void 0===o||o.MeasurementNonAveragingParmeters.forEach(((e,t)=>c.push(`${t}`))),i.push(c.join(this.DELIM)),s.forEach((e=>{var t,n;const r=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null===(t=e.Values)||void 0===t||t.MeasurementAveragingParameters.forEach((e=>{r.push(this.numToCsv(e.LastValue),this.numToCsv(e.Average),this.numToCsv(e.Mode),this.numToCsv(e.Min),this.numToCsv(e.Max))})),null===(n=e.Values)||void 0===n||n.MeasurementNonAveragingParmeters.forEach((e=>r.push(this.numToCsv(e)))),i.push(r.join(this.DELIM))})),ae(i.join("\n"),`EnergyHistory_${e.Name}_${t}.csv`)}GetStatesByTimeRangeAsync(e,t,n,r,o,s,i){return Hf(this,arguments,void 0,(function*(e,t,n,r,o,s,i,a=!1){var c;try{if(!(yield this.DoesSupportPreciseTimeFramesAsync()))return new Ie(lf.FunctionalityNotSupported,"State history data in time range is not supported with this version of controller software, update software to get this functionality.");let u;if("string"==typeof e){const t=yield ry.Get(zs.ServiceName).GetDevice(e);if(null==t)return new Ie(lf.CannotFindDevice,`Device with specified GUID ${e} does not exist.`);u=t}else u=e;if(!u.Channels.any((e=>e.Number===t)))return new Ie(lf.InvalidChannelNumber,`Given channel not found in device with guid: ${u.Guid}.`);if(!u.Channels.any((e=>e.Number===t&&e.AvailableResponseTypes.any((e=>e.Type===n)))))return new Ie(lf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const l=new Xf;l.DeviceGuid=u.Guid,l.DeviceChannel=t,l.StateInterfaceType=n,l.ReverseOrder=a,l.DataRange=r,l.Time=o,l.Limit=s,l.Offset=i;const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Jf(l),3e4,!1);if(null==d)return new Ie(lf.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new Ie(lf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ie(lf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ie(lf.OtherError,"Cannot get state history data - some parameters are incorrect!");case"UnsupportedRange":return new Ie(lf.OtherError,"Cannot get state history data - time range is incorrect!");default:return new Ie(lf.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new Ie(lf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new Ie(lf.ResponseTypeNotSupported,`Device or channel not supporting requested DeviceResponseType or device/channel does not exist. ${d.Data}`);case ue.OK:if(null==d.Data)return new Ie(lf.NoData,"Controller responded with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===bt.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new Ie(lf.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new Ie(lf.FatalError,`Cannot get state history data - exception occurs! ${e}`)}}))}GetServiceName(){return Kf.ServiceName}DoesSupportPreciseTimeFramesAsync(){return Hf(this,void 0,void 0,(function*(){let e=(yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>6||6===Number(e[0])&&Number(e[1])>=101}))}GetStatesByIntervalAsync(e,t,n,r,o,s){return Hf(this,arguments,void 0,(function*(e,t,n,r,o,s,i=!1){var a;try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Ie(lf.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 ry.Get(zs.ServiceName).GetDevice(e);if(null==t)return new Ie(lf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new Ie(lf.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 Ie(lf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new zf;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=o,u.Offset=s;let l=(yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");if(Number(l[0])>6||6===Number(l[0])&&Number(l[1])>=101)switch(r){case df.ThisHour:u.Range=df.Hour;break;case df.ThisDay:u.Range=df.Day;break;case df.ThisWeek:u.Range=df.Week;break;case df.ThisMonth:u.Range=df.Month;break;case df.ThisYear:u.Range=df.Year}else u.Range=r;const d=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new jf(u),3e4,!1);if(null==d)return new Ie(lf.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new Ie(lf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ie(lf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ie(lf.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Ie(lf.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new Ie(lf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new Ie(lf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ue.OK:if(null==d.Data)return new Ie(lf.NoData,"Controller responede with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===bt.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new Ie(lf.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new Ie(lf.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){return Hf(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Yf,12e3,!1);return null==t?new Ie(lf.OtherError,"Cannot get available states - response is null."):t.Status!=ue.OK?new Ie(lf.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Ie(lf.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new xf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Ie(lf.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return Hf(this,void 0,void 0,(function*(){let e=(yield ry.Get(ss.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>3||3===Number(e[0])&&Number(e[1])>=42}))}GetAvailableStatesPerChannelAsync(e,t){return Hf(this,void 0,void 0,(function*(){var n;let r;if("string"==typeof e){const t=yield ry.Get(zs.ServiceName).GetDevice(e);if(null==t)return new Ie(lf.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 Qf(new Zf(r.Guid,t)),8e3,!1);if(null==o)return new Ie(lf.OtherError,"Cannot get available states - response is null.");switch(o.Status){case ue.ResourceDoesNotExists:switch(o.Data){case"DeviceNotFound":return new Ie(lf.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Ie(lf.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Ie(lf.OtherError,"Cannot get available states - unknown error!")}case ue.OK:{if(null==o.Data)return new Ie(lf.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 xf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return o.Data.AvailableStates=e,o.Data}default:return new Ie(lf.OtherError,`Cannot get available states - controller responded with response code ${o.Status}`)}}))}}Kf.ServiceName="StatesHistoryService";class jf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=le.Get,this.Data=e}}class zf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=df.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class Jf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/timerange",this.Method=le.Get,this.Data=e}}class Xf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.DataRange=hf.Day,this.Time=new Date,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class Yf extends ce{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=le.Get}}class Qf extends ce{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=le.Get,this.Data=e}}class Zf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(qf=Ff||(Ff={}))[qf.User=0]="User",qf[qf.Controller=1]="Controller",qf[qf.Marketing=2]="Marketing",(Vf=Lf||(Lf={}))[Vf.Notification=0]="Notification",Vf[Vf.Message=1]="Message",Vf[Vf.Alarm=2]="Alarm",Vf[Vf.Warning=3]="Warning",Vf[Vf.Info=4]="Info",($f=Bf||(Bf={}))[$f.Other=0]="Other",$f[$f.UserLoggedIn=1]="UserLoggedIn",$f[$f.UserLoggedOut=2]="UserLoggedOut",$f[$f.FoundNewDevice=3]="FoundNewDevice",$f[$f.DoorBellPress=4]="DoorBellPress",$f[$f.AddedNewDevice=5]="AddedNewDevice",$f[$f.RemovedDevice=6]="RemovedDevice",$f[$f.RegisteredNewUser=7]="RegisteredNewUser",$f[$f.GotAccessToTheInternet=8]="GotAccessToTheInternet",$f[$f.LostAccessToTheInternet=9]="LostAccessToTheInternet",$f[$f.RemovedUser=10]="RemovedUser",$f[$f.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(Wf||(Wf={}));var ev=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 tv{constructor(){this._chatSubscriptions=[],this._connection=ry.Get(Ct.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==Lf.Message)return;const n=new nv;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(Wf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return ev(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new rv,12e3,!1);if(null==e)return new Ie(gv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new Ie(gv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ie(gv.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==Lf.Message)return;const n=new nv;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(Wf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new Ie(gv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return ev(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new ov(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class nv{constructor(){this._sender=Ff.Controller,this._messageType=Lf.Info,this._messageSource=Bf.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 rv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}class ov extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}var sv,iv,av,cv=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._chatSubscriptions=[],this._connection=ry.Get(Ct.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==Lf.Message){const e=new lv;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 cv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new hv,12e3,!1);if(null==e)return new Ie(gv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new Ie(gv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ie(gv.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==Lf.Message){const n=new lv;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 Ie(gv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return cv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new dv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class lv{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 dv extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}class hv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(sv||(sv={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(iv||(iv={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(av||(av={}));var pv,gv,fv,vv=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 yv{constructor(){this._chatSubscriptions=[],this._connection=ry.Get(Ct.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new Av;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=sv[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(av[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return vv(this,void 0,void 0,(function*(){return(yield ry.Get(nt.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return vv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new wv,8e3,!1);return null==e||null==e.Status?new Ie(gv.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ue.OK?new Ie(gv.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Ie(gv.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Ie(gv.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return vv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new Sv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot set chat configuration! ${e}`),ue.FatalError}}))}SendMessageAsync(e){return vv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new mv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(_v.ServiceName,`Cannot send message! ${e}`),ue.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 mv extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=le.Put,this.Data=e}}class wv extends ce{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Get}}class Sv extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Put,this.Data=e}}class Av{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"}(pv||(pv={}));class _v{constructor(){this._services={ControllerChat:new tv,GptChat:new yv,FamillyChat:new uv}}GetServiceName(){return _v.ServiceName}GetChatImplementation(e){switch(e){case pv.ControllerChat:return this._services.ControllerChat;case pv.FamilyChat:return this._services.FamillyChat;case pv.GptChat:return this._services.GptChat;default:throw new Cv(`Chat with type ${e} not implemented!`)}}}_v.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(gv||(gv={}));class Cv 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"}(fv||(fv={}));var Tv=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 Dv{constructor(){this._connection=ry.Get(Ct.ServiceName),this._log=ry.Get(c.ServiceName)}GetServiceName(){return Dv.ServiceName}IsSupportedAsync(){return Tv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new kv,2e3,!0);return this._log.Debug(Dv.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ue.WrongData}))}GetConnectedAppsAsync(){return Tv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Ev,2e3,!0);return(null==e?void 0:e.Status)===ue.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Tv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new bv(e),2e3,!1);switch(null==t?void 0:t.Status){case ue.OK:return new Ie(fv.Changed,"");case ue.WrongData:switch(t.Data){case"AccessTokenToShort":return new Ie(fv.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Ie(fv.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Ie(fv.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Ie(fv.AppNameToShort,t.Data);case"AppUrlToShort":return new Ie(fv.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Ie(fv.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Ie(fv.AppUserNameToShort,t.Data);default:return new Ie(fv.UnkownError,t.Data)}case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new Ie(fv.ResourceIsNotAvailable,t.Data);default:return new Ie(fv.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Tv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Iv(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}Dv.ServiceName="ConnectedAppsService";class kv extends ce{constructor(){super(),this.Resource="/applications/app/auth",this.Method=le.Put,this.Data=""}}class Ev extends ce{constructor(){super(),this.Resource="/applications/get",this.Method=le.Get}}class Iv extends ce{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=le.Delete,this.Data=e}}class bv extends ce{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=le.Put,this.Data=e}}var Gv=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 Nv{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(Nv.AppUserControllersKeyName,e)}null!==o&&localStorage.setItem(Nv.AppUserControllersKeyName,decodeURIComponent(o)),null!==s&&localStorage.setItem(Nv.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 Nv.ServiceName}IsMigrationDataAvailableAsync(){return Gv(this,void 0,void 0,(function*(){try{if(oe.IsIosNative()){var e=yield Nv.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(Nv.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Nv.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return Gv(this,void 0,void 0,(function*(){try{if(oe.IsIosNative()){let e=yield Nv.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(Nv.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return Gv(this,void 0,void 0,(function*(){try{if(oe.IsIosNative()){let e=yield Nv.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(Nv.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)}}))}}Nv.AppSelectedLanguageKeyName="App___SelectedLanguage",Nv.AppUserControllersKeyName="App___UserControllersListDatabase",Nv.ServiceName="DataMigrationService";var Rv=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 Pv{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=ry.Get(Ct.ServiceName),this._logger=ry.Get(c.ServiceName),this._storage=ry.Get(l.ServiceName),ry.Get(Xe.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Rv(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(Pv.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;oe.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(Pv.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(Pv.ServiceName,"Controller not found in local network."))}else this._logger.Error(Pv.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(Pv.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return Rv(this,void 0,void 0,(function*(){if(oe.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(Pv.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){return Rv(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Uv,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(Pv.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return Pv.ServiceName}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("")}}))}}Pv.ServiceName="FindControllerService";class Uv extends ce{constructor(){super(),this.Resource="/network/lan/",this.Method=le.Get}}var Ov,Mv,xv,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._errorOccuredEvent=new a,this._connectionStateChangedEvent=new a,this._dataReceivedEvent=new a,this._onMessageReceived=new a,this._log=ry.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=ry.Get(at.ServiceName),this._cache=ry.Get(Be.ServiceName),this._session=ry.Get(Xe.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return Fv(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 Fv(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 ce;return t.Resource="/system/ping",t.Method=le.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 ry.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(Lv.ServiceName,`Connecting to the WebSockets server ${e}`),this.socket.onerror=t=>(this._log.Debug(Lv.ServiceName,`Error occured in the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._errorOccuredEvent.Invoke(["WebSockets",t.toString()]),n(he.FailedToConnect)),this.socket.onopen=n=>(this._log.Debug(Lv.ServiceName,`Connected to the WebSockets server ${e} info: \n${JSON.stringify(n)}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(pe.Connected),this._pingIntervalId=setInterval((()=>Fv(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval),t(he.Connected)),this.socket.onclose=t=>{this._log.Debug(Lv.ServiceName,`Disconnected from the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(pe.Disconnected)},this.socket.onmessage=t=>{this._log.Debug(Lv.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(Lv.ServiceName,`Received data frame: ${e.Status}`),this._dataReceivedEvent.Invoke(e)}catch(e){this._log.Error(Lv.ServiceName,`Failed to parse message: ${t.data}`)}},this._connectionStateChangedEvent.Invoke(pe.Connecting)}))}AuthorizeAsync(e){return Fv(this,void 0,void 0,(function*(){return ry.WorksInContextOf=e.SerialNumber,!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Lv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,this._connectionStateChangedEvent.Invoke(pe.ConnectedAndAuthorized),!0)}))}ConnectAndAuthorizeAsync(e){return Fv(this,void 0,void 0,(function*(){if(ry.WorksInContextOf=e.SerialNumber,this._log.Debug(Lv.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`),!(yield this.AuthorizeAsync(e)))return he.AuthorizationFailed;let t=yield this.GetServerAddressAsync();return null==t?he.FailedToConnectToServer:yield this.ConnectAsync(t)}))}DisconnectAsync(){var e;return this._log.Debug(Lv.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._connectionStateChangedEvent.Invoke(pe.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(Lv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Lv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Lv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.socket)||void 0===n||n.send(r):this._log.Error(Lv.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 Fv(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)=>Fv(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(Lv.ServiceName,t),a(new Error(t))}),t);let u=l=>Fv(this,void 0,void 0,(function*(){var d,h,p;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(s);const g=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Lv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${g}ms`),(null==l?void 0:l.Status)===ue.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===(p=this._session)||void 0===p?void 0:p.RestoreSessionAsync(),o(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ue.MultiDataResponseStart:case ue.MultiDataResponse:n(l),s=c();break;case ue.MultiDataResponseStop:case ue.FatalError:case ue.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 Fv(this,arguments,void 0,(function*(e,t,n,r=!0,o=!0){var s,i,a;if(e.Method===le.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)=>Fv(this,void 0,void 0,(function*(){let a=i=>Fv(this,void 0,void 0,(function*(){var l,d,h,p;if((null==i?void 0:i.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const g=Date.now()-u;o&&this._log.Debug(Lv.ServiceName,`Received response for: ${null==i?void 0:i.Resource} ${null==i?void 0:i.Method} id: ${null==i?void 0:i.TransactionId} in ${g}ms`),e.Method===le.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ue.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===(p=this._session)||void 0===p?void 0:p.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(Lv.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 Lv.ServiceName}}Lv.ServiceName="ExalusConnectionService";class Bv{constructor(){var e,t;this.OnEnteredPictureInPicture=new ke,this.OnExitedPictureInPicture=new ke,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 Bv.ServiceName}}Bv.ServiceName="PictureInPictureService",(xv=Ov||(Ov={}))[xv.Unknown=-1]="Unknown",xv[xv.Web=0]="Web",xv[xv.Android=1]="Android",xv[xv.iOS=2]="iOS";class Wv{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=Ov.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"}(Mv||(Mv={}));var $v=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 Vv{constructor(){this._connection=ry.Get(Ct.ServiceName),this._logger=ry.Get(c.ServiceName)}GetServiceName(){return Vv.ServiceName}RegisterNotificationsClientAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=new qv({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 Ie(Mv.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ue.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:Mv.UnknownError;return new Ie(e,"Cannot register notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof r.Data?r.Data:new Ie(Mv.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ie(Mv.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new Ie(Mv.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){return $v(this,void 0,void 0,(function*(){var n;try{const r=new Hv({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 Ie(Mv.UnknownError,"Cannot update notifications client - unknown error!");switch(o.Status){case ue.WrongData:{const e=this.isValidErrorCode(o.Data)?o.Data:Mv.UnknownError;return new Ie(e,"Cannot update notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof o.Data?o.Data==e?ue.OK:new Ie(Mv.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${o.Data}`):new Ie(Mv.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ie(Mv.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new Ie(Mv.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(e){return $v(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Kv,8e3,!1);return null==t||null==t.Status?new Ie(Mv.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ue.ResourceDoesNotExists?new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ue.OK?new Ie(Mv.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new Ie(Mv.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new Wv;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 Ie(Mv.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotificationsEnabledForAllUserTokensAsync(e){return $v(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 Ie(Mv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new Ie(e,"Cannot get notifications status!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new Ie(Mv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ie(Mv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ie(Mv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}IsNotificationsEnabledAsync(e){return $v(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 Ie(Mv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:if(null==n.Data)return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new Ie(e,"Cannot get notifications status - resource not exists!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new Ie(Mv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ie(Mv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ie(Mv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){return $v(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 zv(n),8e3,!1);if(null==r||null==r.Status)return new Ie(Mv.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Mv.UnknownError;return new Ie(e,"Cannot enable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new Ie(Mv.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new Ie(Mv.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}EnableNotificationsForAllUserTokensAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Xv(e),8e3,!1);if(null==n||null==n.Status)return new Ie(Mv.UnknownError,"Cannot enable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new Ie(e,"Cannot enable notifications!")}case ue.OK:return ue.OK;default:return new Ie(Mv.UnknownError,`Cannot enable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot enable notifications for lavva user ${e} - error: ${t}`),new Ie(Mv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DisableNotificationsAsync(e){return $v(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 Jv(n),8e3,!1);if(null==r||null==r.Status)return new Ie(Mv.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Mv.UnknownError;return new Ie(e,"Cannot disable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new Ie(Mv.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new Ie(Mv.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}DisableNotificationsForAllUserTokensAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Yv(e),8e3,!1);if(null==n||null==n.Status)return new Ie(Mv.UnknownError,"Cannot disable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ie(Mv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Mv.UnknownError;return new Ie(e,"Cannot disable notifications!")}case ue.OK:return ue.OK;default:return new Ie(Mv.UnknownError,`Cannot disable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot disable notifications for lavva user ${e} - error: ${t}`),new Ie(Mv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DeleteNotificationsTokenAsync(e){return $v(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);return null==n||null==n.Status?new Ie(Mv.UnknownError,"Cannot delete notifications token - unknown error!"):n.Status==ue.OK?ue.OK:new Ie(Mv.UnknownError,`Cannot delete notifications token - response code ${n.Status}!`)}catch(e){return this._logger.Error(`Cannot delete notifications token - error: ${e}`),new Ie(Mv.UnknownError,`Cannot delete notifications token - error: ${e}`)}}))}getClientType(){return oe.IsIosNative()?Ov.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?Ov.Android:Ov.Web}isValidErrorCode(e){return Object.values(Mv).includes(e)}}Vv.ServiceName="NotificationsService";class qv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Post,this.Data=e}}class Hv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Put,this.Data=e}}class Kv extends ce{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=le.Get}}class jv extends ce{constructor(e){super(),this.Resource="/notifications/status",this.Method=le.Get,this.Data={TokenIdentity:e}}}class zv extends ce{constructor(e){super(),this.Resource="/notifications/enable",this.Method=le.Post,this.Data=e}}class Jv extends ce{constructor(e){super(),this.Resource="/notifications/disable",this.Method=le.Post,this.Data=e}}class Xv extends ce{constructor(e){super(),this.Resource="/notifications/enable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Yv extends ce{constructor(e){super(),this.Resource="/notifications/disable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Qv extends ce{constructor(e){super(),this.Resource="/notifications/status/for/lavva/user",this.Method=le.Get,this.Data=e}}class Zv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Delete,this.Data=e}}class ey{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 ey.ServiceName}}ey.ServiceName="AndroidLocationService";class ty{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)}GetNotificationsQueueAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetNotificationsQueueAsync():Promise.resolve(null)}GetServiceName(){return ty.ServiceName}}ty.ServiceName="AndroidNotificationsService";class ny{OpenRateDialogAsync(){if(oe.IsIosNative())try{if(null!=window.webkit.messageHandlers.rateApp)return window.webkit.messageHandlers.rateApp.postMessage(!0),Promise.resolve()}catch(e){return Promise.reject(new Error(`Rate dialog is not available on this platform. Error: ${e}`))}else if(this.IsAvailable())return navigator.AndroidAppRate.OpenRateDialogAsync();return Promise.reject(new Error("AppRateService is not available on this platform."))}IsAvailable(){var e,t;return void 0!==navigator.AndroidAppRate||void 0!==(null===(t=null===(e=window.webkit)||void 0===e?void 0:e.messageHandlers)||void 0===t?void 0:t.rateApp)}GetServiceName(){return ny.ServiceName}}ny.ServiceName="AppRateService",hu(Map),hu(Set),(()=>{const e=String.prototype,t=Object.getOwnPropertyNames(wi.prototype);for(const n of t)e[n]=e[n]??wi.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 fi(gi.NoMatch)}if(0===this.length)throw new fi(gi.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 pi("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 fi(gi.NoMatch)}if(0===this.length)throw new fi(gi.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 wi((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),fg(Array),fg(Int8Array),fg(Int16Array),fg(Int32Array),fg(Uint8Array),fg(Uint8ClampedArray),fg(Uint16Array),fg(Uint32Array),fg(Float32Array),fg(Float64Array);class ry{static Init(){if(u.IsInitialized)return;let e=u.Instance;try{e.RegisterService(new Nv),e.RegisterService(new l),e.RegisterService(new Yg),e.RegisterService(new Be),e.RegisterService(new Xe),e.RegisterService(new Bv),e.RegisterService(new ny),ry.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Lv)):e.RegisterService(new Ct),e.RegisterService(new ey),e.RegisterService(new ty),e.RegisterService(new Co),e.RegisterService(new Co),e.RegisterService(new Po),e.RegisterService(new at),e.RegisterService(new Pv),e.RegisterService(new wo),e.RegisterService(new nt),e.RegisterService(new Ne),e.RegisterService(new $e),e.RegisterService(new zs),e.RegisterService(new Ag),e.RegisterService(new ss),e.RegisterService(new vf),e.RegisterService(new Dv),e.RegisterService(new Kf),e.RegisterService(new Ms),e.RegisterService(new _v),e.RegisterService(new Vv)}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}}ry.WorksInContextOf="",ry.Version=1})();
|
|
2
2
|
//# sourceMappingURL=exalushome-library-bundle.js.map
|