lavva.exalushome 2.0.112 → 2.0.113
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/Api.js +112 -112
- package/build/js/Api.js.map +1 -1
- package/build/js/AsyncLock.js +15 -15
- package/build/js/AsyncSemaphore.js +44 -44
- package/build/js/AsyncSemaphore.js.map +1 -1
- package/build/js/CancelationTokenSource.js +18 -18
- package/build/js/DataFrame.js +86 -86
- package/build/js/DependencyContainer.js +87 -87
- package/build/js/DependencyContainer.js.map +1 -1
- package/build/js/Event.js +24 -24
- package/build/js/Event.js.map +1 -1
- package/build/js/Guid.js +8 -8
- package/build/js/Helpers.js +132 -132
- package/build/js/Helpers.js.map +1 -1
- package/build/js/IDIService.js +1 -1
- package/build/js/INetworkService.js +41 -41
- package/build/js/Services/AppStateService.js +217 -217
- package/build/js/Services/AppStateService.js.map +1 -1
- package/build/js/Services/Chat/ChatImplementations/ControllerChat/ControllerChat.js +224 -224
- package/build/js/Services/Chat/ChatImplementations/ControllerChat/ControllerChat.js.map +1 -1
- package/build/js/Services/Chat/ChatImplementations/ControllerChat/IControllerChat.js +33 -33
- package/build/js/Services/Chat/ChatImplementations/FamillyChat/FamillyChat.js +147 -147
- package/build/js/Services/Chat/ChatImplementations/FamillyChat/FamillyChat.js.map +1 -1
- package/build/js/Services/Chat/ChatImplementations/FamillyChat/IFamillyChat.js +1 -1
- package/build/js/Services/Chat/ChatImplementations/GptChat/GptChat.js +184 -184
- package/build/js/Services/Chat/ChatImplementations/GptChat/GptChat.js.map +1 -1
- package/build/js/Services/Chat/ChatImplementations/GptChat/IGptChat.js +26 -26
- package/build/js/Services/Chat/ChatService.js +43 -43
- package/build/js/Services/Chat/ChatService.js.map +1 -1
- package/build/js/Services/Chat/IChatService.js +6 -6
- package/build/js/Services/Controller/ConnectedAppsService.js +117 -117
- package/build/js/Services/Controller/ConnectedAppsService.js.map +1 -1
- package/build/js/Services/Controller/ControllerConfigurationService.js +319 -319
- package/build/js/Services/Controller/ControllerConfigurationService.js.map +1 -1
- package/build/js/Services/Controller/ControllerExtensionsService.js +148 -148
- package/build/js/Services/Controller/ControllerExtensionsService.js.map +1 -1
- package/build/js/Services/Controller/FindControllerService.js +155 -155
- package/build/js/Services/Controller/FindControllerService.js.map +1 -1
- package/build/js/Services/Controller/GeolocationService.js +111 -111
- package/build/js/Services/Controller/GeolocationService.js.map +1 -1
- package/build/js/Services/Controller/IConnectedAppsService.js +24 -24
- package/build/js/Services/Controller/IControllerConfigurationService.js +1 -1
- package/build/js/Services/Controller/IControllerExtensionsService.js +1 -1
- package/build/js/Services/Controller/IGeolocationService.js +20 -20
- package/build/js/Services/DataMigrationService.js +169 -169
- package/build/js/Services/DataMigrationService.js.map +1 -1
- package/build/js/Services/Devices/ChannelsGroupsService.js +696 -696
- package/build/js/Services/Devices/ChannelsGroupsService.js.map +1 -1
- package/build/js/Services/Devices/Device.js +248 -248
- package/build/js/Services/Devices/Device.js.map +1 -1
- package/build/js/Services/Devices/DeviceChannel.js +304 -304
- package/build/js/Services/Devices/DeviceChannel.js.map +1 -1
- package/build/js/Services/Devices/DevicesService.js +1184 -1184
- package/build/js/Services/Devices/DevicesService.js.map +1 -1
- package/build/js/Services/Devices/IChannelsGroupsService.js +109 -109
- package/build/js/Services/Devices/IChannelsGroupsService.js.map +1 -1
- package/build/js/Services/Devices/IDevice.js +197 -197
- package/build/js/Services/Devices/IDeviceChannel.js +48 -48
- package/build/js/Services/Devices/IDeviceConfigService.js +1 -1
- package/build/js/Services/Devices/IDeviceState.d.ts +7 -1
- package/build/js/Services/Devices/IDeviceState.js +970 -963
- package/build/js/Services/Devices/IDeviceState.js.map +1 -1
- package/build/js/Services/Devices/IDeviceTask.js +36 -36
- package/build/js/Services/Devices/IDevicesService.js +9 -9
- package/build/js/Services/Devices/IManuallyPairedDevicesProtocolService.js +1 -1
- package/build/js/Services/Devices/IManuallyPairedDevicesService.js +1 -1
- package/build/js/Services/Devices/ManuallyPairedDevicesService.js +68 -68
- package/build/js/Services/Devices/ManuallyPairedDevicesService.js.map +1 -1
- package/build/js/Services/Devices/TaskExecutionResult.js +9 -9
- package/build/js/Services/Devices/Tasks/DeviceTask.js +42 -42
- package/build/js/Services/Devices/Tasks/Tasks.js +216 -216
- package/build/js/Services/Devices/dist/DevicesService.d.ts +17 -17
- package/build/js/Services/ExalusConnectionService.js +498 -498
- package/build/js/Services/ExalusConnectionService.js.map +1 -1
- package/build/js/Services/FieldChangeResult.js +51 -51
- package/build/js/Services/IAppStateService.js +66 -66
- package/build/js/Services/IExalusConnectionService.js +31 -31
- package/build/js/Services/ILocalStorageService.js +1 -1
- package/build/js/Services/IRemoteStorageService.js +8 -8
- package/build/js/Services/LocalNetworkExalusConnectionService.js +289 -289
- package/build/js/Services/LocalNetworkExalusConnectionService.js.map +1 -1
- package/build/js/Services/LocalStorageService.js +38 -38
- package/build/js/Services/LocalStorageService.js.map +1 -1
- package/build/js/Services/Logging/ILoggerService.js +8 -8
- package/build/js/Services/Logging/LoggerService.js +132 -132
- package/build/js/Services/Logging/LoggerService.js.map +1 -1
- package/build/js/Services/PictureInPicture.js +28 -28
- package/build/js/Services/PictureInPicture.js.map +1 -1
- package/build/js/Services/Pictures/IPicture.js +6 -6
- package/build/js/Services/Pictures/IPicturesService.js +1 -1
- package/build/js/Services/Pictures/Picture.js +50 -50
- package/build/js/Services/Pictures/PicturesService.js +441 -441
- package/build/js/Services/Pictures/PicturesService.js.map +1 -1
- package/build/js/Services/RemoteStorageService.js +122 -122
- package/build/js/Services/RemoteStorageService.js.map +1 -1
- package/build/js/Services/Scenes/IScenesService.js +7 -7
- package/build/js/Services/Scenes/LeftArgumentTypes.js +166 -166
- package/build/js/Services/Scenes/LeftArgumentTypes.js.map +1 -1
- package/build/js/Services/Scenes/SceneTaskTypes.js +32 -32
- package/build/js/Services/Scenes/Scenes.js +134 -134
- package/build/js/Services/Scenes/ScenesBuilder.js +1097 -1097
- package/build/js/Services/Scenes/ScenesBuilder.js.map +1 -1
- package/build/js/Services/Scenes/ScenesService.js +1131 -1131
- package/build/js/Services/Scenes/ScenesService.js.map +1 -1
- package/build/js/Services/Scenes/dist/ScenesService.d.ts +5 -5
- package/build/js/Services/Session/ISessionService.js +8 -8
- package/build/js/Services/Session/SessionService.js +222 -222
- package/build/js/Services/Session/SessionService.js.map +1 -1
- package/build/js/Services/StatesHistory/IStatesHistoryService.js +12 -12
- package/build/js/Services/StatesHistory/StatesHistory.js +75 -75
- package/build/js/Services/StatesHistory/StatesHistoryService.js +235 -235
- package/build/js/Services/StatesHistory/StatesHistoryService.js.map +1 -1
- package/build/js/Services/SupportedDevices/ISupportedDevicesService.js +115 -115
- package/build/js/Services/SupportedDevices/SupportedDevicesService.js +26 -26
- package/build/js/Services/Updates/CustomUpdateActions/ICustomUpdateActions.js +1 -1
- package/build/js/Services/Updates/IUpdateInfo.js +62 -62
- package/build/js/Services/Updates/IUpdatesProvider.js +48 -48
- package/build/js/Services/Updates/IUpdatesService.js +139 -139
- package/build/js/Services/Updates/UpdateProviderServices/IControllerModulesUpdatesProviderService.js +1 -1
- package/build/js/Services/Updates/UpdateProviderServices/IDeviceUpdateProviderService.js +1 -1
- package/build/js/Services/Updates/UpdateProviderServices/IUpdateProviderService.js +1 -1
- package/build/js/Services/Updates/UpdatesProvider.js +212 -212
- package/build/js/Services/Updates/UpdatesProvider.js.map +1 -1
- package/build/js/Services/Updates/UpdatesService.js +1487 -1487
- package/build/js/Services/Updates/UpdatesService.js.map +1 -1
- package/build/js/Services/Updates/dist/UpdatesService.d.ts +9 -9
- package/build/js/Services/Users/IUser.js +21 -21
- package/build/js/Services/Users/IUsersService.js +1 -1
- package/build/js/Services/Users/User.js +104 -104
- package/build/js/Services/Users/UsersService.js +302 -302
- package/build/js/Services/Users/UsersService.js.map +1 -1
- package/build/js/Services/WebApi/IWebApiCacheService.js +1 -1
- package/build/js/Services/WebApi/WebApiCacheService.js +42 -42
- package/build/js/Services/WebApi/WebApiCacheService.js.map +1 -1
- package/build/js/TypedEvent.js +23 -23
- package/build/js/TypedEvent.js.map +1 -1
- package/build/js/dist/Api.d.ts +12 -12
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(()=>{"use strict";var e,t={d:(e,n)=>{for(var r in n)t.o(n,r)&&!t.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:n[r]})}};t.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),t.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),t.d({},{V:()=>Zf});class n{constructor(){this.handlers=[]}Subscribe(e){this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(e){this.handlers.slice(0).forEach((t=>{var n;try{t(e)}catch(e){null===(n=s.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 r{constructor(){this._blockedServices=[],this._logLevel=e.Debug,void 0!==window.loglevel&&null!==window.loglevel&&(this._logLevel=window.loglevel),window.logger=this}EnableStackTrace(){r.DoesThrowStackTrace=!0}DisableStackTrace(){r.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(r.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(r.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return r.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}`):r.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}`)))}}r.ServiceName="LoggerService",r.DoesThrowStackTrace=!1;class s{constructor(){this._services={},this._serviceRegistrationEvent=new n}static get Instance(){return null!=s._instance||(s._instance=new s,this.Log=new r,this.Log.Warning("Initializing DependencyContainer"),s._instance.RegisterService(this.Log),this.IsInitialized=!0,window.services=this),s._instance}RegisterService(e){var t;null===(t=s.Log)||void 0===t||t.Debug("DependencyContainer",`Registering new service: ${e.GetServiceName()}`),this._services[e.GetServiceName()]=e,this._serviceRegistrationEvent.Invoke(e)}GetService(e){var t;return null===(t=s.Log)||void 0===t||t.Debug("DependencyContainer",`Getting service [${e}] by GetService<T>()`),this._services[e]}GetServiceAsync(e,t){var n,r;return null===(n=s.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service availability [${e}] by GetServiceAsync<T>()`),this._services.hasOwnProperty(e)?(null===(r=s.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=s.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),n(t))},i=()=>{var n;null===(n=s.Log)||void 0===n||n.Debug("DependencyContainer",`Cancelled service [${e}] retrieval by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),null==t||t.CancellationEvent.Unsubscribe(i),r(new Error("Operation cancelled!"))};null==t||t.CancellationEvent.Subscribe(i),this._serviceRegistrationEvent.Subscribe(o)}))}GetServiceWithTimeoutAsync(e,t){var n,r;return null===(n=s.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service[${e}] availability by GetServiceWithTimeoutAsync<T>()`),this._services.hasOwnProperty(e)?(null===(r=s.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,i=e=>{var t;(null==e?void 0:e.GetClassName())===e&&(null===(t=s.Log)||void 0===t||t.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(i),n(e))};o=window.setTimeout((()=>{var t;window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(i),null===(t=s.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(i)}))}}s.IsInitialized=!1;class o{GetServiceName(){return o.ServiceName}GetResourceName(e,t){return`_exalus_${Zf.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=s.Log)||void 0===n||n.Error(o.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}o.ServiceName="LocalStorageService";const i=[0,2e3,1e4,3e4,null];class a{constructor(e){this._retryDelays=void 0!==e?[...e,null]:i}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class c{}c.Authorization="Authorization",c.Cookie="Cookie";class u{constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class l{get(e,t){return this.send({...t,method:"GET",url:e})}post(e,t){return this.send({...t,method:"POST",url:e})}delete(e,t){return this.send({...t,method:"DELETE",url:e})}getCookieString(e){return""}}class d extends l{constructor(e,t){super(),this._innerClient=e,this._accessTokenFactory=t}async send(e){let t=!0;this._accessTokenFactory&&(!this._accessToken||e.url&&e.url.indexOf("/negotiate?")>0)&&(t=!1,this._accessToken=await this._accessTokenFactory()),this._setAuthorizationHeader(e);const n=await this._innerClient.send(e);return t&&401===n.statusCode&&this._accessTokenFactory?(this._accessToken=await this._accessTokenFactory(),this._setAuthorizationHeader(e),await this._innerClient.send(e)):n}_setAuthorizationHeader(e){e.headers||(e.headers={}),this._accessToken?e.headers[c.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[c.Authorization]&&delete e.headers[c.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class h extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class p extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class g extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class f extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class v extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class m extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class y extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class w extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}var S;!function(e){e[e.Trace=0]="Trace",e[e.Debug=1]="Debug",e[e.Information=2]="Information",e[e.Warning=3]="Warning",e[e.Error=4]="Error",e[e.Critical=5]="Critical",e[e.None=6]="None"}(S||(S={}));class _{constructor(){}log(e,t){}}_.instance=new _;const A="7.0.14";class C{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 T{static get isBrowser(){return"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return"object"==typeof self&&"importScripts"in self}static get isReactNative(){return"object"==typeof window&&void 0===window.document}static get isNode(){return!this.isBrowser&&!this.isWebWorker&&!this.isReactNative}}function D(e,t){let n="";return G(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 G(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function k(e,t,n,r,s,o){const i={},[a,c]=E();i[a]=c,e.log(S.Trace,`(${t} transport) sending data. ${D(s,o.logMessageContent)}.`);const u=G(s)?"arraybuffer":"text",l=await n.post(r,{content:s,headers:{...i,...o.headers},responseType:u,timeout:o.timeout,withCredentials:o.withCredentials});e.log(S.Trace,`(${t} transport) request complete. Response status: ${l.statusCode}.`)}class b{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 N{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${S[e]}: ${t}`;switch(e){case S.Critical:case S.Error:this.out.error(n);break;case S.Warning:this.out.warn(n);break;case S.Information:this.out.info(n);break;default:this.out.log(n)}}}}function E(){let e="X-SignalR-User-Agent";return T.isNode&&(e="User-Agent"),[e,I(A,R(),T.isNode?"NodeJS":"Browser",P())]}function I(e,t,n,r){let s="Microsoft SignalR/";const o=e.split(".");return s+=`${o[0]}.${o[1]}`,s+=` (${e}; `,s+=t&&""!==t?`${t}; `:"Unknown OS; ",s+=`${n}`,s+=r?`; ${r}`:"; Unknown Runtime Version",s+=")",s}function R(){if(!T.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function P(){if(T.isNode)return process.versions.node}function O(e){return e.stack?e.stack:e.message?e.message:`${e}`}class U extends l{constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch){const e=require;this._jar=new(e("tough-cookie").CookieJar),this._fetchType=e("node-fetch"),this._fetchType=e("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(function(){if("undefined"!=typeof globalThis)return globalThis;if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==t.g)return t.g;throw new Error("could not find global")}());if("undefined"==typeof AbortController){const e=require;this._abortControllerType=e("abort-controller")}else this._abortControllerType=AbortController}async send(e){if(e.abortSignal&&e.abortSignal.aborted)throw new g;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 g});let r,s=null;if(e.timeout){const r=e.timeout;s=setTimeout((()=>{t.abort(),this._logger.log(S.Warning,"Timeout from HTTP request."),n=new p}),r)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},G(e.content)?e.headers["Content-Type"]="application/octet-stream":e.headers["Content-Type"]="text/plain;charset=UTF-8");try{r=await this._fetchType(e.url,{body:e.content,cache:"no-cache",credentials:!0===e.withCredentials?"include":"same-origin",headers:{"X-Requested-With":"XMLHttpRequest",...e.headers},method:e.method,mode:"cors",redirect:"follow",signal:t.signal})}catch(e){if(n)throw n;throw this._logger.log(S.Warning,`Error from HTTP request. ${e}.`),e}finally{s&&clearTimeout(s),e.abortSignal&&(e.abortSignal.onabort=null)}if(!r.ok){const e=await M(r,"text");throw new h(e||r.statusText,r.status)}const o=M(r,e.responseType),i=await o;return new u(r.status,r.statusText,i)}getCookieString(e){let t="";return T.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function M(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 x extends l{constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new g):e.method?e.url?new Promise(((t,n)=>{const r=new XMLHttpRequest;r.open(e.method,e.url,!0),r.withCredentials=void 0===e.withCredentials||e.withCredentials,r.setRequestHeader("X-Requested-With","XMLHttpRequest"),""===e.content&&(e.content=void 0),e.content&&(G(e.content)?r.setRequestHeader("Content-Type","application/octet-stream"):r.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const s=e.headers;s&&Object.keys(s).forEach((e=>{r.setRequestHeader(e,s[e])})),e.responseType&&(r.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{r.abort(),n(new g)}),e.timeout&&(r.timeout=e.timeout),r.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),r.status>=200&&r.status<300?t(new u(r.status,r.statusText,r.response||r.responseText)):n(new h(r.response||r.responseText||r.statusText,r.status))},r.onerror=()=>{this._logger.log(S.Warning,`Error from HTTP request. ${r.status}: ${r.statusText}.`),n(new h(r.statusText,r.status))},r.ontimeout=()=>{this._logger.log(S.Warning,"Timeout from HTTP request."),n(new p)},r.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class F extends l{constructor(e){if(super(),"undefined"!=typeof fetch||T.isNode)this._httpClient=new U(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new x(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new g):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)}}var L,B,$,W;!function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(L||(L={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(B||(B={}));class q{constructor(){this._isAborted=!1,this.onabort=null}abort(){this._isAborted||(this._isAborted=!0,this.onabort&&this.onabort())}get signal(){return this}get aborted(){return this._isAborted}}class H{constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new q,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}get pollAborted(){return this._pollAbort.aborted}async connect(e,t){if(C.isRequired(e,"url"),C.isRequired(t,"transferFormat"),C.isIn(t,B,"transferFormat"),this._url=e,this._logger.log(S.Trace,"(LongPolling transport) Connecting."),t===B.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[n,r]=E(),s={[n]:r,...this._options.headers},o={abortSignal:this._pollAbort.signal,headers:s,timeout:1e5,withCredentials:this._options.withCredentials};t===B.Binary&&(o.responseType="arraybuffer");const i=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${i}.`);const a=await this._httpClient.get(i,o);200!==a.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${a.statusCode}.`),this._closeError=new h(a.statusText||"",a.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,o)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${n}.`);const r=await this._httpClient.get(n,t);204===r.statusCode?(this._logger.log(S.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==r.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${r.statusCode}.`),this._closeError=new h(r.statusText||"",r.statusCode),this._running=!1):r.content?(this._logger.log(S.Trace,`(LongPolling transport) data received. ${D(r.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(r.content)):this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof p?this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(S.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(S.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?k(this._logger,"LongPolling",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}async stop(){this._logger.log(S.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(S.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=E();e[t]=n;const r={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};await this._httpClient.delete(this._url,r),this._logger.log(S.Trace,"(LongPolling transport) DELETE request sent.")}finally{this._logger.log(S.Trace,"(LongPolling transport) Stop finished."),this._raiseOnClose()}}_raiseOnClose(){if(this.onclose){let e="(LongPolling transport) Firing onclose event.";this._closeError&&(e+=" Error: "+this._closeError),this._logger.log(S.Trace,e),this.onclose(this._closeError)}}}class V{constructor(e,t,n,r){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=r,this.onreceive=null,this.onclose=null}async connect(e,t){return C.isRequired(e,"url"),C.isRequired(t,"transferFormat"),C.isIn(t,B,"transferFormat"),this._logger.log(S.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((n,r)=>{let s,o=!1;if(t===B.Text){if(T.isBrowser||T.isWebWorker)s=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[r,o]=E();n[r]=o,s=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{s.onmessage=e=>{if(this.onreceive)try{this._logger.log(S.Trace,`(SSE transport) data received. ${D(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},s.onerror=e=>{o?this._close():r(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."))},s.onopen=()=>{this._logger.log(S.Information,`SSE connected to ${this._url}`),this._eventSource=s,o=!0,n()}}catch(e){return void r(e)}}else r(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?k(this._logger,"SSE",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}stop(){return this._close(),Promise.resolve()}_close(e){this._eventSource&&(this._eventSource.close(),this._eventSource=void 0,this.onclose&&this.onclose(e))}}class j{constructor(e,t,n,r,s,o){this._logger=n,this._accessTokenFactory=t,this._logMessageContent=r,this._webSocketConstructor=s,this._httpClient=e,this.onreceive=null,this.onclose=null,this._headers=o}async connect(e,t){let n;return C.isRequired(e,"url"),C.isRequired(t,"transferFormat"),C.isIn(t,B,"transferFormat"),this._logger.log(S.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(n=await this._accessTokenFactory()),new Promise(((r,s)=>{let o;e=e.replace(/^http/,"ws");const i=this._httpClient.getCookieString(e);let a=!1;if(T.isNode||T.isReactNative){const t={},[r,s]=E();t[r]=s,n&&(t[c.Authorization]=`Bearer ${n}`),i&&(t[c.Cookie]=i),o=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else n&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(n)}`);o||(o=new this._webSocketConstructor(e)),t===B.Binary&&(o.binaryType="arraybuffer"),o.onopen=t=>{this._logger.log(S.Information,`WebSocket connected to ${e}.`),this._webSocket=o,a=!0,r()},o.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(S.Information,`(WebSockets transport) ${t}.`)},o.onmessage=e=>{if(this._logger.log(S.Trace,`(WebSockets transport) data received. ${D(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},o.onclose=e=>{if(a)this._close(e);else{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"WebSocket failed to connect. The connection could not be found on the server, either the endpoint may not be a SignalR endpoint, the connection ID is not present on the server, or there is a proxy blocking WebSockets. If you have multiple servers check that sticky sessions are enabled.",s(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(S.Trace,`(WebSockets transport) sending data. ${D(e,this._logMessageContent)}.`),this._webSocket.send(e),Promise.resolve()):Promise.reject("WebSocket is not in the OPEN state")}stop(){return this._webSocket&&this._close(void 0),Promise.resolve()}_close(e){this._webSocket&&(this._webSocket.onclose=()=>{},this._webSocket.onmessage=()=>{},this._webSocket.onerror=()=>{},this._webSocket.close(),this._webSocket=void 0),this._logger.log(S.Trace,"(WebSockets transport) socket closed."),this.onclose&&(!this._isCloseEvent(e)||!1!==e.wasClean&&1e3===e.code?e instanceof Error?this.onclose(e):this.onclose():this.onclose(new Error(`WebSocket closed with status code: ${e.code} (${e.reason||"no reason given"}).`)))}_isCloseEvent(e){return e&&"boolean"==typeof e.wasClean&&"number"==typeof e.code}}class K{constructor(e,t={}){var n;if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,C.isRequired(e,"url"),this._logger=void 0===(n=t.logger)?new N(S.Information):null===n?_.instance:void 0!==n.log?n:new N(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 r=null,s=null;if(T.isNode){const e=require;r=e("ws"),s=e("eventsource")}T.isNode||"undefined"==typeof WebSocket||t.WebSocket?T.isNode&&!t.WebSocket&&r&&(t.WebSocket=r):t.WebSocket=WebSocket,T.isNode||"undefined"==typeof EventSource||t.EventSource?T.isNode&&!t.EventSource&&void 0!==s&&(t.EventSource=s):t.EventSource=EventSource,this._httpClient=new d(t.httpClient||new F(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||B.Binary,C.isIn(e,B,"transferFormat"),this._logger.log(S.Debug,`Starting connection with transfer format '${B[e]}'.`),"Disconnected"!==this._connectionState)return Promise.reject(new Error("Cannot start an HttpConnection that is not in the 'Disconnected' state."));if(this._connectionState="Connecting",this._startInternalPromise=this._startInternal(e),await this._startInternalPromise,"Disconnecting"===this._connectionState){const e="Failed to start the HttpConnection before stop() was called.";return this._logger.log(S.Error,e),await this._stopPromise,Promise.reject(new g(e))}if("Connected"!==this._connectionState){const e="HttpConnection.startInternal completed gracefully but didn't enter the connection into the connected state!";return this._logger.log(S.Error,e),Promise.reject(new g(e))}this._connectionStarted=!0}send(e){return"Connected"!==this._connectionState?Promise.reject(new Error("Cannot send data if the connection is not in the 'Connected' State.")):(this._sendQueue||(this._sendQueue=new z(this.transport)),this._sendQueue.send(e))}async stop(e){return"Disconnected"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState="Disconnecting",this._stopPromise=new Promise((e=>{this._stopPromiseResolver=e})),await this._stopInternal(e),void await this._stopPromise)}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch(e){}if(this.transport){try{await this.transport.stop()}catch(e){this._logger.log(S.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(S.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let t=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==L.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(L.WebSockets),await this._startTransport(t,e)}else{let n=null,r=0;do{if(n=await this._getNegotiationResponse(t),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new g("The connection was stopped during negotiation.");if(n.error)throw new Error(n.error);if(n.ProtocolVersion)throw new Error("Detected a connection attempt to an ASP.NET SignalR Server. This client only supports connecting to an ASP.NET Core SignalR Server. See https://aka.ms/signalr-core-differences for details.");if(n.url&&(t=n.url),n.accessToken){const e=n.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}r++}while(n.url&&r<100);if(100===r&&n.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(t,this._options.transport,n,e)}this.transport instanceof H&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(S.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(S.Error,"Failed to start the connection: "+e),this._connectionState="Disconnected",this.transport=void 0,this._stopPromiseResolver(),Promise.reject(e)}}async _getNegotiationResponse(e){const t={},[n,r]=E();t[n]=r;const s=this._resolveNegotiateUrl(e);this._logger.log(S.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}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof h&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(S.Error,t),Promise.reject(new y(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,t,n,r){let s=this._createConnectUrl(e,n.connectionToken);if(this._isITransport(t))return this._logger.log(S.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=t,await this._startTransport(s,r),void(this.connectionId=n.connectionId);const o=[],i=n.availableTransports||[];let a=n;for(const n of i){const i=this._resolveTransportOrError(n,t,r);if(i instanceof Error)o.push(`${n.transport} failed:`),o.push(i);else if(this._isITransport(i)){if(this.transport=i,!a){try{a=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}s=this._createConnectUrl(e,a.connectionToken)}try{return await this._startTransport(s,r),void(this.connectionId=a.connectionId)}catch(e){if(this._logger.log(S.Error,`Failed to start the transport '${n.transport}': ${e}`),a=void 0,o.push(new m(`${n.transport} failed: ${e}`,L[n.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(S.Debug,e),Promise.reject(new g(e))}}}}return o.length>0?Promise.reject(new w(`Unable to connect to the server with any of the available transports. ${o.join(" ")}`,o)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case L.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new j(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case L.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new V(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case L.LongPolling:return new H(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,t,n){const r=L[e.transport];if(null==r)return this._logger.log(S.Debug,`Skipping transport '${e.transport}' because it is not supported by this client.`),new Error(`Skipping transport '${e.transport}' because it is not supported by this client.`);if(!function(e,t){return!e||0!=(t&e)}(t,r))return this._logger.log(S.Debug,`Skipping transport '${L[r]}' because it was disabled by the client.`),new v(`'${L[r]}' is disabled by the client.`,r);if(!(e.transferFormats.map((e=>B[e])).indexOf(n)>=0))return this._logger.log(S.Debug,`Skipping transport '${L[r]}' because it does not support the requested transfer format '${B[n]}'.`),new Error(`'${L[r]}' does not support ${B[n]}.`);if(r===L.WebSockets&&!this._options.WebSocket||r===L.ServerSentEvents&&!this._options.EventSource)return this._logger.log(S.Debug,`Skipping transport '${L[r]}' because it is not supported in your environment.'`),new f(`'${L[r]}' is not supported in your environment.`,r);this._logger.log(S.Debug,`Selecting transport '${L[r]}'.`);try{return this._constructTransport(r)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(S.Debug,`HttpConnection.stopConnection(${e}) called while in state ${this._connectionState}.`),this.transport=void 0,e=this._stopError||e,this._stopError=void 0,"Disconnected"!==this._connectionState){if("Connecting"===this._connectionState)throw this._logger.log(S.Warning,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is still in the connecting state.`),new Error(`HttpConnection.stopConnection(${e}) was called while the connection is still in the connecting state.`);if("Disconnecting"===this._connectionState&&this._stopPromiseResolver(),e?this._logger.log(S.Error,`Connection disconnected with error '${e}'.`):this._logger.log(S.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(S.Error,`TransportSendQueue.stop() threw error '${e}'.`)})),this._sendQueue=void 0),this.connectionId=void 0,this._connectionState="Disconnected",this._connectionStarted){this._connectionStarted=!1;try{this.onclose&&this.onclose(e)}catch(t){this._logger.log(S.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(S.Debug,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is already in the disconnected state.`)}_resolveUrl(e){if(0===e.lastIndexOf("https://",0)||0===e.lastIndexOf("http://",0))return e;if(!T.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(S.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=e.indexOf("?");let n=e.substring(0,-1===t?e.length:t);return"/"!==n[n.length-1]&&(n+="/"),n+="negotiate",n+=-1===t?"":e.substring(t),-1===n.indexOf("negotiateVersion")&&(n+=-1===t?"?":"&",n+="negotiateVersion="+this._negotiateVersion),n}}class z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new J,this._transportResult=new J,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new J),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 J;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 J{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class Y{static write(e){return`${e}${Y.RecordSeparator}`}static parse(e){if(e[e.length-1]!==Y.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(Y.RecordSeparator);return t.pop(),t}}Y.RecordSeparatorCode=30,Y.RecordSeparator=String.fromCharCode(Y.RecordSeparatorCode);class X{writeHandshakeRequest(e){return Y.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(G(e)){const r=new Uint8Array(e),s=r.indexOf(Y.RecordSeparatorCode);if(-1===s)throw new Error("Message is incomplete.");const o=s+1;t=String.fromCharCode.apply(null,Array.prototype.slice.call(r.slice(0,o))),n=r.byteLength>o?r.slice(o).buffer:null}else{const r=e,s=r.indexOf(Y.RecordSeparator);if(-1===s)throw new Error("Message is incomplete.");const o=s+1;t=r.substring(0,o),n=r.length>o?r.substring(o):null}const r=Y.parse(t),s=JSON.parse(r[0]);if(s.type)throw new Error("Expected a handshake response from the server.");return[n,s]}}!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"}($||($={}));class Q{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 b(this,e)}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(W||(W={}));class Z{constructor(e,t,n,r){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(S.Warning,"The page is being frozen, this will likely lead to the connection being closed and messages being lost. For more information see the docs at https://docs.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},C.isRequired(e,"connection"),C.isRequired(t,"logger"),C.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=3e4,this.keepAliveIntervalInMilliseconds=15e3,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=r,this._handshakeProtocol=new X,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=W.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:$.Ping})}static create(e,t,n,r){return new Z(e,t,n,r)}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!==W.Disconnected&&this._connectionState!==W.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!==W.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=W.Connecting,this._logger.log(S.Debug,"Starting HubConnection.");try{await this._startInternal(),T.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=W.Connected,this._connectionStarted=!0,this._logger.log(S.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=W.Disconnected,this._logger.log(S.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise(((e,t)=>{this._handshakeResolver=e,this._handshakeRejecter=t}));await this.connection.start(this._protocol.transferFormat);try{const t={protocol:this._protocol.name,version:this._protocol.version};if(this._logger.log(S.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(t)),this._logger.log(S.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(S.Debug,`Hub handshake failed with error '${e}' during start(). Stopping HubConnection.`),this._cleanupTimeout(),this._cleanupPingTimer(),await this.connection.stop(e),e}}async stop(){const e=this._startPromise;this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){return this._connectionState===W.Disconnected?(this._logger.log(S.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve()):this._connectionState===W.Disconnecting?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState=W.Disconnecting,this._logger.log(S.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(S.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new g("The connection was stopped before the hub handshake could complete."),this.connection.stop(e)))}stream(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._createStreamInvocation(e,t,r);let o;const i=new Q;return i.cancelCallback=()=>{const e=this._createCancelInvocation(s.invocationId);return delete this._callbacks[s.invocationId],o.then((()=>this._sendWithProtocol(e)))},this._callbacks[s.invocationId]=(e,t)=>{t?i.error(t):e&&(e.type===$.Completion?e.error?i.error(new Error(e.error)):i.complete():i.next(e.item))},o=this._sendWithProtocol(s).catch((e=>{i.error(e),delete this._callbacks[s.invocationId]})),this._launchStreams(n,o),i}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._sendWithProtocol(this._createInvocation(e,t,!0,r));return this._launchStreams(n,s),s}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===$.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)switch(e.type){case $.Invocation:this._invokeClientMethod(e);break;case $.StreamItem:case $.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===$.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(S.Error,`Stream callback threw error: ${O(e)}`)}}break}case $.Ping:break;case $.Close:{this._logger.log(S.Information,"Close message received from server.");const t=e.error?new Error("Server returned an error on close: "+e.error):void 0;!0===e.allowReconnect?this.connection.stop(t):this._stopPromise=this._stopInternal(t);break}default:this._logger.log(S.Warning,`Invalid message type: ${e.type}.`)}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let t,n;try{[n,t]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(e){const t="Error parsing handshake response: "+e;this._logger.log(S.Error,t);const n=new Error(t);throw this._handshakeRejecter(n),n}if(t.error){const e="Server returned handshake error: "+t.error;this._logger.log(S.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(S.Debug,"Server handshake complete."),this._handshakeResolver(),n}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=(new Date).getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if(!(this.connection.features&&this.connection.features.inherentKeepAlive||(this._timeoutHandle=setTimeout((()=>this.serverTimeout()),this.serverTimeoutInMilliseconds),void 0!==this._pingServerHandle))){let e=this._nextKeepAlive-(new Date).getTime();e<0&&(e=0),this._pingServerHandle=setTimeout((async()=>{if(this._connectionState===W.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}}),e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const t=e.target.toLowerCase(),n=this._methods[t];if(!n)return this._logger.log(S.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null))));const r=n.slice(),s=!!e.invocationId;let o,i,a;for(const n of r)try{const r=o;o=await n.apply(this,e.arguments),s&&o&&r&&(this._logger.log(S.Error,`Multiple results provided for '${t}'. Sending error to server.`),a=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),i=void 0}catch(e){i=e,this._logger.log(S.Error,`A callback for the method '${t}' threw error '${e}'.`)}a?await this._sendWithProtocol(a):s?(i?a=this._createCompletionMessage(e.invocationId,`${i}`,null):void 0!==o?a=this._createCompletionMessage(e.invocationId,null,o):(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),a=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(a)):o&&this._logger.log(S.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(S.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new g("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===W.Disconnecting?this._completeClose(e):this._connectionState===W.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===W.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=W.Disconnected,this._connectionStarted=!1,T.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onclose callback called with error '${e}' threw error '${t}'.`)}}}async _reconnect(e){const t=Date.now();let n=0,r=void 0!==e?e:new Error("Attempting to reconnect due to a unknown error."),s=this._getNextRetryDelay(n++,0,r);if(null===s)return this._logger.log(S.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=W.Reconnecting,e?this._logger.log(S.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(S.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==W.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==s;){if(this._logger.log(S.Information,`Reconnect attempt number ${n} will start in ${s} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,s)})),this._reconnectDelayHandle=void 0,this._connectionState!==W.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=W.Connected,this._logger.log(S.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(S.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(S.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==W.Reconnecting)return this._logger.log(S.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===W.Disconnecting&&this._completeClose());r=e instanceof Error?e:new Error(e.toString()),s=this._getNextRetryDelay(n++,Date.now()-t,r)}}this._logger.log(S.Information,`Reconnect retries have been exhausted after ${Date.now()-t} ms and ${n} failed attempts. Connection disconnecting.`),this._completeClose()}_getNextRetryDelay(e,t,n){try{return this._reconnectPolicy.nextRetryDelayInMilliseconds({elapsedMilliseconds:t,previousRetryCount:e,retryReason:n})}catch(n){return this._logger.log(S.Error,`IRetryPolicy.nextRetryDelayInMilliseconds(${e}, ${t}) threw error '${n}'.`),null}}_cancelCallbacksWithError(e){const t=this._callbacks;this._callbacks={},Object.keys(t).forEach((n=>{const r=t[n];try{r(null,e)}catch(t){this._logger.log(S.Error,`Stream 'error' callback called with '${e}' threw error: ${O(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:$.Invocation}:{arguments:t,target:e,type:$.Invocation};{const n=this._invocationId;return this._invocationId++,0!==r.length?{arguments:t,invocationId:n.toString(),streamIds:r,target:e,type:$.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:$.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 s=e[r];if(this._isObservable(s)){const o=this._invocationId;this._invocationId++,t[o]=s,n.push(o.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:$.StreamInvocation}:{arguments:t,invocationId:r.toString(),target:e,type:$.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:$.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:$.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:$.Completion}:{invocationId:e,result:n,type:$.Completion}}}class ee{constructor(){this.name="json",this.version=1,this.transferFormat=B.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=_.instance);const n=Y.parse(e),r=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case $.Invocation:this._isInvocationMessage(n);break;case $.StreamItem:this._isStreamItemMessage(n);break;case $.Completion:this._isCompletionMessage(n);break;case $.Ping:case $.Close:break;default:t.log(S.Information,"Unknown message type '"+n.type+"' ignored.");continue}r.push(n)}return r}writeMessage(e){return Y.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),void 0!==e.invocationId&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),void 0===e.item)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const te={trace:S.Trace,debug:S.Debug,info:S.Information,information:S.Information,warn:S.Warning,warning:S.Warning,error:S.Error,critical:S.Critical,none:S.None};class ne{configureLogging(e){if(C.isRequired(e,"logging"),void 0!==e.log)this.logger=e;else if("string"==typeof e){const t=function(e){const t=te[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new N(t)}else this.logger=new N(e);return this}withUrl(e,t){return C.isRequired(e,"url"),C.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return C.isRequired(e,"protocol"),this.protocol=e,this}withAutomaticReconnect(e){if(this.reconnectPolicy)throw new Error("A reconnectPolicy has already been set.");return e?Array.isArray(e)?this.reconnectPolicy=new a(e):this.reconnectPolicy=e:this.reconnectPolicy=new a,this}build(){const e=this.httpConnectionOptions||{};if(void 0===e.logger&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const t=new K(this.url,e);return Z.create(t,this.logger||_.instance,this.protocol||new ee,this.reconnectPolicy)}}class re{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 s(e,t,n,s,o,i){return r(function(e,t){return e<<t|e>>>32-t}(r(r(t,e),r(s,i)),o),n)}function o(e,t,n,r,o,i,a){return s(t&n|~t&r,e,t,o,i,a)}function i(e,t,n,r,o,i,a){return s(t&r|n&~r,e,t,o,i,a)}function a(e,t,n,r,o,i,a){return s(t^n^r,e,t,o,i,a)}function c(e,t,n,r,o,i,a){return s(n^(t|~r),e,t,o,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,m=-1732584194,y=271733878;for(u=0;u<g.length;u+=16)l=f,d=v,h=m,p=y,f=o(f,v,m,y,g[u+0],7,-680876936),y=o(y,f,v,m,g[u+1],12,-389564586),m=o(m,y,f,v,g[u+2],17,606105819),v=o(v,m,y,f,g[u+3],22,-1044525330),f=o(f,v,m,y,g[u+4],7,-176418897),y=o(y,f,v,m,g[u+5],12,1200080426),m=o(m,y,f,v,g[u+6],17,-1473231341),v=o(v,m,y,f,g[u+7],22,-45705983),f=o(f,v,m,y,g[u+8],7,1770035416),y=o(y,f,v,m,g[u+9],12,-1958414417),m=o(m,y,f,v,g[u+10],17,-42063),v=o(v,m,y,f,g[u+11],22,-1990404162),f=o(f,v,m,y,g[u+12],7,1804603682),y=o(y,f,v,m,g[u+13],12,-40341101),m=o(m,y,f,v,g[u+14],17,-1502002290),v=o(v,m,y,f,g[u+15],22,1236535329),f=i(f,v,m,y,g[u+1],5,-165796510),y=i(y,f,v,m,g[u+6],9,-1069501632),m=i(m,y,f,v,g[u+11],14,643717713),v=i(v,m,y,f,g[u+0],20,-373897302),f=i(f,v,m,y,g[u+5],5,-701558691),y=i(y,f,v,m,g[u+10],9,38016083),m=i(m,y,f,v,g[u+15],14,-660478335),v=i(v,m,y,f,g[u+4],20,-405537848),f=i(f,v,m,y,g[u+9],5,568446438),y=i(y,f,v,m,g[u+14],9,-1019803690),m=i(m,y,f,v,g[u+3],14,-187363961),v=i(v,m,y,f,g[u+8],20,1163531501),f=i(f,v,m,y,g[u+13],5,-1444681467),y=i(y,f,v,m,g[u+2],9,-51403784),m=i(m,y,f,v,g[u+7],14,1735328473),v=i(v,m,y,f,g[u+12],20,-1926607734),f=a(f,v,m,y,g[u+5],4,-378558),y=a(y,f,v,m,g[u+8],11,-2022574463),m=a(m,y,f,v,g[u+11],16,1839030562),v=a(v,m,y,f,g[u+14],23,-35309556),f=a(f,v,m,y,g[u+1],4,-1530992060),y=a(y,f,v,m,g[u+4],11,1272893353),m=a(m,y,f,v,g[u+7],16,-155497632),v=a(v,m,y,f,g[u+10],23,-1094730640),f=a(f,v,m,y,g[u+13],4,681279174),y=a(y,f,v,m,g[u+0],11,-358537222),m=a(m,y,f,v,g[u+3],16,-722521979),v=a(v,m,y,f,g[u+6],23,76029189),f=a(f,v,m,y,g[u+9],4,-640364487),y=a(y,f,v,m,g[u+12],11,-421815835),m=a(m,y,f,v,g[u+15],16,530742520),v=a(v,m,y,f,g[u+2],23,-995338651),f=c(f,v,m,y,g[u+0],6,-198630844),y=c(y,f,v,m,g[u+7],10,1126891415),m=c(m,y,f,v,g[u+14],15,-1416354905),v=c(v,m,y,f,g[u+5],21,-57434055),f=c(f,v,m,y,g[u+12],6,1700485571),y=c(y,f,v,m,g[u+3],10,-1894986606),m=c(m,y,f,v,g[u+10],15,-1051523),v=c(v,m,y,f,g[u+1],21,-2054922799),f=c(f,v,m,y,g[u+8],6,1873313359),y=c(y,f,v,m,g[u+15],10,-30611744),m=c(m,y,f,v,g[u+6],15,-1560198380),v=c(v,m,y,f,g[u+13],21,1309151649),f=c(f,v,m,y,g[u+4],6,-145523070),y=c(y,f,v,m,g[u+11],10,-1120210379),m=c(m,y,f,v,g[u+2],15,718787259),v=c(v,m,y,f,g[u+9],21,-343485551),f=r(f,l),v=r(v,d),m=r(m,h),y=r(y,p);return n(f)+n(v)+n(m)+n(y)}}class se{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function oe(e){return new Map(Object.entries(e))}class ie{constructor(){this.TransactionId=re.GenerateUUID()}}var ae,ce,ue,le,de,he,pe,ge,fe,ve,me,ye,we,Se;(ye=ae||(ae={}))[ye.OK=0]="OK",ye[ye.UnknownError=1]="UnknownError",ye[ye.FatalError=2]="FatalError",ye[ye.WrongData=3]="WrongData",ye[ye.ResourceDoesNotExists=4]="ResourceDoesNotExists",ye[ye.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",ye[ye.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",ye[ye.OperationNotPermitted=7]="OperationNotPermitted",ye[ye.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",ye[ye.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",ye[ye.Error=10]="Error",ye[ye.NoData=11]="NoData",ye[ye.NotSupportedMethod=12]="NotSupportedMethod",ye[ye.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",ye[ye.MultiDataResponseStart=14]="MultiDataResponseStart",ye[ye.MultiDataResponse=15]="MultiDataResponse",ye[ye.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"}(ce||(ce={}));class _e{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"}(ue||(ue={})),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"}(le||(le={})),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"}(de||(de={}));class Ae{constructor(){this._log=Zf.Get(r.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)}}))}}(Se=he||(he={}))[Se.Any=0]="Any",Se[Se.Guest=10]="Guest",Se[Se.Standard=20]="Standard",Se[Se.Admin=30]="Admin",Se[Se.Installator=40]="Installator",Se[Se.Support=50]="Support",(we=pe||(pe={}))[we.Unknown=0]="Unknown",we[we.Men=1]="Men",we[we.Woman=2]="Woman",we[we.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(ge||(ge={})),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"}(fe||(fe={}));class Ce{constructor(e,t){this._type=ve.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 Te{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"}(ve||(ve={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(me||(me={}));class De{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=me.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}}class Ge{constructor(){this._log=Zf.Get(r.ServiceName),Ge._localStorageService=Zf.Get(o.ServiceName)}GetServiceName(){return Ge.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ae.OK&&(this._log.Debug(Ge.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Ge._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Ge._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Ge.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Ge._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Ge.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Ge._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Ge.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Ge._localStorageService=null,Ge.ServiceName="WebApiCacheService";var ke=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 be{constructor(){this._imageExistsCaseNumber=0,this._connection=Zf.Get(Gt.ServiceName),this._logger=Zf.Get(r.ServiceName)}GetServiceName(){return be.ServiceName}AddPictureAsync(e){var t,n;return ke(this,void 0,void 0,(function*(){try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ae.WrongData;let r=new Image;const s=new Promise(((t,n)=>{r.src=e.Base64Image,r.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield s))return this._logger.Error(be.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ae.WrongData;if(0===r.height||0===r.width)return this._logger.Error(be.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ae.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(be.ServiceName,"Cannot add picture - Guid must be empty."),ae.WrongData;const o=new Ee;o.Guid=re.GenerateUUID(),o.DateTime=(new Date).toISOString(),o.ImageType=e.ImageType,o.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`,o.Base64Image=e.Base64Image;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(o.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),ae.UnknownError;if(i.Status==ae.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ue(o),8e3,!1);return null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),ae.UnknownError):e.Status}return i.Status==ae.OK?(this._logger.Warning(be.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ae.UnknownError):(this._logger.Error(be.ServiceName,"Cannot add picture - cannot get current picture status."),ae.Error)}catch(e){return this._logger.Error(be.ServiceName,`Cannot add picture! ${e}`),ae.FatalError}}))}EditPictureAsync(e){var t,n;return ke(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot edit picture - guid is empty."),ae.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ae.WrongData;let r=new Image;const s=new Promise(((t,n)=>{r.src=e.Base64Image,r.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield s))return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ae.WrongData;if(0===r.height||0===r.width)return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ae.WrongData;const o=new Ee;o.DateTime=(new Date).toISOString(),o.ImageType=e.ImageType,o.Base64Image=e.Base64Image,o.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?o.OwnerGuid=e.OwnerGuid:o.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(o.Guid),8e3,!1);if(Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),ae.UnknownError;if(i.Status==ae.ResourceDoesNotExists)return this._logger.Error(be.ServiceName,"Cannot edit picture - picture not exists."),ae.OperationNotPermitted;if(i.Status==ae.OK){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ue(o),8e3,!1);return Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),ae.UnknownError):e.Status}return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot get current picture status."),ae.Error}catch(e){return this._logger.Error(be.ServiceName,`Cannot edit picture! ${e}`),ae.FatalError}}))}DeletePictureAsync(e){var t;return ke(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot delete picture - guid is empty."),ae.WrongData;const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Me(e.Guid),8e3,!1);return Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==n||null==n.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),ae.UnknownError):n.Status}catch(e){return this._logger.Error(be.ServiceName,`Cannot delete picture! ${e}`),ae.FatalError}}))}GetPicturesInfoAsync(){var e;return ke(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Pe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures info - unknown error!"),new Te(ae.UnknownError,"NoDataInResult")):t.Status!=ae.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Te(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Te(ae.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ie;return t.DateTime=e.DateTime,t.Guid=e.Guid,t.OwnerGuid=e.OwnerGuid,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture info! ${e}`),new Te(ae.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){var t;return ke(this,void 0,void 0,(function*(){try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(be.ServiceName,"Cannot get picture - unknown error!"),new Te(ae.UnknownError,"NoDataInResult");switch(n.Status){case ae.ResourceDoesNotExists:return new Te(ae.ResourceDoesNotExists,"PictureNotFound");case ae.OK:if(null==n.Data)return new Te(ae.Error,"RespondedWithOKButNoData");const e=new Ne;return e.Base64Image=n.Data.Base64Image,e.DateTime=n.Data.DateTime,e.ImageType=n.Data.ImageType,e.Guid=n.Data.Guid,-1!=n.Data.OwnerGuid.indexOf("_")?(e.OwnerGuid=n.Data.OwnerGuid.substring(0,n.Data.OwnerGuid.indexOf("_")),e.OwnerIdentity=n.Data.OwnerGuid.substring(n.Data.OwnerGuid.indexOf("_")+1)):n.Data.Guid.includes("profilePicture")?(e.OwnerIdentity=n.Data.Guid.substring(n.Data.Guid.indexOf("_")+1),e.OwnerGuid=n.Data.OwnerGuid):n.Data.Guid.includes("devices_group")?(e.OwnerIdentity=n.Data.Guid.substring(0,n.Data.Guid.lastIndexOf("_")),e.OwnerGuid=n.Data.OwnerGuid):(e.OwnerGuid=n.Data.OwnerGuid,e.OwnerIdentity=""),e;default:return new Te(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture! ${e}`),new Te(ae.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){var e;return ke(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Oe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures - unknown error!"),new Te(ae.UnknownError,"NoDataInResult")):t.Status!=ae.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Te(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Te(ae.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ne;return t.Base64Image=e.Base64Image,t.DateTime=e.DateTime,t.Guid=e.Guid,t.ImageType=e.ImageType,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get pictures! ${e}`),new Te(ae.FatalError,"ExceptionOccurred")}}))}}be.ServiceName="PictureService";class Ne extends De{set DateTime(e){this._dateTime=e}}class Ee{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=me.Device,this.DateTime=""}}class Ie{constructor(){this._guid="",this._dateTime="",this._ownerGuid="",this._ownerIdentity=""}get Guid(){return this._guid}get DateTime(){return this._dateTime}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}set Guid(e){this._guid=e}set DateTime(e){this._dateTime=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}}class Re extends ie{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ce.Get,this.Data=e}}class Pe extends ie{constructor(){super(),this.Resource="/pictures/info",this.Method=ce.Get}}class Oe extends ie{constructor(){super(),this.Resource="/pictures/list",this.Method=ce.Get}}class Ue extends ie{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ce.Put,this.Data=e}}class Me extends ie{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ce.Delete,this.Data=e}}var xe=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Fe{constructor(){this._connection=null,this._connection=Zf.Get(Gt.ServiceName),this._pictureService=Zf.Get(be.ServiceName),this._sessionService=Zf.Get(je.ServiceName)}CanEditUser(e){const t=this._sessionService.User;return e.Guid===(null==t?void 0:t.Guid)||this.CanEditUsersOfAccessLevel(e.AccessLevel)}CanEditUsersOfAccessLevel(e){var t;const n=null===(t=this._sessionService.User)||void 0===t?void 0:t.AccessLevel;if(void 0===n)return!1;switch(e){case he.Support:return n===he.Support;case he.Installator:return n>=he.Installator;case he.Admin:default:return n>=he.Admin}}GetServiceName(){return Fe.ServiceName}GetUsersAsync(){var e,t;return xe(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new We,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ae.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new He;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)==ae.NoData)return Promise.resolve([]);throw null===(t=s.Log)||void 0===t||t.Debug(Fe.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){var t,n;return xe(this,void 0,void 0,(function*(){if(""===e)return Promise.resolve(null);null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ae.OK)return null===(n=s.Log)||void 0===n||n.Debug(Fe.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const o=new He;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){var n;return xe(this,void 0,void 0,(function*(){if(null!=e.Guid&&""!=e.Guid)return new Te(ae.WrongData,"GuidMustBeEmpty");const r=new Be;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 s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new $e(r),2e4,!1);return Zf.Get(Ge.ServiceName).ClearCache(),null==s||null==s.Status?new Te(ae.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Te(s.Status,s.Data))}))}UpdateUserAsync(e){var t;return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.WrongData,"GuidCannotBeEmpty");const n=new Be;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 $e(n),2e4,!1);return Zf.Get(Ge.ServiceName).ClearCache(),null==r||null==r.Status?new Te(ae.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Te(r.Status,r.Data))}))}ChangePasswordAsync(e,t){var n;return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Te(ae.ResourceIsNotAvailable,"CannotGetUser");const s=new Be;s.Guid=e.Guid,s.Password=t,s.AccessLevel=r.AccessLevel,s.Email=r.Email;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new $e(s),2e4,!1);return null==o||null==o.Status?new Te(ae.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Te(o.Status,o.Data))}))}DeleteUserAsync(e){var t,n;return xe(this,void 0,void 0,(function*(){if(""===e)return ae.WrongData;null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new qe(e),2e4,!1);return Zf.Get(Ge.ServiceName).ClearCache(),null==r||null==r.Status?ae.FatalError:(r.Status!=ae.OK&&(null===(n=s.Log)||void 0===n||n.Debug(Fe.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}))}GetUserProfilePictureAsync(e){return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.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 Zf.Get(Ge.ServiceName).ClearCache(),null!=e.Type?t:e}return new Te(ae.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.WrongData,"GuidCannotBeEmpty");let n=new De;n.ImageType=me.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(Zf.Get(Ge.ServiceName).ClearCache(),r.Type==ae.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ae.OK?new Te(ae.OK,"PictureSet"):new Te(e,"PictureServiceError")}if(null!=r.Type)return new Te(ae.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ae.OK?new Te(ae.OK,"PictureSet"):new Te(e,"PictureServiceError")}}))}}Fe.ServiceName="UsersService";class Le extends ie{constructor(e){super(),this.Resource="/users/user",this.Method=ce.Get,this.Data=e}}class Be{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=pe.Unknown,this.AccessLevel=he.Any}}class $e extends ie{constructor(e){super(),this.Resource="/users/user",this.Method=ce.Put,this.Data=e}}class We extends ie{constructor(){super(),this.Resource="/users/list",this.Method=ce.Get}}class qe extends ie{constructor(e){super(),this.Resource="/users/user",this.Method=ce.Delete,this.Data=e}}class He{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=pe.Unknown,this._accessLevel=he.Any,this._localization=ge.En_Us}get Guid(){return this._guid}set Guid(e){this._guid=e}get CloudGuid(){return this._cloudGuid}set CloudGuid(e){this._cloudGuid=e}get Name(){return this._name}set Name(e){this._name=e}get Surname(){return this._surname}set Surname(e){this._surname=e}get Phone(){return this._phone}set Phone(e){this._phone=e}get AccessLevel(){return this._accessLevel}set AccessLevel(e){this._accessLevel=e}get Email(){return this._email}set Email(e){this._email=e}get IsAccountOnline(){return this._isAccountOnline}set IsAccountOnline(e){this._isAccountOnline=e}get IsActive(){return this._isAccountActive}set IsActive(e){this._isAccountActive=e}get IsBanned(){return this._isAccountBanned}set IsBanned(e){this._isAccountBanned=e}get NotificationChannels(){return this._notificationChannels}set NotificationChannels(e){this._notificationChannels=e}get Gender(){return this._gender}set Gender(e){this._gender=e}get Localization(){return this._localization}set Localization(e){this._localization=e}GetUserProfilePictureAsync(){return Zf.Get(Fe.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return Zf.Get(Fe.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var Ve=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class je{constructor(){this._onUserLoggedInEvent=new n,this._onUserLoggedOutEvent=new n,this._email="",this._password="",this._authToken="",this._loginTaskCompletionSource=this.CreateSessionCompletionSourceAsync(),this._alreadySubsribedToNetworkEvents=!1,this._user=null}CreateSessionCompletionSourceAsync(){var e;return Ve(this,void 0,void 0,(function*(){null===(e=s.Log)||void 0===e||e.Debug(je.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{let t=n=>{var r;null===(r=s.Log)||void 0===r||r.Debug(je.ServiceName,`Logged in as ${n.Name}, completing CreateSessionCompletionSourceAsync()`),e(),this.OnUserLoggedInEvent().Unsubscribe(t)};this.OnUserLoggedInEvent().Subscribe(t)}))}))}RestoreSessionAsync(){var e;return Ve(this,void 0,void 0,(function*(){null===(e=s.Log)||void 0===e||e.Debug(je.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0!==this._user&&null!==this._user&&(yield this.UserLogInAsync(this._email,this._password))}))}WaitForSessionCreationAsync(){return Ve(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){var e,t;return Ve(this,void 0,void 0,(function*(){var n=new ie;n.Resource="/users/user/logout",n.Method=ce.Put,this._email="",this._password="",(yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ae.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=s.Log)||void 0===e||e.Debug(je.ServiceName,"User has been logged out.")):null===(t=s.Log)||void 0===t||t.Debug(je.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return Ve(this,void 0,void 0,(function*(){switch(e){case de.Disconnected:case de.Failed:break;case de.Connected:Zf.Get(je.ServiceName).RestoreSessionAsync()}}))}AuthorizeAppAsync(e){var t,n,r,o;return Ve(this,void 0,void 0,(function*(){var i=Zf.Get(Gt.ServiceName);const a=yield i.SendAndWaitForResponseAsync(new ze(e),2e4,!1);if(a.Status==ae.OK&&null!=a.Data){this._authToken=e;var c=new He;return this._user=c,c.AccessLevel=a.Data.AccessLevel,c.Email=a.Data.Email,this._email=a.Data.Email,c.Gender=a.Data.Gender,c.Guid=a.Data.Guid,c.IsAccountOnline=a.Data.IsAccountOnline,c.Name=a.Data.Name,c.IsActive=a.Data.IsActive,c.IsBanned=a.Data.IsBanned,c.Phone=a.Data.Phone,c.Surname=a.Data.Surname,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,i.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(t=s.Log)||void 0===t||t.Debug(je.ServiceName,`Did logging in succeded?: ${a.Status==ae.OK}`),this._onUserLoggedInEvent.Invoke(this._user),c}return a.Status===ae.OperationNotPermitted?(null===(n=s.Log)||void 0===n||n.Debug(je.ServiceName,`App login response: ${a.Data}`),fe.AuthDisabled):a.Status===ae.ResourceDoesNotExists?(null===(r=s.Log)||void 0===r||r.Debug(je.ServiceName,`App login response: ${a.Data}`),fe.MethodNotSupported):(null===(o=s.Log)||void 0===o||o.Debug(je.ServiceName,`App login response: ${a.Data}`),fe.WrongAuthData)}))}UserLogInAsync(e,t){var n,r;return Ve(this,void 0,void 0,(function*(){var o=Zf.Get(Gt.ServiceName);const i=yield o.SendAndWaitForResponseAsync(new Je(e,t),2e4,!1);if(i.Status==ae.OK&&null!=i.Data){this._email=e,this._password=t;var a=new He;return this._user=a,a.AccessLevel=i.Data.AccessLevel,a.Email=i.Data.Email,a.Gender=i.Data.Gender,a.Guid=i.Data.Guid,a.IsAccountOnline=i.Data.IsAccountOnline,a.Name=i.Data.Name,a.IsActive=i.Data.IsActive,a.IsBanned=i.Data.IsBanned,a.Phone=i.Data.Phone,a.Surname=i.Data.Surname,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,o.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(n=s.Log)||void 0===n||n.Debug(je.ServiceName,`Did logging in succeded?: ${i.Status==ae.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return null===(r=s.Log)||void 0===r||r.Debug(je.ServiceName,`User login response: ${i.Data}`),fe.WrongAuthData}))}GetServiceName(){return je.ServiceName}}je.ServiceName="SessionService";class Ke{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class ze extends ie{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=ce.Put}}class Je extends ie{constructor(e,t){super(),this.Data=new Ke(e,t),this.Resource="/users/user/login",this.Method=ce.Put}}var Ye=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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{GetServiceName(){return Xe.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new Ae,this._onExitedConfigurationEvent=new Ae,this._onConfigurationTimeCheckedEvent=new n,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{Zf.Get(je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Ye(this,void 0,void 0,(function*(){this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),this._didConfigurationChange&&Zf.Get(Ge.ServiceName).ClearCache(),e()}))))})),this._connection=Zf.Get(Gt.ServiceName),this._session=Zf.Get(je.ServiceName),this._localStorage=Zf.Get(o.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{Zf.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{Zf.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke()}))}GetControllerSystemTimeAsync(){var e;return Ye(this,void 0,void 0,(function*(){try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new st,8e3,!1);return null==t||null==t.Status?ae.Error:t.Status!=ae.OK?t.Status:null==t.Data?ae.ResourceIsNotAvailable:new Date(t.Data)}catch(e){return Zf.Get(r.ServiceName).Error(Xe.ServiceName,`Cannot get current controller time! ${e}`),ae.FatalError}}))}SetControllerSystemTimeAsync(e){var t;return Ye(this,void 0,void 0,(function*(){try{var n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ot(e.toISOString()),8e3,!1);return null==n||null==n.Status?ae.Error:n.Status}catch(e){return Zf.Get(r.ServiceName).Error(Xe.ServiceName,`Cannot set current controller time! ${e}`),ae.FatalError}}))}StartNtpTimeSynchronizationAsync(){var e;return Ye(this,void 0,void 0,(function*(){try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new it,8e3,!1);return null==t||null==t.Status?ae.Error:t.Status}catch(e){return Zf.Get(r.ServiceName).Error(Xe.ServiceName,`Cannot set current controller time! ${e}`),ae.FatalError}}))}FactoryResetAsync(e){var t,n;return Ye(this,void 0,void 0,(function*(){try{Zf.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ze,2e3,!1))||void 0===n?void 0:n.Status;if(r==ae.OK){let t=300,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Zf.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}RollbackLastUpdateAsync(e){var t,n;return Ye(this,void 0,void 0,(function*(){try{Zf.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new et,2e3,!1))||void 0===n?void 0:n.Status;if(r==ae.OK){let t=420,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Zf.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}RestartControllerAsync(e){var t,n;return Ye(this,void 0,void 0,(function*(){try{Zf.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Qe,2e3,!1))||void 0===n?void 0:n.Status;if(r==ae.OK){let t=240,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),Zf.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}DidCofigurationChangeAsync(){return Ye(this,void 0,void 0,(function*(){return yield this._synchronizationTaskCompletionSource,Promise.resolve(this._didConfigurationChange)}))}GetLastKnownConfigurationChangeTime(){var e;const t=null===(e=this._localStorage)||void 0===e?void 0:e.Read(this.GetServiceName(),"last_configuration_time");return null!=t?new Date(t):new Date}SaveLastConfigurationChangeTime(e){var t;null===(t=this._localStorage)||void 0===t||t.Save(this.GetServiceName(),"last_configuration_time",e.toString())}EnterConfigurationModeAsync(){var e;return Ye(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,Zf.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new tt,2e4,!1)}))}ExitConfigurationModeAsync(){var e;return Ye(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,Zf.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new nt,2e4,!1),Zf.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){var e;return Ye(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new rt,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ae.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return Ye(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),Zf.Get(Ge.ServiceName).ClearCache(),!0)}))}}Xe.ServiceName="ControllerConfigurationService";class Qe extends ie{constructor(){super(),this.Resource="/controller/restart",this.Method=ce.Post}}class Ze extends ie{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ce.Post}}class et extends ie{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ce.Post}}class tt extends ie{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ce.Put}}class nt extends ie{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ce.Put}}class rt extends ie{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ce.Get}}class st extends ie{constructor(){super(),this.Resource="/system/time",this.Method=ce.Get}}class ot extends ie{constructor(e){super(),this.Resource="/system/time",this.Method=ce.Put,this.Data=e}}class it extends ie{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=ce.Put}}var at,ct,ut,lt,dt,ht,pt,gt,ft,vt,mt,yt,wt,St,_t,At,Ct,Tt,Dt=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Gt{constructor(){this._logPackets=!1,this._pingInterval=5e3,this._disconnectedOnPurpose=!1,this._defaultPacketsBrokerAddress="br1.tr7.pl",this._serversBrokerAddress="https://broker.tr7.pl",this._serversBrokerAddressList=["https://broker.tr7.pl","https://dev-brokers.lavva.tech"],this._allBrokersChecked=!1,this._address="br1.tr7.pl",this._isEstabilished=!1,this._timeout=1e4,this._dataReceivedEvent=new n,this._pongReceivedEvent=new Ae,this._authorizationReceivedEvent=new n,this._registrationReceivedEvent=new n,this._connectionStateChangedEvent=new n,this._errorOccuredEvent=new n,this._log=Zf.Get(r.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._packetsBrokerServers=["br1.tr7.pl","br1.exala.pl"],this._lastReceivedPacketTime=Date.now()}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}GetControllerSerialNumber(){return this._serialId}GetControllerPin(){return this._PIN}GetServiceName(){return Gt.ServiceName}EnablePacketsLogging(){this._logPackets=!0}DisablePacketsLogging(){this._logPackets=!1}InitializeConnection(){if(this._controllerConfiguration=Zf.Get(Xe.ServiceName),this._cache=Zf.Get(Ge.ServiceName),this._session=Zf.Get(je.ServiceName),this._connection){try{this._connection.stop()}catch(e){}this._connection=void 0}if(!this._address)throw new Error("Domain is not set");if(!this._serialId)throw new Error("SerialId is not set");if(!this._PIN)throw new Error("PIN is not set");this._connection=(new ne).withUrl(`https://${this._address}/broker`).build(),this._dataReceivedEvent.Subscribe((e=>{this._lastReceivedPacketTime=Date.now()})),setInterval((()=>Dt(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval)}GetAuthorizationInfo(){return null!=this._serialId&&null!=this._PIN?new _e(this._serialId,this._PIN):null}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._defaultPacketsBrokerAddress=e,this._address=e}GetServerAddressAsync(){return Dt(this,void 0,void 0,(function*(){try{let e=yield fetch(`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`);if(200===e.status){let t=yield e.text();return t?(this._log.Debug(Gt.ServiceName,`Got server address: ${t}`),t):(this._log.Error(Gt.ServiceName,`Failed to get server address, status: ${e.status}`),null)}return this._allBrokersChecked?(this._allBrokersChecked=!1,null):204===e.status?(this.swapBrokersAsync(!1),this.GetServerAddressAsync()):(this._log.Error(Gt.ServiceName,`Failed to get server address, status: ${e.status}`),null)}catch(e){return this._log.Error(Gt.ServiceName,e),null}}))}ConnectAsync(e){return Dt(this,void 0,void 0,(function*(){return this._address=e,yield this.connectAsync()}))}AuthorizeAsync(e){return new Promise(((t,n)=>Dt(this,void 0,void 0,(function*(){var n;let r=0,s=e=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),this._log.Debug(Gt.ServiceName,`Got authorization result: ${e}`),t(e)};r=window.setTimeout((()=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),t(!1)}),2e3),this._log.Debug(Gt.ServiceName,`Authorizing to cloud using: ${e.SerialNumber} PIN: ${e.PIN}`),this._authorizationReceivedEvent.Subscribe(s),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)}))))}ConnectAndAuthorizeAsync(e){return Dt(this,void 0,void 0,(function*(){Zf.WorksInContextOf=e.SerialNumber,this._serialId=e.SerialNumber,this._PIN=e.PIN;var t=yield this.GetServerAddressAsync();if(t&&null!=t){this._log.Debug(Gt.ServiceName,`Got packets broker address: ${t}`),this.SetDefaultPacketsBrokerAddress(t);let r=yield this.connectAsync();if(r!=le.Connected)return r;var n=yield this.AuthorizeAsync(e);if(!n){if(yield this.swapBrokersAsync(),!this._allBrokersChecked)return this.ConnectAndAuthorizeAsync(e);this._allBrokersChecked=!1}return n?le.Connected:le.AuthorizationFailed}{let t=le.ControllerIsNotConnected;this._log.Warning(Gt.ServiceName,"Server did not return packets broker address, trying to connect to known brokers.");for(let n of this._packetsBrokerServers){this._log.Warning(Gt.ServiceName,`Testing connection to ${n}`),this.SetDefaultPacketsBrokerAddress(n);try{yield this.DisconnectAsync()}catch(e){}this._log.Warning(Gt.ServiceName,`Connecting to server: ${n}`);let r=yield this.connectAsync();if(this._log.Warning(Gt.ServiceName,`Connection result: ${r}`),r==le.Connected){if(yield this.AuthorizeAsync(e))return t=le.Connected,t;this._log.Warning(Gt.ServiceName,`Failed to authorize in ${n}`)}}return t}}))}swapBrokersAsync(e=!0){return Dt(this,void 0,void 0,(function*(){e&&(yield this.DisconnectAsync());var t=this._serversBrokerAddressList.lastIndexOf(this._serversBrokerAddress);t+1<this._serversBrokerAddressList.length?(this._serversBrokerAddress=this._serversBrokerAddressList[t+1],this._log.Debug(`Changing address of next broker from: ${this._serversBrokerAddressList[t]} to: ${this._serversBrokerAddressList[t+1]}`)):(this._log.Debug(`All brokers checked, changing address to first one: ${this._serversBrokerAddressList[0]}`),this._allBrokersChecked=!0,this._serversBrokerAddress=this._serversBrokerAddressList[0])}))}connectAsync(){var e,t,n,r,s,o,i,a,c;return Dt(this,void 0,void 0,(function*(){if(le.FailedToConnect,!this._address)return Promise.resolve(le.ControllerIsNotConnected);this._disconnectedOnPurpose&&(this._disconnectedOnPurpose=!1),this._connectionStateChangedEvent,this.InitializeConnection(),null===(e=this._connection)||void 0===e||e.onclose((()=>Dt(this,void 0,void 0,(function*(){var e,t;if(this._disconnectedOnPurpose?this._log.Info(Gt.ServiceName,"Connection closed on demand."):this._log.Error(Gt.ServiceName,"Connection closed"),Zf.Get(je.ServiceName).CreateSessionCompletionSourceAsync(),this.FireConnectionStateChanged(),(null===(e=this._connection)||void 0===e?void 0:e.state)===W.Disconnected&&!this._disconnectedOnPurpose)return yield null===(t=this._connection)||void 0===t?void 0:t.start(),null!=this._connection?(yield this.AuthorizeAsync(new _e(this._serialId,this._PIN)),this._log.Info(Gt.ServiceName,"Reconnected from onClose"),this.FireConnectionStateChanged()):le.FailedToConnect})))),null===(t=this._connection)||void 0===t||t.onreconnected((()=>Dt(this,void 0,void 0,(function*(){return yield this.AuthorizeAsync(new _e(this._serialId,this._PIN)),this._log.Info(Gt.ServiceName,"Reconnected from onreconnected"),this.FireConnectionStateChanged()})))),null===(n=this._connection)||void 0===n||n.onreconnecting((()=>(this._log.Warning(Gt.ServiceName,"Reconnecting..."),this.FireConnectionStateChanged()))),yield null===(r=this._connection)||void 0===r?void 0:r.start(),null===(s=this._connection)||void 0===s||s.on("Pong",(()=>{this._log.Debug(Gt.ServiceName,"Pong received <-"),this._pongReceivedEvent.Invoke()})),null===(o=this._connection)||void 0===o||o.on("Registration",(e=>{var t;null===(t=this._registrationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(i=this._connection)||void 0===i||i.on("Authorization",(e=>{var t;null===(t=this._authorizationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(a=this._connection)||void 0===a||a.on("SendError",((e,t)=>Dt(this,void 0,void 0,(function*(){e.startsWith("NotAuthorized:")?(this._log.Error(Gt.ServiceName,"Failed to authorize!"),yield this.AuthorizeAsync(new _e(this._serialId,this._PIN))):(this._log.Error(Gt.ServiceName,`Server returned error: ${e} ${t}`),this._errorOccuredEvent.Invoke([e,t]))}))));let u=this._dataReceivedEvent;return null===(c=this._connection)||void 0===c||c.on("Data",((e,t)=>{const n=JSON.parse(t);(this._logPackets||!0===window.packets)&&this._log.Debug(Gt.ServiceName,`Received data:\n${JSON.stringify(n,null,2)}`),u.Invoke(n)})),null!=this._connection?this.FireConnectionStateChanged():le.FailedToConnect}))}FireConnectionStateChanged(){var e;const t=this._connectionStateChangedEvent;switch(null===(e=this._connection)||void 0===e?void 0:e.state){case W.Connected:return t.Invoke(de.Connected),le.Connected;case W.Connecting:return t.Invoke(de.Connecting),le.Connected;case W.Disconnected:return t.Invoke(de.Disconnected),le.FailedToConnect;case W.Disconnecting:return t.Invoke(de.Disconnecting),le.FailedToConnect;case W.Reconnecting:return t.Invoke(de.Reconnecting),le.FailedToConnect}return le.FailedToConnect}DisconnectAsync(){var e;return Dt(this,void 0,void 0,(function*(){this._disconnectedOnPurpose=!0,yield null===(e=this._connection)||void 0===e?void 0:e.stop()}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===W.Connected}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,r)}SendAndWaitForResponseWithRepeatAsync(e,t,n,r=!0,s=!0){var o,i,a;return Dt(this,void 0,void 0,(function*(){if(e.Method===ce.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.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(((o,i)=>Dt(this,void 0,void 0,(function*(){let a=i=>Dt(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;s&&this._log.Debug(Gt.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===ce.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ae.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(),o(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,s))),o(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(Gt.ServiceName,t),i(new p(t))}),t),!(yield this.SendAsync(e,s))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;i(new Error(t))}}))))}))}SendAndHandleResponseAsync(e,t,n,r=!0){var s;return Dt(this,void 0,void 0,(function*(){let o=0;const i=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(s=this._session)||void 0===s?void 0:s.WaitForSessionCreationAsync()),new Promise(((s,a)=>Dt(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(Gt.ServiceName,t),a(new p(t))}),t);let u=l=>Dt(this,void 0,void 0,(function*(){var d,h,p;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(o);const g=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Gt.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)===ae.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(),s(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ae.MultiDataResponseStart:case ae.MultiDataResponse:n(l),o=c();break;case ae.MultiDataResponseStop:n(l),this._dataReceivedEvent.Unsubscribe(u),s();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),o=c(),!(yield this.SendAsync(e,r))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;a(new Error(t))}}))))}))}PingControllerAsync(){var e;return Dt(this,void 0,void 0,(function*(){if((null===(e=this._connection)||void 0===e?void 0:e.state)!==W.Connected)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new ie;return t.Resource="/system/ping",t.Method=ce.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SendAsync(e,t=!1){if(!this.IsConnected())throw new Error("Connection is not established");return new Promise((n=>{var r;this._logPackets||!0===window.packets?this._log.Debug(Gt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId} data:\n${JSON.stringify(e,null,2)}`):t&&this._log.Debug(Gt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId}`),null===(r=this._connection)||void 0===r||r.invoke("SendTo",this._serialId,e).then((()=>{n(!0)})).catch((e=>{this._log.Error(Gt.ServiceName,`${e}`),n(!1)}))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}}Gt.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(at||(at={})),(yt=ct||(ct={}))[yt.Default=0]="Default",yt[yt.Monostable=1]="Monostable",yt[yt.Bistable=2]="Bistable",yt[yt.Gate=3]="Gate",yt[yt.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"}(ut||(ut={}));class kt{constructor(){this._type=dt.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(St=lt||(lt={}))[St.Unknown=0]="Unknown",St[St.BlindMotor=1]="BlindMotor",St[St.DinModule=2]="DinModule",St[St.DinModuleWithAntenna=3]="DinModuleWithAntenna",St[St.Remote=4]="Remote",St[St.RemoteForBlinds=5]="RemoteForBlinds",St[St.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",St[St.MovementSensor=7]="MovementSensor",St[St.TemperatureSensor=8]="TemperatureSensor",St[St.HumiditySensor=9]="HumiditySensor",St[St.DinPowerMeter=10]="DinPowerMeter",St[St.Intercom=11]="Intercom",St[St.SecurityCamera=12]="SecurityCamera",St[St.Multisensor=13]="Multisensor",St[St.FloodSensor=14]="FloodSensor",St[St.FlushMountedReceiver=15]="FlushMountedReceiver",St[St.FlushMountedBlindController=16]="FlushMountedBlindController",St[St.FlushMountedDimmer=17]="FlushMountedDimmer",St[St.FlushMountedRelay=18]="FlushMountedRelay",St[St.FlushMountedGateController=19]="FlushMountedGateController",St[St.WindSensor=20]="WindSensor",St[St.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",St[St.AirPressureSensor=22]="AirPressureSensor",St[St.LightBrightnessSensor=23]="LightBrightnessSensor",St[St.ReedSensor=24]="ReedSensor",St[St.FlushMountedTransceiver=25]="FlushMountedTransceiver",St[St.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",St[St.WallMountedThermoregulator=27]="WallMountedThermoregulator",St[St.ImpulseCounter=28]="ImpulseCounter",St[St.FlushMountedFacadeController=29]="FlushMountedFacadeController",St[St.WallMountedGateController=30]="WallMountedGateController",St[St.WallMountedRGBLightController=31]="WallMountedRGBLightController",St[St.WallMountedDimmer=32]="WallMountedDimmer",St[St.WallMountedRemote=33]="WallMountedRemote",St[St.DinRelay=34]="DinRelay",St[St.DinReceiver=35]="DinReceiver",St[St.DinBlindController=36]="DinBlindController",St[St.DinTransceiver=37]="DinTransceiver",St[St.SocketPlugIn=38]="SocketPlugIn",St[St.WallMountedRelay=39]="WallMountedRelay",St[St.Retransmitter=40]="Retransmitter",(wt=dt||(dt={})).Unknown="Unknown",wt.SetBlindPosition="IBlindPosition",wt.SetBlindPositionSimple="IBlindPositionSimple",wt.SetBlindMicroventilation="IMicroventilation",wt.TurnOff="IChannelOff",wt.TurnOn="IChannelOn",wt.TurnOnWithTime="IChannelOnWithTime",wt.TogleState="IChannelSwitchState",wt.SetLightBrightnessDynamicly="IDynamicLightBrightness",wt.SetLightBrightness="ILightBrightness",wt.SetLightColor="ILightColor",wt.SetLightTemperature="ILightTemperature",wt.PairDevice="IPair",wt.UnpairDevice="IUnpair",wt.IdentifyDevice="IIdentifyDevice",wt.GetChannelsState="IGetDeviceState",wt.GetPowerMeasurements="IGetPowerMeasurements",wt.GetAvailableData="IGetAvailableData",wt.MultipleDataRequest="IMultipleDataRequest",wt.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",wt.SetTemperature="IChangeTemperature",wt.SetGatePosition="IGatePosition",wt.SetGatewayPosition="IGatewayPosition",wt.ChangeGatePositionPulse="IGatePulse",wt.ChangeGatewayPositionPulse="IGatewayPulse",wt.SetFacadePosition="IFacadePosition",wt.GetFacadeType="IGetFacadeType",wt.LightRGBW="ILightRGBW",wt.PreciseGateControl="IPreciseGateControl";class bt{constructor(){this._type=ht.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Tt=ht||(ht={})).Unknown="Unknown",Tt.BatteryState="IBatteryState",Tt.BinarySensorState="IBinarySensor",Tt.BlindOpenCloseTime="IBlindOpenCloseTime",Tt.BlindPosition="IBlindPosition",Tt.BlindRemoteButtonState="IBlindsControlButton",Tt.MeasuredBrightness="IBrightness",Tt.RemoteButtonState="IButtonState",Tt.ChannelOnOffState="IChannelOnOff",Tt.IntercomState="IIntercom",Tt.DoorBellState="IDoorBell",Tt.FacadeRemoteButtonState="IFacadeControlButton",Tt.FacadePosition="IFacadeState",Tt.FacadeType="IFacadeType",Tt.FloodSensorState="IFloodSensor",Tt.GatePosition="IGatePosition",Tt.GatewayPosition="IGatewayPosition",Tt.GateControllerHealth="IGateControllerHealth",Tt.HumiditySensorState="IHumiditySensor",Tt.LightBrightness="ILightBrightness",Tt.LightColor="ILightColor",Tt.LightWarmth="ILightTemperature",Tt.LightTreshold="ILightTreshold",Tt.MovementSensorState="IMovementSensor",Tt.OnlineCamera="IOnlineCamera",Tt.OvercurrentProtectionState="IOvercurrentProtection",Tt.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",Tt.ReedState="IReedState",Tt.SignalStrength="ISignalStrength",Tt.SmokeSensorState="ISmokeSensor",Tt.MeasuredTemperature="ITemperature",Tt.VibrationSensorState="IVibrationSensor",Tt.MeasuredWindSpeed="IWindSpeed",Tt.WindThreshold="IWindThreshold",Tt.MeasuredEnergy="IEnergy",Tt.MeasuredDistance="DistanceSensor",Tt.BlindCalibration="BlindCalibration",Tt.ConfigurationState="ConfigurationState",Tt.CurrentWindThreshold="CurrentWindThreshold",Tt.CurrentLightThreshold="CurrentLightThreshold",Tt.WindSpeedState="WindSpeed",Tt.TamperProtectionState="ITamperProtection",Tt.PressureSensorState="IPressureSensor",Tt.LightRGBWState="ILightRGBW",(Ct=pt||(pt={}))[Ct.NotResponding=0]="NotResponding",Ct[Ct.Working=1]="Working",Ct[Ct.Broken=2]="Broken",Ct[Ct.FirmareUpgradeMode=3]="FirmareUpgradeMode",(At=gt||(gt={}))[At.TwoWay=1]="TwoWay",At[At.OneWay=2]="OneWay",At[At.ConditionalTwoWay=3]="ConditionalTwoWay",(_t=ft||(ft={}))[_t.Unknown=-1]="Unknown",_t[_t.Multipurpose=0]="Multipurpose",_t[_t.Controller=1]="Controller",_t[_t.Driver=2]="Driver",_t[_t.Receiver=3]="Receiver",_t[_t.Remote=4]="Remote",_t[_t.Sensor=5]="Sensor",_t[_t.Scene=6]="Scene";class Nt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=at.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"}(vt||(vt={})),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"}(mt||(mt={}));class Et{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=mt.Unknown}}var It,Rt,Pt,Ot,Ut,Mt,xt,Ft,Lt,Bt,$t,Wt,qt,Ht,Vt,jt,Kt,zt,Jt,Yt,Xt,Qt,Zt,en,tn,nn,rn,sn,on;class an{constructor(){this._type="",this._data=null,this._typeAsEnum=ht.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 s=0;for(r=Object.getOwnPropertySymbols(e);s<r.length;s++)t.indexOf(r[s])<0&&Object.prototype.propertyIsEnumerable.call(e,r[s])&&(n[r[s]]=e[r[s]])}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}}(on=It||(It={}))[on.Confident=0]="Confident",on[on.Unconfident=1]="Unconfident";class cn extends an{constructor(e){super(),this.TypeAsEnum=ht.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class un{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Rt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Rt||(Rt={})),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"}(Pt||(Pt={}));class ln extends an{constructor(e){super(),this.TypeAsEnum=ht.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class dn extends an{constructor(e){super(),this.TypeAsEnum=ht.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class hn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Ot.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(Ot||(Ot={}));class pn extends an{constructor(e){super(),this.TypeAsEnum=ht.ReedState,this.Type="ReedState",this.Data=e.state}}class gn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=!1,this.Time=""}}class fn extends an{constructor(e){super(),this.TypeAsEnum=ht.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return Ut.UnableToMove;case 201:return Ut.MotorOverheatedPleaseWait;default:return Ut.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(Ut||(Ut={}));class vn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class mn extends an{constructor(e){super(),this.TypeAsEnum=ht.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class yn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Mt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(Mt||(Mt={}));class wn extends an{constructor(e){super(),this.TypeAsEnum=ht.LightColor,this.Type="LightColorState",this.Data=e.state}}class Sn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class _n extends an{constructor(e){super(),this.TypeAsEnum=ht.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class An{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Temperature=0,this.Time=""}}class Cn extends an{constructor(e){super(),this.TypeAsEnum=ht.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class Tn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Brightness=0,this.Time=""}}class Dn extends an{constructor(e){super(),this.TypeAsEnum=ht.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class Gn{constructor(){this.Channel=0,this.StateReliability=It.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 kn extends an{constructor(e){super(),this.TypeAsEnum=ht.BatteryState,this.Type="BatteryState",this.Data=e.state}}class bn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Ft.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"}(Ft||(Ft={}));class Nn extends an{constructor(e){super(),this.TypeAsEnum=ht.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class En{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Brightness=0,this.Time=""}}class In extends an{constructor(e){super(),this.TypeAsEnum=ht.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class Rn{constructor(){this.Channel=0,this.StateReliability=It.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"}(Lt||(Lt={}));class Pn extends an{constructor(e){super(),this.TypeAsEnum=ht.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Bt||(Bt={}));class On extends an{constructor(e){super(),this.TypeAsEnum=ht.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Un{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Intensity=0,this.Movement=$t.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}($t||($t={}));class Mn extends an{constructor(e){super(),this.TypeAsEnum=ht.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class xn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Wt.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"}(Wt||(Wt={}));class Fn extends an{constructor(e){super(),this.TypeAsEnum=ht.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class Ln{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=qt.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"}(qt||(qt={}));class Bn extends an{constructor(e){super(),this.TypeAsEnum=ht.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"}(Ht||(Ht={}));class $n extends an{constructor(e){super(),this.TypeAsEnum=ht.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class Wn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.PositionType=Vt.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"}(Vt||(Vt={}));class qn extends an{constructor(e){super(),this.TypeAsEnum=ht.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"}(jt||(jt={}));class Hn extends an{constructor(e){super(),this.TypeAsEnum=ht.GateControllerHealth,this.Type="GateControllerHealthState",this.Data=e.state}}class Vn extends an{constructor(e){super(),this.TypeAsEnum=ht.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"}(Kt||(Kt={}));class jn extends an{constructor(e){super(),this.TypeAsEnum=ht.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class Kn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Type=zt.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"}(zt||(zt={}));class zn extends an{constructor(e){super(),this.TypeAsEnum=ht.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Jt||(Jt={}));class Jn extends an{constructor(e){super(),this.TypeAsEnum=ht.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class Yn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Yt.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(Yt||(Yt={}));class Xn extends an{constructor(e){super(),this.TypeAsEnum=ht.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"}(Xt||(Xt={}));class Qn extends an{constructor(e){super(),this.TypeAsEnum=ht.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class Zn extends an{constructor(e){super(),this.TypeAsEnum=ht.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class er extends an{constructor(e){super(),this.TypeAsEnum=ht.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class tr extends an{constructor(e){super(),this.TypeAsEnum=ht.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class nr extends an{constructor(e){super(),this.TypeAsEnum=ht.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class rr extends an{constructor(e){super(),this.TypeAsEnum=ht.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class sr{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.WindThreshold=Qt.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"}(Qt||(Qt={}));class or extends an{constructor(e){super(),this.TypeAsEnum=ht.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"}(Zt||(Zt={}));class ir extends an{constructor(e){super(),this.TypeAsEnum=ht.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class ar{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Value=0,this.Time=""}}class cr extends an{constructor(e){super(),this.TypeAsEnum=ht.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class ur{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=en.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(en||(en={})),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"}(tn||(tn={}));class lr extends an{constructor(e){super(),this.TypeAsEnum=ht.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class dr{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Pressure=0,this.Time="",this.PressureType=nn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(nn||(nn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(rn||(rn={}));class hr extends an{constructor(e){super(),this.TypeAsEnum=ht.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(sn||(sn={}));class pr extends an{constructor(e){super(),this.TypeAsEnum=ht.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class gr{constructor(){this._onDeviceStateChangedEvent=new n,this._onDeviceStateRefreshedOrChangedEvent=new n,this._onDeviceTasksExecutionChangedOnChannelsEvent=new n,this._onDeviceFirmwareVersionChangedEvent=new n,this._iconType=lt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=pt.Working,this._deviceType=ft.Unknown,this._communicationWay=gt.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==gr._devicesService&&(gr._devicesService=Zf.Get(lo.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;gr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),gr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),gr._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===ft.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!==dt.SetBlindPositionSimple))}return!1}get States(){return r.DoesThrowStackTrace?Zf.Get(lo.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():gr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return gr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return gr._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,s=function*(){try{const t=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new fr(this,e),2e4,!1);switch(t.Status){case ae.OK:return this._name=e,Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),new Ce(ve.Changed,"");case ae.WrongData:if("DeviceNotFound"==t.Data)return new Ce(ve.Failed,"DeviceNotFound");break;case ae.NoPermissionsToCallGivenResource:return new Ce(ve.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new Ce(ve.ControllerResponseTimeout,""):new Ce(ve.UnknownError,"")}return new Ce(ve.Unknown,"")},new((r=void 0)||(r=Promise))((function(e,o){function i(e){try{c(s.next(e))}catch(e){o(e)}}function a(e){try{c(s.throw(e))}catch(e){o(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((s=s.apply(t,n||[])).next())}));var t,n,r,s}ExecuteTaskAsync(e){return gr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class fr extends ie{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ce.Put;const n=new vr;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class vr{constructor(){this.DeviceGuid="",this.Name=""}}var mr,yr,wr,Sr,_r,Ar,Cr=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Tr{constructor(){this._device=new gr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=ct.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this._configurations={},this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new n,this._onChannelStateChangedEvent=new n,this._onChannelStateRefreshedOrChangedEvent=new n,null==Tr._devicesService&&(Tr._devicesService=Zf.Get(lo.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 Cr(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new Dr;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 Dr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new Gr;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 Dr;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 Dr;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Dr;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 Dr;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 Dr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){var t;return Cr(this,void 0,void 0,(function*(){try{const n=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new kr(e),2e4,!1);switch(Zf.Get(Ge.ServiceName).ClearCache(),yield Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),n.Status){case ae.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 Ce(ve.Changed,"");case ae.WrongData:if("DeviceNotFound"===n.Data)return null===(t=s.Log)||void 0===t||t.Error("Failed to change channel configuration, referenced device does not exist!"),new Ce(ve.WrongData,"DeviceNotFound");break;case ae.FatalError:return new Ce(ve.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new Ce(ve.ControllerResponseTimeout,"")}return new Ce(ve.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 r.DoesThrowStackTrace?Zf.Get(lo.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Tr._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,Tr._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(mt.Failed)}}Tr._devicesService=null;class Dr{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new Gr}}class Gr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=ct.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class kr extends ie{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ce.Put,this.Data=e}}(Ar=mr||(mr={}))[Ar.TurnOn=0]="TurnOn",Ar[Ar.TurnOff=1]="TurnOff",Ar[Ar.ToggleState=2]="ToggleState",Ar[Ar.SetBlindPosition=3]="SetBlindPosition",Ar[Ar.SetLightColor=4]="SetLightColor",Ar[Ar.SetLightTemperature=5]="SetLightTemperature",Ar[Ar.SetLightBrightness=6]="SetLightBrightness",Ar[Ar.SetTemperature=7]="SetTemperature",Ar[Ar.GetState=8]="GetState",Ar[Ar.TurnOnWithTimeout=9]="TurnOnWithTimeout",Ar[Ar.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",Ar[Ar.IdentifyDevice=11]="IdentifyDevice",Ar[Ar.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",Ar[Ar.SetBlindMicroventilation=13]="SetBlindMicroventilation",Ar[Ar.GatewayPulse=25]="GatewayPulse",Ar[Ar.GatePulse=26]="GatePulse",Ar[Ar.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",Ar[Ar.GetFacadeType=30]="GetFacadeType",Ar[Ar.LightRGBW=31]="LightRGBW",Ar[Ar.SetGatePositionPrecise=32]="SetGatePositionPrecise";class br{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 Nr{constructor(){this._taskType=dt.GetChannelsState,this._featureType=mr.GetState,this._channel=0,this._guid=br.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 Er extends Nr{constructor(){super(),this.Temperature=0,this.FeatureType=mr.SetTemperature,this.TaskType=dt.SetTemperature}}class Ir extends Nr{constructor(){super(),this.FeatureType=mr.TurnOff,this.TaskType=dt.TurnOff}}class Rr extends Nr{constructor(){super(),this.FeatureType=mr.TurnOn,this.TaskType=dt.TurnOn}}class Pr extends Nr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=mr.TurnOnWithTimeout,this.TaskType=dt.TurnOnWithTime}}class Or extends Nr{constructor(){super(),this.Brightness=0,this.FeatureType=mr.SetLightBrightness,this.TaskType=dt.SetLightBrightness}}class Ur extends Nr{constructor(){super(),this.FeatureType=mr.ToggleState,this.TaskType=dt.TogleState}}class Mr extends Nr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=mr.SetLightColor,this.TaskType=dt.SetLightColor}}class xr extends Nr{constructor(){super(),this.Temperature=0,this.FeatureType=mr.SetLightTemperature,this.TaskType=dt.SetLightTemperature}}class Fr extends Nr{constructor(){super(),this.Action=yr.Stop,this.Position=0,this.FeatureType=mr.SetBlindPosition,this.TaskType=dt.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(yr||(yr={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(wr||(wr={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Sr||(Sr={}));class Lr extends Nr{constructor(){super(),this.Brightness=0,this.FeatureType=mr.SetLightBrightnessDynamicly,this.TaskType=dt.SetLightBrightnessDynamicly}}class Br extends Nr{constructor(){super(),this.FeatureType=mr.IdentifyDevice,this.TaskType=dt.IdentifyDevice}}class $r extends Nr{constructor(){super(),this.Data=new Wr,this.FeatureType=mr.SetBlindOpenCloseTime,this.TaskType=dt.SetBlindOpenCloseTime}}class Wr{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class qr extends Nr{constructor(){super(),this.FeatureType=mr.GetState,this.TaskType=dt.GetChannelsState}}class Hr extends Nr{constructor(){super(),this.Position=0,this.FeatureType=mr.SetBlindMicroventilation,this.TaskType=dt.SetBlindMicroventilation}}class Vr extends Nr{constructor(){super(),this.FeatureType=mr.GatePulse,this.TaskType=dt.ChangeGatewayPositionPulse}}class jr extends Nr{constructor(){super(),this.FeatureType=mr.GatewayPulse,this.TaskType=dt.ChangeGatewayPositionPulse}}class Kr extends Nr{constructor(){super(),this.FacadeAction=_r.Stop,this.Tilt=0,this.Position=0,this.FeatureType=mr.SetFacadePositionAndTilt,this.TaskType=dt.SetFacadePosition}}class zr extends Nr{constructor(){super(),this.FeatureType=mr.GetFacadeType,this.TaskType=dt.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"}(_r||(_r={}));class Jr{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class Yr extends Nr{constructor(){super(),this.Data=new Jr,this.FeatureType=mr.LightRGBW,this.TaskType=dt.LightRGBW}}var Xr=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Qr{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return Qr.ServiceName}RegisterManuallyPairedDevicesProtocol(e){Zf.Get(r.ServiceName).Debug(Qr.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return Xr(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 Xr(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=t?t.AddManuallyPairedDeviceAsync(e):(Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),mt.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}Qr.ServiceName="ManualDeviceService";class Zr{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var es,ts=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 ns{constructor(){this._connection=null,this._localDb=null,this._connection=Zf.Get(Gt.ServiceName),this._localDb=Zf.Get(o.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return ts(this,void 0,void 0,(function*(){let r=new rs(e,t,n),s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ae.OK){const r=new is;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(ns.ServiceName,this.GetLocalDbName(e,t),r)}return s.Status}))}ReadAsync(e,t,n){return ts(this,void 0,void 0,(function*(){let r=new ss(e,t);if(!n){const n=this._localDb.Read(ns.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new Zr;return t.Data=JSON.parse(e.Data),t.IsGlobal=e.IsGlobal,t.ResourceGuid=e.ResourceGuid,t}}let s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ae.OK){const e=new Zr;return e.ResourceGuid=s.ResourceGuid,e.Data=JSON.parse(s.Data),e.IsGlobal=s.IsGlobal,e}return s.Status}))}RemoveAsync(e,t){return ts(this,void 0,void 0,(function*(){let n=new os(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return ns.ServiceName}}ns.ServiceName="RemoteStorageService";class rs extends ie{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ce.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class ss extends ie{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ce.Get,this.ResourceGuid=e,this.Global=t}}class os extends ie{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ce.Delete,this.ResourceGuid=e,this.Global=t}}class is extends ie{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class as{constructor(){this.Longitude=0,this.Latitude=0}}class cs{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"}(es||(es={}));var us,ls,ds,hs,ps,gs,fs,vs,ms,ys,ws,Ss,_s,As,Cs,Ts,Ds,Gs=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 ks{IsControllerGeolocationSetAsync(){return Gs(this,void 0,void 0,(function*(){let e=new bs,t=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ae.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return Gs(this,void 0,void 0,(function*(){return new Promise(((e,t)=>Gs(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){var t,n;return Gs(this,void 0,void 0,(function*(){let r=new Es;r.Data.Latitude=e.Latitude,r.Data.Longitude=e.Longitude,null===(t=s.Log)||void 0===t||t.Warning(ks.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(r)}`);let o=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(r,15e3,!1);switch(null===(n=s.Log)||void 0===n||n.Warning(ks.ServiceName,`${JSON.stringify(o)}`),Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==o?void 0:o.Status){case ae.OK:return new Te(es.OK,"");case ae.NoPermissionToPerformThisOperation:case ae.NoPermissionsToCallGivenResource:return new Te(es.NoPermissions,"");case ae.UserIsNotLoggedIn:return new Te(es.UserIsNotLoggedIn,"");default:return new Te(es.UnknownError,"")}}))}GetControlllerGeolocationAsync(){var e,t;return Gs(this,void 0,void 0,(function*(){let n=new Ns;null===(e=s.Log)||void 0===e||e.Warning(ks.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=s.Log)||void 0===t||t.Warning(ks.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ae.OK){let e=new cs;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 ks.ServiceName}}ks.ServiceName="GeolocationService";class bs extends ie{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ce.Get}}class Ns extends ie{constructor(){super(),this.Resource="/geolocation/get",this.Method=ce.Get}}class Es extends ie{constructor(){super(),this.Data=new as,this.Resource="/geolocation/save",this.Method=ce.Put}}!function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(us||(us={}));class Is{constructor(){this._comparisonParams=new Map,this.Type=ht.Unknown,this.DeviceGuid="",this.ComparisonMethod=ls.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof bn&&(this.Type=ht.BatteryState),e instanceof Yn&&(this.Type=ht.BinarySensorState),e instanceof vn&&(this.Type=ht.BlindPosition),e instanceof Tn&&(this.Type=ht.LightBrightness),e instanceof En&&(this.Type=ht.MeasuredBrightness),e instanceof yn&&(this.Type=ht.RemoteButtonState),e instanceof un&&(this.Type=ht.ChannelOnOffState),e instanceof hn&&(this.Type=ht.DoorBellState),e instanceof Rn&&(this.Type=ht.MeasuredEnergy),e instanceof ur&&(this.Type=ht.FloodSensorState),e instanceof Wn&&(this.Type=ht.GatePosition),e instanceof Sn&&(this.Type=ht.LightColor),e instanceof An&&(this.Type=ht.LightWarmth),e instanceof gn&&(this.Type=ht.ReedState),e instanceof Gn&&(this.Type=ht.MeasuredTemperature),e instanceof Kn&&(this.Type=ht.HumiditySensorState),e instanceof xn&&(this.Type=ht.BlindRemoteButtonState),e instanceof Ln&&(this.Type=ht.FacadeRemoteButtonState),e instanceof Un&&(this.Type=ht.MovementSensorState),e instanceof Rn&&(this.Type=ht.MeasuredEnergy),e instanceof dr&&(this.Type=ht.PressureSensorState),e instanceof ar&&(this.Type=ht.WindSpeedState),e instanceof sr&&(this.Type=ht.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class Rs{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"}(ls||(ls={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(ds||(ds={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(hs||(hs={}));class Os{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"}(ps||(ps={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(gs||(gs={})),(Ds=fs||(fs={}))[Ds.Unknown=0]="Unknown",Ds[Ds.Second=1]="Second",Ds[Ds.Minute=2]="Minute",Ds[Ds.Hour=3]="Hour",Ds[Ds.Day=4]="Day",Ds[Ds.DayOfWeek=5]="DayOfWeek",Ds[Ds.Month=6]="Month",Ds[Ds.Year=7]="Year",Ds[Ds.Date=8]="Date",Ds[Ds.Time=9]="Time",Ds[Ds.WeatherType=11]="WeatherType",Ds[Ds.CompareNumbers=12]="CompareNumbers",Ds[Ds.CompareBooleans=13]="CompareBooleans",Ds[Ds.DeviceState=14]="DeviceState",Ds[Ds.Timer=15]="Timer",Ds[Ds.Temperature=17]="Temperature",Ds[Ds.DaysOfWeek=18]="DaysOfWeek",Ds[Ds.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",Ds[Ds.SceneExecuted=20]="SceneExecuted",(Ts=vs||(vs={}))[Ts.Unknown=0]="Unknown",Ts[Ts.Equal=1]="Equal",Ts[Ts.NotEqueal=2]="NotEqueal",Ts[Ts.BiggerThan=3]="BiggerThan",Ts[Ts.SmallerThan=4]="SmallerThan",Ts[Ts.BiggerThanOrEqual=5]="BiggerThanOrEqual",Ts[Ts.SmallerThanOrEqual=6]="SmallerThanOrEqual",Ts[Ts.OneOfBothIsTrue=7]="OneOfBothIsTrue",Ts[Ts.BothAreTrue=8]="BothAreTrue",function(e){e[e.Unknown=0]="Unknown",e[e.BatteryState=1]="BatteryState",e[e.BinarySensor=2]="BinarySensor",e[e.BlindPosition=3]="BlindPosition",e[e.Brightness=4]="Brightness",e[e.ButtonState=5]="ButtonState",e[e.ChannelOnOff=6]="ChannelOnOff",e[e.DoorBell=7]="DoorBell",e[e.Energy=8]="Energy",e[e.FloodSensor=9]="FloodSensor",e[e.GatePosition=10]="GatePosition",e[e.HeatSensor=11]="HeatSensor",e[e.LightBrightness=12]="LightBrightness",e[e.LightColor=13]="LightColor",e[e.LightTemperature=14]="LightTemperature",e[e.MeasuredCurrent=15]="MeasuredCurrent",e[e.MeasuredPower=16]="MeasuredPower",e[e.MeasuredVoltage=17]="MeasuredVoltage",e[e.ReedState=18]="ReedState",e[e.SmokeSensor=19]="SmokeSensor",e[e.Temperature=20]="Temperature",e[e.BlindsControlButton=21]="BlindsControlButton",e[e.Movement=22]="Movement",e[e.WindSpeed=24]="WindSpeed",e[e.Humidity=25]="Humidity",e[e.AirPressure=26]="AirPressure",e[e.WindThreshold=31]="WindThreshold",e[e.FacadeControlButton=36]="FacadeControlButton"}(ms||(ms={})),function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(ys||(ys={})),(Cs=ws||(ws={})).Null="Null",Cs.Condition="Condition",Cs.ConditionGroup="ConditionGroup",Cs.ArgumentAsInt="ArgumentAsInt",Cs.ArgumentAsTimeSpan="ArgumentAsTimeSpan",Cs.ArgumentAsBoolean="ArgumentAsBoolean",Cs.ArgumentAsTimeout="ArgumentAsTimeout",Cs.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",Cs.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",Cs.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",Cs.ArgumentAsTime="ArgumentAsTime",Cs.ArgumentAsDeviceState="ArgumentAsDeviceState",Cs.ArgumentAsNumber="ArgumentAsNumber",Cs.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",Cs.ArgumentAsConditionInfo="ArgumentAsConditionInfo";class Us 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"}(Ss||(Ss={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(_s||(_s={}));class Ms{constructor(e,t="Cube"){this._result=null,this._tmp=new xs,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=Zf.Get(Qs.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=br.NewGuid())}SetSequenceName(e){this._sequenceName=e,this._editingExistingSequence&&null!=this._result&&(this._result.Name=e)}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==As.Condition?(this._prevSeqGuid=this._currentSeqGuid,this._currentSeqGuid=e.RightArgument.Guid,this._service.MapSequence(JSON.parse(JSON.stringify(e.RightArgument)),!0)):null}}CloneCurrentBuilder(){var e=new Ms;return e._currentSeqGuid="",e._prevSeqGuid="",e._editingExistingSequence=structuredClone(this._editingExistingSequence),e._rawExistingSequenceTasks=structuredClone(this._rawExistingSequenceTasks),e._result=structuredClone(this._result),e._sequenceIcon=structuredClone(this._sequenceIcon),e._sequenceName=structuredClone(this._sequenceName),e._tmp=structuredClone(this._tmp),(e=>{const t=e=>{e.Guid=br.NewGuid(),e.RightArgumentType==As.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=br.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==As.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!=As.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),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=vs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=vs.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=br.NewGuid(),this._tmp.HandledType=fs.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=As.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=vs.Equal)throw new js("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new js("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=vs.Equal;else{if(null==n)throw new js("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=As.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=br.NewGuid(),this._tmp.HandledType=fs.Unknown,this._tmp.LeftArgumentType=As.Null,this._tmp.ConditionType=vs.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=As.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=vs.Equal){return this._tmp.Guid=br.NewGuid(),this._tmp.HandledType=fs.DaysOfWeek,this._tmp.LeftArgumentType=As.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=As.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=vs.Equal){return this._tmp.Guid=br.NewGuid(),this._tmp.HandledType=fs.Timer,this._tmp.LeftArgumentType=As.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=As.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=vs.Equal){return this._tmp.Guid=br.NewGuid(),this._tmp.HandledType=fs.Time,this._tmp.LeftArgumentType=As.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=As.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=vs.Equal){return this._tmp.Guid=br.NewGuid(),this._tmp.HandledType=fs.DeviceState,this._tmp.LeftArgumentType=As.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=As.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=br.NewGuid(),this._tmp.HandledType=fs.SceneExecuted,this._tmp.LeftArgumentType=As.ArgumentAsConditionInfo,this._tmp.ConditionType=vs.Equal,this._tmp.AtMeetCondition=!0;const t=new Os;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=As.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new Bs;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),{[ds[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case ht.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case ht.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case ht.LightBrightness:case ht.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case ht.RemoteButtonState:case ht.ChannelOnOffState:case ht.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[Lt[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case ht.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case ht.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case ht.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case ht.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.SmokeSensorState:throw new Us("Unsupported device state!");case ht.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case ht.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case ht.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.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 ht.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case ht.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case ht.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case ht.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case ht.Unknown:t.CheckedDeviceState={};break;default:throw new Us("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case ht.BatteryState:return ms.BatteryState;case ht.BinarySensorState:return ms.BinarySensor;case ht.BlindPosition:return ms.BlindPosition;case ht.LightBrightness:return ms.LightBrightness;case ht.RemoteButtonState:return ms.ButtonState;case ht.ChannelOnOffState:return ms.ChannelOnOff;case ht.DoorBellState:return ms.DoorBell;case ht.MeasuredEnergy:return ms.Energy;case ht.FloodSensorState:return ms.FloodSensor;case ht.GatePosition:return ms.GatePosition;case ht.MeasuredBrightness:return ms.Brightness;case ht.LightColor:return ms.LightColor;case ht.LightWarmth:return ms.LightTemperature;case ht.ReedState:return ms.ReedState;case ht.SmokeSensorState:return ms.SmokeSensor;case ht.MeasuredTemperature:return ms.Temperature;case ht.HumiditySensorState:return ms.Humidity;case ht.BlindRemoteButtonState:return ms.BlindsControlButton;case ht.FacadeRemoteButtonState:return ms.FacadeControlButton;case ht.MovementSensorState:return ms.Movement;case ht.PressureSensorState:return ms.AirPressure;case ht.WindSpeedState:return ms.WindSpeed;case ht.CurrentWindThreshold:return ms.WindThreshold;default:return ms.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=As.Null)return e(t.RightArgument,n);t.RightArgumentType=As.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new $s)};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 xs,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),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=vs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=vs.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!=As.Condition){if(n.RightArgumentType==As.Condition)return t(n.RightArgument,r);throw new Ks(`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 Ks(`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 xs,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),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=vs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=vs.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==As.Condition?e.RightArgument.Guid:"",this._prevSeqGuid=null!=t?t.Guid:""):this._prevSeqGuid==n&&(this._prevSeqGuid=null!=t?t.Guid:""))},r=(e,s)=>{if(e.Guid!=s){if(t=e,e.RightArgumentType==As.Null)throw new Ks(`Cannot remove sequence, sequence with given guid ${s} not found!`);return r(e.RightArgument,s)}null==t?this._result=null:(t.RightArgument=e.RightArgument,t.RightArgumentType=e.RightArgumentType),n(e,s)};if(null==this._result)throw new Ks("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=As.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),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=vs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=vs.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!=As.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new Ks("Sequence are not initialized! Not found root sequence.");return this._editingExistingSequence&&e(this._result),{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)))}}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:re.GenerateMd5(JSON.stringify(this._tmpTask))}}ParseDeviceTask(e){const t=new qs;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==dt.SetBlindPosition||e instanceof Fr?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==dt.SetLightColor||e instanceof Mr?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==dt.SetLightTemperature||e instanceof xr?t.Data.Temperature=e.Temperature:e.TaskType==dt.SetLightBrightness||e instanceof Or?t.Data.Brightness=e.Brightness:e.TaskType==dt.SetTemperature||e instanceof Er?t.Data.Temperature=e.Temperature:e.TaskType==dt.TurnOnWithTime||e instanceof Pr?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==dt.SetLightBrightnessDynamicly||e instanceof Lr?t.Data.Brightness=e.Brightness:e.TaskType==dt.SetBlindOpenCloseTime||e instanceof $r?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==dt.SetBlindMicroventilation||e instanceof Hr?t.Data.Position=e.Position:e.TaskType==dt.SetFacadePosition||e instanceof Kr?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):(e.TaskType==dt.LightRGBW||e instanceof Yr)&&(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),t}DelayTask(e){const t=new Hs;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:re.GenerateMd5(JSON.stringify(t))}}NotifyTask(e){throw new Js("Funcionality will be available in the future.")}LockExecutionTask(e){const t=new Vs;if(t.LockType=e.LockType,t.LockType==_s.Timeout&&"00:00:00"!=t.LockEndHour)throw new Js("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:re.GenerateMd5(JSON.stringify(t))}}AddTask(){const e=t=>{if(t.RightArgumentType!=As.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 qs&&t.Tasks.DevicesTasks.push(structuredClone(this._tmpTask)),t.Tasks.ControllerTasks.push(structuredClone(this._tmpTask)),this._tmpTask=null,Zf.Get(r.ServiceName).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),{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)))}}EditTask(e){const t=n=>{if(n.RightArgumentType!=As.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 zs("Task not found, cannot edit!");this._tmpTask instanceof qs&&null!=n.Tasks.DevicesTasks&&(n.Tasks.DevicesTasks=n.Tasks.DevicesTasks.map((t=>re.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t))),n.Tasks.ControllerTasks=n.Tasks.ControllerTasks.map((t=>re.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t)),this._tmpTask=null,Zf.Get(r.ServiceName).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),{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)))}}RemoveTask(e){const t=(e,n)=>{if(e.RightArgumentType!=As.Null)return t(e.RightArgument,n);{const t=e.Tasks.ControllerTasks.filter((e=>re.GenerateMd5(JSON.stringify(e))!=n));if(e.Tasks.ControllerTasks=null==t?[]:t,e.Tasks.DevicesTasks.any()){const t=e.Tasks.DevicesTasks.filter((e=>re.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 dt.Unknown:throw new js("Unsupported task type!");case dt.SetBlindPosition:case dt.SetBlindPositionSimple:return mr.SetBlindPosition;case dt.SetBlindMicroventilation:return mr.SetBlindMicroventilation;case dt.TurnOff:return mr.TurnOff;case dt.TurnOn:return mr.TurnOn;case dt.TurnOnWithTime:return mr.TurnOnWithTimeout;case dt.TogleState:return mr.ToggleState;case dt.SetLightBrightnessDynamicly:return mr.SetLightBrightnessDynamicly;case dt.SetLightBrightness:return mr.SetLightBrightness;case dt.SetLightColor:return mr.SetLightColor;case dt.SetLightTemperature:return mr.SetLightTemperature;case dt.PairDevice:case dt.UnpairDevice:throw new js("Unsupported task type!");case dt.IdentifyDevice:return mr.IdentifyDevice;case dt.GetChannelsState:return mr.GetState;case dt.GetPowerMeasurements:case dt.GetAvailableData:case dt.MultipleDataRequest:throw new js("Unsupported task type!");case dt.SetBlindOpenCloseTime:return mr.SetBlindOpenCloseTime;case dt.SetTemperature:return mr.SetTemperature;case dt.ChangeGatePositionPulse:return mr.GatePulse;case dt.ChangeGatewayPositionPulse:return mr.GatewayPulse;case dt.SetFacadePosition:case dt.GetFacadeType:return mr.SetFacadePositionAndTilt;case dt.LightRGBW:return mr.LightRGBW;default:throw new js("Unsupported task type!")}}Build(){const e=t=>{if(t.RightArgumentType!=As.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==As.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}}class xs{constructor(){this.Tasks=new $s,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=fs.Unknown,this.ConditionType=vs.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=As.Null,this.RightArgumentType=As.Null,this.LeftArgument=new Ls({},As.Null),this.RightArgument=new Fs}}class Fs{constructor(){this.HandledType=0,this.Argument=null}}class Ls{constructor(e,t){this.Argument=e,this.HandledType=t}}class Bs{constructor(){this.DeviceStateType=ms.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=ls.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class $s{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Ws{constructor(){this.RunParallel=!1,this.TaskType=ps.Unknown}}class qs extends Ws{constructor(){super(...arguments),this.TaskType=ps.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=mr.TurnOn}}class Hs extends Ws{constructor(){super(...arguments),this.TaskType=ps.DelayTask,this.Delay="00:00:00"}}class Vs extends Ws{constructor(){super(...arguments),this.TaskType=ps.LockExecution,this.LockType=_s.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}!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"}(As||(As={}));class js extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class Ks extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class zs extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class Js extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var Ys,Xs=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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._connection=Zf.Get(Gt.ServiceName),this._configurationService=Zf.Get(Xe.ServiceName)}GetServiceName(){return Qs.ServiceName}GetSequencesListAsync(){var e;return Xs(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Zs,12e3,!1);return Zf.Get(r.ServiceName).Debug(`GetSequencesListAsync result:\n ${JSON.stringify(t)}}`),null==t?new Te(us.OtherError,"Cannot get sequences list - response is null."):t.Status!=ae.OK?new Te(us.OtherError,`Cannot get sequences list - controller responded with response code ${t.Status}.`):null==t.Data?new Te(us.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):t.Data}))}GetSequenceAsync(e){var t;return Xs(this,void 0,void 0,(function*(){let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new eo(n),12e3,!1);if(null==r)return new Te(us.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ae.OK)return new Te(us.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Te(us.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");const s=r.Data;return this.MapSequence(s)}))}GetSequenceBuilder(e,t){return new Ms(e,t)}CreateSequenceAsync(e){var t;return Xs(this,void 0,void 0,(function*(){try{yield this._configurationService.EnterConfigurationModeAsync(),Zf.Get(r.ServiceName).Debug(`Creating sequence ${e.Name} json: \n${JSON.stringify(e)}`);const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new so(e),2e4,!1);return null==n||null==n.Status?ae.Error:n.Status}catch(t){return Zf.Get(r.ServiceName).Error(`Creating sequence ${e.Name} error: ${t}`),ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){var t;return Xs(this,void 0,void 0,(function*(){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 to(n),12e3,!1);if(null==r)return new Te(us.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ae.WrongData:return new Te(us.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ae.OK:return null==r.Data?new Te(us.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Te(us.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Te(us.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){var t;return Xs(this,void 0,void 0,(function*(){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 io(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}catch(e){return ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}EditSequenceAsync(e){var t;return Xs(this,void 0,void 0,(function*(){try{const n={Guid:e.Guid,Icon:e.Icon,Name:e.Name,Condition:e};yield this._configurationService.EnterConfigurationModeAsync();const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new oo(n),2e4,!1);return null==r||null==r.Status?ae.Error:r.Status}catch(t){return Zf.Get(r.ServiceName).Error(`Editing sequence ${e.Name} error: ${t}`),ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}EnableSequenceAsync(e){var t;return Xs(this,void 0,void 0,(function*(){let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ao(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}))}DisableSequenceAsync(e){var t;return Xs(this,void 0,void 0,(function*(){let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new co(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}))}RunSequenceAsync(e){return Xs(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ae.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ae.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new Rr;switch(n.Channel=1,n.DeviceGuid=t,yield Zf.Get(lo.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case mt.Executed:return ae.OK;case mt.DeviceNotFound:return ae.WrongData;default:return ae.Error}}))}GetUtilsAsync(){return Xs(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 Xs(this,void 0,void 0,(function*(){const e=Zf.Get(ks.ServiceName),t=new as;let n=!1;t.Latitude=49.9958888026741,t.Longitude=18.9172596008914;try{if(yield e.IsControllerGeolocationSetAsync()){const n=yield e.GetControlllerGeolocationAsync();n instanceof cs&&(t.Latitude=n.Latitude,t.Longitude=n.Longitude)}}catch(e){Zf.Get(r.ServiceName).Warning(`Cannot get localization data, using default values: 49.9958888026741, 18.9172596008914. Error: ${e}`)}const s=e=>{let n=7.95204*Math.sin(.01768*e+3.03217)+9.98906*Math.sin(.03383*e+3.4687)+4*(t.Longitude-15*Math.round(t.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()})()&&(n-=60),n},o=e=>Math.asin(-.39795*Math.cos(2*Math.PI*(e+10)/365)),i=e=>{const n=t.Latitude*Math.PI/180;let r=Math.sin(n)*Math.sin(e)/(Math.cos(n)*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 r=(u=t,Math.floor((u.valueOf()-new Date(u.getFullYear(),0,0).valueOf())/1e3/60/60/24));var u;const l=s(r),d=o(r),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&&!n?(n=!0,c(1)):(n=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.getMinutes()))},u=e=>{const t=new Date;t.setDate(t.getDate()+e);const r=(c=t,Math.floor((c.valueOf()-new Date(c.getFullYear(),0,0).valueOf())/1e3/60/60/24));var c;const l=s(r),d=o(r),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,l)),g=a(p);return new Date>g&&!n?(n=!0,u(1)):(n=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>u(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=Ys.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=ps.DeviceTask,e.RunParallel=!1})))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=ws.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==ws.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===ws.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new no;switch(n.HandledType=e.HandledType,t){case ws.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case ws.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case ws.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case ws.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case ws.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case ws.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case ws.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case ws.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case ws.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case ws.ArgumentAsDeviceState:{const t=new Is;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?ls.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(ds[e[0]],new Rs(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(ds[e[0]],new Ps(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case ws.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return ws[Ys[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case ms.BatteryState:return ht.BatteryState;case ms.BinarySensor:return ht.BinarySensorState;case ms.BlindPosition:return ht.BlindPosition;case ms.Brightness:return ht.MeasuredBrightness;case ms.ButtonState:return ht.RemoteButtonState;case ms.ChannelOnOff:return ht.ChannelOnOffState;case ms.DoorBell:return ht.DoorBellState;case ms.Energy:return ht.MeasuredEnergy;case ms.FloodSensor:return ht.FloodSensorState;case ms.GatePosition:return ht.GatePosition;case ms.LightBrightness:return ht.LightBrightness;case ms.LightColor:return ht.LightColor;case ms.LightTemperature:return ht.LightWarmth;case ms.ReedState:return ht.ReedState;case ms.SmokeSensor:return ht.SmokeSensorState;case ms.Temperature:return ht.MeasuredTemperature;case ms.Humidity:return ht.HumiditySensorState;case ms.BlindsControlButton:return ht.BlindRemoteButtonState;case ms.FacadeControlButton:return ht.FacadeRemoteButtonState;case ms.Movement:return ht.MovementSensorState;case ms.AirPressure:return ht.PressureSensorState;case ms.WindSpeed:return ht.WindSpeedState;case ms.WindThreshold:return ht.CurrentWindThreshold;default:return ht.Unknown}}CreateDeviceState(e,t,n){switch(n){case ht.BatteryState:return{Channel:t,StateReliability:It.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case ht.BinarySensorState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.BlindPosition:return{Channel:t,StateReliability:It.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case ht.LightBrightness:case ht.MeasuredBrightness:return{Channel:t,StateReliability:It.Unconfident,Brightness:e.Brightness,Time:""};case ht.RemoteButtonState:case ht.ChannelOnOffState:case ht.DoorBellState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(Lt[t],r);return{Channel:t,StateReliability:It.Unconfident,MeasurementParameters:n,Time:""}}case ht.FloodSensorState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.GatePosition:return{Channel:t,StateReliability:It.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case ht.LightColor:return{Channel:t,StateReliability:It.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case ht.LightWarmth:return{Channel:t,StateReliability:It.Unconfident,Temperature:e.Temperature,Time:""};case ht.ReedState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.SmokeSensorState:throw new Us("Unsupported device state!");case ht.MeasuredTemperature:return{Channel:t,StateReliability:It.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case ht.HumiditySensorState:return{Channel:t,StateReliability:It.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case ht.BlindRemoteButtonState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.LightRGBWState:return{StateReliability:It.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case ht.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:It.Unconfident,State:e.State};case ht.MovementSensorState:return{Channel:t,Time:"",StateReliability:It.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case ht.PressureSensorState:return{Channel:t,Time:"",StateReliability:It.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case ht.WindSpeedState:return{Channel:t,Time:"",StateReliability:It.Unconfident,Value:e.Value};case ht.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:It.Unconfident,WindThreshold:e.WindThreshold};case ht.Unknown:return new an;default:throw new Us("Unsupported device state!")}}MapDeviceTask(e){let t=new Nr,n=e;switch(Zf.Get(r.ServiceName).Debug(`[TASK] object: ${JSON.stringify(n)}`),n.ControlFeature){case mr.TurnOn:t=new Rr,t.TaskType=dt.TurnOn;break;case mr.TurnOff:t=new Ir,t.TaskType=dt.TurnOff;break;case mr.ToggleState:t=new Ur,t.TaskType=dt.TogleState;break;case mr.SetBlindPosition:t=new Fr,t.TaskType=dt.SetBlindPosition,t.Action=n.Data.Action,t.Position=n.Data.Position;break;case mr.SetLightColor:t=new Mr,t.TaskType=dt.SetLightColor,t.R=n.Data.R,t.G=n.Data.G,t.B=n.Data.B;break;case mr.SetLightTemperature:t=new xr,t.TaskType=dt.SetLightTemperature,t.Temperature=n.Data.Temperature;break;case mr.SetLightBrightness:t=new Or,t.TaskType=dt.SetLightBrightness,t.Brightness=n.Data.Brightness;break;case mr.SetTemperature:t=new Er,t.TaskType=dt.SetTemperature,t.Temperature=n.Data.Temperature;break;case mr.GetState:t=new qr,t.TaskType=dt.GetChannelsState;break;case mr.TurnOnWithTimeout:t=new Pr,t.TaskType=dt.TurnOnWithTime,t.SwitchOffDelaySeconds=n.Data.SwitchOffDelaySeconds;break;case mr.SetLightBrightnessDynamicly:t=new Lr,t.TaskType=dt.SetLightBrightnessDynamicly,t.Brightness=n.Data.Brightness;break;case mr.IdentifyDevice:t=new Br,t.TaskType=dt.IdentifyDevice;break;case mr.SetBlindOpenCloseTime:t=new $r,t.TaskType=dt.SetBlindOpenCloseTime,t.Data.CloseTime=n.Data;break;case mr.SetBlindMicroventilation:t=new Hr,t.TaskType=dt.SetBlindMicroventilation,t.Position=n.Data.Position;break;case mr.GatewayPulse:t=new jr,t.TaskType=dt.ChangeGatewayPositionPulse;break;case mr.GatePulse:t=new Vr,t.TaskType=dt.ChangeGatePositionPulse;break;case mr.SetFacadePositionAndTilt:t=new Kr,t.TaskType=dt.SetFacadePosition,t.Position=n.Data.Position,t.Tilt=n.Data.Tilt,t.FacadeAction=_r.TiltAndPercentage;break;case mr.GetFacadeType:t=new zr,t.TaskType=dt.GetFacadeType;break;case mr.LightRGBW:t=new Yr,t.TaskType=dt.LightRGBW,t.Data=n.Data}return t.Channel=n.Channel,t.DeviceGuid=n.DeviceGuid,t.FeatureType=n.ControlFeature,t.Guid=br.NewGuid(),t}MapControllerTasks(e){const t=[];Zf.Get(r.ServiceName).Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let n of e){const e=new ro;switch(e.TaskId=re.GenerateMd5(JSON.stringify(n)),n.TaskType){case ps.DeviceTask:e.TaskType=gs.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(n);break;case ps.DelayTask:e.TaskType=gs.DelayTask,e.Task.DelayTask={Delay:new Ps(n.Delay)};break;case ps.NotifyTask:e.TaskType=gs.NotifyTask,e.Task.NotifyTask={Title:n.Title,Message:n.Message,NotifyType:n.NotifyType};break;case ps.LockExecution:case ps.LockExecution:e.TaskType=gs.LockExecution,Zf.Get(r.ServiceName).Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(n)}`),e.Task.LockExecution={LockStartHour:new Ps(n.LockStartHour),LockEndHour:new Ps(n.LockEndHour),LockType:n.LockType,ResetLockScenesGuids:n.ResetLockScenesGuids};case ps.Unknown:}t.push(e)}return t}}Qs.ServiceName="ScenesService";class Zs extends ie{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=ce.Get}}class eo extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Get,this.Data=e}}class to extends ie{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=ce.Get,this.Data=e}}class no{constructor(){this.HandledType=Ys.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"}(Ys||(Ys={}));class ro{constructor(){this.TaskId="",this.TaskType=gs.Unknown,this.Task={}}}class so extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Put,this.Data=e}}class oo extends ie{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=ce.Put,this.Data=e}}class io extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Delete,this.Data=e}}class ao extends ie{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=ce.Post,this.Data=e}}class co extends ie{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=ce.Post,this.Data=e}}var uo=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 lo{constructor(){this._devices=[],this._onDevicesTasksChangedEvent=new n,this._onDeviceFoundEvent=new n,this._onDeviceRegisteredEvent=new n,this._onDeviceRemovedEvent=new n,this._onDeviceFirmwareVersionChangedEvent=new n,this._onDeviceStateChangedEvent=new n,this._onDeviceStateRefreshedOrChangedEvent=new n,this._connection=null,this._session=null,this._controllerConfiguration=null,this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devicesChannelsStates=[],this._synchronizationTaskCompletionSource=null,this._deviceStatesSynchronizationTaskCompletionSource=null,this._connection=Zf.Get(Gt.ServiceName),this._session=Zf.Get(je.ServiceName),this._controllerConfiguration=Zf.Get(Xe.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>uo(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),this._synchronizationTaskCompletionSource=new Promise((e=>{var t;null===(t=this._session)||void 0===t||t.OnUserLoggedInEvent().Subscribe((t=>uo(this,void 0,void 0,(function*(){var t;try{this._devices=yield this.GetPairedDevicesAsync()}catch(e){null===(t=s.Log)||void 0===t||t.Error(lo.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=>uo(this,void 0,void 0,(function*(){var t;try{yield this.WaitForSynchronizationAsync(),yield this.SyncDevicesStatesAsync()}catch(e){null===(t=s.Log)||void 0===t||t.Error(lo.ServiceName,`Failed to sync devices states: ${e}`)}this._synchronizedDevicesStates=!0,e()}))))})),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!=ft.Scene&&(null===(t=s.Log)||void 0===t||t.Debug(lo.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("/devices/blinds/times",(e=>{})),this._connection.SubscribeTo("/info/devices/device/state/changed",(e=>{const t=e.Data,n=this._devices.filter((e=>e.Guid==t.DeviceGuid));if(n.length>0){const e=n[0],r=this.MapApiDeviceStateToDeviceState(e,t);if(null!=r){this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r}),r.TypeAsEnum==ht.SignalStrength?e.Channels.forEach((n=>{let r=new Bn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==ht.BatteryState&&e.Channels.forEach((n=>{let r=new kn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})}));let n=e.States.find((e=>e.TypeAsEnum===r.TypeAsEnum&&e.Data.Channel===r.Data.Channel));if(n){let s=n.StatesComparisonData;n.Data=r.Data,s!==r.StatesComparisonData&&(this._onDeviceStateChangedEvent.Invoke({Device:e,State:r}),r.TypeAsEnum==ht.SignalStrength?e.Channels.forEach((n=>{let r=new Bn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==ht.BatteryState&&e.Channels.forEach((n=>{let r=new kn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})))}else e.States.push(r),this._onDeviceStateChangedEvent.Invoke({Device:e,State:r}),r.TypeAsEnum==ht.SignalStrength?e.Channels.forEach((n=>{let r=new Bn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==ht.BatteryState&&e.Channels.forEach((n=>{let r=new kn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{Zf.Get(Ge.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(lo.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{Zf.Get(Ge.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(lo.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}CheckIfDeviceUsedInScenesAsync(e){var t,n,r,o,i,a;return uo(this,void 0,void 0,(function*(){try{let a;if("string"==typeof e){const n=this.GetDevice(e);if(null==n)return null===(t=s.Log)||void 0===t||t.Error("Cannot check if device is used in scenes! Device with given guid not exists"),ae.ResourceDoesNotExists;a=n}else a=e;const u=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Do(a.Guid),2e4,!1);if(null==u||null==u.Status)return null===(r=s.Log)||void 0===r||r.Error("Cannot check if device is used in scenes! Response or status is null!"),ae.FatalError;if(u.Status!=ae.OK)return u.Status;if(null==u.Data)return null===(o=s.Log)||void 0===o||o.Error("Cannot check if device is used in scenes! No data!"),ae.FatalError;var c=yield Zf.Get(Qs.ServiceName).GetSequencesListAsync();if(c instanceof Te)return null===(i=s.Log)||void 0===i||i.Error(`Cannot check if device is used in scenes! Cannot get sequence list, ScenesServiceErrorCode: ${c.Type}`),ae.Error;const l=new No;return l.DeviceGuid=a.Guid,u.Data.ConditionsAsCondition.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),u.Data.ConditionsAsTask.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),l}catch(e){return null===(a=s.Log)||void 0===a||a.Error(`Cannot check if device is used in scenes! ${e}`),ae.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)>=he.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)>=he.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return uo(this,void 0,void 0,(function*(){const e=Zf.Get(ns.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return yield Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),e}))}DisableFastStatesSyncAsync(){return uo(this,void 0,void 0,(function*(){const e=Zf.Get(ns.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return yield Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),e}))}IsFastStatesSyncEnabledAsync(){return uo(this,void 0,void 0,(function*(){const e=yield Zf.Get(ns.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof Zr?e.Data:e!=ae.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return uo(this,void 0,void 0,(function*(){let t=Zf.Get(Qr.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 uo(this,void 0,void 0,(function*(){var t=yield Zf.Get(Qr.ServiceName).AddManuallyPairedDeviceAsync(e);return yield Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),t}))}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 ho;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));null==e?(e=new ho,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e)):(null!=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum))&&(e.States=e.States.where((e=>e.TypeAsEnum!=t.TypeAsEnum)).toArray()),e.States.push(t))}}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}WaitForDevicesStatesSynchronizationAsync(){return this._deviceStatesSynchronizationTaskCompletionSource}GetCurrentlyRunningTaksAsync(){var e;return uo(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new wo,15e3,!1);(null==t?void 0:t.Status)==ae.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{var n;const r=e.split(";"),o=new Nt;o.DeviceGuid=r[0],o.Channel=Number(r[1]),o.Status=at.ExecutingTasks,t.push(o),null===(n=s.Log)||void 0===n||n.Debug(lo.ServiceName,`Device ${o.DeviceGuid} has task on channel ${o.Channel}`)})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new cn(t);case"DoorBell":return new dn(t);case"ReedPosition":return new pn(t);case"BlindPosition":return new fn(t);case"ButtonState":return new mn(t);case"LightColor":return new wn(t);case"LightTemperature":return new _n(t);case"LightBrightness":return new Cn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new Dn(t);case"BatteryState":return new kn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new Nn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new In(t);case"DistanceSensor":return new Pn(t);case"MovementSensor":return new On(t);case"BlindsControlButton":return new Mn(t);case"FacadeControlButton":return new Fn(t);case"SignalStrength":return new Bn(t);case"GatePosition":return new $n(t);case"GatewayPosition":return new qn(t);case"GateControllerHealth":return new Hn(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new Vn(t);case"HumiditySensor":case"HumidityState":return new jn(t);case"VibrationSensor":return new zn(t);case"DigitalInputSensor":return new Jn(t);case"ConfigurationState":return new Xn(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new Qn(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new Zn(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new er(t);case"FacadePosition":case"FacadeState":return new tr(t);case"FacadeTypeState":return new nr(t);case"CurrentWindThreshold":return new rr(t);case"CurrentLightThreshold":return new or(t);case"WindSpeed":return new ir(t);case"FloodSensor":return new cr(t);case"PressureState":return new lr(t);case"ITamperProtection":case"TamperProtection":return new hr(t);case"ILightRGBW":case"LightRGBW":return new pr(t);case"OnlineCamera":case"IOnlineCamera":return new ln(t);default:null===(n=s.Log)||void 0===n||n.Debug(lo.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return lo.ServiceName}SyncDevicesStatesAsync(e=!1){var t,n,r;return uo(this,void 0,void 0,(function*(){const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new go,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync()){if(e){let e=new fo;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)==ae.OK}return(null==s?void 0:s.Status)==ae.OK}{let e=new fo;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)==ae.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,i,a=new gr;a.Guid=e.Guid,a.Name=e.DeviceName,a.ChannelsAmount=e.ChannelsNumber,a.DeviceType=e.DeviceType,a.CommunicationWay=e.CommunicationWay,a.DeviceState=e.DeviceState,a.IsEnabled=e.IsEnabled,a.IsVirtual=e.IsVirtual,a.SerialNumber=e.DeviceSerialNumber,a.ManufacturerGuid=e.ManufacturerGuid,a.ModelGuid=e.DeviceModelGuid,a.Model=e.DeviceModel,a.Name=e.DeviceName,a.ProtocolGuid=e.ProtocolGuid,void 0!==e.IconType&&null!==e.IconType?a.IconType=e.IconType:a.IconType=lt.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new kt;if(a.CommunicationWay==gt.OneWay)"IBlindPosition"===e&&(t.InterfaceType="IBlindPositionSimple");else switch(e){case"IGatePosition":t.InterfaceType="IGatePulse";break;case"IGatewayPosition":t.InterfaceType="IGatewayPulse";break;default:t.InterfaceType=e}a.AvailableTaskTypes.push(t)})),null===(r=e.AvailableResponses)||void 0===r||r.forEach((e=>{var t=new bt;t.InterfaceType=e,a.AvailableResponseTypes.push(t)})),null===(o=e.ChannelsConfiguration)||void 0===o||o.forEach((e=>{var t,n,r;try{var o=new Tr;o.Number=e.Channel,a.Channels.push(o),o.SetDevice(a),o.Name=e.ChannelName,o.ChannelGroups=e.GroupsGuids,o.IconName=e.IconName,o.IsHidden=e.Hidden,o.Configurations=e.Configurations,o.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(o.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(o.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{var t=new bt;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new kt;t.InterfaceType=e,o.AvailableTaskTypes.push(t)}))}catch(e){null===(r=s.Log)||void 0===r||r.Error(e)}}))}catch(e){null===(i=s.Log)||void 0===i||i.Error(e)}t.push(a)})),t)}GetPairedDevicesAsync(e=!1){var t,n,r;return uo(this,void 0,void 0,(function*(){if(this._synchronized&&!(yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync()))return Promise.resolve(this._devices);const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new po,15e3,!0);return null==o||void 0===o?[]:o.Status==ae.OK&&null!=o.Data?e?this.MapApiDevices(o.Data):this.MapApiDevices(o.Data.filter((e=>e.DeviceType!=ft.Scene))):(null===(r=s.Log)||void 0===r||r.Error(lo.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(e=!1){return uo(this,void 0,void 0,(function*(){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){var e,t;return uo(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new yo,15e3,!1);return null==n?[]:n.Status==ae.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==ft.Scene)).toArray():(null===(t=s.Log)||void 0===t||t.Error(lo.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){var e;return uo(this,void 0,void 0,(function*(){Zf.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new vo,35e3,!1)}))}StopSearchingForDevices(){var e;return uo(this,void 0,void 0,(function*(){yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new mo,2e4,!1)}))}RegisterDeviceAsync(e){var t,n;return uo(this,void 0,void 0,(function*(){try{const n=new So;n.Data=e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,2e4,!1);return Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==r?void 0:r.Status)==ae.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),mt.Executed):mt.Failed}catch(e){return null===(n=s.Log)||void 0===n||n.Error(lo.ServiceName,`Failed to paired devices: ${e}`),mt.ControllerResponseTimeout}}))}RemoveDeviceAsync(e,t=!1){var n;return uo(this,void 0,void 0,(function*(){var r=new _o;t&&(r=new Ao),r.Data=e.Guid;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,35e3,!1);return Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ae.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),mt.Executed):mt.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new Go;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 ko;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 wr.Open:n.Data=101;break;case wr.Close:n.Data=102;break;case wr.Stop:n.Data=103;break;case wr.Percentage:n.Data=r.Position}break;case mr.SetBlindPosition:switch(r.Action){case yr.Open:n.Data=101;break;case yr.Close:n.Data=102;break;case yr.Stop:n.Data=103;break;case yr.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 bo;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){var n,r,o,i,a,c,u,l;return uo(this,void 0,void 0,(function*(){try{null===(n=s.Log)||void 0===n||n.Debug(lo.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new Co(l);null===(r=s.Log)||void 0===r||r.Debug(lo.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 ae.OK:return mt.Executed;case ae.FatalError:return null===(i=s.Log)||void 0===i||i.Error(lo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),mt.Failed;case ae.WrongData:if("DeviceNotFound"===t.Data)return mt.DeviceNotFound;break;case ae.Error:return"DeviceResponseTimeout"===t.Data?mt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(lo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),mt.Failed)}}catch(e){return e.message.includes("timeout")?(null===(c=s.Log)||void 0===c||c.Error(lo.ServiceName,`Failed to get controller response in time.\n${e}`),mt.ControllerResponseTimeout):(null===(u=s.Log)||void 0===u||u.Error(lo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),mt.Failed)}return mt.Unknown}catch(e){return null===(l=s.Log)||void 0===l||l.Error(lo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),mt.Failed}}))}ExecuteDevicesTasksAsync(e){var t,n,r,o;return uo(this,void 0,void 0,(function*(){let i=[],a=[],c=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=c,c++,a.push(e)}const u=new To(a);try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(u,12e4,!1);let o=-1;null===(n=null==r?void 0:r.Data)||void 0===n||n.forEach((t=>{var n,a;o++;let c=mt.Unknown;switch(t.Status){case ae.OK:return mt.Executed;case ae.FatalError:null===(n=s.Log)||void 0===n||n.Error(lo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),c=mt.Failed;break;case ae.WrongData:"DeviceNotFound"===t.Data&&(c=mt.DeviceNotFound);break;case ae.Error:"DeviceResponseTimeout"===t.Data?c=mt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(lo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),c=mt.Failed)}let u=0,l=new Et;for(const[t,n]of e){if(u==o){l.Device=t,l.Task=n,l.Channel=n.Channel,i.push(l);break}u++}}))}catch(t){if(t.message.includes("timeout")){null===(r=s.Log)||void 0===r||r.Error(lo.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new Et;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=mt.ControllerResponseTimeout}}else{null===(o=s.Log)||void 0===o||o.Error(lo.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new Et;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=mt.Failed}}}return i}))}}lo.ServiceName="DevicesService";class ho{constructor(){this.Channel=0,this.States=[]}}class po extends ie{constructor(){super(),this.Resource="/devices/list",this.Method=ce.Get}}class go extends ie{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ce.Get}}class fo extends ie{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ce.Get}}class vo extends ie{constructor(){super(),this.Resource="/devices/search",this.Method=ce.Post}}class mo extends ie{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ce.Post}}class yo extends ie{constructor(){super(),this.Resource="/devices/found/list",this.Method=ce.Get}}class wo extends ie{constructor(){super(),this.Resource="/devices/tasks",this.Method=ce.Get}}class So extends ie{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ce.Put}}class _o extends ie{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ce.Put}}class Ao extends ie{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ce.Put}}class Co extends ie{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ce.Post,this.Data=e}}class To extends ie{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ce.Post,this.Data=e}}class Do extends ie{constructor(e){super(),this.Resource="/logic/device/used",this.Method=ce.Get,this.Data=e}}class Go{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=mr.GetState,this.SequnceExecutionOrder=0}}class ko extends Go{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class bo extends Go{constructor(){super(...arguments),this.FacadeAction=_r.Stop,this.Tilt=0,this.Position=0}}class No{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class Eo extends RangeError{constructor(e){super(`${e} was out of range. Must be non-negative and less than the size of the collection.`),this.paramName=e,this.name="ArgumentOutOfRangeException",this.stack=this.stack||(new Error).stack}}const Io=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 Ro extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Po=(e,t)=>e===t;class Oo{constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Uo{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 Mo{constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class xo extends Array{}const Fo=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return $o(e,t,n,r)}return n?Bo(e,t,n):Lo(e,t)},Lo=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Ro(Io.NoElements);return n},Bo=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},$o=(e,t,n,r)=>{let s=t;for(const t of e)s=n(s,t);return r(s)},Wo=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},qo=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Ho=(e,t)=>t?jo(e,t):Vo(e),Vo=e=>{for(const t of e)return!0;return!1},jo=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Ko=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},zo=e=>{if(Array.isArray(e)){if(0===e.length)throw new Ro(Io.NoElements);return new Oo((async function*(){for await(const t of e)yield t}))}return new Oo(e)},Jo=e=>zo((async function*(){for(const t of e)yield t})),Yo=(e,t)=>new Uo({generator:t,type:e}),Xo=e=>Yo(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Qo=(e,t)=>{let n=0,r=0;if(t)for(const s of e)n+=t(s),r+=1;else for(const t of e)n+=t,r+=1;if(0===r)throw new Ro(Io.NoElements);return n/r},Zo=async(e,t)=>{let n=0,r=0;for(const s of e)n+=await t(s),r+=1;if(0===r)throw new Ro(Io.NoElements);return n/r},ei=(e,t)=>{if(t<1)throw new Eo("index");return new Mo((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},ti=(e,t)=>new Mo((function*(){yield*e,yield*t})),ni=(e,t,n=Po)=>{for(const r of e)if(n(t,r))return!0;return!1},ri=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},si=(e,t)=>t?ii(e,t):oi(e),oi=e=>{let t=0;for(const n of e)t++;return t},ii=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},ai=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},ci=(e,t)=>new Mo((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),ui=(e,t=Po)=>new Mo((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),li=(e,t)=>zo((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}})),di=(e,t)=>new Mo((function*(){for(const n of e)t(n),yield n})),hi=(e,t)=>zo((async function*(){for(const n of e)await t(n),yield n})),pi=(e,t)=>{if(t<0)throw new Eo("index");let n=0;for(const r of e)if(t===n++)return r;throw new Eo("index")},gi=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},fi=(e,t,n=Po)=>new Mo((function*(){const r=[...t];for(const t of e){let e=!1;for(let s=0;s<r.length;s++)if(!0===n(t,r[s])){e=!0;break}!1===e&&(yield t)}})),vi=(e,t,n)=>zo((async function*(){const r=[...t];for(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===await n(t,o)){e=!0;break}}!1===e&&(yield t)}})),mi=(e,t)=>t?wi(e,t):yi(e),yi=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new Ro(Io.NoElements);return t.value},wi=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new Ro(Io.NoMatch)},Si=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new Ro(Io.NoMatch)},_i=(e,t)=>t?Ci(e,t):Ai(e),Ai=e=>e[Symbol.iterator]().next().value||null,Ci=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},Ti=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class Di extends xo{constructor(e,t){super(1),this.key=e,this[0]=t}}const Gi=(e,t,n)=>{let r;return r=n?((e,t,n)=>function*(){const r=new Array;for(const s of e){const e=t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Di(e,s))}for(const e of r)yield e})(e,t,n):((e,t)=>function*(){const n={};for(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new Di(e,r)}for(const e in n)yield n[e]})(e,t),new Mo(r)},ki=(e,t,n)=>n?Ni(e,t,n):bi(e,t),bi=(e,t)=>zo((async function*(){const n={};for(const r of e){const e=await t(r),s=n[e];s?s.push(r):n[e]=new Di(e,r)}for(const e in n)yield n[e]})),Ni=(e,t,n)=>zo((async function*(){const r=new Array;for(const s of e){const e=await t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Di(e,s))}for(const e of r)yield e})),Ei=(e,t,n,r)=>r?((e,t,n,r)=>new Mo((function*(){const s=new Array;for(const o of e){const e=t(o);let i=!1;for(let t=0;t<s.length;t++){const a=s[t];if(r(a.key,e)){a.push(n(o)),i=!0;break}}if(!1===i){const t=n(o);s.push(new Di(e,t))}}for(const e of s)yield e})))(e,t,n,r):((e,t,n)=>new Mo((function*(){const r={};for(const s of e){const e=t(s),o=r[e],i=n(s);o?o.push(i):r[e]=new Di(e,i)}for(const e in r)yield r[e]})))(e,t,n),Ii=(e,t,n,r,s,o)=>{const i=o?Ri(e,t,n,r,s,o):Pi(e,t,n,r,s);return new Mo(i)},Ri=(e,t,n,r,s,o)=>function*(){var i;const a=[];for(const e of t){const t=r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},Pi=(e,t,n,r,s)=>function*(){var o;const i=new Map;for(const e of t){const t=r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},Oi=(e,t,n,r,s,o)=>{const i=o?Ui(e,t,n,r,s,o):Mi(e,t,n,r,s);return zo(i)},Ui=(e,t,n,r,s,o)=>async function*(){var i;const a=[];for(const e of t){const t=await r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=await n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},Mi=(e,t,n,r,s)=>async function*(){var o;const i=new Map;for(const e of t){const t=await r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=await n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},xi=(e,t,n=Po)=>new Mo((function*(){const r=[...e.distinct(n)];if(0===r.length)return;const s=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++)if(!0===n(t,s[e])){yield t;break}}})),Fi=(e,t,n)=>zo((async function*(){const r=[];for await(const t of e.distinctAsync(n))r.push(t);if(0===r.length)return;const s=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===await n(t,r)){yield t;break}}}})),Li=(e,t,n,r,s,o=Po)=>new Mo((function*(){const i=[...t];for(const t of e){const e=n(t);for(const n of i){const i=r(n);!0===o(e,i)&&(yield s(t,n))}}})),Bi=(e,t)=>t?Wi(e,t):$i(e),$i=e=>{let t;for(const n of e)t=n;if(!t)throw new Ro(Io.NoElements);return t},Wi=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new Ro(Io.NoMatch);return n},qi=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new Ro(Io.NoMatch);return n},Hi=(e,t)=>t?ji(e,t):Vi(e),Vi=e=>{let t=null;for(const n of e)t=n;return t},ji=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},Ki=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},zi=(e,t)=>t?Yi(e,t):Ji(e),Ji=e=>{let t=null;for(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new Ro(Io.NoElements);return t},Yi=(e,t)=>{let n=null;for(const r of e)n=Math.max(n||Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new Ro(Io.NoElements);return n},Xi=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 Ro(Io.NoElements);return n},Qi=(e,t)=>t?ea(e,t):Zi(e),Zi=e=>{let t=null;for(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new Ro(Io.NoElements);return t},ea=(e,t)=>{let n=null;for(const r of e)n=Math.min(n||Number.POSITIVE_INFINITY,t(r));if(null===n)throw new Ro(Io.NoElements);return n},ta=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 Ro(Io.NoElements);return n},na=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Mo((function*(){for(const t of e)n(t)&&(yield t)}))};async function*ra(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}function*sa(e,t,n,r){const s=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}class oa extends Oo{constructor(e){super((async function*(){for await(const t of e())yield*t})),this.orderedPairs=e}static generateAsync(e,t,n,r){let s;return s=e instanceof oa?async function*(){for await(const s of e.orderedPairs())yield*ra(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new oa(s)}static generate(e,t,n,r){let s;return s=e instanceof oa?async function*(){for await(const s of e.orderedPairs())yield*sa(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new oa(s)}thenBy(e,t){return oa.generate(this,e,!0,t)}thenByAsync(e,t){return oa.generateAsync(this,e,!0,t)}thenByDescending(e,t){return oa.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return oa.generateAsync(this,e,!1,t)}}function*ia(e,t,n,r){const s=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}async function*aa(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}class ca extends Mo{constructor(e){super((function*(){for(const t of e())yield*t})),this.orderedPairs=e}static generate(e,t,n,r){let s;return s=e instanceof ca?function*(){for(const s of e.orderedPairs())yield*ia(s,t,n,r)}:()=>ia(e,t,n,r),new ca(s)}static generateAsync(e,t,n,r){let s;return s=e instanceof ca?async function*(){for(const s of e.orderedPairs())yield*aa(s,t,n,r)}:()=>aa(e,t,n,r),new oa(s)}thenBy(e,t){return ca.generate(this,e,!0,t)}thenByAsync(e,t){return ca.generateAsync(this,e,!0,t)}thenByDescending(e,t){return ca.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return ca.generateAsync(this,e,!1,t)}}const ua=(e,t,n)=>ca.generate(e,t,!0,n),la=(e,t,n)=>ca.generateAsync(e,t,!0,n),da=(e,t,n)=>ca.generate(e,t,!1,n),ha=(e,t,n)=>ca.generateAsync(e,t,!1,n),pa=(e,t)=>{const n=[],r=[];for(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},ga=async(e,t)=>{const n=[],r=[];for(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},fa=e=>new Mo((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),va=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?ma(e,t):ya(e,t)}return wa(e,t)},ma=(e,t)=>new Mo((function*(){for(const n of e)yield t(n)})),ya=(e,t)=>new Mo((function*(){let n=0;for(const r of e)yield t(r,n),n++})),wa=(e,t)=>new Mo((function*(){for(const n of e)yield n[t]})),Sa=(e,t)=>"function"==typeof t?1===t.length?_a(e,t):Aa(e,t):Ca(e,t),_a=(e,t)=>zo((async function*(){for(const n of e)yield t(n)})),Aa=(e,t)=>zo((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),Ca=(e,t)=>zo((async function*(){for(const n of e)yield n[t]})),Ta=(e,t)=>"function"==typeof t?1===t.length?Da(e,t):Ga(e,t):ka(e,t),Da=(e,t)=>new Mo((function*(){for(const n of e)for(const e of t(n))yield e})),Ga=(e,t)=>new Mo((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),ka=(e,t)=>new Mo((function*(){for(const n of e)for(const e of n[t])yield e})),ba=(e,t)=>1===t.length?Na(e,t):Ea(e,t),Na=(e,t)=>zo((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Ea=(e,t)=>zo((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),Ia=(e,t,n=Po)=>{const r=e[Symbol.iterator](),s=t[Symbol.iterator]();let o=r.next(),i=s.next();for(;!o.done&&!i.done;){if(!n(o.value,i.value))return!1;o=r.next(),i=s.next()}return!0===o.done&&!0===i.done},Ra=async(e,t,n)=>{const r=e[Symbol.iterator](),s=t[Symbol.iterator]();let o=r.next(),i=s.next();for(;!o.done&&!i.done;){if(!1===await n(o.value,i.value))return!1;o=r.next(),i=s.next()}return!0===o.done&&!0===i.done},Pa=(e,t)=>t?Ua(e,t):Oa(e),Oa=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new Ro(Io.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new Ro(Io.NoElements);return n},Ua=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new Ro(Io.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Ro(Io.NoMatch);return r},Ma=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new Ro(Io.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Ro(Io.NoMatch);return r},xa=(e,t)=>t?La(e,t):Fa(e),Fa=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new Ro(Io.MoreThanOneElement);t=!0,n=r}return n},La=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new Ro(Io.MoreThanOneMatchingElement);n=!0,r=s}return r},Ba=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new Ro(Io.MoreThanOneElement);n=!0,r=s}return r},$a=(e,t)=>new Mo((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),Wa=(e,t)=>1===t.length?qa(e,t):Ha(e,t),qa=(e,t)=>new Mo((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Ha=(e,t)=>new Mo((function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),Va=(e,t)=>1===t.length?ja(e,t):Ka(e,t),ja=(e,t)=>zo((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Ka=(e,t)=>zo((async function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===await t(s,n)&&(r=!1,yield s),n++})),za=(e,t)=>t?Ya(e,t):Ja(e),Ja=e=>{let t=0;for(const n of e)t+=n;return t},Ya=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},Xa=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},Qa=(e,t)=>new Mo((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),Za=(e,t)=>1===t.length?ec(e,t):tc(e,t),ec=(e,t)=>new Mo((function*(){for(const n of e){if(!t(n))break;yield n}})),tc=(e,t)=>new Mo((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),nc=(e,t)=>1===t.length?rc(e,t):sc(e,t),rc=(e,t)=>zo((async function*(){for(const n of e){if(!await t(n))break;yield n}})),sc=(e,t)=>zo((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),oc=e=>[...e],ic=(e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},ac=async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},cc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},uc=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},lc=e=>new Set(e),dc=(e,t,n)=>n?pc(e,t,n):hc(e,t),hc=(e,t)=>new Mo((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))})),pc=(e,t,n)=>new Mo((function*(){const r=[];for(const s of[e,t])for(const e of s){let t=!1;for(const s of r)if(!0===n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),gc=(e,t,n)=>zo((async function*(){const r=[];for(const s of[e,t])for(const e of s){let t=!1;for(const s of r)if(!0===await n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),fc=(e,t)=>1===t.length?vc(e,t):mc(e,t),vc=(e,t)=>new Mo((function*(){for(const n of e)!0===t(n)&&(yield n)})),mc=(e,t)=>new Mo((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),yc=(e,t)=>1===t.length?wc(e,t):Sc(e,t),wc=(e,t)=>zo((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),Sc=(e,t)=>zo((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),_c=(e,t,n)=>n?Cc(e,t,n):Ac(e,t),Ac=(e,t)=>new Mo((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]}})),Cc=(e,t,n)=>new Mo((function*(){const r=e[Symbol.iterator](),s=t[Symbol.iterator]();for(;;){const e=r.next(),t=s.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Tc=(e,t,n)=>zo((async function*(){const r=e[Symbol.iterator](),s=t[Symbol.iterator]();for(;;){const e=r.next(),t=s.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Dc=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(Fo,"aggregate"),n(Wo,"all"),n(qo,"allAsync"),n(Ho,"any"),n(Ko,"anyAsync"),n(Jo,"asAsync"),n(Xo,"asParallel"),n(Qo,"average"),n(Zo,"averageAsync"),n(ei,"chunk"),n(ti,"concatenate"),n(ni,"contains"),n(ri,"containsAsync"),n(si,"count"),n(ai,"countAsync"),n(ci,"defaultIfEmpty"),n(ui,"distinct"),n(li,"distinctAsync"),n(di,"each"),n(hi,"eachAsync"),n(pi,"elementAt"),n(gi,"elementAtOrDefault"),n(fi,"except"),n(vi,"exceptAsync"),n(mi,"first"),n(Si,"firstAsync"),n(_i,"firstOrDefault"),n(Ti,"firstOrDefaultAsync"),n(Gi,"groupBy"),n(ki,"groupByAsync"),n(Ei,"groupByWithSel"),n(Ii,"groupJoin"),n(Oi,"groupJoinAsync"),n(xi,"intersect"),n(Fi,"intersectAsync"),n(Li,"joinByKey"),n(Bi,"last"),n(qi,"lastAsync"),n(Hi,"lastOrDefault"),n(Ki,"lastOrDefaultAsync"),n(zi,"max"),n(Xi,"maxAsync"),n(Qi,"min"),n(ta,"minAsync"),n(na,"ofType"),n(ua,"orderBy"),n(la,"orderByAsync"),n(da,"orderByDescending"),n(ha,"orderByDescendingAsync"),n(fa,"reverse"),n(va,"select"),n(Sa,"selectAsync"),n(Ta,"selectMany"),n(ba,"selectManyAsync"),n(Ia,"sequenceEquals"),n(Ra,"sequenceEqualsAsync"),n(Pa,"single"),n(Ma,"singleAsync"),n(xa,"singleOrDefault"),n(Ba,"singleOrDefaultAsync"),n($a,"skip"),n(Wa,"skipWhile"),n(Va,"skipWhileAsync"),n(za,"sum"),n(Xa,"sumAsync"),n(Qa,"take"),n(Za,"takeWhile"),n(nc,"takeWhileAsync"),n(oc,"toArray"),n(ic,"toMap"),n(ac,"toMapAsync"),n(cc,"toObject"),n(uc,"toObjectAsync"),n(pa,"partition"),n(ga,"partitionAsync"),n(lc,"toSet"),n(dc,"union"),n(gc,"unionAsync"),n(fc,"where"),n(yc,"whereAsync"),n(_c,"zip"),n(Tc,"zipAsync")},Gc=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Nc(e,t,n,r)}return n?bc(e,t,n):kc(e,t)},kc=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Ro(Io.NoElements);return n},bc=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Nc=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},Ec=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Ic=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},Rc=(e,t)=>t?Oc(e,t):Pc(e),Pc=async e=>{for await(const t of e)return!0;return!1},Oc=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Uc=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},Mc=e=>Yo(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),xc=async(e,t)=>{let n=0,r=0;if(t)for await(const s of e)n+=t(s),r+=1;else for await(const t of e)n+=t,r+=1;if(0===r)throw new Ro(Io.NoElements);return n/r},Fc=async(e,t)=>{let n=0,r=0;for await(const s of e)n+=await t(s),r+=1;if(0===r)throw new Ro(Io.NoElements);return n/r},Lc=(e,t)=>{if(t<1)throw new Eo("index");return new Oo((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Bc=(e,t)=>new Oo((async function*(){yield*e,yield*t})),$c=async(e,t,n=Po)=>{for await(const r of e)if(n(t,r))return!0;return!1},Wc=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},qc=(e,t)=>t?Vc(e,t):Hc(e),Hc=async e=>{let t=0;for await(const n of e)t++;return t},Vc=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},jc=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},Kc=(e,t)=>new Oo((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),zc=(e,t=Po)=>new Oo((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Jc=(e,t)=>new Oo((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}})),Yc=(e,t)=>new Oo((async function*(){for await(const n of e)t(n),yield n})),Xc=(e,t)=>new Oo((async function*(){for await(const n of e)await t(n),yield n})),Qc=async(e,t)=>{if(t<0)throw new Eo("index");let n=0;for await(const r of e)if(t===n++)return r;throw new Eo("index")},Zc=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},eu=(e,t,n=Po)=>new Oo((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===n(t,o)){e=!0;break}}!1===e&&(yield t)}})),tu=(e,t,n)=>new Oo((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===await n(t,o)){e=!0;break}}!1===e&&(yield t)}})),nu=(e,t)=>t?su(e,t):ru(e),ru=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new Ro(Io.NoElements);return t.value},su=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new Ro(Io.NoMatch)},ou=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new Ro(Io.NoMatch)},iu=(e,t)=>t?cu(e,t):au(e),au=async e=>(await e[Symbol.asyncIterator]().next()).value||null,cu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},uu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},lu=(e,t,n)=>n?du(e,t,n):hu(e,t),du=(e,t,n)=>new Oo((async function*(){const r=new Array;for await(const s of e){const e=t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Di(e,s))}for(const e of r)yield e})),hu=(e,t)=>new Oo((async function*(){const n={};for await(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new Di(e,r)}for(const e in n)yield n[e]})),pu=(e,t,n)=>n?fu(e,t,n):gu(e,t),gu=(e,t)=>new Oo((async function*(){const n={};for await(const r of e){const e=await t(r),s=n[e];s?s.push(r):n[e]=new Di(e,r)}for(const e in n)yield n[e]})),fu=(e,t,n)=>new Oo((async function*(){const r=new Array;for await(const s of e){const e=await t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Di(e,s))}for(const e of r)yield e})),vu=(e,t,n,r)=>r?yu(e,t,n,r):mu(e,t,n),mu=(e,t,n)=>new Oo((async function*(){const r={};for await(const s of e){const e=t(s),o=r[e],i=n(s);o?o.push(i):r[e]=new Di(e,i)}for(const e in r)yield r[e]})),yu=(e,t,n,r)=>new Oo((async function*(){const s=new Array;for await(const o of e){const e=t(o);let i=!1;for(let t=0;t<s.length;t++){const a=s[t];if(r(a.key,e)){a.push(n(o)),i=!0;break}}if(!1===i){const t=n(o);s.push(new Di(e,t))}}for(const e of s)yield e})),wu=(e,t,n,r,s,o)=>{const i=o?Su(e,t,n,r,s,o):_u(e,t,n,r,s);return new Oo(i)},Su=(e,t,n,r,s,o)=>async function*(){var i;const a=[];for await(const e of t){const t=r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},_u=(e,t,n,r,s)=>async function*(){var o;const i=new Map;for await(const e of t){const t=r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},Au=(e,t,n,r,s,o)=>{const i=o?Cu(e,t,n,r,s,o):Tu(e,t,n,r,s);return new Oo(i)},Cu=(e,t,n,r,s,o)=>async function*(){var i;const a=[];for await(const e of t){const t=await r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=await n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},Tu=(e,t,n,r,s)=>async function*(){var o;const i=new Map;for await(const e of t){const t=await r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=await n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},Du=(e,t,n=Po)=>new Oo((async function*(){const r=await e.distinct(n).toArray();if(0===r.length)return;const s=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===n(t,r)){yield t;break}}}})),Gu=(e,t,n)=>new Oo((async function*(){const r=await e.distinctAsync(n).toArray();if(0===r.length)return;const s=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===await n(t,r)){yield t;break}}}})),ku=(e,t,n,r,s,o=Po)=>new Oo((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===o(e,i)&&(yield s(t,n))}}})),bu=(e,t)=>t?Eu(e,t):Nu(e),Nu=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new Ro(Io.NoElements);return t},Eu=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new Ro(Io.NoMatch);return n},Iu=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new Ro(Io.NoMatch);return n},Ru=(e,t)=>t?Ou(e,t):Pu(e),Pu=async e=>{let t=null;for await(const n of e)t=n;return t},Ou=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},Uu=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},Mu=(e,t)=>t?Fu(e,t):xu(e),xu=async e=>{let t=null;for await(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new Ro(Io.NoElements);return t},Fu=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 Ro(Io.NoElements);return n},Lu=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 Ro(Io.NoElements);return n},Bu=(e,t)=>t?Wu(e,t):$u(e),$u=async e=>{let t=null;for await(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new Ro(Io.NoElements);return t},Wu=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 Ro(Io.NoElements);return n},qu=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 Ro(Io.NoElements);return n},Hu=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Oo((async function*(){for await(const t of e)n(t)&&(yield t)}))},Vu=(e,t,n)=>oa.generate(e,t,!0,n),ju=(e,t,n)=>oa.generateAsync(e,t,!0,n),Ku=(e,t,n)=>oa.generate(e,t,!1,n),zu=(e,t,n)=>oa.generateAsync(e,t,!1,n),Ju=async(e,t)=>{const n=[],r=[];for await(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},Yu=async(e,t)=>{const n=[],r=[];for await(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},Xu=e=>new Oo((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]})),Qu=(e,t)=>"function"==typeof t?1===t.length?Zu(e,t):el(e,t):tl(e,t),Zu=(e,t)=>new Oo((async function*(){for await(const n of e)yield t(n)})),el=(e,t)=>new Oo((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),tl=(e,t)=>new Oo((async function*(){for await(const n of e)yield n[t]})),nl=(e,t)=>"string"==typeof t?sl(e,t):rl(e,t),rl=(e,t)=>new Oo((async function*(){for await(const n of e)yield t(n)})),sl=(e,t)=>new Oo((async function*(){for await(const n of e)yield n[t]})),ol=(e,t)=>"function"==typeof t?1===t.length?il(e,t):al(e,t):cl(e,t),il=(e,t)=>new Oo((async function*(){for await(const n of e)for(const e of t(n))yield e})),al=(e,t)=>new Oo((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),cl=(e,t)=>new Oo((async function*(){for await(const n of e)for(const e of n[t])yield e})),ul=(e,t)=>1===t.length?new Oo((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Oo((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++}})),ll=async(e,t,n=Po)=>{const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();let o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1];for(;!i.done&&!a.done;){if(!n(i.value,a.value))return!1;o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1]}return!0===i.done&&!0===a.done},dl=async(e,t,n)=>{const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();let o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1];for(;!i.done&&!a.done;){if(!1===await n(i.value,a.value))return!1;o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1]}return!0===i.done&&!0===a.done},hl=(e,t)=>t?gl(e,t):pl(e),pl=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new Ro(Io.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new Ro(Io.NoElements);return n},gl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new Ro(Io.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Ro(Io.NoMatch);return r},fl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new Ro(Io.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Ro(Io.NoMatch);return r},vl=(e,t)=>t?yl(e,t):ml(e),ml=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new Ro(Io.MoreThanOneElement);t=!0,n=r}return n},yl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new Ro(Io.MoreThanOneMatchingElement);n=!0,r=s}return r},wl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new Ro(Io.MoreThanOneMatchingElement);n=!0,r=s}return r},Sl=(e,t)=>new Oo((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),_l=(e,t)=>1===t.length?Al(e,t):Cl(e,t),Al=(e,t)=>new Oo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Cl=(e,t)=>new Oo((async function*(){let n=0,r=!0;for await(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),Tl=(e,t)=>1===t.length?Dl(e,t):Gl(e,t),Dl=(e,t)=>new Oo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Gl=(e,t)=>new Oo((async function*(){let n=0,r=!0;for await(const s of e)!1===r?yield s:!1===await t(s,n)&&(r=!1,yield s),n++})),kl=(e,t)=>t?Nl(e,t):bl(e),bl=async e=>{let t=0;for await(const n of e)t+=n;return t},Nl=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},El=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},Il=(e,t)=>new Oo((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Rl=(e,t)=>1===t.length?Pl(e,t):Ol(e,t),Pl=(e,t)=>new Oo((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Ol=(e,t)=>new Oo((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Ul=(e,t)=>1===t.length?Ml(e,t):xl(e,t),Ml=(e,t)=>new Oo((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),xl=(e,t)=>new Oo((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Fl=async e=>{const t=[];for await(const n of e)t.push(n);return t},Ll=async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},Bl=async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},$l=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},Wl=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},ql=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Hl=(e,t,n)=>n?jl(e,t,n):Vl(e,t),Vl=(e,t)=>new Oo((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))})),jl=(e,t,n)=>new Oo((async function*(){const r=[];for(const s of[e,t])for await(const e of s){let t=!1;for(const s of r)if(!0===n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),Kl=(e,t,n)=>new Oo((async function*(){const r=[];for(const s of[e,t])for await(const e of s){let t=!1;for(const s of r)if(!0===await n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),zl=(e,t)=>1===t.length?Jl(e,t):Yl(e,t),Jl=(e,t)=>new Oo((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Yl=(e,t)=>new Oo((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),Xl=(e,t)=>1===t.length?Ql(e,t):Zl(e,t),Ql=(e,t)=>new Oo((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),Zl=(e,t)=>new Oo((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),ed=(e,t,n)=>n?nd(e,t,n):td(e,t),td=(e,t)=>new Oo((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]}})),nd=(e,t,n)=>new Oo((async function*(){const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([r.next(),s.next()]);if(e.done||t.done)break;yield n(e.value,t.value)}})),rd=(e,t,n)=>new Oo((async function*(){const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();for(;;){const e=await Promise.all([r.next(),s.next()]),t=e[0],o=e[1];if(t.done||o.done)break;yield n(t.value,o.value)}})),sd=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return ad(e,t,n,r)}return n?id(e,t,n):od(e,t)},od=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Ro(Io.NoElements);return n},id=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},ad=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},cd=(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}}},ud=(e,t)=>{const n=cd(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))}},ld=(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}}},dd=(e,t)=>{const n=ld(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))}},hd=(e,t)=>t?gd(e,t):pd(e),pd=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}},gd=async(e,t)=>{const n=cd(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)}},fd=async(e,t)=>{const n=ld(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 s of r)s.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)}},vd=e=>zo((async function*(){for await(const t of e)yield t})),md=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)}},yd=async(e,t)=>{let n;n=t?cd(e,t):e.dataFunc;const r=await md(n);if(0===r.length)throw new Ro(Io.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},wd=async(e,t)=>{const n=ld(e,t),r=await md(n);if(0===r.length)throw new Ro(Io.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},Sd=(e,t)=>{if(t<1)throw new Eo("index");let n;switch(e.dataFunc.type){case 1:const r=e.dataFunc.generator;n={type:1,generator:()=>{const e=[];let n=[];for(const s of r())n.push(s),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 2:const s=e.dataFunc.generator;n={type:2,generator:async()=>{const e=[];let n=[];for(const r of await s())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 o=e.dataFunc.generator;n={type:0,generator:async()=>{const e=[];let n=[];for(const r of await o())n.push(r),n.length===t&&(e.push(n),n=[]);return n.length&&e.push(n),e}}}return new Uo(n)},_d=(e,t)=>new Uo({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),Ad=async(e,t,n=Po)=>{let r;switch(r=cd(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))}},Cd=async(e,t,n)=>{const r=ld(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))}},Td=(e,t)=>t?Gd(e,t):Dd(e),Dd=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},Gd=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},kd=async(e,t)=>{const n=ld(e,t);let r;switch(n.type){case 1:r=Promise.all(n.generator());break;case 2:r=Promise.all(await n.generator())}let s=0;for(const e of await r)e&&s++;return s},bd=(e,t)=>{const n=e.dataFunc,r=t instanceof Promise;let s;switch(n.type){case 0:s={generator:()=>n.generator().then((e=>e.length?e:r?t.then((e=>[e])):[t])),type:n.type};break;case 1:s={generator:()=>{const e=n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type};break;case 2:s={generator:async()=>{const e=await n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type}}return new Uo(s)},Nd=(e,t=Po)=>new Uo({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),Ed=(e,t)=>new Uo({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}),Id=(e,t)=>new Uo(cd(e,(e=>(t(e),e)))),Rd=(e,t)=>{const n=ld(e,(async e=>(await t(e),e)));return new Uo(n)},Pd=async(e,t)=>{if(t<0)throw new Eo("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new Eo("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new Eo("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new Eo("index");return await e[t]}}},Od=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]}}},Ud=(e,t,n=Po)=>new Uo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=[];for(const e of r){let t=!1;for(let r=0;r<s.length;r++){const o=s[r];if(!0===n(e,o)){t=!0;break}}!1===t&&o.push(e)}return o},type:0}),Md=(e,t,n)=>new Uo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=[];for(const e of r){let t=!1;for(let r=0;r<s.length;r++){const o=s[r];if(!0===await n(e,o)){t=!0;break}}!1===t&&o.push(e)}return o},type:0}),xd=e=>md(e.dataFunc),Fd=(e,t)=>t?Bd(e,t):Ld(e),Ld=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new Ro(Io.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new Ro(Io.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new Ro(Io.NoElements);return await e[0]}}},Bd=async(e,t)=>{const n=await xd(e);for(const e of n)if(!0===t(e))return e;throw new Ro(Io.NoMatch)},$d=async(e,t)=>{const n=await xd(e);for(const e of n)if(!0===await t(e))return e;throw new Ro(Io.NoMatch)},Wd=(e,t)=>t?Hd(e,t):qd(e),qd=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]}}},Hd=async(e,t)=>{const n=await xd(e);for(const e of n)if(!0===t(e))return e;return null},Vd=async(e,t)=>{const n=await xd(e);for(const e of n)if(!0===await t(e))return e;return null},jd=(e,t,n)=>n?zd(e,t,n):Kd(e,t),Kd=(e,t)=>new Uo({generator:async()=>{const n={};for(const r of await e.toArray()){const e=t(r),s=n[e];s?s.push(r):n[e]=new Di(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),zd=(e,t,n)=>new Uo({generator:async()=>{const r=new Array;for(const s of await e.toArray()){const e=t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Di(e,s))}const s=new Array;for(const e of r)s.push(e);return s},type:0}),Jd=(e,t,n)=>n?Yd(e,t,n):Xd(e,t),Yd=(e,t,n)=>new Uo({generator:async()=>{const r=ld(e,(async e=>[await t(e),e]));let s;switch(r.type){case 1:s=await Promise.all(r.generator());break;case 2:s=await Promise.all(await r.generator())}const o=new Array;for(const[e,t]of s){let r=!1;for(let s=0;s<o.length;s++){const i=o[s];if(!0===await n(i.key,e)){i.push(t),r=!0;break}}!1===r&&o.push(new Di(e,t))}const i=new Array;for(const e of o)i.push(e);return i},type:0}),Xd=(e,t)=>new Uo({generator:async()=>{const n=ld(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 s={};for(const[e,t]of r){const n=s[e];n?n.push(t):s[e]=new Di(e,t)}const o=new Array;for(const e in s)o.push(s[e]);return o},type:0}),Qd=(e,t,n,r)=>r?Zd(e,t,n,r):eh(e,t,n),Zd=(e,t,n,r)=>new Uo({generator:async()=>{const s=new Array;for await(const o of e){const e=t(o);let i=!1;for(let t=0;t<s.length;t++){const a=s[t];if(r(a.key,e)){a.push(n(o)),i=!0;break}}if(!1===i){const t=n(o);s.push(new Di(e,t))}}const o=new Array;for(const e of s)o.push(e);return o},type:0}),eh=(e,t,n)=>new Uo({generator:async()=>{const r={};for(const s of await e.toArray()){const e=t(s),o=r[e],i=n(s);o?o.push(i):r[e]=new Di(e,i)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),th=(e,t,n,r,s,o)=>{const i=o?nh(e,t,n,r,s,o):rh(e,t,n,r,s);return new Uo({generator:i,type:0})},nh=(e,t,n,r,s,o)=>async()=>{const i=[];for await(const e of t){const t=r(e),n=i.find((e=>o(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}return(await e.toArray()).map((e=>{var t;const r=n(e),a=null!==(t=i.find((e=>o(e.key,r))))&&void 0!==t?t:{key:r,values:[]};return s(e,a.values)}))},rh=(e,t,n,r,s)=>async()=>{const o=new Map;for await(const e of t){const t=r(e),n=o.get(t);n?n.push(e):o.set(t,[e])}return(await e.toArray()).map((e=>{var t;const r=n(e),i=null!==(t=o.get(r))&&void 0!==t?t:[];return s(e,i)}))},sh=(e,t,n,r,s,o)=>{const i=o?oh(e,t,n,r,s,o):ih(e,t,n,r,s);return new Uo({generator:i,type:0})},oh=(e,t,n,r,s,o)=>async()=>{const i=[];for await(const e of t){const t=await r(e),n=i.find((e=>o(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}const a=(await e.toArray()).map((async e=>{var t;const r=await n(e),a=null!==(t=i.find((e=>o(e.key,r))))&&void 0!==t?t:{key:r,values:[]};return s(e,a.values)}));return await Promise.all(a)},ih=(e,t,n,r,s)=>async()=>{const o=new Map;for await(const e of t){const t=await r(e),n=o.get(t);n?n.push(e):o.set(t,[e])}const i=(await e.toArray()).map((async e=>{var t;const r=await n(e),i=null!==(t=o.get(r))&&void 0!==t?t:[];return s(e,i)}));return await Promise.all(i)},ah=(e,t,n=Po)=>new Uo({generator:async()=>{const r=await e.distinct(n).toArray();if(0===r.length)return[];const s=await t.toArray(),o=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===n(t,r)){o.push(t);break}}}return o},type:0}),ch=(e,t,n)=>new Uo({generator:async()=>{const r=await e.distinctAsync(n).toArray();if(0===r.length)return[];const s=await t.toArray(),o=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===await n(t,r)){o.push(t);break}}}return o},type:0}),uh=(e,t,n,r,s,o=Po)=>new Uo({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===o(t,i)&&c.push(s(e,n))}}return c},type:0}),lh=(e,t)=>t?hh(e,t):dh(e),dh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new Ro(Io.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new Ro(Io.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new Ro(Io.NoElements);return await e[e.length-1]}}},hh=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 Ro(Io.NoMatch)},ph=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 Ro(Io.NoMatch)},gh=(e,t)=>t?vh(e,t):fh(e),fh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();return 0===e.length?null:e[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]}}},vh=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},mh=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},yh=async(e,t)=>{let n;n=t?cd(e,t):e.dataFunc;const r=await md(n);if(0===r.length)throw new Ro(Io.NoElements);return Math.max.apply(null,r)},wh=async(e,t)=>{const n=ld(e,t),r=await md(n);if(0===r.length)throw new Ro(Io.NoElements);return Math.max.apply(null,r)},Sh=async(e,t)=>{let n;n=t?cd(e,t):e.dataFunc;const r=await md(n);if(0===r.length)throw new Ro(Io.NoElements);return Math.min.apply(null,r)},_h=async(e,t)=>{const n=ld(e,t),r=await md(n);if(0===r.length)throw new Ro(Io.NoElements);return Math.min.apply(null,r)},Ah=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Uo({generator:async()=>{const t=cd(e,n),r=await md(t),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0})};async function*Ch(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}async function*Th(e,t,n,r){const s=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}class Dh extends Uo{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 s;return s=e instanceof Dh?async function*(){for await(const s of e.orderedPairs())yield*Ch(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new Dh(s)}static generate(e,t,n,r){let s;return s=e instanceof Dh?async function*(){for await(const s of e.orderedPairs())yield*Th(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new Dh(s)}thenBy(e,t){return Dh.generate(this,e,!0,t)}thenByAsync(e,t){return Dh.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Dh.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Dh.generateAsync(this,e,!1,t)}}const Gh=(e,t,n)=>Dh.generate(e,t,!0,n),kh=(e,t,n)=>Dh.generateAsync(e,t,!0,n),bh=(e,t,n)=>Dh.generate(e,t,!1,n),Nh=(e,t,n)=>Dh.generateAsync(e,t,!1,n),Eh=async(e,t)=>{const n=cd(e,(e=>[t(e),e])),r=await md(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Ih=async(e,t)=>{const n=ld(e,(async e=>[await t(e),e])),r=await md(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Rh=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Uo({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Uo({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Ph=(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}}},Oh=(e,t)=>"function"==typeof t?1===t.length?new Uo(cd(e,t)):new Uo(Ph(e,t)):new Uo(cd(e,(e=>e[t]))),Uh=(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}}},Mh=(e,t)=>{let n;return n="function"==typeof t?1===t.length?ld(e,t):Uh(e,t):ld(e,(e=>e[t])),new Uo(n)},xh=(e,t)=>new Uo({generator:async()=>{let n;n="function"==typeof t?1===t.length?cd(e,t):Ph(e,t):cd(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}),Fh=(e,t)=>new Uo({generator:async()=>{let n;n=1===t.length?ld(e,t):Uh(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}),Lh=async(e,t,n=Po)=>{const r=await e.toArray(),s=await t.toArray();if(r.length!==s.length)return!1;for(let e=0;e<r.length;e++)if(!1===n(r[e],s[e]))return!1;return!0},Bh=async(e,t,n)=>{const r=await e.toArray(),s=await t.toArray();if(r.length!==s.length)return!1;for(let e=0;e<r.length;e++){const t=r[e],o=s[e];if(!1===await n(t,o))return!1}return!0},$h=(e,t)=>t?qh(e,t):Wh(e),Wh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new Ro(Io.MoreThanOneElement);if(0===e.length)throw new Ro(Io.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new Ro(Io.MoreThanOneElement);if(0===e.length)throw new Ro(Io.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new Ro(Io.MoreThanOneElement);if(0===e.length)throw new Ro(Io.NoElements);return await e[0]}}},qh=async(e,t)=>{const n=await xd(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new Ro(Io.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new Ro(Io.NoMatch);return s},Hh=async(e,t)=>{const n=await xd(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new Ro(Io.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new Ro(Io.NoMatch);return s},Vh=(e,t)=>t?Kh(e,t):jh(e),jh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new Ro(Io.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new Ro(Io.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new Ro(Io.MoreThanOneElement);return 0===e.length?null:await e[0]}}},Kh=async(e,t)=>{const n=await xd(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new Ro(Io.MoreThanOneElement);r=!0,s=e}return s},zh=async(e,t)=>{const n=await xd(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new Ro(Io.MoreThanOneElement);r=!0,s=e}return s},Jh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Uo({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Uo({generator:()=>n.generator().slice(t),type:1});case 2:return new Uo({generator:async()=>(await n.generator()).slice(t),type:2})}},Yh=(e,t)=>new Uo({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 s=[];for(;r<n.length;r++)s.push(n[r]);return s},type:0}),Xh=(e,t)=>new Uo({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 s=[];for(;r<n.length;r++)s.push(n[r]);return s},type:0}),Qh=(e,t)=>t?ep(e,t):Zh(e),Zh=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},ep=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},tp=async(e,t)=>{const n=ld(e,t),r=await md(n);let s=0;for(const e of r)s+=e;return s},np=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Uo({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Uo({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Uo({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},rp=(e,t)=>new Uo({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 s=n[e];if(!0!==t(s,e))break;r.push(s)}return r},type:0}),sp=(e,t)=>new Uo({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 s=n[e];if(!0!==await t(s,e))break;r.push(s)}return r},type:0}),op=async(e,t)=>{const n=new Map,r=cd(e,(e=>[t(e),e])),s=await md(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},ip=async(e,t)=>{const n=new Map,r=ld(e,(async e=>[await t(e),e])),s=await md(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},ap=async(e,t)=>{const n=e.dataFunc,r=await md(n),s={};for(const e of r)s[t(e)]=e;return s},cp=async(e,t)=>{const n=ld(e,(async e=>[await t(e),e])),r=await md(n),s={};for(const[e,t]of r)s[e]=t;return s},up=async e=>{const t=e.dataFunc,n=await md(t);return new Set(n)},lp=(e,t,n)=>n?hp(e,t,n):dp(e,t),dp=(e,t)=>new Uo({generator:async()=>{const n=new Set,r=t.toArray();for await(const t of e)!1===n.has(t)&&n.add(t);const s=await r;for(const e of s)!1===n.has(e)&&n.add(e);return[...n.keys()]},type:0}),hp=(e,t,n)=>new Uo({generator:async()=>{const r=[],s=await Promise.all([e.toArray(),t.toArray()]);for(const e of s)for(const t of e){let e=!1;for(const s of r)if(!0===n(t,s)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),pp=(e,t,n)=>new Uo({generator:async()=>{const r=[],s=await Promise.all([e.toArray(),t.toArray()]);for(const e of s)for(const t of e){let e=!1;for(const s of r)if(!0===await n(t,s)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),gp=(e,t)=>new Uo({generator:async()=>(await e.toArray()).filter(t),type:0}),fp=(e,t)=>new Uo({generator:async()=>{const n=Uh(e,(async(e,n)=>[await t(e,n),e])),r=await md(n),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0}),vp=(e,t,n)=>n?yp(e,t,n):mp(e,t),mp=(e,t)=>new Uo({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]),s=n.length<r.length?n.length:r.length,o=new Array(s);for(let e=0;e<s;e++){const t=n[e],s=r[e];o[e]=[t,s]}return o},type:0}),yp=(e,t,n)=>new Uo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=r.length<s.length?r.length:s.length,i=new Array(o);for(let e=0;e<o;e++){const t=r[e],o=s[e];i[e]=n(t,o)}return i},type:0}),wp=(e,t,n)=>new Uo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=r.length<s.length?r.length:s.length,i=new Array(o);for(let e=0;e<o;e++){const t=r[e],o=s[e];i[e]=n(t,o)}return Promise.all(i)},type:0}),Sp=e=>{var t;const n=xo.prototype,r=e.prototype,s=Object.getOwnPropertyNames(n);for(const e of s)r[e]=null!==(t=r[e])&&void 0!==t?t:n[e]};Dc(Mo),(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(Gc,"aggregate"),n(Ec,"all"),n(Ic,"allAsync"),n(Rc,"any"),n(Uc,"anyAsync"),n(Mc,"asParallel"),n(xc,"average"),n(Fc,"averageAsync"),n(Lc,"chunk"),n(Bc,"concatenate"),n($c,"contains"),n(Wc,"containsAsync"),n(qc,"count"),n(jc,"countAsync"),n(Kc,"defaultIfEmpty"),n(zc,"distinct"),n(Jc,"distinctAsync"),n(Yc,"each"),n(Xc,"eachAsync"),n(Qc,"elementAt"),n(Zc,"elementAtOrDefault"),n(eu,"except"),n(tu,"exceptAsync"),n(nu,"first"),n(ou,"firstAsync"),n(iu,"firstOrDefault"),n(uu,"firstOrDefaultAsync"),n(lu,"groupBy"),n(pu,"groupByAsync"),n(vu,"groupByWithSel"),n(wu,"groupJoin"),n(Au,"groupJoinAsync"),n(Du,"intersect"),n(Gu,"intersectAsync"),n(ku,"joinByKey"),n(bu,"last"),n(Iu,"lastAsync"),n(Ru,"lastOrDefault"),n(Uu,"lastOrDefaultAsync"),n(Mu,"max"),n(Lu,"maxAsync"),n(Bu,"min"),n(qu,"minAsync"),n(Hu,"ofType"),n(Vu,"orderBy"),n(ju,"orderByAsync"),n(Ku,"orderByDescending"),n(zu,"orderByDescendingAsync"),n(Ju,"partition"),n(Yu,"partitionAsync"),n(Xu,"reverse"),n(Qu,"select"),n(nl,"selectAsync"),n(ol,"selectMany"),n(ul,"selectManyAsync"),n(ll,"sequenceEquals"),n(dl,"sequenceEqualsAsync"),n(hl,"single"),n(fl,"singleAsync"),n(vl,"singleOrDefault"),n(wl,"singleOrDefaultAsync"),n(Sl,"skip"),n(_l,"skipWhile"),n(Tl,"skipWhileAsync"),n(kl,"sum"),n(El,"sumAsync"),n(Il,"take"),n(Rl,"takeWhile"),n(Ul,"takeWhileAsync"),n(Fl,"toArray"),n(Ll,"toMap"),n(Bl,"toMapAsync"),n($l,"toObject"),n(Wl,"toObjectAsync"),n(ql,"toSet"),n(Hl,"union"),n(Kl,"unionAsync"),n(zl,"where"),n(Xl,"whereAsync"),n(ed,"zip"),n(rd,"zipAsync")})(Oo),(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(sd,"aggregate"),n(ud,"all"),n(dd,"allAsync"),n(hd,"any"),n(fd,"anyAsync"),n(vd,"asAsync"),n(yd,"average"),n(wd,"averageAsync"),n(Sd,"chunk"),n(_d,"concatenate"),n(Ad,"contains"),n(Cd,"containsAsync"),n(Td,"count"),n(kd,"countAsync"),n(bd,"defaultIfEmpty"),n(Nd,"distinct"),n(Ed,"distinctAsync"),n(Id,"each"),n(Rd,"eachAsync"),n(Pd,"elementAt"),n(Od,"elementAtOrDefault"),n(Ud,"except"),n(Md,"exceptAsync"),n(Fd,"first"),n($d,"firstAsync"),n(Wd,"firstOrDefault"),n(Vd,"firstOrDefaultAsync"),n(jd,"groupBy"),n(Jd,"groupByAsync"),n(Qd,"groupByWithSel"),n(th,"groupJoin"),n(sh,"groupJoinAsync"),n(th,"groupJoin"),n(sh,"groupJoinAsync"),n(ah,"intersect"),n(ch,"intersectAsync"),n(uh,"joinByKey"),n(lh,"last"),n(ph,"lastAsync"),n(gh,"lastOrDefault"),n(mh,"lastOrDefaultAsync"),n(yh,"max"),n(wh,"maxAsync"),n(Sh,"min"),n(_h,"minAsync"),n(Ah,"ofType"),n(Gh,"orderBy"),n(kh,"orderByAsync"),n(bh,"orderByDescending"),n(Nh,"orderByDescendingAsync"),n(Eh,"partition"),n(Ih,"partitionAsync"),n(Rh,"reverse"),n(Oh,"select"),n(Mh,"selectAsync"),n(xh,"selectMany"),n(Fh,"selectManyAsync"),n(Lh,"sequenceEquals"),n(Bh,"sequenceEqualsAsync"),n($h,"single"),n(Hh,"singleAsync"),n(Vh,"singleOrDefault"),n(zh,"singleOrDefaultAsync"),n(Jh,"skip"),n(Yh,"skipWhile"),n(Xh,"skipWhileAsync"),n(Qh,"sum"),n(tp,"sumAsync"),n(np,"take"),n(rp,"takeWhile"),n(sp,"takeWhileAsync"),n(xd,"toArray"),n(op,"toMap"),n(ip,"toMapAsync"),n(ap,"toObject"),n(cp,"toObjectAsync"),n(up,"toSet"),n(lp,"union"),n(pp,"unionAsync"),n(gp,"where"),n(fp,"whereAsync"),n(vp,"zip"),n(wp,"zipAsync")})(Uo),(()=>{var e;const{prototype:t}=xo,n=Object.getOwnPropertyNames(Mo.prototype);for(const r of n)t[r]=null!==(e=t[r])&&void 0!==e?e:Mo.prototype[r];t.all=function(e){return this.every(e)},t.any=function(e){return e?this.some(e):0!==this.length},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Eo("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new Ro(Io.NoMatch);return t}if(0===this.length)throw new Ro(Io.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new Ro(Io.NoMatch)}if(0===this.length)throw new Ro(Io.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.max=function(e){if(0===this.length)throw new Ro(Io.NoElements);if(e){let t=Number.NEGATIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.max(e(this[n]),t);return t}return Math.max.apply(null,this)},t.min=function(e){if(0===this.length)throw new Ro(Io.NoElements);if(e){let t=Number.POSITIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.min(e(this[n]),t);return t}return Math.min.apply(null,this)},t.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var _p,Ap;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(_p||(_p={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(Ap||(Ap={}));class Cp{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Cp._devicesService&&(Cp._devicesService=Zf.Get(lo.ServiceName))}GetDevicesChannelsInGroupAsync(e=!1){return t=this,n=void 0,o=function*(){let t=[],n=[];const s=yield Cp._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){Zf.Get(r.ServiceName).Error("Old controller API fallback to old groups API.");for(let e of s)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=s.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((s=void 0)||(s=Promise))((function(e,r){function i(e){try{c(o.next(e))}catch(e){r(e)}}function a(e){try{c(o.throw(e))}catch(e){r(e)}}function c(t){var n;t.done?e(t.value):(n=t.value,n instanceof s?n:new s((function(e){e(n)}))).then(i,a)}c((o=o.apply(t,n||[])).next())}));var t,n,s,o}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 Zf.Get(Gp.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return Zf.Get(Gp.ServiceName).ChangeGroupIconNameAsync(this,e)}}var Tp,Dp=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Gp{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._objectsGroupingSupported=!1,this._connection=Zf.Get(Gt.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{Zf.Get(je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Dp(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}SetObjectsInGroupAndOrderAsync(e,t){var n;return Dp(this,void 0,void 0,(function*(){let r=[],s=[];for(let e of t)if(this.IsDevice(e)){for(let t of e.Channels)r.push(`${t.ChannelId}`);s.push(`${e.Guid}`)}else{if(!this.IsDeviceChannel(e))throw new Error("Passed object is not a device or device channel!");r.push(`${e.ChannelId}`),s.push(`${e.ChannelId}`)}const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Np(e,s),15e3,!1);switch(Zf.Get(Ge.ServiceName).ClearCache(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null==o?void 0:o.Status){case ae.OK:return new Te(_p.Success,"");case ae.NotSupportedMethod:case ae.ResourceDoesNotExists:case ae.ResourceIsNotAvailable:return new Te(_p.FunctionNotSupported,"");case ae.WrongData:return"GroupDoesNotExists"===o.Data?new Te(_p.GroupDoesNotExists,o.Data):new Te(_p.FatalError,o.Data);case ae.Error:case ae.FatalError:default:return new Te(_p.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=Zf.Get(r.ServiceName);e.forEach(((e,n)=>{t.Debug(Gp.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=Zf.Get(r.ServiceName);n.Debug(Gp.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(Gp.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){var t;return Dp(this,void 0,void 0,(function*(){const n=e.select((e=>e.Guid)).toArray(),s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new bp(n),15e3,!1);return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ae.OK?(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ae.OK):(Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to change groups order, controller responded with error ${null==s?void 0:s.Status} data: ${null==s?void 0:s.Data}`),this.LogGroupsOrder(e),null==s?void 0:s.Status)}))}ChangeObjectsPositionsInGroupAsync(e,t){var n;return Dp(this,void 0,void 0,(function*(){const s=t.select((e=>e.ChannelId)).toArray(),o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Pp(e.Guid,s),15e3,!1);return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ae.OK?(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),ae.OK):(Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to change objects positions in group, controller responded with error ${null==o?void 0:o.Status} data: ${null==o?void 0:o.Data}`),this.LogObjectsInGroupOrder(e,t),null==o?void 0:o.Status)}))}IsGroupsAndObjectsOrderingAvailable(){return this._objectsGroupingSupported}MoveGroupPositionAsync(e,t){var n;return Dp(this,void 0,void 0,(function*(){const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new kp(e.Guid,t),15e3,!1);return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ae.OK?(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ae.OK):(Zf.Get(r.ServiceName).Error(Gp.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){var s;return Dp(this,void 0,void 0,(function*(){const o=`${t.GetDevice().Guid}_${t.Number}`,i=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Rp(e.Guid,o,n),15e3,!1);return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ae.OK?(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),ae.OK):(Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to move object in group position, controller responded with error ${null==i?void 0:i.Status} data: ${null==i?void 0:i.Data}`),null==i?void 0:i.Status)}))}AddDeviceChannelToGroupByGuidAsync(e,t){var n,s;return Dp(this,void 0,void 0,(function*(){const o=new Lp;if(o.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");o.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,o.Data.GroupGuid=t;const i=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ae.OK?e.ChannelGroups.push(t):Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to add device channel ${e.Name} to group ${t}, controller responded with error ${i.Status} data: ${i.Data}`),Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ae.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){var n,s;return Dp(this,void 0,void 0,(function*(){const o=new Bp;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");o.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,o.Data.Channel=e.Number,o.Data.GroupGuid=t;const i=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ae.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to remove device channel ${e.Name} from group ${t}, controller responded with error ${i.Status} data: ${i.Data}`),Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ae.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Dp(this,void 0,void 0,(function*(){if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupWithIconAsync(e.Name,e.IconName);if(!(t instanceof Cp))return t instanceof Te?t:new Te(Ap.UnknownError,"");e=t}for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(n,e);if(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),t!==ae.OK)return Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`),new Te(Ap.UnknownError,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`)}let n=yield Zf.Get(lo.ServiceName).GetDevicesAsync();for(let o of n)for(let n of o.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var s of n.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(n,e);if(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ae.OK)return Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),new Te(Ap.UnknownError,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`)}return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Dp(this,void 0,void 0,(function*(){for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(n,e);if(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ae.OK)return Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),ae.FatalError}let n=yield Zf.Get(lo.ServiceName).GetDevicesAsync();for(let o of n)for(let n of o.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var s of n.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(n,e);if(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),t!==ae.OK)return Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),ae.FatalError}return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),ae.OK}))}ChangeGroupNameByGuidAsync(e,t){var n,r;return Dp(this,void 0,void 0,(function*(){let s=new Fp,o=new $p,i=this._groups.first((t=>t.Guid===e));o.Guid=e,o.Name=t,o.IconName=i.IconName,null===(n=s.Data)||void 0===n||n.push(o);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(s,15e3,!1);if(Zf.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return new Te(Ap.Success,"");case ae.WrongData:switch(a.Data){case"NameToShort":return new Te(Ap.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Ap.NameAlreadyExists,"Group with this name already exists");default:return new Te(Ap.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(Ap.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(Ap.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){var r,s;return Dp(this,void 0,void 0,(function*(){let o=new Fp,i=new $p,a=this._groups.first((t=>t.Guid===e));i.Guid=e,i.Name=t,i.IconName=n,i.ObjectsOrder=a.ObjectsOrder,null===(r=o.Data)||void 0===r||r.push(i);const c=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);if(Zf.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=c&&null!=c.Status)switch(c.Status){case ae.OK:return new Te(Ap.Success,"");case ae.WrongData:switch(c.Data){case"NameToShort":return new Te(Ap.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Ap.NameAlreadyExists,"Group with this name already exists");default:return new Te(Ap.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Te(Ap.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Te(Ap.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){var n,r;return Dp(this,void 0,void 0,(function*(){let s=new Fp,o=new $p,i=this._groups.first((t=>t.Guid===e));o.Guid=e,o.Name=i.Name,o.IconName=t,null===(n=s.Data)||void 0===n||n.push(o);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(s,15e3,!1);if(Zf.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return new Te(Ap.Success,"");case ae.WrongData:switch(a.Data){case"NameToShort":return new Te(Ap.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Ap.NameAlreadyExists,"Group with this name already exists");default:return new Te(Ap.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(Ap.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(Ap.UnknownError,"")}))}GetServiceName(){return Gp.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){var t;return Dp(this,void 0,void 0,(function*(){let n=new Mp;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync();for(let t of yield Zf.Get(lo.ServiceName).GetDevicesAsync())for(let n of t.Channels)n.ChannelGroups.any((t=>t===e))&&(n.ChannelGroups=n.ChannelGroups.except(e,((e,t)=>e===t)).toArray());return Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=r&&null!=r.Status?null==r?void 0:r.Status:ae.Error}))}GetGroupsAsync(e=!1){var t,n;return Dp(this,void 0,void 0,(function*(){const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new xp,15e3,e);let o=[];if((null==s?void 0:s.Status)===ae.OK){let e=Zf.Get(r.ServiceName),t=0,i=yield Zf.Get(lo.ServiceName).GetDevicesAsync();return null===(n=s.Data)||void 0===n||n.forEach((n=>{t++;let r=new Cp;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.Info(Gp.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),o.push(r)})),this._groups=o,o}throw new Error(`Failed to get groups, API responded with status ${null==s?void 0:s.Status} data: ${null==s?void 0:s.Data}`)}))}AddDeviceChannelToGroupAsync(e,t){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid)}RemoveDeviceChannelFromGroupAsync(e,t){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid)}AddNewGroupAsync(e){var t,n;return Dp(this,void 0,void 0,(function*(){let s=new Fp,o=new $p;o.Name=e,null===(t=s.Data)||void 0===t||t.push(o);const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(s,15e3,!1);if(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status)switch(i.Status){case ae.OK:return this._groups.first((t=>t.Name===e));case ae.WrongData:switch(Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new Te(Ap.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Ap.NameAlreadyExists,"Group with this name already exists");default:return new Te(Ap.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Te(Ap.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Te(Ap.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){var n,s;return Dp(this,void 0,void 0,(function*(){let o=new Fp,i=new $p;i.Name=e,i.IconName=t,null===(n=o.Data)||void 0===n||n.push(i);const a=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);if(Zf.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield Zf.Get(lo.ServiceName).GetDevicesAsync(),Zf.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return this._groups.first((t=>t.Name===e));case ae.WrongData:switch(Zf.Get(r.ServiceName).Error(Gp.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new Te(Ap.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Ap.NameAlreadyExists,"Group with this name already exists");default:return new Te(Ap.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(Ap.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(Ap.UnknownError,"")}))}}Gp.ServiceName="ChannelsGroupsService";class kp extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ce.Post,this.Data=new Ip,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class bp extends ie{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ce.Post,this.Data=e}}class Np extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=ce.Post,this.Data=new Ep,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Ep{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Ip{constructor(){this.GroupGuid="",this.NewPosition=0}}class Rp extends ie{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ce.Post,this.Data=new Op,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Pp extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ce.Post,this.Data=new Up,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class Op{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Up{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Mp extends ie{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ce.Delete}}class xp extends ie{constructor(){super(),this.Resource="/devices/groups/",this.Method=ce.Get}}class Fp extends ie{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ce.Put,this.Data=[]}}class Lp extends ie{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ce.Put,this.Data=new Wp}}class Bp extends ie{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ce.Delete,this.Data=new Wp}}class $p{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class Wp{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class qp{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"}(Tp||(Tp={}));var Hp=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Vp{constructor(){this._syncLock=new qp,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=Tp.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new Ae,this._onSuspendedEvent=new Ae,this._onEnterLowPowerModeEvent=new Ae,this._onExitLowPowerModeEvent=new Ae,this._onBackButtonPressedEvent=new Ae,this._onForwardButtonPressedEvent=new Ae,this._onAppStateChanged=new n,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>Hp(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=s.Log)||void 0===t||t.Warning(Vp.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=s.Log)||void 0===r||r.Warning(Vp.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return Hp(this,void 0,void 0,(function*(){this._session=yield Zf.GetAsync("SessionService"),this._connection=yield Zf.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(Vp.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(Tp.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(Vp.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(Tp.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,o,i,a;switch(e){case de.Connected:null===(t=s.Log)||void 0===t||t.Warning(Vp.ServiceName,"App state changed to: connected"),this._onAppStateChanged.Invoke(Tp.Connected);break;case de.Disconnected:null===(n=s.Log)||void 0===n||n.Warning(Vp.ServiceName,"App state changed to: disconnected"),this._onAppStateChanged.Invoke(Tp.Disconnected);break;case de.Connecting:null===(r=s.Log)||void 0===r||r.Warning(Vp.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(Tp.Connecting);break;case de.Disconnecting:null===(o=s.Log)||void 0===o||o.Warning(Vp.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(Tp.Disconnecting);break;case de.Reconnecting:null===(i=s.Log)||void 0===i||i.Warning(Vp.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(Tp.Reconnecting);break;case de.Failed:null===(a=s.Log)||void 0===a||a.Warning(Vp.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(Tp.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(Tp.Suspended),null===(e=s.Log)||void 0===e||e.Warning(Vp.ServiceName,"App state changed to: suspended"),null===(t=s.Log)||void 0===t||t.Warning(Vp.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(Tp.ReturnedFromSuspension),null===(e=s.Log)||void 0===e||e.Warning(Vp.ServiceName,"App state changed to: returned from suspension"),null===(t=s.Log)||void 0===t||t.Warning(Vp.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Tp.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Tp.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 Vp.ServiceName}}Vp.ServiceName="AppStateService";class jp{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 Kp,zp,Jp=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Yp{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new jp(1)}GetServiceName(){return Yp.ServiceName}GetExtensionsInfoAsync(e,t=!1){return Jp(this,void 0,void 0,(function*(){Zf.Get(r.ServiceName).Debug(Yp.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);var n=yield this._semaphore.AcquireAsync();if(this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync()),n.Release(),0==[...this._extensionInfoCache.values()].length)return[];if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new Zp("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e,t=!1,n=!1){return Jp(this,void 0,void 0,(function*(){if(Zf.Get(r.ServiceName).Debug(Yp.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 Zp("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 Zp("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return Jp(this,void 0,void 0,(function*(){const e=new Xp,t=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new Zp("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ae.OK)throw new Zp(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new Zp("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 Jp(this,void 0,void 0,(function*(){const e=new Qp,t=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new Zp("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(t.Status){case ae.OK:if(null==t.Data)throw new Zp("Cannot get ProtocolInfo from controller, controller response does not contain data!");t.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ae.ResourceDoesNotExists:Zf.Get(r.ServiceName).Debug(Yp.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new Zp(`Cannot get ProtocolInfo from controller! Response status: ${t.Status}`)}}))}}Yp.ServiceName="StatisticsInfoService";class Xp extends ie{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ce.Get}}class Qp extends ie{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ce.Get}}class Zp extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Kp||(Kp={}));class eg{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=zp.Unknown,this.ResourceGuid=""}}class tg{constructor(){this.UpdateDescription=new Map,this.Update=new eg,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"}(zp||(zp={}));class ng extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var rg,sg,og,ig,ag,cg,ug,lg,dg,hg,pg=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 gg{constructor(){this._services=new Map,this._runtimeInfo=new fg,this._hardwareInfo=new mg,this._semaphore=new jp(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return gg.ServiceName}RegisterUpdatesProvider(e){Zf.Get(r.ServiceName).Debug(gg.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return pg(this,void 0,void 0,(function*(){Zf.Get(r.ServiceName).Debug(gg.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const t=this._services.get(e);if(null==t)throw new ng("Cannot get update provider! Requested update provider has not been registered.");return t}))}GetUpdatesProvidersAsync(e){return pg(this,void 0,void 0,(function*(){Zf.Get(r.ServiceName).Debug(gg.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let t=[];if(t=[...this._services.values()].filter((t=>t.ProviderType==e)),0==t.length)throw new ng("Cannot get update providers! Requested update providers has not been registered.");return t}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return pg(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){Zf.Get(r.ServiceName).Debug(gg.ServiceName,`Getting update providers with protocol guid: [${e}] by GetUpdateProvidersByProtocolAsync<T>()`);let s=[];if(s=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==s.length)throw new ng("Cannot get update providers! Requested update providers has not been registered.");return s}throw new ng("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return pg(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){Zf.Get(r.ServiceName).Debug(gg.ServiceName,`Getting update providers with extension guid: [${e}] by GetUpdateProvidersByExtensionAsync<T>()`);let s=[];if(s=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==s.length)throw new ng("Cannot get update providers! Requested update providers has not been registered.");return s}throw new ng("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(e=!1){return pg(this,void 0,void 0,(function*(){var t=yield this._semaphore.AcquireAsync();return!this._isRuntimeInfoInitialized||e?(yield this.GetRuntimeControllerInfoAsync(),t.Release(),this._runtimeInfo):(t.Release(),this._runtimeInfo)}))}GetRuntimeControllerInfoAsync(){return pg(this,void 0,void 0,(function*(){Zf.Get(r.ServiceName).Debug(gg.ServiceName,"Getting runtime version info from controller.");try{const e=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new vg,16e3,!1);if(null==e||null==e.Status)throw new wg('Cannot get runtime info, controller response result is empty."',rg.EmptyResponse);if(e.Status!=ae.OK)throw new wg(`Cannot get runtime info, controller responded with status ${e.Status}.`,rg.WrongResponseStatus);if(null==e.Data)throw new wg("Cannot get runtime info, controller responded with status OK but response does not contains data.",rg.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof p?new wg("Cannot get runtime info, controller response timeout.",rg.Timeout):e}}))}GetHardwareInfoAsync(e=!1){return pg(this,void 0,void 0,(function*(){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return pg(this,void 0,void 0,(function*(){Zf.Get(r.ServiceName).Debug(gg.ServiceName,"Getting hardware info from controller.");const e=yield Zf.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new yg,8e3,!1);if(null==e||null==e.Status)throw new wg('Cannot get hardware info, controller response result is empty."',rg.EmptyResponse);if(e.Status!=ae.OK)throw new wg(`Cannot get hardware info, controller responded with status ${e.Status}.`,rg.WrongResponseStatus);if(null==e.Data)throw new wg("Cannot get hardware info, controller responded with status OK but response does not contains data.",rg.NoDataInResponse);this._hardwareInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}}gg.ServiceName="UpdateProvider";class fg{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class vg extends ie{constructor(){super(),this.Resource="/controller/software/info",this.Method=ce.Get}}class mg{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class yg extends ie{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ce.Get}}class wg 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"}(rg||(rg={}));class Sg{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class _g{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class Ag{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(sg||(sg={})),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"}(og||(og={})),(hg=ig||(ig={}))[hg.WaitingForUser=1]="WaitingForUser",hg[hg.Downloading=2]="Downloading",hg[hg.Unpackaging=3]="Unpackaging",hg[hg.CheckingApplicability=4]="CheckingApplicability",hg[hg.MigratingData=5]="MigratingData",hg[hg.CreatingBackup=6]="CreatingBackup",hg[hg.Deploying=7]="Deploying",hg[hg.Installing=8]="Installing",hg[hg.Removing=9]="Removing",hg[hg.Error=10]="Error",hg[hg.ReadyToDownload=11]="ReadyToDownload",hg[hg.PreparingSystem=12]="PreparingSystem",hg[hg.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",hg[hg.CheckingIntegrity=14]="CheckingIntegrity",hg[hg.UndoingInstallation=15]="UndoingInstallation",hg[hg.Installed=16]="Installed",(dg=ag||(ag={}))[dg.Ignore=0]="Ignore",dg[dg.Cancel=1]="Cancel",dg[dg.Install=2]="Install";class Cg{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=og.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class Tg{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=cg.Unknown}}!function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate"}(cg||(cg={})),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"}(ug||(ug={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(lg||(lg={}));var Dg,Gg,kg,bg,Ng,Eg,Ig,Rg,Pg=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5.56,this._updateOfflineStageTime=8.5,this._updateProviders=Zf.Get(gg.ServiceName),this._logger=Zf.Get(r.ServiceName),this._connection=Zf.Get(Gt.ServiceName),this._appStateService=Zf.Get(Vp.ServiceName),this._extensionService=Zf.Get(Yp.ServiceName)}GetAutomaticControllerUpdateDownloadStatusAsync(){return Pg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(ug.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let t=yield this._connection.SendAndWaitForResponseAsync(new zg,1e4,!1);return!(t.Status!=ae.OK||!t.Data)}))}GetServiceName(){return Og.ServiceName}CheckDeviceVersionAsync(e){var t;return Pg(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield Zf.Get(lo.ServiceName).GetDevice(e);if(null==t)return new Te(ug.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Te(ug.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Kp.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){var t;return Pg(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield Zf.Get(lo.ServiceName).GetDevice(e);if(null==t)return new Te(ug.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Te(ug.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Kp.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const s=new xg;s.CurrentResourceVersion=r.CurrentResourceVersion,s.NewResourceVersion=r.Update.Version,s.UpdatedResourceName=r.UpdatedResourceName,s.UpdateResourceGuid=r.Update.ResourceGuid,s.UpdateDescription=new Map([["pl-PL",r.Update.Description]]);let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(n.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}return s.Protocol=o,s.ProtocolGuid=n.ProtocolGuid,(yield Zf.Get(lo.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(s.IsUpdateSafe=!1),s}))}InstallDeviceUpdateAsync(e,t,n,r=!1){var s;return Pg(this,void 0,void 0,(function*(){let o;if("string"==typeof e){const t=yield Zf.Get(lo.ServiceName).GetDevice(e);if(null==t)return new Te(ug.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);o=t}else o=e;if(null==o.ProtocolGuid)return new Te(ug.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(s=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,Kp.Device)).first())||void 0===s?void 0:s.GetAvailableUpdateAsync(o);if(null!=i.Type)return i;this._appStateService.DisallowHibernation();const a=yield(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,Kp.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ae.OK)}))}CheckControllerUpdatesAsync(){return Pg(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new Sg,n=yield this.getRuntimeInfoAsync();if(n instanceof Te){const e=new Ug;return e.UpdateType=sg.SoftwareUpdate,e.ResponseResult=n,t.UpdatesNotAvailable.push(e),t}const r=parseFloat(n.SoftwareVersion);try{e=yield this._updateProviders.GetUpdatesProvidersAsync(Kp.Controller)}catch(e){if(!(e instanceof ng))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 s=new Ug;s.ResponseResult=r,s.UpdateType=sg.RadioUpdate;let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(e[n].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}s.UpdatedResourceName=new Map([["pl-PL",o],["en-US",o]]),s.CurrentResourceVersion=yield e[n].GetCurrentRadioVersionAsync(),t.UpdatesNotAvailable.push(s)}else{const s=r,o=new Mg;o.UpdatedResourceName=new Map([["pl-PL",s.UpdatedResourceName],["en-US",s.UpdatedResourceName]]),o.CurrentResourceVersion=s.CurrentResourceVersion,o.NewResourceVersion=s.Update.Version,o.UpdateDescription=new Map([["pl-PL",s.Update.Description]]),o.UpdateType=sg.RadioUpdate,o.UpdateIdentifier=re.GenerateUUID(),o.UpdateIsDownloading=!1,o.DownloadProgress=100,o.UpdateCreationTime=null,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:e[n].GetUpdateProviderName(),UpdateType:sg.RadioUpdate}))}}if(r>this._oldUpdateVersion){const e=yield this._connection.SendAndWaitForResponseAsync(new Hg,1e4,!1);if(null==e||e.Status!=ae.OK&&e.Status!=ae.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 tg;r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,r.UpdateDescription=oe(e.Data.Update.UpdateDescription),r.UpdatedResourceName=oe(e.Data.Update.UpdateName).get("en-US");const s=new Mg;s.UpdatedResourceName=oe(e.Data.Update.UpdateName),s.UpdateDescription=oe(e.Data.Update.UpdateDescription),s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.NewResourceVersion=`${e.Data.Update.Version.BaseRuntime}.${e.Data.Update.Version.ContainerSoftwareVersion}`,s.UpdateType=sg.SoftwareUpdate,s.UpdateIdentifier=e.Data.Update.Guid,s.UpdateIsDownloading=e.Data.UpdateStep==bg.DownloadingInstaller||e.Data.UpdateStep==bg.DownloadingUpdate||e.Data.UpdateStep==bg.CheckingUpdate,s.DownloadProgress=e.Data.DownloadProgress,s.UpdateCreationTime=e.Data.Update.Creationtime,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:Og.ServiceName,UpdateType:sg.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Vg,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ae.NoData:const r=new Ug;r.UpdateType=sg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Te(ug.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ae.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const s=new tg;s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateDescription=oe(e.Data.UpdateDescription),s.UpdatedResourceName=oe(e.Data.UpdateName).get("en-US");const o=new Mg;o.UpdatedResourceName=oe(e.Data.UpdateName),o.UpdateDescription=oe(e.Data.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateType=sg.SoftwareUpdate,o.UpdateIdentifier=e.Data.Guid,o.NewResourceVersion=`${e.Data.Version.BaseRuntime}.${e.Data.Version.ContainerSoftwareVersion}`,o.UpdateIsDownloading=!1,o.DownloadProgress=0,o.UpdateCreationTime=e.Data.Creationtime,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:Og.ServiceName,UpdateType:sg.SoftwareUpdate}));break;default:throw new Error(`Cannot check updates! Response status is not OK. Status: ${e.Status}`)}}}else{const e=`https://updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const r=yield fetch(e);let s,o=new tg;const i=new Ug;switch(i.UpdateType=sg.SoftwareUpdate,i.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.status){case 200:null!=r.body&&(s=yield r.json());break;case 404:i.ResponseResult=new Te(ug.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Te(ug.CannotGetUpdates,`Response status code does not indicate success. Status: ${r.status}`),t.UpdatesNotAvailable.push(i)}if(null!=s){o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.Update=s;const e=new Mg;e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.CurrentResourceVersion=o.CurrentResourceVersion,e.NewResourceVersion=o.Update.Version,e.UpdateDescription=new Map([["pl-PL",o.Update.Description]]),e.UpdateType=sg.SoftwareUpdate,e.UpdateIdentifier=re.GenerateUUID(),e.DownloadProgress=100,e.UpdateIsDownloading=!1,e.UpdateCreationTime=null,t.UpdatesAvailable.push(e),this._controllerUpdates.push(Object.assign(Object.assign({},o),{UpdateIdentifier:e.UpdateIdentifier,ProviderName:Og.ServiceName,UpdateType:sg.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 Te){const e=new Ug;e.UpdateType=sg.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new Ug;r.UpdateType=sg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Te(ug.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return Pg(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Kp.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Te)return t;const n=[];let r;r=new Ag,r.Resource="Controller software",r.Type=sg.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new Ag,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=sg.RadioUpdate;let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(e[t].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}r.Resource=s,n.push(r)}return n}))}GetControllerUpdateBranchAsync(){return Pg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(ug.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new Wg,1e4,!1);if(null==t||(null==t?void 0:t.Status)!=ae.OK)return new Te(ug.CannotGetUpdatesBranch,`Cannot get update branch, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`);switch(t.Data){case 0:return lg.Public;case 1:return lg.Beta;case 2:return lg.Development;default:return new Te(ug.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${t.Data}`)}}))}SetControllerUpdateBranchAsync(e){return Pg(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Te)return t;if(parseFloat(t.SoftwareVersion)<=this._oldUpdateVersion)return new Te(ug.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const n=yield this._connection.SendAndWaitForResponseAsync(new qg(e),1e4,!1);return null==n||(null==n?void 0:n.Status)!=ae.OK?new Te(ug.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==n?void 0:n.Status}`):ae.OK}))}EnableAutomaticControllerUpdateDonwloadAsync(){return Pg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(ug.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new Jg,1e4,!1);return null==t||(null==t?void 0:t.Status)!=ae.OK?new Te(ug.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`):ae.OK}))}DisableAutomaticControllerUpdateDonwloadAsync(){return Pg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(ug.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new Yg,1e4,!1);return null==t||(null==t?void 0:t.Status)!=ae.OK?new Te(ug.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`):ae.OK}))}GetControllerUpdatesHistoryAsync(){return Pg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(ug.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new Xg,1e4,!1);if(null==t)return new Te(ug.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(t.Status){case ae.OK:return null!=t.Data?t.Data.map((e=>{const t=new _g;return t.UpdatedResourceName=oe(e.UpdateName),t.UpdateDescription=oe(e.UpdateDescription),t.UpdateCreationTime=e.Creationtime,t.UpdateChannel=e.UpdateChannel,t.Version=`${e.Version.BaseRuntime}.${e.Version.ContainerSoftwareVersion}`,t})):new Te(ug.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ae.NoData:return[];default:return new Te(ug.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${t.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,s){return Pg(this,void 0,void 0,(function*(){const o=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),i=this._controllerUpdates.length,a=yield this.getRuntimeInfoAsync();if(a instanceof Te)return a;const c=parseFloat(a.SoftwareVersion);if(0==this._controllerUpdates.length)return new Te(ug.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if("string"!=typeof n||!o.test(n)){const s=[1],o=t=>{t.UpdateNumber=s[0],t.AvailableUpdates=i,e(t)},a=e=>Pg(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let u=this._controllerUpdates.where((e=>e.UpdateType==sg.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],o,n);yield a(5e3),t==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=u[e].UpdateIdentifier))),l.push(t),s[0]++}const d=this._controllerUpdates.find((e=>e.UpdateType==sg.SoftwareUpdate));if(null!=d)if(c<=this._oldUpdateVersion){const e=yield this.UpdateControllerUsingScriptAsync(d.Update,o);e==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=d.UpdateIdentifier))),l.push(e),s[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(o,t,r);this._appStateService.AllowHibernation(),e==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),l.push(e),s[0]++}const h=l.where((e=>e instanceof Te)).toArray();if(null!=h&&0!=h.length){let e="";return h.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),new Te(ug.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ae.OK}{let o;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Te(ug.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 sg.RadioUpdate:return r?new Te(ug.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it."):(o=yield(yield this._updateProviders.GetUpdatesProviderAsync(i.ProviderName)).InstallRadioUpdateAsync(i,e,s),this._appStateService.AllowHibernation(),o==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),o);case sg.SoftwareUpdate:if(c<=this._oldUpdateVersion){if(r)return new Te(ug.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");o=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),o==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else o=yield this.UpdateControllerUsingApiAsync(e,t,r),this._appStateService.AllowHibernation(),o==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)));return o;default:return new Te(ug.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){var n,r,s,o,i,a;return Pg(this,void 0,void 0,(function*(){switch(e.UpdateType){case zp.Container:case zp.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Fg(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new Cg;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ae.MultiDataResponseStart:r.Status=og.PreparingForUpgrade;break;case ae.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(Og.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case ig.CheckingApplicability:case ig.CheckingIntegrity:case ig.CheckingPackageIntegrity:r.Status=og.CheckingPackage;break;case ig.CreatingBackup:case ig.MigratingData:case ig.Removing:r.Status=og.MovingData;break;case ig.Deploying:case ig.Installing:r.Status=og.Upgrading;break;case ig.Downloading:r.Status=og.DownloadingPackage;break;case ig.Error:r.Status=og.Error;break;case ig.Installed:r.Status=og.Upgraded;break;case ig.PreparingSystem:case ig.ReadyToDownload:r.Status=og.PreparingForUpgrade;break;case ig.UndoingInstallation:r.Status=og.InstallationStopped;break;case ig.Unpackaging:r.Status=og.MovingData;break;case ig.WaitingForUser:r.Status=og.Upgrading}break;case ae.MultiDataResponseStop:r.Status=og.OK}t(r)}),!1),ae.OK}catch(e){return new Te(ug.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case zp.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 Te)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield Zf.Get(lo.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(Og.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new Cg;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=og.PreparingForUpgrade,t(r);let s=2;const o=Date.now(),i=900*c+8e5,a=i/100,u=o+i,l=new Promise(((o,c)=>Pg(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=og.Upgraded,t(r),o(ae.OK);else{var e=u-Date.now();e<i?s=95-e/a:(clearInterval(n),n=setInterval((()=>{clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=og.Upgraded,t(r),o(ae.OK)}),e))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),n=setInterval((()=>{if(s>99)clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=og.Upgraded,t(r),o(ae.OK);else{var e=s;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=og.Upgrading,t(r))}s++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Lg(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ae.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=og.InstallationError,t(r),this._logger.Debug(Og.ServiceName,`Update failed with error. Update response status: ${d.Status}`),o(new Te(ug.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(Og.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=og.Error,t(r),clearInterval(n),o(new Te(ug.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new Cg;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Te(ug.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Bg({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ae.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.PreparingForUpgrade,t(n);let r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new $g("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ae.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.PreparingForUpgrade,t(n),r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new $g(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ae.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new $g("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ae.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.Upgrading,t(n);let e,r=0;const s=.95,o=Date.now(),i=900*c+15e5,a=i/95,u=o+i,l=new Promise(((o,c)=>Pg(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=og.Upgraded,t(n),o(ae.OK);else{var s=u-Date.now();s<i?r=95-s/a:(clearInterval(e),e=setInterval((()=>{clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.Upgraded,t(n),o(ae.OK)}),s))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),e=setInterval((()=>{if(r>99)clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.Upgraded,t(n),o(ae.OK);else{var i=5+r*s;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=og.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new $g("/runtime/tmp/update.sh"),12e3,!1)}catch(e){o(new Te(ug.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=og.InstallationError,t(n),new Te(ug.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new $g("/runtime/scripts/restart_all.sh"),12e3,!1),new Te(ug.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Te(ug.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Te(ug.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Te(ug.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}UpdateControllerUsingApiAsync(e,t,n){return Pg(this,void 0,void 0,(function*(){const r=e=>Pg(this,void 0,void 0,(function*(){return new Promise(((r,s)=>Pg(this,void 0,void 0,(function*(){yield this._connection.SendAndHandleResponseAsync(new jg,this._updateRequestTimeout,(s=>{var o,i,a,c;const u=new Tg;switch(u.UpdatedResourceName=oe(e.Update.UpdateName),s.Status){case ae.MultiDataResponseStart:u.Percentage=0,u.SpeedMbps=0,u.PercentageTotal=0,u.CurrentTask=cg.DownloadingInstaller,t(u);break;case ae.MultiDataResponse:if(null!=s.Data){switch(u.Percentage=s.Data.StepProgressInPercentage,u.SpeedMbps=s.Data.DownloadSpeedInMbs,u.PercentageTotal=n?Math.round(2*(null===(o=s.Data)||void 0===o?void 0:o.UpdateProgressInPercentage)):Math.round(null===(i=s.Data)||void 0===i?void 0:i.UpdateProgressInPercentage),s.Data.UpdateStep){case bg.DownloadingInstaller:u.CurrentTask=cg.DownloadingInstaller;break;case bg.DownloadingUpdate:u.CurrentTask=cg.DownloadingUpdate;break;default:u.CurrentTask=cg.CheckingUpdate}t(u)}break;case ae.MultiDataResponseStop:if(null!=s.Data)switch(s.Data.UpdateStep){case bg.UpdateDownloaded:u.Percentage=100,u.PercentageTotal=n?Math.round(2*(null===(a=s.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)):Math.round(null===(c=s.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),u.SpeedMbps=0,u.CurrentTask=cg.CheckingUpdate,t(u),r(ae.OK);break;case bg.UpdateDownloadFailed:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=cg.Unknown,t(u),r(new Te(ug.UpdateDownloadFailed,"Update download failed!"))}}}),!1)}))))})),s=t=>Pg(this,void 0,void 0,(function*(){return new Promise(((n,r)=>Pg(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let s=0;yield this._connection.SendAndHandleResponseAsync(new Kg,this._updateRequestTimeout,(o=>{var i,a;const c=new Cg;switch(c.UpdatedResourceName=oe(t.Update.UpdateName),o.Status){case ae.MultiDataResponseStart:c.Status=og.PreparingForUpgrade,c.Percentage=null===(i=o.Data)||void 0===i?void 0:i.StepProgressInPercentage,c.PercentageTotal=null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage,e(c);break;case ae.MultiDataResponse:null!=o.Data&&(c.Status=og.Upgrading,c.Percentage=Math.round(o.Data.StepProgressInPercentage),c.PercentageTotal=Math.round(o.Data.UpdateProgressInPercentage),s=o.Data.StepProgressInPercentage,e(c));break;case ae.MultiDataResponseStop:if(null!=o.Data)switch(o.Data.UpdateStep){case bg.UpdateInstallationFailed:c.Status=og.InstallationError,c.Percentage=0,c.PercentageTotal=0,e(c),n(new Te(ug.CannotProcessUpdate,"Update installation failed!"));break;case bg.OfflineUpdateStep:{c.Percentage=Math.round(o.Data.StepProgressInPercentage),c.PercentageTotal=Math.round(o.Data.UpdateProgressInPercentage);let t=(100-c.PercentageTotal)/100,i=c.PercentageTotal;const a=setInterval((()=>{s++,i+=t,i>100&&(i=100),s>=100?(c.Status=og.Upgraded,c.Percentage=100,c.PercentageTotal=100,e(c),clearInterval(a),n(ae.OK)):(c.Status=og.Upgrading,c.Percentage=Math.round(s),c.PercentageTotal=Math.round(i),e(c))}),r/(100-s))}}}}),!1)}))))}));if(n){const e=yield this._connection.SendAndWaitForResponseAsync(new Hg,1e4,!1);if(null==e||(null==e?void 0:e.Status)!=ae.OK||null==(null==e?void 0:e.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);switch(e.Data.UpdateStep){case bg.DownloadingInstaller:case bg.DownloadingUpdate:case bg.UpdateDownloaded:return new Te(ug.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case bg.InstallingUpdate:case bg.PreparingUpdate:return new Te(ug.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield r(e.Data)}}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Hg,1e4,!1);if(null==e||(null==e?void 0:e.Status)!=ae.OK||null==(null==e?void 0:e.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);switch(e.Data.UpdateStep){case bg.DownloadingInstaller:case bg.DownloadingUpdate:return new Te(ug.UpdateAlreadyDownloaded,"Update already downloaded, or donwload in progress.");case bg.InstallingUpdate:case bg.PreparingUpdate:return new Te(ug.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case bg.UpdateDownloaded:return yield s(e.Data);default:var o=yield r(e.Data);return o!=ae.OK?o:yield s(e.Data)}}}))}getRuntimeInfoAsync(){return Pg(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof wg&&e.code==rg.Timeout?new Te(ug.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Te(ug.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}Og.ServiceName="UpdatesService";class Ug{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class Mg{constructor(){this._updateIdentifier="",this._updateResourceName=new Map,this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map,this._updateIsDownloading=!1,this._updateCheckDownloadProgress=0,this._updateCreationTime=null}get UpdateCreationTime(){return this._updateCreationTime}get DownloadProgress(){return this._updateCheckDownloadProgress}get UpdateDescription(){return this._updateDescription}get UpdateIdentifier(){return this._updateIdentifier}get UpdatedResourceName(){return this._updateResourceName}get UpdateType(){return this._updateType}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}get UpdateIsDownloading(){return this._updateIsDownloading}set UpdateCreationTime(e){this._updateCreationTime=e}set DownloadProgress(e){this._updateCheckDownloadProgress=e}set UpdateDescription(e){this._updateDescription=e}set UpdateIdentifier(e){this._updateIdentifier=e}set UpdatedResourceName(e){this._updateResourceName=e}set UpdateType(e){this._updateType=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}set UpdateIsDownloading(e){this._updateIsDownloading=e}}class xg{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 Fg extends ie{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=ce.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"}(Dg||(Dg={})),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"}(Gg||(Gg={})),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"}(kg||(kg={})),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"}(bg||(bg={}));class Lg extends ie{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ce.Put,this.Data=e}}class Bg extends ie{constructor(e){super(),this.Resource="/users/user/login",this.Method=ce.Put,this.Data=e}}class $g extends ie{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ce.Post,this.Data=e}}class Wg extends ie{constructor(){super(),this.Resource="/updates/branch",this.Method=ce.Get}}class qg extends ie{constructor(e){super(),this.Resource="/updates/branch",this.Method=ce.Put,this.Data=e}}class Hg extends ie{constructor(){super(),this.Resource="/updates/pending",this.Method=ce.Get}}class Vg extends ie{constructor(){super(),this.Resource="/updates/check",this.Method=ce.Get}}class jg extends ie{constructor(){super(),this.Resource="/updates/download",this.Method=ce.Post}}class Kg extends ie{constructor(){super(),this.Resource="/updates/install",this.Method=ce.Post}}class zg extends ie{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=ce.Get}}class Jg extends ie{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=ce.Put}}class Yg extends ie{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=ce.Put}}class Xg extends ie{constructor(){super(),this.Resource="/updates/history",this.Method=ce.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"}(Ng||(Ng={})),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"}(Eg||(Eg={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(Ig||(Ig={}));class Qg{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"}(Rg||(Rg={}));var Zg,ef,tf,nf,rf,sf,of,af=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 cf{constructor(){this._connection=null,this._connection=Zf.Get(Gt.ServiceName)}GetServiceName(){return cf.ServiceName}GetStatesByIntervalAsync(e,t,n,r,s,o,i=!1){var a;return af(this,void 0,void 0,(function*(){try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Te(Ng.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 Zf.Get(lo.ServiceName).GetDevice(e);if(null==t)return new Te(Ng.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new Te(Ng.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 Te(Ng.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new lf;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.Range=r,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=s,u.Offset=o;const l=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new uf(u),2e4,!1);if(null==l)return new Te(Ng.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case ae.WrongData:switch(l.Data){case"IncorrectLimitValue":return new Te(Ng.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Te(Ng.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Te(Ng.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Te(Ng.OtherError,"Cannot get state history data - unknown error!")}case ae.FatalError:return new Te(Ng.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ae.ResourceDoesNotExists:return new Te(Ng.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ae.OK:if(null==l.Data)return new Te(Ng.NoData,"Controller responede with status OK, but response does not contain data!");if(l.Data.AggregateDataList=l.Data.AggregateDataList.map((e=>(e.AggregateData=oe(e.AggregateData),e))),n===ht.MeasuredEnergy){const e=l.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=oe(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=oe(e.Values.MeasurementNonAveragingParmeters),t}));return l.Data.Data=e,l.Data}return l.Data;default:return new Te(Ng.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new Te(Ng.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){var e;return af(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new df,12e3,!1);return null==t?new Te(Ng.OtherError,"Cannot get available states - response is null."):t.Status!=ae.OK?new Te(Ng.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Te(Ng.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Qg;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Te(Ng.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return af(this,void 0,void 0,(function*(){return!(parseFloat((yield Zf.Get(gg.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}GetAvailableStatesPerChannelAsync(e,t){var n;return af(this,void 0,void 0,(function*(){let r;if("string"==typeof e){const t=yield Zf.Get(lo.ServiceName).GetDevice(e);if(null==t)return new Te(Ng.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);r=t}else r=e;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new hf(new pf(r.Guid,t)),8e3,!1);if(null==s)return new Te(Ng.OtherError,"Cannot get available states - response is null.");switch(s.Status){case ae.ResourceDoesNotExists:switch(s.Data){case"DeviceNotFound":return new Te(Ng.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Te(Ng.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Te(Ng.OtherError,"Cannot get available states - unknown error!")}case ae.OK:{if(null==s.Data)return new Te(Ng.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!");const e=s.Data.AvailableStates.map((e=>{const t=new Qg;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return s.Data.AvailableStates=e,s.Data}default:return new Te(Ng.OtherError,`Cannot get available states - controller responded with response code ${s.Status}`)}}))}}cf.ServiceName="StatesHistoryService";class uf extends ie{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ce.Get,this.Data=e}}class lf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=Eg.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class df extends ie{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ce.Get}}class hf extends ie{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=ce.Get,this.Data=e}}class pf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(of=Zg||(Zg={}))[of.User=0]="User",of[of.Controller=1]="Controller",of[of.Marketing=2]="Marketing",(sf=ef||(ef={}))[sf.Notification=0]="Notification",sf[sf.Message=1]="Message",sf[sf.Alarm=2]="Alarm",sf[sf.Warning=3]="Warning",sf[sf.Info=4]="Info",(rf=tf||(tf={}))[rf.Other=0]="Other",rf[rf.UserLoggedIn=1]="UserLoggedIn",rf[rf.UserLoggedOut=2]="UserLoggedOut",rf[rf.FoundNewDevice=3]="FoundNewDevice",rf[rf.DoorBellPress=4]="DoorBellPress",rf[rf.AddedNewDevice=5]="AddedNewDevice",rf[rf.RemovedDevice=6]="RemovedDevice",rf[rf.RegisteredNewUser=7]="RegisteredNewUser",rf[rf.GotAccessToTheInternet=8]="GotAccessToTheInternet",rf[rf.LostAccessToTheInternet=9]="LostAccessToTheInternet",rf[rf.RemovedUser=10]="RemovedUser",rf[rf.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(nf||(nf={}));var gf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 ff{constructor(){this._chatSubscriptions=[],this._connection=Zf.Get(Gt.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==ef.Message)return;const n=new vf;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(nf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return gf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new mf,12e3,!1);if(null==e)return new Te(bf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ae.OK)return new Te(bf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Te(bf.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==ef.Message)return;const n=new vf;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(nf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new Te(bf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return gf(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new yf(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return Zf.Get(r.ServiceName).Error(Mf.ServiceName,`Cannot send message! ${e}`),ae.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class vf{constructor(){this._sender=Zg.Controller,this._messageType=ef.Info,this._messageSource=tf.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 mf extends ie{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ce.Get}}class yf extends ie{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ce.Put,this.Data=e}}var wf,Sf,_f,Af=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Cf{constructor(){this._chatSubscriptions=[],this._connection=Zf.Get(Gt.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==ef.Message){const e=new Tf;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 Af(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Gf,12e3,!1);if(null==e)return new Te(bf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ae.OK)return new Te(bf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Te(bf.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==ef.Message){const n=new Tf;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 Te(bf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return Af(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Df(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return Zf.Get(r.ServiceName).Error(Mf.ServiceName,`Cannot send message! ${e}`),ae.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class Tf{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 Df extends ie{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ce.Put,this.Data=e}}class Gf extends ie{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ce.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(wf||(wf={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(Sf||(Sf={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(_f||(_f={}));var kf,bf,Nf,Ef=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 If{constructor(){this._chatSubscriptions=[],this._connection=Zf.Get(Gt.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new Uf;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=wf[e],s=new Map;for(let[e,t]of Object.entries(r))s.set(e,t);n.ControllerActivities.set(t,s)}if(null!=t.Errors)for(let[e,r]of Object.entries(t.Errors))n.Errors.set(_f[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return Ef(this,void 0,void 0,(function*(){return(yield Zf.Get(Yp.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return Ef(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Pf,8e3,!1);return null==e||null==e.Status?new Te(bf.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ae.OK?new Te(bf.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Te(bf.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Te(bf.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return Ef(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Of(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return Zf.Get(r.ServiceName).Error(Mf.ServiceName,`Cannot set chat configuration! ${e}`),ae.FatalError}}))}SendMessageAsync(e){return Ef(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Rf(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return Zf.Get(r.ServiceName).Error(Mf.ServiceName,`Cannot send message! ${e}`),ae.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 Rf extends ie{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=ce.Put,this.Data=e}}class Pf extends ie{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ce.Get}}class Of extends ie{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ce.Put,this.Data=e}}class Uf{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"}(kf||(kf={}));class Mf{constructor(){this._services={ControllerChat:new ff,GptChat:new If,FamillyChat:new Cf}}GetServiceName(){return Mf.ServiceName}GetChatImplementation(e){switch(e){case kf.ControllerChat:return this._services.ControllerChat;case kf.FamilyChat:return this._services.FamillyChat;case kf.GptChat:return this._services.GptChat;default:throw new xf(`Chat with type ${e} not implemented!`)}}}Mf.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(bf||(bf={}));class xf 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"}(Nf||(Nf={}));var Ff=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Lf{constructor(){this._connection=Zf.Get(Gt.ServiceName),this._log=Zf.Get(r.ServiceName)}GetServiceName(){return Lf.ServiceName}IsSupportedAsync(){return Ff(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Bf,2e3,!0);return this._log.Debug(Lf.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ae.WrongData}))}GetConnectedAppsAsync(){return Ff(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new $f,2e3,!0);return(null==e?void 0:e.Status)===ae.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Ff(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new qf(e),2e3,!1);switch(null==t?void 0:t.Status){case ae.OK:return new Te(Nf.Changed,"");case ae.WrongData:switch(t.Data){case"AccessTokenToShort":return new Te(Nf.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Te(Nf.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Te(Nf.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Te(Nf.AppNameToShort,t.Data);case"AppUrlToShort":return new Te(Nf.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Te(Nf.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Te(Nf.AppUserNameToShort,t.Data);default:return new Te(Nf.UnkownError,t.Data)}case ae.ResourceDoesNotExists:case ae.ResourceIsNotAvailable:return new Te(Nf.ResourceIsNotAvailable,t.Data);default:return new Te(Nf.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Ff(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Wf(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}Lf.ServiceName="ConnectedAppsService";class Bf extends ie{constructor(){super(),this.Resource="/applications/app/auth",this.Method=ce.Put,this.Data=""}}class $f extends ie{constructor(){super(),this.Resource="/applications/get",this.Method=ce.Get}}class Wf extends ie{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=ce.Delete,this.Data=e}}class qf extends ie{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=ce.Put,this.Data=e}}var Hf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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(){try{void 0!==navigator.exalusMigration&&(Vf.exNativeMig=navigator.exalusMigration);const e=window.location.href,t=new URL(e),n=new URLSearchParams(t.search),r=n.get("mig_c_enc"),s=n.get("mig_controllers"),o=n.get("mig_lang");if(null!==r){const e=decodeURIComponent(this.b64DecodeUnicode(decodeURIComponent(r)));localStorage.setItem(Vf.AppUserControllersKeyName,e)}null!==s&&localStorage.setItem(Vf.AppUserControllersKeyName,decodeURIComponent(s)),null!==o&&localStorage.setItem(Vf.AppSelectedLanguageKeyName,o)}catch(e){console.error(e)}}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 Vf.ServiceName}IsMigrationDataAvailableAsync(){return Hf(this,void 0,void 0,(function*(){if(null!=window.webkit&&null!=window.webkit.messageHandlers){var e=yield Vf.GetIosMigrationStatus();return null!==e&&e}if(this.IsExalusNativeMigrationAvailable()){let e=yield Vf.exNativeMig.IsMigrationDataAvailableAsync();return null!=e&&e.DataMigrated}return null!==localStorage.getItem(Vf.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Vf.AppUserControllersKeyName)}))}GetControllersDataAsync(){return Hf(this,void 0,void 0,(function*(){if(null!=window.webkit&&null!=window.webkit.messageHandlers)return yield Vf.GetIosControllerList();{if(this.IsExalusNativeMigrationAvailable())return yield Vf.exNativeMig.GetControllersDataAsync();let e=localStorage.getItem(Vf.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}))}GetLanguageCodeAsync(){return Hf(this,void 0,void 0,(function*(){return null!=window.webkit&&null!=window.webkit.messageHandlers?yield Vf.GetIosDefaultLanguage():this.IsExalusNativeMigrationAvailable()?yield Vf.exNativeMig.GetLanguageCodeAsync():localStorage.getItem(Vf.AppSelectedLanguageKeyName)}))}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)}}))}}Vf.AppSelectedLanguageKeyName="App___SelectedLanguage",Vf.AppUserControllersKeyName="App___UserControllersListDatabase",Vf.ServiceName="DataMigrationService";var jf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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._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=Zf.Get(Gt.ServiceName),this._logger=Zf.Get(r.ServiceName),this._storage=Zf.Get(o.ServiceName),Zf.Get(je.ServiceName).OnUserLoggedInEvent().Subscribe((e=>jf(this,void 0,void 0,(function*(){var e;try{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(Kf.ServiceName,"LocalIpAddress",this._localIpAddress);const n=this.GetControllerHostName(this._connection.GetControllerSerialNumber());this._logger.Debug(`Looking for controller in local network with host name: ${n}`);let r=null;this.isIos()?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(Kf.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(Kf.ServiceName,"Controller not found in local network."))}else this._logger.Error(Kf.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(Kf.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return jf(this,void 0,void 0,(function*(){if(this.isIos()){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(Kf.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){var e;return jf(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new zf,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(Kf.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return Kf.ServiceName}isIos(){return null!=window.webkit&&null!=window.webkit.messageHandlers}getIosControllerIpAsync(e,t=2e4){let n;return new Promise(((r,s)=>{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("")}}))}}Kf.ServiceName="FindControllerService";class zf extends ie{constructor(){super(),this.Resource="/network/lan/",this.Method=ce.Get}}var Jf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Yf{constructor(){this._errorOccuredEvent=new n,this._connectionStateChangedEvent=new n,this._dataReceivedEvent=new n,this._onMessageReceived=new n,this._log=Zf.Get(r.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._logPackets=!1,this.sockets=null,this._address=null,this._port="81",this._isOpen=!1,this._pin=null,this._serial=null,this._auth=null,this._initialized=!1}Initialize(){this._initialized||(this._initialized=!0,this._controllerConfiguration=Zf.Get(Xe.ServiceName),this._cache=Zf.Get(Ge.ServiceName),this._session=Zf.Get(je.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return Jf(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}`}))}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}SetServersBrokerAddress(e){throw new Error("Method not implemented.")}SetDefaultPacketsBrokerAddress(e){throw new Error("Method not implemented.")}GetServerAddressAsync(){return Zf.IsRunningFromLocalNetwork()&&(this._address=`${window.location.hostname}:${this._port}`),Promise.resolve(this._address)}ConnectAsync(e){var t;return this.Initialize(),null===(t=this.sockets)||void 0===t||t.close(),this.sockets=new WebSocket(`ws://${e}/api`),this._log.Debug(Yf.ServiceName,`Connecting to the WebSockets server ${e}`),this.sockets.onerror=t=>{this._log.Debug(Yf.ServiceName,`Error occured in the WebSockets server ${e}: ${t}`),this._errorOccuredEvent.Invoke(["WebSockets",t.toString()])},this.sockets.onopen=t=>{this._log.Debug(Yf.ServiceName,`Connected to the WebSockets server ${e}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(de.Connected)},this.sockets.onclose=t=>{this._log.Debug(Yf.ServiceName,`Disconnected from the WebSockets server ${e}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(de.Disconnected)},this.sockets.onmessage=t=>{this._log.Debug(Yf.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);let n=JSON.parse(t.data);this._log.Debug(Yf.ServiceName,`Received data frame: ${n.Status}`),this._dataReceivedEvent.Invoke(n)},this._connectionStateChangedEvent.Invoke(de.Connecting),Promise.resolve(le.Connected)}AuthorizeAsync(e){return Jf(this,void 0,void 0,(function*(){return!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Yf.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,!0)}))}ConnectAndAuthorizeAsync(e){return Jf(this,void 0,void 0,(function*(){if(this._log.Debug(Yf.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`),!(yield this.AuthorizeAsync(e)))return le.AuthorizationFailed;let t=yield this.GetServerAddressAsync();return null==t?le.FailedToConnectToServer:yield this.ConnectAsync(t)}))}DisconnectAsync(){var e;return this._log.Debug(Yf.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._connectionStateChangedEvent.Invoke(de.Disconnecting),null===(e=this.sockets)||void 0===e||e.close(),Promise.resolve()}IsConnected(){return this._isOpen}EnablePacketsLogging(){this._log.Debug(Yf.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Yf.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Yf.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.sockets)||void 0===n||n.send(r):this._log.Error(Yf.ServiceName,`Failed to send data frame: ${r}`),Promise.resolve(this._isOpen)}SendAsync(e){return this._isOpen&&this.SendData(e,this._logPackets),Promise.resolve(this._isOpen)}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,r)}SendAndHandleResponseAsync(e,t,n,r){var s;return Jf(this,void 0,void 0,(function*(){let o=0;const i=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(s=this._session)||void 0===s?void 0:s.WaitForSessionCreationAsync()),new Promise(((s,a)=>Jf(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(Yf.ServiceName,t),a(new Error(t))}),t);let u=l=>Jf(this,void 0,void 0,(function*(){var d,h,p;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(o);const g=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Yf.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)===ae.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(),s(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ae.MultiDataResponseStart:case ae.MultiDataResponse:n(l),o=c();break;case ae.MultiDataResponseStop:n(l),this._dataReceivedEvent.Unsubscribe(u),s();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),o=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,r=!0,s=!0){var o,i,a;return Jf(this,void 0,void 0,(function*(){if(e.Method===ce.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.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(((o,i)=>Jf(this,void 0,void 0,(function*(){let a=i=>Jf(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;s&&this._log.Debug(Yf.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===ce.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ae.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(),o(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,s))),o(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(Yf.ServiceName,t),i(new Error(t))}),t),!this.SendData(e,s)){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 Yf.ServiceName}}Yf.ServiceName="ExalusConnectionService";class Xf{constructor(){var e,t;this.OnEnteredPictureInPicture=new Ae,this.OnExitedPictureInPicture=new Ae,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 Xf.ServiceName}}Xf.ServiceName="PictureInPictureService";class Qf{GetServiceName(){return Qf.ServiceName}GetSupportedDevicesAsync(){return e=this,t=void 0,r=function*(){let e=yield fetch("https://updates.tr7.pl/supportedDevices/pl-PL.json",{method:"GET"});if(e.ok)return JSON.parse(yield e.text());throw new Error("Failed to download supported devices list!")},new((n=void 0)||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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}}Qf.ServiceName="SupportedDevicesService",Dc(Map),Dc(Set),(()=>{var e;const t=String.prototype,n=Object.getOwnPropertyNames(Mo.prototype);for(const r of n)t[r]=null!==(e=t[r])&&void 0!==e?e:Mo.prototype[r];t.first=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}throw new Ro(Io.NoMatch)}if(0===this.length)throw new Ro(Io.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[0]},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Eo("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new Ro(Io.NoMatch)}if(0===this.length)throw new Ro(Io.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.reverse=function(){const e=this;return new Mo((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),Sp(Array),Sp(Int8Array),Sp(Int16Array),Sp(Int32Array),Sp(Uint8Array),Sp(Uint8ClampedArray),Sp(Uint16Array),Sp(Uint32Array),Sp(Float32Array),Sp(Float64Array);class Zf{static Init(){if(s.IsInitialized)return;let e=s.Instance;try{e.RegisterService(new Vf),e.RegisterService(new o),e.RegisterService(new Vp),e.RegisterService(new Ge),e.RegisterService(new je),e.RegisterService(new Xf),Zf.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Yf)):e.RegisterService(new Gt),e.RegisterService(new ns),e.RegisterService(new Qf),e.RegisterService(new ns),e.RegisterService(new ks),e.RegisterService(new Xe),e.RegisterService(new Kf),e.RegisterService(new Qr),e.RegisterService(new Yp),e.RegisterService(new be),e.RegisterService(new Fe),e.RegisterService(new lo),e.RegisterService(new Gp),e.RegisterService(new gg),e.RegisterService(new Og),e.RegisterService(new Lf),e.RegisterService(new cf),e.RegisterService(new Qs),e.RegisterService(new Mf)}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 s.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return s.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return s.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}}Zf.WorksInContextOf="",Zf.Version=1})();
|
|
1
|
+
(()=>{"use strict";var e,t={d:(e,n)=>{for(var r in n)t.o(n,r)&&!t.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:n[r]})}};t.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),t.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),t.d({},{V:()=>ev});class n{constructor(){this.handlers=[]}Subscribe(e){this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(e){this.handlers.slice(0).forEach((t=>{var n;try{t(e)}catch(e){null===(n=s.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 r{constructor(){this._blockedServices=[],this._logLevel=e.Debug,void 0!==window.loglevel&&null!==window.loglevel&&(this._logLevel=window.loglevel),window.logger=this}EnableStackTrace(){r.DoesThrowStackTrace=!0}DisableStackTrace(){r.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(r.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(r.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return r.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}`):r.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}`)))}}r.ServiceName="LoggerService",r.DoesThrowStackTrace=!1;class s{constructor(){this._services={},this._serviceRegistrationEvent=new n}static get Instance(){return null!=s._instance||(s._instance=new s,this.Log=new r,this.Log.Warning("Initializing DependencyContainer"),s._instance.RegisterService(this.Log),this.IsInitialized=!0,window.services=this),s._instance}RegisterService(e){var t;null===(t=s.Log)||void 0===t||t.Debug("DependencyContainer",`Registering new service: ${e.GetServiceName()}`),this._services[e.GetServiceName()]=e,this._serviceRegistrationEvent.Invoke(e)}GetService(e){var t;return null===(t=s.Log)||void 0===t||t.Debug("DependencyContainer",`Getting service [${e}] by GetService<T>()`),this._services[e]}GetServiceAsync(e,t){var n,r;return null===(n=s.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service availability [${e}] by GetServiceAsync<T>()`),this._services.hasOwnProperty(e)?(null===(r=s.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=s.Log)||void 0===r||r.Debug("DependencyContainer",`Got service [${e}] by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),n(t))},i=()=>{var n;null===(n=s.Log)||void 0===n||n.Debug("DependencyContainer",`Cancelled service [${e}] retrieval by GetServiceAsync<T>()`),this._serviceRegistrationEvent.Unsubscribe(o),null==t||t.CancellationEvent.Unsubscribe(i),r(new Error("Operation cancelled!"))};null==t||t.CancellationEvent.Subscribe(i),this._serviceRegistrationEvent.Subscribe(o)}))}GetServiceWithTimeoutAsync(e,t){var n,r;return null===(n=s.Log)||void 0===n||n.Debug("DependencyContainer",`Waiting for service[${e}] availability by GetServiceWithTimeoutAsync<T>()`),this._services.hasOwnProperty(e)?(null===(r=s.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,i=e=>{var t;(null==e?void 0:e.GetClassName())===e&&(null===(t=s.Log)||void 0===t||t.Debug("DependencyContainer",`Got service [${e}] by GetServiceWithTimeoutAsync<T>()`),window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(i),n(e))};o=window.setTimeout((()=>{var t;window.clearTimeout(o),this._serviceRegistrationEvent.Unsubscribe(i),null===(t=s.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(i)}))}}s.IsInitialized=!1;class o{GetServiceName(){return o.ServiceName}GetResourceName(e,t){return`_exalus_${ev.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=s.Log)||void 0===n||n.Error(o.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}o.ServiceName="LocalStorageService";const i=[0,2e3,1e4,3e4,null];class a{constructor(e){this._retryDelays=void 0!==e?[...e,null]:i}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class c{}c.Authorization="Authorization",c.Cookie="Cookie";class u{constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class l{get(e,t){return this.send({...t,method:"GET",url:e})}post(e,t){return this.send({...t,method:"POST",url:e})}delete(e,t){return this.send({...t,method:"DELETE",url:e})}getCookieString(e){return""}}class d extends l{constructor(e,t){super(),this._innerClient=e,this._accessTokenFactory=t}async send(e){let t=!0;this._accessTokenFactory&&(!this._accessToken||e.url&&e.url.indexOf("/negotiate?")>0)&&(t=!1,this._accessToken=await this._accessTokenFactory()),this._setAuthorizationHeader(e);const n=await this._innerClient.send(e);return t&&401===n.statusCode&&this._accessTokenFactory?(this._accessToken=await this._accessTokenFactory(),this._setAuthorizationHeader(e),await this._innerClient.send(e)):n}_setAuthorizationHeader(e){e.headers||(e.headers={}),this._accessToken?e.headers[c.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[c.Authorization]&&delete e.headers[c.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class h extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class p extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class g extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class f extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class v extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class m extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class y extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class w extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}var S;!function(e){e[e.Trace=0]="Trace",e[e.Debug=1]="Debug",e[e.Information=2]="Information",e[e.Warning=3]="Warning",e[e.Error=4]="Error",e[e.Critical=5]="Critical",e[e.None=6]="None"}(S||(S={}));class _{constructor(){}log(e,t){}}_.instance=new _;const A="7.0.14";class C{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 T{static get isBrowser(){return"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return"object"==typeof self&&"importScripts"in self}static get isReactNative(){return"object"==typeof window&&void 0===window.document}static get isNode(){return!this.isBrowser&&!this.isWebWorker&&!this.isReactNative}}function D(e,t){let n="";return G(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 G(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function k(e,t,n,r,s,o){const i={},[a,c]=E();i[a]=c,e.log(S.Trace,`(${t} transport) sending data. ${D(s,o.logMessageContent)}.`);const u=G(s)?"arraybuffer":"text",l=await n.post(r,{content:s,headers:{...i,...o.headers},responseType:u,timeout:o.timeout,withCredentials:o.withCredentials});e.log(S.Trace,`(${t} transport) request complete. Response status: ${l.statusCode}.`)}class b{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 N{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${S[e]}: ${t}`;switch(e){case S.Critical:case S.Error:this.out.error(n);break;case S.Warning:this.out.warn(n);break;case S.Information:this.out.info(n);break;default:this.out.log(n)}}}}function E(){let e="X-SignalR-User-Agent";return T.isNode&&(e="User-Agent"),[e,I(A,R(),T.isNode?"NodeJS":"Browser",P())]}function I(e,t,n,r){let s="Microsoft SignalR/";const o=e.split(".");return s+=`${o[0]}.${o[1]}`,s+=` (${e}; `,s+=t&&""!==t?`${t}; `:"Unknown OS; ",s+=`${n}`,s+=r?`; ${r}`:"; Unknown Runtime Version",s+=")",s}function R(){if(!T.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function P(){if(T.isNode)return process.versions.node}function O(e){return e.stack?e.stack:e.message?e.message:`${e}`}class U extends l{constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch){const e=require;this._jar=new(e("tough-cookie").CookieJar),this._fetchType=e("node-fetch"),this._fetchType=e("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(function(){if("undefined"!=typeof globalThis)return globalThis;if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==t.g)return t.g;throw new Error("could not find global")}());if("undefined"==typeof AbortController){const e=require;this._abortControllerType=e("abort-controller")}else this._abortControllerType=AbortController}async send(e){if(e.abortSignal&&e.abortSignal.aborted)throw new g;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 g});let r,s=null;if(e.timeout){const r=e.timeout;s=setTimeout((()=>{t.abort(),this._logger.log(S.Warning,"Timeout from HTTP request."),n=new p}),r)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},G(e.content)?e.headers["Content-Type"]="application/octet-stream":e.headers["Content-Type"]="text/plain;charset=UTF-8");try{r=await this._fetchType(e.url,{body:e.content,cache:"no-cache",credentials:!0===e.withCredentials?"include":"same-origin",headers:{"X-Requested-With":"XMLHttpRequest",...e.headers},method:e.method,mode:"cors",redirect:"follow",signal:t.signal})}catch(e){if(n)throw n;throw this._logger.log(S.Warning,`Error from HTTP request. ${e}.`),e}finally{s&&clearTimeout(s),e.abortSignal&&(e.abortSignal.onabort=null)}if(!r.ok){const e=await M(r,"text");throw new h(e||r.statusText,r.status)}const o=M(r,e.responseType),i=await o;return new u(r.status,r.statusText,i)}getCookieString(e){let t="";return T.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function M(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 x extends l{constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new g):e.method?e.url?new Promise(((t,n)=>{const r=new XMLHttpRequest;r.open(e.method,e.url,!0),r.withCredentials=void 0===e.withCredentials||e.withCredentials,r.setRequestHeader("X-Requested-With","XMLHttpRequest"),""===e.content&&(e.content=void 0),e.content&&(G(e.content)?r.setRequestHeader("Content-Type","application/octet-stream"):r.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const s=e.headers;s&&Object.keys(s).forEach((e=>{r.setRequestHeader(e,s[e])})),e.responseType&&(r.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{r.abort(),n(new g)}),e.timeout&&(r.timeout=e.timeout),r.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),r.status>=200&&r.status<300?t(new u(r.status,r.statusText,r.response||r.responseText)):n(new h(r.response||r.responseText||r.statusText,r.status))},r.onerror=()=>{this._logger.log(S.Warning,`Error from HTTP request. ${r.status}: ${r.statusText}.`),n(new h(r.statusText,r.status))},r.ontimeout=()=>{this._logger.log(S.Warning,"Timeout from HTTP request."),n(new p)},r.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class F extends l{constructor(e){if(super(),"undefined"!=typeof fetch||T.isNode)this._httpClient=new U(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new x(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new g):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)}}var L,B,$,W;!function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(L||(L={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(B||(B={}));class q{constructor(){this._isAborted=!1,this.onabort=null}abort(){this._isAborted||(this._isAborted=!0,this.onabort&&this.onabort())}get signal(){return this}get aborted(){return this._isAborted}}class H{constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new q,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}get pollAborted(){return this._pollAbort.aborted}async connect(e,t){if(C.isRequired(e,"url"),C.isRequired(t,"transferFormat"),C.isIn(t,B,"transferFormat"),this._url=e,this._logger.log(S.Trace,"(LongPolling transport) Connecting."),t===B.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[n,r]=E(),s={[n]:r,...this._options.headers},o={abortSignal:this._pollAbort.signal,headers:s,timeout:1e5,withCredentials:this._options.withCredentials};t===B.Binary&&(o.responseType="arraybuffer");const i=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${i}.`);const a=await this._httpClient.get(i,o);200!==a.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${a.statusCode}.`),this._closeError=new h(a.statusText||"",a.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,o)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(S.Trace,`(LongPolling transport) polling: ${n}.`);const r=await this._httpClient.get(n,t);204===r.statusCode?(this._logger.log(S.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==r.statusCode?(this._logger.log(S.Error,`(LongPolling transport) Unexpected response code: ${r.statusCode}.`),this._closeError=new h(r.statusText||"",r.statusCode),this._running=!1):r.content?(this._logger.log(S.Trace,`(LongPolling transport) data received. ${D(r.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(r.content)):this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof p?this._logger.log(S.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(S.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(S.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?k(this._logger,"LongPolling",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}async stop(){this._logger.log(S.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(S.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=E();e[t]=n;const r={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};await this._httpClient.delete(this._url,r),this._logger.log(S.Trace,"(LongPolling transport) DELETE request sent.")}finally{this._logger.log(S.Trace,"(LongPolling transport) Stop finished."),this._raiseOnClose()}}_raiseOnClose(){if(this.onclose){let e="(LongPolling transport) Firing onclose event.";this._closeError&&(e+=" Error: "+this._closeError),this._logger.log(S.Trace,e),this.onclose(this._closeError)}}}class V{constructor(e,t,n,r){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=r,this.onreceive=null,this.onclose=null}async connect(e,t){return C.isRequired(e,"url"),C.isRequired(t,"transferFormat"),C.isIn(t,B,"transferFormat"),this._logger.log(S.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((n,r)=>{let s,o=!1;if(t===B.Text){if(T.isBrowser||T.isWebWorker)s=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[r,o]=E();n[r]=o,s=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{s.onmessage=e=>{if(this.onreceive)try{this._logger.log(S.Trace,`(SSE transport) data received. ${D(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},s.onerror=e=>{o?this._close():r(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."))},s.onopen=()=>{this._logger.log(S.Information,`SSE connected to ${this._url}`),this._eventSource=s,o=!0,n()}}catch(e){return void r(e)}}else r(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?k(this._logger,"SSE",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}stop(){return this._close(),Promise.resolve()}_close(e){this._eventSource&&(this._eventSource.close(),this._eventSource=void 0,this.onclose&&this.onclose(e))}}class j{constructor(e,t,n,r,s,o){this._logger=n,this._accessTokenFactory=t,this._logMessageContent=r,this._webSocketConstructor=s,this._httpClient=e,this.onreceive=null,this.onclose=null,this._headers=o}async connect(e,t){let n;return C.isRequired(e,"url"),C.isRequired(t,"transferFormat"),C.isIn(t,B,"transferFormat"),this._logger.log(S.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(n=await this._accessTokenFactory()),new Promise(((r,s)=>{let o;e=e.replace(/^http/,"ws");const i=this._httpClient.getCookieString(e);let a=!1;if(T.isNode||T.isReactNative){const t={},[r,s]=E();t[r]=s,n&&(t[c.Authorization]=`Bearer ${n}`),i&&(t[c.Cookie]=i),o=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else n&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(n)}`);o||(o=new this._webSocketConstructor(e)),t===B.Binary&&(o.binaryType="arraybuffer"),o.onopen=t=>{this._logger.log(S.Information,`WebSocket connected to ${e}.`),this._webSocket=o,a=!0,r()},o.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(S.Information,`(WebSockets transport) ${t}.`)},o.onmessage=e=>{if(this._logger.log(S.Trace,`(WebSockets transport) data received. ${D(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},o.onclose=e=>{if(a)this._close(e);else{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"WebSocket failed to connect. The connection could not be found on the server, either the endpoint may not be a SignalR endpoint, the connection ID is not present on the server, or there is a proxy blocking WebSockets. If you have multiple servers check that sticky sessions are enabled.",s(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(S.Trace,`(WebSockets transport) sending data. ${D(e,this._logMessageContent)}.`),this._webSocket.send(e),Promise.resolve()):Promise.reject("WebSocket is not in the OPEN state")}stop(){return this._webSocket&&this._close(void 0),Promise.resolve()}_close(e){this._webSocket&&(this._webSocket.onclose=()=>{},this._webSocket.onmessage=()=>{},this._webSocket.onerror=()=>{},this._webSocket.close(),this._webSocket=void 0),this._logger.log(S.Trace,"(WebSockets transport) socket closed."),this.onclose&&(!this._isCloseEvent(e)||!1!==e.wasClean&&1e3===e.code?e instanceof Error?this.onclose(e):this.onclose():this.onclose(new Error(`WebSocket closed with status code: ${e.code} (${e.reason||"no reason given"}).`)))}_isCloseEvent(e){return e&&"boolean"==typeof e.wasClean&&"number"==typeof e.code}}class K{constructor(e,t={}){var n;if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,C.isRequired(e,"url"),this._logger=void 0===(n=t.logger)?new N(S.Information):null===n?_.instance:void 0!==n.log?n:new N(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 r=null,s=null;if(T.isNode){const e=require;r=e("ws"),s=e("eventsource")}T.isNode||"undefined"==typeof WebSocket||t.WebSocket?T.isNode&&!t.WebSocket&&r&&(t.WebSocket=r):t.WebSocket=WebSocket,T.isNode||"undefined"==typeof EventSource||t.EventSource?T.isNode&&!t.EventSource&&void 0!==s&&(t.EventSource=s):t.EventSource=EventSource,this._httpClient=new d(t.httpClient||new F(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||B.Binary,C.isIn(e,B,"transferFormat"),this._logger.log(S.Debug,`Starting connection with transfer format '${B[e]}'.`),"Disconnected"!==this._connectionState)return Promise.reject(new Error("Cannot start an HttpConnection that is not in the 'Disconnected' state."));if(this._connectionState="Connecting",this._startInternalPromise=this._startInternal(e),await this._startInternalPromise,"Disconnecting"===this._connectionState){const e="Failed to start the HttpConnection before stop() was called.";return this._logger.log(S.Error,e),await this._stopPromise,Promise.reject(new g(e))}if("Connected"!==this._connectionState){const e="HttpConnection.startInternal completed gracefully but didn't enter the connection into the connected state!";return this._logger.log(S.Error,e),Promise.reject(new g(e))}this._connectionStarted=!0}send(e){return"Connected"!==this._connectionState?Promise.reject(new Error("Cannot send data if the connection is not in the 'Connected' State.")):(this._sendQueue||(this._sendQueue=new z(this.transport)),this._sendQueue.send(e))}async stop(e){return"Disconnected"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState="Disconnecting",this._stopPromise=new Promise((e=>{this._stopPromiseResolver=e})),await this._stopInternal(e),void await this._stopPromise)}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch(e){}if(this.transport){try{await this.transport.stop()}catch(e){this._logger.log(S.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(S.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let t=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==L.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(L.WebSockets),await this._startTransport(t,e)}else{let n=null,r=0;do{if(n=await this._getNegotiationResponse(t),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new g("The connection was stopped during negotiation.");if(n.error)throw new Error(n.error);if(n.ProtocolVersion)throw new Error("Detected a connection attempt to an ASP.NET SignalR Server. This client only supports connecting to an ASP.NET Core SignalR Server. See https://aka.ms/signalr-core-differences for details.");if(n.url&&(t=n.url),n.accessToken){const e=n.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}r++}while(n.url&&r<100);if(100===r&&n.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(t,this._options.transport,n,e)}this.transport instanceof H&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(S.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(S.Error,"Failed to start the connection: "+e),this._connectionState="Disconnected",this.transport=void 0,this._stopPromiseResolver(),Promise.reject(e)}}async _getNegotiationResponse(e){const t={},[n,r]=E();t[n]=r;const s=this._resolveNegotiateUrl(e);this._logger.log(S.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}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof h&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(S.Error,t),Promise.reject(new y(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,t,n,r){let s=this._createConnectUrl(e,n.connectionToken);if(this._isITransport(t))return this._logger.log(S.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=t,await this._startTransport(s,r),void(this.connectionId=n.connectionId);const o=[],i=n.availableTransports||[];let a=n;for(const n of i){const i=this._resolveTransportOrError(n,t,r);if(i instanceof Error)o.push(`${n.transport} failed:`),o.push(i);else if(this._isITransport(i)){if(this.transport=i,!a){try{a=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}s=this._createConnectUrl(e,a.connectionToken)}try{return await this._startTransport(s,r),void(this.connectionId=a.connectionId)}catch(e){if(this._logger.log(S.Error,`Failed to start the transport '${n.transport}': ${e}`),a=void 0,o.push(new m(`${n.transport} failed: ${e}`,L[n.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(S.Debug,e),Promise.reject(new g(e))}}}}return o.length>0?Promise.reject(new w(`Unable to connect to the server with any of the available transports. ${o.join(" ")}`,o)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case L.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new j(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case L.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new V(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case L.LongPolling:return new H(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,t,n){const r=L[e.transport];if(null==r)return this._logger.log(S.Debug,`Skipping transport '${e.transport}' because it is not supported by this client.`),new Error(`Skipping transport '${e.transport}' because it is not supported by this client.`);if(!function(e,t){return!e||0!=(t&e)}(t,r))return this._logger.log(S.Debug,`Skipping transport '${L[r]}' because it was disabled by the client.`),new v(`'${L[r]}' is disabled by the client.`,r);if(!(e.transferFormats.map((e=>B[e])).indexOf(n)>=0))return this._logger.log(S.Debug,`Skipping transport '${L[r]}' because it does not support the requested transfer format '${B[n]}'.`),new Error(`'${L[r]}' does not support ${B[n]}.`);if(r===L.WebSockets&&!this._options.WebSocket||r===L.ServerSentEvents&&!this._options.EventSource)return this._logger.log(S.Debug,`Skipping transport '${L[r]}' because it is not supported in your environment.'`),new f(`'${L[r]}' is not supported in your environment.`,r);this._logger.log(S.Debug,`Selecting transport '${L[r]}'.`);try{return this._constructTransport(r)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(S.Debug,`HttpConnection.stopConnection(${e}) called while in state ${this._connectionState}.`),this.transport=void 0,e=this._stopError||e,this._stopError=void 0,"Disconnected"!==this._connectionState){if("Connecting"===this._connectionState)throw this._logger.log(S.Warning,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is still in the connecting state.`),new Error(`HttpConnection.stopConnection(${e}) was called while the connection is still in the connecting state.`);if("Disconnecting"===this._connectionState&&this._stopPromiseResolver(),e?this._logger.log(S.Error,`Connection disconnected with error '${e}'.`):this._logger.log(S.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(S.Error,`TransportSendQueue.stop() threw error '${e}'.`)})),this._sendQueue=void 0),this.connectionId=void 0,this._connectionState="Disconnected",this._connectionStarted){this._connectionStarted=!1;try{this.onclose&&this.onclose(e)}catch(t){this._logger.log(S.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(S.Debug,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is already in the disconnected state.`)}_resolveUrl(e){if(0===e.lastIndexOf("https://",0)||0===e.lastIndexOf("http://",0))return e;if(!T.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(S.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=e.indexOf("?");let n=e.substring(0,-1===t?e.length:t);return"/"!==n[n.length-1]&&(n+="/"),n+="negotiate",n+=-1===t?"":e.substring(t),-1===n.indexOf("negotiateVersion")&&(n+=-1===t?"?":"&",n+="negotiateVersion="+this._negotiateVersion),n}}class z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new J,this._transportResult=new J,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new J),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 J;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 J{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class Y{static write(e){return`${e}${Y.RecordSeparator}`}static parse(e){if(e[e.length-1]!==Y.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(Y.RecordSeparator);return t.pop(),t}}Y.RecordSeparatorCode=30,Y.RecordSeparator=String.fromCharCode(Y.RecordSeparatorCode);class X{writeHandshakeRequest(e){return Y.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(G(e)){const r=new Uint8Array(e),s=r.indexOf(Y.RecordSeparatorCode);if(-1===s)throw new Error("Message is incomplete.");const o=s+1;t=String.fromCharCode.apply(null,Array.prototype.slice.call(r.slice(0,o))),n=r.byteLength>o?r.slice(o).buffer:null}else{const r=e,s=r.indexOf(Y.RecordSeparator);if(-1===s)throw new Error("Message is incomplete.");const o=s+1;t=r.substring(0,o),n=r.length>o?r.substring(o):null}const r=Y.parse(t),s=JSON.parse(r[0]);if(s.type)throw new Error("Expected a handshake response from the server.");return[n,s]}}!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"}($||($={}));class Q{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 b(this,e)}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(W||(W={}));class Z{constructor(e,t,n,r){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(S.Warning,"The page is being frozen, this will likely lead to the connection being closed and messages being lost. For more information see the docs at https://docs.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},C.isRequired(e,"connection"),C.isRequired(t,"logger"),C.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=3e4,this.keepAliveIntervalInMilliseconds=15e3,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=r,this._handshakeProtocol=new X,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=W.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:$.Ping})}static create(e,t,n,r){return new Z(e,t,n,r)}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!==W.Disconnected&&this._connectionState!==W.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!==W.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=W.Connecting,this._logger.log(S.Debug,"Starting HubConnection.");try{await this._startInternal(),T.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=W.Connected,this._connectionStarted=!0,this._logger.log(S.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=W.Disconnected,this._logger.log(S.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise(((e,t)=>{this._handshakeResolver=e,this._handshakeRejecter=t}));await this.connection.start(this._protocol.transferFormat);try{const t={protocol:this._protocol.name,version:this._protocol.version};if(this._logger.log(S.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(t)),this._logger.log(S.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(S.Debug,`Hub handshake failed with error '${e}' during start(). Stopping HubConnection.`),this._cleanupTimeout(),this._cleanupPingTimer(),await this.connection.stop(e),e}}async stop(){const e=this._startPromise;this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){return this._connectionState===W.Disconnected?(this._logger.log(S.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve()):this._connectionState===W.Disconnecting?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState=W.Disconnecting,this._logger.log(S.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(S.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new g("The connection was stopped before the hub handshake could complete."),this.connection.stop(e)))}stream(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._createStreamInvocation(e,t,r);let o;const i=new Q;return i.cancelCallback=()=>{const e=this._createCancelInvocation(s.invocationId);return delete this._callbacks[s.invocationId],o.then((()=>this._sendWithProtocol(e)))},this._callbacks[s.invocationId]=(e,t)=>{t?i.error(t):e&&(e.type===$.Completion?e.error?i.error(new Error(e.error)):i.complete():i.next(e.item))},o=this._sendWithProtocol(s).catch((e=>{i.error(e),delete this._callbacks[s.invocationId]})),this._launchStreams(n,o),i}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._sendWithProtocol(this._createInvocation(e,t,!0,r));return this._launchStreams(n,s),s}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===$.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)switch(e.type){case $.Invocation:this._invokeClientMethod(e);break;case $.StreamItem:case $.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===$.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(S.Error,`Stream callback threw error: ${O(e)}`)}}break}case $.Ping:break;case $.Close:{this._logger.log(S.Information,"Close message received from server.");const t=e.error?new Error("Server returned an error on close: "+e.error):void 0;!0===e.allowReconnect?this.connection.stop(t):this._stopPromise=this._stopInternal(t);break}default:this._logger.log(S.Warning,`Invalid message type: ${e.type}.`)}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let t,n;try{[n,t]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(e){const t="Error parsing handshake response: "+e;this._logger.log(S.Error,t);const n=new Error(t);throw this._handshakeRejecter(n),n}if(t.error){const e="Server returned handshake error: "+t.error;this._logger.log(S.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(S.Debug,"Server handshake complete."),this._handshakeResolver(),n}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=(new Date).getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if(!(this.connection.features&&this.connection.features.inherentKeepAlive||(this._timeoutHandle=setTimeout((()=>this.serverTimeout()),this.serverTimeoutInMilliseconds),void 0!==this._pingServerHandle))){let e=this._nextKeepAlive-(new Date).getTime();e<0&&(e=0),this._pingServerHandle=setTimeout((async()=>{if(this._connectionState===W.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}}),e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const t=e.target.toLowerCase(),n=this._methods[t];if(!n)return this._logger.log(S.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null))));const r=n.slice(),s=!!e.invocationId;let o,i,a;for(const n of r)try{const r=o;o=await n.apply(this,e.arguments),s&&o&&r&&(this._logger.log(S.Error,`Multiple results provided for '${t}'. Sending error to server.`),a=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),i=void 0}catch(e){i=e,this._logger.log(S.Error,`A callback for the method '${t}' threw error '${e}'.`)}a?await this._sendWithProtocol(a):s?(i?a=this._createCompletionMessage(e.invocationId,`${i}`,null):void 0!==o?a=this._createCompletionMessage(e.invocationId,null,o):(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),a=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(a)):o&&this._logger.log(S.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(S.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new g("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===W.Disconnecting?this._completeClose(e):this._connectionState===W.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===W.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=W.Disconnected,this._connectionStarted=!1,T.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onclose callback called with error '${e}' threw error '${t}'.`)}}}async _reconnect(e){const t=Date.now();let n=0,r=void 0!==e?e:new Error("Attempting to reconnect due to a unknown error."),s=this._getNextRetryDelay(n++,0,r);if(null===s)return this._logger.log(S.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=W.Reconnecting,e?this._logger.log(S.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(S.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==W.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==s;){if(this._logger.log(S.Information,`Reconnect attempt number ${n} will start in ${s} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,s)})),this._reconnectDelayHandle=void 0,this._connectionState!==W.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=W.Connected,this._logger.log(S.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(S.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(S.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==W.Reconnecting)return this._logger.log(S.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===W.Disconnecting&&this._completeClose());r=e instanceof Error?e:new Error(e.toString()),s=this._getNextRetryDelay(n++,Date.now()-t,r)}}this._logger.log(S.Information,`Reconnect retries have been exhausted after ${Date.now()-t} ms and ${n} failed attempts. Connection disconnecting.`),this._completeClose()}_getNextRetryDelay(e,t,n){try{return this._reconnectPolicy.nextRetryDelayInMilliseconds({elapsedMilliseconds:t,previousRetryCount:e,retryReason:n})}catch(n){return this._logger.log(S.Error,`IRetryPolicy.nextRetryDelayInMilliseconds(${e}, ${t}) threw error '${n}'.`),null}}_cancelCallbacksWithError(e){const t=this._callbacks;this._callbacks={},Object.keys(t).forEach((n=>{const r=t[n];try{r(null,e)}catch(t){this._logger.log(S.Error,`Stream 'error' callback called with '${e}' threw error: ${O(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:$.Invocation}:{arguments:t,target:e,type:$.Invocation};{const n=this._invocationId;return this._invocationId++,0!==r.length?{arguments:t,invocationId:n.toString(),streamIds:r,target:e,type:$.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:$.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 s=e[r];if(this._isObservable(s)){const o=this._invocationId;this._invocationId++,t[o]=s,n.push(o.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:$.StreamInvocation}:{arguments:t,invocationId:r.toString(),target:e,type:$.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:$.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:$.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:$.Completion}:{invocationId:e,result:n,type:$.Completion}}}class ee{constructor(){this.name="json",this.version=1,this.transferFormat=B.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=_.instance);const n=Y.parse(e),r=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case $.Invocation:this._isInvocationMessage(n);break;case $.StreamItem:this._isStreamItemMessage(n);break;case $.Completion:this._isCompletionMessage(n);break;case $.Ping:case $.Close:break;default:t.log(S.Information,"Unknown message type '"+n.type+"' ignored.");continue}r.push(n)}return r}writeMessage(e){return Y.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),void 0!==e.invocationId&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),void 0===e.item)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const te={trace:S.Trace,debug:S.Debug,info:S.Information,information:S.Information,warn:S.Warning,warning:S.Warning,error:S.Error,critical:S.Critical,none:S.None};class ne{configureLogging(e){if(C.isRequired(e,"logging"),void 0!==e.log)this.logger=e;else if("string"==typeof e){const t=function(e){const t=te[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new N(t)}else this.logger=new N(e);return this}withUrl(e,t){return C.isRequired(e,"url"),C.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return C.isRequired(e,"protocol"),this.protocol=e,this}withAutomaticReconnect(e){if(this.reconnectPolicy)throw new Error("A reconnectPolicy has already been set.");return e?Array.isArray(e)?this.reconnectPolicy=new a(e):this.reconnectPolicy=e:this.reconnectPolicy=new a,this}build(){const e=this.httpConnectionOptions||{};if(void 0===e.logger&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const t=new K(this.url,e);return Z.create(t,this.logger||_.instance,this.protocol||new ee,this.reconnectPolicy)}}class re{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 s(e,t,n,s,o,i){return r(function(e,t){return e<<t|e>>>32-t}(r(r(t,e),r(s,i)),o),n)}function o(e,t,n,r,o,i,a){return s(t&n|~t&r,e,t,o,i,a)}function i(e,t,n,r,o,i,a){return s(t&r|n&~r,e,t,o,i,a)}function a(e,t,n,r,o,i,a){return s(t^n^r,e,t,o,i,a)}function c(e,t,n,r,o,i,a){return s(n^(t|~r),e,t,o,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,m=-1732584194,y=271733878;for(u=0;u<g.length;u+=16)l=f,d=v,h=m,p=y,f=o(f,v,m,y,g[u+0],7,-680876936),y=o(y,f,v,m,g[u+1],12,-389564586),m=o(m,y,f,v,g[u+2],17,606105819),v=o(v,m,y,f,g[u+3],22,-1044525330),f=o(f,v,m,y,g[u+4],7,-176418897),y=o(y,f,v,m,g[u+5],12,1200080426),m=o(m,y,f,v,g[u+6],17,-1473231341),v=o(v,m,y,f,g[u+7],22,-45705983),f=o(f,v,m,y,g[u+8],7,1770035416),y=o(y,f,v,m,g[u+9],12,-1958414417),m=o(m,y,f,v,g[u+10],17,-42063),v=o(v,m,y,f,g[u+11],22,-1990404162),f=o(f,v,m,y,g[u+12],7,1804603682),y=o(y,f,v,m,g[u+13],12,-40341101),m=o(m,y,f,v,g[u+14],17,-1502002290),v=o(v,m,y,f,g[u+15],22,1236535329),f=i(f,v,m,y,g[u+1],5,-165796510),y=i(y,f,v,m,g[u+6],9,-1069501632),m=i(m,y,f,v,g[u+11],14,643717713),v=i(v,m,y,f,g[u+0],20,-373897302),f=i(f,v,m,y,g[u+5],5,-701558691),y=i(y,f,v,m,g[u+10],9,38016083),m=i(m,y,f,v,g[u+15],14,-660478335),v=i(v,m,y,f,g[u+4],20,-405537848),f=i(f,v,m,y,g[u+9],5,568446438),y=i(y,f,v,m,g[u+14],9,-1019803690),m=i(m,y,f,v,g[u+3],14,-187363961),v=i(v,m,y,f,g[u+8],20,1163531501),f=i(f,v,m,y,g[u+13],5,-1444681467),y=i(y,f,v,m,g[u+2],9,-51403784),m=i(m,y,f,v,g[u+7],14,1735328473),v=i(v,m,y,f,g[u+12],20,-1926607734),f=a(f,v,m,y,g[u+5],4,-378558),y=a(y,f,v,m,g[u+8],11,-2022574463),m=a(m,y,f,v,g[u+11],16,1839030562),v=a(v,m,y,f,g[u+14],23,-35309556),f=a(f,v,m,y,g[u+1],4,-1530992060),y=a(y,f,v,m,g[u+4],11,1272893353),m=a(m,y,f,v,g[u+7],16,-155497632),v=a(v,m,y,f,g[u+10],23,-1094730640),f=a(f,v,m,y,g[u+13],4,681279174),y=a(y,f,v,m,g[u+0],11,-358537222),m=a(m,y,f,v,g[u+3],16,-722521979),v=a(v,m,y,f,g[u+6],23,76029189),f=a(f,v,m,y,g[u+9],4,-640364487),y=a(y,f,v,m,g[u+12],11,-421815835),m=a(m,y,f,v,g[u+15],16,530742520),v=a(v,m,y,f,g[u+2],23,-995338651),f=c(f,v,m,y,g[u+0],6,-198630844),y=c(y,f,v,m,g[u+7],10,1126891415),m=c(m,y,f,v,g[u+14],15,-1416354905),v=c(v,m,y,f,g[u+5],21,-57434055),f=c(f,v,m,y,g[u+12],6,1700485571),y=c(y,f,v,m,g[u+3],10,-1894986606),m=c(m,y,f,v,g[u+10],15,-1051523),v=c(v,m,y,f,g[u+1],21,-2054922799),f=c(f,v,m,y,g[u+8],6,1873313359),y=c(y,f,v,m,g[u+15],10,-30611744),m=c(m,y,f,v,g[u+6],15,-1560198380),v=c(v,m,y,f,g[u+13],21,1309151649),f=c(f,v,m,y,g[u+4],6,-145523070),y=c(y,f,v,m,g[u+11],10,-1120210379),m=c(m,y,f,v,g[u+2],15,718787259),v=c(v,m,y,f,g[u+9],21,-343485551),f=r(f,l),v=r(v,d),m=r(m,h),y=r(y,p);return n(f)+n(v)+n(m)+n(y)}}class se{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function oe(e){return new Map(Object.entries(e))}class ie{constructor(){this.TransactionId=re.GenerateUUID()}}var ae,ce,ue,le,de,he,pe,ge,fe,ve,me,ye,we,Se;(ye=ae||(ae={}))[ye.OK=0]="OK",ye[ye.UnknownError=1]="UnknownError",ye[ye.FatalError=2]="FatalError",ye[ye.WrongData=3]="WrongData",ye[ye.ResourceDoesNotExists=4]="ResourceDoesNotExists",ye[ye.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",ye[ye.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",ye[ye.OperationNotPermitted=7]="OperationNotPermitted",ye[ye.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",ye[ye.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",ye[ye.Error=10]="Error",ye[ye.NoData=11]="NoData",ye[ye.NotSupportedMethod=12]="NotSupportedMethod",ye[ye.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",ye[ye.MultiDataResponseStart=14]="MultiDataResponseStart",ye[ye.MultiDataResponse=15]="MultiDataResponse",ye[ye.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"}(ce||(ce={}));class _e{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"}(ue||(ue={})),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"}(le||(le={})),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"}(de||(de={}));class Ae{constructor(){this._log=ev.Get(r.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)}}))}}(Se=he||(he={}))[Se.Any=0]="Any",Se[Se.Guest=10]="Guest",Se[Se.Standard=20]="Standard",Se[Se.Admin=30]="Admin",Se[Se.Installator=40]="Installator",Se[Se.Support=50]="Support",(we=pe||(pe={}))[we.Unknown=0]="Unknown",we[we.Men=1]="Men",we[we.Woman=2]="Woman",we[we.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(ge||(ge={})),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"}(fe||(fe={}));class Ce{constructor(e,t){this._type=ve.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 Te{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"}(ve||(ve={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(me||(me={}));class De{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=me.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}}class Ge{constructor(){this._log=ev.Get(r.ServiceName),Ge._localStorageService=ev.Get(o.ServiceName)}GetServiceName(){return Ge.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ae.OK&&(this._log.Debug(Ge.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Ge._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Ge._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Ge.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=Ge._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Ge.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Ge._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Ge.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Ge._localStorageService=null,Ge.ServiceName="WebApiCacheService";var ke=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 be{constructor(){this._imageExistsCaseNumber=0,this._connection=ev.Get(Gt.ServiceName),this._logger=ev.Get(r.ServiceName)}GetServiceName(){return be.ServiceName}AddPictureAsync(e){var t,n;return ke(this,void 0,void 0,(function*(){try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ae.WrongData;let r=new Image;const s=new Promise(((t,n)=>{r.src=e.Base64Image,r.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield s))return this._logger.Error(be.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ae.WrongData;if(0===r.height||0===r.width)return this._logger.Error(be.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ae.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(be.ServiceName,"Cannot add picture - Guid must be empty."),ae.WrongData;const o=new Ee;o.Guid=re.GenerateUUID(),o.DateTime=(new Date).toISOString(),o.ImageType=e.ImageType,o.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`,o.Base64Image=e.Base64Image;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(o.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),ae.UnknownError;if(i.Status==ae.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ue(o),8e3,!1);return null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot add picture - unknown error!"),ae.UnknownError):e.Status}return i.Status==ae.OK?(this._logger.Warning(be.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ae.UnknownError):(this._logger.Error(be.ServiceName,"Cannot add picture - cannot get current picture status."),ae.Error)}catch(e){return this._logger.Error(be.ServiceName,`Cannot add picture! ${e}`),ae.FatalError}}))}EditPictureAsync(e){var t,n;return ke(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot edit picture - guid is empty."),ae.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(be.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ae.WrongData;let r=new Image;const s=new Promise(((t,n)=>{r.src=e.Base64Image,r.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield s))return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ae.WrongData;if(0===r.height||0===r.width)return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ae.WrongData;const o=new Ee;o.DateTime=(new Date).toISOString(),o.ImageType=e.ImageType,o.Base64Image=e.Base64Image,o.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?o.OwnerGuid=e.OwnerGuid:o.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const i=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(o.Guid),8e3,!1);if(ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==i||null==i.Status)return this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),ae.UnknownError;if(i.Status==ae.ResourceDoesNotExists)return this._logger.Error(be.ServiceName,"Cannot edit picture - picture not exists."),ae.OperationNotPermitted;if(i.Status==ae.OK){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ue(o),8e3,!1);return ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),ae.UnknownError):e.Status}return this._logger.Error(be.ServiceName,"Cannot edit picture - cannot get current picture status."),ae.Error}catch(e){return this._logger.Error(be.ServiceName,`Cannot edit picture! ${e}`),ae.FatalError}}))}DeletePictureAsync(e){var t;return ke(this,void 0,void 0,(function*(){try{if(""==e.Guid||null==e.Guid)return this._logger.Error(be.ServiceName,"Cannot delete picture - guid is empty."),ae.WrongData;const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Me(e.Guid),8e3,!1);return ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==n||null==n.Status?(this._logger.Error(be.ServiceName,"Cannot edit picture - unknown error!"),ae.UnknownError):n.Status}catch(e){return this._logger.Error(be.ServiceName,`Cannot delete picture! ${e}`),ae.FatalError}}))}GetPicturesInfoAsync(){var e;return ke(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Pe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures info - unknown error!"),new Te(ae.UnknownError,"NoDataInResult")):t.Status!=ae.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Te(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Te(ae.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ie;return t.DateTime=e.DateTime,t.Guid=e.Guid,t.OwnerGuid=e.OwnerGuid,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture info! ${e}`),new Te(ae.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){var t;return ke(this,void 0,void 0,(function*(){try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Re(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(be.ServiceName,"Cannot get picture - unknown error!"),new Te(ae.UnknownError,"NoDataInResult");switch(n.Status){case ae.ResourceDoesNotExists:return new Te(ae.ResourceDoesNotExists,"PictureNotFound");case ae.OK:if(null==n.Data)return new Te(ae.Error,"RespondedWithOKButNoData");const e=new Ne;return e.Base64Image=n.Data.Base64Image,e.DateTime=n.Data.DateTime,e.ImageType=n.Data.ImageType,e.Guid=n.Data.Guid,-1!=n.Data.OwnerGuid.indexOf("_")?(e.OwnerGuid=n.Data.OwnerGuid.substring(0,n.Data.OwnerGuid.indexOf("_")),e.OwnerIdentity=n.Data.OwnerGuid.substring(n.Data.OwnerGuid.indexOf("_")+1)):n.Data.Guid.includes("profilePicture")?(e.OwnerIdentity=n.Data.Guid.substring(n.Data.Guid.indexOf("_")+1),e.OwnerGuid=n.Data.OwnerGuid):n.Data.Guid.includes("devices_group")?(e.OwnerIdentity=n.Data.Guid.substring(0,n.Data.Guid.lastIndexOf("_")),e.OwnerGuid=n.Data.OwnerGuid):(e.OwnerGuid=n.Data.OwnerGuid,e.OwnerIdentity=""),e;default:return new Te(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture! ${e}`),new Te(ae.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){var e;return ke(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Oe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(be.ServiceName,"Cannot get pictures - unknown error!"),new Te(ae.UnknownError,"NoDataInResult")):t.Status!=ae.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Te(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Te(ae.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ne;return t.Base64Image=e.Base64Image,t.DateTime=e.DateTime,t.Guid=e.Guid,t.ImageType=e.ImageType,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(be.ServiceName,`Cannot get pictures! ${e}`),new Te(ae.FatalError,"ExceptionOccurred")}}))}}be.ServiceName="PictureService";class Ne extends De{set DateTime(e){this._dateTime=e}}class Ee{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=me.Device,this.DateTime=""}}class Ie{constructor(){this._guid="",this._dateTime="",this._ownerGuid="",this._ownerIdentity=""}get Guid(){return this._guid}get DateTime(){return this._dateTime}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}set Guid(e){this._guid=e}set DateTime(e){this._dateTime=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}}class Re extends ie{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ce.Get,this.Data=e}}class Pe extends ie{constructor(){super(),this.Resource="/pictures/info",this.Method=ce.Get}}class Oe extends ie{constructor(){super(),this.Resource="/pictures/list",this.Method=ce.Get}}class Ue extends ie{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ce.Put,this.Data=e}}class Me extends ie{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ce.Delete,this.Data=e}}var xe=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Fe{constructor(){this._connection=null,this._connection=ev.Get(Gt.ServiceName),this._pictureService=ev.Get(be.ServiceName),this._sessionService=ev.Get(je.ServiceName)}CanEditUser(e){const t=this._sessionService.User;return e.Guid===(null==t?void 0:t.Guid)||this.CanEditUsersOfAccessLevel(e.AccessLevel)}CanEditUsersOfAccessLevel(e){var t;const n=null===(t=this._sessionService.User)||void 0===t?void 0:t.AccessLevel;if(void 0===n)return!1;switch(e){case he.Support:return n===he.Support;case he.Installator:return n>=he.Installator;case he.Admin:default:return n>=he.Admin}}GetServiceName(){return Fe.ServiceName}GetUsersAsync(){var e,t;return xe(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new We,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ae.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new He;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)==ae.NoData)return Promise.resolve([]);throw null===(t=s.Log)||void 0===t||t.Debug(Fe.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){var t,n;return xe(this,void 0,void 0,(function*(){if(""===e)return Promise.resolve(null);null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ae.OK)return null===(n=s.Log)||void 0===n||n.Debug(Fe.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const o=new He;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){var n;return xe(this,void 0,void 0,(function*(){if(null!=e.Guid&&""!=e.Guid)return new Te(ae.WrongData,"GuidMustBeEmpty");const r=new Be;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 s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new $e(r),2e4,!1);return ev.Get(Ge.ServiceName).ClearCache(),null==s||null==s.Status?new Te(ae.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Te(s.Status,s.Data))}))}UpdateUserAsync(e){var t;return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.WrongData,"GuidCannotBeEmpty");const n=new Be;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 $e(n),2e4,!1);return ev.Get(Ge.ServiceName).ClearCache(),null==r||null==r.Status?new Te(ae.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Te(r.Status,r.Data))}))}ChangePasswordAsync(e,t){var n;return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Te(ae.ResourceIsNotAvailable,"CannotGetUser");const s=new Be;s.Guid=e.Guid,s.Password=t,s.AccessLevel=r.AccessLevel,s.Email=r.Email;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new $e(s),2e4,!1);return null==o||null==o.Status?new Te(ae.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Te(o.Status,o.Data))}))}DeleteUserAsync(e){var t,n;return xe(this,void 0,void 0,(function*(){if(""===e)return ae.WrongData;null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new qe(e),2e4,!1);return ev.Get(Ge.ServiceName).ClearCache(),null==r||null==r.Status?ae.FatalError:(r.Status!=ae.OK&&(null===(n=s.Log)||void 0===n||n.Debug(Fe.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}))}GetUserProfilePictureAsync(e){return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.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 ev.Get(Ge.ServiceName).ClearCache(),null!=e.Type?t:e}return new Te(ae.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ae.WrongData,"GuidCannotBeEmpty");let n=new De;n.ImageType=me.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(ev.Get(Ge.ServiceName).ClearCache(),r.Type==ae.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ae.OK?new Te(ae.OK,"PictureSet"):new Te(e,"PictureServiceError")}if(null!=r.Type)return new Te(ae.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ae.OK?new Te(ae.OK,"PictureSet"):new Te(e,"PictureServiceError")}}))}}Fe.ServiceName="UsersService";class Le extends ie{constructor(e){super(),this.Resource="/users/user",this.Method=ce.Get,this.Data=e}}class Be{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=pe.Unknown,this.AccessLevel=he.Any}}class $e extends ie{constructor(e){super(),this.Resource="/users/user",this.Method=ce.Put,this.Data=e}}class We extends ie{constructor(){super(),this.Resource="/users/list",this.Method=ce.Get}}class qe extends ie{constructor(e){super(),this.Resource="/users/user",this.Method=ce.Delete,this.Data=e}}class He{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=pe.Unknown,this._accessLevel=he.Any,this._localization=ge.En_Us}get Guid(){return this._guid}set Guid(e){this._guid=e}get CloudGuid(){return this._cloudGuid}set CloudGuid(e){this._cloudGuid=e}get Name(){return this._name}set Name(e){this._name=e}get Surname(){return this._surname}set Surname(e){this._surname=e}get Phone(){return this._phone}set Phone(e){this._phone=e}get AccessLevel(){return this._accessLevel}set AccessLevel(e){this._accessLevel=e}get Email(){return this._email}set Email(e){this._email=e}get IsAccountOnline(){return this._isAccountOnline}set IsAccountOnline(e){this._isAccountOnline=e}get IsActive(){return this._isAccountActive}set IsActive(e){this._isAccountActive=e}get IsBanned(){return this._isAccountBanned}set IsBanned(e){this._isAccountBanned=e}get NotificationChannels(){return this._notificationChannels}set NotificationChannels(e){this._notificationChannels=e}get Gender(){return this._gender}set Gender(e){this._gender=e}get Localization(){return this._localization}set Localization(e){this._localization=e}GetUserProfilePictureAsync(){return ev.Get(Fe.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return ev.Get(Fe.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var Ve=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class je{constructor(){this._onUserLoggedInEvent=new n,this._onUserLoggedOutEvent=new n,this._email="",this._password="",this._authToken="",this._loginTaskCompletionSource=this.CreateSessionCompletionSourceAsync(),this._alreadySubsribedToNetworkEvents=!1,this._user=null}CreateSessionCompletionSourceAsync(){var e;return Ve(this,void 0,void 0,(function*(){null===(e=s.Log)||void 0===e||e.Debug(je.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{let t=n=>{var r;null===(r=s.Log)||void 0===r||r.Debug(je.ServiceName,`Logged in as ${n.Name}, completing CreateSessionCompletionSourceAsync()`),e(),this.OnUserLoggedInEvent().Unsubscribe(t)};this.OnUserLoggedInEvent().Subscribe(t)}))}))}RestoreSessionAsync(){var e;return Ve(this,void 0,void 0,(function*(){null===(e=s.Log)||void 0===e||e.Debug(je.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0!==this._user&&null!==this._user&&(yield this.UserLogInAsync(this._email,this._password))}))}WaitForSessionCreationAsync(){return Ve(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){var e,t;return Ve(this,void 0,void 0,(function*(){var n=new ie;n.Resource="/users/user/logout",n.Method=ce.Put,this._email="",this._password="",(yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ae.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=s.Log)||void 0===e||e.Debug(je.ServiceName,"User has been logged out.")):null===(t=s.Log)||void 0===t||t.Debug(je.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return Ve(this,void 0,void 0,(function*(){switch(e){case de.Disconnected:case de.Failed:break;case de.Connected:ev.Get(je.ServiceName).RestoreSessionAsync()}}))}AuthorizeAppAsync(e){var t,n,r,o;return Ve(this,void 0,void 0,(function*(){var i=ev.Get(Gt.ServiceName);const a=yield i.SendAndWaitForResponseAsync(new ze(e),2e4,!1);if(a.Status==ae.OK&&null!=a.Data){this._authToken=e;var c=new He;return this._user=c,c.AccessLevel=a.Data.AccessLevel,c.Email=a.Data.Email,this._email=a.Data.Email,c.Gender=a.Data.Gender,c.Guid=a.Data.Guid,c.IsAccountOnline=a.Data.IsAccountOnline,c.Name=a.Data.Name,c.IsActive=a.Data.IsActive,c.IsBanned=a.Data.IsBanned,c.Phone=a.Data.Phone,c.Surname=a.Data.Surname,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,i.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(t=s.Log)||void 0===t||t.Debug(je.ServiceName,`Did logging in succeded?: ${a.Status==ae.OK}`),this._onUserLoggedInEvent.Invoke(this._user),c}return a.Status===ae.OperationNotPermitted?(null===(n=s.Log)||void 0===n||n.Debug(je.ServiceName,`App login response: ${a.Data}`),fe.AuthDisabled):a.Status===ae.ResourceDoesNotExists?(null===(r=s.Log)||void 0===r||r.Debug(je.ServiceName,`App login response: ${a.Data}`),fe.MethodNotSupported):(null===(o=s.Log)||void 0===o||o.Debug(je.ServiceName,`App login response: ${a.Data}`),fe.WrongAuthData)}))}UserLogInAsync(e,t){var n,r;return Ve(this,void 0,void 0,(function*(){var o=ev.Get(Gt.ServiceName);const i=yield o.SendAndWaitForResponseAsync(new Je(e,t),2e4,!1);if(i.Status==ae.OK&&null!=i.Data){this._email=e,this._password=t;var a=new He;return this._user=a,a.AccessLevel=i.Data.AccessLevel,a.Email=i.Data.Email,a.Gender=i.Data.Gender,a.Guid=i.Data.Guid,a.IsAccountOnline=i.Data.IsAccountOnline,a.Name=i.Data.Name,a.IsActive=i.Data.IsActive,a.IsBanned=i.Data.IsBanned,a.Phone=i.Data.Phone,a.Surname=i.Data.Surname,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,o.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(n=s.Log)||void 0===n||n.Debug(je.ServiceName,`Did logging in succeded?: ${i.Status==ae.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return null===(r=s.Log)||void 0===r||r.Debug(je.ServiceName,`User login response: ${i.Data}`),fe.WrongAuthData}))}GetServiceName(){return je.ServiceName}}je.ServiceName="SessionService";class Ke{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class ze extends ie{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=ce.Put}}class Je extends ie{constructor(e,t){super(),this.Data=new Ke(e,t),this.Resource="/users/user/login",this.Method=ce.Put}}var Ye=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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{GetServiceName(){return Xe.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new Ae,this._onExitedConfigurationEvent=new Ae,this._onConfigurationTimeCheckedEvent=new n,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{ev.Get(je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Ye(this,void 0,void 0,(function*(){this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),this._didConfigurationChange&&ev.Get(Ge.ServiceName).ClearCache(),e()}))))})),this._connection=ev.Get(Gt.ServiceName),this._session=ev.Get(je.ServiceName),this._localStorage=ev.Get(o.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{ev.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{ev.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke()}))}GetControllerSystemTimeAsync(){var e;return Ye(this,void 0,void 0,(function*(){try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new st,8e3,!1);return null==t||null==t.Status?ae.Error:t.Status!=ae.OK?t.Status:null==t.Data?ae.ResourceIsNotAvailable:new Date(t.Data)}catch(e){return ev.Get(r.ServiceName).Error(Xe.ServiceName,`Cannot get current controller time! ${e}`),ae.FatalError}}))}SetControllerSystemTimeAsync(e){var t;return Ye(this,void 0,void 0,(function*(){try{var n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ot(e.toISOString()),8e3,!1);return null==n||null==n.Status?ae.Error:n.Status}catch(e){return ev.Get(r.ServiceName).Error(Xe.ServiceName,`Cannot set current controller time! ${e}`),ae.FatalError}}))}StartNtpTimeSynchronizationAsync(){var e;return Ye(this,void 0,void 0,(function*(){try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new it,8e3,!1);return null==t||null==t.Status?ae.Error:t.Status}catch(e){return ev.Get(r.ServiceName).Error(Xe.ServiceName,`Cannot set current controller time! ${e}`),ae.FatalError}}))}FactoryResetAsync(e){var t,n;return Ye(this,void 0,void 0,(function*(){try{ev.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ze,2e3,!1))||void 0===n?void 0:n.Status;if(r==ae.OK){let t=300,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),ev.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}RollbackLastUpdateAsync(e){var t,n;return Ye(this,void 0,void 0,(function*(){try{ev.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new et,2e3,!1))||void 0===n?void 0:n.Status;if(r==ae.OK){let t=420,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),ev.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}RestartControllerAsync(e){var t,n;return Ye(this,void 0,void 0,(function*(){try{ev.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Qe,2e3,!1))||void 0===n?void 0:n.Status;if(r==ae.OK){let t=240,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield se.Delay(1e3*t),ev.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}DidCofigurationChangeAsync(){return Ye(this,void 0,void 0,(function*(){return yield this._synchronizationTaskCompletionSource,Promise.resolve(this._didConfigurationChange)}))}GetLastKnownConfigurationChangeTime(){var e;const t=null===(e=this._localStorage)||void 0===e?void 0:e.Read(this.GetServiceName(),"last_configuration_time");return null!=t?new Date(t):new Date}SaveLastConfigurationChangeTime(e){var t;null===(t=this._localStorage)||void 0===t||t.Save(this.GetServiceName(),"last_configuration_time",e.toString())}EnterConfigurationModeAsync(){var e;return Ye(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,ev.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new tt,2e4,!1)}))}ExitConfigurationModeAsync(){var e;return Ye(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,ev.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new nt,2e4,!1),ev.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){var e;return Ye(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new rt,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ae.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return Ye(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),ev.Get(Ge.ServiceName).ClearCache(),!0)}))}}Xe.ServiceName="ControllerConfigurationService";class Qe extends ie{constructor(){super(),this.Resource="/controller/restart",this.Method=ce.Post}}class Ze extends ie{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ce.Post}}class et extends ie{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ce.Post}}class tt extends ie{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ce.Put}}class nt extends ie{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ce.Put}}class rt extends ie{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ce.Get}}class st extends ie{constructor(){super(),this.Resource="/system/time",this.Method=ce.Get}}class ot extends ie{constructor(e){super(),this.Resource="/system/time",this.Method=ce.Put,this.Data=e}}class it extends ie{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=ce.Put}}var at,ct,ut,lt,dt,ht,pt,gt,ft,vt,mt,yt,wt,St,_t,At,Ct,Tt,Dt=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Gt{constructor(){this._logPackets=!1,this._pingInterval=5e3,this._disconnectedOnPurpose=!1,this._defaultPacketsBrokerAddress="br1.tr7.pl",this._serversBrokerAddress="https://broker.tr7.pl",this._serversBrokerAddressList=["https://broker.tr7.pl","https://dev-brokers.lavva.tech"],this._allBrokersChecked=!1,this._address="br1.tr7.pl",this._isEstabilished=!1,this._timeout=1e4,this._dataReceivedEvent=new n,this._pongReceivedEvent=new Ae,this._authorizationReceivedEvent=new n,this._registrationReceivedEvent=new n,this._connectionStateChangedEvent=new n,this._errorOccuredEvent=new n,this._log=ev.Get(r.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._packetsBrokerServers=["br1.tr7.pl","br1.exala.pl"],this._lastReceivedPacketTime=Date.now()}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}GetControllerSerialNumber(){return this._serialId}GetControllerPin(){return this._PIN}GetServiceName(){return Gt.ServiceName}EnablePacketsLogging(){this._logPackets=!0}DisablePacketsLogging(){this._logPackets=!1}InitializeConnection(){if(this._controllerConfiguration=ev.Get(Xe.ServiceName),this._cache=ev.Get(Ge.ServiceName),this._session=ev.Get(je.ServiceName),this._connection){try{this._connection.stop()}catch(e){}this._connection=void 0}if(!this._address)throw new Error("Domain is not set");if(!this._serialId)throw new Error("SerialId is not set");if(!this._PIN)throw new Error("PIN is not set");this._connection=(new ne).withUrl(`https://${this._address}/broker`).build(),this._dataReceivedEvent.Subscribe((e=>{this._lastReceivedPacketTime=Date.now()})),setInterval((()=>Dt(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval)}GetAuthorizationInfo(){return null!=this._serialId&&null!=this._PIN?new _e(this._serialId,this._PIN):null}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._defaultPacketsBrokerAddress=e,this._address=e}GetServerAddressAsync(){return Dt(this,void 0,void 0,(function*(){try{let e=yield fetch(`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`);if(200===e.status){let t=yield e.text();return t?(this._log.Debug(Gt.ServiceName,`Got server address: ${t}`),t):(this._log.Error(Gt.ServiceName,`Failed to get server address, status: ${e.status}`),null)}return this._allBrokersChecked?(this._allBrokersChecked=!1,null):204===e.status?(this.swapBrokersAsync(!1),this.GetServerAddressAsync()):(this._log.Error(Gt.ServiceName,`Failed to get server address, status: ${e.status}`),null)}catch(e){return this._log.Error(Gt.ServiceName,e),null}}))}ConnectAsync(e){return Dt(this,void 0,void 0,(function*(){return this._address=e,yield this.connectAsync()}))}AuthorizeAsync(e){return new Promise(((t,n)=>Dt(this,void 0,void 0,(function*(){var n;let r=0,s=e=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),this._log.Debug(Gt.ServiceName,`Got authorization result: ${e}`),t(e)};r=window.setTimeout((()=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),t(!1)}),2e3),this._log.Debug(Gt.ServiceName,`Authorizing to cloud using: ${e.SerialNumber} PIN: ${e.PIN}`),this._authorizationReceivedEvent.Subscribe(s),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)}))))}ConnectAndAuthorizeAsync(e){return Dt(this,void 0,void 0,(function*(){ev.WorksInContextOf=e.SerialNumber,this._serialId=e.SerialNumber,this._PIN=e.PIN;var t=yield this.GetServerAddressAsync();if(t&&null!=t){this._log.Debug(Gt.ServiceName,`Got packets broker address: ${t}`),this.SetDefaultPacketsBrokerAddress(t);let r=yield this.connectAsync();if(r!=le.Connected)return r;var n=yield this.AuthorizeAsync(e);if(!n){if(yield this.swapBrokersAsync(),!this._allBrokersChecked)return this.ConnectAndAuthorizeAsync(e);this._allBrokersChecked=!1}return n?le.Connected:le.AuthorizationFailed}{let t=le.ControllerIsNotConnected;this._log.Warning(Gt.ServiceName,"Server did not return packets broker address, trying to connect to known brokers.");for(let n of this._packetsBrokerServers){this._log.Warning(Gt.ServiceName,`Testing connection to ${n}`),this.SetDefaultPacketsBrokerAddress(n);try{yield this.DisconnectAsync()}catch(e){}this._log.Warning(Gt.ServiceName,`Connecting to server: ${n}`);let r=yield this.connectAsync();if(this._log.Warning(Gt.ServiceName,`Connection result: ${r}`),r==le.Connected){if(yield this.AuthorizeAsync(e))return t=le.Connected,t;this._log.Warning(Gt.ServiceName,`Failed to authorize in ${n}`)}}return t}}))}swapBrokersAsync(e=!0){return Dt(this,void 0,void 0,(function*(){e&&(yield this.DisconnectAsync());var t=this._serversBrokerAddressList.lastIndexOf(this._serversBrokerAddress);t+1<this._serversBrokerAddressList.length?(this._serversBrokerAddress=this._serversBrokerAddressList[t+1],this._log.Debug(`Changing address of next broker from: ${this._serversBrokerAddressList[t]} to: ${this._serversBrokerAddressList[t+1]}`)):(this._log.Debug(`All brokers checked, changing address to first one: ${this._serversBrokerAddressList[0]}`),this._allBrokersChecked=!0,this._serversBrokerAddress=this._serversBrokerAddressList[0])}))}connectAsync(){var e,t,n,r,s,o,i,a,c;return Dt(this,void 0,void 0,(function*(){if(le.FailedToConnect,!this._address)return Promise.resolve(le.ControllerIsNotConnected);this._disconnectedOnPurpose&&(this._disconnectedOnPurpose=!1),this._connectionStateChangedEvent,this.InitializeConnection(),null===(e=this._connection)||void 0===e||e.onclose((()=>Dt(this,void 0,void 0,(function*(){var e,t;if(this._disconnectedOnPurpose?this._log.Info(Gt.ServiceName,"Connection closed on demand."):this._log.Error(Gt.ServiceName,"Connection closed"),ev.Get(je.ServiceName).CreateSessionCompletionSourceAsync(),this.FireConnectionStateChanged(),(null===(e=this._connection)||void 0===e?void 0:e.state)===W.Disconnected&&!this._disconnectedOnPurpose)return yield null===(t=this._connection)||void 0===t?void 0:t.start(),null!=this._connection?(yield this.AuthorizeAsync(new _e(this._serialId,this._PIN)),this._log.Info(Gt.ServiceName,"Reconnected from onClose"),this.FireConnectionStateChanged()):le.FailedToConnect})))),null===(t=this._connection)||void 0===t||t.onreconnected((()=>Dt(this,void 0,void 0,(function*(){return yield this.AuthorizeAsync(new _e(this._serialId,this._PIN)),this._log.Info(Gt.ServiceName,"Reconnected from onreconnected"),this.FireConnectionStateChanged()})))),null===(n=this._connection)||void 0===n||n.onreconnecting((()=>(this._log.Warning(Gt.ServiceName,"Reconnecting..."),this.FireConnectionStateChanged()))),yield null===(r=this._connection)||void 0===r?void 0:r.start(),null===(s=this._connection)||void 0===s||s.on("Pong",(()=>{this._log.Debug(Gt.ServiceName,"Pong received <-"),this._pongReceivedEvent.Invoke()})),null===(o=this._connection)||void 0===o||o.on("Registration",(e=>{var t;null===(t=this._registrationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(i=this._connection)||void 0===i||i.on("Authorization",(e=>{var t;null===(t=this._authorizationReceivedEvent)||void 0===t||t.Invoke(e)})),null===(a=this._connection)||void 0===a||a.on("SendError",((e,t)=>Dt(this,void 0,void 0,(function*(){e.startsWith("NotAuthorized:")?(this._log.Error(Gt.ServiceName,"Failed to authorize!"),yield this.AuthorizeAsync(new _e(this._serialId,this._PIN))):(this._log.Error(Gt.ServiceName,`Server returned error: ${e} ${t}`),this._errorOccuredEvent.Invoke([e,t]))}))));let u=this._dataReceivedEvent;return null===(c=this._connection)||void 0===c||c.on("Data",((e,t)=>{const n=JSON.parse(t);(this._logPackets||!0===window.packets)&&this._log.Debug(Gt.ServiceName,`Received data:\n${JSON.stringify(n,null,2)}`),u.Invoke(n)})),null!=this._connection?this.FireConnectionStateChanged():le.FailedToConnect}))}FireConnectionStateChanged(){var e;const t=this._connectionStateChangedEvent;switch(null===(e=this._connection)||void 0===e?void 0:e.state){case W.Connected:return t.Invoke(de.Connected),le.Connected;case W.Connecting:return t.Invoke(de.Connecting),le.Connected;case W.Disconnected:return t.Invoke(de.Disconnected),le.FailedToConnect;case W.Disconnecting:return t.Invoke(de.Disconnecting),le.FailedToConnect;case W.Reconnecting:return t.Invoke(de.Reconnecting),le.FailedToConnect}return le.FailedToConnect}DisconnectAsync(){var e;return Dt(this,void 0,void 0,(function*(){this._disconnectedOnPurpose=!0,yield null===(e=this._connection)||void 0===e?void 0:e.stop()}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===W.Connected}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,r)}SendAndWaitForResponseWithRepeatAsync(e,t,n,r=!0,s=!0){var o,i,a;return Dt(this,void 0,void 0,(function*(){if(e.Method===ce.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.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(((o,i)=>Dt(this,void 0,void 0,(function*(){let a=i=>Dt(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;s&&this._log.Debug(Gt.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===ce.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ae.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(),o(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,s))),o(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(Gt.ServiceName,t),i(new p(t))}),t),!(yield this.SendAsync(e,s))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;i(new Error(t))}}))))}))}SendAndHandleResponseAsync(e,t,n,r=!0){var s;return Dt(this,void 0,void 0,(function*(){let o=0;const i=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(s=this._session)||void 0===s?void 0:s.WaitForSessionCreationAsync()),new Promise(((s,a)=>Dt(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(Gt.ServiceName,t),a(new p(t))}),t);let u=l=>Dt(this,void 0,void 0,(function*(){var d,h,p;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(o);const g=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Gt.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)===ae.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(),s(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ae.MultiDataResponseStart:case ae.MultiDataResponse:n(l),o=c();break;case ae.MultiDataResponseStop:n(l),this._dataReceivedEvent.Unsubscribe(u),s();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),o=c(),!(yield this.SendAsync(e,r))){let t=`Failed to send request, resource: ${e.Resource} method: ${e.Method} transaction id: ${e.TransactionId}`;a(new Error(t))}}))))}))}PingControllerAsync(){var e;return Dt(this,void 0,void 0,(function*(){if((null===(e=this._connection)||void 0===e?void 0:e.state)!==W.Connected)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new ie;return t.Resource="/system/ping",t.Method=ce.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SendAsync(e,t=!1){if(!this.IsConnected())throw new Error("Connection is not established");return new Promise((n=>{var r;this._logPackets||!0===window.packets?this._log.Debug(Gt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId} data:\n${JSON.stringify(e,null,2)}`):t&&this._log.Debug(Gt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId}`),null===(r=this._connection)||void 0===r||r.invoke("SendTo",this._serialId,e).then((()=>{n(!0)})).catch((e=>{this._log.Error(Gt.ServiceName,`${e}`),n(!1)}))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}}Gt.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(at||(at={})),(yt=ct||(ct={}))[yt.Default=0]="Default",yt[yt.Monostable=1]="Monostable",yt[yt.Bistable=2]="Bistable",yt[yt.Gate=3]="Gate",yt[yt.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"}(ut||(ut={}));class kt{constructor(){this._type=dt.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(St=lt||(lt={}))[St.Unknown=0]="Unknown",St[St.BlindMotor=1]="BlindMotor",St[St.DinModule=2]="DinModule",St[St.DinModuleWithAntenna=3]="DinModuleWithAntenna",St[St.Remote=4]="Remote",St[St.RemoteForBlinds=5]="RemoteForBlinds",St[St.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",St[St.MovementSensor=7]="MovementSensor",St[St.TemperatureSensor=8]="TemperatureSensor",St[St.HumiditySensor=9]="HumiditySensor",St[St.DinPowerMeter=10]="DinPowerMeter",St[St.Intercom=11]="Intercom",St[St.SecurityCamera=12]="SecurityCamera",St[St.Multisensor=13]="Multisensor",St[St.FloodSensor=14]="FloodSensor",St[St.FlushMountedReceiver=15]="FlushMountedReceiver",St[St.FlushMountedBlindController=16]="FlushMountedBlindController",St[St.FlushMountedDimmer=17]="FlushMountedDimmer",St[St.FlushMountedRelay=18]="FlushMountedRelay",St[St.FlushMountedGateController=19]="FlushMountedGateController",St[St.WindSensor=20]="WindSensor",St[St.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",St[St.AirPressureSensor=22]="AirPressureSensor",St[St.LightBrightnessSensor=23]="LightBrightnessSensor",St[St.ReedSensor=24]="ReedSensor",St[St.FlushMountedTransceiver=25]="FlushMountedTransceiver",St[St.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",St[St.WallMountedThermoregulator=27]="WallMountedThermoregulator",St[St.ImpulseCounter=28]="ImpulseCounter",St[St.FlushMountedFacadeController=29]="FlushMountedFacadeController",St[St.WallMountedGateController=30]="WallMountedGateController",St[St.WallMountedRGBLightController=31]="WallMountedRGBLightController",St[St.WallMountedDimmer=32]="WallMountedDimmer",St[St.WallMountedRemote=33]="WallMountedRemote",St[St.DinRelay=34]="DinRelay",St[St.DinReceiver=35]="DinReceiver",St[St.DinBlindController=36]="DinBlindController",St[St.DinTransceiver=37]="DinTransceiver",St[St.SocketPlugIn=38]="SocketPlugIn",St[St.WallMountedRelay=39]="WallMountedRelay",St[St.Retransmitter=40]="Retransmitter",(wt=dt||(dt={})).Unknown="Unknown",wt.SetBlindPosition="IBlindPosition",wt.SetBlindPositionSimple="IBlindPositionSimple",wt.SetBlindMicroventilation="IMicroventilation",wt.TurnOff="IChannelOff",wt.TurnOn="IChannelOn",wt.TurnOnWithTime="IChannelOnWithTime",wt.TogleState="IChannelSwitchState",wt.SetLightBrightnessDynamicly="IDynamicLightBrightness",wt.SetLightBrightness="ILightBrightness",wt.SetLightColor="ILightColor",wt.SetLightTemperature="ILightTemperature",wt.PairDevice="IPair",wt.UnpairDevice="IUnpair",wt.IdentifyDevice="IIdentifyDevice",wt.GetChannelsState="IGetDeviceState",wt.GetPowerMeasurements="IGetPowerMeasurements",wt.GetAvailableData="IGetAvailableData",wt.MultipleDataRequest="IMultipleDataRequest",wt.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",wt.SetTemperature="IChangeTemperature",wt.SetGatePosition="IGatePosition",wt.SetGatewayPosition="IGatewayPosition",wt.ChangeGatePositionPulse="IGatePulse",wt.ChangeGatewayPositionPulse="IGatewayPulse",wt.SetFacadePosition="IFacadePosition",wt.GetFacadeType="IGetFacadeType",wt.LightRGBW="ILightRGBW",wt.PreciseGateControl="IPreciseGateControl";class bt{constructor(){this._type=ht.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Tt=ht||(ht={})).Unknown="Unknown",Tt.BatteryState="IBatteryState",Tt.BinarySensorState="IBinarySensor",Tt.BlindOpenCloseTime="IBlindOpenCloseTime",Tt.BlindPosition="IBlindPosition",Tt.BlindRemoteButtonState="IBlindsControlButton",Tt.MeasuredBrightness="IBrightness",Tt.RemoteButtonState="IButtonState",Tt.ChannelOnOffState="IChannelOnOff",Tt.IntercomState="IIntercom",Tt.DoorBellState="IDoorBell",Tt.FacadeRemoteButtonState="IFacadeControlButton",Tt.FacadePosition="IFacadeState",Tt.FacadeType="IFacadeType",Tt.FloodSensorState="IFloodSensor",Tt.GatePosition="IGatePosition",Tt.GatewayPosition="IGatewayPosition",Tt.GateControllerHealth="IGateControllerHealth",Tt.HumiditySensorState="IHumiditySensor",Tt.LightBrightness="ILightBrightness",Tt.LightColor="ILightColor",Tt.LightWarmth="ILightTemperature",Tt.LightTreshold="ILightTreshold",Tt.MovementSensorState="IMovementSensor",Tt.OnlineCamera="IOnlineCamera",Tt.OvercurrentProtectionState="IOvercurrentProtection",Tt.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",Tt.ReedState="IReedState",Tt.SignalStrength="ISignalStrength",Tt.SmokeSensorState="ISmokeSensor",Tt.MeasuredTemperature="ITemperature",Tt.VibrationSensorState="IVibrationSensor",Tt.MeasuredWindSpeed="IWindSpeed",Tt.WindThreshold="IWindThreshold",Tt.MeasuredEnergy="IEnergy",Tt.MeasuredDistance="DistanceSensor",Tt.BlindCalibration="BlindCalibration",Tt.ConfigurationState="ConfigurationState",Tt.CurrentWindThreshold="CurrentWindThreshold",Tt.CurrentLightThreshold="CurrentLightThreshold",Tt.WindSpeedState="WindSpeed",Tt.TamperProtectionState="ITamperProtection",Tt.PressureSensorState="IPressureSensor",Tt.LightRGBWState="ILightRGBW",(Ct=pt||(pt={}))[Ct.NotResponding=0]="NotResponding",Ct[Ct.Working=1]="Working",Ct[Ct.Broken=2]="Broken",Ct[Ct.FirmareUpgradeMode=3]="FirmareUpgradeMode",(At=gt||(gt={}))[At.TwoWay=1]="TwoWay",At[At.OneWay=2]="OneWay",At[At.ConditionalTwoWay=3]="ConditionalTwoWay",(_t=ft||(ft={}))[_t.Unknown=-1]="Unknown",_t[_t.Multipurpose=0]="Multipurpose",_t[_t.Controller=1]="Controller",_t[_t.Driver=2]="Driver",_t[_t.Receiver=3]="Receiver",_t[_t.Remote=4]="Remote",_t[_t.Sensor=5]="Sensor",_t[_t.Scene=6]="Scene";class Nt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=at.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"}(vt||(vt={})),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"}(mt||(mt={}));class Et{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=mt.Unknown}}var It,Rt,Pt,Ot,Ut,Mt,xt,Ft,Lt,Bt,$t,Wt,qt,Ht,Vt,jt,Kt,zt,Jt,Yt,Xt,Qt,Zt,en,tn,nn,rn,sn,on,an;class cn{constructor(){this._type="",this._data=null,this._typeAsEnum=ht.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 s=0;for(r=Object.getOwnPropertySymbols(e);s<r.length;s++)t.indexOf(r[s])<0&&Object.prototype.propertyIsEnumerable.call(e,r[s])&&(n[r[s]]=e[r[s]])}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=It||(It={}))[an.Confident=0]="Confident",an[an.Unconfident=1]="Unconfident";class un extends cn{constructor(e){super(),this.TypeAsEnum=ht.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class ln{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Rt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Rt||(Rt={})),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"}(Pt||(Pt={}));class dn extends cn{constructor(e){super(),this.TypeAsEnum=ht.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class hn extends cn{constructor(e){super(),this.TypeAsEnum=ht.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class pn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Ot.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(Ot||(Ot={}));class gn extends cn{constructor(e){super(),this.TypeAsEnum=ht.ReedState,this.Type="ReedState",this.Data=e.state}}class fn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=!1,this.Time=""}}class vn extends cn{constructor(e){super(),this.TypeAsEnum=ht.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return Ut.UnableToMove;case 201:return Ut.MotorOverheatedPleaseWait;default:return Ut.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(Ut||(Ut={}));class mn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class yn extends cn{constructor(e){super(),this.TypeAsEnum=ht.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class wn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Mt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(Mt||(Mt={}));class Sn extends cn{constructor(e){super(),this.TypeAsEnum=ht.LightColor,this.Type="LightColorState",this.Data=e.state}}class _n{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class An extends cn{constructor(e){super(),this.TypeAsEnum=ht.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class Cn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Temperature=0,this.Time=""}}class Tn extends cn{constructor(e){super(),this.TypeAsEnum=ht.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class Dn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Brightness=0,this.Time=""}}class Gn extends cn{constructor(e){super(),this.TypeAsEnum=ht.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class kn{constructor(){this.Channel=0,this.StateReliability=It.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 bn extends cn{constructor(e){super(),this.TypeAsEnum=ht.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Nn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Ft.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"}(Ft||(Ft={}));class En extends cn{constructor(e){super(),this.TypeAsEnum=ht.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class In{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Brightness=0,this.Time=""}}class Rn extends cn{constructor(e){super(),this.TypeAsEnum=ht.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class Pn{constructor(){this.Channel=0,this.StateReliability=It.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"}(Lt||(Lt={}));class On extends cn{constructor(e){super(),this.TypeAsEnum=ht.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Bt||(Bt={}));class Un extends cn{constructor(e){super(),this.TypeAsEnum=ht.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Mn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Intensity=0,this.Movement=$t.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}($t||($t={}));class xn extends cn{constructor(e){super(),this.TypeAsEnum=ht.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class Fn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Wt.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"}(Wt||(Wt={}));class Ln extends cn{constructor(e){super(),this.TypeAsEnum=ht.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class Bn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=qt.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"}(qt||(qt={}));class $n extends cn{constructor(e){super(),this.TypeAsEnum=ht.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"}(Ht||(Ht={}));class Wn extends cn{constructor(e){super(),this.TypeAsEnum=ht.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class qn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.PositionType=Vt.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"}(Vt||(Vt={}));class Hn extends cn{constructor(e){super(),this.TypeAsEnum=ht.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"}(jt||(jt={}));class Vn extends cn{constructor(e){super(),this.TypeAsEnum=ht.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"}(Kt||(Kt={}));class jn extends cn{constructor(e){super(),this.TypeAsEnum=ht.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"}(zt||(zt={}));class Kn extends cn{constructor(e){super(),this.TypeAsEnum=ht.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class zn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Type=Jt.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"}(Jt||(Jt={}));class Jn extends cn{constructor(e){super(),this.TypeAsEnum=ht.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Yt||(Yt={}));class Yn extends cn{constructor(e){super(),this.TypeAsEnum=ht.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class Xn{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=Xt.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(Xt||(Xt={}));class Qn extends cn{constructor(e){super(),this.TypeAsEnum=ht.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"}(Qt||(Qt={}));class Zn extends cn{constructor(e){super(),this.TypeAsEnum=ht.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class er extends cn{constructor(e){super(),this.TypeAsEnum=ht.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class tr extends cn{constructor(e){super(),this.TypeAsEnum=ht.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class nr extends cn{constructor(e){super(),this.TypeAsEnum=ht.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class rr extends cn{constructor(e){super(),this.TypeAsEnum=ht.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class sr extends cn{constructor(e){super(),this.TypeAsEnum=ht.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class or{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.WindThreshold=Zt.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"}(Zt||(Zt={}));class ir extends cn{constructor(e){super(),this.TypeAsEnum=ht.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"}(en||(en={}));class ar extends cn{constructor(e){super(),this.TypeAsEnum=ht.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class cr{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Value=0,this.Time=""}}class ur extends cn{constructor(e){super(),this.TypeAsEnum=ht.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class lr{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.State=tn.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(tn||(tn={})),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"}(nn||(nn={}));class dr extends cn{constructor(e){super(),this.TypeAsEnum=ht.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class hr{constructor(){this.Channel=0,this.StateReliability=It.Unconfident,this.Pressure=0,this.Time="",this.PressureType=rn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(rn||(rn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(sn||(sn={}));class pr extends cn{constructor(e){super(),this.TypeAsEnum=ht.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(on||(on={}));class gr extends cn{constructor(e){super(),this.TypeAsEnum=ht.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class fr{constructor(){this._onDeviceStateChangedEvent=new n,this._onDeviceStateRefreshedOrChangedEvent=new n,this._onDeviceTasksExecutionChangedOnChannelsEvent=new n,this._onDeviceFirmwareVersionChangedEvent=new n,this._iconType=lt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=pt.Working,this._deviceType=ft.Unknown,this._communicationWay=gt.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==fr._devicesService&&(fr._devicesService=ev.Get(ho.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;fr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),fr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),fr._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===ft.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!==dt.SetBlindPositionSimple))}return!1}get States(){return r.DoesThrowStackTrace?ev.Get(ho.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():fr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return fr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return fr._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,s=function*(){try{const t=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new vr(this,e),2e4,!1);switch(t.Status){case ae.OK:return this._name=e,ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),new Ce(ve.Changed,"");case ae.WrongData:if("DeviceNotFound"==t.Data)return new Ce(ve.Failed,"DeviceNotFound");break;case ae.NoPermissionsToCallGivenResource:return new Ce(ve.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new Ce(ve.ControllerResponseTimeout,""):new Ce(ve.UnknownError,"")}return new Ce(ve.Unknown,"")},new((r=void 0)||(r=Promise))((function(e,o){function i(e){try{c(s.next(e))}catch(e){o(e)}}function a(e){try{c(s.throw(e))}catch(e){o(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((s=s.apply(t,n||[])).next())}));var t,n,r,s}ExecuteTaskAsync(e){return fr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class vr extends ie{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ce.Put;const n=new mr;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class mr{constructor(){this.DeviceGuid="",this.Name=""}}var yr,wr,Sr,_r,Ar,Cr,Tr=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Dr{constructor(){this._device=new fr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=ct.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this._configurations={},this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new n,this._onChannelStateChangedEvent=new n,this._onChannelStateRefreshedOrChangedEvent=new n,null==Dr._devicesService&&(Dr._devicesService=ev.Get(ho.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 Tr(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new Gr;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 Gr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new kr;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 Gr;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 Gr;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Gr;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 Gr;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 Gr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){var t;return Tr(this,void 0,void 0,(function*(){try{const n=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new br(e),2e4,!1);switch(ev.Get(Ge.ServiceName).ClearCache(),yield ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),n.Status){case ae.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 Ce(ve.Changed,"");case ae.WrongData:if("DeviceNotFound"===n.Data)return null===(t=s.Log)||void 0===t||t.Error("Failed to change channel configuration, referenced device does not exist!"),new Ce(ve.WrongData,"DeviceNotFound");break;case ae.FatalError:return new Ce(ve.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new Ce(ve.ControllerResponseTimeout,"")}return new Ce(ve.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 r.DoesThrowStackTrace?ev.Get(ho.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Dr._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,Dr._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(mt.Failed)}}Dr._devicesService=null;class Gr{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new kr}}class kr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=ct.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class br extends ie{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ce.Put,this.Data=e}}(Cr=yr||(yr={}))[Cr.TurnOn=0]="TurnOn",Cr[Cr.TurnOff=1]="TurnOff",Cr[Cr.ToggleState=2]="ToggleState",Cr[Cr.SetBlindPosition=3]="SetBlindPosition",Cr[Cr.SetLightColor=4]="SetLightColor",Cr[Cr.SetLightTemperature=5]="SetLightTemperature",Cr[Cr.SetLightBrightness=6]="SetLightBrightness",Cr[Cr.SetTemperature=7]="SetTemperature",Cr[Cr.GetState=8]="GetState",Cr[Cr.TurnOnWithTimeout=9]="TurnOnWithTimeout",Cr[Cr.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",Cr[Cr.IdentifyDevice=11]="IdentifyDevice",Cr[Cr.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",Cr[Cr.SetBlindMicroventilation=13]="SetBlindMicroventilation",Cr[Cr.GatewayPulse=25]="GatewayPulse",Cr[Cr.GatePulse=26]="GatePulse",Cr[Cr.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",Cr[Cr.GetFacadeType=30]="GetFacadeType",Cr[Cr.LightRGBW=31]="LightRGBW",Cr[Cr.SetGatePositionPrecise=32]="SetGatePositionPrecise";class Nr{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 Er{constructor(){this._taskType=dt.GetChannelsState,this._featureType=yr.GetState,this._channel=0,this._guid=Nr.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 Ir extends Er{constructor(){super(),this.Temperature=0,this.FeatureType=yr.SetTemperature,this.TaskType=dt.SetTemperature}}class Rr extends Er{constructor(){super(),this.FeatureType=yr.TurnOff,this.TaskType=dt.TurnOff}}class Pr extends Er{constructor(){super(),this.FeatureType=yr.TurnOn,this.TaskType=dt.TurnOn}}class Or extends Er{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=yr.TurnOnWithTimeout,this.TaskType=dt.TurnOnWithTime}}class Ur extends Er{constructor(){super(),this.Brightness=0,this.FeatureType=yr.SetLightBrightness,this.TaskType=dt.SetLightBrightness}}class Mr extends Er{constructor(){super(),this.FeatureType=yr.ToggleState,this.TaskType=dt.TogleState}}class xr extends Er{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=yr.SetLightColor,this.TaskType=dt.SetLightColor}}class Fr extends Er{constructor(){super(),this.Temperature=0,this.FeatureType=yr.SetLightTemperature,this.TaskType=dt.SetLightTemperature}}class Lr extends Er{constructor(){super(),this.Action=wr.Stop,this.Position=0,this.FeatureType=yr.SetBlindPosition,this.TaskType=dt.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(wr||(wr={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Sr||(Sr={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(_r||(_r={}));class Br extends Er{constructor(){super(),this.Brightness=0,this.FeatureType=yr.SetLightBrightnessDynamicly,this.TaskType=dt.SetLightBrightnessDynamicly}}class $r extends Er{constructor(){super(),this.FeatureType=yr.IdentifyDevice,this.TaskType=dt.IdentifyDevice}}class Wr extends Er{constructor(){super(),this.Data=new qr,this.FeatureType=yr.SetBlindOpenCloseTime,this.TaskType=dt.SetBlindOpenCloseTime}}class qr{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class Hr extends Er{constructor(){super(),this.FeatureType=yr.GetState,this.TaskType=dt.GetChannelsState}}class Vr extends Er{constructor(){super(),this.Position=0,this.FeatureType=yr.SetBlindMicroventilation,this.TaskType=dt.SetBlindMicroventilation}}class jr extends Er{constructor(){super(),this.FeatureType=yr.GatePulse,this.TaskType=dt.ChangeGatewayPositionPulse}}class Kr extends Er{constructor(){super(),this.FeatureType=yr.GatewayPulse,this.TaskType=dt.ChangeGatewayPositionPulse}}class zr extends Er{constructor(){super(),this.FacadeAction=Ar.Stop,this.Tilt=0,this.Position=0,this.FeatureType=yr.SetFacadePositionAndTilt,this.TaskType=dt.SetFacadePosition}}class Jr extends Er{constructor(){super(),this.FeatureType=yr.GetFacadeType,this.TaskType=dt.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"}(Ar||(Ar={}));class Yr{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class Xr extends Er{constructor(){super(),this.Data=new Yr,this.FeatureType=yr.LightRGBW,this.TaskType=dt.LightRGBW}}var Qr=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Zr{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return Zr.ServiceName}RegisterManuallyPairedDevicesProtocol(e){ev.Get(r.ServiceName).Debug(Zr.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return Qr(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 Qr(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=t?t.AddManuallyPairedDeviceAsync(e):(ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),mt.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}Zr.ServiceName="ManualDeviceService";class es{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var ts,ns=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 rs{constructor(){this._connection=null,this._localDb=null,this._connection=ev.Get(Gt.ServiceName),this._localDb=ev.Get(o.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return ns(this,void 0,void 0,(function*(){let r=new ss(e,t,n),s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ae.OK){const r=new as;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(rs.ServiceName,this.GetLocalDbName(e,t),r)}return s.Status}))}ReadAsync(e,t,n){return ns(this,void 0,void 0,(function*(){let r=new os(e,t);if(!n){const n=this._localDb.Read(rs.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new es;return t.Data=JSON.parse(e.Data),t.IsGlobal=e.IsGlobal,t.ResourceGuid=e.ResourceGuid,t}}let s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ae.OK){const e=new es;return e.ResourceGuid=s.ResourceGuid,e.Data=JSON.parse(s.Data),e.IsGlobal=s.IsGlobal,e}return s.Status}))}RemoveAsync(e,t){return ns(this,void 0,void 0,(function*(){let n=new is(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return rs.ServiceName}}rs.ServiceName="RemoteStorageService";class ss extends ie{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ce.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class os extends ie{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ce.Get,this.ResourceGuid=e,this.Global=t}}class is extends ie{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ce.Delete,this.ResourceGuid=e,this.Global=t}}class as extends ie{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class cs{constructor(){this.Longitude=0,this.Latitude=0}}class us{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"}(ts||(ts={}));var ls,ds,hs,ps,gs,fs,vs,ms,ys,ws,Ss,_s,As,Cs,Ts,Ds,Gs,ks=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 bs{IsControllerGeolocationSetAsync(){return ks(this,void 0,void 0,(function*(){let e=new Ns,t=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ae.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return ks(this,void 0,void 0,(function*(){return new Promise(((e,t)=>ks(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){var t,n;return ks(this,void 0,void 0,(function*(){let r=new Is;r.Data.Latitude=e.Latitude,r.Data.Longitude=e.Longitude,null===(t=s.Log)||void 0===t||t.Warning(bs.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(r)}`);let o=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(r,15e3,!1);switch(null===(n=s.Log)||void 0===n||n.Warning(bs.ServiceName,`${JSON.stringify(o)}`),ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null==o?void 0:o.Status){case ae.OK:return new Te(ts.OK,"");case ae.NoPermissionToPerformThisOperation:case ae.NoPermissionsToCallGivenResource:return new Te(ts.NoPermissions,"");case ae.UserIsNotLoggedIn:return new Te(ts.UserIsNotLoggedIn,"");default:return new Te(ts.UnknownError,"")}}))}GetControlllerGeolocationAsync(){var e,t;return ks(this,void 0,void 0,(function*(){let n=new Es;null===(e=s.Log)||void 0===e||e.Warning(bs.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=s.Log)||void 0===t||t.Warning(bs.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ae.OK){let e=new us;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 bs.ServiceName}}bs.ServiceName="GeolocationService";class Ns extends ie{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ce.Get}}class Es extends ie{constructor(){super(),this.Resource="/geolocation/get",this.Method=ce.Get}}class Is extends ie{constructor(){super(),this.Data=new cs,this.Resource="/geolocation/save",this.Method=ce.Put}}!function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(ls||(ls={}));class Rs{constructor(){this._comparisonParams=new Map,this.Type=ht.Unknown,this.DeviceGuid="",this.ComparisonMethod=ds.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Nn&&(this.Type=ht.BatteryState),e instanceof Xn&&(this.Type=ht.BinarySensorState),e instanceof mn&&(this.Type=ht.BlindPosition),e instanceof Dn&&(this.Type=ht.LightBrightness),e instanceof In&&(this.Type=ht.MeasuredBrightness),e instanceof wn&&(this.Type=ht.RemoteButtonState),e instanceof ln&&(this.Type=ht.ChannelOnOffState),e instanceof pn&&(this.Type=ht.DoorBellState),e instanceof Pn&&(this.Type=ht.MeasuredEnergy),e instanceof lr&&(this.Type=ht.FloodSensorState),e instanceof qn&&(this.Type=ht.GatePosition),e instanceof _n&&(this.Type=ht.LightColor),e instanceof Cn&&(this.Type=ht.LightWarmth),e instanceof fn&&(this.Type=ht.ReedState),e instanceof kn&&(this.Type=ht.MeasuredTemperature),e instanceof zn&&(this.Type=ht.HumiditySensorState),e instanceof Fn&&(this.Type=ht.BlindRemoteButtonState),e instanceof Bn&&(this.Type=ht.FacadeRemoteButtonState),e instanceof Mn&&(this.Type=ht.MovementSensorState),e instanceof Pn&&(this.Type=ht.MeasuredEnergy),e instanceof hr&&(this.Type=ht.PressureSensorState),e instanceof cr&&(this.Type=ht.WindSpeedState),e instanceof or&&(this.Type=ht.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class Ps{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class Os{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"}(ds||(ds={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(hs||(hs={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(ps||(ps={}));class Us{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"}(gs||(gs={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(fs||(fs={})),(Gs=vs||(vs={}))[Gs.Unknown=0]="Unknown",Gs[Gs.Second=1]="Second",Gs[Gs.Minute=2]="Minute",Gs[Gs.Hour=3]="Hour",Gs[Gs.Day=4]="Day",Gs[Gs.DayOfWeek=5]="DayOfWeek",Gs[Gs.Month=6]="Month",Gs[Gs.Year=7]="Year",Gs[Gs.Date=8]="Date",Gs[Gs.Time=9]="Time",Gs[Gs.WeatherType=11]="WeatherType",Gs[Gs.CompareNumbers=12]="CompareNumbers",Gs[Gs.CompareBooleans=13]="CompareBooleans",Gs[Gs.DeviceState=14]="DeviceState",Gs[Gs.Timer=15]="Timer",Gs[Gs.Temperature=17]="Temperature",Gs[Gs.DaysOfWeek=18]="DaysOfWeek",Gs[Gs.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",Gs[Gs.SceneExecuted=20]="SceneExecuted",(Ds=ms||(ms={}))[Ds.Unknown=0]="Unknown",Ds[Ds.Equal=1]="Equal",Ds[Ds.NotEqueal=2]="NotEqueal",Ds[Ds.BiggerThan=3]="BiggerThan",Ds[Ds.SmallerThan=4]="SmallerThan",Ds[Ds.BiggerThanOrEqual=5]="BiggerThanOrEqual",Ds[Ds.SmallerThanOrEqual=6]="SmallerThanOrEqual",Ds[Ds.OneOfBothIsTrue=7]="OneOfBothIsTrue",Ds[Ds.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"}(ys||(ys={})),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"}(ws||(ws={})),(Ts=Ss||(Ss={})).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";class Ms 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"}(_s||(_s={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(As||(As={}));class xs{constructor(e,t="Cube"){this._result=null,this._tmp=new Fs,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=ev.Get(Zs.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Nr.NewGuid())}SetSequenceName(e){this._sequenceName=e,this._editingExistingSequence&&null!=this._result&&(this._result.Name=e)}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==Cs.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 xs;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=Nr.NewGuid(),e.RightArgumentType==Cs.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Nr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==Cs.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!=Cs.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),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=ms.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=ms.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=Nr.NewGuid(),this._tmp.HandledType=vs.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=Cs.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=ms.Equal)throw new Ks("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new Ks("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=ms.Equal;else{if(null==n)throw new Ks("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Cs.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Nr.NewGuid(),this._tmp.HandledType=vs.Unknown,this._tmp.LeftArgumentType=Cs.Null,this._tmp.ConditionType=ms.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=Cs.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=ms.Equal){return this._tmp.Guid=Nr.NewGuid(),this._tmp.HandledType=vs.DaysOfWeek,this._tmp.LeftArgumentType=Cs.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Cs.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=ms.Equal){return this._tmp.Guid=Nr.NewGuid(),this._tmp.HandledType=vs.Timer,this._tmp.LeftArgumentType=Cs.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Cs.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=ms.Equal){return this._tmp.Guid=Nr.NewGuid(),this._tmp.HandledType=vs.Time,this._tmp.LeftArgumentType=Cs.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Cs.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=ms.Equal){return this._tmp.Guid=Nr.NewGuid(),this._tmp.HandledType=vs.DeviceState,this._tmp.LeftArgumentType=Cs.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=Cs.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Nr.NewGuid(),this._tmp.HandledType=vs.SceneExecuted,this._tmp.LeftArgumentType=Cs.ArgumentAsConditionInfo,this._tmp.ConditionType=ms.Equal,this._tmp.AtMeetCondition=!0;const t=new Us;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=Cs.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new $s;t.Channel=e.GetCheckDeviceState().Channel,t.ComparisonMethod=e.ComparisonMethod;let n={},r=e.GetComparisonParams().entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[hs[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case ht.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case ht.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case ht.LightBrightness:case ht.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case ht.RemoteButtonState:case ht.ChannelOnOffState:case ht.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[Lt[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case ht.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case ht.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case ht.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case ht.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.SmokeSensorState:throw new Ms("Unsupported device state!");case ht.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case ht.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case ht.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.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 ht.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case ht.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case ht.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case ht.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case ht.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case ht.Unknown:t.CheckedDeviceState={};break;default:throw new Ms("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case ht.BatteryState:return ys.BatteryState;case ht.BinarySensorState:return ys.BinarySensor;case ht.BlindPosition:return ys.BlindPosition;case ht.LightBrightness:return ys.LightBrightness;case ht.RemoteButtonState:return ys.ButtonState;case ht.ChannelOnOffState:return ys.ChannelOnOff;case ht.DoorBellState:return ys.DoorBell;case ht.MeasuredEnergy:return ys.Energy;case ht.FloodSensorState:return ys.FloodSensor;case ht.GatePosition:return ys.GatePosition;case ht.MeasuredBrightness:return ys.Brightness;case ht.LightColor:return ys.LightColor;case ht.LightWarmth:return ys.LightTemperature;case ht.ReedState:return ys.ReedState;case ht.SmokeSensorState:return ys.SmokeSensor;case ht.MeasuredTemperature:return ys.Temperature;case ht.HumiditySensorState:return ys.Humidity;case ht.BlindRemoteButtonState:return ys.BlindsControlButton;case ht.FacadeRemoteButtonState:return ys.FacadeControlButton;case ht.MovementSensorState:return ys.Movement;case ht.PressureSensorState:return ys.AirPressure;case ht.WindSpeedState:return ys.WindSpeed;case ht.CurrentWindThreshold:return ys.WindThreshold;default:return ys.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=Cs.Null)return e(t.RightArgument,n);t.RightArgumentType=Cs.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Ws)};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 Fs,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),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=ms.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=ms.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!=Cs.Condition){if(n.RightArgumentType==Cs.Condition)return t(n.RightArgument,r);throw new zs(`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 zs(`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 Fs,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),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=ms.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=ms.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==Cs.Condition?e.RightArgument.Guid:"",this._prevSeqGuid=null!=t?t.Guid:""):this._prevSeqGuid==n&&(this._prevSeqGuid=null!=t?t.Guid:""))},r=(e,s)=>{if(e.Guid!=s){if(t=e,e.RightArgumentType==Cs.Null)throw new zs(`Cannot remove sequence, sequence with given guid ${s} not found!`);return r(e.RightArgument,s)}null==t?this._result=null:(t.RightArgument=e.RightArgument,t.RightArgumentType=e.RightArgumentType),n(e,s)};if(null==this._result)throw new zs("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=Cs.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),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=ms.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=ms.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!=Cs.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new zs("Sequence are not initialized! Not found root sequence.");return this._editingExistingSequence&&e(this._result),{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)))}}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:re.GenerateMd5(JSON.stringify(this._tmpTask))}}ParseDeviceTask(e){const t=new Hs;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==dt.SetBlindPosition||e instanceof Lr?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==dt.SetLightColor||e instanceof xr?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==dt.SetLightTemperature||e instanceof Fr?t.Data.Temperature=e.Temperature:e.TaskType==dt.SetLightBrightness||e instanceof Ur?t.Data.Brightness=e.Brightness:e.TaskType==dt.SetTemperature||e instanceof Ir?t.Data.Temperature=e.Temperature:e.TaskType==dt.TurnOnWithTime||e instanceof Or?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==dt.SetLightBrightnessDynamicly||e instanceof Br?t.Data.Brightness=e.Brightness:e.TaskType==dt.SetBlindOpenCloseTime||e instanceof Wr?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==dt.SetBlindMicroventilation||e instanceof Vr?t.Data.Position=e.Position:e.TaskType==dt.SetFacadePosition||e instanceof zr?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):(e.TaskType==dt.LightRGBW||e instanceof Xr)&&(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),t}DelayTask(e){const t=new Vs;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:re.GenerateMd5(JSON.stringify(t))}}NotifyTask(e){throw new Ys("Funcionality will be available in the future.")}LockExecutionTask(e){const t=new js;if(t.LockType=e.LockType,t.LockType==As.Timeout&&"00:00:00"!=t.LockEndHour)throw new Ys("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:re.GenerateMd5(JSON.stringify(t))}}AddTask(){const e=t=>{if(t.RightArgumentType!=Cs.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 Hs&&t.Tasks.DevicesTasks.push(structuredClone(this._tmpTask)),t.Tasks.ControllerTasks.push(structuredClone(this._tmpTask)),this._tmpTask=null,ev.Get(r.ServiceName).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),{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)))}}EditTask(e){const t=n=>{if(n.RightArgumentType!=Cs.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 Js("Task not found, cannot edit!");this._tmpTask instanceof Hs&&null!=n.Tasks.DevicesTasks&&(n.Tasks.DevicesTasks=n.Tasks.DevicesTasks.map((t=>re.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t))),n.Tasks.ControllerTasks=n.Tasks.ControllerTasks.map((t=>re.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t)),this._tmpTask=null,ev.Get(r.ServiceName).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),{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)))}}RemoveTask(e){const t=(e,n)=>{if(e.RightArgumentType!=Cs.Null)return t(e.RightArgument,n);{const t=e.Tasks.ControllerTasks.filter((e=>re.GenerateMd5(JSON.stringify(e))!=n));if(e.Tasks.ControllerTasks=null==t?[]:t,e.Tasks.DevicesTasks.any()){const t=e.Tasks.DevicesTasks.filter((e=>re.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 dt.Unknown:throw new Ks("Unsupported task type!");case dt.SetBlindPosition:case dt.SetBlindPositionSimple:return yr.SetBlindPosition;case dt.SetBlindMicroventilation:return yr.SetBlindMicroventilation;case dt.TurnOff:return yr.TurnOff;case dt.TurnOn:return yr.TurnOn;case dt.TurnOnWithTime:return yr.TurnOnWithTimeout;case dt.TogleState:return yr.ToggleState;case dt.SetLightBrightnessDynamicly:return yr.SetLightBrightnessDynamicly;case dt.SetLightBrightness:return yr.SetLightBrightness;case dt.SetLightColor:return yr.SetLightColor;case dt.SetLightTemperature:return yr.SetLightTemperature;case dt.PairDevice:case dt.UnpairDevice:throw new Ks("Unsupported task type!");case dt.IdentifyDevice:return yr.IdentifyDevice;case dt.GetChannelsState:return yr.GetState;case dt.GetPowerMeasurements:case dt.GetAvailableData:case dt.MultipleDataRequest:throw new Ks("Unsupported task type!");case dt.SetBlindOpenCloseTime:return yr.SetBlindOpenCloseTime;case dt.SetTemperature:return yr.SetTemperature;case dt.ChangeGatePositionPulse:return yr.GatePulse;case dt.ChangeGatewayPositionPulse:return yr.GatewayPulse;case dt.SetFacadePosition:case dt.GetFacadeType:return yr.SetFacadePositionAndTilt;case dt.LightRGBW:return yr.LightRGBW;default:throw new Ks("Unsupported task type!")}}Build(){const e=t=>{if(t.RightArgumentType!=Cs.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==Cs.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}}class Fs{constructor(){this.Tasks=new Ws,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=vs.Unknown,this.ConditionType=ms.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=Cs.Null,this.RightArgumentType=Cs.Null,this.LeftArgument=new Bs({},Cs.Null),this.RightArgument=new Ls}}class Ls{constructor(){this.HandledType=0,this.Argument=null}}class Bs{constructor(e,t){this.Argument=e,this.HandledType=t}}class $s{constructor(){this.DeviceStateType=ys.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=ds.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Ws{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class qs{constructor(){this.RunParallel=!1,this.TaskType=gs.Unknown}}class Hs extends qs{constructor(){super(...arguments),this.TaskType=gs.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=yr.TurnOn}}class Vs extends qs{constructor(){super(...arguments),this.TaskType=gs.DelayTask,this.Delay="00:00:00"}}class js extends qs{constructor(){super(...arguments),this.TaskType=gs.LockExecution,this.LockType=As.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}!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"}(Cs||(Cs={}));class Ks extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class zs extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class Js extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class Ys extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var Xs,Qs=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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(){this._connection=ev.Get(Gt.ServiceName),this._configurationService=ev.Get(Xe.ServiceName)}GetServiceName(){return Zs.ServiceName}GetSequencesListAsync(){var e;return Qs(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new eo,12e3,!1);return ev.Get(r.ServiceName).Debug(`GetSequencesListAsync result:\n ${JSON.stringify(t)}}`),null==t?new Te(ls.OtherError,"Cannot get sequences list - response is null."):t.Status!=ae.OK?new Te(ls.OtherError,`Cannot get sequences list - controller responded with response code ${t.Status}.`):null==t.Data?new Te(ls.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):t.Data}))}GetSequenceAsync(e){var t;return Qs(this,void 0,void 0,(function*(){let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new to(n),12e3,!1);if(null==r)return new Te(ls.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ae.OK)return new Te(ls.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Te(ls.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");const s=r.Data;return this.MapSequence(s)}))}GetSequenceBuilder(e,t){return new xs(e,t)}CreateSequenceAsync(e){var t;return Qs(this,void 0,void 0,(function*(){try{yield this._configurationService.EnterConfigurationModeAsync(),ev.Get(r.ServiceName).Debug(`Creating sequence ${e.Name} json: \n${JSON.stringify(e)}`);const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new oo(e),2e4,!1);return null==n||null==n.Status?ae.Error:n.Status}catch(t){return ev.Get(r.ServiceName).Error(`Creating sequence ${e.Name} error: ${t}`),ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){var t;return Qs(this,void 0,void 0,(function*(){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 no(n),12e3,!1);if(null==r)return new Te(ls.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ae.WrongData:return new Te(ls.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ae.OK:return null==r.Data?new Te(ls.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Te(ls.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Te(ls.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){var t;return Qs(this,void 0,void 0,(function*(){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 ao(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}catch(e){return ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}EditSequenceAsync(e){var t;return Qs(this,void 0,void 0,(function*(){try{const n={Guid:e.Guid,Icon:e.Icon,Name:e.Name,Condition:e};yield this._configurationService.EnterConfigurationModeAsync();const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new io(n),2e4,!1);return null==r||null==r.Status?ae.Error:r.Status}catch(t){return ev.Get(r.ServiceName).Error(`Editing sequence ${e.Name} error: ${t}`),ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}EnableSequenceAsync(e){var t;return Qs(this,void 0,void 0,(function*(){let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new co(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}))}DisableSequenceAsync(e){var t;return Qs(this,void 0,void 0,(function*(){let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new uo(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}))}RunSequenceAsync(e){return Qs(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ae.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ae.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new Pr;switch(n.Channel=1,n.DeviceGuid=t,yield ev.Get(ho.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case mt.Executed:return ae.OK;case mt.DeviceNotFound:return ae.WrongData;default:return ae.Error}}))}GetUtilsAsync(){return Qs(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 Qs(this,void 0,void 0,(function*(){const e=ev.Get(bs.ServiceName),t=new cs;let n=!1;t.Latitude=49.9958888026741,t.Longitude=18.9172596008914;try{if(yield e.IsControllerGeolocationSetAsync()){const n=yield e.GetControlllerGeolocationAsync();n instanceof us&&(t.Latitude=n.Latitude,t.Longitude=n.Longitude)}}catch(e){ev.Get(r.ServiceName).Warning(`Cannot get localization data, using default values: 49.9958888026741, 18.9172596008914. Error: ${e}`)}const s=e=>{let n=7.95204*Math.sin(.01768*e+3.03217)+9.98906*Math.sin(.03383*e+3.4687)+4*(t.Longitude-15*Math.round(t.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()})()&&(n-=60),n},o=e=>Math.asin(-.39795*Math.cos(2*Math.PI*(e+10)/365)),i=e=>{const n=t.Latitude*Math.PI/180;let r=Math.sin(n)*Math.sin(e)/(Math.cos(n)*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 r=(u=t,Math.floor((u.valueOf()-new Date(u.getFullYear(),0,0).valueOf())/1e3/60/60/24));var u;const l=s(r),d=o(r),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&&!n?(n=!0,c(1)):(n=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.getMinutes()))},u=e=>{const t=new Date;t.setDate(t.getDate()+e);const r=(c=t,Math.floor((c.valueOf()-new Date(c.getFullYear(),0,0).valueOf())/1e3/60/60/24));var c;const l=s(r),d=o(r),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,l)),g=a(p);return new Date>g&&!n?(n=!0,u(1)):(n=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>u(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=Xs.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=gs.DeviceTask,e.RunParallel=!1})))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=Ss.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==Ss.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===Ss.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new ro;switch(n.HandledType=e.HandledType,t){case Ss.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case Ss.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case Ss.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case Ss.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case Ss.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case Ss.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case Ss.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case Ss.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case Ss.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case Ss.ArgumentAsDeviceState:{const t=new Rs;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?ds.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(hs[e[0]],new Ps(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(hs[e[0]],new Os(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case Ss.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return Ss[Xs[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case ys.BatteryState:return ht.BatteryState;case ys.BinarySensor:return ht.BinarySensorState;case ys.BlindPosition:return ht.BlindPosition;case ys.Brightness:return ht.MeasuredBrightness;case ys.ButtonState:return ht.RemoteButtonState;case ys.ChannelOnOff:return ht.ChannelOnOffState;case ys.DoorBell:return ht.DoorBellState;case ys.Energy:return ht.MeasuredEnergy;case ys.FloodSensor:return ht.FloodSensorState;case ys.GatePosition:return ht.GatePosition;case ys.LightBrightness:return ht.LightBrightness;case ys.LightColor:return ht.LightColor;case ys.LightTemperature:return ht.LightWarmth;case ys.ReedState:return ht.ReedState;case ys.SmokeSensor:return ht.SmokeSensorState;case ys.Temperature:return ht.MeasuredTemperature;case ys.Humidity:return ht.HumiditySensorState;case ys.BlindsControlButton:return ht.BlindRemoteButtonState;case ys.FacadeControlButton:return ht.FacadeRemoteButtonState;case ys.Movement:return ht.MovementSensorState;case ys.AirPressure:return ht.PressureSensorState;case ys.WindSpeed:return ht.WindSpeedState;case ys.WindThreshold:return ht.CurrentWindThreshold;default:return ht.Unknown}}CreateDeviceState(e,t,n){switch(n){case ht.BatteryState:return{Channel:t,StateReliability:It.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case ht.BinarySensorState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.BlindPosition:return{Channel:t,StateReliability:It.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case ht.LightBrightness:case ht.MeasuredBrightness:return{Channel:t,StateReliability:It.Unconfident,Brightness:e.Brightness,Time:""};case ht.RemoteButtonState:case ht.ChannelOnOffState:case ht.DoorBellState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(Lt[t],r);return{Channel:t,StateReliability:It.Unconfident,MeasurementParameters:n,Time:""}}case ht.FloodSensorState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.GatePosition:return{Channel:t,StateReliability:It.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case ht.LightColor:return{Channel:t,StateReliability:It.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case ht.LightWarmth:return{Channel:t,StateReliability:It.Unconfident,Temperature:e.Temperature,Time:""};case ht.ReedState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.SmokeSensorState:throw new Ms("Unsupported device state!");case ht.MeasuredTemperature:return{Channel:t,StateReliability:It.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case ht.HumiditySensorState:return{Channel:t,StateReliability:It.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case ht.BlindRemoteButtonState:return{Channel:t,StateReliability:It.Unconfident,State:e.State,Time:""};case ht.LightRGBWState:return{StateReliability:It.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case ht.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:It.Unconfident,State:e.State};case ht.MovementSensorState:return{Channel:t,Time:"",StateReliability:It.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case ht.PressureSensorState:return{Channel:t,Time:"",StateReliability:It.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case ht.WindSpeedState:return{Channel:t,Time:"",StateReliability:It.Unconfident,Value:e.Value};case ht.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:It.Unconfident,WindThreshold:e.WindThreshold};case ht.Unknown:return new cn;default:throw new Ms("Unsupported device state!")}}MapDeviceTask(e){let t=new Er,n=e;switch(ev.Get(r.ServiceName).Debug(`[TASK] object: ${JSON.stringify(n)}`),n.ControlFeature){case yr.TurnOn:t=new Pr,t.TaskType=dt.TurnOn;break;case yr.TurnOff:t=new Rr,t.TaskType=dt.TurnOff;break;case yr.ToggleState:t=new Mr,t.TaskType=dt.TogleState;break;case yr.SetBlindPosition:t=new Lr,t.TaskType=dt.SetBlindPosition,t.Action=n.Data.Action,t.Position=n.Data.Position;break;case yr.SetLightColor:t=new xr,t.TaskType=dt.SetLightColor,t.R=n.Data.R,t.G=n.Data.G,t.B=n.Data.B;break;case yr.SetLightTemperature:t=new Fr,t.TaskType=dt.SetLightTemperature,t.Temperature=n.Data.Temperature;break;case yr.SetLightBrightness:t=new Ur,t.TaskType=dt.SetLightBrightness,t.Brightness=n.Data.Brightness;break;case yr.SetTemperature:t=new Ir,t.TaskType=dt.SetTemperature,t.Temperature=n.Data.Temperature;break;case yr.GetState:t=new Hr,t.TaskType=dt.GetChannelsState;break;case yr.TurnOnWithTimeout:t=new Or,t.TaskType=dt.TurnOnWithTime,t.SwitchOffDelaySeconds=n.Data.SwitchOffDelaySeconds;break;case yr.SetLightBrightnessDynamicly:t=new Br,t.TaskType=dt.SetLightBrightnessDynamicly,t.Brightness=n.Data.Brightness;break;case yr.IdentifyDevice:t=new $r,t.TaskType=dt.IdentifyDevice;break;case yr.SetBlindOpenCloseTime:t=new Wr,t.TaskType=dt.SetBlindOpenCloseTime,t.Data.CloseTime=n.Data;break;case yr.SetBlindMicroventilation:t=new Vr,t.TaskType=dt.SetBlindMicroventilation,t.Position=n.Data.Position;break;case yr.GatewayPulse:t=new Kr,t.TaskType=dt.ChangeGatewayPositionPulse;break;case yr.GatePulse:t=new jr,t.TaskType=dt.ChangeGatePositionPulse;break;case yr.SetFacadePositionAndTilt:t=new zr,t.TaskType=dt.SetFacadePosition,t.Position=n.Data.Position,t.Tilt=n.Data.Tilt,t.FacadeAction=Ar.TiltAndPercentage;break;case yr.GetFacadeType:t=new Jr,t.TaskType=dt.GetFacadeType;break;case yr.LightRGBW:t=new Xr,t.TaskType=dt.LightRGBW,t.Data=n.Data}return t.Channel=n.Channel,t.DeviceGuid=n.DeviceGuid,t.FeatureType=n.ControlFeature,t.Guid=Nr.NewGuid(),t}MapControllerTasks(e){const t=[];ev.Get(r.ServiceName).Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let n of e){const e=new so;switch(e.TaskId=re.GenerateMd5(JSON.stringify(n)),n.TaskType){case gs.DeviceTask:e.TaskType=fs.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(n);break;case gs.DelayTask:e.TaskType=fs.DelayTask,e.Task.DelayTask={Delay:new Os(n.Delay)};break;case gs.NotifyTask:e.TaskType=fs.NotifyTask,e.Task.NotifyTask={Title:n.Title,Message:n.Message,NotifyType:n.NotifyType};break;case gs.LockExecution:case gs.LockExecution:e.TaskType=fs.LockExecution,ev.Get(r.ServiceName).Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(n)}`),e.Task.LockExecution={LockStartHour:new Os(n.LockStartHour),LockEndHour:new Os(n.LockEndHour),LockType:n.LockType,ResetLockScenesGuids:n.ResetLockScenesGuids};case gs.Unknown:}t.push(e)}return t}}Zs.ServiceName="ScenesService";class eo extends ie{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=ce.Get}}class to extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Get,this.Data=e}}class no extends ie{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=ce.Get,this.Data=e}}class ro{constructor(){this.HandledType=Xs.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"}(Xs||(Xs={}));class so{constructor(){this.TaskId="",this.TaskType=fs.Unknown,this.Task={}}}class oo extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Put,this.Data=e}}class io extends ie{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=ce.Put,this.Data=e}}class ao extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Delete,this.Data=e}}class co extends ie{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=ce.Post,this.Data=e}}class uo extends ie{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=ce.Post,this.Data=e}}var lo=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 ho{constructor(){this._devices=[],this._onDevicesTasksChangedEvent=new n,this._onDeviceFoundEvent=new n,this._onDeviceRegisteredEvent=new n,this._onDeviceRemovedEvent=new n,this._onDeviceFirmwareVersionChangedEvent=new n,this._onDeviceStateChangedEvent=new n,this._onDeviceStateRefreshedOrChangedEvent=new n,this._connection=null,this._session=null,this._controllerConfiguration=null,this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devicesChannelsStates=[],this._synchronizationTaskCompletionSource=null,this._deviceStatesSynchronizationTaskCompletionSource=null,this._connection=ev.Get(Gt.ServiceName),this._session=ev.Get(je.ServiceName),this._controllerConfiguration=ev.Get(Xe.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>lo(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),this._synchronizationTaskCompletionSource=new Promise((e=>{var t;null===(t=this._session)||void 0===t||t.OnUserLoggedInEvent().Subscribe((t=>lo(this,void 0,void 0,(function*(){var t;try{this._devices=yield this.GetPairedDevicesAsync()}catch(e){null===(t=s.Log)||void 0===t||t.Error(ho.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=>lo(this,void 0,void 0,(function*(){var t;try{yield this.WaitForSynchronizationAsync(),yield this.SyncDevicesStatesAsync()}catch(e){null===(t=s.Log)||void 0===t||t.Error(ho.ServiceName,`Failed to sync devices states: ${e}`)}this._synchronizedDevicesStates=!0,e()}))))})),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!=ft.Scene&&(null===(t=s.Log)||void 0===t||t.Debug(ho.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("/devices/blinds/times",(e=>{})),this._connection.SubscribeTo("/info/devices/device/state/changed",(e=>{const t=e.Data,n=this._devices.filter((e=>e.Guid==t.DeviceGuid));if(n.length>0){const e=n[0],r=this.MapApiDeviceStateToDeviceState(e,t);if(null!=r){this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r}),r.TypeAsEnum==ht.SignalStrength?e.Channels.forEach((n=>{let r=new $n(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==ht.BatteryState&&e.Channels.forEach((n=>{let r=new bn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})}));let n=e.States.find((e=>e.TypeAsEnum===r.TypeAsEnum&&e.Data.Channel===r.Data.Channel));if(n){let s=n.StatesComparisonData;n.Data=r.Data,s!==r.StatesComparisonData&&(this._onDeviceStateChangedEvent.Invoke({Device:e,State:r}),r.TypeAsEnum==ht.SignalStrength?e.Channels.forEach((n=>{let r=new $n(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==ht.BatteryState&&e.Channels.forEach((n=>{let r=new bn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})))}else e.States.push(r),this._onDeviceStateChangedEvent.Invoke({Device:e,State:r}),r.TypeAsEnum==ht.SignalStrength?e.Channels.forEach((n=>{let r=new $n(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==ht.BatteryState&&e.Channels.forEach((n=>{let r=new bn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{ev.Get(Ge.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(ho.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{ev.Get(Ge.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(ho.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}CheckIfDeviceUsedInScenesAsync(e){var t,n,r,o,i,a;return lo(this,void 0,void 0,(function*(){try{let a;if("string"==typeof e){const n=this.GetDevice(e);if(null==n)return null===(t=s.Log)||void 0===t||t.Error("Cannot check if device is used in scenes! Device with given guid not exists"),ae.ResourceDoesNotExists;a=n}else a=e;const u=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Go(a.Guid),2e4,!1);if(null==u||null==u.Status)return null===(r=s.Log)||void 0===r||r.Error("Cannot check if device is used in scenes! Response or status is null!"),ae.FatalError;if(u.Status!=ae.OK)return u.Status;if(null==u.Data)return null===(o=s.Log)||void 0===o||o.Error("Cannot check if device is used in scenes! No data!"),ae.FatalError;var c=yield ev.Get(Zs.ServiceName).GetSequencesListAsync();if(c instanceof Te)return null===(i=s.Log)||void 0===i||i.Error(`Cannot check if device is used in scenes! Cannot get sequence list, ScenesServiceErrorCode: ${c.Type}`),ae.Error;const l=new Eo;return l.DeviceGuid=a.Guid,u.Data.ConditionsAsCondition.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),u.Data.ConditionsAsTask.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),l}catch(e){return null===(a=s.Log)||void 0===a||a.Error(`Cannot check if device is used in scenes! ${e}`),ae.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)>=he.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)>=he.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return lo(this,void 0,void 0,(function*(){const e=ev.Get(rs.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return yield ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),e}))}DisableFastStatesSyncAsync(){return lo(this,void 0,void 0,(function*(){const e=ev.Get(rs.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return yield ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),e}))}IsFastStatesSyncEnabledAsync(){return lo(this,void 0,void 0,(function*(){const e=yield ev.Get(rs.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof es?e.Data:e!=ae.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return lo(this,void 0,void 0,(function*(){let t=ev.Get(Zr.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 lo(this,void 0,void 0,(function*(){var t=yield ev.Get(Zr.ServiceName).AddManuallyPairedDeviceAsync(e);return yield ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),t}))}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 po;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));null==e?(e=new po,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e)):(null!=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum))&&(e.States=e.States.where((e=>e.TypeAsEnum!=t.TypeAsEnum)).toArray()),e.States.push(t))}}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}WaitForDevicesStatesSynchronizationAsync(){return this._deviceStatesSynchronizationTaskCompletionSource}GetCurrentlyRunningTaksAsync(){var e;return lo(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new So,15e3,!1);(null==t?void 0:t.Status)==ae.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{var n;const r=e.split(";"),o=new Nt;o.DeviceGuid=r[0],o.Channel=Number(r[1]),o.Status=at.ExecutingTasks,t.push(o),null===(n=s.Log)||void 0===n||n.Debug(ho.ServiceName,`Device ${o.DeviceGuid} has task on channel ${o.Channel}`)})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new un(t);case"DoorBell":return new hn(t);case"ReedPosition":return new gn(t);case"BlindPosition":return new vn(t);case"ButtonState":return new yn(t);case"LightColor":return new Sn(t);case"LightTemperature":return new An(t);case"LightBrightness":return new Tn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new Gn(t);case"BatteryState":return new bn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new En(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new Rn(t);case"DistanceSensor":return new On(t);case"MovementSensor":return new Un(t);case"BlindsControlButton":return new xn(t);case"FacadeControlButton":return new Ln(t);case"SignalStrength":return new $n(t);case"GatePosition":return new Wn(t);case"GatewayPosition":return new Hn(t);case"GateControllerHealth":return new Vn(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new jn(t);case"HumiditySensor":case"HumidityState":return new Kn(t);case"VibrationSensor":return new Jn(t);case"DigitalInputSensor":return new Yn(t);case"ConfigurationState":return new Qn(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new Zn(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new er(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new tr(t);case"FacadePosition":case"FacadeState":return new nr(t);case"FacadeTypeState":return new rr(t);case"CurrentWindThreshold":return new sr(t);case"CurrentLightThreshold":return new ir(t);case"WindSpeed":return new ar(t);case"FloodSensor":return new ur(t);case"PressureState":return new dr(t);case"ITamperProtection":case"TamperProtection":return new pr(t);case"ILightRGBW":case"LightRGBW":return new gr(t);case"OnlineCamera":case"IOnlineCamera":return new dn(t);default:null===(n=s.Log)||void 0===n||n.Debug(ho.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return ho.ServiceName}SyncDevicesStatesAsync(e=!1){var t,n,r;return lo(this,void 0,void 0,(function*(){const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new fo,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync()){if(e){let e=new vo;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)==ae.OK}return(null==s?void 0:s.Status)==ae.OK}{let e=new vo;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)==ae.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,i,a=new fr;a.Guid=e.Guid,a.Name=e.DeviceName,a.ChannelsAmount=e.ChannelsNumber,a.DeviceType=e.DeviceType,a.CommunicationWay=e.CommunicationWay,a.DeviceState=e.DeviceState,a.IsEnabled=e.IsEnabled,a.IsVirtual=e.IsVirtual,a.SerialNumber=e.DeviceSerialNumber,a.ManufacturerGuid=e.ManufacturerGuid,a.ModelGuid=e.DeviceModelGuid,a.Model=e.DeviceModel,a.Name=e.DeviceName,a.ProtocolGuid=e.ProtocolGuid,void 0!==e.IconType&&null!==e.IconType?a.IconType=e.IconType:a.IconType=lt.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new kt;if(a.CommunicationWay==gt.OneWay)"IBlindPosition"===e&&(t.InterfaceType="IBlindPositionSimple");else switch(e){case"IGatePosition":t.InterfaceType="IGatePulse";break;case"IGatewayPosition":t.InterfaceType="IGatewayPulse";break;default:t.InterfaceType=e}a.AvailableTaskTypes.push(t)})),null===(r=e.AvailableResponses)||void 0===r||r.forEach((e=>{var t=new bt;t.InterfaceType=e,a.AvailableResponseTypes.push(t)})),null===(o=e.ChannelsConfiguration)||void 0===o||o.forEach((e=>{var t,n,r;try{var o=new Dr;o.Number=e.Channel,a.Channels.push(o),o.SetDevice(a),o.Name=e.ChannelName,o.ChannelGroups=e.GroupsGuids,o.IconName=e.IconName,o.IsHidden=e.Hidden,o.Configurations=e.Configurations,o.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(o.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(o.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{var t=new bt;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new kt;t.InterfaceType=e,o.AvailableTaskTypes.push(t)}))}catch(e){null===(r=s.Log)||void 0===r||r.Error(e)}}))}catch(e){null===(i=s.Log)||void 0===i||i.Error(e)}t.push(a)})),t)}GetPairedDevicesAsync(e=!1){var t,n,r;return lo(this,void 0,void 0,(function*(){if(this._synchronized&&!(yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync()))return Promise.resolve(this._devices);const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new go,15e3,!0);return null==o||void 0===o?[]:o.Status==ae.OK&&null!=o.Data?e?this.MapApiDevices(o.Data):this.MapApiDevices(o.Data.filter((e=>e.DeviceType!=ft.Scene))):(null===(r=s.Log)||void 0===r||r.Error(ho.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(e=!1){return lo(this,void 0,void 0,(function*(){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){var e,t;return lo(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new wo,15e3,!1);return null==n?[]:n.Status==ae.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==ft.Scene)).toArray():(null===(t=s.Log)||void 0===t||t.Error(ho.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){var e;return lo(this,void 0,void 0,(function*(){ev.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new mo,35e3,!1)}))}StopSearchingForDevices(){var e;return lo(this,void 0,void 0,(function*(){yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new yo,2e4,!1)}))}RegisterDeviceAsync(e){var t,n;return lo(this,void 0,void 0,(function*(){try{const n=new _o;n.Data=e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,2e4,!1);return ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==r?void 0:r.Status)==ae.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),mt.Executed):mt.Failed}catch(e){return null===(n=s.Log)||void 0===n||n.Error(ho.ServiceName,`Failed to paired devices: ${e}`),mt.ControllerResponseTimeout}}))}RemoveDeviceAsync(e,t=!1){var n;return lo(this,void 0,void 0,(function*(){var r=new Ao;t&&(r=new Co),r.Data=e.Guid;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,35e3,!1);return ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ae.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),mt.Executed):mt.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new ko;const r=t;switch(r.FeatureType){case yr.SetTemperature:n.Data=r.Temperature;break;case yr.SetLightBrightness:n.Data=r.Brightness;break;case yr.SetLightColor:n=new bo;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case yr.SetLightTemperature:n.Data=r.Temperature;break;case yr.SetGatePositionPrecise:switch(r.GateControlAction){case Sr.Open:n.Data=101;break;case Sr.Close:n.Data=102;break;case Sr.Stop:n.Data=103;break;case Sr.Percentage:n.Data=r.Position}break;case yr.SetBlindPosition:switch(r.Action){case wr.Open:n.Data=101;break;case wr.Close:n.Data=102;break;case wr.Stop:n.Data=103;break;case wr.Percentage:n.Data=r.Position}break;case yr.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case yr.SetBlindOpenCloseTime:n.Data=r.Data;break;case yr.SetBlindMicroventilation:n.Data=r.Position;break;case yr.SetFacadePositionAndTilt:n=new No;const t=r;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case yr.LightRGBW:n.Data=r.Data;break;case yr.GatePulse:case yr.GatewayPulse:n.Data=0;break;case yr.TurnOnWithTimeout:n.Data=r.SwitchOffDelaySeconds}return n.Channel=r.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=r.FeatureType,n}ExecuteDeviceTaskAsync(e,t){var n,r,o,i,a,c,u,l;return lo(this,void 0,void 0,(function*(){try{null===(n=s.Log)||void 0===n||n.Debug(ho.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new To(l);null===(r=s.Log)||void 0===r||r.Debug(ho.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 ae.OK:return mt.Executed;case ae.FatalError:return null===(i=s.Log)||void 0===i||i.Error(ho.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),mt.Failed;case ae.WrongData:if("DeviceNotFound"===t.Data)return mt.DeviceNotFound;break;case ae.Error:return"DeviceResponseTimeout"===t.Data?mt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(ho.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),mt.Failed)}}catch(e){return e.message.includes("timeout")?(null===(c=s.Log)||void 0===c||c.Error(ho.ServiceName,`Failed to get controller response in time.\n${e}`),mt.ControllerResponseTimeout):(null===(u=s.Log)||void 0===u||u.Error(ho.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),mt.Failed)}return mt.Unknown}catch(e){return null===(l=s.Log)||void 0===l||l.Error(ho.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),mt.Failed}}))}ExecuteDevicesTasksAsync(e){var t,n,r,o;return lo(this,void 0,void 0,(function*(){let i=[],a=[],c=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=c,c++,a.push(e)}const u=new Do(a);try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(u,12e4,!1);let o=-1;null===(n=null==r?void 0:r.Data)||void 0===n||n.forEach((t=>{var n,a;o++;let c=mt.Unknown;switch(t.Status){case ae.OK:return mt.Executed;case ae.FatalError:null===(n=s.Log)||void 0===n||n.Error(ho.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),c=mt.Failed;break;case ae.WrongData:"DeviceNotFound"===t.Data&&(c=mt.DeviceNotFound);break;case ae.Error:"DeviceResponseTimeout"===t.Data?c=mt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(ho.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),c=mt.Failed)}let u=0,l=new Et;for(const[t,n]of e){if(u==o){l.Device=t,l.Task=n,l.Channel=n.Channel,i.push(l);break}u++}}))}catch(t){if(t.message.includes("timeout")){null===(r=s.Log)||void 0===r||r.Error(ho.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new Et;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=mt.ControllerResponseTimeout}}else{null===(o=s.Log)||void 0===o||o.Error(ho.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new Et;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=mt.Failed}}}return i}))}}ho.ServiceName="DevicesService";class po{constructor(){this.Channel=0,this.States=[]}}class go extends ie{constructor(){super(),this.Resource="/devices/list",this.Method=ce.Get}}class fo extends ie{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ce.Get}}class vo extends ie{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ce.Get}}class mo extends ie{constructor(){super(),this.Resource="/devices/search",this.Method=ce.Post}}class yo extends ie{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ce.Post}}class wo extends ie{constructor(){super(),this.Resource="/devices/found/list",this.Method=ce.Get}}class So extends ie{constructor(){super(),this.Resource="/devices/tasks",this.Method=ce.Get}}class _o extends ie{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ce.Put}}class Ao extends ie{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ce.Put}}class Co extends ie{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ce.Put}}class To extends ie{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ce.Post,this.Data=e}}class Do extends ie{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ce.Post,this.Data=e}}class Go extends ie{constructor(e){super(),this.Resource="/logic/device/used",this.Method=ce.Get,this.Data=e}}class ko{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=yr.GetState,this.SequnceExecutionOrder=0}}class bo extends ko{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class No extends ko{constructor(){super(...arguments),this.FacadeAction=Ar.Stop,this.Tilt=0,this.Position=0}}class Eo{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class Io extends RangeError{constructor(e){super(`${e} was out of range. Must be non-negative and less than the size of the collection.`),this.paramName=e,this.name="ArgumentOutOfRangeException",this.stack=this.stack||(new Error).stack}}const Ro=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 Po extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Oo=(e,t)=>e===t;class Uo{constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Mo{constructor(e){this.dataFunc=e}[Symbol.asyncIterator](){const{dataFunc:e}=this;return async function*(){if(1===e.type)for(const t of e.generator())yield t;else for(const t of await e.generator())yield t}()}}class xo{constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class Fo extends Array{}const Lo=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Wo(e,t,n,r)}return n?$o(e,t,n):Bo(e,t)},Bo=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Po(Ro.NoElements);return n},$o=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},Wo=(e,t,n,r)=>{let s=t;for(const t of e)s=n(s,t);return r(s)},qo=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},Ho=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Vo=(e,t)=>t?Ko(e,t):jo(e),jo=e=>{for(const t of e)return!0;return!1},Ko=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},zo=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},Jo=e=>{if(Array.isArray(e)){if(0===e.length)throw new Po(Ro.NoElements);return new Uo((async function*(){for await(const t of e)yield t}))}return new Uo(e)},Yo=e=>Jo((async function*(){for(const t of e)yield t})),Xo=(e,t)=>new Mo({generator:t,type:e}),Qo=e=>Xo(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Zo=(e,t)=>{let n=0,r=0;if(t)for(const s of e)n+=t(s),r+=1;else for(const t of e)n+=t,r+=1;if(0===r)throw new Po(Ro.NoElements);return n/r},ei=async(e,t)=>{let n=0,r=0;for(const s of e)n+=await t(s),r+=1;if(0===r)throw new Po(Ro.NoElements);return n/r},ti=(e,t)=>{if(t<1)throw new Io("index");return new xo((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},ni=(e,t)=>new xo((function*(){yield*e,yield*t})),ri=(e,t,n=Oo)=>{for(const r of e)if(n(t,r))return!0;return!1},si=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},oi=(e,t)=>t?ai(e,t):ii(e),ii=e=>{let t=0;for(const n of e)t++;return t},ai=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},ci=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},ui=(e,t)=>new xo((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),li=(e,t=Oo)=>new xo((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),di=(e,t)=>Jo((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}})),hi=(e,t)=>new xo((function*(){for(const n of e)t(n),yield n})),pi=(e,t)=>Jo((async function*(){for(const n of e)await t(n),yield n})),gi=(e,t)=>{if(t<0)throw new Io("index");let n=0;for(const r of e)if(t===n++)return r;throw new Io("index")},fi=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},vi=(e,t,n=Oo)=>new xo((function*(){const r=[...t];for(const t of e){let e=!1;for(let s=0;s<r.length;s++)if(!0===n(t,r[s])){e=!0;break}!1===e&&(yield t)}})),mi=(e,t,n)=>Jo((async function*(){const r=[...t];for(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===await n(t,o)){e=!0;break}}!1===e&&(yield t)}})),yi=(e,t)=>t?Si(e,t):wi(e),wi=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new Po(Ro.NoElements);return t.value},Si=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new Po(Ro.NoMatch)},_i=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new Po(Ro.NoMatch)},Ai=(e,t)=>t?Ti(e,t):Ci(e),Ci=e=>e[Symbol.iterator]().next().value||null,Ti=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},Di=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class Gi extends Fo{constructor(e,t){super(1),this.key=e,this[0]=t}}const ki=(e,t,n)=>{let r;return r=n?((e,t,n)=>function*(){const r=new Array;for(const s of e){const e=t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Gi(e,s))}for(const e of r)yield e})(e,t,n):((e,t)=>function*(){const n={};for(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new Gi(e,r)}for(const e in n)yield n[e]})(e,t),new xo(r)},bi=(e,t,n)=>n?Ei(e,t,n):Ni(e,t),Ni=(e,t)=>Jo((async function*(){const n={};for(const r of e){const e=await t(r),s=n[e];s?s.push(r):n[e]=new Gi(e,r)}for(const e in n)yield n[e]})),Ei=(e,t,n)=>Jo((async function*(){const r=new Array;for(const s of e){const e=await t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Gi(e,s))}for(const e of r)yield e})),Ii=(e,t,n,r)=>r?((e,t,n,r)=>new xo((function*(){const s=new Array;for(const o of e){const e=t(o);let i=!1;for(let t=0;t<s.length;t++){const a=s[t];if(r(a.key,e)){a.push(n(o)),i=!0;break}}if(!1===i){const t=n(o);s.push(new Gi(e,t))}}for(const e of s)yield e})))(e,t,n,r):((e,t,n)=>new xo((function*(){const r={};for(const s of e){const e=t(s),o=r[e],i=n(s);o?o.push(i):r[e]=new Gi(e,i)}for(const e in r)yield r[e]})))(e,t,n),Ri=(e,t,n,r,s,o)=>{const i=o?Pi(e,t,n,r,s,o):Oi(e,t,n,r,s);return new xo(i)},Pi=(e,t,n,r,s,o)=>function*(){var i;const a=[];for(const e of t){const t=r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},Oi=(e,t,n,r,s)=>function*(){var o;const i=new Map;for(const e of t){const t=r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},Ui=(e,t,n,r,s,o)=>{const i=o?Mi(e,t,n,r,s,o):xi(e,t,n,r,s);return Jo(i)},Mi=(e,t,n,r,s,o)=>async function*(){var i;const a=[];for(const e of t){const t=await r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for(const t of e){const e=await n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},xi=(e,t,n,r,s)=>async function*(){var o;const i=new Map;for(const e of t){const t=await r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for(const t of e){const e=await n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},Fi=(e,t,n=Oo)=>new xo((function*(){const r=[...e.distinct(n)];if(0===r.length)return;const s=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++)if(!0===n(t,s[e])){yield t;break}}})),Li=(e,t,n)=>Jo((async function*(){const r=[];for await(const t of e.distinctAsync(n))r.push(t);if(0===r.length)return;const s=[...t];for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===await n(t,r)){yield t;break}}}})),Bi=(e,t,n,r,s,o=Oo)=>new xo((function*(){const i=[...t];for(const t of e){const e=n(t);for(const n of i){const i=r(n);!0===o(e,i)&&(yield s(t,n))}}})),$i=(e,t)=>t?qi(e,t):Wi(e),Wi=e=>{let t;for(const n of e)t=n;if(!t)throw new Po(Ro.NoElements);return t},qi=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new Po(Ro.NoMatch);return n},Hi=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new Po(Ro.NoMatch);return n},Vi=(e,t)=>t?Ki(e,t):ji(e),ji=e=>{let t=null;for(const n of e)t=n;return t},Ki=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},zi=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},Ji=(e,t)=>t?Xi(e,t):Yi(e),Yi=e=>{let t=null;for(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new Po(Ro.NoElements);return t},Xi=(e,t)=>{let n=null;for(const r of e)n=Math.max(n||Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new Po(Ro.NoElements);return n},Qi=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 Po(Ro.NoElements);return n},Zi=(e,t)=>t?ta(e,t):ea(e),ea=e=>{let t=null;for(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new Po(Ro.NoElements);return t},ta=(e,t)=>{let n=null;for(const r of e)n=Math.min(n||Number.POSITIVE_INFINITY,t(r));if(null===n)throw new Po(Ro.NoElements);return n},na=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 Po(Ro.NoElements);return n},ra=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new xo((function*(){for(const t of e)n(t)&&(yield t)}))};async function*sa(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}function*oa(e,t,n,r){const s=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}class ia extends Uo{constructor(e){super((async function*(){for await(const t of e())yield*t})),this.orderedPairs=e}static generateAsync(e,t,n,r){let s;return s=e instanceof ia?async function*(){for await(const s of e.orderedPairs())yield*sa(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new ia(s)}static generate(e,t,n,r){let s;return s=e instanceof ia?async function*(){for await(const s of e.orderedPairs())yield*oa(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new ia(s)}thenBy(e,t){return ia.generate(this,e,!0,t)}thenByAsync(e,t){return ia.generateAsync(this,e,!0,t)}thenByDescending(e,t){return ia.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return ia.generateAsync(this,e,!1,t)}}function*aa(e,t,n,r){const s=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}async function*ca(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}class ua extends xo{constructor(e){super((function*(){for(const t of e())yield*t})),this.orderedPairs=e}static generate(e,t,n,r){let s;return s=e instanceof ua?function*(){for(const s of e.orderedPairs())yield*aa(s,t,n,r)}:()=>aa(e,t,n,r),new ua(s)}static generateAsync(e,t,n,r){let s;return s=e instanceof ua?async function*(){for(const s of e.orderedPairs())yield*ca(s,t,n,r)}:()=>ca(e,t,n,r),new ia(s)}thenBy(e,t){return ua.generate(this,e,!0,t)}thenByAsync(e,t){return ua.generateAsync(this,e,!0,t)}thenByDescending(e,t){return ua.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return ua.generateAsync(this,e,!1,t)}}const la=(e,t,n)=>ua.generate(e,t,!0,n),da=(e,t,n)=>ua.generateAsync(e,t,!0,n),ha=(e,t,n)=>ua.generate(e,t,!1,n),pa=(e,t,n)=>ua.generateAsync(e,t,!1,n),ga=(e,t)=>{const n=[],r=[];for(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},fa=async(e,t)=>{const n=[],r=[];for(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},va=e=>new xo((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),ma=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?ya(e,t):wa(e,t)}return Sa(e,t)},ya=(e,t)=>new xo((function*(){for(const n of e)yield t(n)})),wa=(e,t)=>new xo((function*(){let n=0;for(const r of e)yield t(r,n),n++})),Sa=(e,t)=>new xo((function*(){for(const n of e)yield n[t]})),_a=(e,t)=>"function"==typeof t?1===t.length?Aa(e,t):Ca(e,t):Ta(e,t),Aa=(e,t)=>Jo((async function*(){for(const n of e)yield t(n)})),Ca=(e,t)=>Jo((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),Ta=(e,t)=>Jo((async function*(){for(const n of e)yield n[t]})),Da=(e,t)=>"function"==typeof t?1===t.length?Ga(e,t):ka(e,t):ba(e,t),Ga=(e,t)=>new xo((function*(){for(const n of e)for(const e of t(n))yield e})),ka=(e,t)=>new xo((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),ba=(e,t)=>new xo((function*(){for(const n of e)for(const e of n[t])yield e})),Na=(e,t)=>1===t.length?Ea(e,t):Ia(e,t),Ea=(e,t)=>Jo((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Ia=(e,t)=>Jo((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),Ra=(e,t,n=Oo)=>{const r=e[Symbol.iterator](),s=t[Symbol.iterator]();let o=r.next(),i=s.next();for(;!o.done&&!i.done;){if(!n(o.value,i.value))return!1;o=r.next(),i=s.next()}return!0===o.done&&!0===i.done},Pa=async(e,t,n)=>{const r=e[Symbol.iterator](),s=t[Symbol.iterator]();let o=r.next(),i=s.next();for(;!o.done&&!i.done;){if(!1===await n(o.value,i.value))return!1;o=r.next(),i=s.next()}return!0===o.done&&!0===i.done},Oa=(e,t)=>t?Ma(e,t):Ua(e),Ua=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new Po(Ro.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new Po(Ro.NoElements);return n},Ma=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new Po(Ro.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Po(Ro.NoMatch);return r},xa=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new Po(Ro.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Po(Ro.NoMatch);return r},Fa=(e,t)=>t?Ba(e,t):La(e),La=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new Po(Ro.MoreThanOneElement);t=!0,n=r}return n},Ba=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new Po(Ro.MoreThanOneMatchingElement);n=!0,r=s}return r},$a=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new Po(Ro.MoreThanOneElement);n=!0,r=s}return r},Wa=(e,t)=>new xo((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),qa=(e,t)=>1===t.length?Ha(e,t):Va(e,t),Ha=(e,t)=>new xo((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Va=(e,t)=>new xo((function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),ja=(e,t)=>1===t.length?Ka(e,t):za(e,t),Ka=(e,t)=>Jo((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),za=(e,t)=>Jo((async function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===await t(s,n)&&(r=!1,yield s),n++})),Ja=(e,t)=>t?Xa(e,t):Ya(e),Ya=e=>{let t=0;for(const n of e)t+=n;return t},Xa=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},Qa=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},Za=(e,t)=>new xo((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),ec=(e,t)=>1===t.length?tc(e,t):nc(e,t),tc=(e,t)=>new xo((function*(){for(const n of e){if(!t(n))break;yield n}})),nc=(e,t)=>new xo((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),rc=(e,t)=>1===t.length?sc(e,t):oc(e,t),sc=(e,t)=>Jo((async function*(){for(const n of e){if(!await t(n))break;yield n}})),oc=(e,t)=>Jo((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),ic=e=>[...e],ac=(e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},cc=async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},uc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},lc=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},dc=e=>new Set(e),hc=(e,t,n)=>n?gc(e,t,n):pc(e,t),pc=(e,t)=>new xo((function*(){const n=new Set;for(const t of e)!1===n.has(t)&&(yield t,n.add(t));for(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),gc=(e,t,n)=>new xo((function*(){const r=[];for(const s of[e,t])for(const e of s){let t=!1;for(const s of r)if(!0===n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),fc=(e,t,n)=>Jo((async function*(){const r=[];for(const s of[e,t])for(const e of s){let t=!1;for(const s of r)if(!0===await n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),vc=(e,t)=>1===t.length?mc(e,t):yc(e,t),mc=(e,t)=>new xo((function*(){for(const n of e)!0===t(n)&&(yield n)})),yc=(e,t)=>new xo((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),wc=(e,t)=>1===t.length?Sc(e,t):_c(e,t),Sc=(e,t)=>Jo((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),_c=(e,t)=>Jo((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),Ac=(e,t,n)=>n?Tc(e,t,n):Cc(e,t),Cc=(e,t)=>new xo((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]}})),Tc=(e,t,n)=>new xo((function*(){const r=e[Symbol.iterator](),s=t[Symbol.iterator]();for(;;){const e=r.next(),t=s.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Dc=(e,t,n)=>Jo((async function*(){const r=e[Symbol.iterator](),s=t[Symbol.iterator]();for(;;){const e=r.next(),t=s.next();if(e.done||t.done)break;yield n(e.value,t.value)}})),Gc=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(Lo,"aggregate"),n(qo,"all"),n(Ho,"allAsync"),n(Vo,"any"),n(zo,"anyAsync"),n(Yo,"asAsync"),n(Qo,"asParallel"),n(Zo,"average"),n(ei,"averageAsync"),n(ti,"chunk"),n(ni,"concatenate"),n(ri,"contains"),n(si,"containsAsync"),n(oi,"count"),n(ci,"countAsync"),n(ui,"defaultIfEmpty"),n(li,"distinct"),n(di,"distinctAsync"),n(hi,"each"),n(pi,"eachAsync"),n(gi,"elementAt"),n(fi,"elementAtOrDefault"),n(vi,"except"),n(mi,"exceptAsync"),n(yi,"first"),n(_i,"firstAsync"),n(Ai,"firstOrDefault"),n(Di,"firstOrDefaultAsync"),n(ki,"groupBy"),n(bi,"groupByAsync"),n(Ii,"groupByWithSel"),n(Ri,"groupJoin"),n(Ui,"groupJoinAsync"),n(Fi,"intersect"),n(Li,"intersectAsync"),n(Bi,"joinByKey"),n($i,"last"),n(Hi,"lastAsync"),n(Vi,"lastOrDefault"),n(zi,"lastOrDefaultAsync"),n(Ji,"max"),n(Qi,"maxAsync"),n(Zi,"min"),n(na,"minAsync"),n(ra,"ofType"),n(la,"orderBy"),n(da,"orderByAsync"),n(ha,"orderByDescending"),n(pa,"orderByDescendingAsync"),n(va,"reverse"),n(ma,"select"),n(_a,"selectAsync"),n(Da,"selectMany"),n(Na,"selectManyAsync"),n(Ra,"sequenceEquals"),n(Pa,"sequenceEqualsAsync"),n(Oa,"single"),n(xa,"singleAsync"),n(Fa,"singleOrDefault"),n($a,"singleOrDefaultAsync"),n(Wa,"skip"),n(qa,"skipWhile"),n(ja,"skipWhileAsync"),n(Ja,"sum"),n(Qa,"sumAsync"),n(Za,"take"),n(ec,"takeWhile"),n(rc,"takeWhileAsync"),n(ic,"toArray"),n(ac,"toMap"),n(cc,"toMapAsync"),n(uc,"toObject"),n(lc,"toObjectAsync"),n(ga,"partition"),n(fa,"partitionAsync"),n(dc,"toSet"),n(hc,"union"),n(fc,"unionAsync"),n(vc,"where"),n(wc,"whereAsync"),n(Ac,"zip"),n(Dc,"zipAsync")},kc=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Ec(e,t,n,r)}return n?Nc(e,t,n):bc(e,t)},bc=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Po(Ro.NoElements);return n},Nc=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Ec=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},Ic=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Rc=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},Pc=(e,t)=>t?Uc(e,t):Oc(e),Oc=async e=>{for await(const t of e)return!0;return!1},Uc=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Mc=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},xc=e=>Xo(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),Fc=async(e,t)=>{let n=0,r=0;if(t)for await(const s of e)n+=t(s),r+=1;else for await(const t of e)n+=t,r+=1;if(0===r)throw new Po(Ro.NoElements);return n/r},Lc=async(e,t)=>{let n=0,r=0;for await(const s of e)n+=await t(s),r+=1;if(0===r)throw new Po(Ro.NoElements);return n/r},Bc=(e,t)=>{if(t<1)throw new Io("index");return new Uo((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},$c=(e,t)=>new Uo((async function*(){yield*e,yield*t})),Wc=async(e,t,n=Oo)=>{for await(const r of e)if(n(t,r))return!0;return!1},qc=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},Hc=(e,t)=>t?jc(e,t):Vc(e),Vc=async e=>{let t=0;for await(const n of e)t++;return t},jc=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},Kc=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},zc=(e,t)=>new Uo((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),Jc=(e,t=Oo)=>new Uo((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Yc=(e,t)=>new Uo((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}})),Xc=(e,t)=>new Uo((async function*(){for await(const n of e)t(n),yield n})),Qc=(e,t)=>new Uo((async function*(){for await(const n of e)await t(n),yield n})),Zc=async(e,t)=>{if(t<0)throw new Io("index");let n=0;for await(const r of e)if(t===n++)return r;throw new Io("index")},eu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},tu=(e,t,n=Oo)=>new Uo((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===n(t,o)){e=!0;break}}!1===e&&(yield t)}})),nu=(e,t,n)=>new Uo((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===await n(t,o)){e=!0;break}}!1===e&&(yield t)}})),ru=(e,t)=>t?ou(e,t):su(e),su=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new Po(Ro.NoElements);return t.value},ou=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new Po(Ro.NoMatch)},iu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new Po(Ro.NoMatch)},au=(e,t)=>t?uu(e,t):cu(e),cu=async e=>(await e[Symbol.asyncIterator]().next()).value||null,uu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},lu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},du=(e,t,n)=>n?hu(e,t,n):pu(e,t),hu=(e,t,n)=>new Uo((async function*(){const r=new Array;for await(const s of e){const e=t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Gi(e,s))}for(const e of r)yield e})),pu=(e,t)=>new Uo((async function*(){const n={};for await(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new Gi(e,r)}for(const e in n)yield n[e]})),gu=(e,t,n)=>n?vu(e,t,n):fu(e,t),fu=(e,t)=>new Uo((async function*(){const n={};for await(const r of e){const e=await t(r),s=n[e];s?s.push(r):n[e]=new Gi(e,r)}for(const e in n)yield n[e]})),vu=(e,t,n)=>new Uo((async function*(){const r=new Array;for await(const s of e){const e=await t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(!0===await n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Gi(e,s))}for(const e of r)yield e})),mu=(e,t,n,r)=>r?wu(e,t,n,r):yu(e,t,n),yu=(e,t,n)=>new Uo((async function*(){const r={};for await(const s of e){const e=t(s),o=r[e],i=n(s);o?o.push(i):r[e]=new Gi(e,i)}for(const e in r)yield r[e]})),wu=(e,t,n,r)=>new Uo((async function*(){const s=new Array;for await(const o of e){const e=t(o);let i=!1;for(let t=0;t<s.length;t++){const a=s[t];if(r(a.key,e)){a.push(n(o)),i=!0;break}}if(!1===i){const t=n(o);s.push(new Gi(e,t))}}for(const e of s)yield e})),Su=(e,t,n,r,s,o)=>{const i=o?_u(e,t,n,r,s,o):Au(e,t,n,r,s);return new Uo(i)},_u=(e,t,n,r,s,o)=>async function*(){var i;const a=[];for await(const e of t){const t=r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},Au=(e,t,n,r,s)=>async function*(){var o;const i=new Map;for await(const e of t){const t=r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},Cu=(e,t,n,r,s,o)=>{const i=o?Tu(e,t,n,r,s,o):Du(e,t,n,r,s);return new Uo(i)},Tu=(e,t,n,r,s,o)=>async function*(){var i;const a=[];for await(const e of t){const t=await r(e),n=a.find((e=>o(e.key,t)));n?n.values.push(e):a.push({key:t,values:[e]})}for await(const t of e){const e=await n(t),r=null!==(i=a.find((t=>o(t.key,e))))&&void 0!==i?i:{key:e,values:[]};yield s(t,r.values)}},Du=(e,t,n,r,s)=>async function*(){var o;const i=new Map;for await(const e of t){const t=await r(e),n=i.get(t);n?n.push(e):i.set(t,[e])}for await(const t of e){const e=await n(t),r=null!==(o=i.get(e))&&void 0!==o?o:[];yield s(t,r)}},Gu=(e,t,n=Oo)=>new Uo((async function*(){const r=await e.distinct(n).toArray();if(0===r.length)return;const s=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===n(t,r)){yield t;break}}}})),ku=(e,t,n)=>new Uo((async function*(){const r=await e.distinctAsync(n).toArray();if(0===r.length)return;const s=await t.toArray();for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===await n(t,r)){yield t;break}}}})),bu=(e,t,n,r,s,o=Oo)=>new Uo((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===o(e,i)&&(yield s(t,n))}}})),Nu=(e,t)=>t?Iu(e,t):Eu(e),Eu=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new Po(Ro.NoElements);return t},Iu=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new Po(Ro.NoMatch);return n},Ru=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new Po(Ro.NoMatch);return n},Pu=(e,t)=>t?Uu(e,t):Ou(e),Ou=async e=>{let t=null;for await(const n of e)t=n;return t},Uu=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},Mu=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},xu=(e,t)=>t?Lu(e,t):Fu(e),Fu=async e=>{let t=null;for await(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new Po(Ro.NoElements);return t},Lu=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 Po(Ro.NoElements);return n},Bu=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 Po(Ro.NoElements);return n},$u=(e,t)=>t?qu(e,t):Wu(e),Wu=async e=>{let t=null;for await(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new Po(Ro.NoElements);return t},qu=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 Po(Ro.NoElements);return n},Hu=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 Po(Ro.NoElements);return n},Vu=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Uo((async function*(){for await(const t of e)n(t)&&(yield t)}))},ju=(e,t,n)=>ia.generate(e,t,!0,n),Ku=(e,t,n)=>ia.generateAsync(e,t,!0,n),zu=(e,t,n)=>ia.generate(e,t,!1,n),Ju=(e,t,n)=>ia.generateAsync(e,t,!1,n),Yu=async(e,t)=>{const n=[],r=[];for await(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},Xu=async(e,t)=>{const n=[],r=[];for await(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},Qu=e=>new Uo((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]})),Zu=(e,t)=>"function"==typeof t?1===t.length?el(e,t):tl(e,t):nl(e,t),el=(e,t)=>new Uo((async function*(){for await(const n of e)yield t(n)})),tl=(e,t)=>new Uo((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),nl=(e,t)=>new Uo((async function*(){for await(const n of e)yield n[t]})),rl=(e,t)=>"string"==typeof t?ol(e,t):sl(e,t),sl=(e,t)=>new Uo((async function*(){for await(const n of e)yield t(n)})),ol=(e,t)=>new Uo((async function*(){for await(const n of e)yield n[t]})),il=(e,t)=>"function"==typeof t?1===t.length?al(e,t):cl(e,t):ul(e,t),al=(e,t)=>new Uo((async function*(){for await(const n of e)for(const e of t(n))yield e})),cl=(e,t)=>new Uo((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),ul=(e,t)=>new Uo((async function*(){for await(const n of e)for(const e of n[t])yield e})),ll=(e,t)=>1===t.length?new Uo((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Uo((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++}})),dl=async(e,t,n=Oo)=>{const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();let o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1];for(;!i.done&&!a.done;){if(!n(i.value,a.value))return!1;o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1]}return!0===i.done&&!0===a.done},hl=async(e,t,n)=>{const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();let o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1];for(;!i.done&&!a.done;){if(!1===await n(i.value,a.value))return!1;o=await Promise.all([r.next(),s.next()]),i=o[0],a=o[1]}return!0===i.done&&!0===a.done},pl=(e,t)=>t?fl(e,t):gl(e),gl=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new Po(Ro.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new Po(Ro.NoElements);return n},fl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new Po(Ro.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Po(Ro.NoMatch);return r},vl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new Po(Ro.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Po(Ro.NoMatch);return r},ml=(e,t)=>t?wl(e,t):yl(e),yl=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new Po(Ro.MoreThanOneElement);t=!0,n=r}return n},wl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new Po(Ro.MoreThanOneMatchingElement);n=!0,r=s}return r},Sl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new Po(Ro.MoreThanOneMatchingElement);n=!0,r=s}return r},_l=(e,t)=>new Uo((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),Al=(e,t)=>1===t.length?Cl(e,t):Tl(e,t),Cl=(e,t)=>new Uo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Tl=(e,t)=>new Uo((async function*(){let n=0,r=!0;for await(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),Dl=(e,t)=>1===t.length?Gl(e,t):kl(e,t),Gl=(e,t)=>new Uo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),kl=(e,t)=>new Uo((async function*(){let n=0,r=!0;for await(const s of e)!1===r?yield s:!1===await t(s,n)&&(r=!1,yield s),n++})),bl=(e,t)=>t?El(e,t):Nl(e),Nl=async e=>{let t=0;for await(const n of e)t+=n;return t},El=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},Il=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},Rl=(e,t)=>new Uo((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Pl=(e,t)=>1===t.length?Ol(e,t):Ul(e,t),Ol=(e,t)=>new Uo((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Ul=(e,t)=>new Uo((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Ml=(e,t)=>1===t.length?xl(e,t):Fl(e,t),xl=(e,t)=>new Uo((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Fl=(e,t)=>new Uo((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Ll=async e=>{const t=[];for await(const n of e)t.push(n);return t},Bl=async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},$l=async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},Wl=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},ql=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},Hl=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Vl=(e,t,n)=>n?Kl(e,t,n):jl(e,t),jl=(e,t)=>new Uo((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))})),Kl=(e,t,n)=>new Uo((async function*(){const r=[];for(const s of[e,t])for await(const e of s){let t=!1;for(const s of r)if(!0===n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),zl=(e,t,n)=>new Uo((async function*(){const r=[];for(const s of[e,t])for await(const e of s){let t=!1;for(const s of r)if(!0===await n(e,s)){t=!0;break}!1===t&&(yield e,r.push(e))}})),Jl=(e,t)=>1===t.length?Yl(e,t):Xl(e,t),Yl=(e,t)=>new Uo((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Xl=(e,t)=>new Uo((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),Ql=(e,t)=>1===t.length?Zl(e,t):ed(e,t),Zl=(e,t)=>new Uo((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),ed=(e,t)=>new Uo((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),td=(e,t,n)=>n?rd(e,t,n):nd(e,t),nd=(e,t)=>new Uo((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]}})),rd=(e,t,n)=>new Uo((async function*(){const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([r.next(),s.next()]);if(e.done||t.done)break;yield n(e.value,t.value)}})),sd=(e,t,n)=>new Uo((async function*(){const r=e[Symbol.asyncIterator](),s=t[Symbol.asyncIterator]();for(;;){const e=await Promise.all([r.next(),s.next()]),t=e[0],o=e[1];if(t.done||o.done)break;yield n(t.value,o.value)}})),od=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return cd(e,t,n,r)}return n?ad(e,t,n):id(e,t)},id=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Po(Ro.NoElements);return n},ad=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},cd=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},ud=(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}}},ld=(e,t)=>{const n=ud(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))}},dd=(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}}},hd=(e,t)=>{const n=dd(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))}},pd=(e,t)=>t?fd(e,t):gd(e),gd=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}},fd=async(e,t)=>{const n=ud(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)}},vd=async(e,t)=>{const n=dd(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 s of r)s.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)}},md=e=>Jo((async function*(){for await(const t of e)yield t})),yd=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)}},wd=async(e,t)=>{let n;n=t?ud(e,t):e.dataFunc;const r=await yd(n);if(0===r.length)throw new Po(Ro.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},Sd=async(e,t)=>{const n=dd(e,t),r=await yd(n);if(0===r.length)throw new Po(Ro.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},_d=(e,t)=>{if(t<1)throw new Io("index");let n;switch(e.dataFunc.type){case 1:const r=e.dataFunc.generator;n={type:1,generator:()=>{const e=[];let n=[];for(const s of r())n.push(s),n.length===t&&(e.push(Promise.all(n)),n=[]);return n.length&&e.push(Promise.all(n)),e}};break;case 2:const s=e.dataFunc.generator;n={type:2,generator:async()=>{const e=[];let n=[];for(const r of await s())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 o=e.dataFunc.generator;n={type:0,generator:async()=>{const e=[];let n=[];for(const r of await o())n.push(r),n.length===t&&(e.push(n),n=[]);return n.length&&e.push(n),e}}}return new Mo(n)},Ad=(e,t)=>new Mo({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),Cd=async(e,t,n=Oo)=>{let r;switch(r=ud(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))}},Td=async(e,t,n)=>{const r=dd(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))}},Dd=(e,t)=>t?kd(e,t):Gd(e),Gd=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},kd=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},bd=async(e,t)=>{const n=dd(e,t);let r;switch(n.type){case 1:r=Promise.all(n.generator());break;case 2:r=Promise.all(await n.generator())}let s=0;for(const e of await r)e&&s++;return s},Nd=(e,t)=>{const n=e.dataFunc,r=t instanceof Promise;let s;switch(n.type){case 0:s={generator:()=>n.generator().then((e=>e.length?e:r?t.then((e=>[e])):[t])),type:n.type};break;case 1:s={generator:()=>{const e=n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type};break;case 2:s={generator:async()=>{const e=await n.generator();return e.length?e:r?[t]:[Promise.resolve(t)]},type:n.type}}return new Mo(s)},Ed=(e,t=Oo)=>new Mo({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),Id=(e,t)=>new Mo({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}),Rd=(e,t)=>new Mo(ud(e,(e=>(t(e),e)))),Pd=(e,t)=>{const n=dd(e,(async e=>(await t(e),e)));return new Mo(n)},Od=async(e,t)=>{if(t<0)throw new Io("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new Io("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new Io("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new Io("index");return await e[t]}}},Ud=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]}}},Md=(e,t,n=Oo)=>new Mo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=[];for(const e of r){let t=!1;for(let r=0;r<s.length;r++){const o=s[r];if(!0===n(e,o)){t=!0;break}}!1===t&&o.push(e)}return o},type:0}),xd=(e,t,n)=>new Mo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=[];for(const e of r){let t=!1;for(let r=0;r<s.length;r++){const o=s[r];if(!0===await n(e,o)){t=!0;break}}!1===t&&o.push(e)}return o},type:0}),Fd=e=>yd(e.dataFunc),Ld=(e,t)=>t?$d(e,t):Bd(e),Bd=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new Po(Ro.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new Po(Ro.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new Po(Ro.NoElements);return await e[0]}}},$d=async(e,t)=>{const n=await Fd(e);for(const e of n)if(!0===t(e))return e;throw new Po(Ro.NoMatch)},Wd=async(e,t)=>{const n=await Fd(e);for(const e of n)if(!0===await t(e))return e;throw new Po(Ro.NoMatch)},qd=(e,t)=>t?Vd(e,t):Hd(e),Hd=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]}}},Vd=async(e,t)=>{const n=await Fd(e);for(const e of n)if(!0===t(e))return e;return null},jd=async(e,t)=>{const n=await Fd(e);for(const e of n)if(!0===await t(e))return e;return null},Kd=(e,t,n)=>n?Jd(e,t,n):zd(e,t),zd=(e,t)=>new Mo({generator:async()=>{const n={};for(const r of await e.toArray()){const e=t(r),s=n[e];s?s.push(r):n[e]=new Gi(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),Jd=(e,t,n)=>new Mo({generator:async()=>{const r=new Array;for(const s of await e.toArray()){const e=t(s);let o=!1;for(let t=0;t<r.length;t++){const i=r[t];if(n(i.key,e)){i.push(s),o=!0;break}}!1===o&&r.push(new Gi(e,s))}const s=new Array;for(const e of r)s.push(e);return s},type:0}),Yd=(e,t,n)=>n?Xd(e,t,n):Qd(e,t),Xd=(e,t,n)=>new Mo({generator:async()=>{const r=dd(e,(async e=>[await t(e),e]));let s;switch(r.type){case 1:s=await Promise.all(r.generator());break;case 2:s=await Promise.all(await r.generator())}const o=new Array;for(const[e,t]of s){let r=!1;for(let s=0;s<o.length;s++){const i=o[s];if(!0===await n(i.key,e)){i.push(t),r=!0;break}}!1===r&&o.push(new Gi(e,t))}const i=new Array;for(const e of o)i.push(e);return i},type:0}),Qd=(e,t)=>new Mo({generator:async()=>{const n=dd(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 s={};for(const[e,t]of r){const n=s[e];n?n.push(t):s[e]=new Gi(e,t)}const o=new Array;for(const e in s)o.push(s[e]);return o},type:0}),Zd=(e,t,n,r)=>r?eh(e,t,n,r):th(e,t,n),eh=(e,t,n,r)=>new Mo({generator:async()=>{const s=new Array;for await(const o of e){const e=t(o);let i=!1;for(let t=0;t<s.length;t++){const a=s[t];if(r(a.key,e)){a.push(n(o)),i=!0;break}}if(!1===i){const t=n(o);s.push(new Gi(e,t))}}const o=new Array;for(const e of s)o.push(e);return o},type:0}),th=(e,t,n)=>new Mo({generator:async()=>{const r={};for(const s of await e.toArray()){const e=t(s),o=r[e],i=n(s);o?o.push(i):r[e]=new Gi(e,i)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),nh=(e,t,n,r,s,o)=>{const i=o?rh(e,t,n,r,s,o):sh(e,t,n,r,s);return new Mo({generator:i,type:0})},rh=(e,t,n,r,s,o)=>async()=>{const i=[];for await(const e of t){const t=r(e),n=i.find((e=>o(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}return(await e.toArray()).map((e=>{var t;const r=n(e),a=null!==(t=i.find((e=>o(e.key,r))))&&void 0!==t?t:{key:r,values:[]};return s(e,a.values)}))},sh=(e,t,n,r,s)=>async()=>{const o=new Map;for await(const e of t){const t=r(e),n=o.get(t);n?n.push(e):o.set(t,[e])}return(await e.toArray()).map((e=>{var t;const r=n(e),i=null!==(t=o.get(r))&&void 0!==t?t:[];return s(e,i)}))},oh=(e,t,n,r,s,o)=>{const i=o?ih(e,t,n,r,s,o):ah(e,t,n,r,s);return new Mo({generator:i,type:0})},ih=(e,t,n,r,s,o)=>async()=>{const i=[];for await(const e of t){const t=await r(e),n=i.find((e=>o(e.key,t)));n?n.values.push(e):i.push({key:t,values:[e]})}const a=(await e.toArray()).map((async e=>{var t;const r=await n(e),a=null!==(t=i.find((e=>o(e.key,r))))&&void 0!==t?t:{key:r,values:[]};return s(e,a.values)}));return await Promise.all(a)},ah=(e,t,n,r,s)=>async()=>{const o=new Map;for await(const e of t){const t=await r(e),n=o.get(t);n?n.push(e):o.set(t,[e])}const i=(await e.toArray()).map((async e=>{var t;const r=await n(e),i=null!==(t=o.get(r))&&void 0!==t?t:[];return s(e,i)}));return await Promise.all(i)},ch=(e,t,n=Oo)=>new Mo({generator:async()=>{const r=await e.distinct(n).toArray();if(0===r.length)return[];const s=await t.toArray(),o=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===n(t,r)){o.push(t);break}}}return o},type:0}),uh=(e,t,n)=>new Mo({generator:async()=>{const r=await e.distinctAsync(n).toArray();if(0===r.length)return[];const s=await t.toArray(),o=new Array;for(let e=0;e<r.length;e++){const t=r[e];for(let e=0;e<s.length;e++){const r=s[e];if(!0===await n(t,r)){o.push(t);break}}}return o},type:0}),lh=(e,t,n,r,s,o=Oo)=>new Mo({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===o(t,i)&&c.push(s(e,n))}}return c},type:0}),dh=(e,t)=>t?ph(e,t):hh(e),hh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new Po(Ro.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new Po(Ro.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new Po(Ro.NoElements);return await e[e.length-1]}}},ph=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 Po(Ro.NoMatch)},gh=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 Po(Ro.NoMatch)},fh=(e,t)=>t?mh(e,t):vh(e),vh=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]}}},mh=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},yh=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},wh=async(e,t)=>{let n;n=t?ud(e,t):e.dataFunc;const r=await yd(n);if(0===r.length)throw new Po(Ro.NoElements);return Math.max.apply(null,r)},Sh=async(e,t)=>{const n=dd(e,t),r=await yd(n);if(0===r.length)throw new Po(Ro.NoElements);return Math.max.apply(null,r)},_h=async(e,t)=>{let n;n=t?ud(e,t):e.dataFunc;const r=await yd(n);if(0===r.length)throw new Po(Ro.NoElements);return Math.min.apply(null,r)},Ah=async(e,t)=>{const n=dd(e,t),r=await yd(n);if(0===r.length)throw new Po(Ro.NoElements);return Math.min.apply(null,r)},Ch=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Mo({generator:async()=>{const t=ud(e,n),r=await yd(t),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0})};async function*Th(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}async function*Dh(e,t,n,r){const s=((e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}class Gh extends Mo{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 s;return s=e instanceof Gh?async function*(){for await(const s of e.orderedPairs())yield*Th(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=await t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new Gh(s)}static generate(e,t,n,r){let s;return s=e instanceof Gh?async function*(){for await(const s of e.orderedPairs())yield*Dh(s,t,n,r)}:()=>async function*(e,t,n,r){const s=await(async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),s=n.get(e);s?s.push(r):n.set(e,[r])}return n})(e,t),o=[...s.keys()].sort(r||void 0);if(n)for(let e=0;e<o.length;e++)yield s.get(o[e]);else for(let e=o.length-1;e>=0;e--)yield s.get(o[e])}(e,t,n,r),new Gh(s)}thenBy(e,t){return Gh.generate(this,e,!0,t)}thenByAsync(e,t){return Gh.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Gh.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Gh.generateAsync(this,e,!1,t)}}const kh=(e,t,n)=>Gh.generate(e,t,!0,n),bh=(e,t,n)=>Gh.generateAsync(e,t,!0,n),Nh=(e,t,n)=>Gh.generate(e,t,!1,n),Eh=(e,t,n)=>Gh.generateAsync(e,t,!1,n),Ih=async(e,t)=>{const n=ud(e,(e=>[t(e),e])),r=await yd(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Rh=async(e,t)=>{const n=dd(e,(async e=>[await t(e),e])),r=await yd(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Ph=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Mo({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Mo({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Oh=(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}}},Uh=(e,t)=>"function"==typeof t?1===t.length?new Mo(ud(e,t)):new Mo(Oh(e,t)):new Mo(ud(e,(e=>e[t]))),Mh=(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}}},xh=(e,t)=>{let n;return n="function"==typeof t?1===t.length?dd(e,t):Mh(e,t):dd(e,(e=>e[t])),new Mo(n)},Fh=(e,t)=>new Mo({generator:async()=>{let n;n="function"==typeof t?1===t.length?ud(e,t):Oh(e,t):ud(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}),Lh=(e,t)=>new Mo({generator:async()=>{let n;n=1===t.length?dd(e,t):Mh(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}),Bh=async(e,t,n=Oo)=>{const r=await e.toArray(),s=await t.toArray();if(r.length!==s.length)return!1;for(let e=0;e<r.length;e++)if(!1===n(r[e],s[e]))return!1;return!0},$h=async(e,t,n)=>{const r=await e.toArray(),s=await t.toArray();if(r.length!==s.length)return!1;for(let e=0;e<r.length;e++){const t=r[e],o=s[e];if(!1===await n(t,o))return!1}return!0},Wh=(e,t)=>t?Hh(e,t):qh(e),qh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new Po(Ro.MoreThanOneElement);if(0===e.length)throw new Po(Ro.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new Po(Ro.MoreThanOneElement);if(0===e.length)throw new Po(Ro.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new Po(Ro.MoreThanOneElement);if(0===e.length)throw new Po(Ro.NoElements);return await e[0]}}},Hh=async(e,t)=>{const n=await Fd(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new Po(Ro.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new Po(Ro.NoMatch);return s},Vh=async(e,t)=>{const n=await Fd(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new Po(Ro.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new Po(Ro.NoMatch);return s},jh=(e,t)=>t?zh(e,t):Kh(e),Kh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new Po(Ro.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new Po(Ro.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new Po(Ro.MoreThanOneElement);return 0===e.length?null:await e[0]}}},zh=async(e,t)=>{const n=await Fd(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new Po(Ro.MoreThanOneElement);r=!0,s=e}return s},Jh=async(e,t)=>{const n=await Fd(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new Po(Ro.MoreThanOneElement);r=!0,s=e}return s},Yh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Mo({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Mo({generator:()=>n.generator().slice(t),type:1});case 2:return new Mo({generator:async()=>(await n.generator()).slice(t),type:2})}},Xh=(e,t)=>new Mo({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 s=[];for(;r<n.length;r++)s.push(n[r]);return s},type:0}),Qh=(e,t)=>new Mo({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 s=[];for(;r<n.length;r++)s.push(n[r]);return s},type:0}),Zh=(e,t)=>t?tp(e,t):ep(e),ep=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},tp=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},np=async(e,t)=>{const n=dd(e,t),r=await yd(n);let s=0;for(const e of r)s+=e;return s},rp=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Mo({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Mo({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Mo({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},sp=(e,t)=>new Mo({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 s=n[e];if(!0!==t(s,e))break;r.push(s)}return r},type:0}),op=(e,t)=>new Mo({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 s=n[e];if(!0!==await t(s,e))break;r.push(s)}return r},type:0}),ip=async(e,t)=>{const n=new Map,r=ud(e,(e=>[t(e),e])),s=await yd(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},ap=async(e,t)=>{const n=new Map,r=dd(e,(async e=>[await t(e),e])),s=await yd(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},cp=async(e,t)=>{const n=e.dataFunc,r=await yd(n),s={};for(const e of r)s[t(e)]=e;return s},up=async(e,t)=>{const n=dd(e,(async e=>[await t(e),e])),r=await yd(n),s={};for(const[e,t]of r)s[e]=t;return s},lp=async e=>{const t=e.dataFunc,n=await yd(t);return new Set(n)},dp=(e,t,n)=>n?pp(e,t,n):hp(e,t),hp=(e,t)=>new Mo({generator:async()=>{const n=new Set,r=t.toArray();for await(const t of e)!1===n.has(t)&&n.add(t);const s=await r;for(const e of s)!1===n.has(e)&&n.add(e);return[...n.keys()]},type:0}),pp=(e,t,n)=>new Mo({generator:async()=>{const r=[],s=await Promise.all([e.toArray(),t.toArray()]);for(const e of s)for(const t of e){let e=!1;for(const s of r)if(!0===n(t,s)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),gp=(e,t,n)=>new Mo({generator:async()=>{const r=[],s=await Promise.all([e.toArray(),t.toArray()]);for(const e of s)for(const t of e){let e=!1;for(const s of r)if(!0===await n(t,s)){e=!0;break}!1===e&&r.push(t)}return r},type:0}),fp=(e,t)=>new Mo({generator:async()=>(await e.toArray()).filter(t),type:0}),vp=(e,t)=>new Mo({generator:async()=>{const n=Mh(e,(async(e,n)=>[await t(e,n),e])),r=await yd(n),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0}),mp=(e,t,n)=>n?wp(e,t,n):yp(e,t),yp=(e,t)=>new Mo({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]),s=n.length<r.length?n.length:r.length,o=new Array(s);for(let e=0;e<s;e++){const t=n[e],s=r[e];o[e]=[t,s]}return o},type:0}),wp=(e,t,n)=>new Mo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=r.length<s.length?r.length:s.length,i=new Array(o);for(let e=0;e<o;e++){const t=r[e],o=s[e];i[e]=n(t,o)}return i},type:0}),Sp=(e,t,n)=>new Mo({generator:async()=>{const[r,s]=await Promise.all([e.toArray(),t.toArray()]),o=r.length<s.length?r.length:s.length,i=new Array(o);for(let e=0;e<o;e++){const t=r[e],o=s[e];i[e]=n(t,o)}return Promise.all(i)},type:0}),_p=e=>{var t;const n=Fo.prototype,r=e.prototype,s=Object.getOwnPropertyNames(n);for(const e of s)r[e]=null!==(t=r[e])&&void 0!==t?t:n[e]};Gc(xo),(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(kc,"aggregate"),n(Ic,"all"),n(Rc,"allAsync"),n(Pc,"any"),n(Mc,"anyAsync"),n(xc,"asParallel"),n(Fc,"average"),n(Lc,"averageAsync"),n(Bc,"chunk"),n($c,"concatenate"),n(Wc,"contains"),n(qc,"containsAsync"),n(Hc,"count"),n(Kc,"countAsync"),n(zc,"defaultIfEmpty"),n(Jc,"distinct"),n(Yc,"distinctAsync"),n(Xc,"each"),n(Qc,"eachAsync"),n(Zc,"elementAt"),n(eu,"elementAtOrDefault"),n(tu,"except"),n(nu,"exceptAsync"),n(ru,"first"),n(iu,"firstAsync"),n(au,"firstOrDefault"),n(lu,"firstOrDefaultAsync"),n(du,"groupBy"),n(gu,"groupByAsync"),n(mu,"groupByWithSel"),n(Su,"groupJoin"),n(Cu,"groupJoinAsync"),n(Gu,"intersect"),n(ku,"intersectAsync"),n(bu,"joinByKey"),n(Nu,"last"),n(Ru,"lastAsync"),n(Pu,"lastOrDefault"),n(Mu,"lastOrDefaultAsync"),n(xu,"max"),n(Bu,"maxAsync"),n($u,"min"),n(Hu,"minAsync"),n(Vu,"ofType"),n(ju,"orderBy"),n(Ku,"orderByAsync"),n(zu,"orderByDescending"),n(Ju,"orderByDescendingAsync"),n(Yu,"partition"),n(Xu,"partitionAsync"),n(Qu,"reverse"),n(Zu,"select"),n(rl,"selectAsync"),n(il,"selectMany"),n(ll,"selectManyAsync"),n(dl,"sequenceEquals"),n(hl,"sequenceEqualsAsync"),n(pl,"single"),n(vl,"singleAsync"),n(ml,"singleOrDefault"),n(Sl,"singleOrDefaultAsync"),n(_l,"skip"),n(Al,"skipWhile"),n(Dl,"skipWhileAsync"),n(bl,"sum"),n(Il,"sumAsync"),n(Rl,"take"),n(Pl,"takeWhile"),n(Ml,"takeWhileAsync"),n(Ll,"toArray"),n(Bl,"toMap"),n($l,"toMapAsync"),n(Wl,"toObject"),n(ql,"toObjectAsync"),n(Hl,"toSet"),n(Vl,"union"),n(zl,"unionAsync"),n(Jl,"where"),n(Ql,"whereAsync"),n(td,"zip"),n(sd,"zipAsync")})(Uo),(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(od,"aggregate"),n(ld,"all"),n(hd,"allAsync"),n(pd,"any"),n(vd,"anyAsync"),n(md,"asAsync"),n(wd,"average"),n(Sd,"averageAsync"),n(_d,"chunk"),n(Ad,"concatenate"),n(Cd,"contains"),n(Td,"containsAsync"),n(Dd,"count"),n(bd,"countAsync"),n(Nd,"defaultIfEmpty"),n(Ed,"distinct"),n(Id,"distinctAsync"),n(Rd,"each"),n(Pd,"eachAsync"),n(Od,"elementAt"),n(Ud,"elementAtOrDefault"),n(Md,"except"),n(xd,"exceptAsync"),n(Ld,"first"),n(Wd,"firstAsync"),n(qd,"firstOrDefault"),n(jd,"firstOrDefaultAsync"),n(Kd,"groupBy"),n(Yd,"groupByAsync"),n(Zd,"groupByWithSel"),n(nh,"groupJoin"),n(oh,"groupJoinAsync"),n(nh,"groupJoin"),n(oh,"groupJoinAsync"),n(ch,"intersect"),n(uh,"intersectAsync"),n(lh,"joinByKey"),n(dh,"last"),n(gh,"lastAsync"),n(fh,"lastOrDefault"),n(yh,"lastOrDefaultAsync"),n(wh,"max"),n(Sh,"maxAsync"),n(_h,"min"),n(Ah,"minAsync"),n(Ch,"ofType"),n(kh,"orderBy"),n(bh,"orderByAsync"),n(Nh,"orderByDescending"),n(Eh,"orderByDescendingAsync"),n(Ih,"partition"),n(Rh,"partitionAsync"),n(Ph,"reverse"),n(Uh,"select"),n(xh,"selectAsync"),n(Fh,"selectMany"),n(Lh,"selectManyAsync"),n(Bh,"sequenceEquals"),n($h,"sequenceEqualsAsync"),n(Wh,"single"),n(Vh,"singleAsync"),n(jh,"singleOrDefault"),n(Jh,"singleOrDefaultAsync"),n(Yh,"skip"),n(Xh,"skipWhile"),n(Qh,"skipWhileAsync"),n(Zh,"sum"),n(np,"sumAsync"),n(rp,"take"),n(sp,"takeWhile"),n(op,"takeWhileAsync"),n(Fd,"toArray"),n(ip,"toMap"),n(ap,"toMapAsync"),n(cp,"toObject"),n(up,"toObjectAsync"),n(lp,"toSet"),n(dp,"union"),n(gp,"unionAsync"),n(fp,"where"),n(vp,"whereAsync"),n(mp,"zip"),n(Sp,"zipAsync")})(Mo),(()=>{var e;const{prototype:t}=Fo,n=Object.getOwnPropertyNames(xo.prototype);for(const r of n)t[r]=null!==(e=t[r])&&void 0!==e?e:xo.prototype[r];t.all=function(e){return this.every(e)},t.any=function(e){return e?this.some(e):0!==this.length},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Io("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new Po(Ro.NoMatch);return t}if(0===this.length)throw new Po(Ro.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new Po(Ro.NoMatch)}if(0===this.length)throw new Po(Ro.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.max=function(e){if(0===this.length)throw new Po(Ro.NoElements);if(e){let t=Number.NEGATIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.max(e(this[n]),t);return t}return Math.max.apply(null,this)},t.min=function(e){if(0===this.length)throw new Po(Ro.NoElements);if(e){let t=Number.POSITIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.min(e(this[n]),t);return t}return Math.min.apply(null,this)},t.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var Ap,Cp;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(Ap||(Ap={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(Cp||(Cp={}));class Tp{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Tp._devicesService&&(Tp._devicesService=ev.Get(ho.ServiceName))}GetDevicesChannelsInGroupAsync(e=!1){return t=this,n=void 0,o=function*(){let t=[],n=[];const s=yield Tp._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){ev.Get(r.ServiceName).Error("Old controller API fallback to old groups API.");for(let e of s)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=s.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((s=void 0)||(s=Promise))((function(e,r){function i(e){try{c(o.next(e))}catch(e){r(e)}}function a(e){try{c(o.throw(e))}catch(e){r(e)}}function c(t){var n;t.done?e(t.value):(n=t.value,n instanceof s?n:new s((function(e){e(n)}))).then(i,a)}c((o=o.apply(t,n||[])).next())}));var t,n,s,o}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 ev.Get(kp.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return ev.Get(kp.ServiceName).ChangeGroupIconNameAsync(this,e)}}var Dp,Gp=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 kp{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._objectsGroupingSupported=!1,this._connection=ev.Get(Gt.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{ev.Get(je.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Gp(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}SetObjectsInGroupAndOrderAsync(e,t){var n;return Gp(this,void 0,void 0,(function*(){let r=[],s=[];for(let e of t)if(this.IsDevice(e)){for(let t of e.Channels)r.push(`${t.ChannelId}`);s.push(`${e.Guid}`)}else{if(!this.IsDeviceChannel(e))throw new Error("Passed object is not a device or device channel!");r.push(`${e.ChannelId}`),s.push(`${e.ChannelId}`)}const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ep(e,s),15e3,!1);switch(ev.Get(Ge.ServiceName).ClearCache(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null==o?void 0:o.Status){case ae.OK:return new Te(Ap.Success,"");case ae.NotSupportedMethod:case ae.ResourceDoesNotExists:case ae.ResourceIsNotAvailable:return new Te(Ap.FunctionNotSupported,"");case ae.WrongData:return"GroupDoesNotExists"===o.Data?new Te(Ap.GroupDoesNotExists,o.Data):new Te(Ap.FatalError,o.Data);case ae.Error:case ae.FatalError:default:return new Te(Ap.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=ev.Get(r.ServiceName);e.forEach(((e,n)=>{t.Debug(kp.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=ev.Get(r.ServiceName);n.Debug(kp.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(kp.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){var t;return Gp(this,void 0,void 0,(function*(){const n=e.select((e=>e.Guid)).toArray(),s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Np(n),15e3,!1);return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ae.OK?(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ae.OK):(ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to change groups order, controller responded with error ${null==s?void 0:s.Status} data: ${null==s?void 0:s.Data}`),this.LogGroupsOrder(e),null==s?void 0:s.Status)}))}ChangeObjectsPositionsInGroupAsync(e,t){var n;return Gp(this,void 0,void 0,(function*(){const s=t.select((e=>e.ChannelId)).toArray(),o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Op(e.Guid,s),15e3,!1);return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ae.OK?(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),ae.OK):(ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to change objects positions in group, controller responded with error ${null==o?void 0:o.Status} data: ${null==o?void 0:o.Data}`),this.LogObjectsInGroupOrder(e,t),null==o?void 0:o.Status)}))}IsGroupsAndObjectsOrderingAvailable(){return this._objectsGroupingSupported}MoveGroupPositionAsync(e,t){var n;return Gp(this,void 0,void 0,(function*(){const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new bp(e.Guid,t),15e3,!1);return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ae.OK?(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ae.OK):(ev.Get(r.ServiceName).Error(kp.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){var s;return Gp(this,void 0,void 0,(function*(){const o=`${t.GetDevice().Guid}_${t.Number}`,i=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Pp(e.Guid,o,n),15e3,!1);return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ae.OK?(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),ae.OK):(ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to move object in group position, controller responded with error ${null==i?void 0:i.Status} data: ${null==i?void 0:i.Data}`),null==i?void 0:i.Status)}))}AddDeviceChannelToGroupByGuidAsync(e,t){var n,s;return Gp(this,void 0,void 0,(function*(){const o=new Bp;if(o.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");o.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,o.Data.GroupGuid=t;const i=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ae.OK?e.ChannelGroups.push(t):ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to add device channel ${e.Name} to group ${t}, controller responded with error ${i.Status} data: ${i.Data}`),ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ae.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){var n,s;return Gp(this,void 0,void 0,(function*(){const o=new $p;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");o.Data.DeviceGuid=null===(n=e.GetDevice())||void 0===n?void 0:n.Guid,o.Data.Channel=e.Number,o.Data.GroupGuid=t;const i=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ae.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to remove device channel ${e.Name} from group ${t}, controller responded with error ${i.Status} data: ${i.Data}`),ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ae.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Gp(this,void 0,void 0,(function*(){if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupWithIconAsync(e.Name,e.IconName);if(!(t instanceof Tp))return t instanceof Te?t:new Te(Cp.UnknownError,"");e=t}for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(n,e);if(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),t!==ae.OK)return ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`),new Te(Cp.UnknownError,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`)}let n=yield ev.Get(ho.ServiceName).GetDevicesAsync();for(let o of n)for(let n of o.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var s of n.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(n,e);if(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ae.OK)return ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),new Te(Cp.UnknownError,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`)}return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Gp(this,void 0,void 0,(function*(){for(let n of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(n,e);if(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ae.OK)return ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),ae.FatalError}let n=yield ev.Get(ho.ServiceName).GetDevicesAsync();for(let o of n)for(let n of o.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(var s of n.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(n,e);if(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),t!==ae.OK)return ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),ae.FatalError}return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),ae.OK}))}ChangeGroupNameByGuidAsync(e,t){var n,r;return Gp(this,void 0,void 0,(function*(){let s=new Lp,o=new Wp,i=this._groups.first((t=>t.Guid===e));o.Guid=e,o.Name=t,o.IconName=i.IconName,null===(n=s.Data)||void 0===n||n.push(o);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(s,15e3,!1);if(ev.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return new Te(Cp.Success,"");case ae.WrongData:switch(a.Data){case"NameToShort":return new Te(Cp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Cp.NameAlreadyExists,"Group with this name already exists");default:return new Te(Cp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(Cp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(Cp.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){var r,s;return Gp(this,void 0,void 0,(function*(){let o=new Lp,i=new Wp,a=this._groups.first((t=>t.Guid===e));i.Guid=e,i.Name=t,i.IconName=n,i.ObjectsOrder=a.ObjectsOrder,null===(r=o.Data)||void 0===r||r.push(i);const c=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);if(ev.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=c&&null!=c.Status)switch(c.Status){case ae.OK:return new Te(Cp.Success,"");case ae.WrongData:switch(c.Data){case"NameToShort":return new Te(Cp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Cp.NameAlreadyExists,"Group with this name already exists");default:return new Te(Cp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Te(Cp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Te(Cp.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){var n,r;return Gp(this,void 0,void 0,(function*(){let s=new Lp,o=new Wp,i=this._groups.first((t=>t.Guid===e));o.Guid=e,o.Name=i.Name,o.IconName=t,null===(n=s.Data)||void 0===n||n.push(o);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(s,15e3,!1);if(ev.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return new Te(Cp.Success,"");case ae.WrongData:switch(a.Data){case"NameToShort":return new Te(Cp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Cp.NameAlreadyExists,"Group with this name already exists");default:return new Te(Cp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(Cp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(Cp.UnknownError,"")}))}GetServiceName(){return kp.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){var t;return Gp(this,void 0,void 0,(function*(){let n=new xp;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync();for(let t of yield ev.Get(ho.ServiceName).GetDevicesAsync())for(let n of t.Channels)n.ChannelGroups.any((t=>t===e))&&(n.ChannelGroups=n.ChannelGroups.except(e,((e,t)=>e===t)).toArray());return ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=r&&null!=r.Status?null==r?void 0:r.Status:ae.Error}))}GetGroupsAsync(e=!1){var t,n;return Gp(this,void 0,void 0,(function*(){const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Fp,15e3,e);let o=[];if((null==s?void 0:s.Status)===ae.OK){let e=ev.Get(r.ServiceName),t=0,i=yield ev.Get(ho.ServiceName).GetDevicesAsync();return null===(n=s.Data)||void 0===n||n.forEach((n=>{t++;let r=new Tp;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.Info(kp.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),o.push(r)})),this._groups=o,o}throw new Error(`Failed to get groups, API responded with status ${null==s?void 0:s.Status} data: ${null==s?void 0:s.Data}`)}))}AddDeviceChannelToGroupAsync(e,t){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid)}RemoveDeviceChannelFromGroupAsync(e,t){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid)}AddNewGroupAsync(e){var t,n;return Gp(this,void 0,void 0,(function*(){let s=new Lp,o=new Wp;o.Name=e,null===(t=s.Data)||void 0===t||t.push(o);const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(s,15e3,!1);if(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status)switch(i.Status){case ae.OK:return this._groups.first((t=>t.Name===e));case ae.WrongData:switch(ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new Te(Cp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Cp.NameAlreadyExists,"Group with this name already exists");default:return new Te(Cp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Te(Cp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Te(Cp.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){var n,s;return Gp(this,void 0,void 0,(function*(){let o=new Lp,i=new Wp;i.Name=e,i.IconName=t,null===(n=o.Data)||void 0===n||n.push(i);const a=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(o,15e3,!1);if(ev.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield ev.Get(ho.ServiceName).GetDevicesAsync(),ev.Get(Xe.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return this._groups.first((t=>t.Name===e));case ae.WrongData:switch(ev.Get(r.ServiceName).Error(kp.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new Te(Cp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(Cp.NameAlreadyExists,"Group with this name already exists");default:return new Te(Cp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(Cp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(Cp.UnknownError,"")}))}}kp.ServiceName="ChannelsGroupsService";class bp extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ce.Post,this.Data=new Rp,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Np extends ie{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ce.Post,this.Data=e}}class Ep extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=ce.Post,this.Data=new Ip,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Ip{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Rp{constructor(){this.GroupGuid="",this.NewPosition=0}}class Pp extends ie{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ce.Post,this.Data=new Up,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Op extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ce.Post,this.Data=new Mp,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class Up{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Mp{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class xp extends ie{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ce.Delete}}class Fp extends ie{constructor(){super(),this.Resource="/devices/groups/",this.Method=ce.Get}}class Lp extends ie{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ce.Put,this.Data=[]}}class Bp extends ie{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ce.Put,this.Data=new qp}}class $p extends ie{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ce.Delete,this.Data=new qp}}class Wp{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class qp{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Hp{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"}(Dp||(Dp={}));var Vp=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 jp{constructor(){this._syncLock=new Hp,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=Dp.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new Ae,this._onSuspendedEvent=new Ae,this._onEnterLowPowerModeEvent=new Ae,this._onExitLowPowerModeEvent=new Ae,this._onBackButtonPressedEvent=new Ae,this._onForwardButtonPressedEvent=new Ae,this._onAppStateChanged=new n,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>Vp(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=s.Log)||void 0===t||t.Warning(jp.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=s.Log)||void 0===r||r.Warning(jp.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return Vp(this,void 0,void 0,(function*(){this._session=yield ev.GetAsync("SessionService"),this._connection=yield ev.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(jp.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(Dp.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(jp.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(Dp.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,o,i,a;switch(e){case de.Connected:null===(t=s.Log)||void 0===t||t.Warning(jp.ServiceName,"App state changed to: connected"),this._onAppStateChanged.Invoke(Dp.Connected);break;case de.Disconnected:null===(n=s.Log)||void 0===n||n.Warning(jp.ServiceName,"App state changed to: disconnected"),this._onAppStateChanged.Invoke(Dp.Disconnected);break;case de.Connecting:null===(r=s.Log)||void 0===r||r.Warning(jp.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(Dp.Connecting);break;case de.Disconnecting:null===(o=s.Log)||void 0===o||o.Warning(jp.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(Dp.Disconnecting);break;case de.Reconnecting:null===(i=s.Log)||void 0===i||i.Warning(jp.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(Dp.Reconnecting);break;case de.Failed:null===(a=s.Log)||void 0===a||a.Warning(jp.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(Dp.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(Dp.Suspended),null===(e=s.Log)||void 0===e||e.Warning(jp.ServiceName,"App state changed to: suspended"),null===(t=s.Log)||void 0===t||t.Warning(jp.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(Dp.ReturnedFromSuspension),null===(e=s.Log)||void 0===e||e.Warning(jp.ServiceName,"App state changed to: returned from suspension"),null===(t=s.Log)||void 0===t||t.Warning(jp.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Dp.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Dp.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 jp.ServiceName}}jp.ServiceName="AppStateService";class Kp{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 zp,Jp,Yp=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Xp{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new Kp(1)}GetServiceName(){return Xp.ServiceName}GetExtensionsInfoAsync(e,t=!1){return Yp(this,void 0,void 0,(function*(){ev.Get(r.ServiceName).Debug(Xp.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);var n=yield this._semaphore.AcquireAsync();if(this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync()),n.Release(),0==[...this._extensionInfoCache.values()].length)return[];if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new eg("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e,t=!1,n=!1){return Yp(this,void 0,void 0,(function*(){if(ev.Get(r.ServiceName).Debug(Xp.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 eg("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 eg("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return Yp(this,void 0,void 0,(function*(){const e=new Qp,t=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new eg("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ae.OK)throw new eg(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new eg("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 Yp(this,void 0,void 0,(function*(){const e=new Zp,t=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new eg("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(t.Status){case ae.OK:if(null==t.Data)throw new eg("Cannot get ProtocolInfo from controller, controller response does not contain data!");t.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ae.ResourceDoesNotExists:ev.Get(r.ServiceName).Debug(Xp.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new eg(`Cannot get ProtocolInfo from controller! Response status: ${t.Status}`)}}))}}Xp.ServiceName="StatisticsInfoService";class Qp extends ie{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ce.Get}}class Zp extends ie{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ce.Get}}class eg extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(zp||(zp={}));class tg{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=Jp.Unknown,this.ResourceGuid=""}}class ng{constructor(){this.UpdateDescription=new Map,this.Update=new tg,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"}(Jp||(Jp={}));class rg extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var sg,og,ig,ag,cg,ug,lg,dg,hg,pg,gg=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 fg{constructor(){this._services=new Map,this._runtimeInfo=new vg,this._hardwareInfo=new yg,this._semaphore=new Kp(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return fg.ServiceName}RegisterUpdatesProvider(e){ev.Get(r.ServiceName).Debug(fg.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return gg(this,void 0,void 0,(function*(){ev.Get(r.ServiceName).Debug(fg.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const t=this._services.get(e);if(null==t)throw new rg("Cannot get update provider! Requested update provider has not been registered.");return t}))}GetUpdatesProvidersAsync(e){return gg(this,void 0,void 0,(function*(){ev.Get(r.ServiceName).Debug(fg.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let t=[];if(t=[...this._services.values()].filter((t=>t.ProviderType==e)),0==t.length)throw new rg("Cannot get update providers! Requested update providers has not been registered.");return t}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return gg(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){ev.Get(r.ServiceName).Debug(fg.ServiceName,`Getting update providers with protocol guid: [${e}] by GetUpdateProvidersByProtocolAsync<T>()`);let s=[];if(s=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==s.length)throw new rg("Cannot get update providers! Requested update providers has not been registered.");return s}throw new rg("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return gg(this,void 0,void 0,(function*(){if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){ev.Get(r.ServiceName).Debug(fg.ServiceName,`Getting update providers with extension guid: [${e}] by GetUpdateProvidersByExtensionAsync<T>()`);let s=[];if(s=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==s.length)throw new rg("Cannot get update providers! Requested update providers has not been registered.");return s}throw new rg("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(e=!1){return gg(this,void 0,void 0,(function*(){var t=yield this._semaphore.AcquireAsync();return!this._isRuntimeInfoInitialized||e?(yield this.GetRuntimeControllerInfoAsync(),t.Release(),this._runtimeInfo):(t.Release(),this._runtimeInfo)}))}GetRuntimeControllerInfoAsync(){return gg(this,void 0,void 0,(function*(){ev.Get(r.ServiceName).Debug(fg.ServiceName,"Getting runtime version info from controller.");try{const e=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new mg,16e3,!1);if(null==e||null==e.Status)throw new Sg('Cannot get runtime info, controller response result is empty."',sg.EmptyResponse);if(e.Status!=ae.OK)throw new Sg(`Cannot get runtime info, controller responded with status ${e.Status}.`,sg.WrongResponseStatus);if(null==e.Data)throw new Sg("Cannot get runtime info, controller responded with status OK but response does not contains data.",sg.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof p?new Sg("Cannot get runtime info, controller response timeout.",sg.Timeout):e}}))}GetHardwareInfoAsync(e=!1){return gg(this,void 0,void 0,(function*(){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return gg(this,void 0,void 0,(function*(){ev.Get(r.ServiceName).Debug(fg.ServiceName,"Getting hardware info from controller.");const e=yield ev.Get(Gt.ServiceName).SendAndWaitForResponseAsync(new wg,8e3,!1);if(null==e||null==e.Status)throw new Sg('Cannot get hardware info, controller response result is empty."',sg.EmptyResponse);if(e.Status!=ae.OK)throw new Sg(`Cannot get hardware info, controller responded with status ${e.Status}.`,sg.WrongResponseStatus);if(null==e.Data)throw new Sg("Cannot get hardware info, controller responded with status OK but response does not contains data.",sg.NoDataInResponse);this._hardwareInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}}fg.ServiceName="UpdateProvider";class vg{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class mg extends ie{constructor(){super(),this.Resource="/controller/software/info",this.Method=ce.Get}}class yg{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class wg extends ie{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ce.Get}}class Sg 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"}(sg||(sg={}));class _g{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class Ag{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class Cg{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(og||(og={})),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"}(ig||(ig={})),(pg=ag||(ag={}))[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",(hg=cg||(cg={}))[hg.Ignore=0]="Ignore",hg[hg.Cancel=1]="Cancel",hg[hg.Install=2]="Install";class Tg{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=ig.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class Dg{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=ug.Unknown}}!function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate"}(ug||(ug={})),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"}(lg||(lg={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(dg||(dg={}));var Gg,kg,bg,Ng,Eg,Ig,Rg,Pg,Og=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Ug{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5.56,this._updateOfflineStageTime=8.5,this._updateProviders=ev.Get(fg.ServiceName),this._logger=ev.Get(r.ServiceName),this._connection=ev.Get(Gt.ServiceName),this._appStateService=ev.Get(jp.ServiceName),this._extensionService=ev.Get(Xp.ServiceName)}GetAutomaticControllerUpdateDownloadStatusAsync(){return Og(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(lg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let t=yield this._connection.SendAndWaitForResponseAsync(new Jg,1e4,!1);return!(t.Status!=ae.OK||!t.Data)}))}GetServiceName(){return Ug.ServiceName}CheckDeviceVersionAsync(e){var t;return Og(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield ev.Get(ho.ServiceName).GetDevice(e);if(null==t)return new Te(lg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Te(lg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,zp.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){var t;return Og(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield ev.Get(ho.ServiceName).GetDevice(e);if(null==t)return new Te(lg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Te(lg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,zp.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const s=new Fg;s.CurrentResourceVersion=r.CurrentResourceVersion,s.NewResourceVersion=r.Update.Version,s.UpdatedResourceName=r.UpdatedResourceName,s.UpdateResourceGuid=r.Update.ResourceGuid,s.UpdateDescription=new Map([["pl-PL",r.Update.Description]]);let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(n.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}return s.Protocol=o,s.ProtocolGuid=n.ProtocolGuid,(yield ev.Get(ho.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(s.IsUpdateSafe=!1),s}))}InstallDeviceUpdateAsync(e,t,n,r=!1){var s;return Og(this,void 0,void 0,(function*(){let o;if("string"==typeof e){const t=yield ev.Get(ho.ServiceName).GetDevice(e);if(null==t)return new Te(lg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);o=t}else o=e;if(null==o.ProtocolGuid)return new Te(lg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(s=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,zp.Device)).first())||void 0===s?void 0:s.GetAvailableUpdateAsync(o);if(null!=i.Type)return i;this._appStateService.DisallowHibernation();const a=yield(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,zp.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ae.OK)}))}CheckControllerUpdatesAsync(){return Og(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new _g,n=yield this.getRuntimeInfoAsync();if(n instanceof Te){const e=new Mg;return e.UpdateType=og.SoftwareUpdate,e.ResponseResult=n,t.UpdatesNotAvailable.push(e),t}const r=parseFloat(n.SoftwareVersion);try{e=yield this._updateProviders.GetUpdatesProvidersAsync(zp.Controller)}catch(e){if(!(e instanceof rg))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 s=new Mg;s.ResponseResult=r,s.UpdateType=og.RadioUpdate;let o="n/a";try{o=(yield this._extensionService.GetProtocolInfoAsync(e[n].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}s.UpdatedResourceName=new Map([["pl-PL",o],["en-US",o]]),s.CurrentResourceVersion=yield e[n].GetCurrentRadioVersionAsync(),t.UpdatesNotAvailable.push(s)}else{const s=r,o=new xg;o.UpdatedResourceName=new Map([["pl-PL",s.UpdatedResourceName],["en-US",s.UpdatedResourceName]]),o.CurrentResourceVersion=s.CurrentResourceVersion,o.NewResourceVersion=s.Update.Version,o.UpdateDescription=new Map([["pl-PL",s.Update.Description]]),o.UpdateType=og.RadioUpdate,o.UpdateIdentifier=re.GenerateUUID(),o.UpdateIsDownloading=!1,o.DownloadProgress=100,o.UpdateCreationTime=null,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:e[n].GetUpdateProviderName(),UpdateType:og.RadioUpdate}))}}if(r>this._oldUpdateVersion){const e=yield this._connection.SendAndWaitForResponseAsync(new Vg,1e4,!1);if(null==e||e.Status!=ae.OK&&e.Status!=ae.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 ng;r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,r.UpdateDescription=oe(e.Data.Update.UpdateDescription),r.UpdatedResourceName=oe(e.Data.Update.UpdateName).get("en-US");const s=new xg;s.UpdatedResourceName=oe(e.Data.Update.UpdateName),s.UpdateDescription=oe(e.Data.Update.UpdateDescription),s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.NewResourceVersion=`${e.Data.Update.Version.BaseRuntime}.${e.Data.Update.Version.ContainerSoftwareVersion}`,s.UpdateType=og.SoftwareUpdate,s.UpdateIdentifier=e.Data.Update.Guid,s.UpdateIsDownloading=e.Data.UpdateStep==Ng.DownloadingInstaller||e.Data.UpdateStep==Ng.DownloadingUpdate||e.Data.UpdateStep==Ng.CheckingUpdate,s.DownloadProgress=e.Data.DownloadProgress,s.UpdateCreationTime=e.Data.Update.Creationtime,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:Ug.ServiceName,UpdateType:og.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new jg,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ae.NoData:const r=new Mg;r.UpdateType=og.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Te(lg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ae.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const s=new ng;s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateDescription=oe(e.Data.UpdateDescription),s.UpdatedResourceName=oe(e.Data.UpdateName).get("en-US");const o=new xg;o.UpdatedResourceName=oe(e.Data.UpdateName),o.UpdateDescription=oe(e.Data.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateType=og.SoftwareUpdate,o.UpdateIdentifier=e.Data.Guid,o.NewResourceVersion=`${e.Data.Version.BaseRuntime}.${e.Data.Version.ContainerSoftwareVersion}`,o.UpdateIsDownloading=!1,o.DownloadProgress=0,o.UpdateCreationTime=e.Data.Creationtime,t.UpdatesAvailable.push(o),this._controllerUpdates.push(Object.assign(Object.assign({},s),{UpdateIdentifier:o.UpdateIdentifier,ProviderName:Ug.ServiceName,UpdateType:og.SoftwareUpdate}));break;default:throw new Error(`Cannot check updates! Response status is not OK. Status: ${e.Status}`)}}}else{const e=`https://updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const r=yield fetch(e);let s,o=new ng;const i=new Mg;switch(i.UpdateType=og.SoftwareUpdate,i.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.status){case 200:null!=r.body&&(s=yield r.json());break;case 404:i.ResponseResult=new Te(lg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Te(lg.CannotGetUpdates,`Response status code does not indicate success. Status: ${r.status}`),t.UpdatesNotAvailable.push(i)}if(null!=s){o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.Update=s;const e=new xg;e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.CurrentResourceVersion=o.CurrentResourceVersion,e.NewResourceVersion=o.Update.Version,e.UpdateDescription=new Map([["pl-PL",o.Update.Description]]),e.UpdateType=og.SoftwareUpdate,e.UpdateIdentifier=re.GenerateUUID(),e.DownloadProgress=100,e.UpdateIsDownloading=!1,e.UpdateCreationTime=null,t.UpdatesAvailable.push(e),this._controllerUpdates.push(Object.assign(Object.assign({},o),{UpdateIdentifier:e.UpdateIdentifier,ProviderName:Ug.ServiceName,UpdateType:og.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 Te){const e=new Mg;e.UpdateType=og.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new Mg;r.UpdateType=og.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Te(lg.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return Og(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(zp.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Te)return t;const n=[];let r;r=new Cg,r.Resource="Controller software",r.Type=og.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new Cg,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=og.RadioUpdate;let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(e[t].ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}r.Resource=s,n.push(r)}return n}))}GetControllerUpdateBranchAsync(){return Og(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(lg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new qg,1e4,!1);if(null==t||(null==t?void 0:t.Status)!=ae.OK)return new Te(lg.CannotGetUpdatesBranch,`Cannot get update branch, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`);switch(t.Data){case 0:return dg.Public;case 1:return dg.Beta;case 2:return dg.Development;default:return new Te(lg.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${t.Data}`)}}))}SetControllerUpdateBranchAsync(e){return Og(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Te)return t;if(parseFloat(t.SoftwareVersion)<=this._oldUpdateVersion)return new Te(lg.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const n=yield this._connection.SendAndWaitForResponseAsync(new Hg(e),1e4,!1);return null==n||(null==n?void 0:n.Status)!=ae.OK?new Te(lg.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==n?void 0:n.Status}`):ae.OK}))}EnableAutomaticControllerUpdateDonwloadAsync(){return Og(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(lg.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new Yg,1e4,!1);return null==t||(null==t?void 0:t.Status)!=ae.OK?new Te(lg.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`):ae.OK}))}DisableAutomaticControllerUpdateDonwloadAsync(){return Og(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(lg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new Xg,1e4,!1);return null==t||(null==t?void 0:t.Status)!=ae.OK?new Te(lg.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==t?void 0:t.Status}`):ae.OK}))}GetControllerUpdatesHistoryAsync(){return Og(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;if(parseFloat(e.SoftwareVersion)<=this._oldUpdateVersion)return new Te(lg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const t=yield this._connection.SendAndWaitForResponseAsync(new Qg,1e4,!1);if(null==t)return new Te(lg.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(t.Status){case ae.OK:return null!=t.Data?t.Data.map((e=>{const t=new Ag;return t.UpdatedResourceName=oe(e.UpdateName),t.UpdateDescription=oe(e.UpdateDescription),t.UpdateCreationTime=e.Creationtime,t.UpdateChannel=e.UpdateChannel,t.Version=`${e.Version.BaseRuntime}.${e.Version.ContainerSoftwareVersion}`,t})):new Te(lg.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ae.NoData:return[];default:return new Te(lg.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${t.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,s){return Og(this,void 0,void 0,(function*(){const o=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),i=this._controllerUpdates.length,a=yield this.getRuntimeInfoAsync();if(a instanceof Te)return a;const c=parseFloat(a.SoftwareVersion);if(0==this._controllerUpdates.length)return new Te(lg.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if("string"!=typeof n||!o.test(n)){const s=[1],o=t=>{t.UpdateNumber=s[0],t.AvailableUpdates=i,e(t)},a=e=>Og(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let u=this._controllerUpdates.where((e=>e.UpdateType==og.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],o,n);yield a(5e3),t==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=u[e].UpdateIdentifier))),l.push(t),s[0]++}const d=this._controllerUpdates.find((e=>e.UpdateType==og.SoftwareUpdate));if(null!=d)if(c<=this._oldUpdateVersion){const e=yield this.UpdateControllerUsingScriptAsync(d.Update,o);e==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=d.UpdateIdentifier))),l.push(e),s[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(o,t,r);this._appStateService.AllowHibernation(),e==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),l.push(e),s[0]++}const h=l.where((e=>e instanceof Te)).toArray();if(null!=h&&0!=h.length){let e="";return h.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),new Te(lg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ae.OK}{let o;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Te(lg.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 og.RadioUpdate:return r?new Te(lg.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it."):(o=yield(yield this._updateProviders.GetUpdatesProviderAsync(i.ProviderName)).InstallRadioUpdateAsync(i,e,s),this._appStateService.AllowHibernation(),o==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),o);case og.SoftwareUpdate:if(c<=this._oldUpdateVersion){if(r)return new Te(lg.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");o=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),o==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else o=yield this.UpdateControllerUsingApiAsync(e,t,r),this._appStateService.AllowHibernation(),o==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)));return o;default:return new Te(lg.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){var n,r,s,o,i,a;return Og(this,void 0,void 0,(function*(){switch(e.UpdateType){case Jp.Container:case Jp.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Lg(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new Tg;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ae.MultiDataResponseStart:r.Status=ig.PreparingForUpgrade;break;case ae.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(Ug.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case ag.CheckingApplicability:case ag.CheckingIntegrity:case ag.CheckingPackageIntegrity:r.Status=ig.CheckingPackage;break;case ag.CreatingBackup:case ag.MigratingData:case ag.Removing:r.Status=ig.MovingData;break;case ag.Deploying:case ag.Installing:r.Status=ig.Upgrading;break;case ag.Downloading:r.Status=ig.DownloadingPackage;break;case ag.Error:r.Status=ig.Error;break;case ag.Installed:r.Status=ig.Upgraded;break;case ag.PreparingSystem:case ag.ReadyToDownload:r.Status=ig.PreparingForUpgrade;break;case ag.UndoingInstallation:r.Status=ig.InstallationStopped;break;case ag.Unpackaging:r.Status=ig.MovingData;break;case ag.WaitingForUser:r.Status=ig.Upgrading}break;case ae.MultiDataResponseStop:r.Status=ig.OK}t(r)}),!1),ae.OK}catch(e){return new Te(lg.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case Jp.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 Te)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield ev.Get(ho.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(Ug.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new Tg;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=ig.PreparingForUpgrade,t(r);let s=2;const o=Date.now(),i=900*c+8e5,a=i/100,u=o+i,l=new Promise(((o,c)=>Og(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=ig.Upgraded,t(r),o(ae.OK);else{var e=u-Date.now();e<i?s=95-e/a:(clearInterval(n),n=setInterval((()=>{clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=ig.Upgraded,t(r),o(ae.OK)}),e))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),n=setInterval((()=>{if(s>99)clearInterval(n),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=ig.Upgraded,t(r),o(ae.OK);else{var e=s;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=ig.Upgrading,t(r))}s++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Bg(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ae.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=ig.InstallationError,t(r),this._logger.Debug(Ug.ServiceName,`Update failed with error. Update response status: ${d.Status}`),o(new Te(lg.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(Ug.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=ig.Error,t(r),clearInterval(n),o(new Te(lg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new Tg;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Te(lg.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new $g({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ae.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.PreparingForUpgrade,t(n);let r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Wg("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ae.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.PreparingForUpgrade,t(n),r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Wg(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ae.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Wg("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ae.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.Upgrading,t(n);let e,r=0;const s=.95,o=Date.now(),i=900*c+15e5,a=i/95,u=o+i,l=new Promise(((o,c)=>Og(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=ig.Upgraded,t(n),o(ae.OK);else{var s=u-Date.now();s<i?r=95-s/a:(clearInterval(e),e=setInterval((()=>{clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.Upgraded,t(n),o(ae.OK)}),s))}};this._appStateService.OnReturnedFromSuspension().Subscribe(l),e=setInterval((()=>{if(r>99)clearInterval(e),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.Upgraded,t(n),o(ae.OK);else{var i=5+r*s;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Wg("/runtime/tmp/update.sh"),12e3,!1)}catch(e){o(new Te(lg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=ig.InstallationError,t(n),new Te(lg.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Wg("/runtime/scripts/restart_all.sh"),12e3,!1),new Te(lg.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Te(lg.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Te(lg.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Te(lg.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}UpdateControllerUsingApiAsync(e,t,n){return Og(this,void 0,void 0,(function*(){const r=e=>Og(this,void 0,void 0,(function*(){return new Promise(((r,s)=>Og(this,void 0,void 0,(function*(){yield this._connection.SendAndHandleResponseAsync(new Kg,this._updateRequestTimeout,(s=>{var o,i,a,c;const u=new Dg;switch(u.UpdatedResourceName=oe(e.Update.UpdateName),s.Status){case ae.MultiDataResponseStart:u.Percentage=0,u.SpeedMbps=0,u.PercentageTotal=0,u.CurrentTask=ug.DownloadingInstaller,t(u);break;case ae.MultiDataResponse:if(null!=s.Data){switch(u.Percentage=s.Data.StepProgressInPercentage,u.SpeedMbps=s.Data.DownloadSpeedInMbs,u.PercentageTotal=n?Math.round(2*(null===(o=s.Data)||void 0===o?void 0:o.UpdateProgressInPercentage)):Math.round(null===(i=s.Data)||void 0===i?void 0:i.UpdateProgressInPercentage),s.Data.UpdateStep){case Ng.DownloadingInstaller:u.CurrentTask=ug.DownloadingInstaller;break;case Ng.DownloadingUpdate:u.CurrentTask=ug.DownloadingUpdate;break;default:u.CurrentTask=ug.CheckingUpdate}t(u)}break;case ae.MultiDataResponseStop:if(null!=s.Data)switch(s.Data.UpdateStep){case Ng.UpdateDownloaded:u.Percentage=100,u.PercentageTotal=n?Math.round(2*(null===(a=s.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)):Math.round(null===(c=s.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),u.SpeedMbps=0,u.CurrentTask=ug.CheckingUpdate,t(u),r(ae.OK);break;case Ng.UpdateDownloadFailed:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=ug.Unknown,t(u),r(new Te(lg.UpdateDownloadFailed,"Update download failed!"))}}}),!1)}))))})),s=t=>Og(this,void 0,void 0,(function*(){return new Promise(((n,r)=>Og(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let s=0;yield this._connection.SendAndHandleResponseAsync(new zg,this._updateRequestTimeout,(o=>{var i,a;const c=new Tg;switch(c.UpdatedResourceName=oe(t.Update.UpdateName),o.Status){case ae.MultiDataResponseStart:c.Status=ig.PreparingForUpgrade,c.Percentage=null===(i=o.Data)||void 0===i?void 0:i.StepProgressInPercentage,c.PercentageTotal=null===(a=o.Data)||void 0===a?void 0:a.UpdateProgressInPercentage,e(c);break;case ae.MultiDataResponse:null!=o.Data&&(c.Status=ig.Upgrading,c.Percentage=Math.round(o.Data.StepProgressInPercentage),c.PercentageTotal=Math.round(o.Data.UpdateProgressInPercentage),s=o.Data.StepProgressInPercentage,e(c));break;case ae.MultiDataResponseStop:if(null!=o.Data)switch(o.Data.UpdateStep){case Ng.UpdateInstallationFailed:c.Status=ig.InstallationError,c.Percentage=0,c.PercentageTotal=0,e(c),n(new Te(lg.CannotProcessUpdate,"Update installation failed!"));break;case Ng.OfflineUpdateStep:{c.Percentage=Math.round(o.Data.StepProgressInPercentage),c.PercentageTotal=Math.round(o.Data.UpdateProgressInPercentage);let t=(100-c.PercentageTotal)/100,i=c.PercentageTotal;const a=setInterval((()=>{s++,i+=t,i>100&&(i=100),s>=100?(c.Status=ig.Upgraded,c.Percentage=100,c.PercentageTotal=100,e(c),clearInterval(a),n(ae.OK)):(c.Status=ig.Upgrading,c.Percentage=Math.round(s),c.PercentageTotal=Math.round(i),e(c))}),r/(100-s))}}}}),!1)}))))}));if(n){const e=yield this._connection.SendAndWaitForResponseAsync(new Vg,1e4,!1);if(null==e||(null==e?void 0:e.Status)!=ae.OK||null==(null==e?void 0:e.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);switch(e.Data.UpdateStep){case Ng.DownloadingInstaller:case Ng.DownloadingUpdate:case Ng.UpdateDownloaded:return new Te(lg.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case Ng.InstallingUpdate:case Ng.PreparingUpdate:return new Te(lg.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield r(e.Data)}}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Vg,1e4,!1);if(null==e||(null==e?void 0:e.Status)!=ae.OK||null==(null==e?void 0:e.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);switch(e.Data.UpdateStep){case Ng.DownloadingInstaller:case Ng.DownloadingUpdate:return new Te(lg.UpdateAlreadyDownloaded,"Update already downloaded, or donwload in progress.");case Ng.InstallingUpdate:case Ng.PreparingUpdate:return new Te(lg.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case Ng.UpdateDownloaded:return yield s(e.Data);default:var o=yield r(e.Data);return o!=ae.OK?o:yield s(e.Data)}}}))}getRuntimeInfoAsync(){return Og(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof Sg&&e.code==sg.Timeout?new Te(lg.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Te(lg.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}Ug.ServiceName="UpdatesService";class Mg{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class xg{constructor(){this._updateIdentifier="",this._updateResourceName=new Map,this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map,this._updateIsDownloading=!1,this._updateCheckDownloadProgress=0,this._updateCreationTime=null}get UpdateCreationTime(){return this._updateCreationTime}get DownloadProgress(){return this._updateCheckDownloadProgress}get UpdateDescription(){return this._updateDescription}get UpdateIdentifier(){return this._updateIdentifier}get UpdatedResourceName(){return this._updateResourceName}get UpdateType(){return this._updateType}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}get UpdateIsDownloading(){return this._updateIsDownloading}set UpdateCreationTime(e){this._updateCreationTime=e}set DownloadProgress(e){this._updateCheckDownloadProgress=e}set UpdateDescription(e){this._updateDescription=e}set UpdateIdentifier(e){this._updateIdentifier=e}set UpdatedResourceName(e){this._updateResourceName=e}set UpdateType(e){this._updateType=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}set UpdateIsDownloading(e){this._updateIsDownloading=e}}class Fg{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 Lg extends ie{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=ce.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"}(Gg||(Gg={})),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"}(kg||(kg={})),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"}(bg||(bg={})),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"}(Ng||(Ng={}));class Bg extends ie{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ce.Put,this.Data=e}}class $g extends ie{constructor(e){super(),this.Resource="/users/user/login",this.Method=ce.Put,this.Data=e}}class Wg extends ie{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ce.Post,this.Data=e}}class qg extends ie{constructor(){super(),this.Resource="/updates/branch",this.Method=ce.Get}}class Hg extends ie{constructor(e){super(),this.Resource="/updates/branch",this.Method=ce.Put,this.Data=e}}class Vg extends ie{constructor(){super(),this.Resource="/updates/pending",this.Method=ce.Get}}class jg extends ie{constructor(){super(),this.Resource="/updates/check",this.Method=ce.Get}}class Kg extends ie{constructor(){super(),this.Resource="/updates/download",this.Method=ce.Post}}class zg extends ie{constructor(){super(),this.Resource="/updates/install",this.Method=ce.Post}}class Jg extends ie{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=ce.Get}}class Yg extends ie{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=ce.Put}}class Xg extends ie{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=ce.Put}}class Qg extends ie{constructor(){super(),this.Resource="/updates/history",this.Method=ce.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"}(Eg||(Eg={})),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"}(Ig||(Ig={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(Rg||(Rg={}));class Zg{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"}(Pg||(Pg={}));var ef,tf,nf,rf,sf,of,af,cf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 uf{constructor(){this._connection=null,this._connection=ev.Get(Gt.ServiceName)}GetServiceName(){return uf.ServiceName}GetStatesByIntervalAsync(e,t,n,r,s,o,i=!1){var a;return cf(this,void 0,void 0,(function*(){try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Te(Eg.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 ev.Get(ho.ServiceName).GetDevice(e);if(null==t)return new Te(Eg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new Te(Eg.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 Te(Eg.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new df;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.Range=r,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=s,u.Offset=o;const l=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new lf(u),2e4,!1);if(null==l)return new Te(Eg.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case ae.WrongData:switch(l.Data){case"IncorrectLimitValue":return new Te(Eg.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Te(Eg.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Te(Eg.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Te(Eg.OtherError,"Cannot get state history data - unknown error!")}case ae.FatalError:return new Te(Eg.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ae.ResourceDoesNotExists:return new Te(Eg.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ae.OK:if(null==l.Data)return new Te(Eg.NoData,"Controller responede with status OK, but response does not contain data!");if(l.Data.AggregateDataList=l.Data.AggregateDataList.map((e=>(e.AggregateData=oe(e.AggregateData),e))),n===ht.MeasuredEnergy){const e=l.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=oe(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=oe(e.Values.MeasurementNonAveragingParmeters),t}));return l.Data.Data=e,l.Data}return l.Data;default:return new Te(Eg.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new Te(Eg.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){var e;return cf(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new hf,12e3,!1);return null==t?new Te(Eg.OtherError,"Cannot get available states - response is null."):t.Status!=ae.OK?new Te(Eg.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Te(Eg.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Zg;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Te(Eg.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return cf(this,void 0,void 0,(function*(){return!(parseFloat((yield ev.Get(fg.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}GetAvailableStatesPerChannelAsync(e,t){var n;return cf(this,void 0,void 0,(function*(){let r;if("string"==typeof e){const t=yield ev.Get(ho.ServiceName).GetDevice(e);if(null==t)return new Te(Eg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);r=t}else r=e;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new pf(new gf(r.Guid,t)),8e3,!1);if(null==s)return new Te(Eg.OtherError,"Cannot get available states - response is null.");switch(s.Status){case ae.ResourceDoesNotExists:switch(s.Data){case"DeviceNotFound":return new Te(Eg.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Te(Eg.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Te(Eg.OtherError,"Cannot get available states - unknown error!")}case ae.OK:{if(null==s.Data)return new Te(Eg.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!");const e=s.Data.AvailableStates.map((e=>{const t=new Zg;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return s.Data.AvailableStates=e,s.Data}default:return new Te(Eg.OtherError,`Cannot get available states - controller responded with response code ${s.Status}`)}}))}}uf.ServiceName="StatesHistoryService";class lf extends ie{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ce.Get,this.Data=e}}class df{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=Ig.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class hf extends ie{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ce.Get}}class pf extends ie{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=ce.Get,this.Data=e}}class gf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(af=ef||(ef={}))[af.User=0]="User",af[af.Controller=1]="Controller",af[af.Marketing=2]="Marketing",(of=tf||(tf={}))[of.Notification=0]="Notification",of[of.Message=1]="Message",of[of.Alarm=2]="Alarm",of[of.Warning=3]="Warning",of[of.Info=4]="Info",(sf=nf||(nf={}))[sf.Other=0]="Other",sf[sf.UserLoggedIn=1]="UserLoggedIn",sf[sf.UserLoggedOut=2]="UserLoggedOut",sf[sf.FoundNewDevice=3]="FoundNewDevice",sf[sf.DoorBellPress=4]="DoorBellPress",sf[sf.AddedNewDevice=5]="AddedNewDevice",sf[sf.RemovedDevice=6]="RemovedDevice",sf[sf.RegisteredNewUser=7]="RegisteredNewUser",sf[sf.GotAccessToTheInternet=8]="GotAccessToTheInternet",sf[sf.LostAccessToTheInternet=9]="LostAccessToTheInternet",sf[sf.RemovedUser=10]="RemovedUser",sf[sf.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(rf||(rf={}));var ff=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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._chatSubscriptions=[],this._connection=ev.Get(Gt.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==tf.Message)return;const n=new mf;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(rf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return ff(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new yf,12e3,!1);if(null==e)return new Te(Nf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ae.OK)return new Te(Nf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Te(Nf.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==tf.Message)return;const n=new mf;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(rf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new Te(Nf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return ff(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new wf(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return ev.Get(r.ServiceName).Error(xf.ServiceName,`Cannot send message! ${e}`),ae.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class mf{constructor(){this._sender=ef.Controller,this._messageType=tf.Info,this._messageSource=nf.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 yf extends ie{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ce.Get}}class wf extends ie{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ce.Put,this.Data=e}}var Sf,_f,Af,Cf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Tf{constructor(){this._chatSubscriptions=[],this._connection=ev.Get(Gt.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==tf.Message){const e=new Df;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 Cf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new kf,12e3,!1);if(null==e)return new Te(Nf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ae.OK)return new Te(Nf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Te(Nf.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==tf.Message){const n=new Df;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 Te(Nf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return Cf(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Gf(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return ev.Get(r.ServiceName).Error(xf.ServiceName,`Cannot send message! ${e}`),ae.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class Df{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 Gf extends ie{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ce.Put,this.Data=e}}class kf extends ie{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ce.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(Sf||(Sf={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(_f||(_f={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(Af||(Af={}));var bf,Nf,Ef,If=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Rf{constructor(){this._chatSubscriptions=[],this._connection=ev.Get(Gt.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new Mf;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=Sf[e],s=new Map;for(let[e,t]of Object.entries(r))s.set(e,t);n.ControllerActivities.set(t,s)}if(null!=t.Errors)for(let[e,r]of Object.entries(t.Errors))n.Errors.set(Af[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return If(this,void 0,void 0,(function*(){return(yield ev.Get(Xp.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return If(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Of,8e3,!1);return null==e||null==e.Status?new Te(Nf.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ae.OK?new Te(Nf.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Te(Nf.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Te(Nf.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return If(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Uf(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return ev.Get(r.ServiceName).Error(xf.ServiceName,`Cannot set chat configuration! ${e}`),ae.FatalError}}))}SendMessageAsync(e){return If(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Pf(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return ev.Get(r.ServiceName).Error(xf.ServiceName,`Cannot send message! ${e}`),ae.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 Pf extends ie{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=ce.Put,this.Data=e}}class Of extends ie{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ce.Get}}class Uf extends ie{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ce.Put,this.Data=e}}class Mf{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"}(bf||(bf={}));class xf{constructor(){this._services={ControllerChat:new vf,GptChat:new Rf,FamillyChat:new Tf}}GetServiceName(){return xf.ServiceName}GetChatImplementation(e){switch(e){case bf.ControllerChat:return this._services.ControllerChat;case bf.FamilyChat:return this._services.FamillyChat;case bf.GptChat:return this._services.GptChat;default:throw new Ff(`Chat with type ${e} not implemented!`)}}}xf.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(Nf||(Nf={}));class Ff 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"}(Ef||(Ef={}));var Lf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Bf{constructor(){this._connection=ev.Get(Gt.ServiceName),this._log=ev.Get(r.ServiceName)}GetServiceName(){return Bf.ServiceName}IsSupportedAsync(){return Lf(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new $f,2e3,!0);return this._log.Debug(Bf.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ae.WrongData}))}GetConnectedAppsAsync(){return Lf(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Wf,2e3,!0);return(null==e?void 0:e.Status)===ae.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Lf(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Hf(e),2e3,!1);switch(null==t?void 0:t.Status){case ae.OK:return new Te(Ef.Changed,"");case ae.WrongData:switch(t.Data){case"AccessTokenToShort":return new Te(Ef.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Te(Ef.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Te(Ef.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Te(Ef.AppNameToShort,t.Data);case"AppUrlToShort":return new Te(Ef.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Te(Ef.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Te(Ef.AppUserNameToShort,t.Data);default:return new Te(Ef.UnkownError,t.Data)}case ae.ResourceDoesNotExists:case ae.ResourceIsNotAvailable:return new Te(Ef.ResourceIsNotAvailable,t.Data);default:return new Te(Ef.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Lf(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new qf(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}Bf.ServiceName="ConnectedAppsService";class $f extends ie{constructor(){super(),this.Resource="/applications/app/auth",this.Method=ce.Put,this.Data=""}}class Wf extends ie{constructor(){super(),this.Resource="/applications/get",this.Method=ce.Get}}class qf extends ie{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=ce.Delete,this.Data=e}}class Hf extends ie{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=ce.Put,this.Data=e}}var Vf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 jf{constructor(){try{void 0!==navigator.exalusMigration&&(jf.exNativeMig=navigator.exalusMigration);const e=window.location.href,t=new URL(e),n=new URLSearchParams(t.search),r=n.get("mig_c_enc"),s=n.get("mig_controllers"),o=n.get("mig_lang");if(null!==r){const e=decodeURIComponent(this.b64DecodeUnicode(decodeURIComponent(r)));localStorage.setItem(jf.AppUserControllersKeyName,e)}null!==s&&localStorage.setItem(jf.AppUserControllersKeyName,decodeURIComponent(s)),null!==o&&localStorage.setItem(jf.AppSelectedLanguageKeyName,o)}catch(e){console.error(e)}}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 jf.ServiceName}IsMigrationDataAvailableAsync(){return Vf(this,void 0,void 0,(function*(){if(null!=window.webkit&&null!=window.webkit.messageHandlers){var e=yield jf.GetIosMigrationStatus();return null!==e&&e}if(this.IsExalusNativeMigrationAvailable()){let e=yield jf.exNativeMig.IsMigrationDataAvailableAsync();return null!=e&&e.DataMigrated}return null!==localStorage.getItem(jf.AppSelectedLanguageKeyName)||null!==localStorage.getItem(jf.AppUserControllersKeyName)}))}GetControllersDataAsync(){return Vf(this,void 0,void 0,(function*(){if(null!=window.webkit&&null!=window.webkit.messageHandlers)return yield jf.GetIosControllerList();{if(this.IsExalusNativeMigrationAvailable())return yield jf.exNativeMig.GetControllersDataAsync();let e=localStorage.getItem(jf.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}))}GetLanguageCodeAsync(){return Vf(this,void 0,void 0,(function*(){return null!=window.webkit&&null!=window.webkit.messageHandlers?yield jf.GetIosDefaultLanguage():this.IsExalusNativeMigrationAvailable()?yield jf.exNativeMig.GetLanguageCodeAsync():localStorage.getItem(jf.AppSelectedLanguageKeyName)}))}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)}}))}}jf.AppSelectedLanguageKeyName="App___SelectedLanguage",jf.AppUserControllersKeyName="App___UserControllersListDatabase",jf.ServiceName="DataMigrationService";var Kf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 zf{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=ev.Get(Gt.ServiceName),this._logger=ev.Get(r.ServiceName),this._storage=ev.Get(o.ServiceName),ev.Get(je.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Kf(this,void 0,void 0,(function*(){var e;try{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(zf.ServiceName,"LocalIpAddress",this._localIpAddress);const n=this.GetControllerHostName(this._connection.GetControllerSerialNumber());this._logger.Debug(`Looking for controller in local network with host name: ${n}`);let r=null;this.isIos()?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(zf.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(zf.ServiceName,"Controller not found in local network."))}else this._logger.Error(zf.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(zf.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return Kf(this,void 0,void 0,(function*(){if(this.isIos()){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(zf.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){var e;return Kf(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Jf,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(zf.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return zf.ServiceName}isIos(){return null!=window.webkit&&null!=window.webkit.messageHandlers}getIosControllerIpAsync(e,t=2e4){let n;return new Promise(((r,s)=>{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("")}}))}}zf.ServiceName="FindControllerService";class Jf extends ie{constructor(){super(),this.Resource="/network/lan/",this.Method=ce.Get}}var Yf=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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 Xf{constructor(){this._errorOccuredEvent=new n,this._connectionStateChangedEvent=new n,this._dataReceivedEvent=new n,this._onMessageReceived=new n,this._log=ev.Get(r.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._logPackets=!1,this.sockets=null,this._address=null,this._port="81",this._isOpen=!1,this._pin=null,this._serial=null,this._auth=null,this._initialized=!1}Initialize(){this._initialized||(this._initialized=!0,this._controllerConfiguration=ev.Get(Xe.ServiceName),this._cache=ev.Get(Ge.ServiceName),this._session=ev.Get(je.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return Yf(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}`}))}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}SetServersBrokerAddress(e){throw new Error("Method not implemented.")}SetDefaultPacketsBrokerAddress(e){throw new Error("Method not implemented.")}GetServerAddressAsync(){return ev.IsRunningFromLocalNetwork()&&(this._address=`${window.location.hostname}:${this._port}`),Promise.resolve(this._address)}ConnectAsync(e){var t;return this.Initialize(),null===(t=this.sockets)||void 0===t||t.close(),this.sockets=new WebSocket(`ws://${e}/api`),this._log.Debug(Xf.ServiceName,`Connecting to the WebSockets server ${e}`),this.sockets.onerror=t=>{this._log.Debug(Xf.ServiceName,`Error occured in the WebSockets server ${e}: ${t}`),this._errorOccuredEvent.Invoke(["WebSockets",t.toString()])},this.sockets.onopen=t=>{this._log.Debug(Xf.ServiceName,`Connected to the WebSockets server ${e}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(de.Connected)},this.sockets.onclose=t=>{this._log.Debug(Xf.ServiceName,`Disconnected from the WebSockets server ${e}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(de.Disconnected)},this.sockets.onmessage=t=>{this._log.Debug(Xf.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);let n=JSON.parse(t.data);this._log.Debug(Xf.ServiceName,`Received data frame: ${n.Status}`),this._dataReceivedEvent.Invoke(n)},this._connectionStateChangedEvent.Invoke(de.Connecting),Promise.resolve(le.Connected)}AuthorizeAsync(e){return Yf(this,void 0,void 0,(function*(){return!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Xf.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,!0)}))}ConnectAndAuthorizeAsync(e){return Yf(this,void 0,void 0,(function*(){if(this._log.Debug(Xf.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`),!(yield this.AuthorizeAsync(e)))return le.AuthorizationFailed;let t=yield this.GetServerAddressAsync();return null==t?le.FailedToConnectToServer:yield this.ConnectAsync(t)}))}DisconnectAsync(){var e;return this._log.Debug(Xf.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._connectionStateChangedEvent.Invoke(de.Disconnecting),null===(e=this.sockets)||void 0===e||e.close(),Promise.resolve()}IsConnected(){return this._isOpen}EnablePacketsLogging(){this._log.Debug(Xf.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Xf.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Xf.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.sockets)||void 0===n||n.send(r):this._log.Error(Xf.ServiceName,`Failed to send data frame: ${r}`),Promise.resolve(this._isOpen)}SendAsync(e){return this._isOpen&&this.SendData(e,this._logPackets),Promise.resolve(this._isOpen)}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,r)}SendAndHandleResponseAsync(e,t,n,r){var s;return Yf(this,void 0,void 0,(function*(){let o=0;const i=Date.now();if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(s=this._session)||void 0===s?void 0:s.WaitForSessionCreationAsync()),new Promise(((s,a)=>Yf(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(Xf.ServiceName,t),a(new Error(t))}),t);let u=l=>Yf(this,void 0,void 0,(function*(){var d,h,p;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(o);const g=Date.now()-i;switch((r||!0===window.packets)&&this._log.Debug(Xf.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)===ae.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(),s(yield this.SendAndHandleResponseAsync(e,t,n,r))),null==l?void 0:l.Status){case ae.MultiDataResponseStart:case ae.MultiDataResponse:n(l),o=c();break;case ae.MultiDataResponseStop:n(l),this._dataReceivedEvent.Unsubscribe(u),s();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),o=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,r=!0,s=!0){var o,i,a;return Yf(this,void 0,void 0,(function*(){if(e.Method===ce.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.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(((o,i)=>Yf(this,void 0,void 0,(function*(){let a=i=>Yf(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;s&&this._log.Debug(Xf.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===ce.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ae.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(),o(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,s))),o(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(Xf.ServiceName,t),i(new Error(t))}),t),!this.SendData(e,s)){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 Xf.ServiceName}}Xf.ServiceName="ExalusConnectionService";class Qf{constructor(){var e,t;this.OnEnteredPictureInPicture=new Ae,this.OnExitedPictureInPicture=new Ae,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 Qf.ServiceName}}Qf.ServiceName="PictureInPictureService";class Zf{GetServiceName(){return Zf.ServiceName}GetSupportedDevicesAsync(){return e=this,t=void 0,r=function*(){let e=yield fetch("https://updates.tr7.pl/supportedDevices/pl-PL.json",{method:"GET"});if(e.ok)return JSON.parse(yield e.text());throw new Error("Failed to download supported devices list!")},new((n=void 0)||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(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}}Zf.ServiceName="SupportedDevicesService",Gc(Map),Gc(Set),(()=>{var e;const t=String.prototype,n=Object.getOwnPropertyNames(xo.prototype);for(const r of n)t[r]=null!==(e=t[r])&&void 0!==e?e:xo.prototype[r];t.first=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}throw new Po(Ro.NoMatch)}if(0===this.length)throw new Po(Ro.NoElements);return this[0]},t.firstOrDefault=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[0]},t.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},t.elementAt=function(e){if(e<0||e>=this.length)throw new Io("index");return this[e]},t.elementAtOrDefault=function(e){return this[e]||null},t.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new Po(Ro.NoMatch)}if(0===this.length)throw new Po(Ro.NoElements);return this[this.length-1]},t.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},t.reverse=function(){const e=this;return new xo((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),_p(Array),_p(Int8Array),_p(Int16Array),_p(Int32Array),_p(Uint8Array),_p(Uint8ClampedArray),_p(Uint16Array),_p(Uint32Array),_p(Float32Array),_p(Float64Array);class ev{static Init(){if(s.IsInitialized)return;let e=s.Instance;try{e.RegisterService(new jf),e.RegisterService(new o),e.RegisterService(new jp),e.RegisterService(new Ge),e.RegisterService(new je),e.RegisterService(new Qf),ev.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Xf)):e.RegisterService(new Gt),e.RegisterService(new rs),e.RegisterService(new Zf),e.RegisterService(new rs),e.RegisterService(new bs),e.RegisterService(new Xe),e.RegisterService(new zf),e.RegisterService(new Zr),e.RegisterService(new Xp),e.RegisterService(new be),e.RegisterService(new Fe),e.RegisterService(new ho),e.RegisterService(new kp),e.RegisterService(new fg),e.RegisterService(new Ug),e.RegisterService(new Bf),e.RegisterService(new uf),e.RegisterService(new Zs),e.RegisterService(new xf)}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 s.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return s.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return s.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}}ev.WorksInContextOf="",ev.Version=1})();
|
|
2
2
|
//# sourceMappingURL=exalushome-library-bundle.js.map
|